@charset "utf-8";
/* CSS Document */

/*common
=======================*/
.biz-udpmincho-regular {
  font-family: "BIZ UDPMincho", serif;
  font-weight: 400;
  font-style: normal;
}

.biz-udpmincho-bold {
  font-family: "BIZ UDPMincho", serif;
  font-weight: 700;
  font-style: normal;
}

html
#main {
  box-sizing: border-box;
  font-size: 1.6rem;
  color: #323232;
  line-height: 1.7;
  margin: 0 auto;
}
#main img{
	vertical-align:top;
  pointer-events: none;
  -webkit-touch-callout:none;
  -webkit-user-select:none;
  -moz-touch-callout:none;
  -moz-user-select:none;
  user-select:none;
}
@media screen and (min-width:768px) {
  .spOnly {
    display: none;
  }
}
@media screen and (max-width:767.98px) {
  .pcOnly {
    display: none;
  }
}

/*---animation---*/
.anim_fadein {
  animation: fadeIn 4s cubic-bezier(0.33, 1, 0.68, 1) 1 forwards;
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.anim_scroll {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 1s, transform 1s;
}
.anim_scroll.scrollin {
  opacity: 1;
  transform: translate(0, 0);
}
.kvTitWrap .anim_scroll {
  transform: translateY(30px) scale(.7);
}
.kvTitWrap .anim_scroll.scrollin {
  transform: translate(0, 0) scale(1);
}
@media screen and (max-width:767.98px) {
  .anim_scroll_sp {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 1s, transform 1s;
  }
}
/*=====================*/


/*kvArea
=======================*/
.kvArea {
  position: relative;
}
.kv {
  margin: 0;
}
.kvArea h1 {
  margin: 0;
  position: absolute;
  top: 0;
  left: 35%;
  transform: translateX(-50%);
  z-index: 5;
}
.announce_pc {
  position: absolute;
  bottom: 4%;
  right: 20%;
  z-index: 5;
}
.kv img {
  object-fit: cover;
  object-position: bottom;
  width: 100%;
  height: 100%;
}
@media (min-width: 768px) {
  .kv {
    height: 316px;
  }
}
@media (max-width: 1600px) {
  .kvArea h1 {
    left: 30%;
  }
  .announce_pc {
    right: 140px;
  }
}
@media screen and (max-width:767.98px) {
  .kv {
    height: 395px;
  }
  .kvArea h1 {
    left: 50%;
    width: 375px;
  }
}
@media screen and (max-width:550px) {
  .kv {
    height: 340px;
  }
}
@media screen and (max-width:400px) {
  .kv {
    height: 310px;
  }
}
@media screen and (max-width:374.98px) {
  .kvArea h1 {
    width: 100%;
  }
}
/*=====================*/

/*announce_sp
=======================*/
@media screen and (max-width:767.98px) {
  .announce_sp {
    padding: 5px 0;
    background-color: #c1272d;
  }
  .announce_sp p {
    font-size: 1.5rem;
    font-family: "BIZ UDPMincho", serif;
    color: #c1272d;
    background-color: #fff;
    padding: 3px 0;
    text-align: center;
    overflow: hidden;
  }
  .announce_sp p span {
    position: relative;
  }
  .announce_sp p span::before,
  .announce_sp p span::after {
    position: absolute;
    content: "";
    width: 37px;
    height: 13px;
    top: 45%;
    transform: translateY(-50%);
  }
  .announce_sp p span::before {
    background: url("/med/feature/domestic/asuka35th/img/ann_sp_01.webp") no-repeat;
    background-size: contain;
    left: -18%;
  }
  .announce_sp p span::after {
    background: url("/med/feature/domestic/asuka35th/img/ann_sp_02.webp") no-repeat;
    background-size: contain;
    right: -18%;
  }
}
@media screen and (max-width:360px) {
  .announce_sp p span::before,
  .announce_sp p span::after {
    width: 25px;
    height: 8px;
  }
  .announce_sp p span::before {
    left: -10%;
  }
  .announce_sp p span::after {
    right: -10%;
  }

}
/*=====================*/

/*lead_wrap
=======================*/
.lead_wrap {
  background-color: #cabca0;
}
.lead_t {
  text-align: center;
  font-family: "BIZ UDPMincho", serif;
  font-size: 1.7rem;
  line-height: 1.5;
  padding: 8px 0;
}
.lead_t span {
  font-size: 2.6rem;

  display: inline-block;
  padding-bottom: 10px;
}
.lead_t_box {
  max-width: 1160px;
  margin: 0 auto;
  padding: 8px 0 10px;
  border: 10px solid #f2ebd9;
  background-color: #fff;
  position: relative;
}
.lead_wrap .frameParts {
  position: absolute;
}
.lead_wrap .frameParts:first-of-type {
  top: -1px;
  left: -1px;
}
.lead_wrap .frameParts:nth-of-type(2) {
  top: -1px;
  right: -1px;
  transform: scale(-1, 1);
}
.lead_wrap .frameParts:nth-of-type(3) {
  bottom: -1px;
  left: -1px;
  transform: scale(1, -1);
}
.lead_wrap .frameParts:nth-of-type(4) {
  bottom: -1px;
  right: -1px;
  transform: scale(-1, -1);
}
@media screen and (max-width:767.98px) {
  .lead_t {
    font-size: 1.2rem;
  }
  .lead_t span {
    font-size: 1.5rem;
  }
}
@media screen and (max-width:340px) {
  .lead_t_box {
    border: 5px solid #f2ebd9;
  }
  .lead_wrap .frameParts {
    width: 38px;
    height: auto;
  }
}
/*=====================*/

/*menuNav
=======================*/
.menuNav_inner {
  display: flex;
  justify-content: center;
  max-width: 1160px;
  margin: 0 auto;
}
.menuNav .navItem {
  width: 100%;
  font-size: 2rem;
  text-align: center;
  border-right: 1px solid #fff;
}
.menuNav .navItem:last-of-type {
  border-right: none;
}
.menuNav .navItem a {
  display: block;
  width: 100%;
  padding: 20px;
  height: 75px;
  color: #fff;
  font-weight: bold;
  background: #185a85;
}
.menuNav .navItem a span {
  position: relative;
}
.menuNav .navItem a span::after {
  position: absolute;
  content: '';
  top: 50%;
  right: -25px;
  width: 10px;
  height: 10px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: translateY(-50%) rotate(45deg);
}
/* --- 1. 全体・親要素の制御 --- */
.menuNav {
  overflow: visible !important;
  position: sticky;
  top: 0;
  z-index: 1000;
  background: #b1d0e0;
}

.menuNav_inner {
  position: relative;
  display: flex; 
  overflow: visible !important;
}

.menuNav .navItem {
  position: relative;
  width: 50%; 
  z-index: 1;
}

/* --- 2. Pタグ（親ボタン）のデザイン --- */
.menuNav .navItem p,
.menuNav .navItem > a {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  /*background-color: #185a85;
  color: #fff;*/
  margin: 0;
  box-sizing: border-box;
  text-decoration: none;
  cursor: pointer;
}

/* 矢印（↓） */
.menuNav .navItem p span {
  position: relative;
  padding-right: 10px;
	font-weight: bold;
}

.menuNav .navItem p span::after {
  position: absolute;
  content: '';
  top: 50%;
  right: -25px;
  width: 10px;
  height: 10px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: translateY(-50%) rotate(45deg);
  transition: transform 0.3s ease;
}

/* --- 3. ドロップダウンメニュー本体（ul） --- */
.menuNav .navItem ul {
  position: absolute;
  top: 75px;
  left: 0;
  width: 100%;
  z-index: 1001;
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transition: all 0.4s ease;
  list-style: none;
  padding: 0;
  margin: 0;
  background-color: #fff;
  border: 1px solid #185a85;
  box-sizing: border-box;
  pointer-events: none;
}

/* --- 4. メニュー内アイテム --- */
.menuNav .navItem ul li a {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 15px;
  color: #6e6e6e;
  background: #fff;
  text-decoration: none;
  border-bottom: 1px solid #6e6e6e;
  position: relative;
}

.menuNav .navItem ul li:last-child a {
  border-bottom: none;
}

.menuNav .navItem ul li a span {
  position: relative;
  padding-right: 10px;
}

.menuNav .navItem ul li a span::after {
  position: absolute;
  content: '';
  top: 50%;
  right: -20px;
  width: 8px;
  height: 8px;
  border-right: 2px solid #6e6e6e;
  border-bottom: 2px solid #6e6e6e;
  transform: translateY(-50%) rotate(45deg);
}

/* --- 5. スマホ用設定 (767.98px以下) --- */
@media (max-width: 767.98px) {
  .menuNav .navItem {
    position: static; 
  }
  
  .menuNav_inner {
    position: relative;
  }
  /* クリックで .is-open が付与された時のみ表示 */
  .menuNav .navItem.is-open ul {
    max-height: 500px;
    opacity: 1;
    pointer-events: auto;
  }
  .menuNav .navItem.is-open p {
    background-color: #174a99;
  }
  .menuNav .navItem ul {
    top: 70px;
    left: 0;
    right: 0;
    width: 100%;
    box-shadow: 0 10px 20px rgba(0,0,0,0.2);
  }
  .menuNav .navItem p {
    width: 100%;
  }
  .menuNav .navItem p span {
    width: 100%;
  }
  .menuNav .navItem p span::after {
    right: 2px;
  }
  .menuNav .navItem.is-open p span::after {
    transform: translateY(-20%) rotate(-135deg);
  }
  .menuNav .navItem ul li a span::after {
    right: 0;
  }
  .menuNav .navItem.is-open ul li a {
    height: 50px;
  }
}

/* --- 6. デスクトップ用設定 (768px以上) --- */
@media (min-width: 768px) {
  /* ホバー時のみ表示。クリックでの固定(is-open)は無視 */
  .menuNav .navItem:hover ul {
    max-height: 500px;
    opacity: 1;
    pointer-events: auto;
  }
  .menuNav .navItem:hover p span::after {
    transform: translateY(-20%) rotate(-135deg);
  }
}


@media (min-width: 768px) {
  .menuNav .navItem {
    transition: 0.2s ease all;
  }
  .menuNav .navItem a:hover {
    opacity: .8;
    transition: 0.2s ease all;
    background: #deeef6;
    color: #185a85;
  }
  .menuNav .navItem a:hover span::after {
    border-right: 2px solid #185a85;
    border-bottom: 2px solid #185a85;
  }
}

@media screen and (max-width:767.98px) {
  .menuNav .navItem {
    font-size: 1.5rem;
	  display: flex;
	  align-items: stretch;
  }
  .menuNav .navItem a {
	  display: flex;
	  align-items: center;
    padding: 20px 15px 18px 5px;
	  line-height: 1.2;
    height: 70px;
  }
	.menuNav .navItem a span{
		display: inline-block;
		width: 100%;
	}
  .menuNav .navItem a span::after {
    top: 35%;
    right: 5px;
    transform: translateY(-30%) rotate(45deg);
  }
}

@media screen and (max-width:359px) {
  .menuNav .navItem {
    font-size: 1.2rem;
  }
}
/*=====================*/

/*announce
=======================*/
.announce {
  text-align: center;
  font-weight: 700;
  font-size: 3.6rem;
  color: #cc0d21;
  padding: 30px 0;
}
/*=====================*/


/*section共通
=======================*/
section {
  /*max-width: 1250px;*/
  /*margin: 20px auto;*/
}
h2 {
  font-family: "BIZ UDPMincho", serif;
  font-size: 2.4rem;
  font-weight: 700;
  color: #185a85;
  text-align: center;
  padding: 10px 0;
  margin: 0 0 20px;
  overflow: hidden;
}
h2 span {
  position: relative;
  display: inline-block;
}
h2 span::before,
h2 span::after {
  position: absolute;
  content: "";
  width: 150px;
  height: 2px;
  top: 50%;
  transform: translateY(-50%);
  background-color: #185a85;
}
h2 span::before {
  left: -200px;
}
h2 span::after {
  right: -200px;
}
@media screen and (max-width:767.98px) {
  h2 {
    margin: 0 0 10px;
    font-size: 2.4rem;
    line-height: 1.2;
  }
  h2 span::before,
  h2 span::after {
    width: 60px;
  }
  h2 span::before {
    left: -80px;
  }
  h2 span::after {
    right: -80px;
  }
}
@media screen and (max-width:340px) {
  h2 {
    font-size: 2.0rem;
  }
}
/*=====================*/

/*sec_course
=======================*/
.sec_course {
  background-color: #f7f5ea;
  padding: 40px 0;
}
.crs_wrap {
  max-width: 1220px;
  margin: 0 auto;
  padding: 40px;
  background-color: #fff;
  border: 1px solid #bead8b;
  border-radius: 25px;
  font-family: "BIZ UDPGothic", "Meiryo", "メイリオ", sans-serif;
  position: relative;
}
.crs_wrap::before {
  position: absolute;
  content: "";
  top: 10px;
  left: 10px;
  right: 10px;
  bottom: 10px;
  border: 1px solid #bead8b;
  border-radius: 15px;
  pointer-events: none;
}
.tab-group {
  width: 100%;
  display: flex;
  border-bottom: 20px solid #185a85;
}
.tab-group .tab-btn {
  width: calc(100% / 5);
  padding: 5px 0;
  color: #185a85;
  font-size: 2.0rem;
  border-radius: 20px 20px 0 0;
  border: 2px solid #185a85;
  background-color: #fff;
  box-sizing: border-box;
}
.tab-group .tab-btn.active {
  background-color: #185a85;
  border: 1px solid #185a85;
}
/* タブの切替 */
.tab-content01 {
  display: none;
  position: relative;
  padding-bottom: 50px;
}
.tab-content01.active {
  display: block;
}
.tab-btn.active {
  background: #333;
  color: #fff;
}

.js-hidden {
  display: none!important;
}
.more-control {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 230px;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 50%, rgba(255, 255, 255, 1) 100%);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  pointer-events: none;
  padding-bottom: 20px;
  z-index: 10;
}
.more-btn {
  pointer-events: auto;
  margin-bottom: 40px;
  display: block;
  margin: 0 auto;
  width: 280px;
  padding: 10px 0;
  font-size: 2.0rem;
  text-align: center;
  color: #174d83;
  background-color: #d6f0fd;
  border: 2px solid #174d83;
  border-radius: 30px;
  cursor: pointer;
  position: relative;
}

