@charset "UTF-8";

/* ========================================
   災害時対策についてページ (Safety Page)
======================================== */

/* --- ページヘッダー --- */
.safety-header {
	background: url('../img/common/corporate-subpage-header-image.png') no-repeat center center / cover;
	padding: 35px 20px;
	text-align: center;
}

.safety-header-title {
	color: #877469;
	font-size: 2rem;
	font-weight: 700;
	letter-spacing: 0.5em;
}

/* --- コンテンツセクション --- */
.safety-section {
	padding: 80px 0;
}

.safety-intro {
	line-height: 2;
	color: #808080;
	font-size: 1.1rem;
	margin: 0;
}

/* --- 行動指針セクション --- */
.safety-guidelines {
	background-color: #ffffff;
	padding: 80px 0;
}

.safety-guidelines-list {
	display: grid;
	grid-auto-rows: 1fr;
	gap: 30px;
}

.safety-guidelines-item {
	background-color: #fcf7e8;
	padding: 10px 40px 10px 130px;
	position: relative;
	min-height: 100px;
	display: flex;
	align-items: center;
}

.safety-guidelines-number {
	position: absolute;
	left: 45px;
	top: 50%;
	transform: translateY(-50%);
	font-size: 4rem;
	font-weight: 700;
	color: #6a9b1b;
}

.safety-guidelines-text {
	font-size: 1.1rem;
	line-height: 2;
	color: #666666;
	font-weight: 500;
	margin: 0;
}

.safety-guidelines-keyword {
	color: #ff7676;
	font-weight: 700;
}

/* --- 連絡方法セクション --- */
.safety-contact-method {
	padding: 80px 0;
}

.safety-contact-method-title {
	font-size: 1.8rem;
	font-weight: 400;
	color: #4d4d4d;
	margin: 0 0 30px;
}

.safety-contact-method-box {
	background-color: #fcf7e8;
	padding: 30px 50px;
}

.safety-contact-method-text {
	font-size: 1.3rem;
	font-weight: 500;
	color: #333;
	line-height: 2;
	margin: 0;
}

.safety-contact-method-highlight {
	color: #6a9b1b;
	font-weight: 700;
}

/* --- 連絡先詳細セクション --- */
.safety-contact-detail {
	background-color: #fcf7e8;
	padding: 80px 0;
}

.safety-contact-detail-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px 80px;
}

.safety-contact-detail-heading {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 1.5rem;
	font-weight: 400;
	color: #333;
	margin: 0 0 20px;
}

.safety-contact-detail-dot {
	display: inline-block;
	width: 24px;
	height: 24px;
	background-color: #ffbe71;
	border-radius: 50%;
	flex-shrink: 0;
}

.safety-contact-detail-desc {
	background-color: #fff;
	border: 1px solid #ddd;
	padding: 25px 30px;
	margin-bottom: 20px;
}

.safety-contact-detail-desc p {
	font-size: 1rem;
	line-height: 1.8;
	color: #555;
	margin: 0;
}

.safety-contact-detail-table {
	width: 100%;
	border-collapse: collapse;
}

.safety-contact-detail-table th,
.safety-contact-detail-table td {
	padding: 12px 20px;
	border: 1px solid #ddd;
	font-size: 1rem;
}

.safety-contact-detail-table th {
	background-color: #a3938b;
	color: #fff;
	font-weight: 700;
	text-align: center;
	white-space: nowrap;
	width: 120px;
}

.safety-contact-detail-table td {
	background-color: #fff;
}

.safety-contact-detail-table td a {
	color: #333;
	text-decoration: underline;
}

.safety-contact-detail-right {
	display: flex;
	flex-direction: column;
	gap: 40px;
}

/* --- 災害用伝言ダイヤルセクション --- */
.safety-dial {
	padding: 80px 0;
}

.safety-dial-title {
	font-size: 1.8rem;
	font-weight: 700;
	color: #6a9b1b;
	letter-spacing: 0.1em;
	margin: 0 0 20px;
}

.safety-dial-desc {
	font-size: 1rem;
	line-height: 2;
	color: #808080;
	margin: 0 0 40px;
}

.safety-dial-table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: 30px;
}

.safety-dial-table thead th {
	background-color: #a3938b;
	color: #fff;
	font-size: 1.1rem;
	font-weight: 700;
	padding: 14px 20px;
	text-align: center;
	letter-spacing: 0.1em;
}

