/* ==================================================
   Policy Page - Hotel de H
================================================== */

.policy-page {
	background: #f5f1ea;
	padding: 72px 24px 104px;
	color: #222;

	font-family:
		"Yu Mincho",
		"Hiragino Mincho ProN",
		"YuMincho",
		"Hiragino Mincho Pro",
		serif;

	font-size: 15px;
	line-height: 2.2;
	letter-spacing: .05em;
	font-feature-settings: "palt";
}

.policy-container {
	max-width: 960px;
	margin: 0 auto;
}

.policy-container h1 {
	margin: 0 0 56px;
	text-align: center;

	font-size: 22px;
	line-height: 1.8;
	letter-spacing: .12em;
	font-weight: 500;
}


/* ==============================
Index
============================== */

.policy-index {
	margin-bottom: 72px;
	padding: 34px 42px;
	background: rgba(255,255,255,.42);
	border: 1px solid rgba(0,0,0,.14);
}

.policy-index h2 {
	margin: 0 0 22px;
	padding-bottom: 14px;
	border-bottom: 1px solid rgba(0,0,0,.18);

	font-size: 16px;
	line-height: 1.8;
	letter-spacing: .14em;
	font-weight: 500;
}

.policy-index ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

.policy-index li {
	margin: 0 0 10px;
}

.policy-index li:last-child {
	margin-bottom: 0;
}

.policy-index a {
	color: #222;
	text-decoration: none;

	font-size: 15px;
	line-height: 1.9;
	letter-spacing: .05em;
	font-weight: 400;
}

.policy-index a:hover {
	opacity: .65;
}


/* ==============================
Section
============================== */

.policy-section {
	margin-bottom: 88px;
	padding-top: 8px;
	scroll-margin-top: 120px;
}

.policy-section:last-child {
	margin-bottom: 0;
}

.policy-section h2 {
	margin: 0 0 30px;
	padding-bottom: 14px;
	border-bottom: 1px solid rgba(0,0,0,.42);

	font-size: 22px;
	line-height: 1.8;
	letter-spacing: .08em;
	font-weight: 500;
}


/* ==============================
Content
============================== */

.policy-content {
	max-width: 900px;

	font-size: 15px;
	line-height: 2.2;
	letter-spacing: .05em;
	font-weight: 400;
}

.policy-content p {
	margin: 0 0 1.45em;
}

.policy-content p:empty {
	display: none;
}

.policy-content ul,
.policy-content ol {
	margin: 0 0 1.6em;
	padding-left: 1.5em;
}

.policy-content li {
	margin-bottom: .45em;
}

.policy-content strong,
.policy-content b {
	font-weight: 600;
}

.policy-content h3,
.policy-content h4 {
	margin: 2.6em 0 1em;

	font-size: 16px;
	line-height: 1.8;
	letter-spacing: .08em;
	font-weight: 600;
}

.policy-content hr {
	margin: 48px 0;
	border: none;
	border-top: 1px solid rgba(0,0,0,.18);
}

.policy-content table {
	width: 100%;
	margin: 2rem 0;
	border-collapse: collapse;

	font-size: 14px;
	line-height: 1.9;
	letter-spacing: .04em;
}

.policy-content th,
.policy-content td {
	padding: 12px 14px;
	border: 1px solid rgba(0,0,0,.18);
	vertical-align: top;
}

.policy-content th {
	background: rgba(255,255,255,.45);
	font-weight: 500;
}


/* ==============================
Mobile
============================== */

@media (max-width: 1024px) {
	.policy-page {
		padding: 56px 20px 88px;
	}

	.policy-container {
		max-width: 100%;
	}

	.policy-container h1 {
		margin-bottom: 42px;
		font-size: 20px;
		letter-spacing: .08em;
	}

	.policy-index {
		margin-bottom: 56px;
		padding: 28px 24px;
	}

	.policy-section {
		margin-bottom: 72px;
	}

	.policy-section h2 {
		font-size: 20px;
	}
}

@media (max-width: 767px) {
	.policy-page {
		padding: 44px 18px 72px;

		font-size: 14px;
		line-height: 2;
		letter-spacing: .04em;
	}

	.policy-container h1 {
		font-size: 18px;
		line-height: 1.7;
	}

	.policy-index h2 {
		font-size: 15px;
	}

	.policy-index a,
	.policy-content {
		font-size: 14px;
		line-height: 2;
		letter-spacing: .04em;
	}

	.policy-content h3,
	.policy-content h4 {
		font-size: 15px;
	}

	.policy-content table {
		font-size: 13px;
	}
}