@charset "utf-8";
/* CSS Document */
.cf::after {
  content: "";
  display: block;
  clear: both;
}


.mt10 { margin-top: 10px; }
.mt20 { margin-top: 20px; }
.mt30 { margin-top: 30px; }
.mb10 { margin-bottom: 10px; }
.mb20 { margin-bottom: 20px; }
.mb30 { margin-bottom: 30px; }

body#topics {
	box-sizing: border-box;
}

body#topics #contents {
	width: 900px;
	margin: 150px auto 80px;
	text-align: left;
}


body#topics #contents a.link:link,
body#topics #contents a.link:visited,
body#topics #contents a.link:active {
	color: #53585a;
	text-decoration: none;
	border-bottom: #53585a 1px dashed;
}
body#topics #contents a.link:hover {
	color: #aa002b;
	border-bottom: #aa002b 1px dashed;
}
body#topics #contents > h1 {
	font-size: 24px;
	letter-spacing: .1em;
	text-align: center;
	line-height: 1.4;
	border-bottom: #000 1px solid;
	margin: 0 auto 30px;
	padding-bottom: 20px;
}

body#topics #contents p.lead {
	font-size: 16px;
	line-height: 1.8;
	margin-top: 30px;
}

body#topics #contents ul.caution li {
	font-size: 15px;
	text-indent:-1em;
	padding-left:1em;
	line-height: 160%;
	padding-bottom: 8px;
}

body#topics #contents dl.tbl {
	width: 90%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center; /*横*/
	align-items: stretch; /*高さ揃え*/
	margin: auto;
}
body#topics #contents dl.tbl dt {
	width: 10%;
	letter-spacing: 5px;
	line-height: 1.4;
	padding: 5px 0;
}
body#topics #contents dl.tbl dd {
	width: 90%;
	line-height: 1.4;
	padding: 5px 0;
}

body#topics #contents dl.tbl dt::after {
    content: "：";
}
body#topics #contents a.btn {
	display: inline-block;
	color: #fff;
	background-color: #000;
	border-bottom: 0;
	padding: 16px 32px;
	position: relative;
}
body#topics #contents a.btn:before {
content: "";
	display: inline-block;
	background-image: url(/common/images/arrow_right_w.png);
	width: 6px;
	height: 14px;
	background-size: contain;
	background-repeat: no-repeat;
	margin-right: 10px;
	position: absolute;
	top: 50%;
	left: 8%;
	-webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}

@media only screen and (max-width: 768px) {
	body#topics {
		width: 100%;
	}
	body#topics #contents {
		width: 90%;
		margin: 150px auto 80px;
	}
	body#topics #contents h1 {
		font-size: 5.5vw;
	}
	body#topics #contents dl.tbl dt {
		width: 20%;
		letter-spacing: 0;
	}
	body#topics #contents dl.tbl dd {
		width: 80%;
	}
}

.pctac {
	text-align: center;
}
	@media only screen and (max-width: 768px) {
		.pctac {
			text-align: left;
		}
	}

@media only screen and (min-width: 768px){
		a.tel {
			pointer-events: none;
			color: #53585a;
			border:none;
		 }
		}
		@media only screen and (max-width: 768px) {
			a.tel {
				color: #333;
				border-bottom:#333 1px solid;
			  }
		}
