﻿@charset "UTF-8";

* {
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-ms-box-sizing: border-box;
	-o-box-sizing: border-box;
}

img {
	vertical-align: middle;
	max-width: 100%;
	height: auto;
	width /***/: auto;
}

.container {
	width: 100%;
}

/*:::::::::::::::::::::::::::::::::::::::::::::::::::::::::: reset */

button, fieldset, form, input, label, legend, select, textarea {
	font-family: inherit;
	font-size: 100%;
	font-style: inherit;
	font-weight: inherit;
	margin: 0;
	padding: 0;
	vertical-align: middle;
}


/*:::::::::::::::::::::::::::::::::::::::::::::::::::::::::: add class */

:root {
  --logo-size: 250px;
  --box-shadow: 0 2px 4px rgba(0,0,0,.1),0 4px 4px -4px rgba(0,0,0,0.7);
}


.floatL {
	float: left;
}

.floatR {
	float: right;
}

.clearB {
	clear: both;
}

.center {
	text-align: center;
}

.right {
	text-align: right;
}

.bold {
	font-weight: bold;
}

            @media screen and (max-width: 719px) {
              br.forPc {
              	display: none;
              }
              }

br.forTab {
	display: none;
}

br.forSp {
	display: none;
}

.hidden {
  display:none;
}

/*:::::::::::::::::::::::::::::::::::::::::::::::::::::::::: container */

html {
	height: 100%;
	margin: 0;
	padding: 0;
  scroll-behavior: smooth;
}

body {
	height: 100%;
	margin: 0;
	padding: 0;
  overflow-x: hidden;
}

article {
  width: 100%;
	margin: 0 auto;
	max-width: 1210px;/* 共通コンテンツ幅 */
	padding-left:30px;
	padding-right:30px;
  padding-bottom: 90px;
}
            @media screen and (max-width:798px) {
                article {
                  padding-left: 20px;
                  padding-right: 20px;
                  padding-bottom: 60px;
                }
                }

.breadCrumb ul {
	max-width: 1210px;
}

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

header {
  display: flex;
	position: fixed;
  height: auto;
  width: 100%;
  top: -50px;
  left: 0;
  opacity: 0;
  z-index: 9;
  /*background-color:rgba(0, 0, 0, 0.562);*/
  padding:0 50px 0 90px;
  color:var(--side-fontcolor);
  transition: all 0.4s ease;
}
.lower header,
header.color {
  top: 0;
  background-color: rgba(255, 255, 255, 0.662);
  font-size:0.86em;
  align-items: flex-start;
  height: 100px;
  opacity: 1;
}


            @media screen and (max-width:1124px) {
                header {
                    padding:15px 20px 10px 20px;
                }
                header.color {
                    display: none;
                }
                }

@media screen and (max-width:1124px) {
	header {
		width: 100%;
    height: auto;
    padding: 10px 20px 10px 20px;
	}
	header #header_logo {
		text-align: left;
    margin: 0;
	}
}

#header_logo {
  width: var(--logo-size);
  margin: 0;
  line-height: 0;
  transition : all 0.5s ease 0s;
}
header.color #header_logo {
  transition : all 0.5s ease 0s;
}

header #header_contents{
	flex: 1;
}
header #header_logo a {
	display: inline-block;
	padding: 20px 0 0;
}
header.color #header_logo a {
	padding: 10px 0 0;
}
                      @media screen and (max-width: 814px) {
                        header #header_logo a,header.color #header_logo a {
                              padding: 0;
                          }
                      }

header #header_logo {
  width: 180px;
  transition: transform 0.4s ease;
  transform-origin: top left;
}
.lower header #header_logo {
  width: 130px;
}

                      @media screen and (max-width: 814px) {
                        header #header_logo {
                              width: 120px;
                          }
                      }

header.color #header_logo {
  transform: scale(0.85);
}
.lower header.color #header_logo {
  transform: scale(0.55);
}

#header_logo img {
  width: 100%;
  display: block;
}

header #header_logo img.b {
  display:none;
}
header.color #header_logo img.w {
  display:none;
  transition: all 0.5s ease 0s;
}
header.color #header_logo img.b {
  display:block;
  max-width: 100px;
  transition: all 0.5s ease 0s;
}

/* nav */
header nav {
  width: calc(100% - var(--logo-size));
}

header > nav ul {
  font-family: var(--sub-font);
  overflow: visible;
  display:flex;
  padding: 0;
  justify-content: space-around;
  font-size: 1.5em;
  margin: 0;
  
}
header > nav ul li {
  position: relative;
  overflow: visible;
  text-align:center;
}
header nav ul > li span {
  display: block;
  font-size: 0.6em;
  font-family: var(--base-font);
}
header nav li {
  list-style:none;
}
header nav li a {
  display:block;
  text-decoration:none;
}
header > nav ul li:hover {
  background-color: rgba(0, 0, 0, 0.862);
  transition : all 0.5s ease 0s;
}
header > nav ul li a {
  color: #fff;
  display: block;
  padding: 20px;
  transition : all 0.5s ease 0s;
}
header.color nav ul > li a {
  padding: 15px 20px;
  transition : all 0.5s ease 0s;
}

header.color nav > ul > li a,
.lower header > nav ul > li a {
  color: #222;
}
            @media screen and (max-width: 1124px) {
              header.color nav > ul > li a,
              .lower header > nav ul > li a {
                color: #FFF;
              }
              }

header nav ul li:hover a{
  color:#FFF;
}
header nav ul > li div {
  background-color: rgba(0, 0, 0, 0.862);
  left: 0;
  opacity: 0;
  position: absolute;
  text-align: center;
  visibility: hidden;
  width: 100%;
  font-size: 0.5em;
  transition : all 0.5s ease 0s;
}
header nav ul > li ul {
  margin: 0 10px 10px;
  display: block;
  border-top:dotted 1px #fcfcfc;
}
header nav ul > li ul li {
  display: block;
  text-align:left;
}
header nav ul > li li a {
  padding: 10px 10px;
}

/* メニューをhoverした時のスタイル */
header > nav ul li:hover div {
  opacity: 1;
  visibility: visible;
}


                  @media screen and (max-width:1124px) {
                  header nav {
                  		display:none;
                  	}
                  header .sp_menu nav {
                    height: 100%;
                    display: flex;
                    flex-direction: column;
                    justify-content: center;
                    width: 100%;
                    }
                  }

header nav .sp_menu_navi {
  padding-left: 10px;
  display: flex;
  flex-wrap: wrap;
}
header nav .sp_menu_navi li {
	list-style: none;
  position:relative;
  margin-bottom: 36px;
}
            @media screen and (max-width: 1124px) {
              header nav .sp_menu_navi li {
                margin-bottom: 20px;
                width: calc(50% - 20px);
              }
              }


            @media screen and (max-height:820px) {
                header nav .sp_menu_navi li {
                    margin-bottom: 20px;
                }
                }
            @media screen and (max-height:765px) {
                header nav .sp_menu_navi li {
                    margin-bottom: 16px;
                }
                }
            @media screen and (max-height:695px) {
                header nav .sp_menu_navi li {
                    margin-bottom: 10px;
                }
                }
            @media screen and (max-height:515px) {
                header nav .sp_menu_navi li {
                    margin-bottom: 9px;
                    line-height: 1.3;
                }
                }

header nav .sp_menu_navi li a {
	text-decoration: none;
  color:#FFF;
  padding-left:25px;
  font-size:1.7em;
  display:block;
}
header nav .sp_menu_navi li a:before {
	content:"";
  display:inline-block;
  width:15px;
  border-top:solid 1.5px var(--side-fontcolor);
  height:1px;
  top:0.7em;
  left:0;
  position:absolute;
}
header nav .sp_menu_navi li a span {
  display: block;
  font-size: 0.5em;
  margin-top: 3px;
  margin-left: 23px;
}
            @media screen and (max-height:515px) {
                header nav .sp_menu_navi li a span {
                    margin-top: 0;
                }
                }


/* contact btn */
.contactBtn {
  position: fixed;
  right: 0;
  top: 0; 
  margin-top: 0;
  z-index: 20;
  color: #fff;
  font-size: 15px;
  font-weight: 600;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.contactBtn a {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px 12px 8px 14px;
  border-radius: 0 0 0 8px;
  text-decoration: none;
  color:#FFF;
  writing-mode: vertical-rl;
  text-orientation: upright;
  background: linear-gradient(135deg,rgba(166, 129, 20, 1) 0%, rgba(191, 154, 42, 1) 18%, rgba(242, 200, 75, 1) 54%, rgba(217, 164, 65, 1) 90%, rgba(242, 186, 82, 1) 100%);;
  overflow: hidden;
}
.contactBtn a:hover {
  color:#FFF;
}
.contactBtn a .bg {
  position: absolute;
  inset: 0;
  background: #000;
  opacity: 0;
  transition: opacity 0.5s ease;
  z-index: 0;
  border-radius: 0 0 0 8px;
}

/* テキストは最前面に */
.contactBtn a .label {
  position: relative;
  z-index: 1;
}

.contactBtn a:hover .bg {
  opacity: 1; /* 黒がフェードインして全体を覆う */
}

.dli-mail {
  display: inline-block;
  vertical-align: middle;
  line-height: 1;
  position: relative;
  width: 1.06667em;
  height: 0.8em;
  border: 0.1em solid currentColor;
  border-radius: 0.1em;
  box-sizing: content-box;
  overflow: hidden;
  margin-bottom:10px;
}

.dli-mail::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 0;
  width: 0.75425em;
  height: 0.75425em;
  border: 0.1em solid currentColor;
  border-top-color: transparent;
  border-right-color: transparent;
  border-radius: 0 0 0 0.1em;
  box-sizing: content-box;
  transform: translate(-50%, -50%) rotate(-45deg) skew(10deg, 10deg);
}



  
/* sns navi */
.snsList {
  padding-top: 10px;
}