/* アイコンの外枠（円） */
.icon-wrap {
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  transition: 0.4s;
}

/* プラス・マイナスの線（共通） */
.icon-wrap::before,
.icon-wrap::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 20px;
  height: 2px;
  background-color: #185a85;
  transform: translate(-50%, -50%);
  transition: all 0.3s ease;
}
.icon-wrap::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

/* 【開いた時（is-open）のスタイル】 */
.tab-content01.is-open .more-control {
  position: static;
  height: auto;
  background: none;
  padding: 30px 0;
}
/* 全体を180度回転 */
.more-btn.is-open .icon-wrap {
  transform: translateY(-50%) rotate(180deg); 
}

/* 縦線を横線に重ねる（回転させて「－」にする） */
.more-btn.is-open .icon-wrap::after {
  transform: translate(-50%, -50%) rotate(0deg);
}
@media (min-width: 768px) {
  .tab-btn:hover:not(.active) {
    background-color: #d9edf5;
  }
  .tab-btn.active:hover {
    cursor: default;
  }
  .more-btn:hover {
    background: #185a85;
    color: #fff;
    transition: .25s;
  }
  .more-btn:hover .icon-wrap::before,
  .more-btn:hover .icon-wrap::after {
    background-color: #fff;
  }
}
@media screen and (max-width:767.98px) {
  .sec_course {
    padding: 20px 0;
  }
  .crs_wrap {
    border-radius: 0;
    border: none;
    border-top: 1px solid #bead8b;
    border-bottom: 1px solid #bead8b;
    padding: 20px 0;
  }
  .crs_wrap::before {
    border-radius: 0;
    border: none;
    border-top: 1px solid #bead8b;
    border-bottom: 1px solid #bead8b;
    left: 0;
    right: 0;
  }
  .crs_wrap .list {
    padding: 0 20px;
    margin: 10px 0 20px;
  }
  .tab-group {
    border-bottom: 20px solid #185a85;
  }
  .tab-group .tab-btn {
    font-size: 1.5rem;
    border-radius: 10px 10px 0 0;
  }
  .more-control {
    height: 115px;
    padding-bottom: 5px;
  }
  .more-btn {
    width: 87%;
    font-size: 1.7rem;
    padding: 4px 0;
  }
  .tab-content01 {
    padding-bottom: 0;
  }
}

