@charset "utf-8";

/* theme original */
.h_bar,
#beltbnr {
  display: none;
}
/* html,
body,
.div.wrapper_ {
  overflow: visible!important;
} */
html {
  font-size: 62.5%;
  scroll-padding-top: 70px;
}
*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  -ms-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
/* ここ不要 */
img {
  border-radius: 1px;
  max-width: 100%;
  height: auto;
  vertical-align: middle;
  object-fit: cover;
}
ul,
li {
  list-style: none;
  /* counter-increment: number; */
}
/* buttonタグ打ち消し */
button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none;
}
.fontJa {
  color: #2f3033;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-size: 1.4rem;
  font-feature-settings: "palt";
  letter-spacing: .04em;
  line-height: 1.75;
  text-align: justify; /* 両端揃え */
}
.fontEn {
  color: #2f3033;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-size: 1.4rem;
  letter-spacing: 0;
  line-height: 1;
}
a.btn {
  color: #2f3033;
  display: inline-block;
  text-decoration: none;
}
/* contents */
.pc__img {
  display: block;
}
.sp__img {
  display: none;
}
.contents.topContents {
  width: 1140px;
  margin-inline: auto;
}
.kvSection .kvSection__img {
  width: 900px;
  margin-inline: auto;
}
.lead {
  width: 900px;
  margin-inline: auto;
  padding-top: 74.75px;
  margin-bottom: 60px;
}
.lead .fontJa+.fontJa {
  padding-top: 30px;
}
.container {
  width: 900px;
  margin-inline: auto;
}
.kvArticle__section {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: nowrap;
}
.kvArticle__section--right {
  display: block;
  width: 30%;
  position: sticky;
  top: 70px;
  height: 100%;
  overflow-y: scroll;
}
.kvArticle__section--left {
  width: 65%;
}
.about .about__theme .fontEn {
  text-align: center;
  letter-spacing: 0;
}
.about .about__theme p.fontEn {
  font-size: 1.5rem;
  font-weight: 600;
  padding-bottom: 15px;
}
.about .about__theme h2.fontEn {
  font-size: 3.0rem;
  font-weight: 700;
  margin-bottom: 40px;
  position: relative;
}
.about .about__theme h2.fontEn::before,
.about .about__theme h2.fontEn::after {
  content: "";
  width: 23%;
  height: 1px;
  background: #2f3033;
  position: absolute;
  top: 50%;
  -ms-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.about .about__theme h2.fontEn::before {
  left: 0;
}
.about .about__theme h2.fontEn::after {
  right: 0;
}
/* Accordion */
.details {
  border-radius: 1px;
}
.details:last-of-type {
  border-bottom: 1px solid #2f3033;
}
.details__summary {
  border-radius: 1px;
  display: block;
  padding: 11px 0 10px;
  position: relative;
}
.details__summary:hover {
  cursor: pointer;
}
.details__summary p.fontEn {
  color: #2e4eb4;
  font-size: 2.4rem;
  font-weight: 700;
}
.details__summary .detailsBtn {
  background: #bcbfc4;
  border-radius: 20px;
  position: absolute;
  top: 41%;
  right: 0;
  width: 15px;
  height: 15px;
  transform-origin: center center;
  transition-duration: .2s;
}
/* +の状態(閉じてる時) */
.details__summary .detailsBtn::before,
.details__summary .detailsBtn::after {
  background: #FFFFFF;
  content: "";
  position: absolute;
  border-radius: 10px;
  width: 9px;
  height: 1px;
  top: 7px;
  left: 3px;
  transform-origin: center center;
}
.details__summary .detailsBtn {
  right: 5px;
}
/* 縦線(+のための縦棒) */
.details__summary .detailsBtn::before {
  width: 1px;
  height: 9px;
  top: 3px;
  left: 7px;
}
.details__summary.is-active .detailsBtn {
  -webkit-transform: rotate(-180deg);
  transform: rotate(-180deg);
}
.details__summary.is-active .detailsBtn::before {
  content: none;
}
.details__summary.details__summary::-webkit-details-marker {
  display: none;
}
.details__content {
  padding: 20px;
}
.linkItems {
  padding: 20px 0;
}
.linkItems a.btn {
  display: block;
  width: 100%;
}
.linkItems>a:not(:last-child)>li {
  background: #FFFFFF;
  border-bottom: 2px solid #d0d3d9;
  border-radius: 1px;
  margin-left: 8px;
  margin-bottom: 24px;
  padding-left: 20px;
  padding-right: 20px;
  padding-top: 8px;
  padding-bottom: 8px;
  position: relative;
}
.linkItems .circle {
  background: #2e4eb4;
  border-radius: 50%;
  content: "";
  display: block;
  position: absolute;
  top: -10px;
  left: -7px;
  width: 25px;
  height: 25px;
  line-height: 25px;
}
.linkItems .circle::after {
  content: "";
  display: block;
  height: 0;
  width: 0;
  border-top: 4px solid transparent;
  border-bottom: 4px solid transparent;
  border-left: 9px solid #2e4eb4;
  position: absolute;
  top: 105%;
  left: 16px;
  -moz-transform: translateY(-105%) rotate(30deg);
  -o-transform: translateY(-105%) rotate(30deg);
  -ms-transform: translateY(-105%) rotate(30deg);
  -webkit-transform: translateY(-105%) rotate(30deg);
  transform: translateY(-105%) rotate(30deg);
}
.linkItems .circle p {
  color: #FFFFFF;
  font-size: 1.2rem;
  font-weight: 600;
  font-style: normal;
  text-align: center;
  line-height: 24px;
}
.linkItems li span.fontJa {
  color: #8d9099;
  font-size: 1.2rem;
}
.linkItems li p.fontJa {
  font-size: 1.4rem;
}
.closeArea {
  width: 160px;
  margin-inline: auto;
}
.closeArea li p.fontJa {
  font-weight: 500;
  text-align: center;
}
.closeArea li p.fontJa span.detailsBtn {
  cursor: pointer;
}
.gridItem {
  position: relative;
}
.grid__container {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 2px;
  grid-template-areas:
    "areaA areaA areaA areaA"
    "areaB areaB areaC areaC"
    "areaD areaD areaE areaE"
    "areaF areaF areaF areaF"
    "areaG areaG areaH areaH"
    "areaI areaI areaJ areaJ"
    "areaK areaK areaL areaL"
    "areaM areaM areaM areaM"
    "areaN areaN areaO areaO"
    "areaP areaP areaQ areaQ"
}
#item01 {
  grid-area: areaA;
}
#item02 {
  grid-area: areaB;
}

