@charset "UTF-8";
/* CSS Document */
body{
	margin: 0px !important;
	overscroll-behavior: none;
}
h1,h2,h3,h4,h5,h6{margin: 0;}
ul {
    display: block;
    list-stslideyle-type: disc;
    margin-block-start: 0;
    margin-block-end: 0;
    margin-inline-start: 0;
    margin-inline-end: 0;
    padding-inline-start: 0;
}
*{
    min-height: 0;
    min-width : 0;
}
#by{
    padding: 0;
    font-family: "Noto Sans JP", sans-serif;
    margin: 0 auto;
    line-height: 2.0;
    font-size: 11px;
    letter-spacing: 1px;
	width: 100%;
    box-sizing: border-box;
    color: #2b2b2b;
    -webkit-text-size-adjust: 100%;
}
#by a {
	text-decoration: none;
	color: #2b2b2b;
}
#by p {
    margin: 0;
}
#by　a:hover {
	opacity: 1;
}
#by .clear{
	clear: both;
}
#by img{
    width: 100%;
    line-height: 0;
}
#by ul,#by li {
	list-style: none;
	padding: 0;
	margin: 0;
}
.key-slider,
.slick-list,
.slick-track {
  height: 100%;
}
.f-be {
	font-family: "Bebas Neue", sans-serif;
	font-weight: 400;
}
@media only screen and (min-width: 769px) {
	#by{
		background: #2f566a;
	}
}
/*********************************************
                by_header
*********************************************/
#by #by_header {
	display: flex;
	justify-content: space-between;
	
}
#by #by_header div:nth-of-type(1) {
	position: relative;
	width: 58%;
}
#by #by_header div:nth-of-type(1) img {
	width: 84%;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
#by #by_header div:nth-of-type(2) {
	width: 42%;
}
@media only screen and (min-width: 769px) {
	#by #by_header {
		max-width: 1200px;
		width: 70%;
		margin: 0 auto;
		background: #fff;
	}
	#by #by_header div:nth-of-type(1) img {
		max-width: 360px;
	}
	#by #by_header div:nth-of-type(2) {
		width: 54%;
	}
}
/*********************************************
              #contents
*********************************************/
#by #contents {
	margin: 0;
	overflow: hidden;
	background: #fff;
	position: relative;
}
#by #contents .read {
	text-align: left;
	margin: 0% 0 14%;
	padding: 6% 5%;
	font-size: 12px;
	border-top: solid 3px #2f566a;
	border-bottom: solid 3px #2f566a;
}
#by #contents section {
	margin-bottom: 20%;
}

