@charset "UTF-8";

/*＝＝＝＝＝＝common＝＝＝＝＝＝＝＝*/
section h3 {
	text-align: center;
	margin-bottom: 60px;
	position: relative;
}
section h3 img {
	position: relative;
	z-index: 2;
}
section.colorBg {
	background: #eae7e0;
}


.access_location_wrapp h3.page_title {
        font-family: 'Anton', sans-serif;
    font-size: min(5vw, 50px);
    letter-spacing: 0.1em;
    color:#30a068;
    text-align: center;
    margin-bottom: 50px;
}

.access_location_wrapp h3.page_title.location {
    margin-bottom: 10px;
}


.access_location_wrapp h2 {
    text-align: center;
     font-size: min(3vw, 27px);
    line-height: 200%;
    margin-bottom: 60px;
}

.access_location_wrapp .location_text {
    text-align: center;
    font-size: min(1.5vw, 18px);
    line-height: 200%;
    margin-bottom: 50px;
}



/*＝＝＝＝＝＝access＝＝＝＝＝＝＝＝*/


.acsess_wrapp_in {
    background: #f4f1ef;
    padding: 65px 0;
        font-family: "Noto Sans JP", sans-serif;
}


.acsess_wrapp_in .train_image {
    width: 98%;
    max-width: 1100px;
    margin: 0 auto 50px;
}


.acsess_wrapp_in .train_access {
    width: 98%;
    max-width: 970px;
    margin: 0 auto ;
}

.acsess_wrapp_in .note {
  margin: 0 auto;
}

.busAccessContents figure {
	position: relative;
}
.busAccessContents figure figcaption {
	position: absolute;
    bottom: 10px;
    right: 10px;
    font-size: 12px;
	color: #fff;
    text-shadow: 0px 0px 5px #000;
}
.accessContents {
	/*display: flex;
	justify-content: space-between;
	gap: 30px;*/
}
.accessContents .time .line_text {
	font-size: 12px;
    margin-left: 1.5rem;
}
.accessContents .time .minutes {
	    font-size: min(2.2vw, 30px);
	display: flex;
	align-items: center;
	line-height: 1;
}
.accessContents .time .toho {
	writing-mode: vertical-rl;
	font-size: min(2.2vw, 25px);
	padding-left: 0.35em;
}
.accessContents .time .red-text {
	color: #c0163a;
}
.accessContents .time .bigText {
	font-size: 200%;
	padding-left: 0.1em;
}

.accessContents .time .rail_info {
  	text-align: center;
    margin: 0 auto;
    border-top: 1px solid #333;
    width: 90%;
    max-width: 900px;
    padding-top: 30px;
    padding-bottom: 30px;
}

.accessContents .time ul {
  	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;  
    margin: 0 auto;
    border-top: 1px solid #333;
     border-bottom: 1px solid #333;
    width: 90%;
    max-width: 1100px;
    padding-top: 30px;
    margin-bottom: 30px;
}


.accessContents .time ul li {
	margin-bottom: 30px;
    text-align: left;
}
.accessContents .time ul li small {
	text-align: right;
    display: block;
}
.accessContents .time small {
	font-size: 70%;
}
.accessContents .time .otherText {
	border-top: 1px solid #000;
	border-bottom: 1px solid #000;
	padding: 1em;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
}
.trainAccess {
	padding: 0 !important;
}

.trainAccess .accessRoot {
	display: flex;
	margin-top: 30px;
}
.trainAccess .accessRoot li {
	width: calc(100% / 3);
}
.trainAccess .accessRoot li img {
	width: 100%;
}
.trainAccessContents .time {
	width: 35%;
}
.trainAccessContents .time .otherText {
	margin-bottom: 30px;
}
.trainAccessContents .time .minutes {
	line-height: 1.2;
}
.trainAccessContents ul li:nth-child(2) {
	border-top: 1px solid #000;
	border-bottom: 1px solid #000;
	padding: 1em;
}
.trainAccessContents ul li p {
	justify-content: center;
}
.trainAccessContents ul li p sup {
	font-size: 50%;
	vertical-align: top;
	position: relative;
	top: -0.5em;
}

/*＝＝＝＝＝＝location＝＝＝＝＝＝＝＝*/


.location_wrapp_in {
    background: #fff;
    padding: 65px 0 0;
        font-family: "Noto Sans JP", sans-serif;
}

