/* 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(131, 88, 163, 1.00);
  border-bottom: rgba(228, 181, 210, 0.67) 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.6rem;
}
h3 {
  font-size: 1.4rem;
  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";
  padding-right: 0.3em;
  color: rgba(148, 188, 205, 1.00)
}
h4 {}
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: 191px;
  background-repeat: no-repeat
}
#home #pcLayout #sideBar-img {
  background-image: url("../images/home/pc/bg_keyvisual-sidebar.png");
  min-height: 863px;
  background-repeat: no-repeat
}
#home #pcLayout #mainContent-img {
  background-image: url("../images/home/pc/bg_keyvisual-main.png");
  min-height: 863px;
  background-repeat: no-repeat
}
#home #pcLayout footer {
  background-image: url("../images/home/pc/bg_keyvisual-footer.png");
  min-height: 171px;
  background-repeat: no-repeat
}
#home #mobileLayout footer {
  min-height: 171px;
  background-repeat: no-repeat;
  background-image: -webkit-linear-gradient(180deg, rgba(80,20,0, 0.30) 0%, rgba(80,20,0, 0.45) 15.0%, rgba(80,20,0, 0.60) 30.0%, rgba(80,20,0, 0.90) 75.0%, rgba(80,20,0,1.00) 100.0%);
  background-image: -moz-linear-gradient(180deg, rgba(80,20,0, 0.30) 0%, rgba(80,20,0, 0.45) 15.0%, rgba(80,20,0, 0.60) 30.0%, rgba(80,20,0, 0.90) 75.0%, rgba(80,20,0,1.00) 100.0%);
  background-image: -o-linear-gradient(180deg, rgba(80,20,0, 0.30) 0%, rgba(80,20,0, 0.45) 15.0%, rgba(80,20,0, 0.60) 30.0%, rgba(80,20,0, 0.90) 75.0%, rgba(80,20,0,1.00) 100.0%);
  background-image: linear-gradient(180deg, rgba(80,20,0, 0.30) 0%, rgba(80,20,0, 0.45) 15.0%, rgba(80,20,0, 0.60) 30.0%, rgba(80,20,0, 0.90) 75.0%, rgba(80,20,0,1.00) 100.0%);
}
#page #pcLayout {
  background-color: rgba(255, 240, 238, 1.00)
}
#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"), -webkit-linear-gradient(180deg, rgba(80,20,0, 0.30) 0%, rgba(80,20,0, 0.45) 15.0%, rgba(80,20,0, 0.60) 30.0%, rgba(80,20,0, 0.90) 75.0%, rgba(80,20,0,1.00) 100.0%);
  background-image: url("../images/page/pc/bg_keyvisual-footer.png"), -moz-linear-gradient(180deg, rgba(80,20,0, 0.30) 0%, rgba(80,20,0, 0.45) 15.0%, rgba(80,20,0, 0.60) 30.0%, rgba(80,20,0, 0.90) 75.0%, rgba(80,20,0,1.00) 100.0%);
  background-image: url("../images/page/pc/bg_keyvisual-footer.png"), -o-linear-gradient(180deg, rgba(80,20,0, 0.30) 0%, rgba(80,20,0, 0.45) 15.0%, rgba(80,20,0, 0.60) 30.0%, rgba(80,20,0, 0.90) 75.0%, rgba(80,20,0,1.00) 100.0%);
  background-image: url("../images/page/pc/bg_keyvisual-footer.png"), linear-gradient(180deg, rgba(80,20,0, 0.30) 0%, rgba(80,20,0, 0.45) 15.0%, rgba(80,20,0, 0.60) 30.0%, rgba(80,20,0, 0.90) 75.0%, rgba(80,20,0,1.00) 100.0%);
  min-height: 225px;
  background-repeat: no-repeat
}
#page #mobileLayout footer {
  background-image: url("../images/page/mobile/bg_keyvisual-footer.png"), -webkit-linear-gradient(180deg, rgba(80,20,0, 0.30) 0%, rgba(80,20,0, 0.45) 15.0%, rgba(80,20,0, 0.60) 30.0%, rgba(80,20,0, 0.90) 75.0%, rgba(80,20,0,1.00) 100.0%);
  background-image: url("../images/page/mobile/bg_keyvisual-footer.png"), -moz-linear-gradient(180deg, rgba(80,20,0, 0.30) 0%, rgba(80,20,0, 0.45) 15.0%, rgba(80,20,0, 0.60) 30.0%, rgba(80,20,0, 0.90) 75.0%, rgba(80,20,0,1.00) 100.0%);
  background-image: url("../images/page/mobile/bg_keyvisual-footer.png"), -o-linear-gradient(180deg, rgba(80,20,0, 0.30) 0%, rgba(80,20,0, 0.45) 15.0%, rgba(80,20,0, 0.60) 30.0%, rgba(80,20,0, 0.90) 75.0%, rgba(80,20,0,1.00) 100.0%);
  background-image: url("../images/page/mobile/bg_keyvisual-footer.png"), linear-gradient(180deg, rgba(70, 20, 0, 0.00) 0%, rgba(70, 20, 0, 0.40) 15.0%, rgba(70, 20, 0, 0.75) 75.0%, rgba(70, 20, 0, 0.95) 100.0%);
  min-height: 225px;
  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(255, 245, 215, 1.00)
}
#page #pcLayout #sideBar .overlay-nav {
  background-image: linear-gradient(to bottom, rgba(255, 219, 212, 0.00), rgba(255, 172, 210, 0.50), rgba(255, 245, 215, 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(42, 21, 62, 1.00);
  border: 1px solid rgba(255, 255, 255, 1.00);
  background-image: linear-gradient(to right, rgba(255, 0, 0, 0.2), rgba(75, 0, 130, 0.2), rgba(238, 130, 238, 0.2));
}
#pcLayout #sideBar .overlay-nav a:hover {
  color: rgba(255, 246, 246, 1.00);
  border: 1px solid rgba(138, 90, 213, 1.00);
  background-image: linear-gradient(to left, rgba(255, 0, 0, 0.6), rgba(75, 0, 130, 0.6), rgba(238, 130, 238, 0.6));
}
#pcLayout #sideBar .overlay-nav a.active {
  color: rgba(255, 255, 255, 1.00);
  background-color: rgba(0, 108, 255, 0.49);
}
#pcLayout #sideBar .overlay-nav a.active i {
  color: rgba(178, 216, 255, 1.00);
}

#poster{
	display: block;
	position: relative;
	top: 600px;
	margin-left: 1em;
	margin-bottom: 1em
}
#poster img{
width: 90%;
height: 90%
}

/*****************************/
/* ■レイアウト（モバイル用）　　　*/
/*****************************/
#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: 53px;
  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;
}
#mobileLayout #illust {
  background-image: url("../images/home/mobile/illust.png");
  min-height: 300px;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}
