@charset "UTF-8";

/* ====================================================== *
		ベース
 * ====================================================== */

body {
	min-width: 300px;
}

/* ------------------------------------------------------ */

/* pagenavi ----------------------------------------------- */


/* ====================================================== *
		レイアウト
 * ====================================================== */

.l_header {
	height: initial;
}

.l_main {
	margin: 6px auto 0;
	width: 100%;
	min-width: 300px;
}

.l_eyecatch {
	margin: 0 auto;
	width: 100%;
	min-width: 300px;
}

.l_contents {
	float: none;
	margin: 0 auto 40px;
	width: 90%;
	min-width: 300px;
}

body.page .l_contents {
	margin-bottom: 40px;	
}

.l_sidebar {
	float: none;
	margin: 0 auto;
	width: 90%;
	min-width: 300px;
}

.l_footer {
	width: 100%;
	height: auto;
}

/* ====================================================== *
		モジュール＆コンポーネント
 * ====================================================== */

/* header ----------------------------------------------- */

.c_header__site-title > a {
	background-size: 87%;
	background-position-x: 10px;
}

@media screen and (max-width: 390px){
	.c_header__site-title > a {
		background-size: 80%;
	}
}

@media screen and (max-width: 350px){
	.c_header__site-title > a {
		background-size: 68%;
		background-position-y: 16px;
	}
}

.m_header__user-interface {
	position: initial;
	top: initial;
	right: initial;
/*	display: initial;*/
	padding: 4px 10px 6px;
	width: 100%;
	border-radius: initial;
}

.m_header__ui_ruby,
.m_header__ui_font-size,
.m_header__ui_site-color {
	display: initial;
	width: 33%;
	background-image: none;
	text-indent: 0;
}

#js_fontruby_y,
#js_fontruby_n,
#js_fontsize_m,
#js_fontsize_l,
#js_sitecolor_full,
#js_sitecolor_mono {
	margin-left: 0;
	text-align: center;
	padding: 6px 0;
	margin: 0 0 10px;
}

.c_gnav__home-bt {
	display: none;
}

.m_header__ui_ruby .c_bt_fr:hover,
.m_header__ui_font-size .c_bt_fs:hover,
.m_header__ui_site-color .c_bt_sc:hover,
.m_header__inquiry a:hover {
	color: #fff;
	text-decoration: underline;
	font-weight: bold;
}

.m_header__search {
	padding: 10px 0px 12px;
	background-color: #1e1e1e;
}

.m_header__search form {
	margin: 0 auto;
	text-align: center;
}

.input-keyword {
	width: 200px;
}

.m_gnav__wrap {
	display: block;
}

.m_gnav__wrap .c_gnav__en {
	margin-left: 1rem;
}

.m_header {
	width: 100%;
	min-width: 300px;
	height: 78px;
/*	height: initial;*/
	padding-bottom: 8px;
	margin-bottom: 1px;
	border-bottom: 4px solid #b50000;
}

.m_accordion_menu {
	display: inherit;
/*	display: initial;
	min-width: 300px;*/
}

#accordion_menu_toggle {
	display:none;
}

.accordion_menu_toggle-label::before,
.accordion_menu_toggle-label::after {
	width:26px;
	position:absolute;
	display: block;
	right: 11px;
	content:'';
	background:#fff;
	transition:0.3s ease;
}

.accordion_menu_toggle-label::before {
	top: 14px;
	position:absolute;
	content:'';
	box-shadow: #fff 0 10px 0;
	height: 4px;
}

.accordion_menu_toggle-label::after {
	position:absolute;
	bottom:12px;
	right: 11px;
	content:'';
	height: 4px;
}

#accordion_menu_toggle:checked + *:before {
	box-shadow:none;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg) translate3d(7px, 7px, 0);
}

#accordion_menu_toggle:checked + *:after {
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg) translate3d(7px, -8px, 0);
}

.m_accordion_menu {
/*	margin: 0 auto;*/
}

.m_accordion_menu {
/*	position: absolute;
	top: 30px;
	right: 6px;*/
}

