@charset "UTF-8";
/* CSS Document */

/*フォントファミリー指定*/

/* M PLUSラウンド1c
font-family: 'M PLUS Rounded 1c', sans-serif;
 */
/* はち　まる　pop
font-family: 'Hachi Maru Pop', cursive;
 */


/*サイト表示時にファードインさせるため、一時body非表示*/
body {
	display: none;
}
/* 一般共通設定 */
body,h1,h2,h3,h4,p,ul,ol,li,figure,figcaption,blokqute,dl,dd {
	padding: 0px;
	margin: 0px;
}
body {
	font-family: 'M PLUS Rounded 1c', sans-serif;
	width: 100%;
}
h1 {
	font-size: 32px;
}
h2 {
	font-size: 28px;
}
h3 {
	font-size: 24px;
}
p {
	font-size: 16px;
	text-align: left;
}
a {
	text-decoration: none;
	color: inherit;
	font-size: 16px;
}
a:hover {
	opacity: 0.5;
}
img {
	display: block;
}
li {
	list-style: none;
}
figcaption {
	font-size: 16px;
}
em {
	font-size: 20px;
	display: block;
}

/*jQueryga絡む設定   （ハンバーガーメニュー）
 ******************************************************/
a.trigger {
	display: none;
}
.trigger,
.trigger span {
	display: inline-block;
	transition: all 0.4s;
}
.trigger{
	position: fixed;
	top: 10px;
	right: 2%;
	width: 28px;
	height: 28px;
	z-index: 101;
	background-color: rgba(245,61,238,0.5);
}
.trigger span{
	position: absolute;
	left: 10%;
	width: 80%;
	height: 2px;
	background-color: #ffffff;
	border-radius: 2px;
	opacity: 1;
	z-index: 1001;
}
.trigger span:nth-of-type(1){
	top: 3px;
}
.trigger span:nth-of-type(2){
	top: 13px;
	width:60%
}
.trigger span:nth-of-type(3){
	bottom: 3px;
}
.trigger.active span:nth-of-type(1){
	transform: translateY(9px) rotate(-45deg);
}
.trigger.active span:nth-of-type(2){
	left: 50%;
	opacity: 0;
	animation: active-menu-bar02 0.8s forwards;
}
@keyframes active-menu-bar02{100%{height:0;}}

.trigger.active span:nth-of-type(3){
	transform: translateY(-11px)rotate(45deg);
}
		/**********************ここまで************************/
		/*jQueryni絡む設定   （slickによる画像スライド）*/
		.slider{
			margin: 80px auto;
			max-width: 800px;
		}
		.slide{
			position: relative;
		}
		.slide__content-wrap {
			color: #fff;
			text-align: center;
		}
		.slide img{
			height: auto;
			width: 100%;
			opacity: 0.8;
			filter: sepia(.7);
		}
		.slide__content-wrap{
			left: 35%;
			position: absolute;
			top: 15%;
		}
		.slide__content{
			display: block;
			opacity: 0;
			transform: translate(-100%,50%);
			transition: 0s;
		}
		.slide__content.on{
			opacity: 1;
			transform: translate(-100%,-40%);
			transition: .3s;
		}
		h2.slide__title{
			font-size: 3vw;
			width: 100%;
			text-align: center;
			text-shadow: 2px 2px 3px #909090;
		}
		.slide__text {
			width: 100%;
			text-align: center;
			text-shadow: 1px 1px 2px #909090;
		}
		@keyframes title-animation {
			0% {opacity: 0;}
			80%{opacity: 1}
			100%{opacity: 0;}
			}
		.slide__content.on .slide__title,
		.slide__content.on .slide__text {
			animation-name: title-animation;
			animation-duration: 3s;
		}
		   /**********************ここまで************************/

