@charset "UTF-8";


/* 基本 */
* {
  box-sizing: border-box;
}

.is-sp {
  display: none;
}

@media screen and (max-width: 767px) {
.is-pc {
  display: none;
}
.is-sp {
  display: block;
}
br.is-sp {
  display: inline;
}
}


/* LPヘッダー */
.l-header {
  position: relative;
  z-index: 100;
}

.l-header-inner .header-lp-black {
  background-color: rgba(1, 3, 6, 0);
  padding: 15px 20px;
}

.header-lp-inner {
  max-width: 1000px;
}

.header-logo img {
  width: 160px;
}
/* snsアイコン */
.lp-black-icon{
  color: #1A439A !important;
}

@media screen and (max-width: 980px) {
.header-logo img {
  width: 110px;
}
}


main {
  margin-top: -56px;
  position: relative;
  background: url(../images/summer2024/wave_3.png) no-repeat bottom center,url(../images/summer2024/mv_circle_l.png) no-repeat left calc(50% - 600px) top 140px,url(../images/summer2024/mv_circle_m.png) no-repeat right calc(50% - 100px) top 50px,url(../images/summer2024/mv_circle_r.png) no-repeat right calc(50% - 560px) top 90px,url(../images/summer2024/mv_bg_pc.webp) no-repeat right center;
  background-size: 100% auto,155px auto,164px auto,215px auto,cover;
  background-attachment: fixed;
}


/* MV */
.mv2024 {
   position: relative;
   height: 100%;
}
.mv2024-inner{
   position: absolute;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%;
   clip-path: inset(0);
}

.mv2024 h1 {
  max-width: 1090px;
  margin: 0 auto;
  padding: 116px 0 80px;
}
.mv2024 h1 img{
  max-width: 650px;
}


@media screen and (max-width: 767px) {
main {
  background:none;
}

main:before{
  content:"";
  display:block;
  position:fixed;
  top:0;
  left:0;
  z-index:-1;
  width:100%;
  height:100vh;
  background: url(../images/summer2024/wave_3.png) no-repeat bottom center,url(../images/summer2024/mv_circle_l.png) no-repeat left -75px top 230px,url(../images/summer2024/mv_circle_m.png) no-repeat right -115px top 60px, url(../images/summer2024/mv_bg_sp.webp) no-repeat center bottom;
  background-size: 100% auto,155px auto,164px auto,cover;
}

.mv2024 h1 {
  padding: 80px 15px 40px 20px;
}
}


/* イベント */
.content {
  max-width: 1040px;
  margin: 0 auto;
  padding: 0 20px;
}

.content-list {
  padding-bottom: 80px;
}

.content-list li{
  box-shadow: 0 0 2px rgba(0,0,0,0.1);
  border-radius: 20px;
}

.content-list li + li{
  margin-top: 40px;
}

.content-list a {
  width: 100%;
  padding: 30px;
  border-radius: 20px;
  display: flex;
  justify-content: space-between;
  color: #fff;
  text-decoration: none;
  background: rgba(26,67,154,0.8);
  box-shadow: 0 1px 5px rgba(2, 30, 82, 0.15);
}
.content-list a:hover {
  opacity: 0.75;
}

.content-img {
  width: 330px;
}

.content-img img {
  border-radius: 10px;
}

.content-img img.img-fit {
  width: 100%;
  height: 225px;
  object-fit: cover;
}

.content-detail {
  width: calc(100% - 350px);
  display: flex;
  align-content: center;
  flex-wrap: wrap;
}

.content-detail h2 {
  width: 100%;
  margin-bottom: 15px;
  font-size: 24px;
  color: #fff;
  line-height: 1.2;
}

.content-spot,
.content-date {
  width: 100%;
  margin-bottom: 12px;
  font-size: 18px;
  font-weight: bold;
  display: flex;
  justify-content: space-between;
}
.content-spot .content-spot-small {
  padding-top: 3px;
  font-size: 14px;
}

