@charset "utf-8";

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
共通
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+*/
* {
	-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
	box-shadow: none;
	outline: none;
}

html, body, div, span, iframe, h1, h2, h3, h4, h5, h6, p, a, address, img, dl, dt, dd, ol, ul, li, label, table, tr, th, td, hr, input, textarea,
article, aside, details, figure, figcaption, header, footer, hgroup, menu, nav, section, picture { 
	margin: 0;
	padding: 0;
	border: 0;
	box-sizing: border-box;
	font-size: 100%;
	vertical-align: baseline;
}

iframe, article, aside, details, figure, figcaption, header, footer, hgroup, menu, nav, section, picture { 
	display: block;
}

body {
	line-height: 1;
	-ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%;
}

p { 
	font-size: 120%;
}

a {
	color: inherit;
	text-decoration: none;
}

address {
	font-style: normal;
}

img {
	max-width: 100%;
	height: auto;
	vertical-align: middle;
}

ol, ul {
	list-style: none;
	list-style-type: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

input, textarea, select, button {
	border: 0;
	border-radius: inherit;
	background: none;
	color: inherit;
	font-weight: inherit;
	font-size: inherit;
	font-family: inherit;
	line-height: inherit;
	letter-spacing: inherit;
}

input[type="radio"]{
  transform: scale(1.5); /* 2.5倍 */
  margin:10px 2px 15px 10px;
}	

textarea {
	overflow: auto;
}

input:not([type="checkbox"]):not([type="radio"]), textarea, button {
	-webkit-appearance: none;
}

/* margin - 要素の外側の余白 */
.m0 { margin: 0!important; }
.mt0 { margin-top: 0!important; }
.mr0 { margin-right: 0!important; }
.mb0 { margin-bottom: 0!important; }
.ml0 { margin-left: 0!important; }
.m5 { margin: 5px !important; }
.mt5 { margin-top: 5px !important; }
.mr5 { margin-right: 5px !important; }
.mb5 { margin-bottom: 5px !important; }
.ml5 { margin-left: 5px !important; }
.m10 { margin: 10px !important; }
.mt10 { margin-top: 10px !important; }
.mr10 { margin-right: 10px !important; }
.mb10 { margin-bottom: 10px !important; }
.ml10 { margin-left: 10px !important; }
.m15 { margin: 15px !important; }
.mt15 { margin-top: 15px !important; }
.mr15 { margin-right: 15px !important; }
.mb15 { margin-bottom: 15px !important; }
.ml15 { margin-left: 15px !important; }
.m20 { margin: 20px !important; }
.mt20 { margin-top: 20px !important; }
.mr20 { margin-right: 20px !important; }
.mb20 { margin-bottom: 20px !important; }
.ml20 { margin-left: 20px !important; }
.m25 { margin: 25px !important; }
.mt25 { margin-top: 25px !important; }
.mr25 { margin-right: 25px !important; }
.mb25 { margin-bottom: 25px !important; }
.ml25 { margin-left: 25px !important; }
.m30 { margin: 30px !important; }
.mt30 { margin-top: 30px !important; }
.mr30 { margin-right: 30px !important; }
.mb30 { margin-bottom: 30px !important; }
.ml30 { margin-left: 30px !important; }
.m35 { margin: 35px !important; }
.mt35 { margin-top: 35px !important; }
.mr35 { margin-right: 35px !important; }
.mb35 { margin-bottom: 35px !important; }
.ml35 { margin-left: 35px !important; }
.m40 { margin: 40px !important; }
.mt40 { margin-top: 40px !important; }
.mr40 { margin-right: 40px !important; }
.mb40 { margin-bottom: 40px !important; }
.ml40 { margin-left: 40px !important; }
.m45 { margin: 45px !important; }
.mt45 { margin-top: 45px !important; }
.mr45 { margin-right: 45px !important; }
.mb45 { margin-bottom: 45px !important; }
.ml45 { margin-left: 45px !important; }
.m50 { margin: 50px !important; }
.mt50 { margin-top: 50px !important; }
.mr50 { margin-right: 50px !important; }
.mb50 { margin-bottom: 50px !important; }
.ml50 { margin-left: 50px !important; }
.m55 { margin: 55px !important; }
.mt55 { margin-top: 55px !important; }
.mr55 { margin-right: 55px !important; }
.mb55 { margin-bottom: 55px !important; }
.ml55 { margin-left: 55px !important; }
.m60 { margin: 60px !important; }
.mt60 { margin-top: 60px !important; }
.mr60 { margin-right: 60px !important; }
.mb60 { margin-bottom: 60px !important; }
.ml60 { margin-left: 60px !important; }
.m65 { margin: 65px !important; }
.mt65 { margin-top: 65px !important; }
.mr65 { margin-right: 65px !important; }
.mb65 { margin-bottom: 65px !important; }
.ml65 { margin-left: 65px !important; }
.m70 { margin: 70px !important; }
.mt70 { margin-top: 70px !important; }
.mr70 { margin-right: 70px !important; }
.mb70 { margin-bottom: 70px !important; }
.ml70 { margin-left: 70px !important; }
.m75 { margin: 75px !important; }
.mt75 { margin-top: 75px !important; }
.mr75 { margin-right: 75px !important; }
.mb75 { margin-bottom: 75px !important; }
.ml75 { margin-left: 75px !important; }
.m80 { margin: 80px !important; }
.mt80 { margin-top: 80px !important; }
.mr80 { margin-right: 80px !important; }
.mb80 { margin-bottom: 5em !important; }
.ml80 { margin-left: 80px !important; }

/* padding - 要素の内側の余白 */
.p0 { padding: 0!important; }
.pt0 { padding-top: 0!important; }
.pr0 { padding-right: 0!important; }
.pb0 { padding-bottom: 0!important; }
.pl0 { padding-left: 0!important; }
.p5 { padding: 5px !important; }
.pt5 { padding-top: 5px !important; }
.pr5 { padding-right: 5px !important; }
.pb5 { padding-bottom: 5px !important; }
.pl5 { padding-left: 5px !important; }
.p10 { padding: 10px !important; }
.pt10 { padding-top: 10px !important; }
.pr10 { padding-right: 10px !important; }
.pb10 { padding-bottom: 10px !important; }
.pl10 { padding-left: 10px !important; }
.p15 { padding: 15px !important; }
.pt15 { padding-top: 15px !important; }
.pr15 { padding-right: 15px !important; }
.pb15 { padding-bottom: 15px !important; }
.pl15 { padding-left: 15px !important; }
.p20 { padding: 20px !important; }
.pt20 { padding-top: 20px !important; }
.pr20 { padding-right: 20px !important; }
.pb20 { padding-bottom: 20px !important; }
.pl20 { padding-left: 20px !important; }
.p25 { padding: 25px !important; }
.pt25 { padding-top: 25px !important; }
.pr25 { padding-right: 25px !important; }
.pb25 { padding-bottom: 25px !important; }
.pl25 { padding-left: 25px !important; }
.p30 { padding: 30px !important; }
.pt30 { padding-top: 30px !important; }
.pr30 { padding-right: 30px !important; }
.pb30 { padding-bottom: 30px !important; }
.pl30 { padding-left: 30px !important; }
.p35 { padding: 35px !important; }
.pt35 { padding-top: 35px !important; }
.pr35 { padding-right: 35px !important; }
.pb35 { padding-bottom: 35px !important; }
.pl35 { padding-left: 35px !important; }
.p40 { padding: 40px !important; }
.pt40 { padding-top: 40px !important; }
.pr40 { padding-right: 40px !important; }
.pb40 { padding-bottom: 40px !important; }
.pl40 { padding-left: 40px !important; }
.p45 { padding: 45px !important; }
.pt45 { padding-top: 45px !important; }
.pr45 { padding-right: 45px !important; }
.pb45 { padding-bottom: 45px !important; }
.pl45 { padding-left: 45px !important; }
.p50 { padding: 50px !important; }
.pt50 { padding-top: 50px !important; }
.pr50 { padding-right: 50px !important; }
.pb50 { padding-bottom: 50px !important; }
.pl50 { padding-left: 50px !important; }
.p55 { padding: 55px !important; }
.pt55 { padding-top: 55px !important; }
.pr55 { padding-right: 55px !important; }
.pb55 { padding-bottom: 55px !important; }
.pl55 { padding-left: 55px !important; }
.p60 { padding: 60px !important; }
.pt60 { padding-top: 60px !important; }
.pr60 { padding-right: 60px !important; }
.pb60 { padding-bottom: 60px !important; }
.pl60 { padding-left: 60px !important; }
.p65 { padding: 65px !important; }
.pt65 { padding-top: 65px !important; }
.pr65 { padding-right: 65px !important; }
.pb65 { padding-bottom: 65px !important; }
.pl65 { padding-left: 65px !important; }
.p70 { padding: 70px !important; }
.pt70 { padding-top: 70px !important; }
.pr70 { padding-right: 70px !important; }
.pb70 { padding-bottom: 70px !important; }
.pl70 { padding-left: 70px !important; }
.p75 { padding: 75px !important; }
.pt75 { padding-top: 75px !important; }
.pr75 { padding-right: 75px !important; }
.pb75 { padding-bottom: 75px !important; }
.pl75 { padding-left: 75px !important; }
.p80 { padding: 80px !important; }
.pt80 { padding-top: 80px !important; }
.pr80 { padding-right: 80px !important; }
.pb80 { padding-bottom: 5em !important; }
.pl80 { padding-left: 80px !important; }

.hihyouji {
	display: none;
}

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+-*/

.background-color {
	background: var(--sub-color);
}

html {
	font-size: 62.5%;
}

body {
	overflow: hidden scroll;
	color: var(--main-color);
	font-size: 1em;
	letter-spacing: 0.1em;
	line-height: 1.5;
}

/*
@media screen\0 {
body {
	font-family: "BIZ UDPMincho", "MS PMincho", serif;
}
}
*/

main {
	overflow-x: hidden;
}

article {
	overflow-x: hidden;
}

section,
.section {
	padding: 30px 0;
}

.inner {
	width: 100%;
	max-width: 1260px;
	margin: auto;
	padding: 0 6%;
}

span:not([class]) {
	display: inline-block;
}

p:not([class]) + p:not([class]) {
	margin-top: 1.5em;
}

a,
a::before,
a::after {
	transition: 0.3s ease-in-out;
}

a {
	display: inline-block;
}

a:hover {
	opacity: 0.7;
}

svg {
	fill: var(--main-color);
}

a svg {
	transition: 0.3s ease-in-out;
}

.ul:nth-child(n+2) {
	margin-top: 1.5em;
}

.ul:nth-last-child(n+2) {
	margin-bottom: 1.5em;
}

.ul > li {
	position: relative;
	padding-left: 1.2em;
}

.ul > li::before {
	position: absolute;
	top: 0;
	left: 0;
	content: "・";
}

.ul > li:nth-last-child(n+2) {
	margin-bottom: 0.5em;
}

table {
	width: 100%;
}

th {
	text-align: left;
	vertical-align: top;
}

td {
	text-align: left;
	vertical-align: top;
}

.block-center {
	margin: auto;
}

.block-right {
	margin-left: auto;
}

.table-center {
	display: table;
	margin: auto;
}

.line-through {
	text-decoration: line-through;
}

.marker {
	background: linear-gradient(transparent 55%, var(--sub-color) 55%, var(--sub-color) 90%, transparent 90%);
}

.annotation {
	position: relative;
	margin-top: 0.5em;
	padding-left: 1em;
}

.annotation::before {
	position: absolute;
	top: 0;
	left: 0;
	content: "※";
}

li.spacer {
	margin-bottom: 0;
}
.pc {
	display: none;	
}
.sp {
	display: block;	
}	

@media screen and (min-width: 768px) {
body {
	font-size: 1.6em;
}

section,
.section {
	padding: 80px 0;
}

.inner {
	padding: 0 30px;
}

a[href^="tel:"] {
	pointer-events: none;
}

.annotation {
	font-size: 1.4rem;
}
.pc {
	display: block;
}
.sp {
	display: none;	
}	
}

@media screen and (max-width: 767.9px) {
.block-table th {
	display: block;
}

.block-table td {
	display: block;
}
}

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
アニメーション
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+*/
@keyframes fade {
0% {
	opacity: 0;
}

100% {
	opacity: 1;
}
}

@keyframes fade-up {
0% {
	opacity: 0;
	transform: translateY(30px);
}

100% {
	opacity: 1;
	transform: translateY(0);
}
}

@keyframes fade-right {
0% {
	opacity: 0;
	transform: translateX(40px);
}

100% {
	opacity: 1;
	transform: translate(0);
}
}

@keyframes fade-left {
0% {
	opacity: 0;
	transform: translateX(-40px);
}

100% {
	opacity: 1;
	transform: translate(0);
}
}

@keyframes fade-zoom-in {
0% {
	opacity: 0;
	transform: scale(0.9);
}

100% {
	opacity: 1;
	transform: scale(1);
}
}

@keyframes fade-zoom-out {
0% {
	opacity: 0;
	transform: scale(1.1);
}

100% {
	opacity: 1;
	transform: scale(1);
}
}

.animation {
	animation-duration: 0.6s;
	animation-timing-function: ease-out;
	animation-delay: 0.3s;
	animation-fill-mode: forwards;
	will-change: transform;
}

.load .animation.fade {
	animation-name: fade;
}

.load .animation.fade-up {
	animation-name: fade-up;
	animation-duration: 0.5s;
}

.load .animation.fade-right {
	animation-name: fade-right;
}

.load .animation.fade-left {
	animation-name: fade-left;
}

.load .animation.fade-zoom-in {
	animation-name: fade-zoom-in;
	animation-duration: 0.8s;
}

.load .animation.fade-zoom-out {
	animation-name: fade-zoom-out;
	animation-duration: 0.8s;
}

.delay05 {
	animation-delay: 0.5s;
}

.delay07 {
	animation-delay: 0.7s;
}

.delay09 {
	animation-delay: 0.9s;
}

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
セクション
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+*/
.section-header {
	margin-bottom: 20px;
	font-weight: 700;
	text-align: center;
}

.section-header a{
/* text-decoration: underline;*/
}

.section-heading {
	margin-bottom: 0.2em;
	font-size: 2.5em;
	line-height: 1.3;
	color: var(--content-title-color);
}

.section-subheading {
	margin-bottom: 0.5em;
	font-size: 1.2rem;
}

@media screen and (min-width: 768px) {
.section-header {
	margin-bottom: 40px;
}

.section-heading {
	font-size: 5rem;
}

.section-subheading {
	font-size: 2.4rem;
}
}

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
リンク
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+*/
.button-container {
	display: flex;
	flex-flow: wrap;
	justify-content: center;
	align-items: center;
}

.button {
	display: flex;
	position: relative;
	width: 100%;
	max-width: 278px;
	height: 53px;
	margin-top: 20px;
	padding: 0.3em 1em;
/*	border: 2px solid var(--button-text-hover-color);*/
	border-radius: 10px;
	background: var(--button-bg-color);
	color: var(--button-text-color);
	font-weight: 700;
	font-size: 1.8rem;
	line-height: 1.3;
	text-align: center;
	justify-content: center;
	align-items: center;
	box-shadow: 0em 0.05em 3px #939393;
	/*pointer-events: none;*/	/*ボタン押せないように*/	
}

a.button:hover {
/*	opacity: 1;
	background: #fff;
	color: var(--button-text-hover-color);*/
}

.button01 {
	max-width: 90%;
/*	max-width: 300px;*/
}	

.button01 a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 10px 0px 10px 0px;
    padding: 0.8em 2em;
    color: var(--button-text-color);
    font-size: 1.8em;
    font-weight: 700;
	border-radius:10px;	
    background: var(--button-bg-color);
    border: 5px solid var(--button-bg-color);
/*    box-shadow: 5px 5px #D3D3D3;*/	
	box-shadow: 0em 0.05em 3px #939393;
}
.button01 a::after {
    content: '';
    width: 0.4em;
    height: 0.4em;
    border-top: 0.1em solid var(--button-text-color);
    border-right: 0.1em solid var(--button-text-color);
    transform: rotate(45deg);
    margin-left: 0.3em;
}

