@charset "UTF-8";

/*共通フォント設定*/
body, div, article, section, aside, div, 
main, p, ul, ol, li, dl, dt, dd, a, 
input, textarea, select, option {
    font-size:1.6rem;
}
h1, h2, h3, h4, h5, h6 {
    font-size:1.8rem;
    font-weight:normal;
}
span {
    font-size:1.5rem;
}
h2 {
    text-align:center;
    font-size:3.6rem;
    font-weight:600;
    margin:0 0 80px;
    position:relative;
}
h2::after {
    position:absolute;
    content:"";
    background:#fff8ba;
    width:100%;
    max-width:506px;
    height:32px;
    bottom:-18px;
    left:50%;
    transform:translateX(-50%);
    z-index:-999;
}
h2.ColorB {
    text-align:center;
    font-size:3.6rem;
    font-weight:600;
    margin:0 0 80px;
    position:relative;
}
h2.ColorB::after {
    position:absolute;
    content:"";
    background:#cde8f9;
    width:100%;
    max-width:506px;
    height:32px;
    bottom:-18px;
    left:50%;
    transform:translateX(-50%);
    z-index:-999;
}
h2.ColorP {
    text-align:center;
    font-size:3.6rem;
    font-weight:600;
    margin:0 0 80px;
    position:relative;
}
h2.ColorP::after {
    position:absolute;
    content:"";
    background:#ffcacb;
    width:100%;
    max-width:506px;
    height:32px;
    bottom:-18px;
    left:50%;
    transform:translateX(-50%);
    z-index:-999;
}
h2.ColorG {
    text-align:center;
    font-size:3.6rem;
    font-weight:600;
    margin:0 0 80px;
    position:relative;
}
h2.ColorG::after {
    position:absolute;
    content:"";
    background:#b1ce77;
    width:100%;
    max-width:506px;
    height:32px;
    bottom:-18px;
    left:50%;
    transform:translateX(-50%);
    z-index:-1;
}
/*共通ボタンサイズ*/
p.BtnSize1 {
    width:100%;
    max-width:320px;
}
/*全体レイアウト*/
#Container {
    width:100%;
    padding:27px 0 0;
    margin:0 auto;
}
@media screen and (min-width:1280px) {
.PcContainer {
    max-width:1280px;
}
}

/*ヘッダー設定*/
header {
    width:100%;
    max-width:961px;
    height:80px;
    border:1px solid #959595;
    border-radius:50px;
    display:flex;
    align-items:center;
    margin:0 auto 80px;
    position:relative;
    background:#fff;
}
/*ロゴ部分*/
.LogoArea {
    width:381px;
    height:50px;
    margin:0 0 0 14px;
}
.LogoArea ul {
    width:381PX;
    display:flex;
    justify-content:space-between;
    align-items:center;
    position:absolute;
}
.LogoArea ul::before {
    content:"";
    position:absolute;
    left:41.33%;
    top:12%;
    background:#959595;
    width:1px;
    height:80%;
}
.LogoArea ul li:first-child, 
.LogoArea ul li:first-child h1, 
.LogoArea ul li:first-child a {
    width:148px;
    height:50px;
}
.LogoArea ul li:last-child {
    width:214px;
    height:32px;
}
.LogoArea ul li:last-child {
    display:flex;
    justify-content:space-between;
    align-items:center;
}
.LogoArea ul li:first-child h1 a, 
.LogoArea ul li:last-child h1 a {
    display:block;
}
.LogoArea ul li:last-child h1:first-child, 
.LogoArea ul li:last-child h1:first-child a, 
.LogoArea ul li:last-child h1:first-child a img {
    width:96px;
    height:32px;
}
.LogoArea ul li:last-child h1:last-child, 
.LogoArea ul li:last-child h1:last-child a, 
.LogoArea ul li:last-child h1:last-child a img {
    width:94px;
    height:25px;
}
.LogoArea ul li:last-child p, 
.LogoArea ul li:last-child p img {
    width:12px;
    height:12px;
    vertical-align:top;
}

/*ナビゲーション設定*/
nav {
    width:445px;
    display:flex;
    margin:0 0 0 25px;
}
nav ul {
    display:flex;
    flex-wrap:wrap;
    justify-content:right;
    align-items:center;
    position:relative;
}
nav ul::before {
    content:"";
    position:absolute;
    top:50%;
    background: #959595;
    width:447px;
    height:1px;

}
nav ul li {
    font-size:1.5rem;
    font-weight:600;
    margin:0 30px 24px 0;
}
nav ul li:nth-child(3), 
nav ul li:nth-child(7) {
    margin-right:0;
}
nav ul li:nth-child(n+4) {
    margin-bottom:0;
}
nav ul li:nth-child(6) {
    margin-right:0;
}
nav ul li.CustomerImg {
    display:none;
}
nav hr.SpNav, nav ul.SpNav {
    display:none;
}
nav ul li a {
    display:block;
    font-size:1.5rem;
    letter-spacing:0.025em;
    font-weight:600;
    color: #222;
}