.sec_course .ann_txt {
  font-family: "BIZ UDPMincho", serif;
  font-weight: 700;
  font-size: 3.0rem;
  color: #d02335;
  text-align: center;
  padding: 20px 0;
  line-height: 1.8;
}
@media screen and (max-width:767.98px) {
  .sec_course .ann_txt {
    font-size: 1.8rem;
    line-height: 1.5;
    letter-spacing: -0.8px;
    padding: 10px 0;
  }
}
/*=====================*/


/*courseArea
=======================*/

/*---areaMenu---*/
.areaMenu {
  position: sticky;
  top: 0;
  margin-top: 30px;
  background: #d7d7d7;
  box-shadow: 0 1px 2px 2px rgba(0, 0, 0, .1);
  z-index: 10;
}
.areaMenu ul {
  display: flex;
  max-width: 1160px;
  margin: 0 auto;
}
.areaMenu li {
  width: 100%;
  text-align: center;
}
.areaMenu li a {
  display: block;
  width: 100%;
  padding: 12px 0;
  color: #323232;
  font-size: 1.8rem;
}
.areaMenu li a span {
  position: relative;
  padding-left: 10px;
}
.areaMenu li a span::after {
  position: absolute;
  content: '';
  top: 45%;
  left: -8px;
  width: 10px;
  height: 10px;
  border-right: 2px solid #323232;
  border-bottom: 2px solid #323232;
  transform: translateY(-45%) rotate(45deg);
}
@media (min-width: 768px) {
  .areaMenu li a {
    position: relative;
    overflow: hidden;
    transition: 0.2s ease all;
  }
  .areaMenu li a:hover {
    background: #fff;
    opacity: .8;
    transition: 0.2s ease all;
  }
}

@media screen and (max-width:767.98px) {
  .areaMenu ul {
    justify-content: center;
    flex-wrap: wrap;
    overflow: hidden;
  }
  .areaMenu li {
    width: calc(100% / 2);
  }
  .areaMenu li a {
    padding: 10px 20px 10px 25px;
    font-size: 1.4rem;
  }
  .areaMenu li a span {
    padding-left: 10px;
  }
  .areaMenu li a span::after {
    top: 40%;
    lright: -16px;
    width: 8px;
    height: 8px;
    transform: translateY(-35%) rotate(45deg);
  }
}

/*---courseItemsBox---*/
.crs_item_wrap {
  display: flex;
  justify-content: space-between;
  align-items: end;
  padding: 20px 10px;
  border-bottom: 2px solid #185a85;
}
.crs_t_wrap {
  width: 68%;
}
.crs_id {
  font-size: 2.0rem;
  color: #fff;
  background-color: #005983;
  display: inline-block;
  padding: 1px 10px;
  margin-bottom: 5px;
}
.course__card__title a {
  font-size: 2.4rem;
  color: #323232;
}
.course__card__unit {
  margin-top: 25px;
  font-size: 1.4rem;
  color: #000;
  text-align: right;
}
.course__card__price {
  font-size: 2.5rem;
  font-weight: 700;
  letter-spacing: -0.8px;
  line-height: 1.2;
  color: #cc0d21;
  text-align: right;
}
.noCourseTxt {
  margin: 0 auto;
  font-size: 1.6rem;
}
@media (min-width: 768px) {
  .course__card__title a:hover {
    color: #d02335;
    transition: .25s;
  }
}
@media screen and (max-width:767.98px) {
  .crs_item_wrap {
    padding: 15px 0;
  }
  .crs_id {
    font-size: 1.5rem;
  }
  .course__card__title a {
    font-size: 1.9rem;
  }
  .course__card__unit {
    margin-top: 5px;
    font-size: 1.2rem;
  }
  .course__card__price {
    margin-top: 10px;
    font-size: 1.9rem;
  }
  .noCourseTxt {
    font-size: 1.3rem;
    text-align: center;
  }
  .crs_item_wrap {
    flex-direction: column;
  }
  .crs_t_wrap {
    width: 100%;
  }
}
.noCourse {
  font-size: 2.2rem;
  font-weight: 700;
  text-align: center;
  color: #005983;
  padding: 50px 0;
}
@media screen and (max-width:767.98px) {
  .noCourse {
    font-size: 1.8rem;
    padding: 30px 0;
  }
}
/*=====================*/