.m_accordion_menu > input {
	display: none;
}

.m_accordion_menu > label {
	position: absolute;
	top: 20px;
	display: block;
	width: 50px;
	height: 50px;
	background: #f99;
	cursor: pointer;
	border-radius: 6px; 
}

.m_accordion_menu > label {
	right: 16px;
}

.m_accordion_menu > input:checked + label {
	background: #fd9999;
	height: 50px;
}

.m_accordion_menu .m_accordion_menu_wrap {
	transition: 0.6s;
	height: 0;
/*	overflow: hidden;*/
}

.m_accordion_menu > input:checked ~ .m_accordion_menu_wrap {
	height: auto;
	margin-bottom: 130px
}

.m_gnav__wrap {
	width: 100%;
	padding: 0;
	border-top: 1px solid #fff;
}

.m_gnav__wrap > li {
	float: initial;
	width: 100%;
	border-right: none;
	border-bottom: 1px solid #fff;
}

.m_gnav__wrap > li > a,
.m_gnav__wrap > li > label {
	line-height: 44px;
	height: initial;
	font-size: 16px;
	font-size: 1.6rem;
	text-align: left;
	text-indent: 1.6rem;
	color: #fff;
}

#pid-home .c_gnav__home-bt,
#pid-information .c_gnav__info-bt,
#pid-congress .c_gnav__cong-bt,
#pid-policy .c_gnav__poli-bt,
#pid-handout .c_gnav__hand-bt {
	background-color: #b50000;
}

#pid-home .c_gnav__home-bt .c_gnav__border_l,
#pid-information .c_gnav__info-bt .c_gnav__border_l,
#pid-congress .c_gnav__cong-bt .c_gnav__border_l,
#pid-policy .c_gnav__poli-bt .c_gnav__border_l,
#pid-handout .c_gnav__hand-bt .c_gnav__border_l {
	color: #fff;
	border-left: 4px solid #fff;
}


/*.m_gnav__wrap > li > a:before,
.m_gnav__wrap > li > label:before {
	content: "»";
	margin-right: 6px;
}*/

.m_gnav__wrap > li:first-child {
	width: initial;
}

.m_gnav__wrap > li > label {
	display: block;
}

.m_gnav_inquiry {
	margin-top: 2px;
	border-top: 1px dotted #666;
	border-bottom: 1px dotted #666;
}

.m_gnav_inquiry li a {
	display: block;
	color: #1a1a1a;
	padding: 10px 1rem 8px 4rem;
	/* padding-left: 2.8rem; */
	background: url(../img/_common/c_header_icon_inquiry.svg) no-repeat;
	background-position-x: 1rem;
	background-position-y: 14px;
	background-size: 24px 18px;
	text-decoration: none;
}

.m_accordion_menu_wrap .m_sidebar__item {
	margin-top: 2px;
}

.m_accordion_menu_wrap .m_sidebar__item:last-child {
	top: 82px;
}

.m_link__wrap {
	margin-bottom: 0;
}

.c_gnav__blog-bt > label {
	background-color: #7db3de;
}

.c_gnav__blog-bt .m_category-list > li.c_gnav__blog-bt > a {
	background-color: #a9cbe7;
	font-weight: bold;
	color: #1a1a1a;
}

.c_gnav__blog-bt .m_category-list > li > a {
	background-color: #cfe0ee;
	border-bottom: 1px solid #fff;
}

.c_gnav__policy-bt > label {
	background-color: #ffb577;
}

.c_gnav__policy-bt .m_category-list > li.c_gnav__policy-bt > a {
	background-color: #fdd0ab;
	font-weight: bold;
	color: #1a1a1a;
}

.c_gnav__policy-bt .m_category-list > li > a {
	background-color: #fce4d0;
	border-bottom: 1px solid #fff;
}

.c_gnav__publi-bt > label {
	background-color: #cc99cc;
}

.c_gnav__publi-bt .m_category-list > li.c_gnav__publi-bt > a {
	background-color: #ddbbdd;
	font-weight: bold;
	color: #1a1a1a;
}

