@charset "UTF-8";

/* ====================================
   Access Template 専用スタイル
   ==================================== */

/* ブロック共通（マージン） */
.access-block {
	display: grid;
	gap: 1.5em;
}

.access-block + .access-block {
	margin-top: 2em;
}

/* メインエリア: 地図 + 住所・営業時間 */
@media (min-width: 768px) {
	.access-block:first-of-type {
		grid-template-columns: 1.5fr 1fr;
	}
}

.access-map iframe {
	width: 100%;
	height: 300px;
	border: none;
	border-radius: 4px;
}

@media (max-width: 767px) {
	.access-map iframe {
		height: 250px;
	}
}

/* 住所・営業時間リスト */
.access-info-list {
	display: grid;
	gap: 0;
}

.access-info-list dt,
.access-info-list dd {
	margin: 0;
	padding: 0.5em 0;
	border-bottom: 1px solid light-dark(#eee, #444);
}

.access-info-list dt {
	font-weight: bold;
	color: light-dark(#555, #bbb);
	font-size: 0.85em;
}

.access-info-list dd {
	color: light-dark(#333, #ddd);
	line-height: 1.6;
}

/* PC: 横並び表形式 */
@media (min-width: 768px) {
	.access-info-list {
		grid-template-columns: 6em 1fr;
	}

	.access-info-list dt {
		grid-column: 1;
	}

	.access-info-list dd {
		grid-column: 2;
	}
}

/* SP: 縦並び */
@media (max-width: 767px) {
	.access-info-list {
		grid-template-columns: 1fr;
	}

	.access-info-list dt {
		padding-bottom: 0.2em;
		border-bottom: none;
	}

	.access-info-list dd {
		padding-top: 0;
		margin-bottom: 0.5em;
	}
}

/* ====================================
   画像+テキストブロック（2カラム）
   ==================================== */

@media (min-width: 768px) {
	.access-block-cols {
		grid-template-columns: 1fr 1fr;
	}
}

.access-block-image img {
	width: 100%;
	height: auto;
	border-radius: 4px;
}

.access-block-text {
	line-height: 1.8;
}

.access-block-text p {
	margin-bottom: 1em;
}

.access-block-text p:last-child {
	margin-bottom: 0;
}