.snsList li {
  list-style: none;
  display: inline-block;
  margin-right: 5px;
}
.snsList li img {
  max-width:30px;
}

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

  .snsList li img {
    max-width: 33px;
}
}



/* site info */
header .siteInfo {
    margin-top: 20px;
    text-align: left;
    font-size: 0.9em;
    font-size: 0.9em;
    line-height: 1.9;
}
            @media screen and (max-width: 1124px) {
              header .siteInfo {
              	display: none;
              }
              header .sp_menu .siteInfo {
              	display: block;
                text-align: left;
                margin: 0 20px 20px 10px;
              }
              }
            @media screen and (max-height:695px) {
                header .siteInfo {
                    margin-top: 5px;
                }
                }
            @media screen and (max-height:555px) {
                header .siteInfo {
                    font-size: 0.8em;
                    line-height: 1.5;
                }
                }
            @media screen and (max-height:465px) {
                header .siteInfo {
                    display:none;
                }
                }


.svglogoFrame {
  width: 93%;
  min-width: 236px;
}
            @media screen and (max-width: 1124px) {
              .svglogoFrame {
              	width: 55%;
                margin: 0 auto;
              }
              }


.svglogoFrame svg {
  width: 100% !important;
  height: auto;
  max-width: 250px;
  
  -webkit-transition: all 0.5s;
	-moz-transition: all 0.5s;
	-ms-transition: all 0.5s;
	-o-transition: all 0.5s;
	transition: all 0.5s;
}



/*--------------------------------------- mainContents */
section {
  position:relative;
}
section:nth-of-type(odd) {
  background-color: var(--main-bgcolor);
  color:var(--sub-fontcolor);
}
.body_common section:nth-of-type(odd) a {
  color:#fff;
}
section:nth-of-type(odd) .list_text li a {
  color:#FFF;
}
section:nth-of-type(odd) h5:before {
  border-color:#FFF;
}
.lower section:nth-of-type(odd) {
  background-color: #FFF;
  color: var(--main-bgcolor);
}
.lower section:nth-of-type(odd) .list_text li a {
  color:#222;
}
.lower section:nth-of-type(even) {
  background-color: var(--main-bgcolor);
  color:#fff;
}
section.white {
  background-color: #FFF;
}
section.diagonal::after {
  content: '';
  display: block;
  position: absolute;
  left:0;
  bottom: 0;
  border-bottom: 100px solid transparent;
  border-right: 50vw solid transparent;
  border-left: 50vw solid var(--main-bgcolor);
  border-top: 100px solid var(--main-bgcolor);
  z-index:-1;
}

section:nth-of-type(even)::after {
  content: '';
  display: block;
  position: absolute;
  left:0;
  bottom: 0;
  border-top: 100px solid transparent;
  border-left: 50vw solid transparent;
  border-right: 50vw solid var(--main-bgcolor);
  border-bottom: 100px solid var(--main-bgcolor);
  z-index:-2;
}

section:nth-of-type(even) article {
  padding-bottom:190px;
  margin-bottom: -1px;
}


                      @media screen and (min-width: 2234px) {
                        section:nth-of-type(even) article {
                              padding-bottom:240px;
                          }
                      }
                      @media screen and (min-width: 2630px) {
                        section:nth-of-type(even) article {
                              padding-bottom:340px;
                          }
                      }
                      @media screen and (max-width: 814px) {
                        section:nth-of-type(even) article {
                              padding-bottom:60px;
                          }
                      }

.lower section:nth-of-type(even) article {
  padding-bottom:10px;
}



/*--------------------------------------- footerContact */
.footerContact {
  background-color:#f7f7f7;
  text-align: center;
  padding:60px 20px;
  margin: 0;
}
                      @media screen and (max-width: 814px) {
                        .footerContact {
                              padding:30px 20px;
                          }
                      }

.footerContact a {
  font-family: var(--sub-font);
  position: relative;
  display: inline-block;
  padding:40px 20px;
  background-color:#FFF;
  font-size:2em;
  text-decoration: none;
  max-width: 820px;
  width:100%;
  margin: 0 auto;
  border-radius: 6px;
  border: solid 1px #eaeaea;
  transition: color 0.5s ease;
}
                      @media screen and (max-width: 814px) {
                        .footerContact a {
                              padding:20px 10px;
                              font-size:1.5em;
                          }
                      }

.footerContact a span span {
  display:block;
  font-size:0.5em;
}


.footerContact a:hover {
  color: #fff;
}
.footerContact a:hover::before {
  transform: scaleX(1);
  transform-origin: left;
}
.footerContact a::before {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: var(--main-bgcolor);
  transform: scaleX(0);
  transform-origin: right;
  transition: all 0.5s ease;
  transition-property: transform;
  border-radius: 6px;
  color: #fff;
}
.footerContact a span {
  position: relative;
}




/*--------------------------------------- footer */
footer {
	max-width: 100%;/* フッタ幅100% */
	/* max-width: 1280px; フッタ最大幅1280px */
  background-color:var(--main-color);
  color:#FFF;
  padding:40px 0;
  background-size: 100% auto;
}
            @media screen and (max-width: 1124px) {
            footer {
              padding-bottom:90px;
            }
            }
            @media screen and (max-width: 814px) {
            footer {
              padding: 10px 0 90px;
              background-size: auto 100%;
              }
              }

footer article {
  display: flex;
}

                            @media screen and (max-width:1124px) {
                            	footer article {
                            		display:block;
                            	}
                            }

footer .footerInfo {
  font-family: var(--sub-font);
    font-size: 0.9em;
}
footer .footerInfo a {
  color:#FFF;
}
footer address {
  margin-bottom:10px;
  font-style:normal;
}
footer .calendar_box {
  margin-top:20px;
}

footer .footerNavi {
  width: calc(100% - 250px);
  padding-left: 50px;
  font-size:1.2em;
}
                            @media screen and (max-width:1124px) {
                            	footer .footerNavi {
                            		width: 100%;
                                padding-left: 0;
                            	}
                            }

footer .footerNavi a {
  display:block;
  color:#FFF;
  text-decoration: none;
  padding:30px 10px;
}
footer .footerNavi li span {
  display:inline-block;
  margin-left:20px;
  font-size:0.7em;
}
footer .footerNavi li li a {
  padding:5px 30px;
  color:#b5b5b5;
  font-size:0.9em;
}
footer .footerNavi li li:first-of-type a {
  padding-top:0;
}
footer .footerNavi li li:last-of-type a {
  padding-bottom:25px;
}
footer ul{
	list-style:none;
	margin:0;
	padding:0;
}
footer .footerNavi > ul {
  font-family: var(--sub-font);
  margin-bottom:40px;
  display: flex;
  flex-wrap: wrap;
  gap: 0 30px;
}
            @media screen and (max-width:1124px) {
              footer .footerNavi > ul {
                    display: block;
                }
                }

footer li {
  margin:0;
  padding:0;
}
footer .footerNavi >ul > li {
  border-bottom: 1px solid rgba(255, 255, 255, .1);
  width: calc(50% - 20px);
}
            @media screen and (max-width:1124px) {
              footer .footerNavi >ul > li {
                    width: 100%;
                }
                }


footer .footer_logo a {
	display: inline-block;
	text-decoration: none;
	padding: 10px;
}
footer .footer_logo a img{
	width:150px;
}
footer .footer_copyright {
  font-family: var(--sub-font);
	text-align: right;
	font-size: 0.65em;
}
                            @media screen and (max-width:1124px) {
                            	footer .footer_copyright {
                            		text-align: center;
                            	}
                            }


/*--------------------------------------- sp footer 固定ナビ */

.footerFixedNavi {
  display:none;
  position: fixed;
  height: auto;
  width: auto;
  top: 63px;
  right: 0;
  z-index: 3;
  padding: 0;
  text-align: center;
  margin: 0;
}

.footerFixedNavi li {
  list-style: none;
  padding:0;
  margin:0;
}

.footerFixedNavi a {
  display:block;
  padding:13px 14px 13px 14px;
  border-radius: 8px 0 0 8px;
  background-color: var(--base-fontcolor);
  color: #FFF;
  text-decoration: none;
  font-size:1.1em;
  vertical-align: middle;
  line-height: 1;
  position: relative;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
}
.footerFixedNavi a:hover {
  color: #FFF;
}

.footerFixedNavi li img {
  max-width: 19px;
}
.footerFixedNavi li i {
  margin-right: 8px;
}

@media screen and (max-width: 1124px) {
.footerFixedNavi {
  display: flex;
  
}
.body_contact .footerFixedNavi {
  display:none;
  }
}

/*--------------------------------------- sp_menu */
header #sp_logo {
  text-align: center;
}
header #sp_logo img {
	width:100%;
	vertical-align: middle;
  max-width: 250px;
}
                  @media screen and (max-width:1124px) {
                    header #sp_logo img {
                    max-width:none;
                    max-height:55px;
                    width: auto;
                  }
                  }
            @media screen and (max-height:640px) {
              header #sp_logo img {
                    max-width: 180px;
                }
                }

