@charset "utf-8";
 @import url(reset.css);
/* common
------------------------------------------------------------*/

body {
    -webkit-text-size-adjust: 100%;
}

@media screen and (min-width:860px) {
body {
    font-size: 110%;
}
}
/* clearfix */
.clearfix:after {
    content: ".";
    display: block;
    height: 0;
    visibility: hidden;
    clear: both;
}

.pcDetail{display:block !important;}
.pctbDetail{display:block !important;}
.tbDetail{display:none !important;}
.spDetail{display:none !important;}

@media screen and (max-width:767px) {
	.pcDetail{display:none !important;}
	.pctbDetail{display:none !important;}
	.tbDetail{display:none !important;}
	.spDetail{display:block !important;}
}

@media screen and (max-width:999px) and (min-width:768px){
	.pcDetail{display:none !important;}
	.pctbDetail{display:block !important;}
	.tbDetail{display:block !important;}
	.spDetail{display:none !important;}
}



/* =========================================================
	SP
========================================================= */

img {
    max-width : 100%;
    height : auto;
    vertical-align: bottom;
}

@media screen and (min-width:860px) {
#page {
    overflow: hidden;
    margin: 0 auto;
    width: 100%;
    background: url(../../img/bg-flow2.png) no-repeat center top;
    background-size: cover;
    background-attachment: fixed;
}
}
/* header
------------------------------------------------------------*/

#head {
    height: auto;
    background: url(../../img/header_bg.jpg) no-repeat center bottom;
    background-size: cover;
}

@media screen and (min-width:860px) {
#head {
    height: 650px;
    background: url(../../img/pc_bg.jpg) no-repeat center bottom;
    background-size: cover;
}
}
.hd-wp {
    position: relative;
    margin: 0 auto;
    width: 100%;
    height: 100%;
    padding-bottom: 230px;
}
.hd-wp ul {
    width: 100%;
}
.hd-wp li {
    display: inline-block;
    vertical-align: middle;
}
.hd-wp li.tfm {
    position: relative;
    max-width: 140px;
    width: 30%;
    height: auto;
    margin-top:1em;
    margin-left: 8px;
    margin-right: 5px;
    z-index: 1111;
}
.hd-wp li.spn {
    position: relative;
    max-width: 100px;
    width: 15%;
    padding-top: 10px;
    margin-right: 5px;
    z-index: 2222;
}

.hd-wp li.bnr-hml {
    position: relative;
    max-width: 90px;
    width: 17%;
    padding-top: 10px;
    z-index: 2222;
}


.hd-wp h1 {
    position: relative;
    text-align: center;
    position: relative;
    margin-top: 20px;
    z-index: 1;
}
.hd-wp h1 img {
    width: 75%;
    max-width: 537px;
}
.bt-entry {
    position: absolute;
    right: 0;
    top: 0;
    text-align: right;
    width: 30%;
    z-index: 4444;
}
.bt-entry img {
    width: 100%;
    max-width: 212px;
}
.mc {
    position: absolute;
    bottom: 0;
    width: 40%;
}
.mc img {
    width: 100%;
    max-width: 268px;
}
.desc {
    position: absolute;
    width: 40%;
}
.desc img {
    width: 100%;
    max-width: 268px;
}

.flower-left {
    position: absolute;
    bottom:-15px;
    left:0px;
    width:150px;
}

.flower-right {
    position: absolute;
    bottom:5px;
    right:0px;
    width:100px;
}

.flower-left img,
.flower-right img{
    width:100%;
}


@media screen and (min-width:860px) {
.hd-wp {
    padding: 0 0 30px 10px;
}
.hd-wp h1 {
    text-align: center;
    position: relative;
    margin:0;
}

.flower-left {
    position: absolute;
    bottom:-15px;
    left:0px;
    width:300px;
}

.flower-right {
    position: absolute;
    bottom:-15px;
    right:0px;
    width:220px;
}


}
/* wrapper
------------------------------------------------------------*/

.le-ad {
    position: relative;
    padding: 20px;
    text-align: left;
    font-size: 90%;
    line-height: 1.8em;
}



.close {
    text-align: center;
}

@media screen and (min-width:860px) {
.le-ad-wrap {
    background: #FFF;
    border-top: 1px dashed #cccccc;
    border-bottom: 1px dashed #cccccc;
}
.le-ad {
    padding: 30px 15px;
    font-size: 90%;
    line-height: 1.8em;
    max-width: 800px;
    margin: 0 auto 0;
}
}
.co-wp {
    width: 100%;
    margin: 0 auto;
    background: #fff;
}
.co-wp.bg {
    background: url(../../img/flower_bg01.svg) no-repeat -20% -30px;
    background-size: 60%;
}
.co-wp .img-pre img, .ai-wp .img-pre img, .event-wp .img-pre img {
    width: 100%;
    max-width: 350px;
}

