/* CSS Document */ :root {
  --navbar-height: 120px;
  --header-height: 160px;
  --scroll-offset: 160px;
  --default-font: "Zen Maru Gothic", serif;
  --nav-font: "BIZ UDPGothic", sans-serif;
  --header-font: "Kiwi Maru", serif;
  --num-font: "Roboto Condensed", sans-serif;
}
/************************/
/* ■ベース設定　　　　　　　*/
/************************/
html, body {
	overflow: hidden;
	height: 100%;
	font-family: var(--default-font);
	font-weight: 400;
	font-size: 16px;

}
body {
  overflow-y: auto;
  min-width: 325px;
}
/* 固定幅 */
.container {
  max-width: 980px;
  min-width: 325px;
}
/* キー画像コンテナ */
.poster-container {
  position: relative;
  width: 100%;
  display: block;
}
#home .poster-container {
  line-height: 0;
}
h1, h2, h3, h4, h5, h6 {
  font-family: var(--header-font);
  font-weight: 600;
  font-style: normal;
}
.pageTitle {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4em; /* 画像とテキストの間隔 */
}
h1 {
  font-size: 1.8rem;
  padding-top: 0.8em;
  margin-bottom: 1.5em;
  padding-left: 10px;
  padding-bottom: 10px;
  color: rgba(30,52,120,1.00);
  border-bottom: rgba(196,181,228,0.75) solid 3px;
}
.pageTitle::before, .pageTitle::after {
  display: inline-block;
  padding-top: 0.2em;
}
.pageTitle::before {
  content: url('../images/h1-l.png');
}
.pageTitle::after {
  content: url('../images/h1-r.png');
}
h2 {
  font-size: 1.4rem;
}
h3 {
  font-size: 1.2rem;
  border-bottom: 2pt rgba(169, 190, 237, 1.00) dashed;
  margin-bottom: 15px;
  padding-bottom: 5px;
  padding-top: 5px;
  color: rgba(98, 108, 167, 1.00);
  padding-left: 10px;
}
h3::before {
  font-family: 'Font Awesome 6 Free';
  content: "\f0c8";
font-size: 1.1rem;	
  padding-right: 0.3em;
  color: rgba(148, 188, 205, 1.00)
}
h4 {font-size: 1.0rem;}
h4::before {}
h5 {
  font-size: 0.9em;
  color: rgba(255, 84, 130, 1.00);
}
h5::before {}
h6 {}
.linkText {
  color: rgba(32, 145, 192, 1);
}
.linkText:hover {
  color: rgba(229, 92, 0, 1);
}
/********************************/
/* ■レイアウト切替 （PC / モバイル）*/
/********************************/
#home #pcLayout, #header, #page #pcLayout, #header {
  display: block;
}
#home #mobileLayout, #home #headerMobile, #page #mobileLayout, #page #headerMobile {
  display: none;
}
@media (max-width: 991.98px) {
  #home #pcLayout, #page #pcLayout {
    display: none;
  }
  #home #pcLayout, #home #header, #page #pcLayout, #page #header {
    display: none;
  }
  #home #mobileLayout, #home #headerMobile, #page #mobileLayout, #page #headerMobile {
    display: block;
  }
}
/*****************************/
/* ■レイアウト（PC用）　　　　　　*/
/*****************************/
#home #pcLayout header {
  background-image: url(../images/home/pc/bg_keyvisual-header.png);
  min-height: 180px;
  background-repeat: no-repeat
}
#home #pcLayout #sideBar-img {
  background-image: url("../images/home/pc/bg_keyvisual-sidebar.png");
  min-height: 1080px;
  background-repeat: no-repeat
}
#home #pcLayout #mainContent-img {
  background-image: url("../images/home/pc/bg_keyvisual-main.png");
  min-height: 1080px;
  background-repeat: no-repeat
}
#home #pcLayout footer {
  background-image: url("../images/home/pc/bg_keyvisual-footer.png");
  min-height: 180px;
  background-repeat: no-repeat
}
#home #mobileLayout footer {
	min-height: 180px;
	background-repeat: no-repeat;
	background-image: -webkit-linear-gradient(270deg,rgba(0,50,170,0.00) 0%,rgba(0,50,170,0.10) 10%,rgba(0,50,170,0.40) 22%,rgba(0,50,170,0.60) 34%,rgba(0,50,170,0.75) 50%,rgba(0,50,170,0.90) 85%);
	background-image: -moz-linear-gradient(270deg,rgba(0,50,170,0.00) 0%,rgba(0,50,170,0.10) 10%,rgba(0,50,170,0.40) 22%,rgba(0,50,170,0.60) 34%,rgba(0,50,170,0.75) 50%,rgba(0,50,170,0.90) 85%);
	background-image: -o-linear-gradient(270deg,rgba(0,50,170,0.00) 0%,rgba(0,50,170,0.10) 10%,rgba(0,50,170,0.40) 22%,rgba(0,50,170,0.60) 34%,rgba(0,50,170,0.75) 50%,rgba(0,50,170,0.90) 85%);
	background-image: linear-gradient(180deg,rgba(0,50,170,0.00) 0%,rgba(0,50,170,0.10) 10%,rgba(0,50,170,0.40) 22%,rgba(0,50,170,0.60) 34%,rgba(0,50,170,0.75) 50%,rgba(0,50,170,0.90) 85%);
}
#page #pcLayout {
  background-color: rgba(255,255,255,0.40)
}
#page #pcLayout header, #page #mobileLayout header {
  background-image: url("../images/page/bg_keyvisual-header.png");
  min-height: 191px;
  background-repeat: no-repeat
}
#page #pcLayout #sideBar-img {
  background-image: url("../images/page/pc/bg_keyvisual-sidebar.png");
  min-height: 809px;
  background-repeat: no-repeat
}
#page #pcLayout #mainContent-img {
  background-image: url("../images/page/pc/bg_keyvisual-main.png");
  min-height: 809px;
  background-repeat: no-repeat
}