#by #contents section .menu {
	width: 78%;
	margin: 0 auto;
	padding: 7%;
	background: #ededed;
	position: relative;
}
#by #contents section .menu:nth-of-type(1) {
	margin: 0 auto 10%;
}
#by #contents section .menu .no {
	position: absolute;
	width: 16%;
	top: -10%;
	left: -3%;
}
#by #contents section .menu a img{
	margin-bottom: 2%;
}
#by #contents section .menu .countArea {
	display: flex;
	align-items: baseline;
	margin: 4% 0;
}
#by #contents section .menu .countArea:nth-of-type(2) {
	margin-bottom: 0;
}
#by #contents section .menu .countArea div:nth-of-type(1) {
	font-size: 12px;
	margin-right: 2%;
	line-height: 1.0;
}
#by #contents section .menu .countArea .countdown {
	font-size: 16px;
	line-height: 1.0;
}
#by #contents section .menu .countArea .countdown-day {
	margin: 0;
    font-size: 29px;
    font-weight: 600;
    letter-spacing: 0.08rem;
    text-align: center;
	margin-right: .5%;
}
/*********/
#by #contents section .menu:nth-of-type(2)  .countArea {
	margin: 4% 0 0;
}
#by #contents section .menu .cdt {
	margin: 0;
    font-size: 29px;
    font-weight: 600;
    letter-spacing: 0.08rem;
	margin-right: .5%;
	line-height: 1.0;
}
#by #contents section .menu .cdt .cdt_date small {
	font-size: 16px;
	line-height: 1.0;
	margin: 0 .2%;
}
#by #contents section .menu .cdt .cdt_date small:first-of-type {
	margin-right: 2%;
}
@media only screen and (min-width: 769px) {
	#by #contents {
		max-width: 1200px;
		width: 70%;
		margin: 0 auto;
		background: #fff;
	}
	#by #contents .read {
		text-align: center;
		margin: 0px 0 90px;
		padding: 35px 0;
		font-size: 12px;
	}
	#by #contents section {
		width: 82%;
		margin: 0 auto 140px;
	}
	#by #contents section:nth-of-type(1){
		display: flex;
		justify-content: space-between;
		align-items: stretch;
		
	}
	#by #contents section .menu {
		width: 36%;
		padding: 36px;
	}
	#by #contents section .menu:nth-of-type(1) {
		margin: 0 auto 0%;
	}
}
/*******************************
        
*******************************/
#by #contents section .midashi {
	width: 88%;
	margin: 0 auto 4%;
}
#by #contents section .midashi img {
	display: block;
	width: 90%;
	margin: 0 auto 4%;
}
#by #contents section .midashi p {
	
}
#by #contents section .about {
	
}
#by #contents section .about .about-inner {
	width: 86%;
	margin: 0 auto;
}
#by #contents section .about .about-inner p {
	margin: 10% auto 14%;
}
#by #contents section .about .about-inner .video {
	width: 82%;
	margin: 0 auto 4%;
}
#by #contents section .about .about-inner .video video {
	width: 100%;
}
#by #contents section .about .about-inner .schedule {
	display: flex;
	justify-content: space-between;
	align-items: start;
}
#by #contents section .about .about-inner .schedule .schedule-inner {
	width: 45%;
	position: relative;
	background: #ededed;
	padding: 10.5% 0 6%;
}
#by #contents section .about .about-inner .schedule .schedule-inner .ttlday {
	position: absolute;
	width: 38%;
	top: -2%;
	left: 50%;
	transform: translate(-50%, -50%);
}
#by #contents section .about .about-inner .schedule .schedule-inner .day {
	display: block;
	width: 66%;
	margin: 0 auto;
}
#by #contents section .about .about-inner .schedule a {
	display: block;
	margin-top: 10%;
	text-align: center;
	text-decoration: underline;
}
#by #contents section .about .about-inner .time_schedule {
	position: relative;
	border: solid 2px #2f566a;
	margin: 18% 0;
}
#by #contents section .about .about-inner .time_schedule .ts {
	position: absolute;
	width: 62%;
	top: -2%;
	left: 50%;
	transform: translate(-50%, -50%);
}
#by #contents section .about .about-inner .time_schedule .time {
	display: block;
	width: 58%;
	margin: 12% auto 10%;
}

@media only screen and (min-width: 769px) {
	#by #contents section .midashi {
		width: 440px;
		margin: 0 auto 45px;
	}
	#by #contents section .about {
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
	#by #contents section .about .about-inner .video {
		width: 100%;
		margin: 0;
	}
	#by #contents section .about .about-inner:nth-of-type(1) {
		width: 42%;
	}
	#by #contents section .about .about-inner:nth-of-type(2) {
		width: 38%;
	}
	#by #contents section .about .about-inner p {
		margin: 0 auto 40px;
	}
	#by #contents section .about .about-inner .time_schedule {
		margin: 18% 0 0;
	}
}
/***********/
#by #contents section .howto h4 {
	text-align: center;
	font-size: 18px;
	margin-bottom: 4%;
}
#by #contents section .howto .howto-inner {
	
}
#by #contents section .howto .howto-inner .box {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 5% 7%;
	border-bottom: solid 2px #2f566a;
}
#by #contents section .howto .howto-inner .box:first-of-type {
	border-top: solid 2px #2f566a;
}
#by #contents section .howto .howto-inner .box img {
	width: 28%;
}
#by #contents section .howto .howto-inner .box div {
	width: 62%;
}
#by #contents section .howto .howto-inner .box div span {
	display: block;
	font-family: "Hanken Grotesk", sans-serif;
	font-size: 16px;
	font-weight: 800;
	line-height: 2.0;
	color: #2f566a;
}
@media only screen and (min-width: 769px) {
	#by #contents section .howto {
		margin-top: 80px;
	}
	#by #contents section .howto .howto-inner {
		display: flex;
		justify-content: space-between;
		align-items: stretch;
	}
	#by #contents section .howto .howto-inner .box {
		border: solid 2px #2f566a;
		padding: 20px 20px;
		width: 22%;
		display: block;
	}
	#by #contents section .howto .howto-inner .box img {
		display: block;
		width: 66%;
		margin: 0 auto 14px;
	}
	#by #contents section .howto .howto-inner .box div {width: 100%;}
	#by #contents section .howto .howto-inner .box div span {
		text-align: center;
	}
}