#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.5rem;
  background: rgba(0, 21, 255, 0.30);
  border: none;
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
}
/*****************************/
/* ■オフキャンバス（モバイル用）　*/
/*****************************/
.offcanvas-body {
  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;
}
.offcanvas-header {
  background-color: rgba(47, 26, 52, 0.73)
}
.offcanvas-title {
  color: rgba(191, 238, 255, 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(42, 21, 62, 1.00);
  background-color: transparent;
  border: none;
}
.offcanvas .overlay-nav a:hover {
  color: rgba(255, 246, 246, 1.00);
  border: 1px solid rgba(138, 90, 213, 1.00);
  background-image: linear-gradient(to left, rgba(255, 0, 0, 0.6), rgba(75, 0, 130, 0.6), rgba(238, 130, 238, 0.6));
}
.offcanvas .overlay-nav a.active {
  color: rgba(255, 255, 255, 1.00);
  background-color: rgba(0, 108, 255, 0.49);
}
.offcanvas .overlay-nav a.active i {
  color: rgba(178, 216, 255, 1.00);
}
/*****************************/
/* ■フッター共通（PC・モバイル）　*/
/*****************************/
#footer #secretariat {
  padding-top: 3em
}
#footer #secretariat dl dt {
  font-size: 1.05em;
  border-bottom: 2px solid rgba(218, 159, 159, 1.00);
  color: rgba(255, 226, 188, 1.00);
  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;
	background-color: rgba(17,0,30,0.60);
	border-radius: 10px;
}
#footer #secretariat dl dd{
  font-size: 92%;
  color: antiquewhite;
}
#footer #secretariat dl dd a{
color: antiquewhite;
text-decoration: none;
}