#page #pcLayout footer {
  background-image: url("../images/page/pc/bg_keyvisual-footer.png");
	min-height: 422px;
	background-repeat: no-repeat
}
#page #mobileLayout footer {
  background-image: url("../images/page/mobile/bg_keyvisual-footer.png");
  min-height: 422px;
  background-repeat: no-repeat;
  background-size: cover
}

/*****************************/
/* ■サイドバー（PC用）　　　　　　*/
/*****************************/
#pcLayout .overlay-nav a {
  display: block;
  width: 90%;
  height: 36px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1em;
}
#home #pcLayout #sideBar .overlay-nav, #page #pcLayout #sideBar .overlay-nav {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  padding-top: 10px;
  display: flex;
  flex-direction: column;
  justify-content: start;
  align-items: center;
}
#home #pcLayout #sideBar .overlay-nav {
  background-image: linear-gradient(to bottom, rgba(255, 0, 0, 0.15), rgba(255, 165, 0, 0.15), rgba(255, 255, 0, 0.15));
  background-size: 100% 100%;
  background-repeat: no-repeat;
}
#page #pcLayout #sideBar {
  background-color: rgba(19,37,71,1.00)
}

#pcLayout #sideBar nav .btn {
  padding-bottom: 2em
}
#pcLayout #sideBar .overlay-nav a, #sideBar .overlay-nav a:hover {
  font-weight: bold;
  font-size: 1rem;
  margin-bottom: 0.5rem;
  text-decoration: none;
}
#pcLayout #sideBar .overlay-nav a {
	color: rgba(238,184,255,1.00);
	border: 2px solid rgba(255,255,255,0.68);
	background-color: rgba(66,39,116,0.74);
}
#pcLayout #sideBar .overlay-nav a:hover {
	color: rgba(255,255,255,1.00);
	text-shadow: 1px 1px 3px rgba(34,35,35,1.00);
	border: 2px solid rgba(0,187,255,1.00);
	background-image: -webkit-linear-gradient(180deg,rgba(0,219,255,0.60) 0%,rgba(122,195,255,0.54) 50%,rgba(70,200,255,0.60) 100%);
	background-image: -moz-linear-gradient(180deg,rgba(0,219,255,0.60) 0%,rgba(122,195,255,0.54) 50%,rgba(70,200,255,0.60) 100%);
	background-image: -o-linear-gradient(180deg,rgba(0,219,255,0.60) 0%,rgba(122,195,255,0.54) 50%,rgba(70,200,255,0.60) 100%);
	background-image: linear-gradient(270deg,rgba(0,219,255,0.60) 0%,rgba(122,195,255,0.54) 50%,rgba(70,200,255,0.60) 100%);
}
#pcLayout #sideBar .overlay-nav a.active {
  color: rgba(255, 255, 255, 1.00);
  background-color: rgba(0,255,220,0.50);
}
#pcLayout #sideBar .overlay-nav a.active i {
  color: rgba(178, 216, 255, 1.00);
}

