/* ============================================================
 * shopInfo.css（shopInfo.html から外だし）
 * ============================================================ */

.shop-info-page {
	background: #f3f4f6;
	padding: 46px 0 90px;
}

.shop-info-container {
	max-width: 1320px;
}

.shop-page-header {
	text-align: center;
	margin-bottom: 42px;
}

.shop-page-title {
	font-size: 36px;
	font-weight: 800;
	line-height: 1.25;
	color: #111827;
	margin-bottom: 16px;
}

.shop-page-subtitle {
	font-size: 20px;
	line-height: 1.8;
	color: #6b7280;
	margin-bottom: 0;
}

/* ---- 電話お問い合わせバナー ---- */
.shop-tel-banner {
	background: #2563eb;
	border-radius: 16px;
	padding: 32px 24px 28px;
	text-align: center;
	margin-bottom: 34px;
}

.shop-tel-banner-label {
	font-size: 18px;
	font-weight: 700;
	color: #ffffff;
	margin-bottom: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
}

.shop-tel-banner-label i {
	font-size: 20px;
}

.shop-tel-banner-number {
	font-size: 42px;
	font-weight: 800;
	line-height: 1.2;
	color: #ffffff;
	margin-bottom: 10px;
}

.shop-tel-banner-number a {
	color: #ffffff;
	text-decoration: none;
}

.shop-tel-banner-number a:hover {
	text-decoration: underline;
	color: #ffffff;
}

.shop-tel-banner-note {
	font-size: 15px;
	color: rgba(255, 255, 255, 0.85);
	margin-bottom: 0;
}

@media (max-width: 767.98px) {
	.shop-tel-banner {
		padding: 24px 18px 20px;
	}

	.shop-tel-banner-number {
		font-size: 32px;
	}

	.shop-tel-banner-label {
		font-size: 16px;
	}
}

.shop-main-card {
	background: #ffffff;
	border: 1px solid #dbe3ee;
	border-radius: 18px;
	box-shadow: 0 10px 28px rgba(17, 24, 39, 0.08);
	overflow: hidden;
	margin-bottom: 34px;
}

.shop-main-card-header {
	background: #2563eb;
	padding: 28px 36px;
}

.shop-main-card-title {
	font-size: 28px;
	font-weight: 800;
	line-height: 1.4;
	color: #ffffff;
	margin-bottom: 0;
}

.shop-main-card-body {
	display: flex;
	min-height: 560px;
}

.shop-main-info {
	width: 50%;
	padding: 34px 36px 30px;
	background: #ffffff;
}

.shop-main-map {
	width: 50%;
	background: #e5e7eb;
	position: relative;
	min-height: 560px;
}

.shop-map-frame {
	width: 100%;
	height: 100%;
	min-height: 560px;
	border: none;
	display: block;
}

.shop-info-block {
	display: flex;
	align-items: flex-start;
	margin-bottom: 34px;
}

.shop-info-icon {
	width: 44px;
	flex: 0 0 44px;
	display: flex;
	justify-content: center;
	padding-top: 4px;
	color: #2563eb;
	font-size: 26px;
}

.shop-info-content {
	flex: 1;
	padding-left: 10px;
}

.shop-info-label {
	font-size: 16px;
	font-weight: 800;
	line-height: 1.5;
	color: #111827;
	margin-bottom: 10px;
}

.shop-info-text {
	font-size: 16px;
	line-height: 1.9;
	color: #374151;
	margin-bottom: 0;
}

.shop-info-text strong {
	font-size: 18px;
	font-weight: 700;
	color: #111827;
}

.shop-info-phone {
	font-size: 24px;
	font-weight: 800;
	line-height: 1.4;
	color: #2563eb;
	margin-bottom: 0;
}

.shop-info-phone a {
	color: #2563eb;
	text-decoration: none;
}

.shop-info-note {
	font-size: 15px;
	line-height: 1.8;
	color: #6b7280;
	margin-top: 4px;
	margin-bottom: 0;
}

.shop-contact-btn-wrap {
	margin-top: 18px;
}