/*参加申し込みボタン設定*/
.RegistBtn {
    width:80px;
    height:80px;
    position:absolute;
    right:-1px;

}
.RegistBtn a {
    display:block;
    width:100%;
    height:100%;
}
.RegistBtn a img {
    width:100%;
    height:100%;
}

/*footer部分設定*/
footer {
    width:stretch;
    max-width:1280px;
    background:url("../images/img_PcFooterBg@2x.png") center center no-repeat;
    background-size: cover;
    aspect-ratio: 16 / 9.3;
}
footer p.deco {
    display:none;
}
footer p.Copyright {
    text-align: center;
    padding:0 0 25px;
}
footer p.footerImg {
    padding:65px 0 0;
    margin:0 auto 140px;
}
ul.TxtNav {
    display:flex;
    justify-content:center;
    flex-wrap: nowrap;
    margin:0 0 70px;
}
ul.TxtNav li:nth-child(odd) {
    margin:0 calc(25vw / 12.8) 0;
}
ul.TxtNav li a {
    font-size:1.5rem;
    color:#000;
    font-weight: 600;
}
.Information {
    width:100%;
    max-width:740px;
    height:260px;
    background:#fff;
    border:1px solid #959595;
    border-radius:25px;
    display:flex;
    justify-content:center;
    align-items:center;
    flex-wrap:wrap;
    margin:0 auto 70px;
    padding:15px;
}

hr.line {
    width:100%;
    max-width:700px;
    border:1px solid #959595;
}
.Infotxt {
    width:630px;
    display:flex;
    justify-content: space-between;
    align-items: center;
}
.Infotxt  p {
    width:100%;
    max-width:300px;
    height:50px;
    background:#a9cf6a;
    border:1px solid #959595;
    border-radius:25px;
    display:inline-block;
    line-height:50px;
    text-align:center;
}
.Infotxt ul {
    width:100%;
    max-width:302px;
}
.Infotxt ul li:first-child {
    font-size:3.6rem;
    letter-spacing:0.12em;
    margin:0 0 10px;
}
.Infotxt ul li:last-child {
    font-size:1.6rem;
    text-align: justify;
    text-align-last:justify;
}
.InfoImg {
    text-align:center;
}
.InfoImg ul {
    width:100%;
    max-width:375px;
    height:60px;
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin:0 auto 28px;
}
.InfoImg ul li:first-child {
    width:157px;
    height:60px;
}
.InfoImg ul li:last-child {
    width:157px;
    height:40px;
}
p.footerImg {
    width:391px;
    height:88px;
}