.sp_menu{
	overflow-y: scroll;
	max-height: 100%;
}
.sp_menu #header_logo {
  margin-bottom: 30px;
}
@media screen and (min-width: 1125px), print {
	.sp_menu_btn,
	.sp_menu {
		display: none;
		/*display: inline-block;
		box-sizing: border-box;*/
	}
}
@media screen and (max-width:1124px) {
	.sp_menu_btn,
	.sp_menu_btn span {
		display: inline-block;
		box-sizing: border-box;
	}
}
.sp_menu_btn {
	position: relative;
	width: 40px;
	height: 34px;
	padding:2px;
}
.sp_menu_btn.close{
	background-color:transparent;
}
.sp_menu_btn span {
	position: absolute;
	width: 36px;
	height: 1px;
	background-color: var(--side-fontcolor);
	border-radius: 4px;
	transition: transform 0.1s;
}
.lower .sp_menu_btn span,
.color .sp_menu_btn span {
  background-color: #000;
}
.sp_menu_btn span:nth-of-type(1) {
	top: 5px;
}
.sp_menu_btn span:nth-of-type(2) {
	top: 18px;
}
.sp_menu_btn span:nth-of-type(3) {
	bottom: 2px;
}
.sp_menu_btn.close span {
  background-color: #FFF;
}
.sp_menu_btn.close span:nth-of-type(1) {
	-webkit-transform: translateY(14px) rotate(-45deg);
	transform: translateY(13px) rotate(-45deg);
}
.sp_menu_btn.close span:nth-of-type(2) {
	opacity: 0;
}
.sp_menu_btn.close span:nth-of-type(3) {
	-webkit-transform: translateY(-15px) rotate(45deg);
	transform: translateY(-13px) rotate(45deg);
}
.sp_menu_btn {
	position: fixed;
	top: 18px;
	right: 10px;
	z-index: 999999;
}
.sp_menu {
	position: fixed;
	z-index: 135;
	right: -100%;
	top: 0;
	width: 90%;
  font-size: 0.8em;
	height: 100%;
	padding: 60px 20px;
	background-color:var(--main-color);
	box-shadow: -5px 0px 10px rgba(0, 0, 0, 0.2);
	overflow-y: auto;
	opacity:0;
	transition: right 0.2s;
}
            @media screen and (max-height:695px) {
                .sp_menu {
                  background-color:#b0b5af;
                }
                }


.sp_menu.menu_fixed {
	right: 0;
	opacity: 10;
}
.sp_menu_bg {
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	display: none;
}
.sp_menu_bg.bg_fixed {
	display: block;
	background-color: transparent;
}


/*--------------------------------------- columnBox */

.columnBox .column {
	padding:1em 20px;
}
@media screen and (min-width: 720px), print {
	.columnBox {
		display: table;
		table-layout: fixed;
		width: 100%;
	}
	.columnBox .column {
		display: table-cell;
		vertical-align: top;
	}
}
.columnBox .column_side {
  display:none;
}

/*:::::::::::::::::::::::::::::::::::::::::::::::::::::::::: common_setting */

img {
	max-width: 100%;
	height: auto !important;
	width /***/: auto;
}
table td img{
	max-width: 100%;
	height:auto !important;
}
iframe{
	max-width:100%;
}
@media screen and (min-width:720px) {
	.only_pc{
		display:block;
	}
	.only_sp{
		display:none;
	}
}
@media screen and (max-width:719px) {
	.only_pc{
		display:none;
	}
	.only_sp{
		display:block;
	}
}

/*--------------------------------------- font */
html {
	font-size: 62.5%;
/* 1em=10px化 */
}

body {
  font-family: var(--base-font);
	line-height: 1.5;
	color: var(--base-fontcolor);
	-webkit-text-size-adjust: 100%;
	font-size: 1.5em;
/* 基準フォントサイズ1.5em=15px */
  letter-spacing: 0.05rem;
	-ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%;
}
@media screen and (max-width:719px) {
	html,body {
		-webkit-text-size-adjust: 100%;
		-webkit-overflow-scrolling: touch;
    font-size: 0.92em;
	}
}

.subFont {
  font-family: var(--sub-font);
}

h1, h2, h3, h4, h5, h6 {
	clear: both;
	position: relative;
}
h1 a, h2 a, h3 a, h4 a, h5 a, h6 a {
	text-decoration: none;
}
.lower h1,
.body_common h2 {
  position: relative;
  z-index: 3;
  font-family: var(--sub-font);
	font-weight: 500;
	padding: 140px 0 50px;
	max-width: 1140px;
	margin: 0 auto;
  line-height: 1.5;
  text-transform: uppercase;
}
.lower h1 {
  padding-top:180px;
}
                      @media screen and (max-width: 1124px) {
                      .lower h1 {
                        padding: 140px 0 20px;
                      }
                      }

                      @media screen and (max-width: 719px) {
                      .body_common h2 {
                              padding: 40px 0 20px;
                          }
                      }

.lower h1 span,
.body_common h2 span {
  display:block;
  font-size: 0.45em;
}

.lower h2 {
  margin: 0;
  padding: 10px 0 30px;
  font-family: var(--sub-font);
}

/* h:変更した場合はstyle_editor.cssにも反映すること */
h3 {
	font-weight: normal;
  margin-bottom: 60px;
  text-align: center;
  font-size: 2em;
  font-weight: bold;
}
h4{
	padding: 0 1em;
	margin: 1em 0;
	font-weight: bold;
	border-left: 3px solid var(--base-fontcolor);
}

h5 {
	margin: 1.5em 0 1em;
	padding: 0 10px 0 30px;
}
h5:before {
	content: "";
	width: 7px;
	height: 7px;
	border-radius: 50%;
	display: inline-block;
	vertical-align: middle;
	border: 6px solid var(--base-fontcolor);
	position: absolute;
	left: 0;
	top: 0.7em;
}
h6 {
	font-weight: bold;
	margin: 1em 0;
	padding:0.2em;
}
@media screen and (min-width: 720px), print {
	.lower h1,
	h2 {
		font-size: 1.85em;
	}
	h3 {
		font-size: 1.65em;
	}
	h4 {
		font-size: 1.3em;
	}
	h5 {
		font-size: 1.1em;
	}
	h6 {
		font-size: 1em;
	}
}
@media screen and (max-width: 719px) {
	.lower h1,
	h2 {
		font-size: 1.8em;
	}
	h3 {
		font-size: 1.4em;
	}
	h4 {
		font-size: 1.2em;
	}
	h5,h6 {
		font-size: 1em;
	}
}
.bold {
	font-weight: bold;
}

/*--------------------------------------- color */

a {
	color: #000000;
  transition: 0.5s;
}
a:hover {
	color: #656565;
  transition: 0.5s;
}
a:hover img{
	opacity: 0.8;
}

/*--------------------------------------- btn */

.btn {
	text-align: right;
	display: block;
	padding: 2.5em 20px;
}
                      @media screen and (max-width: 814px) {
                        .btn {
                              padding: 0 20px;
                          }
                      }

.btn a {
  position:relative;
  z-index: 3;
	padding: 1.4em 2em;
	line-height: 1.5;
	color: #222;
  font-family: var(--sub-font);
	text-decoration: none;
	display: inline-block!important;
  font-size: 1.1em;
  cursor: pointer;
}
.body_common section:nth-of-type(odd) .btn a {
  color:var(--sub-fontcolor);
}

.list_thumbnail li .btn {
  padding: 0.5em 20px;
}
.list_thumbnail li .btn a {
  padding: 1em 2em;
  font-size: 0.9em;
}
.btn a:before,
.btn a:after {
	right: -30px;
  transition: 0.5s;
}

.btn a:before {
  content:'';
  display:inline-block;
  height: 1px;
  background-color: #000;
  top: 50%;
  width: 50px;
  position:absolute;
}
.btn a:after {
  content:'';
  display:inline-block;
  top: 50%;
  transform-origin: right bottom;
  width: 13px;
  height: 1px;
  background-color: #000;
  transform: rotate(45deg);
  position:absolute;
}
section:nth-of-type(odd) .btn a:before,
section:nth-of-type(odd) .btn a:after {
  background-color:var(--sub-fontcolor);
}

.btn a:hover:before,
.btn a:hover:after {
	right: -40px;
  transition: 0.5s;
}
.page_link .btn a:before,
.page_link .btn a:after,
.list_thumbnail li .btn a:before,
.list_thumbnail li .btn a:after {
  content:none;
}

.list_thumbnail li .btn a:before {
  content: '';
  display: inline-block;
  vertical-align: middle;
  color: #333;
  line-height: 1;
  width: 1em;
  height: 1em;
  border: 0.075em solid currentColor;
  background: currentColor;
  border-radius: 50%;
  box-sizing: content-box;
  position: absolute;
  right: 20px;
  top:calc(50% - 0.5em);
}

.list_thumbnail li .btn a:after {
  content: '';
  color: #fff;
  width: 0;
  height: 0;
  border-style: solid;
  border-color: transparent;
  border-width: 0.2em 0.31177em;
  border-left-color: currentColor;
  border-right: 0;
  transform: translateX(15%);
  position: absolute;
  right: calc(20px + 0.4em);
  top:calc(50% - 0.145em);
  margin: auto;
}

/* CMSエディター：ボタン */
.editor-style-btn1 {
	display: inline-block;
	margin: 0.5em 20px;
	color: #FFFFFF;
	border-radius: 5px;
	background-color: #414D99;
	transition: background-color linear 0.2s;
}
.editor-style-btn1:hover {
	background-color: #1d86ed;
}

