@import url(https://fonts.googleapis.com/css?family=Open%20Sans:300,400,500,600,700);
@import url(https://fonts.googleapis.com/css2?family=Zen+Old+Mincho:wght@600&display=swap);
@import url("https://cdn.jsdelivr.net/npm/bootstrap-icons@1.11.3/font/bootstrap-icons.min.css");

/* ------------------------------------------------------------------------------
	 Typography
------------------------------------------------------------------------------- */
p {
	font-size: 1.2em;
	line-height: 2;
	color: #000;
}

h1,
h2,
h3,
h4,
h5 {
	font-family: "Open Sans", "Helvetica Neue", Helvetica, Arial, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
	letter-spacing: 0.1em;
}

h1 {
	font-size: 65px;
	color: #2d3033;
}

h1.title {
	font-size: 1.6em;
	color: #2d3033;
	line-height: 1.4;
}

h1.title small {
	color: #000;
	letter-spacing: 0.3em;
	line-height: 0;
}

@media screen and (max-width: 767px) {
	h1.title {
		font-weight: 500;
		padding: 0.5em 0;
	}
}

h2 {
	font-size: 40px;
	color: #2d3033;
}

h3 {
	font-size: 28px;
	color: #2d3033;
	font-weight: 300;
	line-height: 1.3;
}

h4 {
	font-size: 22px;
	color: #2d3033;
	font-weight: 400;
	line-height: 1.3;
}

h5 {
	font-size: 14px;
	color: #2d3033;
	text-transform: uppercase;
	font-weight: 700;
	letter-spacing: 0.2em;
}

.btn {
	background-color: #333;
	color: #fff;
	font-size: 1em;
	font-weight: 400;
	letter-spacing: 1px;
	min-width: 18em;
	-webkit-border-radius: 2px;
	-moz-border-radius: 2px;
	border-radius: 2px;
	margin: 1em 0;
	padding: 1em 2em;
	display: inline-block;
	text-transform: uppercase;
}

.btn:hover,
.btn:focus {
	background-color: #666;
	color: #fff;
}

.btn-large {
	padding: 15px 40px;
}

b {
	letter-spacing: 0.1em;
}

.line-height-narrow {
	line-height: 1.5 !important;
}

/* ------------------------------------------------------------------------------
	 General Style
------------------------------------------------------------------------------- */
a {
	color: #4487F9;
}

a:hover,
a:focus {
	text-decoration: none;
	-moz-transition: background-color, color, 0.3s;
	-o-transition: background-color, color, 0.3s;
	-webkit-transition: background-color, color, 0.3s;
	transition: background-color, color, 0.3s;
}

body {
	font-family: "Open Sans", "Helvetica Neue", Helvetica, Arial, "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
	font-weight: 400;
	color: #000;
	line-height: 1.42857;
}

ul,
ol {
	margin: 0;
	padding: 0;
}

ul li {
	list-style: none;
}

.section {
	padding: 80px 0;
}

#message.section,
#photo_kawara.section {
	padding: 2em 0;
}

#header-slider {
	padding-top: 140px;
}

#header-message {
	width: 94%;
	margin: 1em auto 0;
	padding: 4%;
	border: 3px double #f2f2f2;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
}

.no-padding {
	padding: 0;
}

.no-gutter [class*=col-] {
	padding-right: 0;
	padding-left: 0;
}

@media screen and (min-width: 768px) {
	#message.section {
		padding: 100px 0;
	}

	.dl-horizontal dt {
		float: left;
		width: 13em;
		overflow: hidden;
		clear: left;
		text-align: right;
		text-overflow: ellipsis;
		white-space: nowrap
	}

	.dl-horizontal dd {
		margin-left: 13em;
	}

	.dl-horizontal_left dt {
		float: left;
		width: 10em;
		overflow: hidden;
		clear: left;
		text-align: left;
		text-overflow: ellipsis;
		white-space: nowrap
	}

	.dl-horizontal_left dd {
		margin-left: 10em;
	}
}