.content-date {
  margin-bottom: 10px;
}

.content-spot span,
.content-date span {
  width: calc(100% - 95px);
}

span.event-label {
  width: 88px;
  line-height: 30px;
  background: #4498D4;
  border-radius: 15px;
  text-align: center;
  color: #fff;
  font-size: 14px;
  font-weight: normal;
  font-weight: bold;
}

.content-txt {
  margin-top: 5px;
  width: 100%;
  font-size: 16px;
  line-height: 1.5;
}

@media screen and (max-width: 767px) {
.content-list {
  margin: 0 0 60px;
}

.content-list li{
  border-radius: 16px;
}

.content-list li + li{
  margin-top: 30px;
}

.content-list a {
  padding: 15px;
  display: block;
  border-radius: 22px;
}

.content-img {
  width: 100%;
  margin-bottom: 10px;
}

.content-img img {
  border-radius: 7px;
}

.content-img img.img-fit {
  width: 100%;
  height: 210px;
  object-fit: cover;
}

.content-detail {
  width: 100%;
  display: block;
}

.content-detail h2 {
  margin-bottom: 10px;
  font-size: 18px;
}
.content-detail h2.narrow {
  letter-spacing: -0.08rem;
}

.content-spot,
.content-date {
  font-size: 14px;
}

.content-spot span,
.content-date span {
  border-radius: 13px;
  font-size: 12px;
  width: calc(100% - 77px);
}

.content-spot span + span,
.content-date span + span {
  padding-top: 4px;
}

span.event-label {
  width: 70px;
  height: 26px;
  line-height: 26px;
  font-size: 12px;
}

.content-txt {
  font-size: 14px;
  line-height: 1.6;
}
}

/* フッター */
.breadcrumb-wrap {
  border: none;
  background: #1A439A;
}

.breadcrumb a,
.icon-arrow_left_thin::before,
.footer-sns-wrap .icon-line::before {
  color: #fff;
}

.l-banner-white,
.l-banner-gray {
  background: #1a397d;
}

.l-footer .l-footer-sub {
  border: none;
  background: #1a397d;
}

.l-footer,
.l-footer-navi {
   background: #1A439A;
}

/* Xロゴ差し替え */
.footer-sns-wrap ul li .icon-x {
  background: url(../images/common/i_x_wh.svg) no-repeat center center;
  background-size: 14px auto;
}


@media screen and (max-width: 980px) {
footer .footer-main .l-footer-menu dd, footer .l-footer-sub .l-footer-menu dd {
  background: #1A439A !important;
}

footer .l-footer-sub .l-footer-menu {
  background: #1A439A !important;
}
footer .footer-main .l-footer-menu {
  border-top: 1px solid #002f66 !important;
}
footer .l-footer-sub .l-footer-menu {
  border-top: 1px solid #002f66 !important;
}
.l-footer-sub .l-footer-menu:last-of-type {
  border-bottom: 1px solid #002f66 !important;
}
footer .footer-main .l-footer-menuList li, .footer-access-list li {
  border-top: 1px solid #002f66;
}
.l-footer .footer-row-icon span {
  background: #97aad2 !important;
}
}


/* 終了表示 */
.event-end {
/*  opacity: 0.5;*/
  position: relative;
}
.event-end .content-list a {
  background: #ccc;
}

.event-end::before {
  content: 'イベントは終了しました'; /* data-hoverの値を表示 */
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transition: opacity 0.3s;
  color: #fff;
  text-align: center;
  font-size: 18px;
  font-weight: bold;
  line-height: 2;
  white-space: pre; /* これがないと改行が効かない */
  z-index: 103;
  text-shadow: 0 0 8px rgba(0,0,0,0.6);
}

.event-end::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #001527;
  opacity: 0.6;
  transition: opacity 0.3s;
  z-index: 102;
  border-radius: 20px;
}