/*briefing_sec
=======================*/
.briefing_sec {
  padding: 40px 0 20px;
}
.briefing_sec ul {
  text-align: center;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 20px auto;
}
.briefing_sec ul li {
  width: 19%;
}
.briefing_sec ul li a {
  display: block;
  font-size: 2.0rem;
  font-weight: 700;
  color: #00456a;
  background-color: #fff;
  height: 100%;
  border: 3px solid #00456a;
  border-radius: 10px;
  box-shadow: 0 1px 5px 1px rgba(0, 0, 0, .3);
  padding: 3px 90px 3px 2px;
  position: relative;
}
.briefing_sec ul li a::before {
    position: absolute;
    content: '';
    top: 50%;
    right: 10px;
    transform: translateY(-50%) rotate(45deg);
    width: 15px;
    height: 15px;
    border-top: 3px solid #00456a;
    border-right: 3px solid #00456a;
}
@media (min-width: 768px) {
  .briefing_sec ul {
    max-width: 1160px;
  }
  .briefing_sec ul a:hover {
    color: #00456a;
    background-color: #ddf1fc;
    cursor: pointer;
  }
}
@media screen and (max-width:767.98px) {
  .briefing_sec {
    padding: 20px 0 10px;
  }
  .briefing_sec ul {
    justify-content: center;
    width: 100%;
    margin: 10px auto;
    gap: 5px;
  }
  .briefing_sec ul li {
    width: 31%;
  }
  .briefing_sec ul li a {
    font-size: 1.5rem;
    padding: 3px 30px 3px 0;
    box-shadow: 0 1px 2px 1px rgba(0, 0, 0, .2);
  }
}

/*=====================*/

/*area_button
=======================*/
.area_button{
  text-align: center;
  margin: 40px 0;
  font-family: 游ゴシック体, YuGothic, 游ゴシック, Yu Gothic, ヒラギノ角ゴ Pro, Hiragino Kaku Gothic Pro, メイリオ, Meiryo, Osaka, Arial, ＭＳ Ｐゴシック, MS PGothic, sans-serif;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.6;
  position: relative;
}
.area_button .contents_wrap{
  justify-content: center;
  flex-wrap: wrap;
}
.area_button__titbox__fukidashi{
  position: relative;
  display: inline-block;
  border-bottom: solid 1px #cc0d20;
  padding: 5px 0;
  color: #cc0d20;
  font-weight: bold;
  font-size: 18px;
}
.area_button__titbox__fukidashi:before,
.area_button__titbox__fukidashi:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}
.area_button__titbox__fukidashi:before {
  border: solid 9px transparent;
  border-top: solid 14px #cc0d20;
}
.area_button__titbox__fukidashi:after {
  border: solid 11px transparent;
  border-top: solid 17px #fff;
  margin-top: -5px;
}
.area_button__titbox__tit{
  font-size: 2.4rem;
  color: #333333;
  margin: 15px 5px;
}
.area_button__link{
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  margin: 0 auto;
  max-width: 760px;
}
.area_button__link li{
  width: 100%;
}
.area_button__link li a{
  text-align: center;
  position: relative;
  display: block;
  font-size: 17px;
  font-weight: bold;
  border: 2px solid #cc0d20;
  border-radius: 5px;
  padding: 10px 36px 9px 9px;
  width: 100%;
  color: #333333;
  box-shadow: 0 1px 1px 1px rgb(0 0 0 / 10%);
}
.area_button__link li a:before{
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  height: 100%;
  background: #cc0d21;
  content: "";
  width: 27px;
}
.area_button__link li a:after{
  -webkit-transform: rotate(45deg);
  display: block;
  position: absolute;
  transform: rotate(45deg);
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  content: "";
  top: calc(50% - 4px);
  right: 10px;
  width: 8px;
  height: 8px;
}
@media screen and (min-width:768px) {
  .area_button {
    margin-top: 0;
  }
  .area_button__link li{
    max-width: 138px;
  }
  .area_button__link li a:hover{
    opacity: 0.7;
  }
}
@media screen and (max-width:767.98px) {
  .area_button__link {
    margin: 0 10px 0;
  }
  .area_button__link li a {
    padding: 10px 36px 9px 9px;
    margin-bottom: 5px;
    font-size: 1.8rem;
    font-weight: bold;
  }
}
/*=====================*/


/*asukaIIinfo
=======================*/
.asukaIIinfo {
  background-image: url("/med/feature/domestic/asuka35th/img/snowflake.webp"), linear-gradient(#bfdce7 0%, #ebc1cf);
  background-repeat: repeat-y, no-repeat;
  background-size: 100% auto, cover;
  padding-bottom: 100px;
  position: relative;
  z-index: 0;
  margin-bottom: 30px;
}
.bg_parts_01 {
  position: absolute;
  width: 100%;
  bottom: 99.5%;
}
.bg_parts_02 {
  position: absolute;
  width: 100%;
  top: 99.5%;
}
.asukaIIinfo h3 {
  display: block;
  font-family: "BIZ UDPMincho", serif;
  font-size: 2.2rem;
  text-align: center;
  color: #fff;
  background-color: #185a85;
  padding: 3px 40px;
  margin: 0 0 20px;
  border: 1px solid #185a85;
  border-radius: 50px;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.6);
}
.asukaIIinfo section {
  max-width: 1160px;
  margin: 0 auto;
  padding: 20px 30px;
  border-radius: 10px;
  background-color: #fff;
}
.asukaIIinfo section + section {
  margin-top: 30px;
}
@media screen and (max-width:767.98px) {
  .asukaIIinfo {
    padding-bottom: 50px;
  }
  .asukaIIinfo section {
    padding: 12px 10px 40px;
    margin: 0 10px;
  }
  .asukaIIinfo h3 {
    font-size: 1.6rem;
    padding: 0 10px;
  }
  .bg_parts_02 {
    top: 99.7%;
  }
}
/*=====================*/


/*spotBlock01
=======================*/
@media screen and (max-width:767.98px) {
  .spotBlock01{
    width: 100%;
    margin: 0 auto 30px;
  }
}
/* Dots */
.spotBlock01 .slick-dotted.slick-slider {
  margin: 0;
}
.spot_slider_wrap {
  position: relative;
  width: auto;
  margin: 0 -12px;
}
.spotBlock01 .slick-dots {
  position: absolute;
  bottom: -74px;
  left: 50%;
  transform: translate(-50%, -10%);
  display: flex;
  width: auto;
  padding: 0;
  margin: 0;
  list-style: none;
  text-align: center;
}

.spotBlock01 .slick-dots li {
  position: relative;
  display: inline-block;
  width: 20px;
  height: 20px;
  margin: 0 2px;
  padding: 0;
  cursor: pointer;
}

.spotBlock01 .slick-dots li button {
  line-height: 0;
  display: block;
  width: 20px;
  height: 20px;
  padding: 5px;
  cursor: pointer;
  color: transparent;
  border: 0;
  outline: none;
  background: transparent;
}
.spotBlock01 .slick-dots li button:before {
  font-family: 'slick';
  font-size: 5rem;
  line-height: 0px;
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  /*content: '•';*/
	content: '\2022';
  text-align: center;
  color: #d2d2d5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.spotBlock01 .slick-dots li.slick-active button:before {
  color: #185a85;
}

