@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=M+PLUS+Rounded+1c:wght@100;300;400;500;700;800;900&display=swap');

* {
	margin:0;
	padding:0;
	box-sizing: border-box;
	/*-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;*/
}

img {
  -webkit-user-drag: none; /* Chrome, Safari, Opera */
  -khtml-user-drag: none; /* Konqueror */
  -moz-user-drag: none; /* Firefox */
}

body {
	position: relative;
	text-align:center;
	font-family:'M PLUS Rounded 1c', Meiryo, sans-serif;
	line-height:1.4;
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}

h1,h2,h3,h4,h5,p{
	margin:0;
	padding:0;
	font-weight:normal;
}
ul,li{
	margin:0;
	padding:0;
	list-style: none;
}

a{text-decoration: none;}

img{
	width:100%;
	height:auto;
}

_::-webkit-full-page-media, _:future, :root
rt{
    margin-bottom:-5px;
	letter-spacing:-0.05em;
}
@-moz-document url-prefix() {
	rt{
		margin-bottom:-5px;
	}
}

.youtube iframe{
	width:100%;
	height:auto;
	aspect-ratio:16 / 9;
}

.youtube_short iframe{
	width:100%;
	height:auto;
	aspect-ratio:9 / 16;
}

.open_title{
	cursor: pointer;
}

/*==============================*/

header{
	top:0;
	position: sticky;
	z-index: 100;
	background-image: url("../img/header_bk.webp");
	background-size: cover;
	background-repeat: no-repeat;
}

.header{
	display: flex;
	margin: auto;
    flex-wrap: wrap;
}

.logo {
    margin: auto auto auto 0;
    width: 300px;
    line-height: 0;
}

.nanda {
    margin:0;
	padding:10px 20px;
    width:110px;
    line-height:0;
	background-color: #e22107;
}

.header > ul{
	display: flex;
	flex-wrap: wrap;
	padding:0 10px;
}

.header > ul > li{
	position: relative;
	border-right:2px solid #513725;
	padding:0 10px;
	margin: auto;
}

.header > ul > li:last-child{
	border-right: none;
}

.header ul li a{
	display: block;
	letter-spacing:-0.02em;
	text-align:center;
	color:#252525;
	font-weight:600;
	min-width:130px;
}

.header > ul > li > ul{
	background-image: url("../img/header_bk.webp");
	background-size: cover;
	background-repeat: no-repeat;
    width: 100%;
	display: block;
    position: absolute;
    top: 32px;
    left: 0;
	visibility: hidden;
    opacity: 0;
    transition: all .3s;
}
.header > ul > li > ul > li{
	padding:10px;
	transition: all .3s;
	position: relative;
	border-left: none;
}
.header > ul > li > ul > li{
	border-bottom: 1px solid #bbb;
}
.header > ul > li > ul > li:last-child{
	border-bottom: none;
}
.header > ul > li > ul > li:first-child{
	padding-top: 13px;	
}

.header > ul > li:hover > ul{
	visibility: visible;
    opacity: 1;
}

.parent{
	display:block;
	margin: auto 10px auto 0;
	letter-spacing:-0.03em;
	font-size:14px;
	border:2px solid #333;
	color:#333;
	padding:2px 10px;
	border-radius:5px;
	transition:.2s;
}

@media screen and (max-width:900px) {
	.header > ul > li{
		padding:0 6px;
		font-size:15px;
	}
	
	.header ul li a {
		min-width: 110px;
	}
	
	.logo {
		width: 235px;
	}
	.nanda {
		width:95px;
	}
}

@media screen and (max-width:767px) {
	.header > ul{
		display: none;
	}
	.parent{
		display:none;
	}	
}

@media screen and (max-width:520px) {
	.header{
		
	}
	.nanda {
		width:75px;
		padding:10px;
	}
	.logo {
		margin: auto auto auto 5px;
		width: 100%;
		max-width:200px;
	}
	.logo a{
		line-height: 0;
	}
}

@media only screen and (min-width: 768px) {
	.parent:hover{
		border:2px solid rgba(35,35,35,0);
		background-color:rgba(35,35,35,.1);
	}
}



/*==============================*/

.footer_nav{
	padding:0 20px 25px;
}

.footer_nav ul{
	display: flex;
	flex-wrap: wrap;
	margin: auto;
	padding:10px;
	font-size: 13px;
	justify-content: center;
	gap:5px 25px;
	background-color: rgba(255,255,255,.6);
	max-width: 800px;
	border-radius:30px;
}
.footer_nav li a{
	position: relative;
	z-index: 2;
	color:#111;
	text-decoration: underline;
}

footer{
    width:100%;
    background-color:rgba(0,0,0,0.5);
    color:#fff;
    text-align:center;
    padding:10px 0;
    bottom:0px;
    clear:left;
    margin-top: auto;
}

address {
	font-style : normal ;
	font-size : 75% ;
}
@media screen and (max-width:520px) {
	.footer_nav ul{
		border-radius:15px;
	}
}

/*==============================*/

#page_top{
	opacity: 0;
	position: fixed;
	bottom:20px;
	right:15px;
	z-index: 20;
	transition: .2s;
}

#page_top.show{
	opacity: 1;
}

#page_top a{
	display:flex;
	flex-wrap: wrap;
	background-color:#e22107;
	width:50px;
	height:auto;
	aspect-ratio:1 / 1;
	padding-bottom: 3px;
	border-radius:50%;
	filter: drop-shadow(1px 1px 1px rgba(53,41,35,.2));
}