/* ------------------------------------------------------------------------------
	 Header & navigation
------------------------------------------------------------------------------- */
#header {
	position: fixed;
	width: 94%;
	z-index: 999;
	margin-left: 3%;
	margin-right: 3%;
	border-top: 3px double #2c70bd;
	padding: 1em 0;
}

#header .header-content {
	margin: 0 auto;
	padding: 30px 0 30px 0;
	width: 100%;
	-moz-transition: padding 0.3s;
	-o-transition: padding 0.3s;
	-webkit-transition: padding 0.3s;
	transition: padding 0.3s;
}

#header h1.logo {
	font-size: 1.6em;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	float: left;
	margin: 0;
	padding: 0;
	line-height: 0;
}

#header h1.logo a:link,
h1.logo a:visited,
h1.logo a:hover,
h1.logo a:active {
	color: #000;
}

.zen-old-mincho-semibold {
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  font-style: normal;
}

@media screen and (max-width: 767px) {
	#header h1.logo {
		font-size: 1.2em;
	}
}

#header small {
	font-size: 12px;
	color: #000;
	letter-spacing: 0.3em;
	margin: 0;
	padding: 0;
	line-height: 0;
}

#header h2 {
	font-size: 1em;
	color: #000;
	letter-spacing: 0.1em;
}

#header.fixed {
	background-color: #fff;
}

#header.fixed .header-content {
	border-bottom: 0;
	padding: 30px 0;
}

#header.fixed .nav-toggle {
	top: 10px;
}

.navigation.open {
	opacity: 0.9;
	visibility: visible;
	-moz-transition: opacity 0.5s;
	-o-transition: opacity 0.5s;
	-webkit-transition: opacity 0.5s;
	transition: opacity 0.5s;
}

.navigation {
	float: right;
	margin: 0;
	padding: 22px 0 0 0;
}

.navigation li {
	display: inline-block;
}

.navigation a {
	color: #333;
	font-size: 1em;
	font-weight: 600;
	margin-left: 1.5em;
	letter-spacing: 2px;
	text-transform: uppercase;
}

.navigation a:hover,
.navigation a.active {
	color: #bcbcbc;
	font-weight: 600;
	padding-bottom: 0.8em;
	border-bottom: 4px double #9ce;
}

.nav-toggle {
	display: none;
	height: 44px;
	overflow: hidden;
	position: fixed;
	right: 3%;
	text-indent: 100%;
	top: 10px;
	white-space: nowrap;
	width: 44px;
	z-index: 99999;
	-moz-transition: all 0.3s;
	-o-transition: all 0.3s;
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
}

.nav-toggle:before,
.nav-toggle:after {
	-webkit-border-radius: 50%;
	-moz-border-radius: 50%;
	border-radius: 50%;
	content: "";
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
	-moz-transform: translateZ(0);
	-ms-transform: translateZ(0);
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
	-moz-backface-visibility: hidden;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	-moz-transition-property: -moz-transform;
	-o-transition-property: -o-transform;
	-webkit-transition-property: -webkit-transform;
	transition-property: transform;
}

.nav-toggle:before {
	background-color: #1ea0ff;
	-moz-transform: scale(1);
	-ms-transform: scale(1);
	-webkit-transform: scale(1);
	transform: scale(1);
	-moz-transition-duration: 0.3s;
	-o-transition-duration: 0.3s;
	-webkit-transition-duration: 0.3s;
	transition-duration: 0.3s;
}

.nav-toggle:after {
	background-color: #1ea0ff;
	-moz-transform: scale(0);
	-ms-transform: scale(0);
	-webkit-transform: scale(0);
	transform: scale(0);
	-moz-transition-duration: 0s;
	-o-transition-duration: 0s;
	-webkit-transition-duration: 0s;
	transition-duration: 0s;
}