@media screen and (min-width:768px) {
  .spotBlock01 .slick-dots li button:hover,
  .spotBlock01 .slick-dots li button:focus {
    outline: none;
  }
  .spotBlock01 .slick-dots li button:hover:before,
  .spotBlock01 .slick-dots li button:focus:before {
    opacity: 1;
  }
  .spotBlock01 .slick-dots li button:hover:before {
  color: #ad894b;
  opacity: 0.75;
  transition: .25s;
  }
  .enjoy_sec .dots_box {
    display: none;
  }
}
@media screen and (max-width:767.98px) {
  .spot_slider_wrap {
    width: 100%;
    max-width: 1100px;
  }
}
/*----------------*/

.spotBlock01 .spot_slider_item .slider_txt p{
	font-size: 1.3rem;
	line-height: 1.4;
	color: #272833;
	padding: 0 10px;
}
.spotBlock01 .spot_slider_item .slider_txt p.slider_tit{
	font-size: 1.8rem;
  font-weight: 700;
	color: #185a85;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-content: center;
	text-align: center;
  padding: 25px 0 20px;
}

.spotBlock01 .spot_slider_item .slider_txt p.slider_tit span{
	font-size: 1.4rem;
	line-height: 1;
}
.spot_slider_wrap ul li{
  padding: 0 15px;
}

@media screen and (max-width:767.98px) {
	.spotBlock01 .spot_slider_item{
		max-width: 310px;
	}
	.spot_slider_wrap ul li{
		padding: 0 20px;
	}
	.pointAreaIN{
		padding: 10px;
	}
	.pointAreaIN .spotBlock01{
		padding: 10px 10px 100px;
	}
  /*.spotBlock01 .spot_slider_item .slider_txt {
    max-width: 310px;
  }*/
  .spotBlock01 .spot_slider_item .slider_txt p.slider_tit {
    font-size: 1.7rem;
    padding: 15px 0 10px;
  }
}
/*---arrow---*/
  .spot_slider_wrap {
    position: relative;
		margin: 0;
  }
	.spot_slider_wrap ul li{
		box-sizing: border-box;
	}
  .spot_slider_wrap .slick-arrow {
    bottom: -100px;
    transform: translateY(-50%);
  }
  .spot_slider_wrap .prev-arrow {
	  left: 2px;
  }
  .spot_slider_wrap .next-arrow {
    right:2px;
  }
  /*.spot_slider_wrap .slick-arrow {
    position: absolute; 
    bottom: -100px;
    transform: translateY(-50%);
    cursor: pointer;
    z-index: 3;
  }
  .spot_slider_wrap .prev-arrow {
    left: 2px;
	  background-size: 40px;
	  width: 40px;
	  height: 40px;
  }
  .spot_slider_wrap .next-arrow {
    right:2px;
	  background-size: 40px;
	  width: 40px;
	  height: 40px;
  }
	.spot_slider_wrap .prev-arrow:hover,.spot_slider_wrap .next-arrow:hover {
		opacity: 0.8;
	}*/
@media screen and (min-width:768px) {
  .prev-arrow:hover,.next-arrow:hover {
    opacity: 0.8;
  }
}
@media screen and (max-width:767.98px) {
	.spot_slider_item{
    opacity: .4;
    transition: opacity .5s; 
}

.spot_slider_item.slick-center{
    opacity: 1;
}
}
/*=====================*/


/*-----------------------*/
.guestroom_area{
  margin-top: 40px;
}
.guestroom_area_txt{
  text-align: center;
  margin-bottom: 30px;
}
.dropdown-tab-container {
  position: relative;
  width: 100%;
  max-width: 1160px;
  margin: 0 auto;
}
.dropdown-toggleBox{
  display: flex;
  justify-content: center;
  position: relative;
}
.dropdown-toggle {
  padding: 10px;
  width:600px;
  background-color: #fff;
  border: 2px solid #185a85;
  cursor: pointer;
  position: relative;
  border-radius: 5px;
  box-shadow: 0px 0px 4px #858585;
  z-index: 4;
  text-align: center;
  color: #185a85;
  font-weight: bold;
  font-size: 2.4rem;
}
.dropdown-toggle::after{
  position: absolute;
  content: '';
  top: 50%;
  right: 20px;
  width: 20px;
  height: 20px;
  border-right: 4px solid #185a85;
  border-bottom: 4px solid #185a85;
  transform: translateY(-68%) rotate(45deg);
}
.dropdown-toggle:hover{
  background-color: #e2f3fc;
  box-shadow: none;
}
.dropdown-menu {
  list-style: none;
  padding: 10px 0 0;
  margin: 0;
  border: 1px solid #ccc;
  border-top: none;
  position: absolute;
  width: 600px;
  background-color: white;
  border-radius: 0 0 5px 5px;
  display: none;
  top: calc(100% - 10px);
  left: 50%;
  transform: translateX(-50%) !important;
  z-index: 2;
  text-align: center;
  font-size: 2.0rem;
}

.dropdown-menu.show {
  display: block;
}

.dropdown-menu li {
  padding: 10px;
  cursor: pointer;
  border-bottom: 1px solid #D9D9D9;
}
  .dropdown-menu li:last-child{
    border: none;
  }
.dropdown-menu li:hover {
  background-color: #a9d0e5;
}

.tab-content02 {
  padding: 20px;
  margin-top: 10px;
  display: none; 
}

