@charset "utf-8";

/* ==================================================
PC
================================================== */

/* iOSでのボタンデザインをリセット */
button,
input[type="button"],
input[type="submit"] {
	-webkit-appearance: none;
	   -moz-appearance: none;
		appearance: none;
	border-radius: 0;
	cursor: pointer;
	color: inherit;
	font-weight: normal;
	font-style: normal;
}

/* 隠す */
.hide {
	display: block;
	width: 0px;
	height: 0px;
	margin: 0px;
	padding: 0px;
	clip: rect(0,0,0,0);
	overflow: hidden;
}
hr.hide {
	border: none;
}

/* 本文へリンク */
.link_skip.hide {
	width: auto;
	height: auto;
	clip: auto;
}
.link_skip.hide a {
	display: block;
	width: 100%;
	height: 0px;
	overflow: hidden;
	background: #ffffff;
	font-size: 1.4rem;
	line-height: 2em;
	color: #0d59b7;
	text-decoration: underline;
	text-align: center;
}
.link_skip.hide a:focus {
	margin: 5px;
	width: calc(100% - 10px);
	height: auto;
}

/* 外部リンク */
.external_link_text {
	display: none;
}

/* telリンク無効 */
.open_page_id a[href^="tel:"],
.f_number a[href^="tel:"] {
	text-decoration: none !important;
	color: currentColor !important;
	pointer-events: none !important;
}

/* AIレコメンド用スクリプトの読み込みタグを非表示 */
.footer_insert_recommend_js {
	display: none;
}

/* レスポンシブアコーディオン用 */
input[id*="acc_ttl_label"] {
	display: none;
}
.acc_icon {
	display: none;
}

/* レスポンシブアコーディオン用（class付与） */
.acc_title.accordion {
	pointer-events: none;
}
.acc_title.accordion:focus {
	outline: none;
}
.acc_title.accordion a {
	pointer-events: auto;
}

/* Googlemap */
.gglmap {
	position: relative;
	padding-top: 30px;
	padding-bottom: 56.25%;
	height: 0px;
	overflow: hidden;
}
.gglmap iframe,
.gglmap object,
.gglmap embed {
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
}

/* 承認枠 */
#approval_table {
	font-size: 1.4rem;
}

/* ページ内目次 */
#main_body .toc_link_wrap {
	display: none;
}
#sidebar1 .toc_link_wrap,
#sidebar2 .toc_link_wrap {
	display: none;
}

.toc_link_wrap {
	border: 1px solid #cccccc;
	margin: 0px 0px 20px;
}
.toc_link_wrap summary {
	cursor: pointer;
	padding: 10px 20px;
}

.toc_link {
	margin: 0px;
	padding: 10px 20px 20px;
	list-style: none;
}
.toc_link > li:not(:first-child) {
	margin: 10px 0px 0px;
}
.toc_link > li {
	font-size: 1.6rem;
	line-height: 1.5;
}
.toc_link > li a {
	display: inline-block;
}
.toc_link > li.toc_type_h3 {
	margin-left: 10px;
}
.toc_link > li.toc_type_h4 {
	margin-left: 20px;
}
.toc_link > li.toc_type_h5 {
	margin-left: 30px;
}
.toc_link > li.toc_type_h6 {
	margin-left: 40px;
}

.ip_headtype_h2 {
	padding: 0px;
}
.ip_headtype_h3 {
	padding-left: 10px;
	font-size: calc(1em * 0.95);
}
.ip_headtype_h4 {
	padding-left: 20px;
	font-size: calc(1em * 0.9);
}
.ip_headtype_h5 {
	padding-left: 30px;
	font-size: calc(1em * 0.85);
}
.ip_headtype_h6 {
	padding-left: 40px;
	font-size: calc(1em * 0.8);
}

/* アンカーリンク先の目印 */
div[class^="detail_"] span[id^="toc"]:target {
	position: relative;
}
div[class^="detail_"] span[id^="toc"]:target::before {
	content: '';
	position: absolute;
	right: calc(100% + 10px);
	top: -10px;
	display: block;
	width: 0px;
	height: 0px;
	border-width: 10px 0px 10px 17px;
	border-style: solid;
	border-color: transparent;
	border-left-color: currentcolor;
}

/* テーブル表の幅対応 */
.sp_table_wrap2 {
	overflow: auto;
	position: relative;
}

#main_body .sp_large_table .sp_table_wrap {
	width: auto;
	overflow: auto;
}
#main_body .sp_large_table .sp_table_wrap :is(th,td) {
	white-space: nowrap;
}

.sp_button {
	display: none;
}
.sp_button.sw_large_table {
	position: sticky;
	left: 0;
	top: 0;
}

/* ==================================================
PC ここまで
================================================== */

/* ==================================================
タブレット
================================================== */
@media screen and (max-width: 1080px) {

}
/* ==================================================
タブレット ここまで
================================================== */



:focus {
  outline-color: #2171cc;
  outline: 3px double #2171cc #fff; /* 外側の枠線 */
  outline-offset: 2px; /* 枠線同士の距離感 */
  box-shadow:
    -2px -2px #fff, 2px -2px #fff, 2px 2px #fff, -2px 2px #fff;
    position: relative;
    z-index: 1;
}

.sp_button.sw_large_table{
    margin-bottom: 10px;
}
.link_skip.hide a{
    color: #222;
}