.nav-toggle span {
	background-color: #fff;
	bottom: auto;
	display: inline-block;
	height: 3px;
	left: 50%;
	position: absolute;
	right: auto;
	top: 50%;
	width: 18px;
	z-index: 10;
	-moz-transform: translateX(-50%) translateY(-50%);
	-ms-transform: translateX(-50%) translateY(-50%);
	-webkit-transform: translateX(-50%) translateY(-50%);
	transform: translateX(-50%) translateY(-50%);
}

.nav-toggle span:before,
.nav-toggle span:after {
	background-color: #fff;
	content: "";
	height: 100%;
	position: absolute;
	right: 0;
	top: 0;
	width: 100%;
	-moz-transform: translateZ(0);
	-ms-transform: translateZ(0);
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
	-moz-backface-visibility: hidden;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	-moz-transition: -moz-transform 0.3s;
	-o-transition: -o-transform 0.3s;
	-webkit-transition: -webkit-transform 0.3s;
	transition: transform 0.3s;
}

.nav-toggle span:before {
	-moz-transform: translateY(-6px) rotate(0deg);
	-ms-transform: translateY(-6px) rotate(0deg);
	-webkit-transform: translateY(-6px) rotate(0deg);
	transform: translateY(-6px) rotate(0deg);
}

.nav-toggle span:after {
	-moz-transform: translateY(6px) rotate(0deg);
	-ms-transform: translateY(6px) rotate(0deg);
	-webkit-transform: translateY(6px) rotate(0deg);
	transform: translateY(6px) rotate(0deg);
}

.nav-toggle.close-nav:before {
	-moz-transform: scale(0);
	-ms-transform: scale(0);
	-webkit-transform: scale(0);
	transform: scale(0);
}

.nav-toggle.close-nav:after {
	-moz-transform: scale(1);
	-ms-transform: scale(1);
	-webkit-transform: scale(1);
	transform: scale(1);
}

.nav-toggle.close-nav span {
	background-color: rgba(255, 255, 255, 0);
}

.nav-toggle.close-nav span:before,
.nav-toggle.close-nav span:after {
	background-color: #fff;
}

.nav-toggle.close-nav span:before {
	-moz-transform: translateY(0) rotate(45deg);
	-ms-transform: translateY(0) rotate(45deg);
	-webkit-transform: translateY(0) rotate(45deg);
	transform: translateY(0) rotate(45deg);
}

.nav-toggle.close-nav span:after {
	-moz-transform: translateY(0) rotate(-45deg);
	-ms-transform: translateY(0) rotate(-45deg);
	-webkit-transform: translateY(0) rotate(-45deg);
	transform: translateY(0) rotate(-45deg);
}

/* ------------------------------------------------------------------------------
	 Header Slider
------------------------------------------------------------------------------- */
.carousel {
	width: 94%;
	/* height: 500px; */
	margin: auto;
}

.item,
.active,
.carousel-inner {
	height: 100%;
}

#header-slider .item img {
	width: 100%;
}

.carousel-caption {
	bottom: 46%;
	color: #fff;
	left: 15%;
	padding-bottom: 20px;
	padding-top: 20px;
	position: absolute;
	right: 15%;
	text-align: center;
	z-index: 10;
}

.carousel-caption h3 {
	font-family: "Open Sans", "Helvetica Neue", Helvetica, Arial, "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
	color: #000;
	text-shadow: 0 -1px 1px #fff, 1px 0 1px #fff;
	font-size: 2em;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 5.5px;
	line-height: 1.3;
}

.carousel-caption p {
	font-family: "Open Sans", "Helvetica Neue", Helvetica, Arial, "游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
	color: #000;
	text-shadow: 0 -1px 1px #fff, 2px 0 1px #fff;
	font-size: 13px;
	font-weight: 400;
	letter-spacing: 2px;
}

.carousel-caption .white {
	color: #fff;
	text-shadow: 0 -1px 1px #000, 1px 0 1px #000;
}

.carousel-control.left {
	background: none;
}

.carousel-control.right {
	background: none;
}

.carousel-control {
	opacity: 1;
	text-shadow: none;
}

