@charset "utf-8";

/* CSS Document */

@keyframes rotation1{
  0%{ transform:rotate(0);}
  100%{ transform:rotate(360deg); }
}
@keyframes infinity-scroll {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

@media all{
	#enrich ul li .textbox .title,
	#journey article .leftbox .titlemap h3,
	#events .contentes .pickup .textbox .title,
	#events .contentes .wpevet .eventlist li .eventtext .title{
		font-family: "Zen Old Mincho", serif;
		font-weight: 600;
		font-style: normal;
	}

	#firstview::before{
		content: "提供　便利堂";
		position: absolute;
		bottom: 58px;
		left: 10px;
		color: #fff;
		font-size: .8rem;
	}
	
	#enrich h2{
		margin-bottom: 60px;
	}
	#enrich ul{
		width: 100%;
		max-width: 1770px;
		margin: 0 auto;
		display: flex;
		flex-wrap: wrap;
	}
	#enrich ul li{
		width: calc(100% / 3);
		margin-bottom: 60px;
	}
	#enrich ul li a{
		display: flex;
		flex-direction: column;
	}
	#enrich ul li .imagebox{
		overflow: hidden;
		aspect-ratio: 25/31;
		position: relative;
	}
	#enrich ul li .imagebox img{
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		transition: .5s;
	}
	#enrich ul li a:hover .imagebox img{
		top: -10%;
		left: -10%;
		width: 120%;
	}
	#enrich ul li .textbox{
		padding: 20px 0 0;
		color: #050807;
	}
	#enrich ul li .textbox .category{
		width: fit-content;
		font-size: 0.86rem;
		padding: 0 1.5em;
		border: solid 1px #B5B5B5;
		border-radius: 1.5em;
		margin-bottom: 0.5em;
	}
	#enrich ul li .textbox .title{
		font-size: 1.46rem;
		margin-bottom: 1em;
	}
	#enrich ul li .textbox .internal_links{
		width: fit-content;
		margin: 0 0 0 auto;
		padding: 0 4em 0 0;
		border-bottom: none;
	}
	#enrich ul li .textbox .internal_links::after{
		border-bottom: none;
	}
	
	#journey{
		padding: 40px 0;
	}
	#journey h2{
		margin-bottom: 30px;
	}
	#journey .maintext{
		text-align: center;
		margin-bottom: 60px;
	}
	#_____01 {
		width: 100%;
		max-width: 1500px;
		height: auto;
		aspect-ratio: 1000/637;
		margin: 0 auto 120px;
	}
	#_____01 a,
	#_____02 a {
		display: block;
		position: relative;
	}
	#_____01 a .hover {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		display: none;
	}
	#_____01 a:hover .hover {
		display: block;
	}
	#_____01 a:hover .base {
		opacity: 0;
	}
	#_____01 img,
	#_____02 img {
		height: auto;
	}
	#_____01 .w100 {
		width: 100%;
	}
	#_____01 .w67 {
		width: 67%;
	}
	#_____01 .w64 {
		width: 64%;
	}
	#_____01 .w60 {
		width: 60%;
	}
	#_____01 .w32 {
		width: 32%;
	}
	#_____01 .w31 {
		width: 31%;
	}
	#_____01 .w29 {
		width: 29%;
	}
	#_____01 .w5 {
		width: 5%;
	}
	#_____01 .w4 {
		width: 4%;
	}
	#_____01 .w2 {
		width: 2%;
	}
	#_____01 .w1 {
		width: 1%;
	}
	#_____01 .spacer img{
		height: 1px;
	}
	#journey article{
		width: calc(100% - 40px);
		max-width: 1600px;
		margin: 0 auto 120px;
		display: flex;
	}
	#journey article .leftbox .titlemap{
		position: sticky;
		top: 100px;
		left: 0;
		padding-left: 87px;
	}
	#journey article .leftbox .titlemap h3{
		display: flex;
		width: 87px;
		position: absolute;
		top: 0;
		left: 0;
		font-size: 2.4rem;
		writing-mode: vertical-rl;
		word-break: keep-all;
		color: #050807;
		align-items: center;
	}
	#journey article .leftbox .titlemap h3 span{
		display: inline-block;
		width: 87px;
		height: 87px;
		margin-bottom: 10px;
	}
	#journey article .rightbox ul{
		display: flex;
		flex-wrap: wrap;
	}
	#journey article .rightbox ul li{
		width: 50%;
		position: relative;
		padding: 0 0 60px 60px;
	}
	#journey article .rightbox ul li.view::before,
	#journey article .rightbox ul li.eat::before{
		position: absolute;
		content: "";
		top: 0;
		left: 60px;
		width: 60px;
		height: 60px;
	}
	#journey article .rightbox ul li.view::before{
		background: #fff url("./images/icon_view.png") no-repeat;
		background-size: contain;
	}
	#journey article .rightbox ul li.eat::before{
		background: #fff url("./images/icon_eat.png") no-repeat;
		background-size: contain;
	}
	#journey article .rightbox ul li .textbox{
		display: flex;
		flex-direction: column;
		padding: 20px 0;
	}
	#journey article .rightbox ul li .textbox.noimage{
		padding: 70px 0 20px;
	}
	#journey article .rightbox ul li .textbox .root{
		font-size: 0.86rem;
		color: #050807;
		word-break: keep-all;
		padding-right: 2em;
	}
	#journey article .rightbox ul li .textbox .title{
		font-size: 1.6rem;
		color: #050807;
		word-break: keep-all;
		padding-right: 3em;