.tab-content02.active {
  display: block; 
}
.tab-content02 h4{
  margin: 0;
  width: 100%;
  background-color: #185a85;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
  color: #fff;
}
.tab-content02 .tab-content02-inner{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 15px;
  margin: 30px 0 0;
}
.tab-content02 .tab-content02-inner .tab-img_wrap{
  min-width: 480px;
}
.tab-content02 .tab-content02-inner .tab-img_wrap p:nth-of-type(2){
  font-size: 1.4rem;
  line-height: 1.2;
  padding: 5px 0;
}
.tab-content02 .tab-content02-inner-txtbox{
  width: 100%;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  align-content: space-between;
}
.tab-content02 .tab-content02-inner-txtbox h5{
  font-size: 1.6rem;
  color: #185a85;
  text-align: center;
  margin: 0 0 5px;
  vertical-align: middle;
}
.tab-content02 .tab-content02-inner-txtbox h5 span {
  position: relative;
}
.tab-content02 .tab-content02-inner-txtbox h5 span::before,
.tab-content02 .tab-content02-inner-txtbox h5 span::after {
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%);
  width: 15px;
  height: 1px;
  background-color: #185a85;
}
.tab-content02 .tab-content02-inner-txtbox h5 span::before {
  left: -30px;
}
.tab-content02 .tab-content02-inner-txtbox h5 span::after {
  right: -30px;
}
.tab-content02 .tab-content02-inner-txtbox .tab-content02-inner-txt{
  text-align: center;
  font-size: 1.5rem;
  border: 1px solid #cacaca;
  width: 100%;
  padding: 3px 0;
  margin-bottom: 10px;
}
.tab-content02 .tab-content02-inner-txtbox .tablewrap{
  width: 100%;
}
.tab-content02 .tab-content02-inner-txtbox table{
  font-size: 1.6rem;
  color: #272833;
  width: 100%;
  border: 1px solid #cacaca;
  font-weight: bold;
}
.tab-content02 .tab-content02-inner-txtbox table tr + tr {
  border-top: 1px solid #cacaca;
}
.tab-content02 .tab-content02-inner-txtbox table tr td + td {
  border-left: 1px solid #cacaca;
}
.tab-content02 .tab-content02-inner-txtbox table tr td{
  -webkit-box-shadow: none;
  box-shadow: none;
}
.tab-content02 .tab-content02-inner-txtbox table tr td:first-child{
  background: #f0f0f0;
  text-align: center;
  width: 13%;
  border-color:#cacaca;
}
.tab-content02 .tab-content02-inner-txtbox table tr td:last-child{
  padding-left: 5px;
  border-color:#cacaca;
}
.tab-content02 .tab-content02-inner-txtbox .benefit_wrap {
  display: flex;
  width: 100%;
  border: 1px solid #cacaca;
  margin-top: 20px;
}
.tab-content02 .tab-content02-inner-txtbox .benefit_wrap div:nth-of-type(1) {
  background-color: #bead8b;
  display: flex;
  justify-content: center;
  align-items: center;
  border-right: 1px solid #cacaca;
}
.tab-content02 .tab-content02-inner-txtbox .benefit_wrap ul {
  display: flex;
  flex-wrap: wrap;
  background-color: #fff4df;
  height: 100%;
  margin: 0;
  padding: 0 4px;
}
.tab-content02 .tab-content02-inner-txtbox .benefit_wrap ul li {
  /*text-indent: -1em;*/
  padding-left: 1em;
  word-break: break-all;
  position: relative;
}
.tab-content02 .tab-content02-inner-txtbox .benefit_wrap ul li::before {
  position: absolute;
  content: "";
  top: 10px;
  left: 7px;
  width: 7.5px;
  height: 7.5px;
  border-radius: 50%;
  background-color: #bead8b;
}
.guestroom_area_note{
  font-size: 1.4rem;
  margin-top: 40px;
  text-align: center;
  margin: 0 auto;
  line-height: 1.2;
}
@media screen and (min-width: 768px) {
  .tab-content02 .tab-content02-inner-txtbox .benefit_wrap div:nth-of-type(1) {
    min-width: 100px;
  }
}
@media screen and (max-width:767.98px) {
  .tab-content02 {
    padding: 10px 0;
  }
  
  .asukaIIinfo .guestroom_area{
    margin-top: 40px;
    padding: 10px 15px;
}
  .guestroom_area_txt{
    margin-bottom: 30px;
    font-size: 1.3rem;
    padding: 0 10px
  }
  .dropdown-tab-container {
    max-width: 100%;
  }
  .dropdown-toggleBox{
    display: flex;
    justify-content: center;
    position: relative;
    flex-wrap: wrap;
  }
  .dropdown-toggle {
    padding: 10px;
    width:100%;
    max-width: 355px;
    font-size: 1.5rem;
  }
  .dropdown-toggle::after {
    right: 10px;
    width: 10px;
    height: 10px;
    border-right: 3px solid #00456a;
    border-bottom: 3px solid #00456a;
  }
  .dropdown-menu {
    list-style: none;
    padding: 10px 0 0;
    margin: 0;
    width: 100%;
    max-width: 355px;
    background-color: white;
    left: 50%;
    text-align: center;
    font-size: 2.0rem;
  }
  .dropdown-menu li {
    padding: 10px;
    cursor: pointer;
    font-size: 1.5rem;
  }
  .tab-content {
    padding:0 20px;
    margin-top: 10px;
    display: none; 
  }
  .tab-content h4{
    margin: 0;
    padding: 10px;
    width: 100%;
    font-size:1.5rem;
    line-height: 1.0;
  }
  .tab-content02 .tab-content02-inner{
    gap: 15px;
    margin: 10px 0 0;
    flex-wrap: wrap;
  }
  .tab-content02 .tab-content02-inner .tab-img_wrap{
    min-width: 100%;
    max-width: 480px;
    /*display: flex;
    justify-content: center;*/
  }
  .tab-content02 .tab-content02-inner .tab-img_wrap p:nth-of-type(2){
    font-size: 1.3rem;
  }
  .tab-content02 .tab-content02-inner-txtbox{
    width: 100%;
  }
  .tab-content02 .tab-content02-inner-txtbox h5{
    font-size: 1.5rem;
    width: 100%;
  }
  .tab-content02 .tab-content02-inner-txtbox .tab-content02-inner-txt{
    font-size: 1.4rem;
    min-height: auto;
    border: none;
  }
  .tab-content02 .tab-content02-inner-txtbox .tablewrap{
    width: 100%;
  }
  .tab-content02 .tab-content02-inner-txtbox table{
    font-size: 1.3rem;
  }
  .tab-content02 .tab-content02-inner-txtbox table tr td:first-child{
    width: 20%;
  }
  .tab-content02 .tab-content02-inner-txtbox table tr td:last-child{
    padding-left: 5px;
  }
  .guestroom_area_note{
    font-size: 1.3rem;
    text-align: left;
    margin-top: 10px;
    padding: 0 5px; 
  }
  .tab-content02 .tab-content02-inner-txtbox .benefit_wrap {
    flex-direction: column;
  }
  .tab-content02 .tab-content02-inner-txtbox .benefit_wrap div:nth-of-type(1) p {
    color: #fff;
    font-size: 1.3rem;
    padding: 3px 0;
  }
  .tab-content02 .tab-content02-inner-txtbox .benefit_wrap ul li {
    font-size: 1.3rem;
  }
  .tab-content02 .tab-content02-inner-txtbox .benefit_wrap ul li::before {
    top: 7px;
    left: 5px;
    width: 6px;
    height: 6px;
  }
}
/*-----------------------*/