/* ------------------------------------------------------------------------------
	 Message
------------------------------------------------------------------------------- */
.message {
	width: 94%;
	margin: auto;
	padding-left: 2em;
	padding-right: 2em;
	background-color: #f2f2f2;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;

}

.message h2 {
	font-size: 2em;
	letter-spacing: 2px;
	font-weight: 300;
}

.message p {
	color: #6c7279;
	font-size: 1.2em;
	font-weight: 400;
	margin-top: 7%;
}

.message-content {
	margin: 6%;
}

.message-content li a {
	color: #6c7279;
	line-height: 30px;
}

.message-content li a:hover {
	color: #000;
}

/* ------------------------------------------------------------------------------
	 photo_kawara
------------------------------------------------------------------------------- */
#photo_kawara {
	width: 94%;
	margin: auto;
}

#photo_kawara .photo_kawara-item {
	right: 0;
	margin: 0 0 2px;
	padding: 0 1px;
}

#photo_kawara .photo_kawara-item .photo_kawara-link {
	display: block;
	position: relative;
	margin: 0 auto;
}

#photo_kawara .photo_kawara-item .photo_kawara-link .caption {
	position: absolute;
	width: 100%;
	height: 100%;
	opacity: 0;
	background: rgba(58, 54, 54, .9);
	-webkit-transition: all ease .5s;
	-moz-transition: all ease .5s;
	transition: all ease .5s;
}

#photo_kawara .photo_kawara-item .photo_kawara-link .caption:hover {
	opacity: 1;
}

#photo_kawara .photo_kawara-item .photo_kawara-link .caption .caption-content {
	position: absolute;
	top: 50%;
	width: 100%;
	height: 20px;
	margin-top: -12px;
	text-align: center;
	font-size: 20px;
	color: #fff;
}

#photo_kawara .photo_kawara-item .photo_kawara-link .caption .caption-content i {
	margin-top: -12px;
}

#photo_kawara .photo_kawara-item .photo_kawara-link .caption .caption-content h3 {
	margin: 0;
	color: #e9eaed;
	font-size: 17px;
	letter-spacing: 4px;
	text-transform: uppercase;
}

#photo_kawara .photo_kawara-item .photo_kawara-link .caption .caption-content h4 {
	margin: 10px 0;
	color: #e9eaed;
	font-size: 12px;
	letter-spacing: 2px;
	text-transform: uppercase;
}

#photo_kawara * {
	z-index: 2;
}

/* ------------------------------------------------------------------------------
	 Policy
------------------------------------------------------------------------------- */
.policy {
	width: 94%;
	margin: auto;
	background-color: #666;
	position: relative;
	text-align: center;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
}

.policy blockquote {
	border: 0;
	margin: 0;
	padding: 4em 4em;
}

.policy blockquote h1 {
	color: #fff;
	font-size: 1.2em;
	font-weight: 300;
	letter-spacing: 1px;
	line-height: 1.5;
}

.policy blockquote p {
	color: #fff;
	display: block;
	font-size: 0.8em;
	font-style: normal;
	letter-spacing: 2px;
	font-weight: 400;
	margin-top: 3em;
	margin-bottom: 2em;
	text-transform: uppercase;
	line-height: 1.5;
}

/* ------------------------------------------------------------------------------
	 Event
------------------------------------------------------------------------------- */
/* --Clearfix */
.cf:before,
.cf:after {
	content: "";
	display: table;
}

.cf:after {
	clear: both;
}

.cf {
	zoom: 1;
}

#event-detail .slider {
	margin: 0 !important;
	overflow: hidden;
}

#carousel li {
	margin-right: 5px;
}

#carousel img {
	display: block;
	opacity: .5;
	cursor: pointer;
}

#carousel img:hover {
	opacity: 1;
}

#carousel .flex-active-slide img {
	opacity: 1;
	cursor: default;
}

/* ------------------------------------------------------------------------------
	 Footer
------------------------------------------------------------------------------- */
.footer {
	clear: both;
	width: 94%;
	margin: auto;
	text-align: left;
	padding-top: 5%;
	padding-bottom: 7%;
	border-bottom: 3px double #2c70bd;
}

