@charset "utf-8";

*,
::before,
::after {
	padding: 0;
	margin: 0;
	box-sizing: border-box;
}

ul {
	list-style: none;
}

a {
	color: inherit;
	text-decoration: none;
}

img {
	max-width: 100%;
}


.header-inner {
	/* max-width: 1366px; */
	margin: 0 auto;
}

html {
	scroll-behavior: smooth;
}


body {
	background-image: url(./img/space-4984262.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-attachment: fixed;
	font-size: 16px;
	color: #fff;
}


main,
footer {
	font-family: "WDXL Lubrifont JP N", sans-serif;
	font-weight: 400;
	font-style: normal;
}

.btn {
	display: none;
}

.newitems {
	text-align: center;
	padding-bottom: 50px;

}

.newitems,
.news .news-title {
	font-size: 35px;
	padding-top: 150px;
}


.top div {
	width: 100%;
	height: 100%;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	margin: 0 auto;
}

.top img {
	width: 100%;
	height: auto;
	margin: 0 auto;
}



/* .topimg1 {
	background-image: url(./img/top1.png);
	background-size: cover;
}

.topimg2 {
	background-image: url(./img/top2.png);
	background-size: cover;
} */



.mini {
	width: 40%;
}

.mini2 {
	width: 80%;
	margin-left: 5%;
	margin-right: 5%;
}


.header-inner {
	width: 100%;
	height: 125px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 5%;
	padding-right: 5%;
	display: flex;
	justify-content: space-between;
	align-items: center;
	background-color: #b1bdff;
}

.site-menu ul {
	display: flex;
}

.site-menu ul li {
	margin-left: 5%;
}


.navtop {
	width: 100%;
	height: auto;
}

.navhako img:hover {
	scale: 1.2;
	rotate: 10deg;
}


h1 {
	text-align: center;
	padding: 100px 0;
}

.item {
	width: 1500px;
	max-width: 90%;
	margin-top: 75px;
	margin-left: auto;
	margin-right: auto;
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	column-gap: 40px;
	row-gap: 40px;
}

.item li img:hover {
	transform: scale(1.1);
	transition-duration: 0.8s;
}

.item dl {
	text-align: center;
	padding: 10px;
}

.item dt {
padding-top: 20px;
	font-size: 20px;
}

.item dt:hover {
	color: rgb(248, 252, 47);
	border-bottom: 1px solid #fff;
}

.item dd {
	padding: 5px;
}

.item p {
	padding: 5px;
}

.more {
	text-align: center;
	padding-top: 50px;
	font-size: 20px;
}

.more:hover {
	color: rgb(248, 252, 47);
}

.news {
	width: clamp(700px, -700px + 100vw, 90vw);
	margin: 0 auto;
}

.news h2 {
	text-align: center;
	padding: 30px 0;
}

.news_list {
	margin: 0 5%;
}

.news_list_item {
	padding: 25px 0;
	border-bottom: 1px solid #E6E6E6;
}

.news_list_item:first-child {
	border-top: 1px solid #E6E6E6;
}

.news_list_item a {
	position: relative;
	display: flex;
	padding-right: 30px;
}

.news_list_date {
	font-size: 15px;
	display: flex;
	margin-right: 15px;
	align-items: center;
}

.news_item {
	background: #7d2f91;
	border-radius: 14px;
	width: 6em;
	text-align: center;
	margin-left: 20px;
}

.arrow {
	width: 25px;
	height: 1px;
	background: #fff;
	position: absolute;
	top: 50%;
	right: 0;
}

.arrow::after {
	content: "";
	display: block;
	width: 6px;
	height: 1px;
	background: #fff;
	transform: rotate(45deg);
	position: absolute;
	right: 0px;
	bottom: 2px;
}

.news_list .news_list_item .sirase:hover {
	color: rgb(248, 252, 47);
}



.owari {
	display: flex;
	justify-content: space-evenly;
	align-items: center;
	font-size: 25px;
}

.owari a:hover {
	color: rgb(248, 252, 47);
}


.ko {
	vertical-align: bottom;
}

.hako1 .owari1 {
	display: flex;
	justify-content: center;
	padding: 130px;
	text-align: center;
}


.svg {
	padding: 100px 0;
}

footer {
	height: 60vh;
}


footer .copy {
	display: flex;
	align-items: center;
	justify-content: center;
}

/* -------------------------------ここからうさし-------------------------------------*/

.breadcrumb {
	display: flex;
	flex-wrap: wrap;
	list-style: none;
}

.breadcrumb_list:not(:last-of-type)::after {
	content: ">";
	margin: 0 .6em;
}

.usaship {
	font-size: 20px;
	color: #000;
}

.usaship2 {
	padding-top: 200px;
	font-size: 35px;
	text-align: center;
}


.usashi .toi {
	width: 500px;
	margin: 50px auto;
}

.usashi .setumei {
	text-align: center;
	line-height: 3;
	font-size: 22px;
}

.flex {
	position: relative;
	width: calc(100% / 2);
	height: 500px;
	display: block;
	overflow: hidden;
	cursor: pointer;
	-webkit-transition: .6s cubic-bezier(0.34, 1.56, 0.64, 1);
	transition: .6s cubic-bezier(0.34, 1.56, 0.64, 1);

}

.flex img {
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	-webkit-transition: 0.5s ease-in-out;
	transition: 0.5s ease-in-out;
	margin: 0 auto;
}

.flex:hover {
	-webkit-transform: scale(1.3);
	transform: scale(1.3);
}

.flex:hover img:nth-of-type(2) {
	opacity: 0;
}

.usashidayo {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 150px 0;
}


h3 {
	font-size: 20px;
	color: #000;
}

.setumei2 {
	color: #000;
}

.syoukai {
	width: 36%;
	background-color: #fff;
	border-radius: 10px;
	text-align: center;
	line-height: 2;
	padding-top: 30px;
	padding-bottom: 30px;
}

.banner-video {
	width: 27%;
	height: auto;
	object-fit: cover;
	display: block;
	margin: 0 auto;
}

.banner-video:hover {
	scale: 1.2;
	transition-duration: 0.8s;
}

.bana {
	text-align: center;
}

.setumei3 {
	padding: 10px 0;
}

.nakama1 {
	display: flex;
	align-items: center;
	justify-content: space-between;
	max-width: 90%;
	padding: 0 30px;
	margin: 0 auto;
	margin-top: 50px;
}

.setumei4 {
	width: 100%;
	background-color: #fff;
	border-radius: 10px;
	line-height: 2;
	padding-top: 20px;
	padding-bottom: 20px;
	text-align: center;
}

.nakamaimg {
	width: 80%;
	text-align: center;
	animation: fuwa 8s ease-in-out infinite alternate-reverse;
}

@keyframes fuwa {

	0% {
		transform: translateY(-10%);
	}

	100% {
		transform: translateY(10%);
	}
}

.reverse {
	flex-direction: row-reverse;
}

.scroll-space {
	margin-top: 150px;
}


/* 
.setumei::before {
	content: "";
	display: block;
	width: 300px;
	height: 300px;
	background-image: url(./img/hosi1.png);
	background-repeat: no-repeat;
	background-size: cover;
	position: absolute;
	top: 350px;
	left: 150px;
}

.usashi {
	position: relative;
}

.setumei::after {
	content: "";
	display: block;
	width: 300px;
	height: 300px;
	background-image: url(./img/hoshi2.png);
	background-repeat: no-repeat;
	background-size: cover;
	position: absolute;
	top: 150px;
	right: 100px;
} */

.usashitoha {
	position: relative;
}

.hoshi {
	position: absolute;
	top: 18%;
	left: 13%;
}

.hoshi2 {
	position: absolute;
	top: 47%;
	right: 10%;
}

.hoshi,
.hoshi2 {
	animation: 8s linear infinite rotation;
}

@keyframes rotation {
	0% {
		transform: rotate(0);
	}

	100% {
		transform: rotate(360deg);
	}
}



/* -------------------------------ここからGOOoooooooooods------------------------------ */

.topimg3 {
	background-image: url(./img/dekazakka4.png);
}

.topimg4 {
	background-image: url(./img/dekazakka1.png);
}

.topimg5 {
	background-image: url(./img/dekazakka3.png);
}

.topimg6 {
	background-image: url(./img/dekazakka15.png);
}

.goods .goodstitle {
	text-align: center;
	font-size: 35px;
	padding-top: 100px;
	padding-bottom: 50px;
}

.pickup {
	text-align: center;
	font-size: 25px;
}

.allitems {
	font-size: 25px;
}

.item-list {
	margin-top: 75px;
	margin-left: auto;
	margin-right: auto;
	display: grid;
	grid-template-columns: 1fr 1fr;
	column-gap: 40px;
	row-gap: 40px;
	text-align: center;
}

.item-list dl {
	text-align: center;
	padding: 10px;
}

.item-list dt {
	padding: 10px;
	font-size: 20px;
}

.item-list dt:hover {
	color: rgb(248, 252, 47);
	border-bottom: 1px solid #fff;
}

.item-list li img:hover {
	transform: scale(1.1);
	transition-duration: 0.8s;
}

.item-list dd {
	padding: 5px;
}

.item-list p {
	padding: 5px;
}

.shop-contents {
	margin-top: 75px;
	margin-left: auto;
	margin-right: auto;
	display: flex;
	width: 80%;
	flex-direction: row-reverse;
}

.shop-menu {
	display: flex;
	align-items: flex-start;
	line-height: 5;
	margin: 0 auto;
	min-width: 250px;
}

.shop-item .all {
	font-size: 20px;
	padding-top: 40px;
	text-align: center;
}

.shop-item .all:hover {
	color: rgb(248, 252, 47);
}



.shop-menu-inner {
	position: sticky;
	top: 50px;
	left: 0;
	right: 0;
	text-align: center;
}

.shop-menu-inner li a{
	border-bottom: 1px dotted
}


.w80 {
	width: 80%;
	margin: 0 auto;
	padding-top: 10px;
}




/* ------------------------------------ここからといあわせ------------------------------------ */

.contact {
	width: 1000px;
	max-width: 90%;
	margin-top: 75px;
	margin-left: auto;
	margin-right: auto;
}

.contacttitle {
	text-align: center;
	font-size: 35px;
	padding-top: 50px;
	padding-bottom: 100px;
}

.form-area {
	background-color: #1c0072c5;
	border-radius: 30px;
	padding-top: 15%;
	padding-left: 20%;
	padding-right: 20%;
	padding-bottom: 30%;
	display: flex;
	flex-wrap: wrap;
}

.form-area dt {
	width: 200px;
	padding: 15px 0;
	font-size: 16px;
	font-weight: bold;
	line-height: 24px;
}

.form-area dt .required::after {
	content: '必須';
	font-size: 11px;
	color: #eb4f32;
	margin-left: 10px;
}

.form-area dd {
	width: calc(100% - 200px);
	padding: 15px 0;
}

.input-text {
	width: 100%;
	max-width: 280px;
	height: 40px;
	padding-left: 10px;
	padding-right: 10px;
}

.message {
	width: 100%;
	height: 260px;
	padding: 10px;
	line-height: 1.5;
}

.confirm-text {
	font-size: 16px;
	line-height: 22px;
	margin-top: 100px;
	text-align: center;
}

.submit-button {
	background-color: #fff;
	display: block;
	min-width: 180px;
	line-height: 48px;
	font-size: 14px;
	text-align: center;
	margin-top: 20px;
	margin-left: auto;
	margin-right: auto;
	cursor: pointer;
	border: none;
	font-family: "WDXL Lubrifont JP N", sans-serif;
}

.submit-button:hover {
	background-color: rgb(248, 252, 47);
}

.form-area {
	position: relative;
}

.gif {
	position: absolute;
	bottom: -53%;
	width: 20%;
	height: auto;
}

.gif2 {
	position: absolute;
	bottom: -37%;
	left: 47%;
	width: 7%;
	height: auto;
}

.topp {
	display: none;
}

.tophe {
	position: fixed;
	right: 30px;
	bottom: 30px;
}

.tophe:hover {
	rotate: -5deg;
}

.owari1 .x:hover {
	transform: translateY(5px);
}

.owari1 .y:hover {
	transform: translateY(5px);
}

.owari1 .i:hover {
	transform: translateY(5px);
}

.svg .svgg {
	width: 100%;
    height: 50vh;
}

.svg .svg1 {
	width: 100%;
	height: 60vh;
}

.logo_fadein{
background-image: url(./img/space-4984262.jpg);
	position: fixed;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	z-index: 9999;
}
.logo_fadein p {
	position: fixed;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	display: none;
	z-index: 999999;
	width: 800px;
}

.kage {
	box-shadow: 5px 5px 10px 5px #ffffffa3;
}




/* .confirm-text::before {
	content: "";
	display: block;
	background-image: url(./gif/usagi.gif);
	background-repeat: no-repeat;
	background-size: cover;
	width: 300px;
	height: 300px;
	bottom: -600px;
	left: 200px;
	position: absolute;
}

.confirm-text::after {
	content: "";
	display: block;
	background-image: url(./gif/nin.gif);
	background-repeat: no-repeat;
	background-size: cover;
	width: 100px;
	height: 100px;
	bottom: -450px;
	left: 500px;
	position: absolute;
} */

/* --------------------------------------ここからスマホ---------------------------------------- */

@media (max-width: 800px) {

	.topp {
		display: block;
	}


	/* .top {
		height: 50vh;
		
	} */

	.top {
		display: none;
	}

	.topp .mobatop1 {
		background-image: url(./img/mobatop1.png);
		background-repeat: no-repeat;
		background-position: center;
		background-size: cover;
	}

	/* 
	.topp .mobatop1 {
		background-image: url(./img/mobatop1.png);
		background-repeat: no-repeat;
		background-size: cover;
	} */


	.item {
		max-width: 90%;
		margin-top: 75px;
		margin-left: auto;
		margin-right: auto;
		display: grid;
		grid-template-columns: 1fr 1fr;
		column-gap: 40px;
		row-gap: 40px;
	}

	.news {
		padding: 0;
		width: 100%;
	}

	.setumei::before,
	.setumei::after {
		display: none;
	}

	.usashidayo {
		display: block;
	}

	.nakama1 {
		display: block;
	}

	.item-list {
		width: 100%;
		display: block;
		margin: 0 auto;

	}

	.form-area dt,
	.form-area dd {
		width: 100%;
	}

	.flex {
		width: 65%;
	}

	.syoukai {
		width: 100%;
	}

	.gif {
		position: absolute;
		bottom: -67%;
		width: 30%;
	}

	.gif2 {
		position: absolute;
		bottom: -63%;
		left: 40%;
		width: 15%;
	}

	.form-area {
		padding-left: 5%;
		padding-right: 5%;
	}

	.shop-menu {
		min-width: 250px;
	}

	.shop-contents {
		width: 80%;
	}

	.mini {
		width: 38%;
	}

	.mini2 {
		width: 100%;
	}

	.site-menu {
		/* ボタンを押す前は非表示 */
		display: none;
		background-color: rgb(254 252 90 / 81%);
		/* 親要素基準での位置決め */
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		height: 100vh;
		/* 重なり順 */
		z-index: 1;
		/* 左右の中央ぞろえ */
		display: flex;
		justify-content: center;
		/* 上下の中央ぞろえ */
		align-items: center;
		/* 切り取る　四角 */
		clip-path: inset(0 0 100% 0);
		transition: all 0.5s;
	}

	.site-menu.is-show {
		clip-path: inset(0 0 0 0);
	}

	.btn {
		display: block;
		width: 50px;
		aspect-ratio: 1/1;
		background-color: transparent;
		border: none;
		outline: none;
	}

	.line {
		display: block;
		width: 100%;
		height: 20px;
		background-color: rgb(254 252 90 / 70%);
		position: relative;
		transition: all 0.5s 0.5s, rotate 0.5s 0s;
	}

	.line::before {
		display: block;
		width: 41%;
		height: 10px;
		background-color: rgb(87 50 235 / 58%);
		position: relative;
		transition: all 0.5s 0.5s, rotate 0.5s 0s;
	}

	.line::after {
		display: block;
		width: 41%;
		height: 10px;
		background-color: rgb(87 50 235 / 58%);
		position: relative;
		transition: all 0.5s 0.5s, rotate 0.5s 0s;
	}

	.line::before,
	.line::after {
		content: "";
		position: absolute;
		left: 0;
	}

	.line::before {
		top: -16px;
		left: 11px;
		width: 60%;
	}

	.line::after {
		top: 25px;
		width: 60%;
		left: 11px;
	}

	.is-show .line {
		background-color: #00000000;
	}

	.is-show .line::before {
		top: 0;
		transition: all 0.5s 0s, rotate 0.5s 0.5s;
		rotate: 45deg;
	}

	.is-show .line::after {
		top: 0;
		transition: all 0.5s 0s, rotate 0.5s 0.5s;
		rotate: -45deg;
	}

	.wrap {
		margin: 0 auto;
	}

	header {
		position: relative;
		z-index: 1;

	}

	.btn {
		position: fixed;
		top: 40px;
		right: 30px;
		z-index: 100000;
	}

	.site-menu ul {
		display: flex;
		flex-direction: column;

	}

	.newitems {
		padding-top: 30px;
		font-size: 25px;
		padding-bottom: 0;
	}

	.allitems {
		font-size: 18px;
	}

	.pickup {
		font-size: 18px;
		padding: 5px 0;
	}

	.item-list dt {
		font-size: 16px;
	}

	.item-list dd {
		font-size: 14px;
	}

	.item-list p {
		font-size: 14px;
	}

	.goods .goodstitle {
		text-align: center;
		font-size: 25px;
		padding-top: 20px;
		padding-bottom: 0;
	}

	.pickup {
		padding: 30px 0;
	}

	.item dt {
		font-size: 16px;
	}

	.item dd {
		font-size: 14px;
	}

	.item p {
		font-size: 14px;
	}

	.tophe {
		position: fixed;
		right: 0;
		bottom: 30px;
	}

	.hoshi {
		position: absolute;
		width: 30%;
		height: auto;
		top: 35%;
		left: -6%;
	}

	.hoshi2 {
		position: absolute;
		width: 25%;
		height: auto;
		top: 16%;
		right: -2%;
	}

	.nakamaimg {
		margin: 0 auto;
	}

	.usaship2 {
		padding-top: 100px;

	}

	.setumei4 {
		margin-top: 50px;
	}

	.flex img {
		top: 50%;
		left: 10%;
		transform: translateX(-50%);
		transform: translateY(-50%);
	}

	.flex {
		width: 100%;
	}

	.usashidayo {
		padding-top: 50px;
	}


	.news .news-title {
		font-size: 25px;
	}

	.more {
		font-size: 18px;
	}

	.top div {
		width: 100%;
		height: 100%;
		background-repeat: no-repeat;
		background-position: center;
		background-size: cover;
		margin: 0 auto;
	}

	.svg .svgg {
		width: 100%;
		height: 25vh;
	}

	.logo_fadein p {
		width: 500px;
	}

	.banner-video {
		width: 50%;
	}

	.scroll-space {
		margin-top: 20px;
	}

.usashi .setumei {
	font-size: 18px;
}

.usaship2 {
	font-size: 25px;
}

.contacttitle {
	font-size: 25px;
	padding-top: 0;
}

.flex {
	width: 100%;
	height: 500px;
	display: block;
	overflow: hidden;
}

.flex img {
	left: 0;
}

.usashitoha {
	width: 100%;
	height: auto;
	margin: 0 auto;
}

.gif {
	position: absolute;
	bottom: -55%;
	width: 30%;
}

.gif2 {
	position: absolute;
	bottom: -50%;
	left: 40%;
	width: 15%;
}


}