.editor-style-btn1 a {
	display: inline-block;
	padding: 0.8em 2em;
	color: #FFFFFF;
	text-decoration: none;
}

.editor-style-text1 {
	color: #ffffff;
	text-shadow: 1px 1px 5px rgba(0, 0, 0, 0.3),-1px -1px 5px rgba(0, 0, 0, 0.3);
}

/*--------------------------------------- table */

table {
	border-collapse: collapse;
}
table th,
table td {
	border: 1px solid #CCCCCC;
}
table th {
	background: #eeeeee;
}
table[border="0"],
table[border="0"] th,
table[border="0"] td {
	border: none;
}
table[border="1"],
table[border="1"] th,
table[border="1"] td {
	border: 1px solid #CCCCCC;
}
table[border="1"] th table[border="0"] td,
table[border="1"] td table[border="0"] td {
	border: none;
}

@media screen and (max-width:719px) {
	table th {
		width: auto !important;
	}
	.sp_table td,
	.sp_table th,
	.sp_table tr{
		display: block;
		width: 100%!important;
	}
}
table.responsive,
table.responsive2c {
	border-collapse: collapse;
	font-size: 0.95em;
}
table.responsive[border="0"],
table.responsive[border="0"] th,
table.responsive[border="0"] td,
table.responsive2c[border="0"],
table.responsive2c[border="0"] th,
table.responsive2c[border="0"] td {
	border: none;
}
@media screen and (max-width: 719px) {
	table.responsive,
	table.responsive2c {
		max-width:100%;
	}
	table.responsive td,
	table.responsive th{
		display: block;
		width: 100% !important;
	}
	table.responsive2c td,
	table.responsive2c th{
		float:left;
		width: 50% !important;
	}
	table.responsive td img,
	table.responsive2c td img {
		max-width:100%;
		height:auto;
	}

}
table.responsive[border="0"] td table:not([border="0"]) th,
table.responsive[border="0"] td table:not([border="0"]) td,
table.responsive2c[border="0"] td table:not([border="0"]) th,
table.responsive2c[border="0"] td table:not([border="0"]) td{
	border: 1px solid #dddddd;
}
@media screen and (max-width: 480px) {
	.sp_table[border="0"] td table:not([border="0"]) th,
	.sp_table[border="0"] td table:not([border="0"]) td{
		display: table-cell;
		width: auto !important;
		border-left:none;
		border-top:none;
	}
	table.responsive2c td,
	table.responsive2c th{
		width: 100% !important;
	}
}

/*--------------------------------------- list_text */

.list_text,
.list_text li {
	display: block;
	padding: 0;
	margin: 0;
	list-style: none;
}
.list_text {
	padding: 1em 0;
}
.list_text li .listBox,
.list_text li a {
  display: flex;
  justify-content: left;
  padding: 30px 20px;
  border-bottom:dotted 1px #FFF;
}
                            @media screen and (max-width:1124px) {
                            	.list_text li .listBox,
                            	.list_text li a {
                            		display:block;
                            	}
                            }

.list_text li .listBox span,
.list_text li a span {
  display: block;
}

.list_text li a {
	text-decoration:none;
	color: #777;
  position:relative;
  padding-right:60px;
}
.list_text li a:hover {
  background-color: rgba(0, 0, 0, 0.1);
}

.list_text li a:before {
  content: '';
  display: inline-block;
  vertical-align: middle;
  color: #333;
  line-height: 1;
  width: 1.4em;
  height: 1.4em;
  background: linear-gradient(135deg,rgba(166, 129, 20, 1) 0%, rgba(191, 154, 42, 1) 18%, rgba(242, 200, 75, 1) 54%, rgba(217, 164, 65, 1) 90%, rgba(242, 186, 82, 1) 100%);
  border-radius: 50%;
  box-sizing: content-box;
  position: absolute;
  right: 20px;
  top:calc(50% - 0.5em);
}

.list_text li a:after {
  content: '';
  color: #fff;
  width: 0;
  height: 0;
  border-style: solid;
  border-color: transparent;
  border-width: 0.3em 0.35em;
  border-left-color: currentColor;
  border-right: 0;
  transform: translateX(15%);
  position: absolute;
  right: calc(20px + 0.5em);
  top:calc(50% - 0.05em);
  margin: auto;
}

.list_text li .category {
  width: 140px;
  text-align: center;
  height: 2.2em;
  padding: 0.3em 4px;
  display: inline-block;
  border: solid 1px #222;
  border-radius: 4px;
  font-size: 0.9em;
  background-color: #FFF;
}
                            @media screen and (max-width:1124px) {
                            	.list_text li .listBox span.category,
                              .list_text li a span.category {
                            		display: inline-block;
                                margin-right:15px;
                            	}
                            }

.list_text li .category.ic02 {
  background:#222;
  color:#FFF;
}
.list_text li .date {
  width:120px;
	font-size: 0.9em;
  text-align: center;
  font-weight:500;
  padding-top:0.3em;
}
                            @media screen and (max-width:1124px) {
                              .list_text li .listBox span.date,
                              .list_text li a span.date {
                            		display: inline-block!important;
                                text-align: left;
                            	}
                            }

.list_text li .text {
  width: calc(100% - 260px);
  padding-top: 0.2em;
}
                            @media screen and (max-width:1124px) {
                            	.list_text li .text {
                            		width: 100%;
                                margin-top:10px;
                            	}
                            }

.list_text li .new {
	margin-left: 10px;
	color: #D2202F;
	padding: 0.01em 0.5em;
	border: 1px solid;
	border-radius: 3px;
	display: inline-block!important;
	vertical-align: bottom;
  font-size: 0.85em;
  margin-right: 15px;
}


/*--------------------------------------- list_thumbnail */

.list_thumbnail {
	width:100%;
	padding: 1em 0;
	margin: 0;
}
.list_thumbnail li {
	display: inline-block;
	vertical-align: top;
	margin: 0;
  padding-bottom: 40px;
}
                      @media screen and (max-width: 814px) {
                        .list_thumbnail li {
                              padding-bottom: 15px;
                          }
                      }

.list_thumbnail li a {
	display: block;
	text-decoration: none;
}
.list_thumbnail .listBox {
	display: block;
	padding: 0 15px;
	position: relative;
}
.list_thumbnail .thumbnail {
	display: block;
	overflow: hidden;
	text-align: center;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
	position: relative;
}
.list_thumbnail .thumbnail > span{
	padding: 42% 0;
	display: block;
	height: 100%;
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
	transition: all 0.5s ease-out;
}
.list_thumbnail li a:hover .thumbnail span{
	transform: scale(1.1);
	box-shadow: none;
}
.list_thumbnail .dateBox {
	display: block;
	padding: 0 10px;
	background-color: #fff9eb;
	font-size: 0.9em;
  font-family: var(--sub-font);
}
.list_thumbnail .date,
.list_thumbnail .new {
	margin: 5px;
	display: inline-block;
	vertical-align: middle;
}
.list_thumbnail .date {
	padding: 0.1em 0;
}
.list_thumbnail .new {
	color: #414D99;
	padding: 0.01em 0.5em;
	border: 1px solid;
	border-radius: 100em;
}
.list_thumbnail .title {
	display: block;
	padding: 0.5em 0 0;
  font-size: 1.1em;
  font-weight: 600;
  font-family: var(--sub-font);
}
.list_thumbnail .text {
	display: block;
  padding: 1em 0 1em;
  border-top: 1px solid #222;
  color: #999;
  font-size: 0.9em;
  margin-top: 10px;
}
@media screen and (min-width: 1200px) {
	.list_thumbnailC5 li{
		width: 20%;
	}
	.list_thumbnailC6 li{
		width: 16%;
	}
}
@media screen and (min-width: 720px) {
	.list_thumbnailC1 li{
		width: 100%;
		display:block;
	}
	.list_thumbnailC2 li{
		width: 49.5%;
	}
	.list_thumbnailC3 li{
		width: 32.5%;
	}
	.list_thumbnailC4 li{
		width: 24.5%;
	}
	.list_thumbnailC5 li{
		width: 19.5%;
	}
	.list_thumbnailC6 li{
		width: 15.5%;
	}
}
@media screen and (max-width: 719px) {
	.list_thumbnailC2 .listBox {
		padding: 0 0 2em;
	}
	.column_thumbnail {
		width: 35.2%;
	}
	.list_thumbnail li{
		width: 100%;
	}
	.list_thumbnailC1 li{
		width: 100%;
		display:block;
	}
	.list_thumbnailC4 li{
		width: 49%;
	}
	.list_thumbnailC5 li{
		width: 50%;
	}
	.list_thumbnailC6 li{
		width: 50%;
	}
}
@media screen and (min-width: 480px) {
	.list_thumbnailC2 li .listBox {
		padding: 0 0 3em;
	}
}
@media screen and (max-width: 479px) {
	.list_thumbnailC2 li,
	.list_thumbnailC3 li {
		width: 100%;
	}
}

.body_common .list_thumbnail .title{
	font-size: 1.1em;
	font-weight: bold;
}

/* ------------------------- flexBoxInfo */

.flexBoxInfo {
  margin-bottom:30px;
}

.flexBoxInfo dl {
  position: relative;
  display: flex;
  line-height: 3.0rem;
  margin: 0;
}

                    @media screen and (max-width: 821px) {
                        .flexBoxInfo dl {
                            display: block;
                            line-height: 2.0rem;
                        }
                    }              