#poster{
	display: block;
	position: relative;
	top: 540px;
	margin-left: 0.5em;
	margin-right: 0.5em;
	margin-bottom: 0.5em;
	text-align: center
}
#poster img{
width: 90%;
height: 90%
}
#pv{
	display: block;
	position: relative;
	top: 540px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 0.3em
}
/*****************************/
/* ■レイアウト（モバイル用）　　　*/
/*****************************/
#mobileLayout {
  background-image: url("../images/home/mobile/bg_base.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
#mobileLayout header, #mobileLayout footer {
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}
#mobileLayout header {
  background-image: url("../images/home/mobile/bg_header.png");
  min-height: 191px;
}
#mobileLayout #theme {
  background-image: url("../images/home/mobile/theme.png");
  height: 150px;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  margin-top: 1em;
  margin-bottom: 2em
}
#mobileLayout #dvp {
  background-image: url("../images/home/mobile/dvp.png");
  height: 250px;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}
#mobileLayout .poster-container {
  min-height: 300px;
}

#page #pcLayout main, #page #mobileLayout main {
  background-color: rgba(255, 255, 255, 0.50);
  -webkit-box-shadow: inset 0px 0px rgba(162, 71, 72, 1.00);
  box-shadow: inset 0px 0px rgba(162, 71, 72, 1.00);
}
@media (max-width: 575.98px) {
  #mobileLayout {
    background-image: url("../images/home/mobile/bg_base.png");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
}
/*****************************/
/* ■ハンバーガー（モバイル用）　　*/
/*****************************/
#headerMobile {
  position: relative;
}
#headerMobile .overlay-menu {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 10;
}
#headerMobile .overlay-menu button {
	color: white;
	font-size: 1.8rem;
	background-color: rgba(200,0,255,0.30);
	border: none;
	padding-top: 0.15rem;
	padding-right: 0.5rem;
	padding-left: 0.5rem;
	padding-bottom: 0.25rem;
	border-radius: 6px;
}
/*****************************/
/* ■オフキャンバス（モバイル用）　*/
/*****************************/
.offcanvas-body {
	background-image: -webkit-linear-gradient(270deg,rgba(255,0,237,0.15) 0%,rgba(89,0,255,0.15) 50%,rgba(0,124,255,0.15) 100%);
	background-image: -moz-linear-gradient(270deg,rgba(255,0,237,0.15) 0%,rgba(89,0,255,0.15) 50%,rgba(0,124,255,0.15) 100%);
	background-image: -o-linear-gradient(270deg,rgba(255,0,237,0.15) 0%,rgba(89,0,255,0.15) 50%,rgba(0,124,255,0.15) 100%);
	background-image: linear-gradient(180deg,rgba(255,0,237,0.15) 0%,rgba(89,0,255,0.15) 50%,rgba(0,124,255,0.15) 100%);
	background-size: 100% 100%;
	background-repeat: no-repeat;
}
.offcanvas-header {
  background-color: rgba(73,50,90,0.88)
}
.offcanvas-title {
  color: rgba(255,210,253,1.00)
}
.offcanvas .overlay-nav a {
  display: block;
  width: 90%;
  height: 24px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1em;
}