/*
		margin-bottom: 1em;
*/
	}
	#journey article .rightbox ul li .links .maplink,
	#journey article .rightbox ul li .links .sitelink{
		display: inline-block;
		width: 105px;
		color: #222222;
		padding: 0 0 0.5em 20px;
		position: relative;
		border-bottom: solid 1px #B5B5B5;
	}
	#journey article .rightbox ul li .links .maplink{
		margin-right: 20px;
	}
	#journey article .rightbox ul li .links .maplink::before,
	#journey article .rightbox ul li .links .sitelink::before{
		position: absolute;
		content: "";
		top: 5px;
		left: 0;
		width: 14px;
		height: 14px;
	}
	#journey article .rightbox ul li .links .maplink::before{
		background: url("../common/images/icon_maplink.png") no-repeat;
		background-size: contain;
	}
	#journey article .rightbox ul li .links .sitelink::before{
		background: url("../common/images/icon_sitelink.png") no-repeat;
		background-size: contain;
	}
	#journey article .rightbox ul li .links .maplink::after,
	#journey article .rightbox ul li .links .sitelink::after{
		position: absolute;
		content: "";
		bottom: 0;
		left: 0;
		width: 0;
		height: 1px;
		background: #000;
		transition: .3s;
	}
	#journey article .rightbox ul li .links .maplink:hover,
	#journey article .rightbox ul li .links .sitelink:hover{
		opacity: .7;
	}
	#journey article .rightbox ul li .links .maplink:hover::after,
	#journey article .rightbox ul li .links .sitelink:hover::after{
		width: 100%;
	}
	
	#events{
		padding: 120px 0;
		background: #050807;
		color: #fff;
	}
	#events .subtitle{
		color: #fff;
	}
	#events h2{
		color: #fff;
		margin-bottom: 80px;
	}
	#events .contentes{
		width: calc(100% - 40px);
		margin: 0 auto;
	}
	#events .contentes .pickup{
		display: flex;
		position: relative;
	}
	#events .contentes .pickup::before{
		position: absolute;
		content: "";
		top: -200px;
		left: -200px;
		width: 440px;
		height: 440px;
		background: url("./images/kazari_circle.webp") no-repeat;
		background-size: contain;
		-webkit-animation: rotation1 60s linear infinite;
		animation: rotation1 60s linear infinite;
		z-index: 1;
	}
	#events .contentes .pickup .imagebox{
		width: 57%;
	}
	#events .contentes .pickup .image{
		width: 100%;
		aspect-ratio: 1000/666;
		position: relative;
	}
	#events .contentes .pickup .imagebox .image::before{
		content: "提供　便利堂";
		position: absolute;
		bottom: 10px;
		right: 10px;
		color: #fff;
		font-size: .8rem;
	}
	#events .contentes .pickup .textbox{
		width: 43%;
		color: #fff;
		padding-left: 80px;
		display: flex;
		flex-direction: column;
		justify-content: center;
	}
	#events .contentes .pickup .textbox .category{
		width: fit-content;
		font-size: 0.86rem;
		padding: 0.2em 2em;
		border: solid 1px #B5B5B5;
		margin-bottom: 1em;
	}
	#events .contentes .pickup .textbox .title{
		font-size: 2rem;
		margin-bottom: 1em;
	}
	#events .contentes .pickup .textbox .text{
		color: #F0F0F0;
		margin-bottom: 60px;
	}
	#events .contentes .wpevet{
		margin-bottom: 80px;
	}
	#events .contentes .wpevet .eventlist{
		display: flex;
		flex-wrap: wrap;
	}
	#events .contentes .wpevet .eventlist li{
		width: calc(100% / 3);
	}
	#events .contentes .wpevet .eventlist li .eventimage{
		width: 100%;
		position: relative;
		margin-bottom: 20px;
	}
	#events .contentes .wpevet .eventlist li .eventimage::before{
		content: "";
		display: block;
		padding-top: 67%;
	}
	#events .contentes .wpevet .eventlist li .eventimage .child{
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		overflow: hidden;
	}
	#events .contentes .wpevet .eventlist li .eventtext{
		width: 100%;
		color: #fff;
		margin-bottom: 2em;
	}
	#events .contentes .wpevet .eventlist li .eventtext .title{
		font-size: 1.46rem;
		margin-bottom: 1em;
	}
	#events .contentes .wpevet .eventlist li .internal_links{
		width: 170px;
		margin: 0 0 0 auto;
	}
	#events .contentes .wpevet .eventlist li .internal_links{
		border-bottom: none;
	}
	#events .contentes .wpevet .eventlist li .internal_links:hover::after{
		width: 0;
	}
	
	#gallery{
		padding: 80px 0;
	}
	#gallery .headbox{
		width: calc(100% - 40px);
		max-width: 1400px;
		margin: 0 auto 40px;
		display: flex;
		justify-content: space-between;
	}
	#gallery .headbox .tab-list {
		display: flex;
	}
	#gallery .headbox .tab-list .tab-item {
		width: 76px;
		font-size: 1.06rem;
		color: #686868;
		border-bottom: solid 1px #B5B5B5;
		padding-bottom: 0.5em;
		display: flex;
		justify-content: center;
		align-items: flex-end;
		cursor: pointer;
	}
	#gallery .headbox .tab-list .tab-item.active {
		color: #101010;
		border-bottom: solid 2px #343434;
	}
	#gallery .tab-content {
		width: 100%;
	}
	#gallery .tab-content .tab-panel {
		display: none;
		overflow: hidden;
	}
	#gallery .tab-content .tab-panel.active {
		display: block;
	}
	#gallery .tab-content .tab-panel .loop-slider {
		display: flex;
		width: max-content;
		animation: infinity-scroll 30s linear infinite;
	}
	#gallery .tab-content .tab-panel .loop-slider .slider_items{
		padding: 0 3px;
	}
	#gallery .tab-content .tab-panel .loop-slider .slider_items .photo{
		display: inline-block;
		height: 30vw;
		padding: 0 3px;
	}
	#gallery .tab-content .tab-panel .loop-slider .slider_items img{
		width: auto;
		height: 100%;
	}
	
	#useful-links .title{
		font-size: 1.86rem;
		text-align: center;
		margin-bottom: 40px;
	}
	#useful-links .links{
		width: calc(100% - 40px);
		max-width: 1030px;
		margin: 0 auto;
		display: flex;
		flex-wrap: wrap;
	}
	
}

