@charset "utf-8";

/* ============================================================

	base

============================================================ */

html {
	height: 100%;
	font-size: 62.5%;
}

body {
	height: 100%;
	background: #fff;
	color: #000;
	font-size: 1.6rem;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

#skip_link a {
	display: block;
	overflow: hidden;
	height: 1px;
	text-indent: -9999px;
}

#skip_link a:active,
#skip_link a:focus {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 9999;
	overflow: visible;
	width: 100%;
	height: auto;
	text-indent: 0;
	text-align: center;
	padding: 1rem;
	background: #fff;
}

#skip_main {
	overflow: hidden;
	height: 1px;
	text-indent: -9999px;
}

a:link {
	text-decoration: none;
}

a:focus {
	text-decoration: underline;
}

img {
	max-width: 100%;
	height: auto;
	border: 0;
	image-rendering: -webkit-optimize-contrast;
}

a img {
	overflow: hidden;
}

a.ov:hover img,
img.ov:hover {
	opacity: 0.7;
}

strong,
b,
.bold {
	font-weight: 700;
}

/* ============================================================

	parts

============================================================ */

.common_inner {
	max-width: 1000px;
	width: 100%;
	margin: 0 auto;
	padding: 0 10px 0;
}

body.fs_l .common_inner {
	max-width: 1470px;
}

body.fs_xl .common_inner {
	max-width: 1960px;
}

.clear {
	clear: both;
	height: 1px;
	overflow: hidden;
}

.clfx::after {
	content: "";
	display: block;
	clear: both;
}

.clfx::before {
	content: "";
	display: block;
	clear: both;
}

.clfx {
	display: block;
}

.nobr {
	white-space: nowrap;
}

.wbreak {
	word-break: break-all;
}

.indent_kakko {
	margin-left: -0.5em;
}

.indent_1em {
	display: inline-block;
	padding-left: 1em;
	text-indent: -1em;
}

.indent_0 {
	text-indent: 0 !important;
}

.ls_0_5em {
	letter-spacing: 0.5em;
}

.ls_1em {
	letter-spacing: 1em;
}

.text_right {
	text-align: right;
}

.text_center {
	text-align: center;
}

.font_normal {
	font-weight: 400 !important;
}

.font_weight_thin {
	font-weight: 100;
}

.font_weight_exlight {
	font-weight: 200;
}

.font_weight_light {
	font-weight: 300;
}

.font_weight_medium {
	font-weight: 500;
}

.font_weight_semibold {
	font-weight: 600;
}

.font_weight_bold {
	font-weight: 700;
}

.font_weight_exbold {
	font-weight: 800;
}

.font_weight_black {
	font-weight: 900;
}

.color_black {
	color: #000 !important;
}

.mb_0 {
	margin-bottom: 0 !important;
}

.mb_1_5em {
	margin-bottom: 1.5em !important;
}

.mb_0_5rem {
	margin-bottom: 0.5rem !important;
}

.mb_1rem {
	margin-bottom: 1rem !important;
}

.mb_2rem {
	margin-bottom: 2rem !important;
}

.mb_3rem {
	margin-bottom: 3rem !important;
}

.mt_1_5em {
	margin-top: 1.5em !important;
}

.mt_0_5rem {
	margin-top: 0.5rem !important;
}

.mt_1rem {
	margin-top: 1rem !important;
}

.mt_2rem {
	margin-top: 2rem !important;
}

.mt_3rem {
	margin-top: 3rem !important;
}

sup {
	display: inline-block;
	font-size: 75.5%;
	vertical-align: top;
	position: relative;
	top: -0.1em;
	text-indent: 0;
}

sub {
	display: inline-block;
	font-size: 75.5%;
	vertical-align: bottom;
	position: relative;
	bottom: 0;
	text-indent: 0;
}

.ruby {
	font-size: 70%;
}

.ruby::before {
	content: '(';
	padding-left: 0.3em;
}

.ruby::after {
	content: ')';
	padding-right: 0.3em;
}

.sp_show,
.large_show {
	display: none !important;
}

body.fs_l .fs_l_show,
body.fs_xl .fs_xl_show {
	display: block !important;
}

body.fs_l .fs_l_show.inline,
body.fs_xl .fs_xl_show.inline {
	display: inline !important;
}

body.fs_l .fs_l_hide,
body.fs_xl .fs_xl_hide {
	display: none !important;
}

.inline_block {
	display: inline-block;
}

.icon_unit {
	display: inline-flex;
	align-items: center;
}

.icon_unit img {
	width: 1em;
	height: auto;
	margin-right: 0.2em;
}

.font_sans_serif {
	font-family: sans-serif;
}

#article p.small {
	font-size: 1.4rem;
}

.anchor {
	padding-top: 5rem;
	margin-top: -5rem;
}

body.fs_l .responsive_hide,
body.fs_xl .responsive_hide {
	display: none !important;
}

@media screen and (max-width: 979px) {

	.responsive_hide {
		display: none !important;
	}

}

@media screen and (max-width: 767px) {

	.sp_show {
		display: block !important;
	}

	.sp_show.inline {
		display: inline !important;
	}

	.sp_hide {
		display: none !important;
	}

	.anchor {
		padding-top: 0;
		margin-top: 0;
	}

}

/* ============================================================

	header

============================================================ */

#header_navi {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 998;
	width: 100%;
	padding: 5px 15px;
}