.flexBoxInfo dt {
  border-top: solid 1px var(--main-color);
  -webkit-flex-basis: 20rem;
  flex-basis: 20rem;
  margin-right: 2rem;
  margin-bottom: 0;
  padding-top: 2.0rem;
  padding-bottom: 2.0rem;
  font-weight: bold;
}

                    @media screen and (max-width: 821px) {
                        .flexBoxInfo dt {
                          -webkit-flex-basis: 100%;
                          flex-basis: 100%;
                          margin-right: 0rem;
                          padding-top: 10px;
                          padding-bottom: 10px;
                        }
                    } 

.flexBoxInfo dd {
  border-top: solid 1px #e5e5e5;
  position: relative;
  -webkit-flex-grow: 1;
  flex-grow: 1;
  -webkit-flex-basis: 100px;
  flex-basis: 100px;
  text-align: left;
  padding-top: 2.0rem;
  padding-bottom: 2.0rem;
}
                    @media screen and (max-width: 821px) {
                        .flexBoxInfo dd {
                          padding-top: 10px;
                          padding-bottom: 5px;
                          margin-left: 0;
                        }
                    }

.flexBoxInfo .floatL {
  width:62%;
}
.flexBoxInfo .floatR {
  width:38%;
}
.flexBoxInfo .floatR img {
  width:100%;
}
                    @media screen and (max-width: 821px) {
                        .flexBoxInfo .floatL,
                        .flexBoxInfo .floatR {
                          float:none;
                          width:100%;
                        }
                    }

/*--------------------------------------- tab */
.tab {
    display: flex;
    flex-wrap: wrap;
}

.tab > label {
    flex: 1 1;
    order: -1;
    min-width: 70px;
    padding: .9em 1em .7em;
    border-bottom: 1px solid #f0f0f0;
    border-radius: 0;
    background-color: var(--main-bgcolor:);
    color: #535353;
    text-align: center;
    cursor: pointer;
  
}

.tab > label:hover {
    opacity: .8;
}

.tab input {
    display: none;
}

.tab > div {
    display: none;
    width: 100%;
    padding: 1.5em 1em;
    background-color: #fff;
}

.tab label:has(:checked) {
    background-color: #fff;
    border-color: var(--main-color) #f0f0f0 #fff;
    border-style: solid;
    border-width: 4px 1px 1px;
    border-radius: 5px;
    color: #333333;
}

.tab label:has(:checked) + div {
    display: block;
}




/*--------------------------------------- pagetop link */

#page_top {
	align-items: center;
  background: #fff;
  border: 1px solid var(--main-bgcolor);
  box-shadow: var(--box-shadow);
  color: var(--main-bgcolor);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  height: 52px;
  justify-content: center;
  letter-spacing: normal;
  line-height: 1;
  opacity: .75;
  overflow: hidden;
  text-align: center;
  transition: all .25s;
  width: 52px;
  border-radius: 50%;
  transition: background-color .25s, color .25s;
}

#page_top a {
  position: relative;
  display: inline-block;
  width: 19.4px;
  height: 10.2px;
}

#page_top a::before,
#page_top a::after {
  content: "";
  position: absolute;
  top: 0;
  left: calc(50% - 0.5px);
  width: 1px;
  height: 14px;
  border-radius: 9999px;
  background-color: #000000;
  transform-origin: 50% 0.5px;
}

#page_top a::before {
  transform: rotate(45deg);
}

#page_top a::after {
  transform: rotate(-45deg);
}

/*--------------------------------------- joinBtn */
.joinBtn {
  transition: all .25s;
  z-index: 9;
}
.joinBtn a {
  display: inline-block;
  background-color: rgba(0, 0, 0, 0.75);
  padding: 10px 30px 14px;
  text-decoration: none;
  color: #FFF;
  font-family: var(--sub-font);
  text-align: center;
  font-size: 1.2em;
  border-radius: 3px;
  border: 2px double rgba(255, 255, 255, 0.562);
}
.joinBtn span {
  display: block;
  font-size:0.6em;
  padding-top: 2px;
  margin-top: 2px;
  border-top: solid 1px #FFF;
}

/*--------------------------------------- pageprev/next link */

.page_link {
	clear: both;
	width: 100%;
	margin: 0;
	padding: 20px 0;
	text-align: center;
}

.page_link a.page_link_left {
	margin: 0 10px 0 0;
	padding: 0 0 0 12px;
	background: url(img/icon_page_link_left.gif) no-repeat left center;
}

.page_link a.page_link_right {
	margin: 0 0 0 10px;
	padding: 0 12px 0 0;
	background: url(img/icon_page_link_right.gif) no-repeat right center;
}

/*--------------------------------------- pager */

.pager_box{
	clear:both;
	text-align:center;
	margin-top:15px;
}
.pager_box .pager{
	width:2.5em;
	display:inline-block;
	border:1px solid #BFBFBE;
	border-radius:3px;
}
.pager_box .pager a{
	display:block;
	width:100%;
	padding-top:0.5em;
	padding-bottom:0.5em;
}
.pager_box .pager a:link,
.pager_box .pager a:visited{
	color:#333333;
	text-decoration:none;
}
.pager_box .pager a:hover,
.pager_box .pager a:active{
	background:#F1F1F1;
	text-decoration:none;
}
.pager_box .pager_current{
	background:#F1F1F1;
	padding-top:0.5em;
	padding-bottom:0.5em;
}
.pager_box .pager_dot{
	width:1.5em;
	display:inline-block;
}
.pager_box .pager_space{
	width:1em;
	display:inline-block;
	padding-left:0.2em;
	padding-right:0.2em;
}
.pager_box .pager_first{
	display:inline-block;
}
.pager_box .pager_last{
	display:inline-block;
}

/*--------------------------------------- breadCrumb */

.breadCrumb ul {
	padding: 17px 30px;
	margin:0 auto;
}
.breadCrumb li {
	display: inline;
}

.lower .breadCrumb {
	background-color: #FFF;
  text-align: right;
  margin-top: 100px;
}
.lower .breadCrumb:last-of-type {
	color: #FFF;
	background-color: #444444;
  margin-top: 0;
}

.lower .breadCrumb ul {
  text-align: right;
  font-size:0.8em;
}
.lower .breadCrumb:last-of-type ul {
  text-align: left;
  font-size:1em;
}

.breadCrumb li a {
  position:relative;
  display: inline-block;
	margin-right: 10px;
	padding-right: 36px;
	text-decoration: none;
  color: #222;
}
.lower .breadCrumb:last-of-type li a {
	color: #FFF;
}
.breadCrumb li a::before, .breadCrumb li a::after {
  content: '';
  position: absolute;
  width: 0.6em;
  height: 0.6em;
  background: currentColor;
  border-radius: 0.1em;
  transform: translateX(-25%) rotate(45deg);
  top: calc(50% - 0.2em);
}

.breadCrumb li a::before {
  right: 0;
  height: 0.1em;
}

.breadCrumb li a::after {
  right: 6px;
  bottom: 0;
  width: 0.1em;
  top:calc(50% - 0.1em);
}

.dli-home {
  display: inline-block;
  vertical-align: middle;
  color: #FFF;
  line-height: 1;
  position: relative;
  width: 1em;
  height: 0.75em;
  border: 0.1em solid currentColor;
  border-top: 0;
  box-sizing: border-box;
}

.dli-home::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  width: 0.70711em;
  height: 0.70711em;
  border: 0.1em solid currentColor;
  border-right: 0;
  border-bottom: 0;
  box-sizing: border-box;
  transform: translate(-50%, -46%) rotate(45deg) skew(-10deg, -10deg);
}

.dli-home::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -0.1em;
  width: 45%;
  height: 75%;
  background: #444444;
  border: 0.1em solid currentColor;
  border-bottom: 0;
  box-sizing: border-box;
  transform: translateX(-50%);
}


/*--------------------------------------- 詳細ページスタイル 01 */

.container.detailStyle {
  font-family: var(--sub-font);
}

.container.detailStyle .main {
  position:relative;
  margin-bottom: 40px;
}
.container.detailStyle .main h2 {
  position:relative;
  position: absolute;
  top: 0;
  left: 0;
  background-color: rgba(255, 255, 255, 0.562);
  padding: 10px 20px;
  font-size: 2em;
}
.container.detailStyle .thumbnail {
  float:right;
  width:30%;
  margin:0 0 30px 30px;
}
.container.detailStyle .thumbnail.sp {
  margin-top:20px;
}
                        @media screen and (max-width: 719px) {
                          .container.detailStyle .main h2 {
                            font-size:1.3em;
                          }
                            .container.detailStyle .thumbnail {
                                float:none;
                                width:100%;
                                margin:0 0 20px;
                                display:block;
                                text-align: center;
                          }
                            .container.detailStyle .thumbnail img {
                                width:80%;
                          }
                          .container.detailStyle .thumbnail.pc {
                            display:none;
                          }
                          }

.container.detailStyle .thumbnail span {
  display:block;
}


/*--------------------------------------- dli-zoom-in（拡大表示アイコン） */

.dli-zoom-in {
  display: inline-block!important;
  vertical-align: middle;
  color: #333;
  line-height: 1;
  width: 0.7em;
  height: 0.7em;
  border: 0.1em solid currentColor;
  border-radius: 50%;
  box-sizing: content-box;
  position: relative;
  margin-right: 6px;
}

.dli-zoom-in::before {
  content: '';
  position: absolute;
  top: calc(85.35534% + 0.07071em);
  left: calc(85.35534% + 0.07071em);
  width: 0.336em;
  height: 0.1em;
  background: currentColor;
  border-radius: 0 0.1em 0.1em 0;
  transform: translateY(-50%) rotate(45deg);
  transform-origin: left center;
}