.footer .right {
	padding-left: 2em;
}

.footer h4 {
	font-size: 1.2em;
	color: #000;
	letter-spacing: 0.1em;
	margin: 0 0 15px 0;
	padding: 0;
}

.footer p {
	font-size: 1em;
	color: #6c7279;
}

.footer address p,
.footer small {
	letter-spacing: 0.1em;
}

.footer a {
	color: #000;
}

.footer a:hover {
	text-decoration: underline;
}

.footer .footer-share {
	margin-top: 0;
}

.footer .footer-share li {
	display: inline-block;
	float: none;
}

.footer .footer-share a {
	border: none;
	font-size: 13px;
	color: #000;
	letter-spacing: 15px;
}

.footer .fa-heart {
	color: #e84545;
	font-size: 11px;
	margin: 0 2px;
}

.entry {
	padding: 2em;
	border: 3px double #f9f1e7;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
	overflow: auto;
}

.footer .competition {
	margin-right: 15px;
}

.footer small {
	display: block;
	padding: 1em 0;
}

/* ------------------------------------------------------------------------------
	 Detial
------------------------------------------------------------------------------- */
.detail-image img {
	width: 100%;
}

.detail-contentbox {
	background: linear-gradient(#f8f8ed, #fff);
	padding: 3%;
}

.detail-contentbox-right {
	background-color: #fff;
	padding: 3%;
}

.detail-content {
	padding-bottom: 3%;
}

.detail-content h4 {
	font-size: 27px;
	line-height: 27px;
	letter-spacing: 1px;
	font-weight: 300;
}

.detail-content h5 {
	line-height: 1.5;
}

.detail-content p {
	color: #000;
	/* font-size: 1em; */
	font-weight: 400;
	/* margin-top: 5%; */
}

.detail-content p.heading {
	color: #e67702;
	font-size: 1.4em;
	letter-spacing: 0.1em;
}

.detail-content p.sub_heading {
	color: #337AB7;
	font-size: 1.2em;
	letter-spacing: 0.1em;
}

.detail-content p.img {
	margin-top: 1%;
}

/* ------------------------------------------------------------------------------
	 guideline Detial
------------------------------------------------------------------------------- */
#guideline-detail {
	width: 94%;
	margin: auto;
	padding-bottom: 1%;
}

.guideline-detail-margin {
	display: block;
	margin-bottom: 2%;
	border-left: 3px double #9ce;
	background: url("../images/guideline/title_bg.png") no-repeat right bottom;
}

#guideline-detail .img-margin-r {
	margin-left: 15px;
	margin-bottom: 15px;
}

#guideline-detail ul {
	margin: 0;
	padding: 0;
}

#guideline-detail ul li {
	list-style: disc;
	margin-left: 1em;
	padding-bottom: 0.5em;
}

.detail-content .outline {
	font-size: 1.2em;
	margin-top: 5%;
}

.detail-content .outline dt,
.detail-content .outline dd {
	line-height: 1.8;
	padding: 1em 1.2em;
	border-top: 1px dotted #eacba0;
}

.detail-content .outline dt {
	letter-spacing: 0.1em;
}

.detail-content .outline dt.dt_top,
.detail-content .outline dd.dd_top {
	border-top: none;
}

@media screen and (min-width: 768px) {
	.detail-content .outline dd {
		border-left: 3px double #eacba0;
	}
}

@media screen and (max-width: 767px) {
	.detail-content .outline dt {
		color: #22559c;
	}

	.detail-content .outline {
		margin-top: 5%;
		border-top: 1px dotted #ccc;
	}

	.detail-content .outline dt,
	.detail-content .outline dd {
		border-top: none;
	}

	.detail-content .outline dd {
		border-bottom: 1px dotted #ccc;
	}

	.detail-content .outline dt.dt_bottom,
	.detail-content .outline dd.dd_bottom {
		border-bottom: none;
	}

	.detail-content .btn {
		min-width: 100%;
	}
}