.c_gnav__publi-bt .m_category-list > li > a {
	background-color: #e9d2e9;
	border-bottom: 1px solid #fff;
}

.c_gnav__useful-bt > label {
	background-color: #54ccab;
}

.c_gnav__useful-bt .m_category-list > li.c_gnav__useful-bt > a {
	background-color: #90ddc7;
	font-weight: bold;
	color: #1a1a1a;
}

.c_gnav__useful-bt .m_category-list > li > a {
	background-color: #b6e5d8;
	border-bottom: 1px solid #fff;
}

.c_gnav__common-theme-bt > label {
	background-color: #d6ce81;;
}

.c_gnav__back-none-bt .m_category-list > li > a {
	background-color: #fff;	
}

input[type="checkbox"].on-off{
	display: none;
}

.m_gnav .m_category-list {
	-webkit-transition: all 0.5s;
	-moz-transition: all 0.5s;
	-ms-transition: all 0.5s;
	-o-transition: all 0.5s;
	transition: all 0.5s;
	margin: 0;
	padding: 0;
	list-style: none;
}

.m_gnav__wrap > li > input[type="checkbox"].on-off + .m_category-list {
	height: 0;
	overflow: hidden;
}

.m_gnav__wrap > li > input[type="checkbox"].on-off:checked + .m_category-list {
/*	height: 370px;*/
}

.m_gnav__wrap > li > input[type="checkbox"].on-off:checked + .m_cat_list_item-08 {
	height: 332px /* 40px*8+8+4 */
}

.m_gnav__wrap > li > input[type="checkbox"].on-off:checked + .m_cat_list_item-09 {
	height: 373px /* 40px*9+9+4 */
}

.m_gnav__wrap > li > input[type="checkbox"].on-off:checked + .m_cat_list_item-10 {
	height: 414px /* 40px*10+10+4 */
}

.m_sp_cont-box__title {
	font-size: 16px;
	font-size: 1.6rem;
	font-weight: bold;
	color: #ffd67f;
	margin: 20px 0 4px 1.6rem;
}

.m_sp_category-list__set {
	list-style: none;
	margin-top: 4px;
}

.m_sp_category-list__set:first-child {
	margin-top: 0;
}

.m_sp_category-list__cats {
	display: table;
	width: 100%;
	margin: 0;
	border-collapse: separate;
}

.m_sp_category-list__cats .cat-item:nth-child(-n+2) {
	border-top: 1px solid #ffd67f;
}

.m_sp_category-list__cats .cat-item:nth-child(odd) {
	border-left: 1px solid #ffd67f;
}

.m_sp_category-list__cats .cat-item {
	display: inline-block;
	width: 49%;
	margin: 0;
	background: #ffe6e6;
	border-right: 1px solid #ffd67f;
	border-bottom: 1px solid #ffd67f;
}

.m_sp_category-list__cats .cat-item br {
	display: none;
}

.m_sp_category-list__cats .cat-item > a {
	width: 100%;
	height: initial;
	display: block;
	margin: 0;
	padding: 8px 0 6px;
	font-size: 16px;
	font-size: 1.6rem;
	text-align: left;
	text-indent: 1.6rem;
	background: #ffe6e6;
	box-shadow: none;
}

@media screen and (max-width: 379px) {
	.m_sp_category-list__cats .cat-item > a {
		font-size: 14px;
		font-size: 1.4rem;
		text-indent: 0.6rem;
	}
}

.m_cont__cont-list li > a {
	display: block;
	width: 220px;
	height: 60px;
	border-top-left-radius: 10px;
	border-bottom-right-radius: 10px;
	background-color: #faf6cc;
	font-size: 1.4rem;
	text-align: center;
	line-height: 6.6rem;
	color: #333333;
}


/* post --------------------------------------------------- */

.m_post {
/*	width: 92%;*/
	margin: 0 auto;
	border-bottom: 1px dotted #999;
}

.m_post__body {
	margin: 0 10px 10px;
}