@media screen and (min-width: 768px) {
.button {
	max-width: 555px;
	height: 75px;
	margin-top: 30px;
	border-width: 3px;
	border-radius: 20px;
	font-size: 3rem;
}

.button-container .button {
	margin-right: 20px;
	margin-left: 20px;
}
	
.button01 {
	max-width: 800px;
}	

.button01 a {
    font-size: 2.5em;
    padding: 0.5em 2em;	
}	
}

@media screen and (max-width: 767.9px) {
.button-container {
	flex-flow: column;
}
}

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
ローダー
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+*/
.loader {
	display: flex;
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 10;
	background: #fff;
	transition: 0.8s ease-in-out;
	justify-content: center;
	align-items: center;
}

@keyframes loader {
0% {
	transform: rotate(0deg);
}

100% {
	transform: rotate(360deg);
}
}

.loader-bar {
	width: 60px;
	height: 60px;
	border: 8px solid var(--sub-color);
	border-left-color: var(--main-color);
	border-radius: 50%;
	animation: loader 1.1s linear infinite;
}

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
ヘッダー
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+*/
header {
	display: flex;
	overflow: hidden;
	position: relative;
	z-index: 4;
	height: 53px;
/*	border-bottom: 1px solid var(--main-color);	*/
}

.header-inner {
	display: flex;
	max-width: none;
	height: 53px;
	background: #fff;
	justify-content: space-between;
}