/* ナビゲーション設定 */
nav {
	display: flex;
	justify-content: space-between;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 100;
	width: 100%;
	padding-top: 10px;
	padding-left: 20px;
	padding-bottom: 10px;
}
.overlay_nav {
	background-color: #f53dee;
}
.nav_wrap {
	display: flex;
	justify-content: space-around;
	margin-right: 50px;
}
.nav_wrap li {
	padding: 10px 20px;
	text-align: center;
}
.nav_wrap li a {
		color: #fff;
}
nav img {
	width: 250px;
	height: auto;
	margin-left: 10px;
	margin-top: auto;
	margin-bottom: auto;
}
.nav-copylight {
	display: none;
}
/* フッター設定 */
footer {
	background-color: #f53dee;
	padding-top: 30px;
	padding-bottom: 20px;
}
footer > .head-contact > em {
	display: inline;
	color: #fff;
}
footer > .head-contact > em:last-child::after {
	content: url("../img/mail_icon.png");
	padding-left: 10px;
}
.copylight {
	font-size: 14px;
	padding-top: 50px;
	color: #fff;
	display: block;
	text-align: center;
}
/* サイト内共通 */
	.h-container {
		max-width: 1280px;
		text-align: center;
		color: #f53edd;
		text-shadow: 2px 2px 3px #909090;
		margin-bottom: 100px;
		margin-left: auto;
		margin-right: auto;
	}
	.flex-container {
		display: flex;
		justify-content: space-around;
		flex-wrap: wrap;
		max-width: 1280px;
		margin-left: auto;
		margin-right: auto;
	}
	.div30 {
		flex-basis: 35%;
		padding-left: 20px;
		padding-right: 20px;
	}
	.div70 {
		flex-basis: 65%;
		padding-left: 20px;
		padding-right: 20px;
		text-align: center;
	}
	.div30 img {
		width: 100%;
		padding: 10px;
	}
/*******************ここまで*/

/* ここから通常設定 */
/*index.html*/
header {
	background-image: url("../img/main-background.png");
	background-position: 0 55px;
	background-repeat: no-repeat;
	background-size: 100% 95%;
}
.main-header {
	display: flex;
	padding-top: 200px;
	color: #707070;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
}
.name-logo {
	border-top: 8px solid #f53dee;
	border-bottom: 8px solid #f53dee;
	border-radius: 50%;
	margin-left: 100px;
	padding: 5px 50px;
}
.name-logo h1,
.name-logo p {
	text-align: center;
}
.name-logo > h1 > span,
.div30 span {
	color: #f53dee;
}
.head-contact {
	width: 370px;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
	margin-top: 20px;
}
.name-logo p {
	width: 100%;
	display: flex;
}
.name-logo p::before,
.name-logo p::after {
	flex-grow: 1;
	content: "";
	border-bottom: 1px solid #707070;
	margin-bottom: 14px;
}
.name-logo p::before {
	margin-right: 10px;
}
.name-logo p::after {
	margin-left: 10px;
}
.h-container h2 p {
	font-size: 28px;
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
	font-family: 'Hachi Maru Pop', cursive;
}
.h-container h2 {
	font-family: 'Hachi Maru Pop', cursive;
}
.daikichi-text {
	padding-top: 30px;
	padding-left: 20px;
	padding-right: 20px;
}
.daikichi-text p {
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
	padding-top: 10px;
	color: #909090;
	text-shadow: none;
}
.h-container h3 {
	padding-bottom: 50px;
	font-family: 'Hachi Maru Pop', cursive;
}
.gallery-grid {
	display: grid;
	grid-template: 
		"gal-1 gal-2 gal-3" auto
		"gal-1 gal-5 gal-3" auto
		"gal-4 gal-5 gal-6" auto / auto auto auto;
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
	gap: 5px;
}
.gallery1 {
	grid-area: gal-1;
}
.gallery2 {
	grid-area: gal-2;
}
.gallery3 {
	grid-area: gal-3;
}
.gallery4 {
	grid-area: gal-4;
}
.gallery5 {
	grid-area: gal-5;
}
.gallery6 {
	grid-area: gal-6;
}
.gallery-grid img {
	width: 100%;
	height: 100%;
	filter: sepia(0.9);
}
.gallery-grid img:hover {
	filter: sepia(0);
}
.daikichi-header,
.daikichi-header p {
	text-align: center;
	color: #000;
}
.daikichi-flexbox {
	max-width: 1000px;
	padding-bottom: 150px;
}
.daikichi-flexbox .div30 {
	border-right: 1px solid #909090;
	color: #909090;
}
.daikichi-introduction {
	font-weight: 400;
	padding-top: 30px;
	padding-bottom: 30px;
}
.daikichi-introduction img {
	max-width: 250px;
	margin-left: auto;
	margin-right: auto;
}
/*information.html*/
.information-header {
	max-width: 1000px;
	height: 20vh;
	display: flex;
	margin-top:100px;
	margin-left: auto;
	margin-right: auto;
	background-color: #f53dee;
}
.information-header > h2,
.information-header > div {
	margin-left: auto;
	margin-right: auto;
	color: #fff;
	margin-top: auto;
	margin-bottom: auto;
	text-align: center;
}
.topics-blog {
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 100px;
}
.topic h1 {
	width: 100%;
	display: flex;
}
.topic h1::before,
.topic h1::after {
	flex-grow: 1;
	content: "";
	border-bottom: 3px solid #f53dee;
	margin-bottom: 17px;
}
.topic h1::before {
	margin-right: 10px;
	margin-left: 5px;
}
.topic h1::after {
	margin-left: 10px;
	margin-right: 5px;
}
iframe {
	width: 100%;
}
.topics-blog h1 {
	text-align: center;
	color: #f53dee;
	text-shadow: 2px 2px 3px #909090;
}
.topics-blog iframe {
	margin-left: auto;
	margin-right: auto;
}
/*contact.html*/


