

/*-===============
main
===============-*/

.policy main {
	position: relative;
	width: 60%;
	max-width: 1000px;
	margin: 100px auto 120px;
	}
@media screen and (max-width: 1024px) {
.policy main {
	width: 86%;
	max-width: 86%;
	margin: 70px auto 80px;
	}
	}

.policy main .intro{
	padding-top: 80px;
	}
@media screen and (max-width: 768px) {
.policy main .intro{
	padding-top: 40px;
	}
	}

.policy main .intro p{
	line-height: 1.8em;
	color: #555;
	font-size: 1em;
	}

.policy main .intro h1{
	font-size: 1.3em;
	line-height: 1.7em;
	font-weight: 500;
	text-align: justify;
	text-justify: inter-ideograph;
	word-break:break-all;
	}
@media screen and (max-width: 768px) {
.policy main .intro h1{
	font-size: 1.1em;
	}
	}

.policy.en main .intro h1{
	text-align: left;
	word-break:break-word;
	}

.policy main .contents{
	position: relative;
	width: 100%;
	margin-top: 70px;
	}
@media screen and (max-width: 768px) {
.policy main .contents{
	margin-top: 30px;
	}
	}

.policy main .contents h2{
	margin-top: 40px;
	font-size: 1em;
	font-weight: 500;
	line-height: 1.8em;
	text-align: justify;
	text-justify: inter-ideograph;
	word-break:break-all;
	}

.en.policy main .contents h2{
	text-align: left;
	word-break:break-word;
	}

.policy main .contents h3{
	margin-top: 40px;
	font-size: 1em;
	line-height: 1.8em;
	text-align: justify;
	text-justify: inter-ideograph;
	word-break:break-all;
	}

.en.policy main .contents h3{
	text-align: left;
	word-break:break-word;
	}

.policy main .contents p{
	margin-top: 1.8em;
	font-size: 1em;
	line-height: 1.8em;
	text-align: justify;
	text-justify: inter-ideograph;
	word-break:break-all;
	}

.en.policy main .contents p{
	text-align: left;
	word-break:break-word;
	}

.policy main ul{
	margin-top: 1.8em;
	margin-left: 1.2em;
	}

.policy main ol{
	margin-top: 1.8em;
	margin-left: 1.2em;
	padding-left: 1em;
	}
.policy main ol.caption{
	margin-top: 0;
	margin-left: 0;
	}

.policy main ul.disc-list li{
	list-style-type: disc;
	font-size: 1em;
	margin-left: 1em;
	line-height: 1.8em;
	}

.policy main ol.decimal-list li{
	list-style-type: decimal;
	font-size: 1em;
	line-height: 1.8em;
	}

.policy main ol.decimal-list li ul.disc-list li{
	margin-left: 0;
	}

.policy main ol.decimal-list li:nth-child(n+2){
	margin-top: .75em;
	}
.policy main ol.decimal-list.caption li:nth-child(n+2){
	margin-top: 0;
	}


.policy main ol.decimal-list li ul.disc-list li:nth-child(n+2){
	margin-top: 0;
	}

.fee-table{
	margin-top: 1em;
	width:100%; 
	border-collapse:collapse; 
	table-layout:fixed; 
	}
.fee-table colgroup col.col-total{
	width: 28%
	}
.fee-table colgroup col.col-type{
	width: 22%
	}
.fee-table colgroup col.col-breakdown{
	width: 50%
	}
.fee-table th,
.fee-table td{
	font-size: 1em;
	font-style: normal;
	font-weight: 400;
	line-height: 1.8em;
	border:1px solid #ccc;
	padding:14px 14px; 
	word-break:break-word
	}
@media screen and (max-width: 768px) {
.fee-table th,
.fee-table td{
	font-size: .8em;
	}
	}
.fee-table thead th.center{
	text-align:center
	}


.fee2-table{
	margin-top: 1em;
	width:100%; 
	border-collapse:collapse; 
	table-layout:fixed; 
	}
.fee2-table colgroup col.col-total{
	width: 70%
	}
.fee2-table colgroup col.col-type{
	width: 30%
	}
.en .fee2-table colgroup col.col-total{
	width: 70%
	}
.en .fee2-table colgroup col.col-type{
	width: 30%
	}
.fee2-table th,
.fee2-table td{
	font-size: 1em;
	font-style: normal;
	font-weight: 400;
	line-height: 1.8em;
	border:1px solid #ccc;
	padding:14px 14px; 
	word-break:break-word;
	text-align:left
	}
@media screen and (max-width: 768px) {
.fee2-table th,
.fee2-table td{
	font-size: .8em;
	}
	}

.fee2-table td{
	text-align:center
	}


ol.parentheses li {
	position: relative;
	list-style-type: none;
	line-height: 1.8em;
	}

ol.parentheses li:before {
	position: absolute;
	right: calc(100% + 0.5rem);
	content: "(" counter(list-item) ")";
	}

.tm li {
	margin-top: 5px;
	}