.header-logo {
	font-weight: 700;
	font-size: 1.5rem;
	align-self: center;
}
.header-logo img{
/*height: 2em;*/
	  max-width: 200px;
	  max-height: 40px;		
}

.header-contact {
	display: flex;
}

.header-contact svg{
	fill: var(--header-tel-color);	
}

.header-contact-tel,
.header-contact-mail {
	display: flex;
	padding: 0 12px;
	font-weight: 700;
	font-size: 3rem;
	justify-content: center;
	align-items: center;
}

.header-contact-tel .icon {
	width: 29px;
	height: 28px;
}

.header-contact-mail .icon {
	width: 31px;
	height: 23px;
}

@media screen and (min-width: 768px) {
header {
	height: 75px;
}

.header-inner {
	height: 75px;
	will-change: transform;
}

header.hide .header-inner {
	position: fixed;
	right: 0;
	bottom: 0;
	left: 0;
/*	border-top: 3px solid;*/
	transform: translateY(100%);
box-shadow: 0 0px 10px 0 #D7D7D7;
}

header.show .header-inner {
	transform: translateY(0);
}

.header-logo {
	font-size: 3rem;
}
.header-logo img{
/*height: 2em;*/
  max-width: 350px;	
  max-height: 50px;		
}	

.header-contact-tel .icon {
	width: 34px;
	height: 33px;
}

.header-contact-mail .icon {
	width: 41px;
	height: 30px;
}
}

