@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=M+PLUS+1p:wght@400;500;700;800&display=swap');

/*!
Theme Name: Cocoon Child
Description: Cocoon専用の子テーマ
Theme URI: https://wp-cocoon.com/
Author: わいひら
Author URI: https://nelog.jp/
Template:   cocoon-master
Version:    1.1.3
*/

/************************************
** 子テーマ用のスタイルを書く
************************************/
/*必要ならばここにコードを書く*/
.alignC{ text-align:center !important; }
.alignL{ text-align:left !important; }
.alignR{ text-align:right !important; }
.valignM{ vertical-align: middle; }
.floatC{ clear:both !important; }
.floatL{ float:left !important; }
.floatR{ float:right !important; }
.noDisp{ display: none; }
.noWrap{ white-space: nowrap; }
.borderSolid{ border: 1px solid #ccc; }
.borderBlue{ border-bottom: 2px solid #0060a5 !important; }
.borderNone{ border: none !important; }
.borderRadius{ border-radius: 15px; }
.borderSolidBlue{ border: 2px solid #bcd5ff; }
.marginC{ margin: 0 auto; }
.mTop0em{ margin-top: 0em; }
.mTop1em{ margin-top: 1em; }
.mTop2em{ margin-top: 2em; }
.mTop3em{ margin-top: 3em; }
.mLeft2em{ margin-left: 2em; }
.mBottom{ margin-bottom: 0em !important; }
.padB5{ padding-bottom: 5px; }
.padB10{ padding-bottom: 10px; }
.pPageEnd{ padding-top: 4em; }
.posRelate{ position: relative; }
.bgTrans{
	background-color: transparent !important;
	background: none !important;
}
.bgWhite{ background-color: #fff; }
.fontWhite{ color: #fff; }
.font12{ font-size: 12px; }
.font14{ font-size: 14px; }
.font18{ font-size: 18px; }
.font20{ font-size: 20px; }
.font22{ font-size: 22px; }
.font24{ font-size: 24px; }
.opacity5{ opacity: 0.5; }
.grecaptcha-badge { visibility: hidden; }
.h100vh{ height: 100vh; }
.mCenter{
	display: flex;
	align-items: center;
	justify-content: center;
}
.mAuto{
	display: flex;
	flex-direction: column;
    flex-grow: 1;
}
.ListTable table, .ListTable th, .ListTable td, .ListTable tr{
	border: 1px solid #ccc;
	font-size: 16px;
}
.ListTable th{
	white-space: nowrap;
	background-color: #f5f5f5;
}
.ListTable td{
	background-color: #fff;
}
.content .fullCover{
	width: auto;
	background: linear-gradient(0deg, rgba(255, 255, 255, 0.3) 0%, #cce5ff 15%, #cce5ff 85%, rgba(255, 255, 255, 0.3) 100%);
	margin-top: 0px;
    margin-bottom: 0px;
	border-radius: 15px;
}
.content .floatNumber1, .content .floatNumber2, .content .floatNumber3, .content .floatCrown{
	padding-left: 50px;
}
.content .floatNumber1:before, .content .floatNumber2:before, .content .floatNumber3:before, .content .floatCrown:before{
	font-size: 72px;
	left: 0px;
    top: -35px;
    position: absolute;
    opacity: 0.3;
    font-weight: bolder;
    color: #004085;
	padding-right: 15px;
}
.content .floatNumber1:before{
	font-style: italic;
	content: '1';
}
.content .floatNumber2:before{
	font-style: italic;
	content: '2';
}
.content .floatNumber3:before{
	font-style: italic;
	content: '3';
}
.content .floatCrown:before{
	font-family: "Font Awesome 5 Free";
	content: '\f521';
	font-size: 60px;
    position: absolute;
    opacity: 0.2;
    top: -28px;
}
#navi .navi-in a:hover{
	color: #666;
}
html, body, .container{
	height: 100%;
/*	background-color: rgba(30,115,190,1);*/
}
body.public-page{
	background-color:rgba(255,255,255,0.7);
	background-blend-mode:lighten;
	background-size: cover;
}
.content h1{
	font-size: calc(1.25vw + 1.5rem);
	text-align:center;
}
.content h2{
	font-size: 32px !important;
	background-color: rgba(255,255,255,0.7);
	margin-bottom: 1em !important;
}
.content h3{
	font-size: 28px !important;
	background-color: rgba(255,255,255,0.4);
	margin-bottom: 1em !important;
}
.content h4{
	font-size: 24px !important;
	background-color: rgba(255,255,255,0.4);
	margin-bottom: 1em !important;
}
.content h5{
	font-size: 20px !important;
	margin-bottom: 1em !important;
}
.content h6{
	font-size: 16px !important;
}
.content .widget-entry-cards.large-thumb-on .card-content{
	background: linear-gradient(180deg, rgba(255,255,255,0.1) 0%,  rgba(0,0,0,0.4) 20%,  rgba(0,0,0,0.9) 100%);
}
.wp-block-gallery.has-nested-images figure.wp-block-image figcaption{
	font-size: 16px;
background: #888;
    opacity: 0.8;
    padding: 0 6px;
}
.videoGallery{
	width: 320px !important;
}
.videoGallery video{
	border-radius: 10px;
	border: 2px solid #ccc;
	width: 320px !important;
	aspect-ratio: unset !important;
}
.videoGallery .wp-element-caption{
	font-size: 16px !important;	
	text-align: center;
}
#footer{
/*	position: fixed;
	bottom: 0;*/
	position: sticky;
    top: 100vh;
	width: 100%;
	background: linear-gradient(0deg, rgba(30,115,190,1) 0%, rgba(30,115,190,1) 80%,  rgba(255,255,255,0.4) 100%) !important;
}
.navi-footer-in{
	margin-bottom: 20px;
}
.navi-footer-in .menu-footer{
	display: flex;
    align-items: center;
    justify-content: center;
}
.main{
    background-color: transparent !important;
	padding-top: 0px;
}
.header-container .navi{
    background-color: #1e73be;
}
.header-container, .header-container .wrap .navi{
	background: linear-gradient(180deg, rgba(30,115,190,1) 0%, rgba(30,115,190,1) 80%,  rgba(255,255,255,0.4) 100%) !important;
}
.mobile-menu-buttons a, .mobile-menu-buttons label{
	color: #004085 !important;
}
.wp-block-gallery.has-nested-images figure.wp-block-image {
    max-width: 320px !important;
    max-height: 320px !important;
}
.blogcard .blogcard-content{
	display: inline-block;
	margin-left: 0px;
}
.blogcard .blogcard-site{
	display: none;
}
.imgImportant{
	width: 30px;
	height: 18px;
	border: none !important;
}
.imgThumb img{
	width: 260px;
	height: 164px;
	object-fit: cover;
}
.mwBtn{
    font-family: "M PLUS 1p", sans-serif;
    font-weight: 500;
	font-size: 16px;
}
.wp-block-cocoon-blocks-column-3 .blogcard-title, .wp-block-cocoon-blocks-column-3 .blogcard-snippet{
	font-size: 90%;
}
.wpcf7-response-output{
	font-size: 24px;
    color: #004085;
	border-color: #004085 !important;
	background-color: rgba(255, 255, 255, 0.7);
}
.wpcf7 form.invalid .wpcf7-response-output{
	border-color: #a00 !important;
    color: #a00 !important;
}
blockquote::before, blockquote::after {
	display: none;
}
.slideShowPC{
	display: block;
}
.slideShowMobile{
	display: none;
}
.slideShowPC img, .slideShowMobile img{
	width: 100% !important;
}
.tagline{
    text-align: left !important;
    margin: 0 auto !important;
    color: #ddd !important;
    display: inline-block;
    width: 600px !important;
    line-height: 1.1em !important;
    text-indent: 1em !important;
	padding-bottom: 3em !important;
}
.instagram-media {
  margin-left: auto !important;
  margin-right: auto !important;
}
.flexslider img{
	border-radius: 15px;
}
.boardTrans{
	background-color: #cce5ffb0;
}
.sidebar{
	background: transparent;
}
.sns-buttons a{
	width: 50px !important;
	background: transparent !important;
}
.sns-buttons a img{
	width: 40px !important;
}
.navi-footer-in a:hover{
	color: #666 !important;
}
.wp-block-gallery.has-nested-images figure.wp-block-image:has(figcaption):before{
	backdrop-filter: none;
}
.sns-follow-buttons{
	margin-bottom: 1.5em;
}
.lineCoupon{
	background: #7cfc00a0;
    border: 1px solid lightgreen;
    border-radius: 1em;
    padding-left: 1em;
    padding-right: 1em;
	font-size: 15px;
	width: fit-content;
    margin: 0 auto;
}
/************************************
** レスポンシブデザイン用のメディアクエリ
************************************/
/*1023px以下*/
@media screen and (max-width: 1023px){
	/*必要ならばここにコードを書く*/
	body.public-page{
		background-size: 1024px;
	}
	footer {
		/*display: none !important;*/
	}
	.copyright {
		margin-bottom: 50px;
	}
	.slideShowPC{
		display: block;
	}
	.slideShowMobile{
		display: none;
	}
}

/*834px以下*/
@media screen and (max-width: 834px){
	/*必要ならばここにコードを書く*/
	.blogcard .blogcard-content {
	    display: inherit;
    	margin-left: inherit;
	}
	.wp-block-cocoon-blocks-column-3 .blogcard-title, .wp-block-cocoon-blocks-column-3 .blogcard-snippet{
		font-size: inherit;
	}
	.slideShowPC{
		display: block;
	}
	.slideShowMobile{
		display: none;
	}
	.tagline{
		display: none !important;
	}
	.sns-follow-buttons a {
		width: 40px;
	}
}

/*480px以下*/
@media screen and (max-width: 480px){
	/*必要ならばここにコードを書く*/
	.slideShowPC{
		display: none;
	}
	.slideShowMobile{
		display: block;
	}
	.tagline{
		display: none !important;
	}
}