.co-wp .img-pre ul{
	display: flex;
	background: #dbe4eb;
}

.co-wp .img-pre ul li{
    width: 50%;
    text-align: center;
    background: #eeeeee;
}

.co-wp .img-pre ul li:last-child{
    background: #d3e2e9;
}


.co-wp .img-pre span {
    display: block;
    text-align: right;
    font-size: 70%;
    padding-top: 5px;
    padding-right: 5px;
}

.co-wp h2 {
    background-color: #fce3e3;
    text-align: center;
    padding:0.5em 0;
}

.co-wp h2 span {
    position: relative;
    display: block;
    margin:auto;
    width:70%;
    max-width:500px;
    height:auto;
}

.co-wp h2 span img{
    width:100%;
    height:auto;
}

.co-wp h2 span em{
    position: absolute;
    top:-20px;
    left:-60px;
    width:110px;
    height:auto;
}

.co-wp h3 {
    padding: 8em 0 0 0;
    color: #e94646;
    font-weight: bold;
    text-align: center;
    line-height: 1em;
    font-size: 120%;
}
.co-wp h3 span, .co-wp h3 time {
    display: block;
    font-size: 90%;
    font-weight: normal;
}
.co-wp h3 span {
    padding: 0 0 5px 0;
    font-weight: bold;
}
.co-wp h3 time {
    padding: 8px 0 0 0;
}
.co-wp p {
    max-width: 800px;
    padding: 20px 20px 20px 20px;
    text-align: left;
    font-size: 90%;
    line-height: 1.8em;
    color: #e94646;
}
.co-wp p a:link,.co-wp p a:visited{
   color: #e94646;
}

.co-wp .txt {
    box-sizing: border-box;
    width: 90%;
    max-width: 800px;
    margin: 0 auto;
    padding: 50px 20px 40px 20px;
    text-align: left;
    font-size: 95%;
    line-height: 1.8em;
    color: #000;
}
.co-wp .txt img {
    width: 240px;
    height: auto;
    float: left;
    margin: 0 20px 0  0;
}

.co-wp .txt a:link,
.co-wp .txt a:visited{
	text-decoration: underline;
	color: #000;
}	

@media screen and (min-width:860px) {

.co-wp h2 span em{
    position: absolute;
    top: -30px;
    left: -80px;
    width:150px;
    height:auto;
}

.co-wp h3 {
    font-size: 130%;
    padding: 50px 0 0 0;
}
.co-wp p {
    line-height: 1.8em;
    margin: 0 auto;
}
.co-wp .txt {
    font-size: 90%;
    padding: 50px 0 0 0;
}

.co-wp .txt img {
    width: 280px;
    height: auto;
    float: left;
    margin: 0 20px 0 0;
}
}

@media screen and (max-width:480px) {
.co-wp .txt img {
    width:90%;
    height: auto;
    display: block;
    float: none;
    margin: 0 auto;
}
}
.co-wp .btn {
    clear: both;
    color: #fff;
    display: block;
    margin: 5px auto;
    width: 90%;
    max-width: 800px;
    height: 50px;
    text-align: center;
    line-height: 50px;
    font-weight: bold;
    text-decoration: none;
    position: relative;
    font-weight: normal;
    background: #e94646;
}
.co-wp .btn span {
    position: absolute;
    top: 50%;
    right: 15px;
    padding-right: 20px;
}
.co-wp .btn span::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    width: 7px;
    height: 7px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg);
    margin-top: -5px;
}
.prog {
    padding: 0 0 100px 0;
    background: url(../../img/flower_bg03.svg) no-repeat -20% bottom;
    background-size: 40%;
    text-align: center;
}
.co-wp .prog .progbg {
    width: 90%;
    max-width: 800px;
    margin: 50px auto 30px;
    background: url(../../img/guest_bg.png) ;
}
.co-wp .prog .progbg_inner {
    position:relative;
    padding: 50px 0;
    background: url(../../img/guest_line.png) repeat-x bottom center,
    url(../../img/guest_line.png) repeat-x top center;
}

.co-wp .prog .progbg_inner .flower-middle{
    position:absolute;
    top:-50px;
    right:0;
    width:30%;
}