.m_post__body dl dd {
	margin:1.4rem 0;
}

.m_post__body .alignleft { /* sp_release */
	float: initial;
	margin: 0 auto 20px;
}

.m_post__body .alignright { /* sp_release */
	float: initial;
	margin: 0 auto 20px;
}

.m_post__body img {
	width: 90%;
	height: 90%;
}

.m_post__head {
	margin: 20px auto 0;
	width: 96%;
}

li.m_post {
	margin: auto;
}

.m_img_thumbnail {
	float: none;
	margin: 10px auto;
	text-align: center;
}

.m_sns-bt {
	float: none;
	margin-bottom: 20px;
	top: auto;
}

.u_mg--top-030 > .m_sns-bt {
	float: right;
}

.m_post__excerpt p {
	text-align: justify;
	text-justify: inter-ideograph;
}

/* sidebar ---------------------------------------------- */

#m_monthly_pulldownmenu {
	width: 90%;
	display: block;
	margin: 20px auto;
}

@media screen and (min-width: 420px) and (max-width: 479px) {
}

@media screen and (max-width: 419px) {
}

.m_bnr_corona2020 img {
	width: 100%;
}

/* footer ----------------------------------------------- */

.c_to-pagetop__link-bt {
	left: 76%;
	position: fixed;
	top: initial;
	bottom: 58px;
/*	right: 40px;*/
	-ms-filter: "alpha(opacity=60)";
	-moz-opacity: 0.6;
	-khtml-opacity: 0.6;
	opacity: 0.6;
}

/*.c_to-pagetop__link-bt.foot_position {
	position: absolute;
	top: -10px;
	-ms-filter: "alpha(opacity=100)";
	-moz-opacity: 1.0;
	-khtml-opacity: 1.0;
	opacity: 1.0;
}*/

@media screen and (max-width: 339px) {
}

.m_footer__to-pagetop {
	width: 100%;
	min-width: 300px;
}

.m_footer {
	position: initial;
}

.m_footer__wrap {
	display: none;
}

.m_footer_office-relation {
	width: 100%;
/*	height: auto;*/
}

.m_footer__site-title {
	width: 90%;
	margin: 0px 5% 10px;
}

.m_footer__copyright {
	width: 90%;
	text-align: left;
}

.m_device_switch {
	min-width: 300px;
	background-color: #b50000;
	border-top: none;
}

.m_device_switch_wrap {
	text-align: center;
	padding:0;
}

.m_device_switch_wrap li{
	display: inline-block;
	width: 45%;
}

.m_device_switch_wrap li > a {
	display: block;
	margin: 14px auto;
	padding: 0;
	background-color: #000;
	border: 2px solid #fff;
	border-radius: 4px 4px 4px 4px / 4px 4px 4px 4px;
	-webkit-border-radius: 4px 4px 4px 4px / 4px 4px 4px 4px;
	-moz-border-radius: 4px 4px 4px 4px / 4px 4px 4px 4px;
}

#c_switch_bt--PC{
	background: #ededed;
	color: #b50000;
	font-weight: bold;
}

#c_switch_bt--SP{
	background: #b50000;
	color: #fff;
	font-weight: bold;
}

/* ====================================================== *
		ユーティリティ
 * ====================================================== */

.u_of--hidden { /* sp_release */
	overflow: initial;
}

.u_contents__name {
	margin-right: 20px;
	margin-left: 20px;
}

@media screen and (max-width: 329px){
	.u_contents__name {
		font-size: 1.8rem;
	}
}

.c_title-archive-monthly {
	display: block;
	margin-left: 0;
	font-size: 1.2rem;
}

.u_mg--top-100 { // PCでは 100px
	margin-top: 70px !important;
}

.u_pc--display-only {
	display: none !important;
}

.u_sp--display-only {
	display: initial !important;
}

/* youtube（iframe） レスポンシブ対応 */
.m_post iframe {
	position: relative;
	top: 0;
	left: 0;
	width: 100%;
	height: auto;
}