@media screen and (min-width: 1112px) {
.header-inner {
	padding-right: 0;
}


.header-contact > :nth-child(n+2) {
/*	border-left: 3px solid var(--main-color);*/
}

.header-contact-tel,
.header-contact-mail {
	padding: 0 40px;
}
	
.header-contact-tel {
	font-size: 2.3em;	
	letter-spacing: 0.1em;
	color: var(--header-tel-color);		
}	

.header-contact-tel .icon {
	margin-right: 10px;
}
	
.header-contact-tel svg {
	fill: var(--header-tel-color);		
}	

.header-contact-mail {
	opacity: 1;
	background: var(--button-bg-color);
	color: var(--button-text-color);
}

.header-contact-mail .icon {
	margin-right: 20px;
}

.header-contact-mail .icon {
	fill: var(--button-text-color);
}
}

@media screen and (max-width: 1111.9px) {
.header-contact-tel .text,
.header-contact-mail .text {
	display: none;
}
}

@media screen and (max-width: 767.9px) {
.header-inner {
	/* position: fixed; */
	top: 0;
	right: 0;
	left: 0;
	padding: 0 15px;
}
}

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
フッター
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+*/
footer {
	position: relative;
}

.page-top {
	display: none;
	visibility: hidden;
	opacity: 0;
	position: absolute;
	position: fixed ;
	right: 10px;
	bottom: 63px;
	z-index: 1;
	width: 59px;
	height: 59px;
	border: 3px solid;
	border-radius: 10px;
	background: var(--main-color);
	cursor: pointer;
	transition: 0.3s ease-in-out;
}