/* ------------------------------------------------------------------------------
	 photo_kawara Detial
------------------------------------------------------------------------------- */
@media screen and (max-width: 767px) {}

/* ------------------------------------------------------------------------------
	 attention Detial
------------------------------------------------------------------------------- */
#attention-detail {
	width: 94%;
	margin: auto;
	padding-left: 2em;
	padding-right: 2em;
	background: linear-gradient(#f8f8ed, #fff);
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
}

.attention h2.title {
	font-size: 1.6em;
	color: #333;
	line-height: 1.4;
}

.attention p {
	color: #333;
	font-weight: 400;
	margin-top: 7%;
}

.attention-content {
	margin: 6%;
}

#attention-detail ul {
	margin: 0;
	padding: 0;
}

#attention-detail ul li {
	list-style: disc;
	line-height: 1.8;
	margin-left: 1em;
	padding-bottom: 1em;
}

.attention-content li a {
	color: #6c7279;
}

.attention-content li a:hover {
	color: #000;
}

#attention-detail ul,
#attention-detail ol {
	margin: 0;
	padding-top: 1em;
}

#attention-detail ol li {
	list-style: decimal;
	line-height: 1.2;
	margin-left: 2em;
}

#attention-detail-link {
	padding: 2em 0;
}

/* ------------------------------------------------------------------------------
	 application Detial
------------------------------------------------------------------------------- */
#application-detail {
	width: 94%;
	margin: 0 auto 2em;
	padding: 4em 0;
	/* background-color: rgba(0, 0, 0, 0.4); */
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
}

.bg {
  background-image: url(../images/slider/slid_02.jpg);
  background-color: rgb(51,122,183,0.9);
	background-blend-mode: lighten;
  /*background-blend-mode: darken; */
}

/* ------------------------------------------------------------------------------
	 dropdown-menu
------------------------------------------------------------------------------- */
.dropdown .pull-center {
	right: auto;
	left: auto;
}

.open>.primary-nav ul.pull-center {
	position: absolute;
	top: 0%;
	z-index: 1000;
	width: 100%;
	text-align: center;
	padding-top: 1.5em;
}

.dropdown-menu>li>a {
	font-size: 1em;
	font-weight: 400;
	color: #000;
	white-space: nowrap;
	margin: 0.4em;
}

.open>.dropdown-menu {
	color: #000;
	border: none;
	padding: 0;
}

.dropdown-menu>.active>a,
.dropdown-menu>.active>a:focus,
.dropdown-menu>.active>a:hover {
	background-color: #2c70bd;
}

ul.dropdown-menu li {
	width: 100%;
}

.caret {
	border-top-color: #2c70bd;
}

.active {
	width: 100%;
}

/* ------------------------------------------------------------------------------
	 arrow_box
------------------------------------------------------------------------------- */
@media screen and (min-width: 768px) {
	.arrow_box {
		position: relative;
		background: #FD901E;
		padding: 0.5em 1.5em;
		margin-top: 3em;
		color: #fff;
		font-size: 1em;
		font-weight: 500;
	}

	.arrow_box:after {
		right: 100%;
		top: 50%;
		border: solid transparent;
		content: " ";
		height: 0;
		width: 0;
		position: absolute;
		pointer-events: none;
		border-color: rgba(251, 178, 4, 0);
		border-right-color: #FD901E;
		border-width: 5px;
		margin-top: -5px;
	}
}

/* ------------------------------------------------------------------------------
	  Google マップ
------------------------------------------------------------------------------- */
#google_map {
	position: relative;
	padding-bottom: 56.25%;
	padding-top: 30px;
	height: 0;
	overflow: hidden;
	margin-bottom: 5%;
}

#google_map iframe,
#google_map object,
#google_map embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/* ------------------------------------------------------------------------------
	 上に戻る
------------------------------------------------------------------------------- */
#gototop {
	z-index: 20000;
	position: fixed;
	bottom: 4%;
	right: 4%;
}