.offcanvas nav .btn {
  padding-bottom: 2em;
}
.offcanvas .overlay-nav a, .offcanvas .overlay-nav a:hover {
  font-weight: bold;
  font-size: 1rem;
  margin-bottom: 0.3rem;
  text-decoration: none;
}
.offcanvas .overlay-nav a {
 color: rgba(238,184,255,1.00);
background-color: rgba(66,39,116,0.74);
  border: none;
}
.offcanvas .overlay-nav a:hover {
  color: rgba(255,255,255,1.00);
  border: 1px solid rgba(0,187,255,1.00);
	background-image: -webkit-linear-gradient(180deg,rgba(0,219,255,0.60) 0%,rgba(122,195,255,0.54) 50%,rgba(70,200,255,0.60) 100%);
	background-image: -moz-linear-gradient(180deg,rgba(0,219,255,0.60) 0%,rgba(122,195,255,0.54) 50%,rgba(70,200,255,0.60) 100%);
	background-image: -o-linear-gradient(180deg,rgba(0,219,255,0.60) 0%,rgba(122,195,255,0.54) 50%,rgba(70,200,255,0.60) 100%);
	background-image: linear-gradient(270deg,rgba(0,219,255,0.60) 0%,rgba(122,195,255,0.54) 50%,rgba(70,200,255,0.60) 100%);
}
.offcanvas .overlay-nav a.active {
  color: rgba(255, 255, 255, 1.00);
  background-color: rgba(0,255,220,0.50);
}
.offcanvas .overlay-nav a.active i {
  color: rgba(178, 216, 255, 1.00);
}
/*****************************/
/* ■フッター共通（PC・モバイル）　*/
/*****************************/
#footer #secretariat {
	padding-top: 32em
}
#footer #secretariat dl dt {
  font-size: 1.05em;
  border-bottom: 3px solid rgba(140,196,255,1.00);
  color: rgba(253,206,255,0.99);
  margin-bottom: 0.5em;
  padding-bottom: 0.2em;
  text-shadow: 1px 1px 2px rgba(49, 34, 24, 1.00);
}
#page #footer #secretariat dl{
	padding: 0.5em;
	border-radius: 10px;
	background-color: rgba(36,47,92,0.73);	
}
#footer #secretariat dl dd{
  font-size: 92%;
  color: antiquewhite;
}
#footer #secretariat dl dd a{
color: antiquewhite;
text-decoration: none;
}

#footer #secretariat h6 {
  color: rgba(44,14,65,1.00);
  height: 24px;
  padding-top: 2px
}
#footer #secretariat dl {
  margin-top: -1.1em
}
#copyright {
	margin-top: 0px;
	clear: left;
	text-align: center;
	color: rgba(147,113,188,1.00);
	padding-top: 2px;
	height: 32px;
	background-color: rgba(41,21,110,1.00);
	position: relative;
	top: 0px;
}
  #page #copyright {
	margin-top: 200px;
  }
@media (min-width: 992px) {
#home #footer #secretariat {
  padding-top: 0em
}	
  #home #copyright {
    margin-top: -35px;
  }
  #page #copyright {
	margin-top: 210px;
  }
}
/*****************************/
/* ■NEWS共通（PC・モバイル）　　*/
/*****************************/
main{
	min-height: 700px
}

#news {
	position: absolute;
	height: auto;
	margin-left: auto;
	margin-right: auto;
	-moz-border-radius: 10px;
	-webkit-border-radius: 10px;
	border-radius: 0px 10px 10px;
	padding-top: 15px;
	padding-bottom: 15px;
	-webkit-box-shadow: 3px 5px 6px 0px rgba(73, 50, 28, 0.30);
	box-shadow: 3px 5px 6px 0px rgba(73, 28, 49, 0.30);
	background-image: -webkit-linear-gradient(270deg,rgba(60,80,150,0.60) 0%,rgba(60,80,150,0.60) 50.00%,rgba(60,80,150,0.80) 100%);
	background-image: -moz-linear-gradient(270deg,rgba(60,80,150,0.60) 0%,rgba(60,80,150,0.60) 50.00%,rgba(60,80,150,0.80) 100%);
	background-image: -o-linear-gradient(270deg,rgba(60,80,150,0.60) 0%,rgba(60,80,150,0.60) 50.00%,rgba(60,80,150,0.80) 100%);
	background-image: linear-gradient(180deg,rgba(60,80,150,0.60) 0%,rgba(60,80,150,0.60) 50.00%,rgba(60,80,150,0.80) 100%);
	background-size: 100% 100%;
	background-repeat: no-repeat;
	padding-left: 8px;
	padding-right: 8px;
}
#news:before {
  font-size: 1.4em;
  font-family: "Font Awesome 6 Free";	
  content: "\f1ea　新着情報";
  position: absolute;
  font-weight: 900;
  top: -25px;
  left: 0px;
  border-bottom: 25px solid rgba(60,80,150,0.60);
  border-left: 0px solid transparent;
  border-right: 0px solid transparent;
  height: 0;
  width: 180px;
  border-top-left-radius: 20px;
  border-top-right-radius: 50px;
  text-align: center;
  line-height: 1.6em;
  text-shadow: 2px 2px 2px #030D23;
  color: rgba(212,217,255,1.00)
}