@media print {

	#header_navi {
		position: static;
	}

}

#header_navi_inner {
	position: relative;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

#logo_shouhi {
	width: 270px;
}

#header .layout {
	flex: 1;
	display: flex;
	justify-content: flex-end;
	align-items: center;
	padding-right: 90px;
}

#font_size,
#voice {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	font-size: 1.4rem;
}

#font_size dt,
#voice dt {
	color: #000;
}

#font_size dd,
#voice dd a {
	display: inline-block;
	margin-left: 0.5rem;
	padding: 0.5rem 0.9rem 0.6rem;
	border-radius: 0.5rem;
	cursor: pointer;
	text-decoration: none;
}

body.fs_s #font_size dd.shrink,
body.fs_xl #font_size dd.enlarge {
	cursor: auto;
}

#voice {
	margin: 0 0 0 20px;
}

#search {
	margin: 0 0 0 20px;
}

#search form.gsc-search-box {
	margin-bottom: 0;
}

#search .gsc-control-cse {
	padding: 0;
	border: none;
	background: none;
}

#search .gsc-input {
	width: 200px;
	padding-right: 5px;
	font-size: 1.6rem;
}

#search .gsc-input-box {
	padding: 0;
	border-radius: 0;
}

#search .gsst_a .gscb_a {
	color: #000;
}

#search button.gsc-search-button {
	padding: 0.6rem 1.5rem;
	border-radius: 0.5rem;
	cursor: pointer;
}

#search button.gsc-search-button svg {
	width: 1.3rem;
	height: 1.3rem;
}

#search .gsib_b {
	height: auto;
}

@media print {

	#font_size,
	#voice,
	#search {
		display: none;
	}

}

#site_title {
	padding: 65px 0 20px;
	text-align: center;
}

body.fs_l #site_title {
	padding-top: 80px;
}

body.fs_xl #site_title {
	padding-top: 90px;
}

#header_logo a {
	display: inline-block;
}

#header_logo a:hover img {
	opacity: 0.9;
}

@media screen and (max-width: 1200px) {

	body.fs_l #search {
		display: none;
	}

}

@media screen and (max-width: 1020px) {

	#search {
		display: none;
	}

}

@media screen and (max-width: 979px) {

	#voice {
		margin-left: 10px;
	}

}

@media screen and (max-width: 767px) {

	#site_title {
		padding: 44px 0 0 !important;
	}

	#header_logo {
		padding: 0.5rem 0 0.8rem;
		text-align: center;
    max-width: 80%;
    margin: 0 auto;
	}

	#site_number {
		padding: 0.1rem 0 0.2rem;
	}

}

/* ============================================================

	gnavi

============================================================ */

#gnavi {
	position: fixed;
	top: 0;
	right: 0;
	z-index: 90;
}

.btn-trigger {
  position: relative;
  width: 50px;
  height: 47.5px;
  cursor: pointer;
}
.btn-trigger span {
  position: absolute;
  left: 10px;
  width: 30px;
  height: 2px;
  background-color: #fff;
  border-radius: 2px;
}
.btn-trigger, .btn-trigger span {
  display: inline-block;
  transition: all .5s;
  box-sizing: border-box;
}
.btn-trigger span:nth-of-type(1) {
  top: 12px;
}
.btn-trigger span:nth-of-type(2) {
  top: 22px;
}
.btn-trigger span:nth-of-type(3) {
  bottom: 13px;
}

#gnavi .menu {
	visibility: hidden;
	position: fixed;
	top: 0;
	right: -100%;
	z-index: 999;
	height: 100%;
	padding: 2rem 1rem;
	transition: right 0.4s;
	background: #000;
	color: #fff;
}

#gnavi .menu.open {
	visibility: visible;
	right: 0;
}

#gnavi .menu .close_btn {
	display: block;
	width: 6em;
	padding: 0.5rem;
	margin: 2rem auto 0;
	background: #fff;
	text-align: center;
	cursor: pointer;
	color: #000;
}

#gnavi .menu .navi a {
	display: block;
	padding: 1rem 1.5rem;
	border-bottom: 1px solid #333;
	background: #fff;
	color: #000;
	text-decoration: none;
}

#gnavi .menu .navi a::before {
	margin-right: 0.8rem;
	font-family: 'Font Awesome 5 Free';
	content: '\f152';
	font-weight: 700;
}

#gnavi .menu navi li {
	margin-bottom: 0.2rem;
}

@media print {

	#gnavi {
		display: none;
	}

}

