/* base */
@charset "utf-8";

/* CSS Document */

/* タイトルスタイル（全ページ共通） */
.section__title .title__lang {
  display: block;
}
.section__title .title__lang--en {
  color: #e07f81;
  font-size: 1.2rem;
  font-weight: 700;
  text-transform: uppercase;
}
.section__title .title__lang--jp {
  font-size: 2.3rem;
  font-weight: 500;
}
.section__title .title--center {
  text-align: center;
}
.section__title .title--left .title__lang--en {
  margin-bottom: 10px;
}

html {
	scroll-behavior: smooth;
}

.hero {
	background: #FFFFFF;
	position: relative;
}

.hero__container {
	aspect-ratio: 529 / 543;
}

.hero__image {
	position: relative;
	height: 100%;
	width: 100%;
}

.hero__mask {
	bottom: 0;
	position: absolute;
	width: 100%;
}

h1.tittle {
	position: absolute;
	top: 40%;
	left: 50%;
	transform: translateX(-50%);
	color: white;
	font-weight: 500;
	font-size: 3.2rem;
	text-align: center;
	text-shadow: 0 0 4px #3b3b3b,
		0 0 8px #3b3b3b,
		0 0 12px #3b3b3b;
	width: 100%;
}

.mb20 {
	margin-bottom: 20px !important;
}

.mb30 {
	margin-bottom: 30px;
}

.mb40 {
	margin-bottom: 40px;
}

.mb50 {
	margin-bottom: 50px;
}

.mt40 {
	margin-top: 40px !important;
}

.section-title {
	text-align: left;
	margin: 20px 0;
}

.section-title__heading {
	display: flex;
	align-items: flex-start;
	font-size: 1.95rem;
	font-weight: 500;
	color: #333;
	border-bottom: 1px dotted #ccc;
	width: 100%;
	padding-bottom: 10px;
	margin-bottom: 20px;
}

.section-title__icon_ {
	flex: 0 0 0.8em;
	width: 14px;
	height: 14px;
	background-image: url("../../images/policy/tt_icon.png");
	background-repeat: no-repeat;
	background-position: left;
	background-size: contain;
	vertical-align: text-top;
	margin-top: 10px;
	margin-right: 8px;
}

/* パンくずナビ全体 */
.breadcrumb {
	display: inline-flex;
	align-items: center;
	padding: 20px;
	border-bottom: 1px solid #cccccc;
	/* 下のライン */
	margin-bottom: 24px;
	width: 100%;
}

/* リストリセット */
.breadcrumb ul {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
}

.breadcrumb li {
	display: flex;
	align-items: center;
}

/* セパレータ */
.breadcrumb li+li::before {
	content: "―";
	margin: 0 8px;
	color: #bbbbbb;
}

/* リンク */
.breadcrumb a {
	color: #bbbbbb;
	text-decoration: none;
}

.breadcrumb a:hover {
	text-decoration: underline;
}

/* 現在ページ */
.breadcrumb .current {
	color: #e07f81;
	font-weight: bold;
}

/* privacy */

/* Logo switching for dual-logo header */
.header__logo-img--normal {
	display: none;
}

.header__logo.is-visible .header__logo-img--white {
	display: none;
}

.header__logo.is-visible .header__logo-img--normal {
	display: block;
}

.privacy-text {
	font-size: 14px;
	letter-spacing: 0.08em;
	line-height: 1.8;
}

.section-heading {
	font-size: 17px;
}

.privacy-list {
	padding-left: 18px;
}

.privacy-list li {
	list-style-type: decimal;
}

h1.tittle {
	font-size: 27px;
}

[data-page=top] .section__title .title__lang--jp {
	font-size: 23px;
}