#footer #secretariat h6 {
  color: rgba(65, 43, 14, 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(115, 88, 124, 1.00);
  padding-top: 2px;
  height: 32px;
  background-color: rgba(37, 20, 32, 1.00);
}
@media (min-width: 992px) {
#home #footer #secretariat {
  padding-top: 0em
}	
  #home #copyright {
    margin-top: -35px;
  }
  #page #copyright {
    margin-top: -0px;
  }
}
/*****************************/
/* ■NEWS共通（PC・モバイル）　　*/
/*****************************/
main{
	min-height: 600px
}

#news {
	position: absolute;
	height: auto;
	margin-left: auto;
	margin-right: auto;
	-moz-border-radius: 6px;
	-webkit-border-radius: 6px;
	border-radius: 6px;
	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(125,95,150,0.20) 0%,rgba(125,95,150,0.30) 51.81%,rgba(125,95,150,0.50) 100%);
	background-image: -moz-linear-gradient(270deg,rgba(125,95,150,0.20) 0%,rgba(125,95,150,0.30) 51.81%,rgba(125,95,150,0.50) 100%);
	background-image: -o-linear-gradient(270deg,rgba(125,95,150,0.20) 0%,rgba(125,95,150,0.30) 51.81%,rgba(125,95,150,0.50) 100%);
	background-image: linear-gradient(180deg,rgba(125,95,150,0.20) 0%,rgba(125,95,150,0.30) 51.81%,rgba(125,95,150,0.50) 100%);
	background-size: 100% 100%;
	background-repeat: no-repeat;
	padding-left: 8px;
	padding-right: 8px;
}
#news:before {
  font-size: 1.2em;
  content: "お知らせ";
  position: absolute;
  font-family: var(--header-font);
  font-weight: 700;
  top: -25px;
  left: 30px;
  border-bottom: 25px solid rgba(125,95,150,0.20);
  border-left: 0px solid transparent;
  border-right: 0px solid transparent;
  height: 0;
  width: 130px;
  border-top-left-radius: 25px;
  border-top-right-radius: 25px;
  text-align: center;
  line-height: 1.6em;
  text-shadow: 2px 2px 2px #FFFFFF;
  color: rgba(0,116,255,1.00)
}
#news {
  top: 420px;
  width: 90%;
  left: 5%;
}
.news {
  padding: 0.5rem 1rem;
  border-radius: 4px;
  z-index: 10;
  height: 150px;
  overflow-y: auto;
}
.news dl {
  width: 100%;
  margin-left: 0px;
  margin-bottom: 0px;
  margin-top: 0px;
  height: 150px;
}
.news dt {
  font-family: var(--num-font);
  font-style: normal;
  font-size: 1em;
  color: rgba(126,49,143,1.00);
  min-width: 5.5rem;
  padding-top: 5px
}
.news dd {
  color: rgba(13, 24, 25, 1.00);
  padding-left: 5.5em;
  text-align: left;
  font-size: 1em;
  margin-top: -13px;
  border-bottom: 1px dashed rgba(168,146,175,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;
  }
  #mobileLayout #illust {
    margin-top: -120px;
    margin-bottom: -24px
  }
  #footer #secretariat {
    padding-top: 6em
  }
  #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: 41px;
    margin-top: -1em;
  }
  #mobileLayout #dvp {
    height: 200px;
  }
  #mobileLayout #illust {
    margin-top: -160px;
    margin-bottom: -40px
  }
}
@media (min-width: 500px) and (max-width: 575.98px) {
  #mobileLayout #theme {
    height: 36px;
    margin-top: -1em;
  }
  #mobileLayout #dvp {
    height: 180px;
  }
  #mobileLayout #illust {
    margin-top: -180px;
    margin-bottom: -60px
  }
}
@media (min-width: 400px) and (max-width: 499.98px) {
  #mobileLayout #theme {
    height: 30px;
    margin-top: -2em;
  }
  #mobileLayout #dvp {
    height: 150px;
  }
  #mobileLayout #illust {
    margin-top: -200px;
    margin-bottom: -80px
  }
}
@media (max-width: 399.98px) {
  #mobileLayout #theme {
    height: 25px;
    margin-top: -2.5em;
    margin-bottom: 1em
  }
  #mobileLayout #dvp {
    height: 120px;
  }
  #mobileLayout #illust {
    margin-top: -210px;
    margin-bottom: -90px
  }
  #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;
}