.dli-zoom-in > span {
  width: 58%;
  height: 0.1em;
  background: currentColor;
  border-radius: 0.1em;
  position: relative;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}

.dli-zoom-in > span::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: inherit;
  border-radius: inherit;
  transform: rotate(90deg);
}


/*--------------------------------------- waves */
.waves {
  position:relative;
  width: 100%;
  height:15vh;
  margin-bottom:-7px; /*Fix for safari gap*/
  min-height:100px;
  max-height:150px;
}
.parallax > use {
  animation: move-forever 25s cubic-bezier(.55,.5,.45,.5)     infinite;
}
.parallax > use:nth-child(1) {
  animation-delay: -2s;
  animation-duration: 7s;
}
.parallax > use:nth-child(2) {
  animation-delay: -3s;
  animation-duration: 10s;
}
.parallax > use:nth-child(3) {
  animation-delay: -4s;
  animation-duration: 13s;
}
.parallax > use:nth-child(4) {
  animation-delay: -5s;
  animation-duration: 20s;
}
@keyframes move-forever {
  0% {
   transform: translate3d(-90px,0,0);
  }
  100% { 
    transform: translate3d(85px,0,0);
  }
}
/*Shrinking for mobile*/
@media (max-width: 768px) {
  .waves {
    height:40px;
    min-height:40px;
  }
}

/*:::::::::::::::::::::::::::::::::::::::::::::::::::::::::: TOPpage（common） */

/* ---------------------------------------- スライド */
/* 横へスライド */
.slider {
  text-align: center;
    font-size: 18px;
    background: #fff;
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    -webkit-align-items: center;
    align-items: center;
    position: relative;
  overflow: hidden;
}
.slider.hidden {
  display:none;
}
@media screen and (max-width:719px) {
	.slider {
    font-size: 0.92em;
	}
}

.slider .slick-track {
  height:700px;
  overflow-y: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
}
.height100 .slider .slick-track {
  height:100svh;
}
.height80 .slider .slick-track {
  height:80vh;
}
.height70 .slider .slick-track {
  height:70vh;
}
.slider .slick-slide {
  float:none;
  width:auto!important;
  height:100% !important;
  flex: 1;
}
.slider .slick-dotted.slick-slider {
  margin-bottom: 0!important;
}
.slider .slick-slide div {
  display: flex;
    justify-content: center;
    align-items: center;
    height: 100svh;
}


/* フェイドイン */
.zoom-fade {
  overflow: hidden;
  width: 100%;
  
  margin: 0 auto;
}
.height100 .zoom-fade {
  height: 100svh;
}
.height80 .zoom-fade {
  height: 80vh;
}
.height70 .zoom-fade {
  height: 70vh;
}
.height100 .zoom-fade img {
  height: 100svh!important;
}
.height80 .zoom-fade img {
  height: 80vh!important;
}
.height70 .zoom-fade img {
  height: 70vh!important;
}
.zoom-fade__item {
  object-fit: cover;
}
.zoom-fade span {
  padding: 30% 0;
  display: block;
  height: 100%;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  transition: all 0.5s ease-out;
}
.height100 .zoom-fade span {
  height: 100svh;
}
.height80 .zoom-fade span {
  height: 80vh;
}
.height70 .zoom-fade span {
  height: 70vh;
}
.add-animation {
  /* アニメーション名 アニメーションにかかる時間 アニメーションの実行前後の状態 */
  /* zoom-fade 10秒 [実行前]最初のキーフレーム（0%） → [実行後]最後のキーフレーム（100%） */
  animation: zoom-fade 10s both;
}

@keyframes zoom-fade {

  0% {
    /*transform: scale(1.05);*/
    transform: scale(1);
  }

  100% {
    /*transform: scale(1);*/
    transform: scale(1.05);
  }

}





.slideFrame {
    position: relative;
}

                      @media screen and (max-width: 1124px) {
                      .slideFrame {
                        margin-top: 74px;
                      }
                      .slideFrame.height100,
                      .slideFrame.height80,
                      .slideFrame.height70 {
                        margin-top: 0;
                      }
                      }

.slideFrame:after {
  content:"";
  width: 100%;
  height: 100%;
  display:block;
  background-color: rgba(0, 0, 0, 0.58);
  position: absolute;
  top: 0;
  left: 0;
}

.sliderText {
    display: flex;
    display: -webkit-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    -webkit-justify-content: end;
    top: auto;
    bottom: 0;
    position: absolute;
    width: 100%;
    height: 100%;
    left: auto;
    right: 0;
    padding: 20px;
    color: #FFF;
    min-height: 5em;
    z-index: 1;
    text-align: center;
    font-size: 2.2em;
    font-family: var(--base-font);
    text-shadow: 0px 0px 9px rgba(0, 0, 0, 0.5);
}
.height100 .sliderText {
  height:100svh;
}
.height80 .sliderText {
  height:80vh;
  height: -webkit-fill-available;
}
.height70 .sliderText {
  height:70vh;
  height: -webkit-fill-available;
}
.sliderText .text {
  position: relative;
    /* top: 25%; */
    height: 100%;
    width: 100%;
    /* -webkit-transform: translateY(-25%); */
    /* transform: translateY(-25%); */
    display: -webkit-box;
    display: -ms-flexbox;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}
                      @media screen and (max-width: 814px) {
                        .sliderText .text {
                              flex-direction: column;
                              justify-content: center;
                              text-align: center;
                              display: flex;
                              margin: 0 auto;
                          }
                      }

.sliderText .text dl {
  margin: 0 0 80px;
}

.sliderText .text .sp {
    display:none;
}

.sliderText .text dt {
  font-family:var(--sub-font);
  font-size: 1.3em;
  font-weight: 500;
  margin-bottom: 15px;
}
                      @media screen and (max-width: 814px) {
                        .sliderText .text dt {
                              font-size: 1.15em;
                          }
                      }

.sliderText .text .sliderLogo img {
  max-width: 230px;
}
                      @media screen and (max-width: 814px) {
                        .sliderText .text .sliderLogo img {
                              max-width: 190px;
                          }
                      }

rt {
  font-size: 0.4em;
  margin-bottom:3px;
}
.sliderText .text dd {
  display:inline-block;
  margin:0;
  font-size: 0.53em;
  padding: 0 20px;
}

                      @media screen and (max-width: 814px) {
                        .sliderText .text dl {
                              margin-top:0;
                              margin-bottom:0;
                          }
                          .sliderText .text .pc {
                              display:none;
                          }
                          .sliderText .text .sp {
                              display:block;
                            font-size: 0.8em;
                          }
                        .sliderText .text dd {
                          padding: 0 20px 30px;
                        }
                      }


#keyNews {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  font-family: var(--sub-font);
  z-index: 1;
  background-color: rgba(0, 0, 0, 0.262);
}

#keyNews.list_text li a,
#keyNews.list_text li .listBox {
  display:block;
  padding: 0 20px;
  border-bottom: none;
}
#keyNews.list_text li .listBox .category {
  border: solid 1px #FFF;
}
#keyNews.list_text li .date,
#keyNews.list_text li .text {
  color:#FFF;
}

#keyNews.list_text li .listBox span {
  display: inline-block;
}
#keyNews.list_text li .text {
    width: calc(100% - 270px);
}
                      @media screen and (max-width: 814px) {
                        #keyNews.list_text li .text {
                              width: 100%;
                          }
                      }


/* ---------------------------- scroll down */
.scroll {
  position: absolute;
  left: 50px;
  bottom: 200px;
  writing-mode: vertical-rl;
}
.scroll::before {
  animation: scroll 2s infinite;
  background-color: #2F2F2F;
  bottom: -115px;
  content: "";
  height: 100px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  width: 1px;
  z-index: 2;
}
.scroll::after {
  background-color: #FFD95E;
  bottom: -115px;
  content: "";
  height: 100px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  width: 1px;
}
@keyframes scroll {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  51% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
}


/* ---------------------------------------- 注目文 */
.body_common .attention {
  font-size: 13.4vw;
  font-feature-settings: "palt";
  margin: 0;
  padding: 0;
  line-height:1;
  text-align: center;
}

/* ---------------------------------------- 導入文 */
#introduction::after {
  border-right: 50vw solid #f8f8f8;
  border-bottom: 100px solid #f8f8f8;
}
.introduction {
  position:relative;
  z-index:3;
  font-family: var(--sub-font);
  font-size: 1.3em;
  line-height: 2;
}
            @media screen and (max-width: 695px) {
              .introduction {
                    font-size: 1em;
                }
                }

.body_common .img01 {
  position: absolute;
  top: 70px;
  right: 0;
  width: 25%;
  box-shadow: var(--box-shadow);
}
            @media screen and (max-width: 695px) {
              .body_common .img01 {
                    position: relative;
                }
                }

.body_common .img02 {
  position: absolute;
  top: 420px;
  right: 20%;
  width: 20%;
  box-shadow: var(--box-shadow);
}

            @media screen and (max-width: 695px) {
              .body_common .img01,
              .body_common .img02 {
                    position: relative;
                    top:auto;
                    right:auto;
                    width:75%;
                }
              .body_common .img02 {
                    margin-left:25%;
                }
                }