@media screen and (max-width: 767px) {

	#gnavi {
		width: 100%;
		top: auto;
		right: 0;
		bottom: -120%;
	}

	#gnavi .btn {
    position: fixed;
		width: 40px;
    height: 35px;
    top: 0;
    right: 0;
		border-radius: 0;
		filter: none;
		background: #000;
		color: #fff;
		text-align: center;
    background-color: #00A0E1;
	}
  
  .btn-trigger {
    position: relative;
    width: 40px;
    height: 35px;
  }
  .btn-trigger span{
    width: 26px;
    left: 7px;
  }
  .btn-trigger span:nth-of-type(1) {
    top: 10px;
  }
  .btn-trigger span:nth-of-type(2) {
    top: 16px;
  }
  .btn-trigger span:nth-of-type(3) {
    bottom: 10px;
  }
  

	#gnavi .menu {
		position: fixed;
		top: auto;
		right: 0;
		bottom: -120%;
		transition: bottom 0.6s;
		width: 100%;
		background: #000;
	}

	#gnavi .menu.open {
		visibility: visible;
		bottom: 0;
	}

	#gnavi #sp_voice {
		margin-bottom: 2rem;
		text-align: right;
		color: #fff;
	}

	#gnavi #sp_voice a {
		display: inline-block;
		background: #fff;
		margin-left: 0.5rem;
		padding: 0.5rem 1rem;
		border-radius: 0.5rem;
		color: #000;
	}

	#sp_navi {
		position: fixed;
		bottom: 0;
		left: 0;
		z-index: 9999;
		display: flex !important;
		justify-content: space-around;
		width: 100%;
		padding: 8px 0;
		box-shadow: 0 -5px 5px -2px rgba(0, 0, 0, 0.5);
	}

	#sp_navi li {
		display: flex;
		width: calc(25% - 2px);
		border-left: 2px solid #fff;
	}

	#sp_navi li.top {
		border-left: none;
	}

	#sp_navi li a,
	#sp_navi li .inner {
		display: flex;
		width: 100%;
		justify-content: center;
		align-items: center;
	}

}

@media screen and (max-width: 321px) {

	#gnavi {
		width: 60px;
	}

}

/* ============================================================

	breadcrumbs

============================================================ */

#breadcrumbs {
	padding: 1rem 0;
	background: #eee;
}

#breadcrumbs li {
	display: inline;
	font-size: 1.3rem;
	line-height: 1.4;
}

#breadcrumbs a {
	color: #000;
	text-decoration: underline;
}

#breadcrumbs a:hover {
	text-decoration: none;
}

#breadcrumbs li.home:after {
	font-family: 'Font Awesome 5 Free';
	content: '\f101';
	font-weight: 700;
	padding: 0 1.5rem;
}

/* ============================================================

	contents

============================================================ */

#contents {
	padding: 20px 0;
}

/*ReadSpeaker*/
#tmp_readspeaker.rsbtn {
	display: block;
	margin: 0 0 1.5rem auto;
}

#article {
	position: relative;
	margin-bottom: 3rem;
	padding: 0;
	line-height: 1.4;
}

#article a:hover {
	text-decoration: underline;
}

#article > .category {
	border-left: 3px solid #fdd000;
	font-size: 2.2rem;
	color: #fff;
	font-weight: 800;
}

#article > .category .bg {
	display: inline-block;
}

#article > .category .inner {
	display: inline-block;
	width: 12em;
	margin-right: -1px; /*背景のずれ解消*/
	padding: 0.8rem;
	padding-left: 1.5rem;
}

#article .main_title_wrap.line {
	margin-bottom: 3rem;
	padding: 0 0 0 1.5rem;
	padding-left: 1.5rem;
	border-left: 5px solid #fdd000;
}

#article .main_title_wrap .main_title {
	font-size: 4rem;
	font-weight: 700;
	line-height: 1.2;
}

#article .main_title_wrap .main_title .small {
	font-size: 3rem;
	font-weight: 600;
}

#article .dl_contact {
	display: flex;
	width: 100%;
	padding: 1rem 1em;
	border-radius: 0.5rem;
	line-height: 1.4;
}

#article .dl_contact dt {
	display: flex;
	justify-content: center;
	align-items: center;
	padding-right: 1em;
	border-right: 1px solid #fff;
	white-space: nowrap;
}

#article .dl_contact dd {
	flex: 1;
	padding-left: 1em;
	font-size: 1.8rem;
}

#article .dl_contact dd .bold {
	font-weight: 800;
}

#article .dl_contact dd .small {
	font-size: 1.4rem;
}

#aside {
	position: relative;
	margin-top: 5rem;
	border: 1px solid #ccc;
	border-radius: 0 0 1rem 1rem;
	background-color: #fff;
	line-height: 1.2;
}

#aside h2 {
	padding: 0.8rem 1.5rem;
	color: #fff;
	font-size: 2rem;
}

#aside .btn {
	position: absolute;
	top: 0.6rem;
	right: 1.5rem;
	z-index: 10;
}

body.fs_s #aside .btn {
	top: 0.5rem;
}

body.fs_l #aside .btn {
	top: 0.8rem;
}

body.fs_xl #aside .btn {
	top: 1rem;
}

#aside .btn a {
	display: inline-block;
	padding: 0.5rem 1.3rem 0.3rem;
	border: none;
	border-radius: 0.5rem;
	background: #fff;
	font-size: 1.4rem;
	color: #000;
}

#aside .btn a:hover,
#aside .btn a:focus {
	border: 1px solid #fff;
	color: #fff;
	text-decoration: none;
}

#aside ul {
	padding: 1.5rem;
}

#aside li {
	margin-top: 0.5em;
	padding: 0.5em 0 0 1.1em;
	border-top: 1px dotted #ccc;
	text-indent: -1.1em;
	line-height: 1.3;
}

#aside li:first-child {
	margin-top: 0;
	padding-top: 0;
	border-top: none;
}

#aside li::before {
	font-family: 'Font Awesome 5 Free';
	content: '\f152';
	font-weight: 700;
	padding-right: 0.5rem;
}

#aside li a {
	color: #000;
}

#aside li a:hover {
	text-decoration: underline;
}