.safety-dial-table-record {
	background-color: #cea89b !important;
}

.safety-dial-table-play {
	background-color: #e0aea4 !important;
}

.safety-dial-table-empty {
	background-color: #fff !important;
	border: none !important;
}

.safety-dial-table tbody th {
	background-color: #a3938b;
	color: #fff;
	font-size: 1.0rem;
	font-weight: 700;
	padding: 14px 20px;
	text-align: center;
	border: 1px solid #ddd;
}

.safety-dial-table tbody td {
	background-color: #fff;
	font-size: 1rem;
	padding: 14px 20px;
	text-align: center;
	border: 1px solid #ddd;
	color: #333;
}

.safety-dial-notes p {
	font-size: 1.0rem;
	line-height: 1.8;
	color: #808080;
	margin: 0;
}

/* --- 災害用伝言ダイヤル利用方法セクション --- */
.safety-dial-usage {
	padding: 80px 0;
	background-color: #ffffff;
}

.safety-dial-usage-title {
	font-size: 1.8rem;
	font-weight: 700;
	color: #6a9b1b;
	letter-spacing: 0.1em;
	margin: 0 0 15px;
}

.safety-dial-usage-desc {
	font-size: 1.0rem;
	color: #808080;
	margin: 0 0 40px;
}

.safety-dial-usage-heading {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 1.5rem;
	font-weight: 400;
	color: #4d4d4d;
	margin: 0 0 25px;
}

.safety-dial-usage-dot {
	display: inline-block;
	width: 24px;
	height: 24px;
	background-color: #ffbe71;
	border-radius: 50%;
	flex-shrink: 0;
}

.safety-dial-usage-flow {
	display: flex;
	align-items: stretch;
	gap: 15px;
	margin-bottom: 50px;
}

.safety-dial-usage-step {
	flex: 1;
	background-color: #fcf7e8;
	padding: 25px 20px;
	text-align: center;
	min-height: 100px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.safety-dial-usage-step p {
	font-size: 1.0rem;
	line-height: 1.8;
	color: #466b00;
	margin: 0;
}

.safety-dial-usage-step strong {
	color: #ff7676;
	font-weight: 700;
}

.safety-dial-usage-arrow {
	display: block;
	width: 0;
	height: 0;
	border-top: 12px solid transparent;
	border-bottom: 12px solid transparent;
	border-left: 16px solid #6a9b1b;
	flex-shrink: 0;
	align-self: center;
}

/* --- 帰宅困難になった場合の心得セクション --- */
.safety-stranded {
	padding: 80px 0;
}

.safety-stranded-title {
	font-size: 1.8rem;
	font-weight: 700;
	color: #6a9b1b;
	letter-spacing: 0.1em;
	margin: 0 0 25px;
}

.safety-stranded-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 15px;
	margin-bottom: 60px;
}

.safety-stranded-item {
	background-color: #e9f4c3;
	padding: 18px 25px;
	font-size: 1.0rem;
	line-height: 1.8;
	color: #466b00;
	display: flex;
	align-items: center;
	gap: 8px;
}

.safety-stranded-check {
	color: #6a9b1b;
	font-weight: 700;
	flex-shrink: 0;
}

.safety-stranded-heading {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 1.5rem;
	font-weight: 400;
	color: #4d4d4d;
	margin: 0 0 25px;
}

.safety-stranded-dot {
	display: inline-block;
	width: 24px;
	height: 24px;
	background-color: #ffbe71;
	border-radius: 50%;
	flex-shrink: 0;
}

.safety-stranded-info {
	background-color: #fcf7e8;
	padding: 15px 35px;
}

.safety-stranded-info p {
	font-size: 1.2rem;
	line-height: 2;
	color: #877469;
	font-weight: bold;
	margin: 0;
}

