@charset "utf-8";

/*
Theme Name:rashinbanban
*/

/* ====================
全ページ共通箇所
==================== */

html,body{
  width: 100vw;
  min-width: 315px;
  height:100%;
  margin:0;
  padding:0;
  font-size: 16px;
  line-height: 1.5rem;
  font-family: 'Avenir','Helvetica Neue','Helvetica','Arial', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro','メイリオ', 'Meiryo', '游ゴシック', 'Yu Gothic', 'ＭＳ Ｐゴシック', sans-serif;
}

html {
  overflow: auto;
  scroll-behavior: smooth;
}

body {
  overflow-x: hidden;
  background: #fff;
  color: #1E3B72;
}

::-moz-selection {
    background: #145FB7;
    color: #fff;
}

::selection {
    background: #145FB7;
    color: #fff;
}

/* スクロールバー */
::-webkit-scrollbar {
  width: 10px;
  height: 10px;
  z-index: 6000;
}
::-webkit-scrollbar-track {
  background: #fff;
  border-radius: 5px;
  z-index: 6000;
}
::-webkit-scrollbar-thumb {
  background: #8ED3D8;
  border-radius: 5px;
  z-index: 6000;
}

.wrap {
    width: 90%;
    max-width: 1180px;
    margin: 0 auto;
}

ul {
    list-style-type: none;
}

img {
    max-width: 100%;
    height: auto;
    vertical-align: bottom;
}

.clearfix {
    content: "";
    display: block;
    clear: both;
}

button:focus {
	outline:0;
}

a, button {
  transition: 0.3s;
}

a:hover, button:hover {
  opacity: 0.8;
}

:focus {
  outline: none;
}

input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
     -webkit-appearance: none;
     margin: 0;
}

input[type="number"] {
     -moz-appearance: textfield;
}

input::-ms-clear {
  visibility:hidden
}

.noto-sans-jp {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

video {
  filter: drop-shadow(0px 0px rgba(0,0,0,0));
  outline: none;
  border: none;
  border: none;
}

.dp_sp {
  display: block;
}
.dp_pc {
  display: none;
}
@media screen and (min-width: 768px){
  .dp_sp {
    display: none;
  }
  .dp_pc {
    display: block;
  }
}

.dp_pc_ft {
  display: none;
}
@media screen and (min-width: 970px){
  .dp_pc_ft {
    display: block;
  }
}

/* グリッドレイアウト(7コンテンツ) */	
.block-grid-1-2-3 button{	
  width: 100%;
}
.block-grid-1-2-3 button:nth-child(2n+1) {	
  clear: both;
}	
@media screen and (min-width: 530px){	
  .block-grid-1-2-3 button {	
    width: 48%;	
    margin-right: 4%;	
    float: left;	
  }	
  .block-grid-1-2-3 button:nth-child(2n) {	
      margin-right: 0;	
  }	
  .block-grid-1-2-3 button:nth-child(2n+1) {	
    clear: both;	
  }	
}	
@media screen and (min-width: 830px){	
  .block-grid-1-2-3 button {	
    width: 13.4%;	
    margin-right: 1%;	
  }	
  .block-grid-1-2-3 button:nth-child(2n) {	
      margin-right: 1%;	
  }	
  .block-grid-1-2-3 button:nth-child(2n+1) {	
      clear: none;	
  }	
  .block-grid-1-2-3 button:nth-child(7n+1) {	
    clear: both;	
  }	
  .block-grid-1-2-3 button:nth-child(7n) {	
      margin-right: 0;	
  }	
}

/* ====================
Header
==================== */

.title {
    padding-top: 30px;
    width: 90%;
    max-width: 600px;
}

.breadcrumbs {
  display: none;
}
@media (min-width:768px){
  .breadcrumbs {
    display: block;
    color: #1E3B72;
    margin-top: 20px;
    font-size: 0.75rem;
  }
}
@media (min-width:1280px){
  .breadcrumbs {
    margin-top: 0;
  }
}

.breadcrumbs.adult {
  display: none;
}
@media (min-width:768px){
  .breadcrumbs.adult {
    display: block;
    padding-top: 50px;
    font-size: 0.75rem;
  }
}

.breadcrumbs a {
  color: #1E3B72;
}

/* メニュー */
@media (max-width:1280px){
    .nav {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100vh;
        padding-bottom: 80px;
        background: #145FB7;
        color: #ffffff;
        align-items: center;
        /* 初期：非表示 */
        visibility: hidden;
        opacity: 0;
        /* ふわっと表示 */
        transition: 0.5s ease-in-out;
        overflow-y: scroll;
        -webkit-overflow-scrolling: touch;
    }
}
@media(min-width: 1280px){
  /* メニューを右に寄せる */
  .nav{
    /* 右寄せ */
    margin-left: auto;
    margin-top: 30px;
  }
}

.nav_list_wrap {
    margin-top: 250px;
}
@media(min-width: 1280px){
    .nav_list_wrap {
        margin-top: 0;
    }
}

.nav_list_item {
    margin-bottom: 20px;
}
@media(min-width: 1280px){
  .nav_list_item {
      margin-left: 30px;
  }
}

@media(min-width: 1280px){
  .nav_list_item_download {
    margin-left: 30px;
  }
}

@media(min-width: 1280px){
  .nav_list_item_sns {
      margin-top: auto;
      margin-bottom: 0;
  }
}

.nav ul {
list-style:none;
}

@media(min-width: 1280px){
  .nav ul.nav_list {
    display: flex;
    list-style:none
  }
}

.nav a {
    display: block;
    position: relative;
}
@media(min-width: 1280px){
  .nav ul li a { 
    display: block;
  }
}

.nav_list_link {
  position: relative;
}

.nav_list_link_12 {
  position: relative;
}

.nav .nav_list_link::before {
    content: '';
    display: block;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: url(../images/menu/hari2.png) no-repeat;
    background-size: contain;
    position: absolute;
    top: 0;
    right: 10px;
    vertical-align: middle;
    z-index: 1;
}
.nav .nav_list_link_12::before {
    content: '';
    display: block;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: url(../images/menu/hari2.png) no-repeat;
    background-size: contain;
    position: absolute;
    top: 0;
    right: 10px;
    vertical-align: middle;
    z-index: 1;
}
@media(min-width: 1280px){
  .nav .nav_list_link::before {
    content: '';
    display: block;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: url(../images/menu/hari.png) no-repeat;
    background-size: contain;
    position: absolute;
    top: 0;
    right: -3px;
    vertical-align: middle;
    z-index: 1;
  }
  .nav .nav_list_link_12::before {
    content: '';
    display: block;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: url(../images/menu/hari.png) no-repeat;
    background-size: contain;
    position: absolute;
    top: 0;
    right: 0;
    vertical-align: middle;
    z-index: 1;
  }
}

.nav .nav_list_link:hover::before {
  transition: transform 1s;
  transform: rotate(360deg);
}

.nav .nav_list_link_12:hover::before {
  transition: transform 1s;
  transform: rotate(360deg);
}

.nav .nav_list_link:hover::before {
  transition: transform 1s;
  transform: rotate(360deg);
}

.nav .nav_list_link_12:hover::before {
  transition: transform 1s;
  transform: rotate(360deg);
}

.header_wrap {
  position: relative;
  margin: 0 auto;
}

/* ナビゲーションボタン（閉じる） */
.open #navbtn{
    z-index: 100;
    background: none;
}
.open #navbtn::after{
    content: '';
    display: inline-block;
    width: 30px;
    height: 30px;
    background: url(../images/menu/menu_icon_white_close.png) no-repeat;
    background-size: cover;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    vertical-align: middle;
}