#news {
	top: 700px;
	width: 90%;
	left: 5%;
}
.news {
  padding: 0.5rem 1rem;
  border-radius: 4px;
  z-index: 10;
  height: 160px;
  overflow-y: auto;
}
.news dl {
  width: 100%;
  margin-left: 0px;
  margin-bottom: 0px;
  margin-top: 0px;
  height: 160px;
}
.news dt {
  font-family: var(--num-font);
  font-style: normal;
  font-size: 1em;
  color: rgba(255,213,154,1.00);
  min-width: 5.5rem;
  padding-top: 5px
}
.news dd {
  color: rgba(255,255,255,1.00);
  padding-left: 5.5em;
	padding-bottom: 0.2em;
  text-align: left;
  font-size: 1em;
  margin-top: -12px;
  border-bottom: 1px dashed rgba(173,215,255,1.00);
  line-height: 1.6em
}
/*****************************/
/* ■レスポンシブ調整　　　　　　　*/
/*****************************/
@media (max-width: 499.98px) {
  .news dt {
    float: none;
    font-size: 0.9em;
  }
  .news dd {
    margin-top: 5px;
    padding-left: 0em;
    font-size: 0.9em;
  }
}
@media (max-width: 991.98px) {
  #news {
    top: 60px;
  }

  #home #footer #secretariat {
    padding-top: 6em
  }
  #page #footer #secretariat {
    padding-top: 29em
  }	
  #copyright {
    margin-top: 30px;
  }
}
@media (min-width: 700px) and (max-width: 767.98px) {
  #footer #secretariat {
    padding-top: 5em
  }
  #copyright {
    margin-top: 30px;
  }
}
@media (max-width: 699.98px) {
  #footer #secretariat {
    padding-top: 4.5em
  }
}
@media (min-width: 576px) and (max-width: 699.98px) {
  #mobileLayout #theme {
    height: 120px;
    margin-top: -1em;
  }
  #mobileLayout #dvp {
    height: 200px;
  }

}
@media (min-width: 500px) and (max-width: 575.98px) {
  #mobileLayout #theme {
    height: 90px;
    margin-top: -1em;
  }
  #mobileLayout #dvp {
    height: 180px;
  }

}
@media (min-width: 400px) and (max-width: 499.98px) {
  #mobileLayout #theme {
    height: 75px;
    margin-top: -2em;
  }
  #mobileLayout #dvp {
    height: 150px;
  }

}
@media (max-width: 399.98px) {
  #mobileLayout #theme {
    height: 60px;
    margin-top: -2.5em;
    margin-bottom: 1em
  }
  #mobileLayout #dvp {
    height: 120px;
  }

  #footer #secretariat dl {
    font-size: 80%
  }
}
/*****************************/
/* ■トップバック　　　　　　　　　*/
/*****************************/
#topBack {
  display: none;
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 1000;
  padding: 10px 20px;
  background-color: #007bff;
  color: white;
  border: none;
  border-radius: 5px;
  cursor: pointer;
  font-size: 16px;
}
#topBack:hover {
  background-color: #0056b3;
}
/*****************************/
/* ■準備中　　　　　　　　　　　　*/
/*****************************/
#nowconst {
  padding: 1em;
  border: 3px solid rgba(188,150,231,1.00);
  border-radius: 16px;
  color: rgba(81,59,116,1.00);
  font-size: 2rem;
  text-align: center;
  margin-bottom: 1em;
  margin-top: 1em;
}