@charset "UTF-8";
/* media query */
/* SP縦から */
/* SP横から */
/* タブレット縦から */
/* フルワイド */
@import url(https://fonts.googleapis.com/earlyaccess/notosansjapanese.css);
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;700&display=swap");
header {
  position: relative;
  background: none !important; }
  header .area_nav .block_logo .logo {
    opacity: 0; }


.is-fixed {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 101;
  width: 100%;
  background: linear-gradient(rgba(255, 255, 255, 0.9) 0%, rgba(255, 255, 255, 0.7) 50%, rgba(255, 255, 255, 0.6) 70%, rgba(255, 255, 255, 0) 100%) !important; }
  .is-fixed .area_nav .block_logo .logo {
    opacity: 1; }
  .is-fixed .area_nav .block_logo .logo .desvg path {
    fill: #191970; }
  .is-fixed .area_nav .block_logo .english {
    border: 1px solid #191970;
    color: #191970; }
    .is-fixed .area_nav .block_logo .english:after {
      background: url() no-repeat center bottom/100% auto; }

header .area_nav .block_logo .logo .desvg path {
  fill: #fff; }

header .area_nav .block_logo .english {
  border: 1px solid #fff;
  color: #fff; }
  header .area_nav .block_logo .english:after {
    background: url() no-repeat center bottom/100% auto; }

.area_title {
  font-family: 游明朝, "Yu Mincho", YuMincho,'Noto Serif JP', "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  position: relative;
  margin: 0 auto 20px auto; }
  .area_title.flex {
    display: flex; }
    .area_title.flex  p {
      margin-left: 30px; }
      @media all and (max-width: 480px) {
        .area_title.flex p {
          margin-left: 10px; } }
  .area_title h2 {
    color: #191970;
    font-size: 6rem;
    line-height: 1em;
    font-family: 'Cormorant Garamond', serif; }
    @media all and (max-width: 480px) {
      .area_title h2 {
        font-size: 3rem; } }
  .area_title p {
    display: flex;
    align-items: center; }
  .area_title .more_btn {
    display: block;
    width: 140px;
    text-align: center;
    padding: 5px 10px 5px 0px;
    box-sizing: border-box;
    position: absolute;
    right: 0;
    top: 15px;
    border: 1px solid #303030; }
    @media all and (max-width: 480px) {
      .area_title .more_btn {
        width: 100px;
        top: 0;
        font-size: 1.3rem; } }

.area_info {
  background: #F85353;
  padding: 10px;
  box-sizing: border-box;
  text-align: center;
  color: #fff;
  position: relative;
  z-index: 2; }
  @media all and (max-width: 480px) {
    .area_info {
      text-align: left; } }
  .area_info dl {
    display: flex;
    justify-content: center; }
    @media all and (max-width: 480px) {
      .area_info dl {
        flex-wrap: wrap; } }
    .area_info dl dt {
      width: 200px;
      display: flex;
      justify-content: center; }
      @media all and (max-width: 480px) {
        .area_info dl dt {
          width: 100%;
          font-size: 1.4rem; } }
      .area_info dl dt span {
        background: #fff;
        padding: 0px 10px;
        box-sizing: border-box;
        font-size: 1.2rem;
        color: #F85353;
        margin: 0 0 0 10px;
        display: inline-block;
        width: 80px;
        text-align: center;
        height: 23px;
        position: relative;
        top: -1px; }
    .area_info dl dd {
      margin-left: 10px;
      text-align: left; }
      @media all and (max-width: 480px) {
        .area_info dl dd {
          margin: 0; } }
      .area_info dl dd a {
        color: #fff; }
        @media all and (max-width: 480px) {
          .area_info dl dd a {
            font-size: 1.2rem;
            line-height: 1.3em; } }

.main {
  position: relative;

  padding: 0;
   z-index: 101;
  top: -60px; }
  .main .area_main {
    height: 100vh; }
    @media all and (max-width: 896px) {
      .main .area_main {
        height: 85vh; } }
    .main .area_main #video_background,
    .main .area_main #video_overlay {
      position: absolute;
      top: 0;
      left: 0;
      min-width: 100%;
      min-height: 100%;
      width: auto;
      height: auto; }
    .main .area_main #video_background {
      z-index: 1;
      /*display: none;*/ }
    .main .area_main #video_overlay {
      z-index: 1; }

.box_ttl {
	box-sizing: border-box;
	text-align: center;
	position: absolute;
	width: 100%;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -30%);
	z-index: 100;
	padding: 0 10px;
}
  @media all and (max-width: 480px) {
    .box_ttl {
      transform: translate(-50%, -80%); } }

.ttl_logo {
  width: 110px;
  margin: 0 auto 15px; }
  @media all and (max-width: 896px) {
    .ttl_logo {
      width: 90px; } }
  @media all and (max-width: 480px) {
    .ttl_logo {
      width: 80px; } }
  .ttl_logo img {
    width: 100%;
    height: auto;
    filter: drop-shadow(0px 0px 12px rgba(117, 83, 150, 0.9)); }

.ttl_top_Eng {
  text-align: center;
  color: #fff;
  font-weight: bold;
  font-style: italic;
  font-family: "Script";
  font-size: 5rem;
  line-height: 1.3em;
  -moz-text-shadow: 0px 0px 12px rgba(19, 19, 70, 0.9);
  -webkit-text-shadow: 0px 0px 12px rgba(19, 19, 70, 0.9);
  -ms-text-shadow: 0px 0px 12px rgba(19, 19, 70, 0.9);
  text-shadow: 0px 0px 12px rgba(19, 19, 70, 0.9); 

}
.ttl_top {
  text-align: center;
  color: #fff;
  font-weight: bold;
  font-family: 游明朝, "Yu Mincho", YuMincho,'Noto Serif JP', "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
  font-size: 5rem;
  line-height: 1.3em;
  -moz-text-shadow: 0px 0px 12px rgba(19, 19, 70, 0.9);
  -webkit-text-shadow: 0px 0px 12px rgba(19, 19, 70, 0.9);
  -ms-text-shadow: 0px 0px 12px rgba(19, 19, 70, 0.9);
  text-shadow: 0px 0px 12px rgba(19, 19, 70, 0.9); }
  @media all and (max-width: 896px) {
    .ttl_top {
      font-size: 3.0rem; } }
  @media all and (max-width: 480px) {
    .ttl_top {
      font-size: 2.4rem; } }
  .ttl_top span {
    font-size: 0.6em; }

.scrolldown {
  position: absolute;
  right: 35px;
  bottom: 10px;
  height: 80px;
  z-index: 10;
  color: #000; }
  @media all and (max-width: 480px) {
    .scrolldown {
      right: 20px; } }
  .scrolldown span {
    position: absolute;
    top: -55px;
    left: 50%;
    transform: translate(-50%, 0) rotate(90deg);
    font-size: 1.4rem; }
    @media all and (max-width: 480px) {
      .scrolldown span {
        font-size: 1rem;
        top: -45px; } }
  .scrolldown::after {
    content: "";
    position: absolute;
    top: 0;
    width: 1px;
    height: 50px;
    background: #000;
    animation: pathmove 1.4s ease-in-out infinite;
    opacity: 0; }

@keyframes pathmove {
  0% {
    height: 0;
    top: 0;
    opacity: 0; }
  30% {
    height: 50px;
    opacity: 1; }
  100% {
    height: 0;
    top: 50px;
    opacity: 0; } }
.news {
  margin-top: 150px; }
  @media all and (max-width: 896px) {
    .news {
      margin-top: 50px; } }
  .news .area_news {
    display: flex;
    justify-content: space-between; }
    @media all and (max-width: 896px) {
      .news .area_news {
        display: block; } }
    .news .area_news .news_box {
      width: calc(50% - 20px); }
      @media all and (max-width: 896px) {
        .news .area_news .news_box {
          width: 100%; } }
    .news .area_news .diary_box {
      width: calc(50% - 30px); }
      @media all and (max-width: 896px) {
        .news .area_news .diary_box {
          width: 100%;
          margin-top: 40px;
          padding-top: 30px;
          border-top: 1px solid #cbcbcb; } }
      .news .area_news .diary_box .area_title h2 {
        font-size: 4.62rem; }
        @media all and (max-width: 480px) {
          .news .area_news .diary_box .area_title h2 {
            font-size: 2.7rem; } }
      .news .area_news .diary_box .area_title p {
        text-align: center;
        justify-content: center;
        max-width: 50%; }
      .news .area_news .diary_box .panel_diary {
        position: relative; }
        .news .area_news .diary_box .panel_diary ul li {
          margin-top: 20px; }
          .news .area_news .diary_box .panel_diary ul li.new .data:after {
            content: "NEW";
            display: inline-block;
            width: 140px;
            color: #fff;
            text-align: center;
            box-sizing: border-box;
            font-size: 1.3rem;
            margin-left: 5px;
            background: #F85353; }
          .news .area_news .diary_box .panel_diary ul li .data {
            display: flex;
            color: #ccc;
            font-size: 1.4rem; }
            .news .area_news .diary_box .panel_diary ul li .data span {
              background: #fff;
              display: inline-block;
              width: 240px;
              text-align: center;
              box-sizing: border-box;
              font-size: 1.3rem;
              margin-left: 15px;
              letter-spacing: 0px;
              color: #FF5558;
              border: 1px solid #FF5558; }
              .news .area_news .diary_box .panel_diary ul li .data span.tab06 {
                color: #6D6F29 !important;
                border: 1px solid #88FF88  !important; }
              .news .area_news .diary_box .panel_diary ul li .data span.tab07 {
                color: #555 !important;
                border: 1px solid #0000FF  !important; }
              .news .area_news .diary_box .panel_diary ul li .data span.tab08 {
                color: #555 !important;
                border: 1px solid #FF0000  !important; }

          .news .area_news .diary_box .panel_diary ul li a {
            display: block;
            margin-top: 10px;
            font-size: 1.4rem;
            font-weight: bold; }
          .news .area_news .diary_box .panel_diary ul li .img {
            max-width: 400px;
            margin-top: 20px; }
            @media all and (max-width: 480px) {
              .news .area_news .diary_box .panel_diary ul li .img {
                max-width: 100%; } }
            .news .area_news .diary_box .panel_diary ul li .img img {
              border-radius: 5px; }
        .news .area_news .diary_box .panel_diary .img2 {
          position: relative;
          width: 100%;
          height: 130px;
          overflow: hidden;
          margin-top: 30px; }
          .news .area_news .diary_box .panel_diary .img2 a {
            height: 100%;
            width: 100%;
            position: absolute;
            top: 0;
            right: 0;
            display: flex;
            justify-content: center;
            align-items: center; }
            .news .area_news .diary_box .panel_diary .img2 a:before {
              content: "";
              background: transparent linear-gradient(65deg, #A792BC 0%, #8BB3DF 100%) 0% 0% no-repeat padding-box;
              opacity: 0.8;
              display: block;
              width: 100%;
              height: 100%;
              position: absolute;
              top: 0px;
              right: 0px;
              z-index: 1; }
            .news .area_news .diary_box .panel_diary .img2 a:hover {
              opacity: 1; }
            .news .area_news .diary_box .panel_diary .img2 a img {
              position: absolute;
              width: 100%;
              height: auto;
              top: 0;
              right: 0;
              bottom: 0;
              left: 0;
              margin: auto; }
            .news .area_news .diary_box .panel_diary .img2 a p {
              position: relative;
              z-index: 1;
              text-align: center;
              color: #fff;
              line-height: 1.4em;
              font-size: 1.8rem;
              margin-top: 8px;
              letter-spacing: 1px;
              width: 80%;
              display: flex;
              justify-content: center;
              align-items: center; }
              @media all and (max-width: 480px) {
                .news .area_news .diary_box .panel_diary .img2 a p {
                  font-size: 1.5rem; } }
              .news .area_news .diary_box .panel_diary .img2 a p:before, .news .area_news .diary_box .panel_diary .img2 a p:after {
                position: absolute;
                top: 50%;
                right: 22px;
                height: 1px;
                background: #fff;
                content: ''; }
              .news .area_news .diary_box .panel_diary .img2 a p:before {
                width: 30px;
                transform: translateY(-50%); }
              .news .area_news .diary_box .panel_diary .img2 a p:after {
                width: 8px;
                transform: translateY(-50%) rotate(45deg);
                transform-origin: right center; }
  .news .box_tab {
    display: flex;
    justify-content: center;
    flex-wrap: wrap; }
    .news .box_tab li {
      width: calc(100% / 3);
      text-align: center;
      cursor: pointer;
      display: flex;
      justify-content: center;
      align-items: center;
      background: #F7F7F7;
      color: #000;
      border: 1px solid #fff;
      padding: 15px;
      box-sizing: border-box;
      line-height: 1.4em; }
      @media all and (max-width: 896px) {
        .news .box_tab li {
          font-size: 1.2rem;
          padding: 10px 5px; } }
      @media all and (max-width: 480px) {
        .news .box_tab li {
          width: 33.333%;
          letter-spacing: 0px; } }
      .news .box_tab li:hover {
        color: #fff !important;
        transition: 0.3s; }
      .news .box_tab li.select {
        color: #fff !important; }
    .news .box_tab #tab1.select {
      background: #191970; }
    .news .box_tab #tab1:hover {
      background: #191970; }
    .news .box_tab #tab2.select {
      background: #1C59AB; }
    .news .box_tab #tab2:hover {
      background: #1C59AB; }
    .news .box_tab #tab3.select {
      background: #FF5558; }
    .news .box_tab #tab3:hover {
      background: #FF5558; }
    .news .box_tab #tab4.select {
      background: #FF8836; }
    .news .box_tab #tab4:hover {
      background: #FF8836; }
    .news .box_tab #tab5.select {
      background: #1E7A23; }
    .news .box_tab #tab5:hover {
      background: #1E7A23; }
    .news .box_tab #tab6.select {
      background: #555; }
    .news .box_tab #tab6:hover {
      background: #555; }
    .news .box_tab #tab7.select {
      background: #555; }
    .news .box_tab #tab7:hover {
      background: #555; }

.panel {
  position: relative; }
  .panel.hide {
    display: none; }
  .panel .inner_tab ul {
    padding-top: 20px; }
    .panel .inner_tab ul li {
      margin-top: 20px; }
      .panel .inner_tab ul li.new .data:after {
        content: "NEW";
        display: inline-block;
        width: 140px;
        color: #fff;
        text-align: center;
        box-sizing: border-box;
        font-size: 1.3rem;
        margin-left: 5px;
        background: #F85353; }
      .panel .inner_tab ul li .data {
        display: flex;
        color: #ccc;
        font-size: 1.4rem; }
        .panel .inner_tab ul li .data span {
          background: #fff;
          display: inline-block;
          width: 140px;
          text-align: center;
          box-sizing: border-box;
          font-size: 1.3rem;
          margin-left: 15px;
          letter-spacing: 0px; }
          .panel .inner_tab ul li .data span.tab01 {
            color: #191970;
            border: 1px solid #191970; }
          .panel .inner_tab ul li .data span.tab02 {
            color: #1C59AB;
            border: 1px solid #1C59AB; }
          .panel .inner_tab ul li .data span.tab03 {
            color: #FF5558;
            border: 1px solid #FF5558; }
          .panel .inner_tab ul li .data span.tab04 {
            color: #FF8836;
            border: 1px solid #FF8836; }
          .panel .inner_tab ul li .data span.tab05 {
            color: #1E7A23;
            border: 1px solid #1E7A23; }
          .panel .inner_tab ul li .data span.tab06 {
            color: #6D6F29;
            border: 1px solid #6D6F29; }
          .panel .inner_tab ul li .data span.tab07 {
            color: #555555;
            border: 1px solid #555555; }
      .panel .inner_tab ul li a {
        display: block;
        margin-top: 10px;
        font-size: 1.4rem;
        font-weight: bold; }

.topics {
  margin-top: 150px; }
  @media all and (max-width: 480px) {
    .topics {
      margin-top: 50px; } }
  .topics .area_topics ul {
    padding-top: 20px;
    display: flex;
    flex-wrap: wrap; }
    .topics .area_topics ul li {
      position: relative;
      width: 25%;
      overflow: hidden; }
      @media all and (max-width: 896px) {
        .topics .area_topics ul li {
          width: 50%; } }
      .topics .area_topics ul li:before {
        content: "";
        display: block;
        padding-top: 100%; }
      .topics .area_topics ul li a:hover {
        opacity: 1; }
      .topics .area_topics ul li:hover img {
        transform: scale(1.1);
        transition: 0.3s; }
      .topics .area_topics ul li.new .data:before {
        content: "NEW";
        padding: 3px 15px;
        color: #fff;
        text-align: center;
        box-sizing: border-box;
        font-size: 1.3rem;
        background: #fff;
        margin-left: -1px;
        margin-right: 5px;
        border-radius: 50px; 








        background: #F85353; }
      .topics .area_topics ul li img {
        position: absolute;
        width: 100%;
        height: 100%;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        margin: auto; }
      .topics .area_topics ul li .block_txt {
        position: absolute;
        bottom: 0;
        right: 0;
        background: transparent linear-gradient(180deg, #19197000 0%, #191970 100%) 0% 0% no-repeat padding-box;
        color: #fff;
        padding: 10px;
        width: 100%;
        box-sizing: border-box; }
        .topics .area_topics ul li .block_txt .data {
          font-size: 1.4rem; }
          .topics .area_topics ul li .block_txt .data span {
            display: inline-block;
            padding: 0 10px;
            text-align: center;
            box-sizing: border-box;
            font-size: 1.3rem;
            margin-left: 15px;
            letter-spacing: 0px;
            color: #fff;
            border: 1px solid #fff; }
            @media all and (max-width: 480px) {
              .topics .area_topics ul li .block_txt .data span {
                display: block;
                margin: 3px 0 0 0; } }
        .topics .area_topics ul li .block_txt .label {
          margin-top: 5px; }
          .topics .area_topics ul li .block_txt .label span {
            background: #fff;
            color: #191970;
            text-align: center;
            box-sizing: border-box;
            font-size: 1.3rem;
            letter-spacing: 0px;
            padding: 3px 15px;
            border: 1px solid #191970; }
        .topics .area_topics ul li .block_txt .txt {
          margin-top: 10px;
          font-size: 1.4rem; }
          @media all and (max-width: 480px) {
            .topics .area_topics ul li .block_txt .txt {
              font-size: 1rem;
              line-height: 1.4em;
              margin-top: 5px; } }

.features {
  margin-top: 150px;
  padding: 100px 0;
  position: relative;
  z-index: 2; }
  @media all and (max-width: 480px) {
    .features {
      margin-top: 50px;
      padding: 50px 0; } }
  .features:before {
    content: "";
    background: #F7F7F7;
    display: block;
    width: 100%;
    height: 50%;
    position: absolute;
    top: 0;
    right: 0; }
  .features .area_features {
    width: 55vw;
    margin: 0 0 0 auto;
    position: relative;
    z-index: 3; }
    @media all and (max-width: 896px) {
      .features .area_features {
        width: calc(100% - 30px);
        margin: 0 auto; } }
    .features .area_features ul {
      display: flex;
      flex-wrap: wrap;
      justify-content: center;
      margin: 30px 5vw 0 -15vw; }
      @media all and (max-width: 896px) {
        .features .area_features ul {
          margin: 30px; } }
      @media all and (max-width: 480px) {
        .features .area_features ul {
          margin: 20px 0 0 0; } }
      .features .area_features ul li {
        position: relative;
        width: calc(25% - 10px);
        overflow: hidden;
        margin: 5px;
  border-radius: 50%/20%; }








        @media all and (max-width: 896px) {
          .features .area_features ul li {
            width: calc(33.333% - 10px); } }
        @media all and (max-width: 480px) {
          .features .area_features ul li {
            width: calc(50% - 10px); } }
        .features .area_features ul li:before {
          content: "";
          display: block;
          padding-top: 100%; }
        .features .area_features ul li:hover img {
          transform: scale(1.1);
          transition: 0.3s; }
        .features .area_features ul li a {
          height: 100%;
          width: 100%;
          position: absolute;
          top: 0;
          right: 0;
          display: flex;
          justify-content: center;
          align-items: center;
 border-radius: 50%/20%; }






          .features .area_features ul li a:before {
            content: "";
            background: transparent linear-gradient(65deg, #A792BC 0%, #8BB3DF 100%) 0% 0% no-repeat padding-box;

/* 変更後案2: 紺色ベースのグラデーションにしたい場合 */
/*   background: linear-gradient(65deg, rgba(25, 25, 112, 0.6) 0%, rgba(60, 60, 140, 0.9) 100%); */
            opacity: 0.8;
            display: block;
    width: calc(100% - 20px);
    height: calc(100% - 20px);
            position: absolute;
            top: 10px;
            right: 10px;
            z-index: 1;
    border-radius: 50%/20%; }

/* 1. 枠線の設定（画像の端に合わせて大きく表示） */
.features .area_features ul li a:before {
  content: "";
          opacity: 0.8;
  /* 枠線の色：紺色(#191970)ベース、太さ5px */
  border: 5px solid rgba(25, 25, 112, 0.5) !important;
 /* background: transparent   背景の塗りつぶしなし */
  background: linear-gradient(65deg, rgba(25, 25, 112, 0.7) 0%, rgba(60, 60, 140, 0) 100%);
  /* サイズと位置：画像ピッタリのサイズ（100%）にする */
  width: 100% !important;
  height: 100% !important;
  top: 0 !important;
  left: 0 !important;
  
  /* その他の必須設定 */
  display: block;
  position: absolute;
  z-index: 2;
  box-sizing: border-box; /* 枠線をサイズ内に含める */
  border-radius: 50%/20%; /* 楕円形にする */
  pointer-events: none;
}


          .features .area_features ul li a:hover {
            opacity: 1; }
          .features .area_features ul li a img {
            position: absolute;
            width: 100%;
            height: 100%;
            top: 0;
            right: 0;
            bottom: 0;
            left: 0;
            margin: auto; }
          .features .area_features ul li a p {
            position: relative;
            z-index: 1;
            text-align: center;
            color: #fff;
            line-height: 1.4em;
            font-size: 1.8rem;
            margin-top: 8px;
            letter-spacing: 1px; }



            @media all and (max-width: 480px) {
              .features .area_features ul li a p {
                font-size: 1.5rem; } }


.features .area_features ul li a p {
  /* 配置：下部に固定 */
  position: absolute;
  bottom: 20px;       /* 下からの距離（お好みで調整してください） */
  left: 0;
  width: 100%;        /* 横幅いっぱい */
  margin: 0;
  
  /* 色の設定 */
  background: rgba(25, 25, 112, 0.9); /* 背景：濃い紺色 */
  color: #fff;                        /* 文字：白 */
  
  /* 見た目の調整 */
  padding: 10px 0;
  text-align: center;
  z-index: 5;
  
  /* フォント設定（元のまま） */
  line-height: 1.4em;
  font-size: 1.8rem;
  letter-spacing: 1px;
}

/* スマホ表示時の文字サイズ調整（既存コードの確認用） */
@media all and (max-width: 480px) {
  .features .area_features ul li a p {
    font-size: 1.5rem;
    bottom: 15px; /* スマホでは位置を少し下げるなどの微調整も可能 */
  }
}
/* --- Featuresセクションここまで --- */











@keyframes image-gallery-slides {
  0% {
    transform: translateX(100px); }
  100% {
    transform: translateX(-10px); } }
  .features .bg_slider {
    position: absolute;
    top: 0;
    left: 0;
    width: 40vw;
    height: 100%; }
    @media all and (max-width: 896px) {
      .features .bg_slider {
        display: none; } }
    .features .bg_slider:before {
      content: "";
      display: block;
      position: absolute;
      top: 0;
      left: 0;
      background: rgba(255, 255, 255, 0.5);
      width: 100%;
      height: 100%;
      z-index: 1; }
    .features .bg_slider .slider {
      height: 100%; }
      .features .bg_slider .slider .slick-track, .features .bg_slider .slider .slick-list, .features .bg_slider .slider .slick-slide, .features .bg_slider .slider .slick-slide > div {
        height: calc(100% - 30px); }
        .features .bg_slider .slider .slick-track .slick-slide.slick-active img, .features .bg_slider .slider .slick-list .slick-slide.slick-active img, .features .bg_slider .slider .slick-slide .slick-slide.slick-active img, .features .bg_slider .slider .slick-slide > div .slick-slide.slick-active img {
          animation: image-gallery-slides 8s linear;
          animation-fill-mode: forwards; }
        .features .bg_slider .slider .slick-track .slick-slide, .features .bg_slider .slider .slick-list .slick-slide, .features .bg_slider .slider .slick-slide .slick-slide, .features .bg_slider .slider .slick-slide > div .slick-slide {
          overflow: hidden; }
        .features .bg_slider .slider .slick-track li, .features .bg_slider .slider .slick-list li, .features .bg_slider .slider .slick-slide li, .features .bg_slider .slider .slick-slide > div li {
          height: 100%;
          transform: scale(1.2); }
          .features .bg_slider .slider .slick-track li img, .features .bg_slider .slider .slick-list li img, .features .bg_slider .slider .slick-slide li img, .features .bg_slider .slider .slick-slide > div li img {
            transform: translateX(-20px);
            height: 100%; }
    .features .bg_slider .slick-dots {
      bottom: 40px !important;
      z-index: 10; }

.movie {
  margin-top: 100px;
  padding: 100px 0;
  position: relative; }
  @media all and (max-width: 896px) {
    .movie {
      padding: 0;
      margin-top: 50px; } }
  .movie:before {
    content: "";
    display: block;
    width: 50vw;
    height: 100%;
    position: absolute;
    top: 0;
    right: 0;
    background: url("") no-repeat center center/cover; }
    @media all and (max-width: 896px) {
      .movie:before {
        position: relative;
        width: 100vw;
        height: 200px;
        margin-bottom: 30px; } }
  .movie .area_movie {
    margin: 0 auto;
    position: relative;
    z-index: 3; }
    .movie .area_movie .sec_movie {
      display: flex;
      flex-wrap: wrap;
      margin: 0 -10px; }
      .movie .area_movie .sec_movie a {
        display: block;
        width: calc(33.333% - 20px);
        margin: 10px;
        background: #fff; }
        @media all and (max-width: 896px) {
          .movie .area_movie .sec_movie a {
            width: calc(50% - 20px); } }
        @media all and (max-width: 480px) {
          .movie .area_movie .sec_movie a {
            width: 100%; } }
        .movie .area_movie .sec_movie a:hover {
          opacity: 1; }
          .movie .area_movie .sec_movie a:hover img {
            transform: scale(1.1);
            transition: 0.3s; }
        .movie .area_movie .sec_movie a dl dt {
          height: 200px;
          overflow: hidden; }
          @media all and (max-width: 480px) {
            .movie .area_movie .sec_movie a dl dt {
              height: 150px; } }
        .movie .area_movie .sec_movie a dl dd {
          padding: 15px;
          box-sizing: border-box; }
        .movie .area_movie .sec_movie a p {
          padding: 15px;
          box-sizing: border-box; }
          .movie .area_movie .sec_movie a p span {
            color: #191970;
            font-size: 1rem;
            display: block;
            line-height: 1em; }

.slide {
  margin-top: 0;
  position: relative; }
  .slide:after {
    content: "";
    display: block;
    position: absolute;
    top: -269px;
    right: 20px;
    background: url("") no-repeat bottom center/100% auto;
    width: 168px;
    height: 269px; }
    @media all and (max-width: 480px) {
      .slide:after {
        width: 130px; } }
  .slide .slide_loop li {
    width: calc(100% / 3); }

.access {
  padding: 100px 0;
  position: relative;
  background: #f7f7f7; }
  @media all and (max-width: 480px) {
    .access {
      padding: 50px 0; } }
  .access:before {
    content: "";
    background: #fff;
    display: block;
    width: 30vw;
    height: 60%;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 0; }
    @media all and (max-width: 480px) {
      .access:before {
        width: 45vw;
        height: 50%; } }
  .access .area_access {
    display: flex;
    position: relative;
    z-index: 1; }
    @media all and (max-width: 896px) {
      .access .area_access {
        flex-wrap: wrap-reverse; } }
    .access .area_access .sec_img {
      width: 50%; }
      @media all and (max-width: 896px) {
        .access .area_access .sec_img {
          width: 100%;
          margin-top: 20px; } }
      .access .area_access .sec_img li {
        height: 300px;
        padding: 5px 0; }
        @media all and (max-width: 896px) {
          .access .area_access .sec_img li {
            height: 200px; } }
        .access .area_access .sec_img li iframe {
          width: 100%;
          height: 100%; }
        .access .area_access .sec_img li p {
          text-align: right;
          margin-top: 5px; }
    .access .area_access .sec_info {
      width: 50%;
      padding: 0 30px 30px 30px;
      box-sizing: border-box; }
      @media all and (max-width: 896px) {
        .access .area_access .sec_info {
          width: 100%; } }
      @media all and (max-width: 480px) {
        .access .area_access .sec_info {
          padding: 0; } }
      .access .area_access .sec_info .block_info {
        margin-top: 30px; }
        .access .area_access .sec_info .block_info > dt {
          font-weight: bold;
          font-size: 1.8rem; }
        .access .area_access .sec_info .block_info > dd {
          margin-top: 10px; }
          .access .area_access .sec_info .block_info > dd dl {
            padding: 20px;
            box-sizing: border-box;
            display: flex;
            background: #fff;
            margin-top: 1px; }
            .access .area_access .sec_info .block_info > dd dl dt {
              width: 80px; }
            .access .area_access .sec_info .block_info > dd dl dd {
              width: calc(100% - 80px);
              border-left: 1px solid #ccc;
              padding-left: 20px; }

.link {
  background: url() no-repeat center center/cover;
  padding: 100px 0; }
  @media all and (max-width: 480px) {
    .link {
      padding: 50px 0; } }
  .link .area_link ul {
    display: flex;
    justify-content: center;
    flex-wrap: wrap; }
    .link .area_link ul li {
      background: #fff;
      padding: 30px;
      box-sizing: border-box;
      width: calc(33.333% - 20px);
      margin: 10px; }
      @media all and (max-width: 896px) {
        .link .area_link ul li {
          width: 100%; } }
      .link .area_link ul li h2 {
        text-align: center;
        font-family: 游明朝, "Yu Mincho", YuMincho,'Noto Serif JP', "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
        font-weight: bold;
        font-size: 1.8rem; }
      .link .area_link ul li .sec_link {
        margin-top: 20px; }
        .link .area_link ul li .sec_link .btn_more {
          margin-top: 1px; }
          .link .area_link ul li .sec_link .btn_more a {
            display: block;
            margin: 0 auto;
            padding: 10px; }

.footslide {
  padding: 50px 0; }
  .footslide .area_footslide li {
    text-align: center;
    padding: 5px;
    box-sizing: border-box; }
    .footslide .area_footslide li a img {
      margin: 0 auto;
      height: 90px; }






    .slideshow-container {
      width: 100%;
      overflow: hidden;
      height: 150px;
    }

    .slideshow-track {
      display: flex;
      width: max-content; /* 必要に応じて調整 */
      animation: scroll 20s linear infinite;
    }

    .slideshow-track img {
      height: 150px;
      width: auto;
      object-fit: cover;
      flex-shrink: 0;
    }

    @keyframes scroll {
      0% {
        transform: translateX(0);
      }
      100% {
        transform: translateX(-50%);
      }
    }


/*20260209*/
/* ======================================================
   【最終手段】ヘッダー・メニュー配置の完全上書き
   ====================================================== */
/* ======================================================
   【最終解決】メニューを画面右上に強制配置する
   ====================================================== */
/* ======================================================
   【安全修正案】ロゴは左、メニューセットを右上へ
   ====================================================== */

/* 1. ロゴとメニューを包む外枠を画面幅いっぱいに広げる */
header .area_nav {
    width: 100% !important;
    max-width: none !important;
    padding: 0 !important;
}

/* 2. ロゴとメニューの親要素を横並び（Flex）にする */
header .area_nav .block_logo {
    display: flex !important;
    justify-content: space-between !important; /* これで左右に振り分けます */
    align-items: flex-start !important;        /* 上端に揃える */
    width: 100% !important;
    padding: 15px 20px !important;              /* 全体の余白 */
    box-sizing: border-box !important;
}

/* 3. ロゴ（左側）の調整 */
header .area_nav .block_logo .logo {
    position: static !important; /* 固定を解除してFlexに従わせる */
    margin: 0 !important;
}

/* 4. メニューと文字のセット（紺地・右側）を右上へ固定 */
header .area_nav .block_logo .nav {
    display: flex !important;
    flex-direction: column !important; /* 三本線とMENUを縦に並べる */
    align-items: center !important;
    margin-left: auto !important;      /* 右側に押し出す */
    z-index: 10000 !important;
}

/* 5. 三本線ボタン自体の調整 */
header .menu-trigger {
    position: relative !important;
    right: 0 !important;
    top: 0 !important;
    margin: 0 !important;
}

/* 6. 「MENU」という文字の位置 */
header .nav p {
    margin-top: 5px !important;
    font-size: 10px !important;
    color: #fff  /* 通常時 */
    font-weight: bold;
    text-align: center;
}