#aside li .num {
	color: #666;
	font-size: 1.4rem;
}
/* content component */

.page_ttl{
  font-size: 3.5rem;
  line-height: 1.45;
}
.article_ttl{
  padding: 0.5rem 0.5rem 0.5rem 1rem;
  font-size: 1rem;
  border-left: solid 5px #000;
}
dl.information{
  display: flex;
  gap:20px;
}
dl.information dt{
  padding: 0.3rem 0.5rem;
}

.wrap_flex{
  display: flex;
  gap:30px;
}
.wrap_flex .wrap_img{
  flex-shrink: 0;
}
.wrap_flex .wrap_txt * + *{
  margin-top: 20px;
}

.question,
.answer{
  display: flex;
  padding: 1rem;
}
.question dt,
.answer dt{
  width: 36px;
  height: 36px;
  font-size: 2rem;
  color: #fff;
  flex-shrink: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50vh;
}


@media screen and (max-width: 767px) {

	#tmp_read_contents {
		padding-bottom: 0;
	}

	#contents {
		padding: 1rem 0 0.5rem;
	}

	#article .main_title_wrap .main_title {
		font-size: 2.2rem;
	}

	#article .main_title_wrap .main_title .small {
		font-size: 1.6rem;
	}

	#article .line_wrap {
		padding-left: 1rem;
	}

	#article .dl_contact {
		display: block;
	}

	#article .dl_contact dt {
		width: 100% !important;
		padding: 0 0 1rem;
		border-right: none;
		border-bottom: 1px solid #fff;
	}

	#article .dl_contact dd {
		width: 100% !important;
		padding: 1rem 0 0;
	}

	#aside {
		margin-top: 0;
	}

	#aside h2 {
		padding: 1rem 5em 1rem 1rem;
		font-size: 1em;
	}

	#aside .btn {
		top: 0.6rem;
		right: 0.6rem;
	}

	#aside li a {
		font-size: 1.4rem;
	}

}

/* ============================================================

	footer

============================================================ */

#footer {
	clear: both;
	position: relative;
	margin-top: 5rem;
	background: #fff;
}
#footer .banner{
  display: flex;
  justify-content: center;
  gap:20px;
}
#footer hr{
  margin-top: 30px;
}

#footer_inner {
	display: flex;
	gap: 30px;
  padding: 30px 0;
  margin: 0 auto;
  max-width: 1200px;
  width: 100%;
  justify-content: space-between;
  flex-direction: row-reverse;
}

#footer_navi {
	order: 2;
	flex: 1;
	padding: 0;
}

#footer_info {
	order: 1;
	width: 400px;
	padding: 0;
}

@media print, screen and (max-width: 1280px) {

	#footer_inner {
		flex-wrap: wrap;
    padding: 30px 20px;
	}

	#footer_navi {
		order: 1;
		width: 100%;
	}

}
@media print, screen and (max-width: 768px) {
  #footer .banner .item{
    
  }
  #footer .banner .slick-slide{
    margin: 0 10px;
  }
  #footer .banner .item img{
    width: 100%;
  }
}

body.fs_l #footer_inner,
body.fs_xl #footer_inner {
	flex-wrap: wrap;
}

body.fs_l #footer_navi,
body.fs_xl #footer_navi {
	order: 1;
	width: 100%;
}

body.fs_l #footer_info,
body.fs_xl #footer_info {
	order: 3;
	width: 100%;
}

#footer_navi_inner {
	font-size: 1.4rem;
}

#backnumber h2 {
	margin-bottom: 1.9rem;
	font-size: 2.8rem;
}

#backnumber_inner {
	position: relative;
	justify-content: space-between;
	gap: 30px;
  max-width: 1200px;
  margin: 0 auto;
  padding: 30px 50px;
  background-color: #fff;
  border-radius: 24px;
}

@media print, screen and (max-width: 1280px) {

	#backnumber_inner {
		gap: 30px;
		flex-wrap: nowrap;
	}

}
#backnumber_inner>dl{
  display: flex;
  gap:60px;
  margin-top: 20px;
}
#backnumber_inner>dl + dl{
  padding-top: 20px;
  background-size: 6px 2px;
  background-image: linear-gradient(to right, #00A0E1 2px, transparent 2px);
  background-repeat: repeat-x;
  background-position: left top;
}
#backnumber_inner>dl>dt {
	padding: 0;
	font-size: 1.4rem;
	font-weight: 700;
  flex-shrink: 0;
  margin-top: 10px;
  min-width: 140px;
}

body.fs_xl #backnumber_inner>dl>dd {
	min-height: 309px;
}


#backnumber_category dd ul {
	display: flex;
	flex-wrap: wrap;
  gap:14px;
}

#backnumber_category dd li {
	display: inline-block;
}

#backnumber_category dd li a {
	font-size: 1.4rem;
  padding: 0.8rem 2rem;
  display: inline-block;
}

#backnumber_category dd li a:hover {
	text-decoration: none;
}

#backnumber_year {
}
#backnumber_year>dd{
  display: flex;
  align-items: flex-end;
  gap:30px;
}
#backnumber_year>dd .more{
	display: block;
  width: fit-content;
	padding: 0.6rem 2rem;
	font-size: 1.4rem;
	line-height: 1;
	text-decoration: none;
	text-align: center;
	cursor: pointer;
}
#backnumber_year>dd .close{
  display: block;
  width: fit-content;
	padding: 0.6rem 2rem;
	font-size: 1.4rem;
	line-height: 1;
	text-decoration: none;
	text-align: center;
	cursor: pointer;
  margin: 30px auto;
}