.body_common .img01::before,
.body_common .img02::before {
    z-index: 1;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: -webkit-gradient(linear, left bottom, left top, from(rgba(15, 21, 26, 0.3)), to(rgba(15, 21, 26, 0.3)));
    /* background: -webkit-linear-gradient(bottom, rgba(15, 21, 26, 0.3) 0%, rgba(15, 21, 26, 0.3) 100%); */
    /* background: linear-gradient(0deg, rgba(15, 21, 26, 0.3) 0%, rgba(15, 21, 26, 0.3) 100%); */
    content: "";
}
.body_common .img01::after,
.body_common .img02::after {
    content: "";
    position: absolute;
    left: 2.5%;
    bottom: 0;
    width: 95%;
    height: 90%;
    z-index: -10;
    transition: all .4s 
cubic-bezier(.19, 1, .22, 1);
    transition-timing-function: 
cubic-bezier(.19, 1, .22, 1);
    box-shadow: 0 3px 30px rgba(182, 182, 186, .6);
}

/* ---------------------------------------- topics */
.body_common #topics {
  background-color:#f8f8f8;
}
.body_common #topics h2 {
  padding: 50px 0 50px;
}
.body_common #topics .btn {
    padding: 0 20px;
}
#topics .list_thumbnail .title {
  font-weight:normal;
  font-family: var(--sub-font);
  text-align: left;
  padding: 0.5em 0 0;
}
#topics .list_thumbnail .thumbnail span {
    padding: 48.5% 0;
}
#topics .list_thumbnail .listBox {
    padding: 0 20px 1em;
}
#topics .list_thumbnail .text {
  padding: 0.5em 0 1em;
  font-family: var(--sub-font);
}

                        @media screen and (max-width: 479px) {
                            #topics .list_thumbnailC2 li, .list_thumbnailC3 li {
                                width: 50%;
                            }
                          #topics .list_thumbnail .listBox {
                          padding: 0 8px 1em;
                          }
                          #topics .list_thumbnail .title {
                            font-size:0.9em;
                          }
                        }

.body_topics .msg {
  font-family: var(--sub-font);
}
.body_topics .msg .thumbnail {
  float:right;
  width:30%;
  margin:0 0 30px 30px;
}
                        @media screen and (max-width: 719px) {
                            .body_topics .msg .thumbnail {
                                float:none;
                                width:100%;
                                margin:0 0 20px;
                                display:block;
                                text-align: center;
                          }
                            .body_topics .msg .thumbnail img {
                                width:80%;
                          }
                          }

.body_topics .msg .thumbnail span {
  display:block;
  font-size: 0.7em;
}
.otherArticles dt {
  padding: 50px 0 20px;
  font-size: 1.2em;
}
.otherArticles dd {
  padding: 0;
  margin:0;
}
.otherArticles a {
  color:#FFF;
}


/* ---------------------------------------- アクセス */
#about .msg {
  width:80%;
  max-width: 560px;
  margin:0 auto 30px;
}

/* ---------------------------------------- activity */
#activity .msg {
  width:55%;
  margin:0 0 40px;
}
                      @media screen and (max-width: 814px) {
                        #activity .msg {
                              width:75%;
                              background-color: rgba(255, 255, 255, 0.862);
                              padding: 10px;
                          }
                      }

#activity .pic {
  position: absolute;
  top: 10%;
  right: 0;
  width:40%;
  display: block;
  height: 100%;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  transition: all 0.5s ease-out;
  padding: 25.5% 0;
  z-index: -1;
  box-shadow: var(--box-shadow);
}
                      @media screen and (max-width: 814px) {
                        #activity .pic {
                              height: auto;
                              top: 5%;
                              width:35%;
                          }
                      }

/* ---------------------------------------- join */
#join .msg {
  border:solid 1px #fff;
  border-radius:10px;
  padding:30px;
}

/* ---------------------------------------- member */
#member .profileArea {
  padding-bottom:50px;
  border-top:dotted 1px #cfcfcf;
  padding-top: 70px;
  font-family:var(--sub-font);
}
                      @media screen and (max-width: 814px) {
                        #member .profileArea {
                              padding-bottom:0;
                          }
                      }

#member .profileArea:first-of-type {
  border-top:none;
  padding-top: 0;
}
#member .pic01 {
  float: right;
  width: 30%;
  text-align: center;
}
#member .pic01 img {
  box-shadow: var(--box-shadow);
}
#member .profileArea:nth-child(odd) .pic01 {
  float: left;
}
#member .floatL {
  width: 65%;
}
#member .profileArea:nth-child(odd) .floatL {
  float:right;
}

            @media screen and (max-width: 719px) {
              #member .pic01,
              #member .floatL {
                float:none;
                width:100%;
              }
              #member .pic01 img {
                width:70%;
              }
              }
              
              
#member .name {
  font-size: 1.9em;
  letter-spacing: 0.2em;
  line-height: 1.5;
}
#member .name,
#member .name_kana {
  margin-block-end: 0;
  margin-block-start: 0;  
}
#member .name_kana {
  font-size: 0.9em;
  margin-bottom:2em;
}
#member .type {
  margin-bottom:2em;
}
#member .profile {
  line-height:2;
  padding-bottom:20px;
}
#member .profile .text {
  padding-bottom:20px;
}
#member .pic02 {
  text-align: center;
}
#member .pic02 img {
  max-width: 820px;
  width: 100%;
}


.body_member .type {
  margin: 0;
  font-size: 0.8em;
}
.body_common #member .btn a {
  background-color:#FFF;
}

/* ---------------------------------------- privacy */

.privacy {
  padding: 15px 40px;
  overflow-y: scroll;
  font-size: 0.8em;
  width: 80%;
  height: 250px;
  border: solid 1px #ccc;
  margin:40px auto 40px;
}
                         @media screen and (max-width:708px) {
                        .privacy {
                          width:100%;
                          padding: 15px 20px;
                        }
                      }




/*:::::::::::::::::::::::::::::::::::::::::::::::::::::::::: clear */
.msg:after,
#topics:after,
.profile:after,
section:after,
article:after,
#message .profile:after,
.menuList .listBox:after {
	content: "";
	display: block;
	clear: both;
}




/*:::::::::::::::::::::::::::::::::::::::::::::::::::::::::: cms common */

.invisible {
	display: none;
}
a.tooltiplink {
	display: inline-block;
	margin: 1px 3px 0;
	padding: 1px 3px 0;
	border: 2px solid #C7C7C7;
	background-color: #075698;
	border-radius: 5px;
	-moz-border-radius: 5px;
	text-decoration: none;
	color: #FFFFFF;
	font-size: 1.0em;
	font-weight: bold;
}
#input-table a.tooltiplink:link,
#input-table a.tooltiplink:visited {
	font-weight: bold;
	color: #FFFFFF;
	text-decoration: none;
}
#input-table a.tooltiplink:hover,
#input-table a.tooltiplink:active {
	font-weight: bold;
	color: #DDDDDD;
	text-decoration: none;
}
a.tooltiplink:link,
a.tooltiplink:visited {
	font-weight: bold;
	color: #FFFFFF;
	text-decoration: none;
}
a.tooltiplink:hover,
a.tooltiplink:active {
	font-weight: bold;
	color: #DDDDDD;
	text-decoration: none;
}
p.tooltipbox {
	position: absolute;
	top: 100px;
	left: 20px;
	font-size: 1.0em;
	margin: 0;
	padding: 10px;
	min-width: 100px;
	min-height: 30px;
	color: #FFFFFF;
	background: #075698;
	border: 2px solid #075698;
	border-radius: 5px;
	-moz-border-radius: 5px;
}
#input-table p.tooltipbox a:link,
#input-table p.tooltipbox a:visited {
	font-weight: bold;
	color: #FFFFFF;
	text-decoration: underline;
}
#input-table p.tooltipbox a:hover,
#input-table p.tooltipbox a:active {
	font-weight: bold;
	color: #DDDDDD;
	text-decoration: underline;
}
p.tooltipbox a:link,
p.tooltipbox a:visited {
	font-weight: bold;
	color: #FFFFFF;
	text-decoration: underline;
}
p.tooltipbox a:hover,
p.tooltipbox a:active {
	font-weight: bold;
	color: #DDDDDD;
	text-decoration: underline;
}

/* comment form */
.comment_box {
	width: 100%;
	margin: 0 0 15px;
	padding: 0;
	border-collapse: collapse;
	border: solid 1px #cccccc;
	background: #eeeeee;
}
.comment_box th,
.comment_box td {
	padding: 10px;
}
.comment_id {
	width: 10%;
	text-align: left;
	white-space: nowrap;
}
.comment_name {
	width: 70%;
	text-align: left;
}
.comment_regist {
	width: 20%;
	text-align: right;
	vertical-align: bottom;
	white-space: nowrap;
	font-size: 0.8em;
	color: #aaaaaa;
}
.comment_box td {
	padding-top: 0;
}
.comment_text {
	padding: 15px;
	background: #ffffff;
}
.icon_comment {
	text-align: right;
}
.icon_comment a {
	padding-left: 30px;
	background: url(./icon_comment.gif) no-repeat left center;
}
/* twitter widget */
#twtr-hd h3,
#twtr-hd h4,
.twtr-widget h3,
.twtr-widget h4,
.twtr-widget p,
.twtr-widget-profile h3,
.twtr-widget-profile h4 {
	clear: none;
	margin: auto;
	padding: auto;
	font-size: auto;
	color: auto;
	border: none;
	background-image: none;
}
/* twitter tweet button */
iframe.twitter-share-button {
	width: 115px!important;
}