/* ナビゲーションボタン（開く） */
#navbtn {
  position: absolute;
  top: 0;
  right: 0;
  padding: 5px;
  outline: none;
  border: none;
  width: 80px;
  height: 80px;
  cursor: pointer;
  background: #145FB7;
}
#navbtn::after {
    content: '';
    display: inline-block;
    width: 60px;
    height: 50px;
    background: url(../images/menu/menu_icon.png) no-repeat;
    background-size: cover;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    vertical-align: middle;
}
@media(min-width: 1280px){
  /* PCではボタン非表示 */
  #navbtn{
    display:none;
  }
}

/* ナビゲーションボタン（閉じる） */
.open #navbtn {
  z-index: 100;
}
/* ナビゲーションメニュー 開いた時*/
.open .nav {
  visibility: visible;
  opacity: 1;
  z-index: 2;
}

@media(min-width: 1280px){
  /* ヘッダーは横並び */
  header{
    display: flex;
    align-items: center;
  }
}

.header_item {
  margin-bottom: 30px;
}
@media(min-width: 1280px){
    .header_item {
        display: flex;
    }
}

.rashinban {
    display: none;
}
.open .rashinban {
    display: block;
    position: absolute;
    top: 50px;
    left: 50%;
    transform: translateX(-50%);
    width: 90%;
    max-width: 450px;
}

.nav_item01 {
    content: '';
    display: block;
    width: 40px;
    height: 300px;
    background: url(../images/menu/top_menu01.png) no-repeat;
    background-size: contain;
    position: static;
    vertical-align: middle;
}
.open .nav_item01 {
    content: '';
    display: block;
    width: 200px;
    height: 20px;
    background: url(../images/menu/top_menu01_white.png) no-repeat;
    background-size: contain;
    position: static;
    vertical-align: middle;
    margin-left: 10px;
}
@media(min-width: 1280px){
  .nav_item01 {
    width: 20px;
    height: 150px;
    position: relative;
    top: 40px;
  }
}