.page-top.show {
	visibility: visible;
	opacity: 1;
}

.page-top.change {
	position: absolute;
	bottom: 130px;
}

.page-top::before {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	width: 0;
	height: 0;
	margin: auto;
	border-right: 8px solid transparent;
	border-bottom: 14px solid #fff;
	border-left: 8px solid transparent;
	content: "";
	transition: 0.3s ease-in-out;
}

.page-top:hover {
	color: var(--main-color);
	background: #fff;
}

.page-top:hover::before {
	border-bottom-color: var(--main-color);
}

.footer-copyright {
	padding: 19px 0;
	background: var(--main-color);
	color: #fff;
	text-align: center;
}

.footer-contact {
	display: none ;	
	position: fixed;
	right: 0;
	z-index: 1;
	transform: translateY(100%);
	transition: 0.3s ease-in-out;
	will-change: transform;
}

footer.show .footer-contact {
	transform: translateY(0);
}

.footer-contact-tel {
	display: flex;
	background: #fff;
	font-weight: 700;
	font-size: 1.5rem;
	justify-content: center;
	align-items: center;
}

.footer-contact-tel:hover {
	opacity: 1;
	background: var(--main-color);
	color: #fff;
}

.footer-contact-tel .icon {
	width: 23px;
	height: 22px;
	flex: none;
}