@media (max-width: 767px){

	#enrich{
		padding: 40px 20px 20px;
	}
	#enrich ul li{
		width: 100%;
		padding: 0 0 20px 10px;
		margin-bottom: 20px;
		border-bottom: solid 1px #000;
	}
	#enrich ul li a{
		flex-direction: row;
	}
	#enrich ul li .imagebox{
		width: 40%;
	}
	#enrich ul li .textbox{
		width: 60%;
		padding: 20px 0 0 10px;
	}
	
	#journey{
		padding: 20px 0;
	}
	#journey .maintext{
		padding:  0 20px;
		margin-bottom: 30px;
	}
	#_____01{
		display: none;
	}
	#_____02 {
		width: calc(100% - 80px);
		height: auto;
		aspect-ratio: 100/199;
		margin: 0 auto 40px;
	}
	#_____02 .w100 {
		width: 100%;
	}
	#_____02 .w44 {
		width: 44%;
	}
	#_____02 .w32 {
		width: 32%;
	}
	#_____02 .w24 {
		width: 24%;
	}
	#_____02 .w12 {
		width: 12%;
	}
	#journey article{
		margin: 0 auto 40px;
		flex-direction: column;
	}
	#journey article .leftbox{
		width: 100%;
		padding: 20px 30px 20px;
		position: sticky;
		top: 0;
		background: url("/common/images/bg_default.webp") no-repeat;
		z-index: 1;
	}
	#journey article .leftbox .titlemap{
		padding: 0 0 0 50px;
	}
	#journey article .rightbox{
		width: 100%;
	}
	#journey article .rightbox ul li{
		width: 100%;
		position: relative;
		padding: 0 0 60px 0;
	}
	#journey article .rightbox ul li.view::before,
	#journey article .rightbox ul li.eat::before{
		left: 0;
		width: 30px;
		height: 30px;
	}
	
	#events{
		padding: 80px 0 60px;
	}
	#events .contentes .pickup{
		flex-direction: column;
		margin: 0 10px 40px;
	}
	#events .contentes .pickup .imagebox{
		width: 100%;
		margin-bottom: 20px;
	}
	#events .contentes .pickup .textbox{
		width: 100%;
		padding-left: 0;
	}
	#events .contentes .wpevet{
		margin-bottom: 40px;
	}
	#events .contentes .wpevet .eventlist li{
		width: 50%;
		padding: 10px;
	}
	
	#gallery{
		padding: 80px 0 40px;
	}
	#gallery .headbox{
		flex-direction: column;
		align-items: center;
	}
	#gallery .headbox .titlebox h2{
		margin-bottom: 40px;
	}
	#gallery .tab-content .tab-panel .loop-slider .slider_items{
		padding: 0 2px;
	}
	#gallery .tab-content .tab-panel .loop-slider .slider_items .photo{
		height: 50vw;
		padding: 0 2px;
	}
	
	#useful-links{
		padding: 40px 0 80px;
	}
	#useful-links .links li{
		width: calc(100% / 3);
		padding: 5px;
	}
	
}