.location_photo {
    width: 96%;
    max-width: 1190px;
    margin: 0 auto 60px;
}
.location_photo h3 {
    background:#e3e5df;
    padding: 10px 15px;
      font-family: 'Anton', sans-serif;
    font-size: min(2.5vw, 22px);
    letter-spacing: 0.05em;
    color: #666666;
    display: flex;
justify-content: flex-start;
      flex-wrap: wrap;
    align-items: center;
    margin-bottom: 15px;
}
.location_photo h3 span {
    margin-left: 20px;
    font-size: min(2vw, 17px);
        font-family: "Noto Sans JP", sans-serif;
    letter-spacing: 0;
}

.location_photo ul {
    display: flex;
justify-content: space-between;
      flex-wrap: wrap;
    margin-bottom: 40px;
    position: relative;
}
.location_photo ul::after {
    content:"";
  display: block;
  width: 24%;
}


.location_photo ul li {
    width: 24%;
    margin-bottom: 20px;
}
.location_photo ul li img {
    margin-bottom: 10px;
}
.location_photo ul li span {
  font-size: min(1.5vw, 13px);
}


.lifeInfomation .list {
	display: flex;
	justify-content: space-between;
    gap: 30px;
    width: 96%;
    max-width: 1200px;
    margin: 0 auto 50px;
}
.lifeInfomation .listBlock {
	width: calc(100% / 2);
}
.lifeInfomation .listBlock .listTitle {
	background: #81cba6;
    color: #fff;
	padding: 0.5em 1em;
	font-weight: bold;
	margin-bottom: 0.5em;
        display: flex;
    align-items: center;
}
.lifeInfomation .listBlock .listTitle .en {
    font-family: 'Anton', sans-serif;
    font-size: min(2.2vw, 20px);
    margin-right: 10px;
    letter-spacing: 0.05em;
}

.lifeInfomation .listBlock_bg {
    background: #efece8;
    padding: 20px;
    margin-bottom: 30px;
}


.lifeInfomation .listBlock ul {
}

.lifeInfomation .listBlock ul li {
	border-bottom: 1px solid #ccc;
	padding: 1.5em 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
     font-size: min(1.5vw, 13px);
}
.lifeInfomation .listBlock ul li .distance {
	width: auto;
    text-align: right;
    font-size: min(1.5vw, 13px);
}

.locationMap {
	padding: 0 !important;
}

.locationMap {
    width: 96%;
    max-width: 1300px;
    margin: 0 auto;
    border: 1px solid #ccc;
}



@media screen and (max-width: 1200px) {
/*＝＝＝＝＝＝common＝＝＝＝＝＝＝＝*/

/*＝＝＝＝＝＝access＝＝＝＝＝＝＝＝*/
	.busAccess::after {
		top: -10%;
		left: 30px;
		background-size: 70%;
	}
	.busAccessContents .time {
		width: 70%;
	}
	.busAccessContents .photo {
		width: 30%;
	}
	.trainAccessContents .time {
		width: 50%;
	}

/*＝＝＝＝＝＝location＝＝＝＝＝＝＝＝*/
	
}

@media screen and (max-width: 1024px) {
/*＝＝＝＝＝＝access＝＝＝＝＝＝＝＝*/
	.accessContents {
		flex-wrap: wrap;
		flex-direction: column-reverse;
	}
	.accessContents > * {
		width: 100%;
	}	
	.trainAccessContents .time {
		width: 100%;
	}
	.busAccessContents .time, .busAccessContents .photo {
		width: 100%;
	}
/*＝＝＝＝＝＝location＝＝＝＝＝＝＝＝*/
}