/* for Sp*/
@media screen and (min-width:0) and (max-width:960px) {
    .SpContainer {
        width:100%;
    }
    header {
        width:100%;
        max-width:960px;
        height:65px;
        /*margin-left:calc(25vw / 9.6);*/
        margin-bottom:calc(40vw / 9.6);
        position:relative;
        border:none;
    }
    .LogoArea {
        width:160px;
        height:40px;
    }
    .LogoArea ul {
        width:stretch;
        max-width:960px;
    }
    .LogoArea ul::before {
        display:none;
    }
    .LogoArea ul li:first-child {
        width:117px;
        height:40px;
    }
    .LogoArea ul li:first-child h1 {
        width:100%;
        height:100%;
    }
    .LogoArea ul li:first-child h1 a {
        width:100%;
        height:100%;
    }
    .LogoArea ul li:last-child {
        display:none;
    }
    nav {
        display:none;
    }
    h2 {
    font-size:2.8rem;
    margin:0 0 50px;
}
    h2::after {
    max-width:calc(320vw /3.75);
    height:15px;
    bottom:-14px;
}
    h2.ColorB {
    font-size:2.8rem;
    margin:0 0 50px;
}
    h2.ColorB::after {
    max-width:calc(320vw /3.75);
    height:15px;
    bottom:-14px;
}


    /* ハンバーガーアイコン */
    .hamburger-menu {
        position: absolute;
        top:0;
        left:calc(285vw / 3.75);
        width:65px;
        height:65px;
        border: 1px solid #959595;
        border-radius: 50%;
        background:#fff8ba;
        z-index:1001;
    }
    .hamburger-menu.active {
          background:#cdf8f9;
    }
.hamburger-icon {
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 5px;
  width: 30px;
  height: 25px;
  justify-content: center;
  align-items: center;
  position: relative;
  top:30%;
  left:25%;
  z-index: 1001;
}

/* ハンバーガーの線 */
.hamburger-icon span {
  width: 30px;
  height: 1px;
  background: #959595;
  transition: transform 0.3s, opacity 0.3s;
  position: absolute;
}

/* 1本目（上の線） */
.hamburger-icon span:nth-child(1) {
  top: 0;
}

/* 2本目（中央の線） */
.hamburger-icon span:nth-child(2) {
  top: 50%;
  transform: translateY(-50%);
}

/* 3本目（下の線） */
.hamburger-icon span:nth-child(3) {
  bottom: 0;
}

/* フルスクリーンメニュー */
.menu {
  position: fixed;
  top: 110px;
  left: 0;
  width: 100vw;
  height: 100%;
  background: rgba(255, 248, 186, 1);
  display: flex;
  flex-direction: column;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease-in-out;
 }

/* メニューが開いたとき */
.menu.active {
  opacity: 1;
  visibility: visible;
  margin:0;
  overflow-y: scroll;
  height:calc(100% - 100px);
}

/* メニューのリンク */
.menu ul {
  list-style: none;
  padding: 0;
  margin: 0;
  flex-direction: column;
  display:block;
  padding:56px 0 0 25px;
}
.menu ul::before {
    content:none;
}
.menu li {
  margin: 20px 0;
}
.menu li.CustomerImg {
    display:block;
    width:calc(320vw / 3.75);
    height:calc(455vw / 3.75);
    margin:65px 0 0;
}
.menu hr.SpNav, .menu ul.SpNav {
    display:block;
}
.menu hr.SpNav {
    width:calc(320vw / 3.75);
    border:1px solid #959595;
    margin:40px auto 40px;
    font-size:1.5rem;
}
.menu ul.SpNav {
    display:flex;
    flex-direction: row;
    flex-wrap: wrap;
    padding:0;
    margin:0 0 0 calc(25vw / 3.75);
    justify-content: flex-start;
}
.menu ul.SpNav li {
    margin:0 0 15px;
}
.menu ul.SpNav li:nth-child(even) {
    margin:0 calc(20vw / 3.75) 15px;
}
.menu a {
  color: #000;
  font-size: 1.6rem;
  text-decoration: none;
  transition: color 0.3s;
}

.menu a:hover {
  color: #ddd;
}
.hamburger-menu.active .hamburger-icon span {
  background: #959595;
}
/* ハンバーガーアイコンが「×」に変形 */
.hamburger-menu.active .hamburger-icon span:nth-child(1) {
  transform: translateY(12px) rotate(45deg);
}

.hamburger-menu.active .hamburger-icon span:nth-child(2) {
  opacity: 0;
}

.hamburger-menu.active .hamburger-icon span:nth-child(3) {
  transform: translateY(-10px) rotate(-45deg);
}


    .RegistBtn {
        width:65px;
        height:65px;
        position:absolute;
        left:208px;
    }
    .RegistBtn a {
        display:block;
        width:100%;
        height:100%;
    }
    footer {
        width:100%;
        max-width:calc(480vw / 4.8);
        /*max-height:1134px;*/
        height:calc(1134vw / 3.75);
        background:url("../images/img_SpFooterBg@2x.png") center no-repeat;
        background-size:cover; 
    }
    footer p.deco {
        display:none;
    }
    footer p.footerImg {
        width:calc(310vw / 3.75);
        height:calc(78vw / 3.75);
    }
    ul.MainNav {
        display:block;
    }
    ul.MainNav li:nth-child(even) {
        display:none !important;
    }
    ul.TxtNav {
        flex-direction: row;
        flex-wrap: wrap;
        justify-content:left;
        margin-left:20px;
    }
    ul.TxtNav li:nth-child(odd) {
        margin-bottom:25px;
    }
    ul.TxtNav li:nth-child(even) {
        display:block;
        margin:0 15px 0;
    }
    ul.TxtNav li:last-child {
        margin-bottom:0;
    }
    .Information {
        width:320px;
        height:454px;
        /*flex-direction:column;*/
        display:block;
        margin:0 auto 50px;
    }
    .Infotxt {
        width:100%;
        max-width:calc(320vw / 3.75);
        display:block;
        padding:30px 0 0;
        margin:0 0 30px;
    }
    .Infotxt p {
        margin:0 0 15px;
    }
    .InfoImg {
        margin:30px 0 0;
    }
    .Infotxt ul li:first-child {
        letter-spacing: 0.09em;
        margin:0 0 15px;
    }
    .InfoImg ul {
        display:block;
        width:157px;
        height:auto;
    }
    .InfoImg ul li {
        margin:0 0 30px;
    }
    p.Copyright {
        position:relative;
        bottom:50px;
        left:-80px;
    }
}
@media screen and (min-width:481px) and (max-width:960px) {
    footer {
        width:100%;
        max-width:960px;
        height:auto;
        background-image:none !important;
        background-color:#fff8ba !important;
        border-top:1px solid #000;
        position:relative;
    }
    footer p.deco {
        display:block;
        width:100%;
        max-width:960px;
        position:relative;
        bottom:0
    }
    footer p.Copyright {
        text-align: center;
    }
}