#backnumber_year .wrap_hide,
#backnumber_year .wrap.hide {
	display: none;
}

#backnumber_year .wrap dl {
  margin-top: 10px;
  padding-top: 10px;
  border-top:solid 1px #333;
}

body.fs_l #backnumber_year .wrap dl,
body.fs_xl #backnumber_year .wrap dl {
	padding-bottom: 2rem;
}

#backnumber_year .wrap dl.no_line {
	border-top: none;
}

#backnumber_year .wrap dd.image {
	float: left;
}

#backnumber_year .wrap dt {
	margin: 0 0 1rem 120px;
	line-height: 1.4;
	font-size: 1.6rem;
}

#backnumber_year .wrap dt a {
	text-decoration: underline;
  font-size: 1.7rem;
  font-weight: 500;
}

#backnumber_year .wrap dt a:hover {
	text-decoration: none;
}

#backnumber_year .wrap dt .small {
	font-size: 1.1rem;
}

#backnumber_year .wrap dd ul {
	margin-left: 120px;
}

#backnumber_year .wrap dd li {
	margin-bottom: 0.5rem;
	padding-left: 1em;
	text-indent: -1em;
	font-size: 1.4rem;
	line-height: 1.4;
}
#backnumber_year .wrap dd li::before{
  content: '・';
}


#backnumber_year .wrap .btn {
	display: inline-block;
	margin: 1.5rem 0 -1px -1px;
	padding: 1rem;
	color: #fff;
	text-align: center;
	cursor: pointer;
}

#backnumber_year .wrap .btn:hover {
	background-color: #fff;
}

#backnumber_year .wrap .btn:after {
	font-family: 'Font Awesome 5 Free';
	content: '\f0d7';
	font-weight: 700;
	padding-left: 0.5rem;
}

#backnumber_year .wrap .btn.open:after {
	content: '\f0d8';
}

#backnumber_year .wrap .btn.hide {
	display: none;
}

#outer_link {
	width: 250px;
}
@media screen and (max-width: 1130px) {
  #backnumber_year>dd{
    flex-direction: column;
  }
}
@media screen and (max-width: 1000px) {
  #backnumber{
    padding: 40px 10px;
  }
  #backnumber_inner{
    padding: 30px 10px;
  }
  #backnumber_inner>dl{
    flex-direction: column;
    gap:20px;
  }
  
}


#outer_link .social {
	display: flex;
	justify-content:flex-end;
  gap:30px;
	margin: 0;
}


@media print, screen and (max-width: 1280px) {

	#footer_info_inner {
		display: flex;
		justify-content: space-between;
	}

}

#contact dt {
	margin-bottom: 1rem;
	font-size: 1.5rem;
	line-height: 1.2;
	vertical-align: top;
}
#contact dt p{
  margin-top: 5px;
}

body.large #contact dt {
	line-height: 1.4;
}

#contact dt .large {
	font-size: 1.8rem;
	font-weight: bold;
}

#contact dd {
	line-height: 1.6;
  font-size: 1.3rem;
}

#contact dd.large {
	font-size: 1.8rem;
	font-weight: 700;
}
#contact dd i{
  font-size: 1.5rem;
}

#contact .icon_tel {
	width: 1em;
	height: 1em;
}

#copyright {
	margin: -3rem auto 0;
  padding-bottom: 3rem;
	font-size: 1.2rem;
	line-height: 1.6;
  max-width: 1200px;
  width: 100%;
  text-align: right;
}

@media screen and (max-width: 1280px) {


}

#pagetop {
	display: none;
	position: fixed;
	bottom: 10px;
	right: 10px;
	z-index: 100;
	max-width: 59px;
}

@media screen and (max-width: 767px) {

	#footer {
		margin-top: 2rem;
		padding-bottom: 8rem;
	}

	#footer_inner {
		gap: 10px;
    justify-content: center;
	}

	#footer_navi {
		padding-top: 0;
	}

	#footer_navi,
	#footer_info {
		padding: 0;
	}

	#footer_navi_inner,
	#footer_info_inner {
		display: block;
	}

	#outer_link,
	#contact,
	#copyright {
		width: 100%;
		padding: 0;
    text-align: center;
	}

	#backnumber h2 {
		display: block;
		margin-bottom: 1rem;
		font-size: 2rem;
		text-align: center;
	}

	#backnumber_inner {
		display: block;
	}

	#backnumber_inner>dl {
		margin-left: 0;
		margin-bottom: 0;
	}

	#backnumber_inner>dl>dt {
		padding: 0.5rem;
	}

	#backnumber_inner>dl>dd {
		min-height: initial;
	}

	#backnumber_category {
		width: 100%;
		margin-bottom: 3rem;
	}

	#backnumber_category dd {
		padding: 1rem;
	}

	#backnumber_category dd select {
		width: 100%;
		font-size: 1.4rem;
	}

	#backnumber_category dd li {
		font-size: 1.4rem;
	}

	#backnumber_category .sp_navi {
		display: flex !important;
	}

	#backnumber_category .sp_navi select {
		flex: 1;
		border: 1px solid #ccc;
		border-radius: 0;
		background: #fff;
		color: #000;
	}

	#backnumber_category .sp_navi button {
		width: 4em;
		background: #eee;
		border: 1px solid #999;
		color: #000;
		white-space: nowrap;
	}

	#backnumber_year {
		width: 100%;
	}

	#backnumber_year .wrap dt {
		font-size: 1.4rem;
	}

	#backnumber_year .wrap dl {
		padding: 10px;
	}

	#backnumber_year .wrap dl.no_line,
	#backnumber_year .wrap dl.last {
		padding-bottom: 2.5rem;
	}

	#backnumber_year .wrap .btn {
		margin-top: 0;
	}

	#outer_link {
		flex-direction: column;
		margin-top: 2rem;
		padding-bottom: 1.5rem;
	}

	#outer_link .social {
		padding-right: 0;
    justify-content: center;
	}

	#outer_link .social_sp {
		display: flex !important;
		justify-content:center;
    gap:30px;
		max-width: 250px;
		width: 100%;
		margin: 0 auto 2rem;
		padding-top: 1.5rem;
	}

	#contact dt,
	#contact dd {
		font-size: 1.4rem;
		line-height: 1.4;
	}

	#copyright {
		margin: 2rem 0;
		text-align: center;
	}

	#logo_shouhi_sp {
		padding: 0.8rem;
		text-align: center;
	}

	#pagetop {
		display: none !important;
		width: 40px;
		bottom: 40px;
	}

}