.nav_item02 {
    content: '';
    display: block;
    width: 40px;
    height: 250px;
    background: url(../images/menu/top_menu02.png) no-repeat;
    background-size: cover;
    position: relative;
    vertical-align: middle;
}
.open .nav_item02 {
    content: '';
    display: block;
    width: 200px;
    height: 20px;
    background: url(../images/menu/top_menu02_white.png) no-repeat;
    background-size: contain;
    position: static;
    vertical-align: middle;
    margin-left: 10px;
}
@media(min-width: 1280px){
  .nav_item02 {
    width: 20px;
    height: 130px;
    position: relative;
    top: 40px;
  }
}

.nav_item03 {
    content: '';
    display: block;
    width: 85px;
    height: 240px;
    background: url(../images/menu/top_menu03.png) no-repeat;
    background-size: cover;
    position: relative;
    vertical-align: middle;
}
.open .nav_item03 {
    content: '';
    display: block;
    width: 200px;
    height: 20px;
    background: url(../images/menu/top_menu03_white.png) no-repeat;
    background-size: contain;
    position: static;
    vertical-align: middle;
    margin-left: 10px;
}
@media(min-width: 1280px){
  .nav_item03 {
    width: 45px;
    height: 130px;
    position: relative;
    top: 40px;
  }
}

.nav_item04 {
    content: '';
    display: block;
    width: 40px;
    height: 280px;
    background: url(../images/menu/top_menu04.png) no-repeat;
    background-size: cover;
    position: relative;
    vertical-align: middle;
}
.open .nav_item04 {
    content: '';
    display: block;
    width: 200px;
    height: 20px;
    background: url(../images/menu/top_menu04_white.png) no-repeat;
    background-size: contain;
    position: static;
    vertical-align: middle;
    margin-left: 10px;
}
@media(min-width: 1280px){
  .nav_item04 {
    width: 23px;
    height: 110px;
    position: relative;
    top: 40px;
  }
}

.nav_item05 {
    content: '';
    display: block;
    width: 130px;
    height: 130px;
    background: url(../images/menu/top_menu05.png) no-repeat;
    background-size: cover;
    position: relative;
    top: 20px;
    vertical-align: middle;
}
.open .nav_item05 {
    content: '';
    display: block;
    width: 100%;
    max-width: 350px;
    height: 50px;
    margin: 0 auto 20px;
    background: url(../images/menu/download.png) no-repeat;
    background-size: contain;
    position: static;
    vertical-align: middle;
}

.nav_item06 {
    content: '';
    display: block;
    width: 30px;
    height: 30px;
    background: url(../images/sns/instagram.png) no-repeat;
    background-size: cover;
    position: relative;
    vertical-align: middle;
}

.nav_list_lower {
    display: none;
}

.open .nav_list_lower {
    display: block;
    background: rgba(225, 241, 250, 0.4);
    border-radius: 10px;
    padding:20px;
    margin-top: 20px;
}

.open .nav_list_lower_link {
    color: #fff;
    text-decoration: none;
    position: relative;
}

.open .nav_list_lower_link::after {
    content: '';
    display: block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: url(../images/menu/icon_link.png) no-repeat;
    background-size: contain;
    position: absolute;
    top: 45%;
    right: 0;
    transform: translate(-50%, -50%);   
    vertical-align: middle;
    z-index: 1;
}

/* ====================
Form-page
==================== */

.bg_form {
    background: url(../images/bg/bg_form_sp.jpg) no-repeat;
    background-size: cover;
    margin: -140px 0 0;
    padding-bottom: 10px;
}
@media(min-width: 768px){
  .bg_form {
      background: url(../images/bg/bg_form.jpg) no-repeat;
      background-size: cover;
      margin: 0;
      padding-bottom: 10px;
  }
}

.bg_form_thankyou {
    background: url(../images/bg/bg_form_sp.jpg) no-repeat;
    background-size: cover;
    margin: -100px 0 0;
    padding-bottom: 10px;
}
@media(min-width: 768px){
  .bg_form_thankyou {
      background: url(../images/bg/bg_form.jpg) no-repeat;
      background-size: cover;
      margin: 0;
      padding-bottom: 10px;
  }
}

.bg_form_adult {
    background: url(../images/bg/bg_form_adult.jpg) no-repeat;
    background-size: cover;
    padding-bottom: 10px;
    margin-top: -10px;
}

.bg_form_adult.thankyou {
  padding-top: 50px;
  z-index: -1;
}

.main_title_bg {
    background: url(../images/bg/title_adult.png) no-repeat;
    background-size: cover;
    padding-bottom: 10px;
    position: relative;
}

.main_title_wrap {
  text-align: center;
  padding-top: 150px;
  margin-bottom: 30px;
}
@media(min-width: 768px){
  .main_title_wrap {
    padding-top: 250px;
  }
}