.footer-contact-tel:hover .icon {
	fill: #fff;
}

.footer-contact-mail {
	display: flex;
	background: var(--button-bg-color);
	color: var(--button-text-color);
	font-weight: 700;
	font-size: 1.3rem;
	justify-content: center;
	align-items: center;
}

/*.footer-contact-mail:hover {
	opacity: 1;
	background: var(--sub-color);
	color: var(--main-color);
}*/

.footer-contact-mail:hover {
	opacity: 1!important;
}

.footer-contact-mail .icon {
	width: 23px;
	height: 17px;
	flex: none;
}
.footer-contact-mail svg{
	fill: var(--button-text-color);
}

/*.footer-contact-mail:hover .icon {
	fill: var(--main-color);
}*/

@media screen and (min-width: 768px) {
.page-top {
	right: 20px;
	bottom: 100px;
	width: 98px;
	height: 98px;
	border-width: 5px;
	border-radius: 20px;
}

.page-top.change {
	bottom: 160px;
}

.page-top::before {
	border-right-width: 15px;
	border-bottom-width: 26px;
	border-left-width: 15px;
}

.footer-copyright {
	padding: 100px 0;
	font-size: 2rem;
}

.footer-contact {
	/* display: none */;
	top: 120px;
	width: 70px;
	letter-spacing: 0;
	transform: translateX(150%);
}

footer.show .footer-contact {
	transform: translateX(0);
}

.footer-contact .close {
	display: none ;			
/*	display: flex;*/
	position: absolute;
	top: 0;
	left: 0;
	width: 45px;
	height: 45px;
	border: 2px solid var(--main-color);
	border-radius: 50%;
	background: var(--main-color);
	color: #fff;
	font-size: 2.6rem;
	cursor: pointer;
	justify-content: center;
	align-items: center;
	transform: translate(-50%, -50%);
	transition: 0.3s ease-in-out;
}

.footer-contact .close:hover {
	background: #fff;
	color: var(--main-color);
}

.footer-contact > :last-child {
	border-bottom: 5px solid var(--main-color);
	border-bottom-left-radius: 30px;
}

.footer-contact-tel {
	display: none ;		
	padding: 20px 0;
	border-top: 5px solid;
	border-left: 5px solid;
	font-size: 2rem;
	flex-flow: column;
}

.footer-contact-tel .icon {
	width: 30px;
	height: 29px;
	margin-bottom: 10px;
}

.footer-contact-tel .text {
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	text-orientation: upright;
}

.footer-contact-mail {
	display: none ;	
	padding: 20px 0;
	border-top: 5px solid var(--main-color);
	border-left: 5px solid var(--main-color);
	font-size: 1.8rem;
	flex-flow: column;
}

.footer-contact-mail .icon {
	width: 30px;
	height: 22px;
	margin-bottom: 20px;
}

.footer-contact-mail .text {
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
}
}