@media (min-width: 768px){

	#journey article .rightbox ul li.firstspot{
		width: 100%;
	}
	#journey article .rightbox ul li.firstspot .textbox{
		flex-direction: row;
		align-items: center;
	}
	#journey article .rightbox ul li.firstspot .textbox .title{
		margin-bottom: 0;
	}
	#journey article .rightbox ul li.firstspot .links{
		display: flex;
		justify-content: flex-end;
	}
	
	#events .contentes .pickup .textbox .internal_links{
		margin: 0 0 0 auto;
	}
	
	#gallery .headbox .titlebox .subtitle{
		margin: 0 auto 0 0;
	}
	
}

@media (max-width: 1024px){
	
	#journey article .leftbox .titlemap h3{
		width: 50px;
		height: 11em;
		font-size: 2rem;
	}
	#journey article .leftbox .titlemap h3 span{
		width: 50px;
		height: 50px;
	}
	#journey article .rightbox ul li .textbox.noimage{
		padding: 40px 0 20px;
	}
	
	#events .contentes .pickup::before{
		top: -100px;
		left: -100px;
		width: 220px;
		height: 220px;
	}
	
}

@media screen and (min-width: 768px) and (max-width: 1024px){

	#enrich{
		padding: 40px 0 20px 20px;
	}
	#enrich ul li{
		padding: 0 20px 0 10px;
		border-left: solid 1px #000;
	}
	
	#journey{
		padding: 20px 0;
	}
	#_____01 {
		margin: 0 auto 60px;
	}
	#_____02{
		display: none;
	}
	#journey article{
		margin: 0 auto 80px;
	}
	#journey article .leftbox{
		width: 30vw;
	}
	#journey article .leftbox .titlemap{
		padding: 0 0 70px 50px;
	}
	#journey article .rightbox{
		width: 70vw;
	}
	#journey article .rightbox ul li{
		padding: 0 0 30px 30px;
	}
	#journey article .rightbox ul li.view::before,
	#journey article .rightbox ul li.eat::before{
		left: 30px;
		width: 30px;
		height: 30px;
	}
	
	#events{
		padding: 80px 0 60px;
	}
	#events .contentes .pickup{
		margin: 0 15px 80px;
	}
	#events .contentes .pickup .textbox{
		padding-left: 40px;
	}
	#events .contentes .wpevet{
		margin-bottom: 60px;
	}
	#events .contentes .wpevet .eventlist li{
		padding: 15px;
	}
	
	#useful-links{
		padding: 40px 0 120px;
	}
	#useful-links .links li{
		width: 20%;
		padding: 5px;
	}
	
}

@media screen and (min-width: 1025px){
	
	#enrich{
		padding: 80px 20px 80px 60px;
	}
	#enrich ul li{
		padding: 0 50px 0 40px;
		border-left: solid 1px #000;
	}
	
	#_____02{
		display: none;
	}
	#journey article .leftbox{
		width: 40vw;
		padding-right: 30px;
	}
	#journey article .rightbox{
		width: 60vw;
	}
	
	#events .contentes{
		max-width: 1460px;
	}
	#events .contentes .pickup{
		margin: 0 30px 80px;
	}
	#events .contentes .wpevet .eventlist li{
		padding: 30px;
	}
	
	#useful-links{
		padding: 80px 0 200px;
	}
	#useful-links .links li{
		width: 20%;
		padding: 10px;
	}
	
}