.main_title_wrap.adult {
  text-align: center;
  padding-top: 50px;
  margin-bottom: 30px;
}
@media(min-width: 768px){
  .main_title_wrap.adult {
    padding-top: 0;
  }
}

.main_sub_title {
  font-size: 1.5rem;
  color: #8ED3D8;
}

.main_title {
  color: #1E3B72;
  font-size: 1.5rem;
  line-height: 2rem;
  font-weight: 500;
  margin-bottom: 50px;
}
@media(min-width: 768px){
  .main_title {
      font-size: 2.25rem;
      line-height: 3rem;
  }
}

.read_wrap {
  border: 10px solid #F0F3F5;
  background: #fff;
  color: #1E3B72;
  border-radius: 10px;
  padding: 20px;
  position: relative;
  max-width: 915px;
  margin: 50px auto 50px;
}
@media(min-width: 768px){
  .read_wrap {
    display: flex;
  }
}

.read_wrap_thankyou {
  border: 10px solid #F0F3F5;
  background: #fff;
  color: #1E3B72;
  border-radius: 10px;
  position: relative;
  max-width: 915px;
  margin: 0 auto 50px;
}

.read_wrap_thankyous.adult {
  border: 10px solid #F0F3F5;
  background: #fff;
  color: #1E3B72;
  border-radius: 10px;
  position: relative;
  max-width: 915px;
  margin: 50px auto 50px;
}

.thankyou_jonathan {
    background: url(../images/item/tokuten_jonathan.png) no-repeat;
    background-position: center center;
    height: 130px;
    background-size: cover;
}
@media(min-width: 705px){
  .thankyou_jonathan {
      height: 200px;
  }
}

.read_wrap::before {
      content: '';
      display: block;
      width: 100px;
      height: 100px;
      border-radius: 50%;
      background: url(../images/item/jonathan_fly.png) no-repeat;
      background-size: contain;
      position: absolute;
      top: -50px;
      left: -5%;
      vertical-align: middle;
      z-index: 1;
}
.read_wrap.adlut::before {
  content: none;
}
@media(min-width: 768px){
  .read_wrap::before {
      content: '';
      display: block;
      width: 150px;
      height: 150px;
      border-radius: 50%;
      background: url(../images/item/right.png) no-repeat;
      background-size: contain;
      position: absolute;
      top: -80px;
      left: 95%;
      vertical-align: middle;
      z-index: 1;
  }
    .read_wrap.adlut::before {
      content: '';
      display: block;
      width: 150px;
      height: 150px;
      border-radius: 50%;
      background: url(../images/item/right.png) no-repeat;
      background-size: contain;
      position: absolute;
      top: -80px;
      left: 95%;
      vertical-align: middle;
      z-index: 1;
  }
}

.read_text {
  line-height: 2rem;
}
@media(min-width: 1280px){
  .read_text {
    margin-right: 40px;
  }
}

.read_text_thantyou {
  padding: 30px;
  text-align: center;
}

.thank_you_present_images_wrap {
  max-width: 700px;
  width: 95%;
  margin: 20px auto 30px;
}

.thank_you_present_text {
  padding: 30px;
  text-align: center;
  margin-top: 30px;
}

.thank_you_present_link {
  display: block;
}

.read_sub {
  font-size: 0.75rem;
}

.read_images {
  width: 80%;
  max-width: 300px;
  margin: -80px auto 20px;
}
@media(min-width: 768px){
  .read_images {
    width: 25%;    
    margin: 0 auto 0;
  }
}

.form-child-text {
  color: #fff;
  font-size: 1.15rem;
}

.form-child-text.adult {
  color: #1E3B72;
  margin-left: 0;
  margin-right: auto;
}

.taikendan {
  border: 2px solid #fff;
  background: rgba(255,255,255,0.15);
  padding: 30px;
  border-radius: 20px;
  max-width: 1180px;
  margin: 0 auto 50px;
}

.taikendan_title {
  text-align: center;
  color: #1E3B72;
  font-size: 1.85em;
  font-weight: bold;
  margin-bottom: 30px;
}

.taikendan_images_wrap {
  max-width: 200px;
  margin: 0 auto 30px;
}

.form-child-label-message {
  width: 100%;
}

.form-for_adult_title {
    background: url(../images/item/line_jonathan.png) no-repeat;
    height: 150px;
    background-size: cover;
}
@media(min-width: 1350px){
  .form-for_adult_title {
    margin-top: -100px;
  }
}

.form-for_adult_title_text {
    font-size: 1.5rem;
    line-height: 2rem;
    color: #fff;
    margin-bottom: 20px;
}
@media(min-width: 1350px){
  .form-for_adult_title_text {
    margin-left: 100px;
  }
}

.form-for_adult_text {
  color: #fff;
  margin-bottom: 20px;
}
@media(min-width: 1280px){
.form-for_adult_text {
  margin-top: 30px;
}
}

