@charset "utf-8";
/* CSS Document */


/* ---------------------------------------------------------------------------------------------

   Access

--------------------------------------------------------------------------------------------- */
#public-transport-access{
	margin-bottom: 75px;
}

@media screen and (max-width:550px) {

#public-transport-access{
	margin-bottom: 50px;
}
	
}

.fa-train{
	color: #b393bf;
	font-size: clamp(20px, 2vw, 24px);
}
.fa-car-alt{
	color: #b393bf;
	font-size: clamp(20px, 2vw, 24px);
}
.fa-bus{
	color: #b393bf;
	font-size: clamp(20px, 2vw, 24px);
}


#trainBus-access .contents1200,
#car-access .contents1200,
#public-transport-access .contents1200 {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-start;
}

.access-table{
	width: 47.5%;
	text-align: center;
	margin: 50px 0 90px;
}

caption{
	font-size: clamp(18px, 2vw, 20px);
	margin-bottom: 10px;
	font-weight: bold;
}

.access-table th{
	padding: 15px;
	border-radius: 10em;
	font-size: clamp(14px, 2vw, 16px);
	font-weight: normal;
	line-height: 1;
	color: #fff;
	background: #666;
}

.access-table th.starting-back{
	background: #1b1b1b;
}

.access-table th.accents-back{
	background: #221639;
   color: #fff;
}

@media screen and (max-width:750px) {
	
.access-table th{
	padding: 10px;
}
	
}

.access-table td{
	padding: 15px;
	font-size: clamp(14px, 2vw, 16px);
}

.fa-angle-double-down{
	font-size: clamp(18px, 2vw, 20px);
}

#trainBus-access, #car-access {
	border-bottom: 0.5px solid #ccc;
}

#trainBus-access, #car-access {
	padding-bottom: 0;
}



/* ---------------------------------------------------------------------------------------------

   G-map

--------------------------------------------------------------------------------------------- */
#g-map{
	width: 100%;
	height: 750px;
}

@media screen and (max-width:1250px) {

#g-map{
	height: 500px;
}
	
}

@media screen and (max-width:750px) {

#g-map{
	height: 400px;
}
	
}










.timetable {
	display: block;
	background-color: #b4b4b4;
	margin: 35px auto 10px;
	padding: 12px;
	box-sizing: border-box;
	width: min(90%, 1200px);
	text-align: center;
	color: #fff;
	border-radius: 10px;
}


/* ---------------------------------------------------------------------------------------------

   Transfer

--------------------------------------------------------------------------------------------- */

#transfer {
	padding: 50px 0;
	background: #f9f9f9;
}

.re-h3 {
	font-size: clamp(24px, 3vw, 32px);
	font-weight: bold;
	text-align: center;
	margin-bottom: 40px;
	padding-bottom: 15px;
	border-bottom: 2px solid #162b39;
	width: fit-content;
	margin-left: auto;
	margin-right: auto;
}

.transfer-content {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 20px;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 40px;
}

.transfer-text {
	flex: 1;
}

.transfer-text > p {
	font-size: clamp(14px, 2vw, 16px);
	line-height: 1.8;
	margin-bottom: 15px;
}

.tel-info {
	font-weight: bold;
	color: #162b39;
}

.transfer-table {
	width: 100%;
	margin: 30px 0;
	border-collapse: collapse;
}

.transfer-table th,
.transfer-table td {
	padding: 15px;
	border: 1px solid #ddd;
	font-size: clamp(14px, 2vw, 16px);
	text-align: left;
}

.transfer-table th {
	background: #162b39;
	color: #fff;
	width: 35%;
	font-weight: normal;
}

.transfer-table td {
	background: #fff;
}

.transfer-notes {
	list-style: none;
	padding: 0;
	margin: 20px 0;
}

.transfer-notes li {
	font-size: clamp(13px, 2vw, 15px);
	line-height: 1.8;
	color: #c00;
}

.bus-info {
	margin: 30px 0 10px;
	font-size: clamp(14px, 2vw, 16px);
}

.bus-link {
	margin-top: 10px;
}

.bus-link a {
	color: #0066cc;
	text-decoration: underline;
	font-size: clamp(14px, 2vw, 16px);
}

.bus-link a:hover {
	text-decoration: none;
}

.transfer-image {
	flex: 0 0 480px;
}

.transfer-image img {
	width: 100%;
	height: auto;
	border-radius: 8px;
	box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

@media screen and (max-width: 900px) {
	.transfer-content {
		flex-direction: column;
	}
	
	.transfer-image {
		flex: 1;
		width: 100%;
		max-width: 600px;
		margin: 0 auto;
	}
}


/* ---------------------------------------------------------------------------------------------

   Parking

--------------------------------------------------------------------------------------------- */

#parking {
	padding: 50px 0;
	background: #f9f9f9;
}