/*--------------------------------------- cms form */
.form_flow {
    position: relative;
    margin: 0 0 40px;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.form_flow li {
    position: relative;
    list-style-type: none;
    text-align: center;
    text-transform: uppercase;
    width: 33.333%;
    color: #999999;
    font-weight: bold;
    counter-increment: steps;
}
.form_flow li:before {
    display: block;
    width: 26px;
    height: 26px;
    margin: 7px auto 20px auto;
    line-height: 26px;
    font-size: 12px;
    text-align: center;
    border-radius: 50%;
    background-color: #F5F5F5;
    content: counter(steps);
    z-index: 3;
    position: relative;
}
.form_flow li:after {
    position: absolute;
    z-index: 1;
    top: 15px;
    left: -50%;
    width: 100%;
    height: 2px;
    content: '';
    background-color: #F5F5F5;
}
.form_flow li:first-child:after {
    content: none;
}
.form_flow li.current,
.form_flow li.complete{
    color: var(--base-fontcolor);
}
.form_flow li.current:before,
.form_flow li.complete:before {
    background-color: var(--base-fontcolor);
    color: #FFF;
}
.form_flow li.current:after,
.form_flow li.complete:after {
    background-color: #0070BD;
}






.contact_msg {
	font-size: 0.9em;
	margin: 0 auto;
}

.contact_msg_complete {
	padding: 40px;
	margin-bottom:30px;
	box-shadow: inset 0 0 0 2px #f0f0f0;
}

.contact_msg .editor-style-btn1 {
	float: right;
}

.contact_msg .editor-style-btn1:after {
	content: "";
	display: block;
	width: 100%;
	clear: both;
}

.error_box {
	font-size: 0.95em;
	margin: 0 auto;
	background-color: #fff7f6;
	box-shadow: 1px 0px #e5e5e5,-1px 0px #e5e5e5;
	padding: 20px 5%;
}

.error_box .error {
	color: #e72719;
	font-weight: bold;
	padding-bottom: 10px;
	border-bottom: 2px solid #e72719;
}

.error_box .error_msg {
	margin-top: 20px;
}

.contact form {
	text-align: center;
}

#input-table {
	display: block;
	width: 100%;
	max-width: 100%;
}

#input-table table {
	width: 100%;
	padding: 5px;
	margin: 10px auto 20px;
	border: none;
	background-color: #ffffff;
}

#input-table table li {
	margin-left: 0;
}

#input-table table th {
	width: 35%;
	padding: 20px 60px 20px 30px;
	color: #3f4242;
	background: rgba(0, 0, 0, 0);
	text-align: left;
	border: none;
	position: relative;
	vertical-align: top;
}

#input-table table td {
	padding-left: 10px;
}

#input-table table tr {
	transition: background-color linear 0.2s;
	border-top: 1px solid #ccc;
}

#input-table table tr:hover {
	background-color: rgba(0, 0, 0, 0.05);
}

#input-table table tr:first-child {
	border-top: none;
}

#input-table table tr:last-child {
	border-top: 2px solid #f0f0f0;
}

.input_required,
.input_not_required:before {
	font-size: 0.9em;
	padding: 2px 6px;
	display: inline-block;
	color: #fff;
	background-color: var(--base-fontcolor);
	position: absolute;
	right: 10px;
	top: 20px;
}
.input_not_required:before {
	color: #ffffff;
}
.input_not_required:before {
	content: "任意";
	background-color: #adadad;
	text-align: center;
}
#input-table .error_msg,
#input-table .error_msg_js {
	padding : 5px 5px 5px 20px;
	background: url(./img/form_error.gif) left 10px no-repeat;
}

#input-table table td {
	padding: 20px 30px;
	border: none;
	text-align: left;
}

#input-table table tr:last-child td {
	text-align: center;
}

#input-table div.formcomment {
	clear: both;
	margin-left: 7px;
	margin-top: 3px;
}

#input-table table td ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

input[type="text"],
input[type="password"] {
	border: 0;
	padding: 4px;
	border: solid 1px #ccc;
	max-width: 100% !important;
	resize: none;
	border-radius: 5px;
}

.body_textbook_form input[type="text"] {
	margin-bottom: 10px;
}

#input-table table .form_input_addnumber {
	width: 40% !important;
}

#input-table table textarea {
	padding: 10px;
	width: 96% !important;
	border: solid 1px #ccc;
	-webkit-border-radius: 4px;
	-moz-border-radius: 4px;
	border-radius: 4px;
}

input:focus,
input:textarea {
	border: solid 1px #414D99;
}

.input_button {
	font-size: 1.2em;
	font-weight: bold;
	-webkit-appearance: none;
	padding: 4px 10px;
	background-color: var(--main-bgcolor);
  color: var(--sub-fontcolor);
	border: none;
	cursor: pointer;
}

#input-table .input_button {
	padding: 30px 50px;
  width: 80%;
  max-width: 470px;
}

#input-table .submit_button {
	text-align: center;
	padding-top: 20px;
}

#input-table .privacy {
	font-size: 0.9em;
	height: 200px;
	overflow: auto;
	border: 1px solid #ddd;
	padding: 10px;
	background: #ffffff;
}

/* セパレーター */
#input-table table tr.input-formgroup-blank th{
	background:#F0F0F0;
	border:none;
}
#input-table table tr.input-formgroup{
	padding-top:20px;
}
#input-table table tr.input-formgroup th{
	text-align:left;
	border:none;
	padding:10px 0 5px 50px;
	background-image:url(./img/icon_arrow_down.png);
	background-repeat:no-repeat;
	background-position: 5px 10px;
	background-color:#074D93;/* セパレーターth背景色 */
	border-top:2px solid #EEEEEE;
	border-left:2px solid #EEEEEE;
	border-right:2px solid #EEEEEE;
	border-bottom:1px solid #EEEEEE;
	border-radius: 5px 5px 0 0 / 5px 5px 0 0;
	-webkit-border-radius: 5px 5px 0 0 / 5px 5px 0 0;
	-moz-border-radius: 5px 5px 0 0 / 5px 5px 0 0;
}
#input-table table tr.input-formgroup th.formgroup-closed{
	background-image:url(./img/icon_arrow_down.png);
	background-repeat:no-repeat;
	background-position: 5px 10px;
	border-bottom:2px solid #EEEEEE;
	border-radius: 5px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
}
#input-table table tr.input-formgroup th:hover{
	cursor:pointer;
	filter: alpha(opacity=90);
	opacity:0.90;
	-moz-opacity:0.90;
	-ms-filter: "alpha(opacity=90)";
}
#input-table table tr.input-formgroup span.input-formgroup-title{
	display:block;
	color:#FFFFFF;/* セパレータータイトル文字色 */
	font-size:1.3em;/* セパレータータイトル文字サイズ */
	padding-bottom:5px;
}
#input-table table tr.input-formgroup span.input-formgroup-text{
	position: relative;
	display:block;
	color:#FFFFFF;/* セパレーター説明文文字色 */
	padding:0 5px 0 1em;
	margin:5px 10px 10px 10px;
	border-radius: 2px;
	-webkit-border-radius: 2px;
	-moz-border-radius: 2px;
}
#input-table table tr.input-formgroup span.input-formgroup-text:before{
	position: absolute;
	top: 0.5em;
	left: 0;
	width: 0.5em;
	height: 0.5em;
	background: #FFFFFF;
	content:"";
	border-radius: 1px;
	-webkit-border-radius: 1px;
	-moz-border-radius: 1px;
}
#input-table table tr.input-formgroup span.input-formgroup-text a:visited,
#input-table table tr.input-formgroup span.input-formgroup-text a:link{
	color:#FFFFFF;/* セパレーター説明文内リンク色1 */
	text-decoration:underline;
}
#input-table table tr.input-formgroup span.input-formgroup-text a:hover,
#input-table table tr.input-formgroup span.input-formgroup-text a:active{
	color:#66FFFF;/* セパレーター説明文内リンク色2 */
	text-decoration:underline;
}
@media screen and (max-width:719px) {
	#input-table table {
		width: 100%;
		border-collapse: collapse;
		border-bottom: 1px solid #CCCCCC;
	}

	#input-table table th ,
		#input-table table td {
		width: 100%;
		display: block;
		border-top: none;
		text-align: left;
	}

	#input-table table th {
		padding: 6px 45px 6px 12px;
		background: #eeeeee none repeat scroll 0 0;
		font-weight: normal;
	}
	#input-table table td {
		padding-bottom: 20px;
	}
	#input-table table td:after {
		content:"";
		display:block;
		clear:both;
	}
	input[type="text"], input[type="password"] {
		width: 100%!important;
	}
	#input-table table textarea {
		width: 96%;
		max-height: 24vw;
		font-size: 110%;
	}
	.input_required,
	.input_not_required:before {
		position: absolute;
		right: 10px;
		font-size: 0.8em;
		top: 6px;
	}
}


/*:::::::::::::::::::::::::::::::::::::::::::::::::::::::::: pages */
.msg {
  font-size: 1.3em;
  line-height:2;
  font-family: var(--sub-font);
  margin:0 auto 30px;
}
                      @media screen and (max-width: 814px) {
                        .msg {
                              font-size: 1em;
                          }
                      }

.lower .msg {
  font-size: 1em;
}
                      @media screen and (max-width: 814px) {
                        .lower .msg {
                              font-size: 1em;
                          }
                      }

/*:::::::::::::::::::::::::::::::::::::::::::::::::::::::::: sp */

.pc {
  display:block;
}
.sp {
  display:none;
}
                      @media screen and (max-width: 814px) {
                          .pc {
                              display:none;
                          }
                          .sp {
                              display:block;
                          }
                      }