#form_adult .form-for_adult_text {
  color: #1E3B72;
}

.form-for_adult_policy {
  color: #fff;
}

.form-for_adult_policy.adult {
  color: #1E3B72;
}

.form-for_adult_policy_text {
  font-size: 1.5rem;
  line-height: 2.5rem;
  text-align: center;
}

.form-for_adult_policy_check_wrap {
  margin-top: 30px;
  text-align: center;
  font-size: 1.5rem;
  font-weight: bold;
}

#openModal {
  color: #fff;
  border-bottom: 2px solid #fff;
  cursor: pointer;
}

#openModal.adult {
  color: #1E3B72;
  border-bottom: 2px solid #1E3B72;
  cursor: pointer;
}


.modalContents_title {
  font-size: 2.25rem;
  line-height: 3rem;
  text-align: center;
  margin-bottom: 50px;
}

.modalContents_text_wrap {
  margin-bottom: 50px;
}

.modalContents_text_title {
  font-size: 1.5rem;
  font-weight: bold;
  margin-bottom: 20px;
}

/* モーダルウィンドウ */
.modalArea {
  display: none;
  position: fixed;
  z-index: 10;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.modalBg {
  width: 100%;
  height: 100%;
  background-color: rgba(30,30,30,0.9);
}

.modalWrapper {
  position: absolute;
  top: 50%;
  left: 50%;
  transform:translate(-50%,-50%);
  width: 90%;
  color: #1E3B72;
  border: 10px solid #F0F3F5;
  background: #fff;
  border-radius: 10px;
  padding: 20px;
  margin: 0 auto;
  overflow-y: auto;
  max-height: 90%;
}

.closeModal {
  position: absolute;
  top: 0.5rem;
  right: 1rem;
  cursor: pointer;
  font-size: 2rem;
}

/* 確認画面 */
.form-label-confirmation {
  color: #fff;
  font-size: 1.15rem;
}

#form_adult .form-label-confirmation {
  color: #1E3B72;
}

.form-label-textarea-confirmation {
  color: #fff;
  font-size: 1.15rem;
  text-align: left;
}

#form_adult .form-label-textarea-confirmation {
  color: #1E3B72;
}

.form-label-ib-confirmation {
  color: #fff;
  font-size: 1.15rem;
  display: inline-block;
}

#form_adult .form-label-ib-confirmation {
  color: #1E3B72;
}

.confirmation_wrap {
  margin: 50px auto 0;
  max-width: 1180px;
}
@media(min-width: 650px){
  .confirmation_wrap {
    margin: 100px auto 0;
  }
}
@media(min-width: 730px){
  .confirmation_wrap {
    margin: 180px auto 0;
  }
}
@media(min-width: 1080px){
  .confirmation_wrap {
    margin: 220px auto 0;
  }
}

#form_adult .confirmation_wrap {
  margin: 50px auto 0;
  max-width: 1180px;
}
@media(min-width: 768px){
  #form_adult .confirmation_wrap {
    margin: 130px auto 0;
  }
}

@media(min-width: 768px){
  .form-label_button_wrap {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 30px;
  }
}

/* ====================
Form-parts
==================== */

#form_adult {
  padding-top: 50px;
}
@media(min-width: 768px){
  #form_adult {
    padding-top: 100px;
  }
}

/* レイアウト */
form {
  margin: 0 auto;
}
.form-child-row {
 margin-bottom: 50px;
}
@media(min-width: 768px){
  .form-child-row.confirmation {
    display: flex;
  }
}
.form-child-row:last-child {
  border-bottom: none;
}
.form-child-label {
  display: flex;
  align-items: center;
}
.form-child-label_avatar {
  overflow: hidden;
}
@media(min-width: 768px){
  .form-child-label_avatar {
    display: flex;
  }
}
.form-child-label_avatar_row {
  display: flex;
  margin-top: 10px;
}
@media(min-width: 768px){
.form-child-label_avatar_row {
  margin-top: 0;
}
}
.form-child-label-title {
  display: flex;
  align-items: center;
  width: 250px;
}
@media(min-width: 768px){
  .form-child-row.confirmation .form-child-label {
    width: 40%;
  }
}
.form-child-label-avatar-title {
  display: flex;
  align-items: center;
}
.form-child-label-note {
  color: #fff;
  margin-bottom: 20px;
}
.form_adult.form-child-label-note {
  color: #1E3B72;
  margin-bottom: 20px;
}
.form-child-label-note.avatar {
  margin-bottom: 10px;
  margin-left: 20px;
}
.form-child-label-note.confirmation {
  text-align: center;
}
#form_adult .form-child-label-note {
  color: #1e3b72;
}
.form-child-label label {
  font-weight: bold;
  margin-bottom: 10px;
  width: 100%;
}
.form-child-label-title_span {
  color: #fff;
  border-bottom: 2px solid #FAF194;
  padding-bottom: 5px;
  font-size: 1.5rem;
  font-weight: bold;
}
.form_adult.form-child-label-title_span {
  color: #1E3B72;
}
.form-child-label-title_span.message {
    color: #1E3B72;
}
.form-child-label-title_main_span {
  color: #1E3B72;
  border-bottom: 2px solid #FAF194;
  padding-bottom: 5px;
  font-size: 1.5rem;
  font-weight: bold;
}
.form-child-row_span {
  min-width: 45px;
  height: 28px;
  margin-left: 10px;
  padding: 2px 10px;
  border-radius: 30px;
  font-size: 12px;
  font-weight: bold;
  color: #169939;
  background-color: #FAF194;
}
.form-child-row_span.adult {
  width: 45px;
  height: 28px;
  margin-left: 10px;
  padding: 2px 10px;
  border-radius: 30px;
  font-size: 12px;
  font-weight: bold;
  color: #1E3B72;
  background-color: #FAF194;
}