/* ============================================================

	lightbox

============================================================ */

#lightbox .lb-nav a.lb-prev {
	float: right;
	width: 50%;
	transform: rotate(180deg);
}

#lightbox .lb-nav a.lb-next {
	float: left;
	width: 50%;
	transform: rotate(180deg);
}


/* ============================================================

	編集部からのご案内

============================================================ */

body.all #article h1 {
	margin-bottom: 1rem;
	font-size: 3.5rem;
	font-weight: 700;
}

body.all #article h2 {
	margin: 5rem 0 3rem;
	padding-bottom: 0.5rem;
	border-bottom: 3px solid #333;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.2;
}

body.all #article p {
	margin-bottom: 1.5em;
}

body.all #sec_1 h2 {
	margin-top: 3rem;
}

body.all #article .list li {
	margin-bottom: 0.5rem;
	padding-left: 1em;
	text-indent: -1em;
	line-height: 1.6;
}

body.all #article .btn {
	text-align: center;
}

body.all #article .btn a {
	display: inline-block;
	margin: 0 auto;
	padding: 1rem 2rem;
	border-radius: 0.5rem;
	color: #fff;
	font-weight: 700;
	text-decoration: none;
}

body.all #article .s {
	font-size: 1.4rem;
}

body.all #article .mark {
	padding-left: 1em;
	text-indent: -1em;
}

body.all #article .mark::before {
	content: '○';
	font-family: sans-serif;
}

body.all #article .indent_1em {
	line-height: 1.6;
}

body.all #article .indent {
	padding-left: 1em;
	line-height: 1.6;
	word-break: break-all;
}

body.all #article #sec_2 .img_cd {
	float: right;
	margin: 0 0 0 1.5rem;
	width: 200px;
}

body.all #article #sec_4 h3 {
	margin: 3rem 0 0.5rem;
	font-size: 1.8rem;
	font-weight: 700;
}

body.all #article #sec_4 dl {
	display: table;
	width: 100%;
	border-right: 1px solid #dfdfdf;
	border-left: 1px solid #dfdfdf;
}

body.all #article #sec_4 dt {
	display: table-cell;
	min-width: 8em;
	width: 20%;
	padding: 1.5rem;
	border-top: 1px solid #dfdfdf;
	border-right: 1px solid #dfdfdf;
	background: #f7f7f7;
	vertical-align: middle;
	font-weight: 700;
	line-height: 1.4;
}

body.all #article #sec_4 dd {
	display: table-cell;
	width: 80%;
	padding: 1.5rem;
	border-top: 1px solid #dfdfdf;
	vertical-align: middle;
	line-height: 1.4;
}

body.all #article #sec_4 dl.form {
	border-bottom: 1px solid #dfdfdf;
}

@media screen and (max-width: 767px) {

	body.all #article h1 {
		font-size: 2.4rem;
		line-height: 1.1;
	}

	body.all #article #sec_4 dt {
		min-width: 6em;
	}

}

/* ============================================================

	バックナンバー

============================================================ */

body.backnumber #article {
	position: relative;
	margin-bottom: 0;
}

body.backnumber #article h1 {
	margin-bottom: 1rem;
	font-size: 3.5rem;
	font-weight: 700;
}

body.backnumber #contents h1 .small {
	display: inline-block;
	color: #333;
	font-size: 1.6rem;
}

body.backnumber #contents .cat_link {
	position: absolute;
	top: 20px;
	right: 10px;
	z-index: 10;
}

body.backnumber #contents .cat_link a {
	padding: 0.8rem 1rem;
	border-radius: 0.5rem;
}

body.backnumber #contents .cat_link a:hover {
	opacity: 0.7;
	text-decoration: none;
}

body.backnumber #article #bn_category {
	margin: 3rem 0 0;
	padding: 1rem;
	border-radius: 0.5rem;
	background: #fff;
	box-shadow: 0 0 0.2rem 0 #666;
	font-size: 1.4rem;
}