@media screen and (max-width: 767.9px) {
footer.show {
	padding-bottom: 55px;
}

.footer-contact {
	bottom: 0;
	left: 0;
	height: 53px;
/*	border-top: 2px solid;*/
	box-shadow: 0 0px 5px 0 #DCDCDC;	
}

.footer-contact .close {
	display: none;
}

.footer-contact-tel {
	min-width: 170px;
	height: 100%;
	padding: 0 10px;
	white-space: nowrap;
	color: var(--header-tel-color);	
}

.footer-contact-tel .icon {
	margin-right: 5px;
}
	
.footer-contact-tel svg {
	fill: var(--header-tel-color);	
}

.footer-contact-mail {
	height: 100%;
	padding: 0 10px;
}

.footer-contact-mail .icon {
	margin-right: 10px;
}

.footer-contact2 {
	display: flex;
}

.footer-contact2 .footer-contact-tel,
.footer-contact2 .footer-contact-mail {
	width: 50%;
}

.footer-contact2 .footer-contact-tel {
/*	border-right: 2px solid #fff;*/
}

.footer-contact2 .footer-contact-mail {
/*	border-left: 2px solid var(--main-color);*/
}
}

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
404 Not Found
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+*/
.notfound-article {
	text-align: center;
}

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
モーダル
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+*/
.modal-container {
	display: flex;
	visibility: hidden;
	opacity: 0;
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 10;
	justify-content: center;
	align-items: center;
	transition: 0.5s ease;
	will-change: visibility;
}

.modal-container.open {
	visibility: visible;
	opacity: 1;
}

.modal-close {
	display: block;
	position: absolute;
	top: 0;
	right: 0;
	z-index: 1;
	width: 50px;
	height: 50px;
	cursor: pointer;
}

.modal-close::before,
.modal-close::after {
	display: block;
	position: absolute;
	right: 0;
	left: 0;
	width: 30px;
	height: 2px;
	margin: auto;
	background: #fff;
	content: "";
	transition: 0.5s ease;
}

.modal-close::before {
	top: 18px;
}

.modal-close::after {
	top: 32px;
}

.modal-container.open .modal-close::before {
	top: 25px;
	transform: rotate(-45deg);
}

.modal-container.open .modal-close::after {
	top: 25px;
	transform: rotate(45deg);
}

.modal-overlay {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	background: rgba(0, 0, 0, 0.8);
}

.modal-content {
	transition: transform 0.5s ease;
	transform: scale(0.8);
}

.modal-container.open .modal-content {
	transform: scale(1);
}

.modal-content_mv {
	transition: transform 0.5s ease;
	transform: scale(0.8);
}

.modal-container.open .modal-content_mv {
	transform: scale(1);
}

.modal-content video,
.modal-content img {
	max-width: calc(100vw - 60px);
	max-height: calc(100vh - 80px);
}

.modal-youtube {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	width: calc(80vh / 0.5625);
	max-width: 90%;
	height: 80vh;
	max-height: calc(90vw * 0.5625);
	margin: auto;
}

.modal-youtube .modal-inner {
	position: relative;
	padding-top: 56.25%;
}

.modal-youtube iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}



/* モーダルのスタイル */
    .modal {
        display: none; /* 初期状態では非表示 */
        position: fixed; /* モーダルがスクロールに追従するように固定位置 */
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background-color: rgba(0, 0, 0, 0.8); /* 背景に半透明の黒を重ねる */
        z-index: 99999999; /* モーダルを最前面に表示する */
    }


.modal-content_mv {
    /* 修正箇所: 高さの調整 */
    max-height: 100vh;
    overflow: hidden;
    /* 修正箇所: その他スタイル */
    background-color: #fff;
    padding: 0px;
    border-radius: 10px;
    position: relative;
	width: 100%;
    display: flex;           /* Flexboxを使って中央寄せを行う */
    justify-content: center; /* 水平方向の中央寄せ */
    align-items: center;     /* 垂直方向の中央寄せ */
    top: 50%;                /* 親要素の中央に配置 */
    left: 50%;               /* 親要素の中央に配置 */
    transform: translate(-50%, -50%); /* 正確な中央寄せのための調整 */
}


.modal .close {
    position: absolute;
    top: 10px;
    right: 20px;
    font-size: 36px;
    font-weight: bold;
    color: #FFFFFF;
    cursor: pointer;
    z-index: 9999999;
}


@media screen and (min-width: 768px) {
.modal-close {
	top: 10px;
	right: 10px;
}

.modal-close::before,
.modal-close::after {
	width: 40px;
}
.modal-content_mv {
	width: 80%;
	border-radius: 20px;
}

}