@media(min-width: 768px){
  .form-child-row_wrap.confirmation {
    text-align: center;
  }
}

.form-child-label-name_wrap {
  display:flex;
  flex-flow: column;
}

@media(min-width: 768px){
  .form-child-row.confirmation .form-child-label-name_wrap {
    width: 60%;
    text-align: left;
  }
}

.form-child-label-email {
  width: 100%;
}

.form-child-row-avatar {
  overflow: hidden;
}

.form-child-row-avatar-item_wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    margin-bottom: 80px;
}
@media(min-width: 768px){
  .form-child-row-avatar-item_wrap {
      gap: 30px;
  }
}

.form-child-row-avatar-item_wrap.confirmation {
    justify-content: center;
    align-items: center;
    margin-bottom: 50px;
}
@media(min-width: 768px){
  .form-child-row-avatar-item_wrap.confirmation {
  }
}

.form-child-row-avatar-item {
    width: calc(20%);
}
@media(min-width: 768px){
  .form-child-row-avatar-item {
      width: calc(10%);
  }
}

.form-child-row-avatar-item_wrap.confirmation .form-child-row-avatar-item {
  width: calc(45%);
  max-width: 150px;
}
@media(min-width: 768px){
  .form-child-row-avatar-item_wrap.confirmation .form-child-row-avatar-item {
      width: calc(20%);
  }
}

/* フォームパーツのデザイン */
input, textarea {
  background-color: #F8FFE2;
  border: 1px solid #8ED3D8;
  padding: 15px 20px;
  font-size: 16px;
  color: #333;
  flex-grow: 1;
}
input.adult, textarea.adult {
  background-color: #fff;
  border: 1px solid #8ED3D8;
  padding: 15px 20px;
  font-size: 16px;
  color: #333;
  flex-grow: 1;
}
input {
  max-width: 600px;
  border-radius: 5px;
}
input.adult {
  max-width: 600px;
}
textarea {
    border-radius: 5px;
}
input::placeholder,
textarea::placeholder {
  color: #999;
  font-size: 14px;
}
select {
  background-color: #f2f4f5;
  border: none;
  border-radius: 3px;
  padding: 15px 20px;
  font-size: 16px;
  color: #333;
}
.checkbox_button {
  display: block;
  cursor: pointer;
  margin: 30px auto 0;
  padding: 15px 45px;
  border-radius: 50px;
  color: #fff;
  font-weight: bold;
  background: #666666;
  font-size: 1.5rem;
  min-width: 310px;
}
.send_button {
  display: block;
  cursor: pointer;
  margin: 30px auto 0;
  padding: 15px 45px;
  border-radius: 50px;
  color: #fff;
  font-weight: bold;
  background: #145FB7;
  font-size: 1.5rem;
  min-width: 310px;
}
.cancel_button {
  display: block;
  cursor: pointer;
  margin: 30px auto 0;
  padding: 15px 45px;
  border-radius: 50px;
  color: #fff;
  border: 2px solid #fff;
  font-weight: bold;
  font-size: 1.5rem;
  min-width: 310px;
}
#form_adult .cancel_button {
  display: block;
  cursor: pointer;
  margin: 30px auto 0;
  padding: 15px 45px;
  border-radius: 50px;
  color: #145FB7;
  border: 2px solid #145FB7;
  font-weight: bold;
  font-size: 1.5rem;
  min-width: 310px;
}

.form-label_button_wrap .send_button {
  margin: 30px auto 0;
}
.form-label_button_wrap .cancel_button {
  margin: 30px auto 0;
}