/*dresscode_sec
=======================*/
.asukaIIinfo .dresscode_sec {
  padding: 20px 30px;
}
.dresscode_sec p {
  text-align: center;
}
.dc_itemWrap .slick-dots button {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: #d2d2d5;
  border: none;
  padding: 0;
  font-size: 0;
}
.dc_itemWrap .slick-dots .slick-active button {
  background: #185a85;
}
/*.dresscode_sec .dc_itemWrap {
  display: flex;
  justify-content: space-around;
}*/
.dresscode_sec .dc_itemWrap .dc_item {
  width: 48%;
  border: 1px solid #d3d0d0;
  border-radius: 10px;
  padding: 20px 0;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
}
.dresscode_sec .dc_itemWrap .dc_item img {
  max-width: 200px;
  width: 100%;
  max-height: 345px;
  height: 100%;
  margin-right: 40px;
}
.dresscode_sec .dc_itemWrap .dc_item .dc_t_wrap {
  text-align: center;
  width: 230px;
}
.dresscode_sec .dc_itemWrap .dc_item .dc_t_wrap p {
  color: #185a85;
  font-weight: 700;
}
.dresscode_sec .dc_itemWrap .dc_item .dc_t_wrap ul {
  margin: 0;
  border: 1px solid #d3d0d0;
  font-size: 1.5rem;
}
.dresscode_sec .dc_itemWrap .dc_item .dc_t_wrap ul li:nth-of-type(2n+1) {
  font-weight: 700;
}
.dresscode_sec .dc_itemWrap .dc_item .dc_t_wrap ul li:nth-of-type(1) {
  background-color: #d8eff7;
}
.dresscode_sec .dc_itemWrap .dc_item .dc_t_wrap ul li:nth-of-type(3) {
  background-color: #fbe1e9;
}
.dresscode_sec .dc_itemWrap .dc_item img {
  margin-right: 0;
}
@media screen and (min-width:768px) {
  .dresscode_sec .dc_itemWrap {
    display: flex;
    gap: 24px;
    margin-top: 15px;
  }
}
@media (max-width: 767.98px) {
  .asukaIIinfo .dresscode_sec {
    padding: 12px 10px;
  }
  .asukaIIinfo .dresscode_sec h3 {
     margin: 0 0 10px; 
  }
  .dresscode_sec p {
    font-size: 1.5rem;
    letter-spacing: -0.8px;
    margin-bottom: 15px;
  }
  .dc_itemWrap {
    display: block;
  }
  .dresscode_sec .dc_itemWrap .dc_item {
    flex-direction: column;
    height: 100%;
    width: 90%;
    margin: 0 5px;
    padding: 0;
    gap: 10px;
    border: none;
  }
  .dresscode_sec .dc_itemWrap .dc_item img {
    width: 150px;
    height: auto;
  }
  .dc_t_wrap {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .dresscode_sec .dc_itemWrap .dc_item .dc_t_wrap {
    width: 100%;
  }
  .dresscode_sec .dc_itemWrap .dc_item .dc_t_wrap ul {
    display: grid;
    grid-template-columns: 60px 1fr;
    border: none;
  }
  .dresscode_sec .dc_itemWrap .dc_item .dc_t_wrap ul li {
    border: 1px solid #d3d0d0;
    text-align: left;
    line-height: 1.4;
  }
  .dresscode_sec .dc_itemWrap .dc_item .dc_t_wrap ul li:nth-child(2n+1) {
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .dresscode_sec .dc_itemWrap .dc_item .dc_t_wrap ul li:nth-child(2n) {
    border-left: none;
    padding: 3px 0 3px 5px;
  }
  .dresscode_sec .dc_itemWrap .dc_item .dc_t_wrap ul li:nth-last-child(-n+2) {
    border-bottom: 1px solid #d3d0d0;
  }

  .dresscode_sec .dc_itemWrap .dc_item .dc_t_wrap ul li:not(:nth-last-child(-n+2)) {
    border-bottom: none;
  }
  .dresscode_sec .dc_itemWrap .dc_item .dc_t_wrap p {
    font-size: 1.7rem;
    margin-bottom: 5px;
  }
  .slick-slide {
  height: auto;
  }
}
/* slick dots カスタム */
.dc_itemWrap .slick-dots {
  display: flex;
  justify-content: center;
  gap: 12px;
  margin-top: 20px;
}

.dc_itemWrap .slick-dots li {
  width: auto;
  height: auto;
  margin: 0;
}
/* 矢印ボタン共通 */
.slide-arrow {
  width: 45px;
  height: 45px;
  background: #185a85;
  border-radius: 50%;
  position: absolute;
  bottom: -40px;
  transform: translateY(-50%);
  cursor: pointer;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* 左 */
.prev-arrow {
  left: -18px;
}

/* 右 */
.next-arrow {
  right: -18px;
}

/* 矢印アイコン */
.slide-arrow::before {
  content: "";
  position: absolute;
  width: 18px;
  height: 18px;
  border-top: 4px solid #fff;
  border-left: 4px solid #fff;
  top: 50%;
  left: 50%;
  transform: translate(-45%, -50%) rotate(-45deg);
}

/* 右矢印向き変更 */
.next-arrow::before {
  transform: translate(-65%, -50%) rotate(135deg);
}
@media (max-width: 767.98px) {
  .slide-arrow {
    width: 35px;
    height: 35px;
    bottom: -25px;
  }
  .slide-arrow::before {
    width: 14px;
    height: 14px;
    border-top: 3px solid #fff;
    border-left: 3px solid #fff;
  }
  .spot_slider_wrap .slick-arrow {
    bottom: -75px;
  }
  .spotBlock01 .slick-dots {
    bottom: -55px;
  }
  .prev-arrow {
  left: 10px;
  }
  .next-arrow {
    right: 10px;
  }
}
/*=====================*/

/*goodnews_sec
=======================*/
.goodnews_sec .early_campaign {
  border: 1px solid #bead8b;
  background-color: #fff4df;
}
.goodnews_sec .early_campaign .early_tit {
  background-color: #bead8b;
  text-align: center;
  padding: 15px 0;
}
.early_date_wrap {
  padding: 20px 0;
  max-width: 1060px;
  margin: 0 auto;
}
.early_date_wrap + .early_date_wrap {
  padding: 0 0 20px;
}
.goodnews_sec .early_campaign .early_date {
  display: flex;
  gap: 10px;
}
.goodnews_sec .early_campaign .early_date p {
  line-height: 1.0;
}
.goodnews_sec .early_campaign .early_date p:nth-child(1) {
  font-size: 1.5rem;
  font-weight: 700;
  color: #fff;
  padding: 5px 10px;
  border-radius: 5px 5px 0 0;
}
.goodnews_sec .early_campaign .early_date p:nth-child(2) {
  font-size: 1.8rem;
}
.goodnews_sec .early_campaign .early_date .e_red {
  color: #d02335;
  font-size: 2.0rem;
  font-weight: 700;
}
.goodnews_sec .early_campaign .early_date .e_large {
  font-size: 2.5rem;
}
.goodnews_sec .early_campaign .early_box {
  display: flex;
  align-items: stretch;
  margin: 10px 0;
}
.goodnews_sec .early_campaign .early_box p {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100%;
}
.goodnews_sec .early_campaign .early_box p:nth-child(1) {
  font-size: 2.0rem;
  font-weight: 700;
  color: #fff;
  width: 66%;
}
.goodnews_sec .early_campaign .early_box p:nth-child(2) {
  font-size: 3.0rem;
  font-weight: 700;
  color: #d02335;
  background-color: #fff;
  white-space: nowrap;
  width: 34%;
}
.goodnews_sec .early_campaign .early_box p:nth-child(2) span {
  font-size: 3.8rem;
}
.goodnews_sec .early_campaign .date01 .early_date {
  border-bottom: 2px solid #185a85;
}
.goodnews_sec .early_campaign .date01 .early_date p:nth-child(1),
.goodnews_sec .early_campaign .date01 .early_box p:nth-child(1) {
  background-color: #185a85;
}
.goodnews_sec .early_campaign .date01 .early_date p:nth-child(2) {
  color: #185a85;
}
.goodnews_sec .early_campaign .date01 .early_box {
  border: 1px solid #185a85;
}

.goodnews_sec .early_campaign .date02 .early_date {
  border-bottom: 2px solid #8e4f70;
}
.goodnews_sec .early_campaign .date02 .early_date p:nth-child(1),
.goodnews_sec .early_campaign .date02 .early_box p:nth-child(1) {
  background-color: #8e4f70;
}
.goodnews_sec .early_campaign .date02 .early_date p:nth-child(2) {
  color: #8e4f70;
}
.goodnews_sec .early_campaign .date02 .early_box {
  border: 1px solid #8e4f70;
}
@media (max-width: 767.98px) {
  .goodnews_sec .early_campaign .early_tit img {
    width: 255px;
  }
  .goodnews_sec .early_campaign .early_date {
    gap: 4px;
  }
  .goodnews_sec .early_campaign .early_date p:nth-child(1) {
    padding: 5px;
    white-space: nowrap;
  }
  .goodnews_sec .early_campaign .early_date p:nth-child(2) {
    font-size: 1.8rem;
    letter-spacing: -1.2px;
  }
  .goodnews_sec .early_campaign .early_date .e_large {
    font-size: 2.0rem;
  }
  .goodnews_sec .early_campaign .early_box {
    flex-direction: column;
    align-items: baseline;
  }
  .goodnews_sec .early_campaign .early_box p:nth-child(1) {
    width: 100%;
    font-size: 1.4rem;
    text-align: center;
    line-height: 1.2;
    padding: 8px 0;
  }
  .goodnews_sec .early_campaign .early_box p:nth-child(2) {
    width: 100%;
    font-size: 2.5rem;
    line-height: 1.4;
  }
  .goodnews_sec .early_campaign .early_box p:nth-child(2) span {
    font-size: 3.0rem;
  }
}
@media (max-width: 370px) {
  .goodnews_sec .early_campaign .early_date p:nth-child(1) {
    font-size: 1.4rem;
  }
  .goodnews_sec .early_campaign .early_date p:nth-child(2) {
    font-size: 1.5rem;
  }
  .goodnews_sec .early_campaign .early_date .e_red {
    font-size: 1.5rem;
  }
  .goodnews_sec .early_campaign .early_date .e_large {
    font-size: 1.7rem;
  }
}

.goodnews_sec .gn_itemwrap {
  display: flex;
  justify-content: space-between;
  margin-top: 20px!important;
}
.goodnews_sec .gn_itemwrap .gn_item {
  width: 265px;
  border: 1px solid #bead8b;
}
.goodnews_sec .gn_itemwrap p {;
  font-size: 1.3rem;
  padding: 10px 5px;
}
.goodnews_sec .gn_itemwrap .gn_tit {
  font-size: 1.9rem;
  font-weight: 700;
  text-align: center;
  background-color: #ede9e0;
  border-bottom: 1px solid #bead8b;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 10px 0;
}
@media (max-width: 767.98px) {
  .goodnews_sec .gn_item {
    /*margin: 0 10px;*/
    display: block;
  }
  .goodnews_sec .gn_itemwrap .slide-arrow {
    bottom: -75px;
  }
  .early_date_wrap {
    padding: 10px;
  }
  .early_date_wrap + .early_date_wrap {
    padding: 0 10px 10px;
  }
}
/*=====================*/

/*route_sec
=======================*/
.route_sec .route_flex {
  display: flex;
  justify-content: space-between;
  max-width: 1100px;
  margin: 0 auto;
}
.route_sec .route_flex h5 {
  font-size: 1.8rem;
  color: #005d8c;
  text-align: center;
  margin: 0 0 10px;
  vertical-align: middle;
}
.route_sec .route_flex h5 span {
  position: relative;
}
.route_sec .route_flex h5 span::before,
.route_sec .route_flex h5 span::after {
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%);
  width: 15px;
  height: 1px;
  background-color: #005d8c;
}
.route_sec .route_flex h5 span::before {
  left: -30px;
}
.route_sec .route_flex h5 span::after {
  right: -30px;
}
.route_sec .route_flex .info_wrap table {
  border: 1px solid #005d8c;
  width: 100%;
  height: 234px;
}
.route_sec .route_flex .info_wrap table tr + tr {
  border-top: 1px solid #005d8c;
}
.route_sec .route_flex .info_wrap table tr th {
  width: 100px;
  border-right: 1px solid #005d8c;
  color: #fff;
  background-color: #337da3;
}
.route_sec .route_flex .info_wrap table tr td {
  font-weight: 700;
  padding-left: 10px;
  background-color: #fff;
}
@media screen and (min-width:768px) {
  .route_sec .route_flex .route_wrap {
    width: 42%;
  }
  .route_sec .route_flex .route_wrap img {
    width: 452px;
  }
  .route_sec .route_flex .info_wrap {
    width: 600px;
  }
}
@media screen and (max-width:767.98px) {
  .asukaIIinfo .route_sec {
    padding: 10px;
  }
  .route_sec h3 {
    margin: 0 0 10px;
  }
  .route_sec .route_flex {
    flex-direction: column;
  }
  .route_sec .route_flex h5 {
    margin: 5px 0;
    font-size: 1.7rem;
  }
  .route_sec .route_flex .route_wrap {
    text-align: center;
  }
  .route_sec .route_flex .info_wrap {
    margin-top: 10px;
  }
  .route_sec .route_flex .info_wrap table {
    height: 210px;
  }
  .route_sec .route_flex .info_wrap table tr th {
    font-size: 1.2rem;
  }
  .route_sec .route_flex .info_wrap table tr td {
    font-size: 1.4rem;
  }
}
/*=====================*/

/*pageTopBtn
=======================*/
.pageTopBtn {
  display: inline-block;
  width: 52px;
  /*left: calc(100vw - 5em);*/
  left: 93%;
  position: sticky;
  bottom: 30px;
  text-align: right;
  opacity: 0;
  z-index: 10;
}
.pageTopBtn_inner {
  margin: auto;
}
.pageTopBtn a {
  box-sizing: border-box;
  display: block;
  position: relative;
  width: 52px;
  height: 52px;
  background: #cbb480;
  border-radius: 50%;
  box-shadow: 0 3px 10px rgb(0 0 0 / 16%);
  cursor: default;
}
.pageTopBtn a:before {
  content: "";
  position: absolute;
  z-index: 10;
  top: 55%;
  left: 50%;
  width: 20px;
  height: 20px;
  border-style: solid;
  border-color: #fff;
  border-width: 2px 0 0 2px;
  transform: translate(-50%, -50%) rotate(45deg);
  transition: border-color ease 0.1s;
}
.pageTopBtn.-show {
  opacity: 1;
}
.pageTopBtn.-show a {
  cursor: pointer;
}
.pageTopBtn.-transition500 {
  transition: .2s ease;
}

@media screen and (min-width:768px) {
  .pageTopBtn a:hover {
    opacity: 0.65;
    transition: .25s;
  }
}

@media screen and (max-width:767.98px) {
  .pageTopBtn a {
    width: 45px;
    height: 45px;
  }
  .pageTopBtn a:before {
    width: 16px;
    height: 16px;
  }
}
/*=====================*/


.scroll-hint-icon{
  z-index: 5;
}