@media screen and (max-width: 768px) {
    
    
.underPage .mainVisual .text .en {
    font-size: 8vw;
}
    
    
.access_location_wrapp h3.page_title {
      font-size: min(6.5vw, 55px);
   margin-bottom: 20px;
}
    
    
	section h3 {
		margin-bottom: 30px;
	}
	section h3 img {
		height: auto;
	}
    
.access_location_wrapp h2 {

    font-size: 16px;
    margin-bottom: 50px;
}
    
/*＝＝＝＝＝＝access＝＝＝＝＝＝＝＝*/
    
.acsess_wrapp_in {
    padding: 65px 0 30px;
}
    
    
	.busAccess::after {
		top: -5%;
		left: 15px;
		background-size: 40%;
		z-index: 3;
	}
	.accessContents {
		position: relative;
		z-index: 4;
	}
    
.accessContents .time ul {
    flex-wrap: wrap;
}
.accessContents .time ul li {
    margin-bottom: 30px;
    text-align: left;
}   
    
	.accessContents .time .hankyubus, .accessContents .time .toho {
		font-size: 3.5vw;
	}
	.accessContents .time .minutes {
		font-size: 5.5vw;
	}
	.accessContents .time .otherText {
		display: block;
	}
	.accessContents .time .otherText small {
		display: block;
	}
	.trainAccess::after {
		top: -5%;
		right: 15px;
		background-size: 50%;
		z-index: 3;
	}
	.trainAccess .accessRoot {
		margin-top: 0;
		display: block;
	}
	.trainAccess .accessRoot li {
		width: 100%;
	}
/*＝＝＝＝＝＝location＝＝＝＝＝＝＝＝*/
    
.location_wrapp_in {
    padding: 35px 0 30px;
}
    
    
.location_photo h3 {
    font-size: min(4.5vw, 30px);
}
.location_photo h3 span {
    font-size: min(2.5vw, 18px);
} 
    
.location_photo ul li {
    width: 49%;
    margin-bottom: 15px;
}
.location_photo ul li img {
    margin-bottom: 5px;
}
.location_photo ul li span {
      font-size: min(2.7vw, 14px);
} 
    
	.lifeInfomation::after {
		top: -2%;
		left: 15px;
		background-size: 40%;
		z-index: 3;
	}
	.lifeInfomation h3::after {
		bottom: auto;
		top: 50%;
		transform: translateY(-50%);
	}
	.lifeInfomation .list {
		flex-wrap: wrap;
		position: relative;
		z-index: 4;
	}
    
.lifeInfomation .listBlock .listTitle {
    font-size: min(2.5vw, 18px);
}
    
.lifeInfomation .listBlock .listTitle .en {
    font-size: min(4.5vw, 30px);
}
    
	.lifeInfomation .listBlock {
		width: 100%;
	}
	.locationMap::after {
		background-size: 40%;
		right: 15px;
		top: -18%;
		z-index: 4;
	}
	.locationMap h3::after {
		bottom: auto;
		top: 50%;
		transform: translateY(-50%);
		left: 30px;
	}
	.locationMap p {
		position: relative;
		z-index: 4;
	}
}

@media screen and (min-width:320px) and ( max-width:767px) {
	.leadText h2 {
		font-size: 7vw;
	}
	.trainAccess::after {
		top: -10%;
	}
	.lifeInfomation .listBlock ul:last-child {
		margin-bottom: 0;
	}
	.lifeInfomation .listBlock ul li {
		font-size: 2.7vw;
	}
    .lifeInfomation .listBlock ul li .distance {
    font-size: 2.3vw;
}
	.locationMap::after {
		top: -30%;
	}
	.locationMap h3::after {
		left: 100px;
	}
}



.shop_wrapp {
    width: 100%;
    margin: 0 auto;
}
.shop_wrapp .shop_title {
    width: 94%;
    max-width: 900px;
    margin: 0 auto;
}

.shop_list {
    background: #e06027;
    padding: 40px 0 40px;
    margin-bottom: 50px;
}
.shop_list .shop_listtitle_image {
    width: 90%;
    max-width: 500px;
    margin: 0 auto 20px;
}
.shop_list h3.shop_listtitle {
      text-align: center;
    font-size: min(3vw, 27px);
    line-height: 200%;
    margin-bottom: 40px;
    color: #fff;
}

.shop_list ul {
    width: 96%;
    max-width: 1190px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    position: relative;
}
.shop_list ul li {
    width: 24%;
    margin-bottom: 20px;
    color: #fff;
}
.shop_list ul li .shop_image {
    margin-bottom: 10px;
}

.shop_list ul li h4 {
    text-align: center;
    margin-bottom: 10px
}
.shop_list ul li p {
    margin: 0 5%;
    font-size: min(1.5vw, 13px);
}

@media screen and (max-width: 768px) {
    
.shop_list ul li {
    width: 49%;
    margin-bottom: 20px;
    color: #fff;
}
    
.shop_list ul li h4 {
    text-align: center;
   font-size: min(2.5vw, 15px);
}
    

}



main .note {
	margin-top: 30px;
  }