/* プレースホルダー */
input[type="text"]::placeholder {
  color: #169939;
}
textarea::placeholder {
  color: #169939;
}
input[type="email"]::placeholder {
  color: #169939;
}
/* Microsoft Edge */
input[type="text"]::-ms-input-placeholder {
  color: #169939;
}
textarea::-ms-input-placeholder {
  color: #169939;
}
input[type="email"]::-ms-input-placeholder {
  color: #169939;
}
/* Internet Explorer */
input[type="text"]:-ms-input-placeholder{
  color: #169939;
}
textarea:-ms-input-placeholder {
  color: #169939;
}
input[type="email"]:-ms-input-placeholder {
  color: #169939;
}
input[type="text"]::placeholder {
  color: #169939;
}
textarea::placeholder {
  color: #169939;
}
input[type="email"]::placeholder {
  color: #169939;
}
/* Microsoft Edge */
input[type="text"]::-ms-input-placeholder {
  color: #169939;
}
textarea::-ms-input-placeholder {
  color: #169939;
}
input[type="email"]::-ms-input-placeholder {
  color: #169939;
}
/* Internet Explorer */
input[type="text"]:-ms-input-placeholder{
  color: #169939;
}
textarea:-ms-input-placeholder {
  color: #169939;
}
input[type="email"]:-ms-input-placeholder {
  color: #169939;
}

input.adult[type="text"]::placeholder {
  color: #1E3B72;
}
textarea.adult::placeholder {
  color: #1E3B72;
}
input.adult[type="email"]::placeholder {
  color: #1E3B72;
}
/* Microsoft Edge */
input.adult[type="text"]::-ms-input-placeholder {
  color: #1E3B72;
}
textarea.adult::-ms-input-placeholder {
  color: #1E3B72;
}
input.adult[type="email"]::-ms-input-placeholder {
  color: #1E3B72;
}
/* Internet Explorer */
input.adult[type="text"]:-ms-input-placeholder{
  color: #1E3B72;
}
textarea.adult:-ms-input-placeholder {
  color: #1E3B72;
}
input.adult[type="email"]:-ms-input-placeholder {
  color: #1E3B72;
}

/* アバター_ラジオボタン */
label.avatar_label {
  position: relative;
  cursor: pointer;
}

label.avatar_label::before,
label.avatar_label::after {
  content: "";
  display: block; 
  border-radius: 50%;
  position: absolute;
  bottom: -30px;
  left: 50%;
  transform: translateX(-50%);
  border: 2px solid #fff;
  border-radius: 50%;
  width: 20px;
  height: 20px;
}
@media(min-width: 768px){
  label.avatar_label::before,
  label.avatar_label::after {
    bottom: -30px;
    width: 20px;
    height: 20px;
  }
}

label.avatar_label::after {
  background-color: #FAF194;
  border-radius: 50%;
  opacity: 0;
  width: 10px;
  height: 10px;
  position: absolute;
  bottom: -25px;
}
@media(min-width: 768px){
  label.avatar_label::after {
    bottom: -25px;
    width: 10px;
    height: 10px;
  }
}

input:checked + label.avatar_label::after {
  opacity: 1;
}

.visually-hidden {
 white-space: nowrap;
 border: 0;
 clip: rect(0 0 0 0);
 clip-path: inset(50%);
 overflow: hidden;
 height: 1px;
 width: 1px;
 margin: -1px;
 padding: 0;
}

/* ラジオボタン */
label.radiobutton_label {
  position: relative;
  cursor: pointer;
}

label.radiobutton_label::before,
label.radiobutton_label::after {
  content: "";
  display: block; 
  border-radius: 50%;
  position: absolute;
  top: 5px;
  left: 0;
  border: 2px solid #fff;
  border-radius: 50%;
  width: 20px;
  height: 20px;
}
@media(min-width: 768px){
  label.radiobutton_label::before,
  label.radiobutton_label::after {
    width: 20px;
    height: 20px;
  }
}

label.radiobutton_label.adult::before {
  border: 2px solid #1E3B72;
}

label.radiobutton_label::after {
  background-color: #FAF194;
  border-radius: 50%;
  opacity: 0;
  width: 10px;
  height: 10px;
  position: absolute;
  top: 10px;
  left: 5px;
}
@media(min-width: 768px){
label.radiobutton_label::after {
  top: 10px;
  width: 10px;
  height: 10px;
}
}

label.radiobutton_label.adult::after {
  background-color: #1E3B72;
  border-radius: 50%;
  opacity: 0;
  width: 10px;
  height: 10px;
  position: absolute;
  top: 10px;
  left: 5px;
  border: none;
}
@media(min-width: 768px){
label.radiobutton_label.adult::after {
  top: 10px;
  width: 10px;
  height: 10px;
}
}

input:checked + label.radiobutton_label::after {
  opacity: 1;
}

/* セレクトタグ */
.form-child-row_selectbox {
    position: relative;
}

.form-child-row_selectbox.confirmation::before,
.form-child-row_selectbox.confirmation::after {
  display: none;
}