/*********************************************
              footer
*********************************************/
footer {
	position: relative;
    padding: 0% 0 1%;
	background: #2f566a;
	color: #fff;
    letter-spacing: .2px;
    font-weight: 600;
    line-height: 1.5;
}
footer .footer-logo {
	width: 52%;
margin: 9% auto 0%;
padding-bottom: 2%;
}
footer .link h4 {
	text-align: center;
	padding: 8% 0;
	font-size: 14px;
}
footer .link a {
	color: #2f2f2f;
    text-decoration: none; 
	line-height: 1.7;
}
footer .link .shop {
	width: 80%;
	margin: 0 auto;
}
footer .link .shop .shopbox:first-of-type {
	border-bottom: solid 1px #fff;
	padding-bottom: 7%;
	margin-bottom: 10%;
}
footer .link .shop .shopbox h5 {
	font-weight: 600;
	font-size: 14px;
	margin-bottom: 4%;
}
footer .link .shop .shopbox div {
	display: flex;
	justify-content: space-between;
	align-items: start;
	flex-wrap: wrap;
	font-size: 13px;
	font-weight: 400;
}
footer .link .shop .shopbox div p {
	color: #fff;
}
footer .link .shop .shopbox div p:nth-of-type(odd){
	width: 32%;
}
footer .link .shop .shopbox div p:nth-of-type(even) {
	width: 58%;
	margin-bottom: 5% !important;
}

footer a {
	display: block;
    margin: 0 auto;
}
footer .link .copy {
	display: block;
	text-align: center;
	font-size: 9px;
	margin: 3% 0 5%;
}
@media only screen and (min-width: 769px) {
	footer {
		max-width: 1200px;
		width: 70%;
		margin: 0 auto;
		background: #fff;
		color: #111;
		padding: 0% 0 20px;
	}
	footer .link h4 {
		padding: 0 0 48px;
		font-size: 16px;
	}
	footer .link .shop {
		width: 60%;
		margin: 0 auto 70px;
		padding-bottom: 40px;
		display: flex;
		justify-content: space-between;
		align-items: flex-start;
		border-bottom: solid 1px #2f566a;
	}
	footer .link .shop .shopbox {
		width: 46%;
	}
	footer .link .shop .shopbox:first-of-type {
		border-bottom: none;
		padding-bottom: 0;
		margin-bottom: 0;
	}
	footer .link .shop .shopbox:last-of-type {
		padding-left: 5%;
	}
	footer .link .shop .shopbox div p {
		color: #111;
	}
	footer .link .shop .shopbox h5 {
		font-size: 13px;
	}
	footer .link .shop .shopbox div {
		font-size: 11px;
	}
	footer .footer-logo {
		width: 38%;
		max-width: 360px;
		margin: 0 auto;
	}
	footer .link .copy {
		margin: 20px 0 40px;
	}
}


/*********************************************
                js
*********************************************/
#by .anim {
	opacity: 0;
	transition: 1.5s all 0s;
}
#by .anim.ac {
	opacity: 1;
	transform: translate(0);
}
#by .paint {
	opacity: 0;
	transition: 1.5s all 0s;
}
#by .paint.ac {
	opacity: 1;
	transform: translate(0);
}
/*********************************************
                view
*********************************************/
#by .spview {
	display: block;
}
#by .pcview {
	display: none;
}
@media only screen and (min-width: 768px)  {
    #by .spview {
		display: none;
	}	
	#by .pcview {
		display: block;
	}
}