.shop-contact-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	max-width: 560px;
	height: 72px;
	border: none;
	border-radius: 14px;
	background: #ff6a00;
	color: #ffffff;
	font-size: 18px;
	font-weight: 800;
	box-shadow: 0 12px 26px rgba(255, 106, 0, 0.22);
	text-decoration: none;
	transition: all 0.2s ease;
}

.shop-contact-btn:hover {
	color: #ffffff;
	text-decoration: none;
	background: #f25f00;
}

.shop-benefit-card {
	background: #ffffff;
	border: 1px solid #dbe3ee;
	border-radius: 18px;
	box-shadow: 0 8px 24px rgba(17, 24, 39, 0.06);
	padding: 38px 24px 28px;
	margin-bottom: 34px;
}

.shop-benefit-title {
	font-size: 26px;
	font-weight: 800;
	line-height: 1.5;
	color: #111827;
	text-align: center;
	margin-bottom: 34px;
}

.shop-benefit-item {
	text-align: center;
	padding: 0 18px;
	margin-bottom: 12px;
}

.shop-benefit-icon {
	width: 86px;
	height: 86px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 20px;
	font-size: 34px;
}

.shop-benefit-icon.blue {
	background: #dbeafe;
	color: #2563eb;
}

.shop-benefit-icon.orange {
	background: #ffedd5;
	color: #ff6a00;
}

.shop-benefit-item-title {
	font-size: 18px;
	font-weight: 800;
	line-height: 1.5;
	color: #111827;
	margin-bottom: 10px;
}

.shop-benefit-item-text {
	font-size: 15px;
	line-height: 1.8;
	color: #6b7280;
	margin-bottom: 0;
}

.shop-parking-card {
	background: #edf4ff;
	border: 1px solid #d4e3fb;
	border-radius: 16px;
	padding: 28px 30px;
}

.shop-parking-title {
	display: flex;
	align-items: center;
	font-size: 18px;
	font-weight: 800;
	line-height: 1.5;
	color: #111827;
	margin-bottom: 12px;
}

.shop-parking-title i {
	color: #2563eb;
	font-size: 22px;
	margin-right: 12px;
}

.shop-parking-text {
	font-size: 16px;
	line-height: 1.9;
	color: #4b5563;
	margin-bottom: 0;
}

@media (max-width: 1199.98px) {
	.shop-page-title {
		font-size: 52px;
	}

	.shop-main-card-body {
		min-height: 520px;
	}

	.shop-main-map,
	.shop-map-frame {
		min-height: 520px;
	}
}

@media (max-width: 991.98px) {
	.shop-info-page {
		padding: 34px 0 72px;
	}

	.shop-page-title {
		font-size: 42px;
	}

	.shop-page-subtitle {
		font-size: 18px;
	}

	.shop-main-card-body {
		flex-direction: column;
	}

	.shop-main-info,
	.shop-main-map {
		width: 100%;
	}

	.shop-main-map,
	.shop-map-frame {
		min-height: 420px;
	}

	.shop-benefit-item {
		margin-bottom: 28px;
	}
}

@media (max-width: 767.98px) {
	.shop-info-page {
		padding: 28px 0 56px;
	}

	.shop-page-header {
		margin-bottom: 28px;
	}

	.shop-page-title {
		font-size: 34px;
	}

	.shop-page-subtitle {
		font-size: 16px;
	}

	.shop-main-card-header {
		padding: 22px 20px;
	}

	.shop-main-card-title {
		font-size: 22px;
	}

	.shop-main-info {
		padding: 24px 20px 24px;
	}

	.shop-main-map,
	.shop-map-frame {
		min-height: 320px;
	}

	.shop-info-block {
		margin-bottom: 26px;
	}

	.shop-info-icon {
		width: 36px;
		flex: 0 0 36px;
		font-size: 22px;
	}

	.shop-info-content {
		padding-left: 8px;
	}

	.shop-info-phone {
		font-size: 22px;
	}

	.shop-contact-btn {
		height: 62px;
		font-size: 16px;
	}

	.shop-benefit-card {
		padding: 28px 18px 10px;
	}

	.shop-benefit-title {
		font-size: 22px;
		margin-bottom: 28px;
	}

	.shop-parking-card {
		padding: 22px 18px;
	}

	.shop-parking-text {
		font-size: 15px;
	}
}