.form-child-row_selectbox::before,
.form-child-row_selectbox::after {
    position: absolute;
    left: 65px;
    width: 9px;
    height: 6px;
    content: '';
    pointer-events: none;
    display: block;
}

.form-child-row_selectbox.adult::before,
.form-child-row_selectbox.adult::after {
  display: none;
}

.form-child-row_selectbox::before {
    background: url(../images/item/icon_up.png) no-repeat;
    background-size: contain;
    vertical-align: middle;
    z-index: 1;
    top: 55px;
}

.form-child-row_selectbox.adult::before {
  display: none;
}

.form-child-row_selectbox.age::before {
    background: url(../images/item/icon_up.png) no-repeat;
    background-size: contain;
    vertical-align: middle;
    z-index: 1;
    top: 55px;
}

.form-child-row_selectbox::after {
    background: url(../images/item/icon_down.png) no-repeat;
    background-size: contain;
    vertical-align: middle;
    z-index: 1;
    bottom: 10px;
}

.form-child-row_selectbox.adult::after {
  display: none;
}

.form-child-row_selectbox select {
    appearance: none;
    width: 80px;
    height: 2.8em;
    padding: .4em calc(.8em + 30px) .4em .8em;
    border: 1px solid #8ED3D8;
    background-color: #F8FEE2;
    color: #169939;
    cursor: pointer;
    border-radius: 5px;
    margin-right: 10px;
}

.form-child-row_checkbox {
  width: 100%;
  margin-bottom: 10px;
}

.form-child-row.confirmation .form-child-row_checkbox {
  width: auto;
}

.form-child-row_checkbox_text {
  margin-left: 30px;
}

.form-child-text.adult.checkbox .form-child-radio_wrap .form-child-row_checkbox_text {
  margin-left: 10px;
}

.form-child-radio {
  	display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.form-child-radio_wrap {
  width: 25%;
}
@media(min-width:900px){
  .form-child-radio_wrap {
    width: 15%;
  }
}
@media(min-width:1150px){
  .form-child-radio_wrap {
    width: 7%;
  }
}

/* チェックボックス */
input.adult[type="checkbox"] {
  cursor: pointer;
}

input[type="checkbox"] {
  position: relative;
  padding: 0;
  background: transparent;
  width: 30px;
  height: 30px;
  border: 2px solid #fff;
  vertical-align: -5px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

input.adult[type="checkbox"] {
  position: relative;
  padding: 0;
  background: transparent;
  width: 30px;
  height: 30px;
  border: 2px solid #1E3B72;
  vertical-align: -5px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

input[type="checkbox"]:checked:before {
  position: absolute;
  top: 3px;
  left: 9px;
  transform: rotate(50deg);
  width: 8px;
  height: 16px;
  border-right: 2px solid #FAF194;
  border-bottom: 2px solid #FAF194;
  content: '';
}

input.adult[type="checkbox"]:checked:before {
  position: absolute;
  top: 3px;
  left: 9px;
  transform: rotate(50deg);
  width: 8px;
  height: 16px;
  border-right: 2px solid #1E3B72;
  border-bottom: 2px solid #1E3B72;
  content: '';
}

/* ====================
Footer
==================== */

.footer {
  background: #145FB7;
  padding: 50px 0;
}

.footer_wrap {
  overflow: hidden;
}
@media(min-width:768px){
  .footer_wrap {
    display: flex;
    gap: 40px;
  }
}

.footer_logo {
  margin: 0 auto 50px;
  max-width: 290px;
}
@media(min-width:768px){
  .footer_logo {
    margin: 0 0 50px;
    max-width: 290px;
  }
}

.footer_list_wrap.sns {
  width: 30px;
  margin: 0 auto 30px;
}
@media(min-width:1280px){
.footer_list_wrap.sns {
  margin: 0 auto 0;
}
}

.footer_list {
  color: #fff;
  width: 300px;
  margin: 0 auto;
}
@media(min-width: 1280px){
  .footer_list {
    display: flex;
    width: 100%;
    gap: 30px;
  }
}


.footer_item {
  margin-bottom: 25px;
}

.footer_item.sampoh {
  display: flex;
}

.footer_item_list_item {
  margin-bottom: 10px;
}

.footer_item_link {
  color: #fff;
  text-decoration: none;
  font-weight: bold;
}

.sampoh .footer_item_link {
  color: #8ED3D8;
  margin-right: 20px;
}

.footer_item_list_item_link {
  color: #fff;
  text-decoration: none;
  margin-left: 15px;
}

.sampoh .footer_item_list_item_link {
  margin-left: 0;
}

.footer_top-back {
  width: 100px;
  margin-right: 0;
  margin-left: auto;
  text-align: right;
}

.footer_top-back img {
  width: 100px;
}

.copyright {
  color: #8ED3D8;
  display: block;
  text-align: center;
}
@media(min-width: 1280px){
.copyright {
  text-align: right;
}
}