body.backnumber #article #bn_category dt {
	padding: 1rem 1.5rem;
	border-radius: 0.5rem;
	background: #ccc;
	font-weight: 700;
}

body.backnumber #article #bn_category dd {
	display: flex;
	width: 100%;
	background: #fff;
}

body.backnumber #article #bn_category dd ul {
	display: flex;
	flex-wrap: wrap;
	padding: 1.5rem 1rem 0;
}

body.backnumber #article #bn_category dd li {
	width: 33.3%;
	list-style-type: none;
}

body.backnumber #article #bn_category dd a::before {
	content: '・';
	font-family: sans-serif;
}

body.backnumber #article #bn_category dd a {
	display: block;
	padding: 0.6rem 1rem;
}

body.backnumber #article #bn_category dd a:hover {
	text-decoration: none;
}

body.backnumber.c_index #article #bn_category .index a,
body.backnumber.c_wadai #article #bn_category .wadai a,
body.backnumber.c_report #article #bn_category .report a,
body.backnumber.c_iken #article #bn_category .iken a,
body.backnumber.c_siryo #article #bn_category .siryo a,
body.backnumber.c_osirase #article #bn_category .osirase a,
body.backnumber.c_signal #article #bn_category .signal a,
body.backnumber.c_fresh #article #bn_category .fresh a,
body.backnumber.c_soudan #article #bn_category .soudan a,
body.backnumber.c_koza #article #bn_category .koza a,
body.backnumber.c_news #article #bn_category .news a,
body.backnumber.c_kotoba #article #bn_category .kotoba a,
body.backnumber.c_houkoku #article #bn_category .houkoku a,
body.backnumber.c_keikan #article #bn_category .keikan a {
	color: #666;
	background-color: #fff;
	border-radius: 0.5rem;
}

body.backnumber.c_index #article .bn_category .index a:hover,
body.backnumber.c_wadai #article .bn_category .wadai a:hover,
body.backnumber.c_report #article .bn_category .report a:hover,
body.backnumber.c_iken #article .bn_category .iken a:hover,
body.backnumber.c_siryo #article .bn_category .siryo a:hover,
body.backnumber.c_osirase #article .bn_category .osirase a:hover,
body.backnumber.c_signal #article .bn_category .signal a:hover,
body.backnumber.c_fresh #article .bn_category .fresh a:hover,
body.backnumber.c_soudan #article .bn_category .soudan a:hover,
body.backnumber.c_koza #article .bn_category .koza a:hover,
body.backnumber.c_news #article .bn_category .news a:hover,
body.backnumber.c_kotoba #article .bn_category .kotoba a:hover,
body.backnumber.c_houkoku #article .bn_category .houkoku a:hover,
body.backnumber.c_keikan #article .bn_category .keikan a:hover {
	color: #fff;
}

body.backnumber #article .layout_1 {
	display: flex;
	width: 100%;
	margin: 2rem 0;
}

body.backnumber #article .layout_1>dl {
	width: 32%;
	margin-right: 2%;
	padding: 1rem;
}

body.backnumber #article .layout_1>dl:nth-child(3n) {
	margin-right: 0;
}

body.backnumber #article .layout_1>dl {
	border-radius: 0.5rem;
	background: #fff;
	box-shadow: 0 0 0.2rem 0 #666;
}

body.backnumber #article .layout_1 dt {
	margin-bottom: 1.5rem;
	padding: 1rem 1rem 0.7rem;
	border-radius: 0.5rem;
	background: #f8f5eb;
	font-size: 2rem;
	font-weight: 700;
}

body.backnumber #article .layout_1 dd {
	padding: 0 0.5rem;
}

body.backnumber #article .layout_1 dd a {
	display: block;
	padding: 1.3rem 1rem 1rem;
	border-bottom: 1px dotted #ccc;
}

body.backnumber #article .layout_1 dd:last-of-type a {
	border-bottom: none;
}

body.backnumber #article .layout_1 dd a:hover {
	text-decoration: none;
}

body.backnumber #article .layout_2 {
	margin: 2rem 0;
}

body.backnumber #article .layout_2>dl {
	margin-bottom: 1.5em;
	padding: 1rem;
	border-radius: 0.5rem;
	background: #fff;
	box-shadow: 0 0 0.2rem 0 #666;
}

body.backnumber #article .layout_2 dt {
	margin-bottom: 1.5rem;
	padding: 1rem 1rem 0.7rem;
	border-radius: 0.5rem;
	font-size: 2rem;
	font-weight: 700;
}

body.backnumber #article .layout_2 dd dl {
	margin-bottom: 0;
}

body.backnumber #article .layout_2 dd dt {
	margin-bottom: 0;
	padding: 2rem 1rem 1rem;
	background: none;
	border-radius: 0;
	border-bottom: 1px dotted #ccc;
	font-size: 1.4rem;
}

body.backnumber #article .layout_2 dd dd {
	display: flex;
	width: 100%;
	border-bottom: 1px dotted #ccc;
	line-height: 1.4;
}

body.backnumber #article .layout_2 dd dd .category {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 10em;
	padding: 1.5rem 1rem 1.3rem;
	text-align: center;
	background: #f7f7f7;
	font-size: 1.3rem;
}

body.backnumber #article .layout_2 dd dd a {
	width: 100%;
	padding: 1.5rem 1.5rem 1.3rem;
}

body.backnumber #article .layout_2 dd dd a:hover {
	text-decoration: none;
}