#item03 {
  grid-area: areaC;
}

#item04 {
  grid-area: areaD;
}

#item05 {
  grid-area: areaE;
}

#item06 {
  grid-area: areaF;
}

#item07 {
  grid-area: areaG;
}

#item08 {
  grid-area: areaH;
}

#item09 {
  grid-area: areaI;
}

#item10 {
  grid-area: areaJ;
}

#item11 {
  grid-area: areaK;
}

#item12 {
  grid-area: areaL;
}

#item13 {
  grid-area: areaM;
}

#item14 {
  grid-area: areaN;
}

#item15 {
  grid-area: areaO;
}

#item16 {
  grid-area: areaP;
}

#item17 {
  grid-area: areaQ;
}

.movieNum {
  position: relative;
}
.movieNum::before {
  background: #2e4eb4;
  border-radius: 1px;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 32px;
  height: 32px;
  line-height: 32px;
  z-index: 11;
}
.movieNum::after {
  content: attr(data-num);
  color: #FFFFFF;
  font-family: "Questrial", sans-serif;
  font-size: 1.4rem;
  font-weight: 400;
  font-style: normal;
  position: absolute;
  top: 9px;
  left: 9px;
  z-index: 11;
}
/* 再生ボタン */
.videoPlay {
  border: .05em solid currentColor;
  border-radius: 50%;
  content: "";
  color: #FFFFFF;
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 50%;
  -ms-transform: translate(-50%);
  -moz-transform: translate(-50%);
  -o-transform: translate(-50%);
  -webkit-transform: translate(-50%);
  transform: translate(-50%);
  width: .7em;
  height: .7em;
  font-size: 50px;
  z-index: 11;
}
.videoPlay::before {
  border: .2em solid transparent;
  border-left: .30em solid currentColor;
  content: "";
  position: absolute;
  top: 50%;
  left: 33%;
  -ms-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 0;
  height: 0;
  z-index: 11;
}
.imgOverlay {
  position: relative;
}
.imgOverlay::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  background-color: rgba(47, 48, 51, .4);
  width: 100%;
  height: 100%;
  z-index: 10;
}
.gridItems__button {
  padding-top: 220px;
  position: relative;
}
.gridItems__button a::before {
  background: #2f3033;
  content: "";
  display: block;
  position: absolute;
  top: 40px;
  left: 50%;
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -o-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 1px;
  height: 120px;
  animation: scroll 1.5s infinite;
}
/* 罫線アニメーション */
@keyframes scroll {
  0% {
    transform: scale(1,0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1,1);
    transform-origin: 0 0;
  }
  50.1% {
    transform: scale(1,1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1,0);
    transform-origin: 0 100%;
  }
}
.gridItems__button a {
  display: block;
}
.gridItems__button a p.fontJa {
  background: #2e4eb4;
  border: 1px solid #2e4eb4;
  border-radius: 1px;
  color: #FFFFFF;
  display: block;
  font-size: 2.0rem;
  width: 560px;
  height: 80px;
  line-height: 80px;
  margin-inline: auto;
  text-align: center;
  transition: all .3s;
}
.gridItems__button a p.fontJa:hover {
  background: #FFFFFF;
  color: #2e4eb4;
}
/* 下からアニメーション表示 */
.fadeIn {
  opacity: 0;
}
.fadeIn.inView {
  animation-name: fade-in;
  animation-duration: .5s;
  animation-timing-function: ease-in-out;
  animation-delay: .4s;
  animation-iteration-count: 1;
  animation-direction: normal;
  animation-fill-mode: forwards;
}
@keyframes fade-in {
  0% {
    transform: translateY(40px);
  }
  100% {
    transform: translateY(0px);
    opacity: 1;
  }
}
/* モーダル CSS */
/* 開くボタン */
.button__open {
  display: block;
  margin: 0 auto;
  cursor: pointer;
}
.modal__window {
  display: none;
  position: fixed;
  top: 50%;
  left: 50%;
  -ms-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -o-transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 400px;
  height: auto;
  max-height: 80vh;
  background-color: #FFFFFF;
  border-radius: 5px;
  z-index: 20;
  padding: 2rem;
  overflow-y: scroll;
}
/* .topButton__close {
  position: absolute;
  top: -48px;
  right: 24px;
  display: block;
  width: 40px;
  height: 40px;
  z-index: 20;
  cursor: pointer;
  background: #FF0000;
} */
/* .topButton__close::before,
.topButton__close::after {
  content: "";
  position: absolute;
  top: 24px;
  right: 19px;
  width: 1px;
  height: 24px;
  background: #FFFFFF;
  opacity: .8;
}
.topButton__close::before {
  transform: rotate(45deg);
}
.topButton__close::after {
  transform: rotate(-45deg);
} */
.bottomButton__Close {
  color: #2f3033;
  margin-top: 30px;
  padding: .3em;
}
/* オーバーレイ */
.overlay {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  background-color: rgba(0, 0, 0, .5);
  width: 100%;
  height: 100%;
  z-index: 15;
}
/* 表示領域外へはスクロールさせない */
.no__scroll {
  overflow: hidden;
}
figure {
  margin-top: 10px;
}
figure figcaption .fontJa:first-child {
  color: #8d9099;
  font-size: 1.2rem;
}
figure figcaption .fontJa:nth-child(2) {
  font-weight: 700;
  padding: .2rem 0 .8rem;
  margin-bottom: 0.2rem;
  background-image: linear-gradient(90deg, #2e4eb4 0 20%, #d0d3d9 20%);
  background-repeat: no-repeat;
  background-size: 100% 5%;
  background-position: bottom;
}
figure figcaption .cap.fontJa {
  padding-top: 19.5px;
}
.kvSection__footer {
  border-top: 1px solid #2f3033;
}
.kvSection__footer {
  border-top: 1px solid #2f3033;
  margin-top: 104px;
  padding-top: 30px;
}
.shipsany__director--txt {
  margin-top: 30px;
  padding-bottom: 70px;
  border-bottom: 1px solid #2f3033;
}
.shipsany__director--txt p {
  width: 400px;
  margin-inline: auto;
}
.shipsany__director--txt p span {
  display: block;
  text-indent: -9999px;
  padding-top: calc(60 / 50 * 100%); /* 60 / 50 * 100 = 親要素の1.2倍の高さを取る */
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: center top;
}
.shipsany__director--txt p span {
  background-image: url(https://www.shipsltd.co.jp/campaign/2025/shipsa_0219/img/comment.jpg);
}
.shipsany__concept {
  margin-top: 80px;
}
.shipsany__concept ul.shipsany__concept--txt {
  display: flex;
  flex-wrap: nowrap;
  flex-direction: row-reverse;
  justify-content: center;
  margin-bottom: 30px;
  height: 100%;
}
.shipsany__concept ul.shipsany__concept--txt li {
  width: 20px;
}
.shipsany__concept ul.shipsany__concept--txt li:not(:first-child) {
  margin-right: 23px;
}
.shipsany__concept ul.shipsany__concept--txt li span {
  display: block;
  text-indent: -9999px;
  height: 0;
  padding-top: calc(452 / 50*100%); /* 452 / 50 * 100= 9.04倍の高さをとる*/
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: center top;
}
.shipsany__concept ul.shipsany__concept--txt li:nth-child(1) span {
  background-image: url(https://www.shipsltd.co.jp/campaign/2025/shipsa_0219/img/concept__text--1.png);
}
.shipsany__concept ul.shipsany__concept--txt li:nth-child(2) span {
  background-image: url(https://www.shipsltd.co.jp/campaign/2025/shipsa_0219/img/concept__text--2.png);
}
.shipsany__concept ul.shipsany__concept--txt li:nth-child(3) span {
  background-image: url(https://www.shipsltd.co.jp/campaign/2025/shipsa_0219/img/concept__text--3.png);
}
.shipsany__concept ul.shipsany__concept--txt li:nth-child(4) span {
  background-image: url(https://www.shipsltd.co.jp/campaign/2025/shipsa_0219/img/concept__text--4.png);
}
.any__logo {
  width: 340px;
  margin-inline: auto;
}
.any__logo p span {
  display: block;
  text-indent: -9999px;
  height: 0;
  padding-top: calc(12 / 50 * 100%); /* 12 / 50 * 100= 0.24倍の高さをとる*/
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: center top;
}
.any__logo p span {
  background-image: url(https://www.shipsltd.co.jp/campaign/2025/shipsa_0219/img/ships-any__logo.png);
}

@media(min-width: 769px) {
  html,
  body,
  div.wrapper_ {
    overflow: visible!important;
  }
}
@media(max-width: 768px) {
  html {
    scroll-padding-top: 0;
  }
  .pc__img {
    display: none;
  }
  .sp__img {
    display: block;
  }
  #SHIPS-any {
    overflow: hidden;
  }
  .contents.topContents,
  .container {
    width: 100%;
  }
  .kvSection .kvSection__img {
    width: 100%;
  }
  .lead {
    width: 89%;
    padding-top: 11.4%;
    margin-bottom: 7.74%;
  }
  .kvArticle__section {
    flex-direction: column;
  }
  .kvArticle__section--right {
    width: 89%;
    margin-inline: auto;
  }
  .kvArticle__section--left {
    width: 100%;
    position: relative;
  }
  .details__summary p.fontEn {
    font-size: 1.6rem;
  }
  .about .about__theme p.fontEn {
    font-size: 1.5rem;
    padding-bottom: 10px;
  }
  .about .about__theme h2.fontEn {
    font-size: 2.4rem;
  }
  .about .about__theme h2.fontEn::before,
  .about .about__theme h2.fontEn::after {
    width: 17%;
  }
  .linkItems li p.fontJa {
    font-size: 1.2rem;
  }
  .linkItems li span.fontJa {
    font-size: 1.0rem;
  }
  .details {
    margin-bottom: 40px;
  }
  /* -の状態（開いているとき） */
  .details__summary .detailsBtn::before {
    display: block;
  }
  .gridItems__button a::before {
    height: 100px;
  }
  .gridItems__button {
    padding-top: 48%;
  }
  .gridItems__button a p.fontJa {
    font-size: 1.6rem;
    width: 80%;
    height: 60px;
    line-height: 60px;
  }
  /* モーダルウィンドウ */
  .modal__window {
    width: 90%;
    max-height: 75vh;
  }
  .kvSection__footer {
    margin-top: 13.87%;
    padding-top: 15px;
  }
  .shipsany__director--txt {
    margin-top: 0;
    padding-bottom: 30px;
  }
  .shipsany__director--txt p {
    width: 90%;
  }
  .shipsany__concept {
    margin-top: 60px;
  }
  .shipsany__concept ul.shipsany__concept--txt li {
    width: 20px;
  }
  .any__logo {
    width: 80%;
  }
}