#gototop a {
	display: block;
	width: 4rem;
	height: 3rem;
	line-height: 3.4rem;
	font-weight: bold;
	color: #fff;
	text-align: center;
	background: rgba(51, 51, 51, 0.3);
	font-size: 2rem;
	text-decoration: none;
	-webkit-border-radius: 10%;
	-moz-border-radius: 10%;
	border-radius: 10%;
}

#gototop a:hover {
	background: rgba(30, 160, 255, 0.5);
}

/* ------------------------------------------------------------------------------
	 印刷時に表示されるURLを消す
------------------------------------------------------------------------------- */
@media print {
	a[href]:after {
		content: "" !important;
	}

	abbr[title]:after {
		content: "" !important;
	}

	.tophead {
		display: none !important;
		/* height: 1px !important; */
	}

	#header-slider {
		padding-top: 0;
	}

	.section {
		padding: 60px 0;
	}
}

/* ------------------------------------------------------------------------------
	 プラス
------------------------------------------------------------------------------- */
.mt-0 {
	margin-top: 0 !important
}
.mt-1 {
	margin-top: .25rem !important
}
.mt-2 {
	margin-top: .5rem !important
}
.mt-3 {
	margin-top: 1rem !important
}
.mt-4 {
	margin-top: 1.5rem !important
}
.mt-5 {
	margin-top: 3rem !important
}
.mt-8 {
	margin-top: 8rem !important
}
.mt-auto {
	margin-top: auto !important
}

.pt-0 {
	padding-top: 0 !important
}
.pt-1 {
	padding-top: .25rem !important
}
.pt-2 {
	padding-top: .5rem !important
}
.pt-3 {
	padding-top: 1rem !important
}
.pt-4 {
	padding-top: 1.5rem !important
}
.pt-5 {
	padding-top: 3rem !important
}

.me-0 {
  margin-right: 0 !important
}
.me-1 {
  margin-right: .25rem !important
}
.me-2 {
  margin-right: .5rem !important
}
.me-3 {
  margin-right: 1rem !important
}
.me-4 {
  margin-right: 1.5rem !important
}
.me-5 {
  margin-right: 3rem !important
}
.me-auto {
  margin-right: auto !important
}

.ms-0 {
  margin-left: 0 !important
}
.ms-1 {
  margin-left: .25rem !important
}
.ms-2 {
  margin-left: .5rem !important
}
.ms-3 {
  margin-left: 1rem !important
}
.ms-4 {
  margin-left: 1.5rem !important
}
.ms-5 {
  margin-left: 3rem !important
}
.ms-auto {
  margin-left: auto !important
}


.mark,
mark {
	padding: .1875em;
	background-color: #fff3cd;
}

.mark-bg-dark {
	padding: .1875em;
	background-color: RGBA(33, 37, 41, var(--bs-bg-opacity, .4)) !important
}

.text-bg-primary {
	color: #fff !important;
	background-color: RGBA(13, 110, 253, var(--bs-bg-opacity, 1)) !important
}

.text-bg-secondary {
	color: #fff !important;
	background-color: RGBA(108, 117, 125, var(--bs-bg-opacity, 1)) !important
}

.text-bg-success {
	color: #fff !important;
	background-color: RGBA(25, 135, 84, var(--bs-bg-opacity, 1)) !important
}

.text-bg-info {
	color: #000 !important;
	background-color: RGBA(13, 202, 240, var(--bs-bg-opacity, 1)) !important
}

.text-bg-warning {
	color: #000 !important;
	background-color: RGBA(255, 193, 7, var(--bs-bg-opacity, 1)) !important
}

.text-bg-danger {
	color: #fff !important;
	background-color: RGBA(220, 53, 69, var(--bs-bg-opacity, 1)) !important
}

.text-bg-light {
	color: #000 !important;
	background-color: RGBA(248, 249, 250, var(--bs-bg-opacity, 1)) !important
}

.text-bg-dark {
	color: #fff !important;
	background-color: RGBA(33, 37, 41, var(--bs-bg-opacity, 1)) !important
}