body.backnumber #article .layout_2 dd dd .small {
	display: inline-block;
	margin-bottom: 0.3rem;
	color: #333;
	font-size: 1.3rem;
}

body.backnumber #article .layout_3 {
	margin: 2rem 0;
}

body.backnumber #article .layout_3>dl {
	margin-bottom: 1.5em;
	padding: 1rem;
	border-radius: 0.5rem;
	background: #fff;
	box-shadow: 0 0 0.2rem 0 #666;
}

body.backnumber #article .layout_3 dt {
	margin-bottom: 1.5rem;
	padding: 1rem 1rem 0.7rem;
	border-radius: 0.5rem;
	background: #f8f5eb;
	font-size: 2rem;
	font-weight: 700;
}

body.backnumber #article .layout_3 dd dl {
	margin-bottom: 0;
}

body.backnumber #article .layout_3 dd dt {
	margin-bottom: 0.5rem;
	padding: 2rem 1rem 0;
	border: none;
	border-radius: 0;
	background: none;
	font-size: 1.4rem;
}

body.backnumber #article .layout_3 dd dd {
	line-height: 1.4;
}

body.backnumber #article .layout_3 dd dd a {
	display: block;
	padding: 1.3rem 1rem 1rem;
	border-bottom: 1px dotted #ccc;
}

body.backnumber #article .layout_3 dd dd:last-of-type a {
	border-bottom: none;
}

body.backnumber #article .layout_3 dd dd a:hover {
	text-decoration: none;
}

body.backnumber #article .layout_4 {
	display: flex;
	width: 100%;
	margin: 2rem 0;
}

body.backnumber #article .layout_4>dl {
	width: 32%;
	margin-right: 2%;
	padding: 1rem;
}

body.backnumber #article .layout_4>dl:nth-child(3n) {
	margin-right: 0;
}

body.backnumber #article .layout_4>dl {
	border-radius: 0.5rem;
	background: #fff;
	box-shadow: 0 0 0.2rem 0 #666;
}

body.backnumber #article .layout_4 dt {
	margin-bottom: 1.5rem;
	padding: 1rem 1rem 0.7rem;
	border-radius: 0.5rem;
	background: #f8f5eb;
	font-size: 2rem;
	font-weight: 700;
}

body.backnumber #article .layout_4 dd {
	line-height: 1.4;
}

body.backnumber #article .layout_4 dd a {
	display: block;
	padding: 1.5rem 1rem 1.3rem;
	border-bottom: 1px dotted #ccc;
}

body.backnumber #article .layout_4 dd dd:last-of-type a {
	border-bottom: none;
}

body.backnumber #article .layout_4 dd a:hover {
	text-decoration: none;
}

body.backnumber #article .layout_4 dd dt {
	margin-bottom: 0.5rem;
	padding: 2rem 1rem 0;
	border: none;
	border-radius: 0;
	background: none;
	font-size: 1.4rem;
}

body.backnumber #article .layout_4 dl dl {
	padding: 0 0.5rem;
}

@media screen and (max-width: 767px) {

	body.backnumber #contents h1 {
		font-size: 2.4rem;
	}

	body.backnumber #contents h1 .small {
		margin-right: 0;
		font-size: 1.6rem;
	}

	body.backnumber #contents .cat_link {
		top: 0;
		font-size: 1.2rem;
	}

	body.backnumber #contents .cat_link a {
		padding: 0.5rem 1rem;
	}

	body.backnumber #article .layout_1,
	body.backnumber #article .layout_2,
	body.backnumber #article .layout_3,
	body.backnumber #article .layout_4 {
		margin: 0;
		padding: 0;
	}

	body.backnumber #article .layout_1,
	body.backnumber #article .layout_2 dd dd,
	body.backnumber #article .layout_4 {
		display: block;
	}

	body.backnumber #article .layout_1>dl,
	body.backnumber #article .layout_2 dd dd .category,
	body.backnumber #article .layout_4>dl {
		width: 100%;
		margin: 0;
	}

	body.backnumber #article .layout_2 dd dd .category {
		justify-content: flex-start;
	}

	body.backnumber #article .layout_1 .space,
	body.backnumber #article .layout_4 .space {
		display: none;
	}

	body.backnumber #article .layout_2 dd dd .category {
		padding: 0.5rem 1rem;
		text-align: left;
	}

	body.backnumber #article .layout_1 dl,
	body.backnumber #article .layout_4>dl {
		margin-bottom: 2rem;
		padding: 0.5rem;
	}

	body.backnumber #article .layout_2>dl {
		margin-bottom: 2rem;
		padding: 0.5rem;
		background: #fff;
	}

	body.backnumber #article .layout_2 dd dd a {
		display: block;
		padding: 1.5rem 1rem;
	}

	body.backnumber #article .layout_3>dl {
		margin-bottom: 2rem;
		padding: 0.5rem;
		background: #fff;
	}

	body.backnumber #article #bn_category {
		margin-bottom: 2rem;
	}

	body.backnumber #article #bn_category dd {
		display: block;
		padding: 0.5rem;
	}

	body.backnumber #article #bn_category dd ul {
		display: block;
		width: 100%;
		padding: 0;
	}

	body.backnumber #article #bn_category dd li {
		width: 100%;
	}

	body.backnumber #article #bn_category dd a {
		padding-left: 1rem;
	}

}