/*** スマホ用設定記述 ****************************************/
/*見出しテキストの折返し調整　クラス名brを付けたbr部で改行*/
	@media screen and (min-width: 768px) {
		.br {
			display: none;
		}
	}
    @media screen and (max-width: 640px){
	/*ヘッダーのスマホ対応*/
		/* ハンバーガーメニュー表示 */
	a.trigger {
		display: block;
	}
	/* 一般共通設定 */
	.flex-container {
		display: block;
	}
	h1 {
		font-size: 24px;;
		}
	h2 {
		font-size: 20px;;
		}
	h3 {
		font-size: 16px;;
		}
	p {
		font-size: 12px;;
		}
	figcaption {
		font-size: 14px;
	}
	h2.slide__title {
		font-size: 24px;
	}
	/* ハンバーガーメニュークリックで表示されるメニュー画面 */
	nav {
		padding: 0;
	}
	.overlay_nav {
		position: fixed;
		top: 0;
		left: 0;
		z-index: 99;
		display: none;
		width: 100%;
		height: 100%;
		background-color: #f53dee;
		opacity: 0.9;
	}
	.nav_wrap {
		display: block;
		margin-right: auto;
		margin-left: auto;
	}
	nav img {
		margin-left: auto;
		margin-right: auto;
		margin-top: 100px;
		margin-bottom: 50px;
	}
	.nav-copylight {
		display: block;
		text-align: center;
		color: #fff;
		padding-top: 100px;
		font-size: 12px;
	}
	.on_animation .nav_wrap,
	.on_animation{
		display: block;
	}
          /******************************ここまで*****************/

/* ここから通常設定（スマホ用） */
/*index.html*/
		header {
			background-position: top;
		}
		.main-header {
			display: block;
			padding-top: 150px;
		}
		.name-logo {
			margin-left: auto;
			margin-left: 20px;
			margin-right: 20px;
		}
		.slide__content-wrap{
			left: 45%;
		}
		.h-container h2 p {
			font-size: 4.5vw;
		}
		.div70 {
			padding-top: 50px;
		}
		.daikichi-flexbox {
			padding-bottom: 50px;
		}
		footer > .head-contact > em {
			display: block;
			font-size: 14px;
		}
		footer ul li {
			background-color: #fff;
			border-bottom: 1px solid #f53dee;
		}
		footer > .nav_wrap > li > a {
			color: #f53dee;
			font-size: 12px;
		}
		.information-header img {
			display: none;
		}
		.topics-blog,
		.contact {
			margin-top: 50px;
		}
}