.co-wp .prog .progbg_inner .prog-guest {
    position: relative;
    display:block;
    width:65%;
    margin:0 auto 4em;
    color: #000;
}

.co-wp .prog .progbg_inner .prog-guest:nth-child(3) {
    margin:0 auto 0;
}

.co-wp .prog .prog-guest .guest-badge{
    width:50px;
    height:auto;
    position: absolute;
    top:-20px;
    left:-20px;
}

.co-wp .prog .prog-guest .guest-badge img{
    width:100%;
}

.co-wp .prog .prog-guest img {
    margin-bottom:5px;
}

.co-wp .prog .prog-guest span{
    font-size:20px;
    font-weight:bold;
    color:#e94646;
}


@media screen and (min-width:1000px) {
    .co-wp .prog .progbg_inner {
        box-sizing: border-box;
        padding: 7em 3em 3em;
        width:100%;
    }
    .co-wp.bg {
        background: #fff url(../../img/flower_bg01.svg) no-repeat -10% -35px;
        background-size: 30%;
    }
    .prog {
        background: url(../../img/flower_bg03.svg) no-repeat 5% bottom;
        background-size: 25% auto;
    }
    .co-wp .prog .progbg_inner .flower-middle{
        position:absolute;
        top:-100px;
        right:-20px;
        width:25%;
    }

    .co-wp .prog .progbg_inner .prog-guest {
        position: relative;
        display:block;
        float:left;
        width:calc(92%/3);
        margin:0 4% 0 0;
    }

    .co-wp .prog .progbg_inner .prog-guest:nth-child(3) {
        margin:0;
    }

    .co-wp .prog .prog-guest .guest-badge{
        width:60px;
        height:auto;
        position: absolute;
        top:-30px;
        left:-15px;
    }
}

@media screen and (max-width:480px) {
.prog {
    padding: 0 0 50px 0;
}
.co-wp .prog .progbg {
    margin: 0 auto 20px;
}

.co-wp .prog dl dt {
    width:45%;
}

.co-wp .prog dl dt .guest-badge{
    width:40px;
    top:-15px;
    left:-15px;
}

.co-wp .prog dl dt img {
    margin-bottom:5px;
}

.co-wp .prog dl dt span{
    font-size:16px;
}


.co-wp .prog dl dd {
    font-size:12px;
}

}

.co-wp .message-word {
    display: block;
    width: 90%;
    margin: 0 auto;
    clear: both;
    color: #e94646;
}

.co-wp .message-word h5{
    display:block;
    font-size: 16px;
    font-weight: bold;
	line-height: 1.4em;
    margin-bottom: 1em;
}

.co-wp .message-word em{
    display:block;
    font-size: 13px;
    margin-bottom: 1em;
}

.co-wp .message-word span{
    display:block;
    text-align: center;
    font-size: 16px;
    font-weight: bold;
	line-height: 1.4em;
    margin-bottom: 1em;
}

.co-wp i {
    display: block;
    width: 90%;
    margin: 0 auto;
    clear: both;
    color: #e94646;
    font-size: 90%;
	line-height: 1.4em;
    font-style: normal;
    font-weight: normal;
}

@media screen and (min-width:860px) {
.co-wp strong br, .co-wp i br {
    display: none;
}

.co-wp .message-word h5{
    display:block;
    font-size: 24px;
    font-weight: bold;
	line-height: 1.4em;
    margin-bottom: 1em;
}

.co-wp .message-word em{
    font-size: 14px;
}

.co-wp .message-word span{
    display:block;
    text-align: center;
    font-size: 20px;
    font-weight: bold;
	line-height: 1.4em;
    margin-bottom: 1em;
}
}

.event-wp {
    width: 100%;
    margin: 0 auto;
    background: url(../../img/bg-flow2.png) no-repeat center 0px;
    background-size: 100% auto;
}

@media screen and (min-width:860px) {
.event-wp {
    margin: 0 auto 50px;
    background: none;
}
}
.event-wp .img-pre span {
    display: block;
    text-align: right;
    font-size: 70%;
    padding-top: 5px;
    padding-right: 5px;
}

.event-wp h2 {
    background-color: #d2e2ca;
    padding:0.5em 0;
}

.event-wp h2 span {
    display:block;
    width:70%;
    max-width:500px;
    margin:auto;
}

.event-wp h2 span img {
    width:100%;
    height:auto;
}

.event-wp p {
    padding: 30px;
    text-align: left;
    font-size: 90%;
    line-height: 1.8em;
    color: #e94646;
}
.event-wp dl {
    font-size: 90%;
    width: 85%;
    max-width: 320px;
    margin: 30px auto;
    line-height: 1.8em;
}