#page_top a span{	
	display: block;
	margin:auto;
	width: 0;
	height: 0;
	border-style: solid;
	border-color: transparent transparent #f7f1dc transparent;
	border-width: 0 10px 10px 10px;
}

@media screen and (max-width:520px) {
	#page_top {
	    bottom: 30px;
		right: 8px;
	}
	#page_top a{
		width:40px;
	}
}


/*==============================*/

.hamburger_btn{
	aspect-ratio:1 / 1;
	width:60px;
	height:auto;
}

.hamburger_btn.open{
	padding: 14px 10px 0 20px;
}

.hamburger_btn.open span{
	display: block;
	height:2px;
	width:100%;
	border-radius: 10px;
	background-color: #333;
	margin: auto 0 10px;
}
.hamburger_btn.open.hide span{
	background-color: rgba(0,0,0,0);
}

.hamburger_btn_box{
	display: none;
}
.hamburger_menu{
	display: none;
	position: fixed;
	top:0;
	left:0;
	width:100vw;
	height:100vh;
	padding-bottom: 60px;
	background-image: url("../img/bk.webp");
	background-size: 120%;
	background-repeat: repeat;
	z-index: 80;
	overflow-y: scroll;
}
.hamburger_btn_innerbox{
	display: flex;
	justify-content: flex-end;
}
.hamburger_btn.close{
	padding:23px 10px 0;
}
.hamburger_btn.close span{
	display: block;
	height:2px;
	width:100%;
	border-radius: 10px;
	background-color: #333;
}
.hamburger_btn.close span:nth-child(1){
	margin: 5px 0px 0px -3px;
	transform: rotate(45deg);
}
.hamburger_btn.close span:nth-child(2){
	margin: -1px 0px 0px -3px;
	transform: rotate(-45deg);
}

.hamburger_menu_mv{
	margin:-15px auto 0;
	max-width:600px;
	padding: 0 30px;
}

.hamburger_menu_box{
	display: flex;
	flex-wrap: wrap;
	margin: auto;
	max-width: 500px;
	gap:10px;
	padding:20px 20px 5px;
}

.hamburger_menu_box a{
	position: relative;
	display: block;
	width:100%;
	color:#fff;
	border-radius: 8px;
	padding:5px 0 2px;
	font-size:22px;
	font-weight:600;
	line-height: 1.9em;
}

.hamburger_menu_box a img{
	position: absolute;
	width:24px;
	right:8px;
	top:50%;
	transform: translateY(-50%);	
}

.hamburger_menu_box a:nth-child(1){background-color:#e22107;}
.hamburger_menu_box a:nth-child(2){background-color:#0099a5;}
.hamburger_menu_box a:nth-child(3){background-color:#ff9d01;}

.hamburger_menu_box a.double{
	width: calc((100% - 10px)/ 2);
}

.hamburger_menu_box h2{
	margin-top: 25px;
	width:100%;
	font-size:22px;
	font-weight:600;
	text-shadow: 1px 1px 2px rgba(0, 0, 0, .6);
}

.hamburger_menu_nanimono{
	margin: auto;
	max-width: 500px;
	padding:0 20px;
}

.hamburger_menu_nanimono a{
	position: relative;
	display: flex;
	flex-wrap: wrap;
	width:100%;
	color:#fff;
	border-radius: 8px;
	font-size:22px;
	font-weight:600;
	line-height: 0;
}

.hamburger_menu_links{
	display: flex;
	flex-wrap: wrap;
	margin: auto;
	max-width: 500px;
	gap:10px;
	padding:20px;
}

.hamburger_menu_links a{
	display:block;
	position:relative;
	width:100%;
	margin: auto 0;
	letter-spacing:-0.03em;
	font-size:17px;
	border:2px solid #333;
	color:#333;
	padding:4px 10px;
	border-radius:8px;
	background-color: rgb(253, 245, 227, .65);
	transition:.2s;
}
.hamburger_menu_links a::before{
	position: absolute;
    content: '';
    width: 10px;
    height: 10px;
    border-bottom: #333 2px solid;
    border-right: #333 2px solid;
    top:31%;
    right: 18px;
    transform: rotate(-45deg);
    transition: .2s;
}


@media screen and (max-width:767px) {
	.hamburger_btn_box{
		display: block;
	}
}

@media screen and (max-width:520px) {
	.hamburger_btn{
		width:45px;
	}
	.hamburger_btn.open{
		padding:14px 8px 0 5px;
	}
	.hamburger_btn.open span{
		margin: auto 0 8px;
	}
	.hamburger_btn.close span:nth-child(1) {
		 margin: 7px 0px 0px -3px;
	}
	.hamburger_a{
		font-size: 14px;
	}
}

@media screen and (max-width:374px) {
	
}


/*==============================*/

.tbw{display:none}
@media only screen and (max-width: 1100px) {
	.tbw{display:inline}
	.tbw_b{display:block}
	.no_tbw{display:none}
}

.tb{display:none}
@media only screen and (max-width: 767px) {
	.tb{display:inline}
	.tb_b{display:block}
	.no_tb{display:none}
}

.phone{display:none;}
@media only screen and (max-width: 520px) {
	.phone{display: inline;}
	.phone_b{display:block}
	.no_phone {display: none;}
}

.mobile{display:none}
@media only screen and (max-width: 374px) {
	.mobile{display:inline}
	.no_mobile{display:none}
}