/* ========================================
   レスポンシブ - タブレット
======================================== */
@media screen and (max-width: 1023px) {
	.safety-header {
		padding: 40px 20px;
	}

	.safety-header-title {
		font-size: 1.6rem;
	}

	.safety-section {
		padding: 60px 0;
	}

	.safety-guidelines {
		padding: 60px 0;
	}

	.safety-guidelines-item {
		padding: 25px 30px 25px 85px;
	}

	.safety-guidelines-number {
		left: 25px;
		font-size: 2.2rem;
	}

	.safety-contact-method {
		padding: 60px 0;
	}

	.safety-contact-method-box {
		padding: 25px 30px;
	}

	.safety-contact-method-text {
		font-size: 1.1rem;
	}

	.safety-contact-detail {
		padding: 60px 0;
	}

	.safety-contact-detail-grid {
		gap: 30px 40px;
	}

	.safety-dial {
		padding: 60px 0;
	}

	.safety-dial-usage {
		padding: 60px 0;
	}

	.safety-dial-usage-flow {
		gap: 10px;
	}

	.safety-dial-usage-step {
		padding: 20px 15px;
	}

	.safety-dial-usage-step p {
		font-size: 1.0rem;
	}

	.safety-dial-usage-arrow {
		border-top: 8px solid transparent;
		border-bottom: 8px solid transparent;
		border-left: 12px solid #6a9b1b;
	}

	.safety-stranded {
		padding: 60px 0;
	}

}

/* ========================================
   レスポンシブ - スマホ
======================================== */
@media screen and (max-width: 767px) {
	.safety-header {
		padding: 30px 15px;
	}

	.safety-header-title {
		font-size: 1.3rem;
		letter-spacing: 0.2em;
	}

	.safety-section {
		padding: 40px 0;
	}

	.safety-guidelines {
		padding: 40px 0;
	}

	.safety-guidelines-list {
		gap: 15px;
	}

	.safety-guidelines-item {
		padding: 20px 20px 20px 70px;
	}

	.safety-guidelines-number {
		left: 18px;
		font-size: 1.8rem;
	}

	.safety-guidelines-text {
		font-size: 1.0rem;
	}

	.safety-contact-method {
		padding: 40px 0;
	}

	.safety-contact-method-title {
		font-size: 1.4rem;
	}

	.safety-contact-method-box {
		padding: 20px 25px;
	}

	.safety-contact-method-text {
		font-size: 1rem;
	}

	.safety-contact-detail {
		padding: 40px 0;
	}

	.safety-contact-detail-grid {
		grid-template-columns: 1fr;
		gap: 30px;
	}

	.safety-contact-detail-heading {
		font-size: 1.3rem;
	}

	.safety-contact-detail-desc {
		padding: 20px;
	}

	.safety-contact-detail-right {
		gap: 30px;
	}

	.safety-contact-detail-table,
	.safety-contact-detail-table tbody,
	.safety-contact-detail-table tr,
	.safety-contact-detail-table th,
	.safety-contact-detail-table td {
		display: block;
		width: 100%;
	}

	.safety-contact-detail-table th {
		width: 100%;
	}

	.safety-dial {
		padding: 40px 0;
	}

	.safety-dial-title {
		font-size: 1.4rem;
	}

	.safety-dial-desc {
		margin-bottom: 25px;
	}

	.safety-dial-table thead th {
		font-size: 1.0rem;
		padding: 10px 8px;
	}

	.safety-dial-table tbody th {
		font-size: 1.0rem;
		padding: 10px 8px;
		width: 80px;
	}

	.safety-dial-table tbody td {
		font-size: 1.0rem;
		padding: 10px 8px;
	}

	.safety-dial-usage {
		padding: 40px 0;
	}

	.safety-dial-usage-title {
		font-size: 1.4rem;
	}

	.safety-dial-usage-heading {
		font-size: 1.2rem;
	}

	.safety-dial-usage-flow {
		flex-direction: column;
		gap: 0;
		margin-bottom: 40px;
	}

	.safety-dial-usage-step {
		padding: 20px;
		min-height: auto;
	}

	.safety-dial-usage-step p {
		font-size: 1.0rem;
	}

	.safety-dial-usage-arrow {
		border-top: none;
		border-bottom: none;
		border-left: 12px solid transparent;
		border-right: 12px solid transparent;
		border-top: 16px solid #6a9b1b;
		width: 0;
		height: 0;
	}

	.safety-stranded {
		padding: 40px 0;
	}

	.safety-stranded-title {
		font-size: 1.4rem;
	}

	.safety-stranded-grid {
		grid-template-columns: 1fr;
		gap: 10px;
		margin-bottom: 40px;
	}

	.safety-stranded-item {
		padding: 15px 20px;
		font-size: 1.0rem;
	}

	.safety-stranded-heading {
		font-size: 1.2rem;
	}

	.safety-stranded-info {
		padding: 20px 25px;
	}

	.safety-stranded-info p {
		font-size: 1.0rem;
	}

}