@media screen and (min-width:860px) {
.event-wp p {
    padding: 30px 15px;
    font-size: 90%;
    line-height: 1.8em;
    width: 50%;
    margin: 0 auto;
    text-align: center;
}
.event-wp dl {
    display:table;
    font-size: 90%;
    width: 100%;
    max-width: 360px;
    margin: 50px auto;
    line-height: 1.8em;
}
}
.event-wp dl dt {
    display:table-cell;
    width:20%;
    max-width: 200px;
    margin-right: 5px;
}

.event-wp dl dd {
    display:table-cell;
}

.map a {
    background-color: #000;
    padding: 2px 10px;
    font-size: 80%;
    color: #FFF;
    text-decoration: none;
    margin-left: 10px;
}
.event-wp ul.btn {
    color: #FFF;
    display: flex;
    margin: 0 auto;
    width: 90%;
    max-width: 800px;
    height: 60px;
    text-align: center;
    line-height: 60px;
    background: #4c8c2b;
    font-weight: bold;
    text-decoration: none;
    position: relative;
    font-weight: normal;
}
.event-wp .btn li {
    width: 100%;
}

.event-wp .btn li a{
    display:block;
    color: #FFF;
    text-decoration: none;
}

.event-wp ul.btn:hover {
    opacity: 0.8;
}

.ai-wp {
    padding: 20px 0;
    border-bottom: 1px dashed #cccccc;
}

.summaryTbl{
    max-width: 800px;
    width:90%;
    margin: 20px auto;
    border-collapse: collapse;
    font-size:14px;
    line-height: 1.8;
}

.summaryTbl th{
   width:20%;
   padding: 5px;
   background-color: #fff;
   color: #333;
   text-align: left;
   vertical-align: top;
   font-weight:bold;
}

.summaryTbl td{
   width:80%;
   padding: 5px;
   background-color: #fff;
}

.bnr-hml{
    width:50%;
    max-width: 284px;
    margin:0 auto;
}

.bnr-hml img{
   width:100%;
}


@media screen and (max-width:480px) {
.ai-wp {
    padding: 10px 0;
}

.ai-wp h2 {
    text-align: center;
    padding: 15px 0;
    width: 50%;
    margin: 0 auto;
}
.ai-wp h3 {
    text-align: center;
    padding: 15px 0;
    width: 70%;
    margin: 0 auto;
}
.ai-wp dl {
    width: 80%;
    max-width: 320px;
    margin: 30px auto;
}

.summaryTbl{
    font-size:12px;
}

}

@media screen and (min-width:860px) {
.ai-wp dl {
    width: 100%;
    max-width: 400px;
    margin: 30px auto;
}
}


.ai-wp dl dt {
    font-weight: bold;
    margin-bottom: 10px;
}
.ai-wp dl dd {
    font-size: 75%;
    line-height: 1.4em;
}
.ai-wp .btn {
    color: #000;
    display: block;
    margin: 0 auto 20px;
    width: 65%;
    max-width: 800px;
    height: 50px;
    text-align: center;
    line-height: 50px;
    font-weight: bold;
    text-decoration: none;
    position: relative;
    font-weight: normal;
    border: 1px solid #000;
}
.ai-wp .btn span {
    position: absolute;
    top: 50%;
    right: 15px;
    padding-right: 20px;
}
.ai-wp .btn span::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    width: 7px;
    height: 7px;
    border-top: 2px solid #000;
    border-right: 2px solid #000;
    transform: rotate(45deg);
    margin-top: -5px;
}
.bn-spo {
    padding: 30px 30px 20px 30px;
    text-align: center;
}
.bn-spo img {
    width: 50%;
    max-width: 284px;
}
.copy {
    font-size: 65%;
    text-align: center;
    padding-bottom: 25px;
}
/*  footer
------------------------------------------------------------*/

.footer {
    background: url(../../img/bg-flow.png) no-repeat 0 top;
    background-size: 100% auto;
    text-align: center;
}
/* pagetop
 ------------------------------------------------------------*/

.go-top {
    margin: 15px auto 0;
    background: url(../../img/bt-top.png) no-repeat 0 top;
    background-size: 95px 52px;
    width: 95px;
    height: 52px;
    cursor: pointer;
}

@media screen and (min-width:860px) {
.go-top {
    margin: 15px auto 0;
    background: url(../../img/bt-top.png) no-repeat 0 top;
    background-size: 165px 90px;
    width: 165px;
    height: 90px;
    cursor: pointer;
}
}
