@charset "UTF-8";
/*--------------------
共通設定
----------------------*/
* {
  padding: 0;
  margin: 0;
  box-shadow: none !important; }

.fs-l-page {
  overflow: visible !important; }

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom; }

a {
  text-decoration: none;
  color: #000000;
  transition: .4s; }
  a.disabled {
    pointer-events: none;
    text-decoration: none; }
  a:hover {
    text-decoration: none;
    color: #000000; }
  a:visited {
    text-decoration: none;
    color: #000000; }

ul, ol {
  list-style: none; }

.pc {
  display: block; }
  @media screen and (max-width: 1080px) {
    .pc {
      display: none; } }

.sp {
  display: none; }
  @media screen and (max-width: 1080px) {
    .sp {
      display: block; } }

.wrapper {
  margin: 0 auto !important; }

main {
  max-width: 100%; }

.mainBox {
  margin: 0 auto !important;
  padding-top: 0 !important; }

footer {
  position: relative;
  z-index: 999; }

#special {
  padding-top: 60px;
  overflow-x: hidden;
  /* flexbox */ }
  #special.lp_wrapper {
    margin: 0 auto;
    box-sizing: border-box;
    padding: 0;
    letter-spacing: 0;
    color: #000000;
    font-size: 16px;
    text-align: left;
    letter-spacing: 1px;
    font-weight: 400;
    font-family: "open-sans", sans-serif;
    font-style: normal;
    position: relative;
    top: 60px; }
  #special .mv {
    position: relative;
    width: 100%;
    overflow: hidden;
    max-height: fit-content; }
    @media screen and (max-width: 1080px) {
      #special .mv {
        margin-bottom: 10%; } }
    @media screen and (max-width: 600px) {
      #special .mv {
        height: auto; } }
    #special .mv .swiper {
      width: 100%; }
      #special .mv .swiper .swiper-wrapper .swiper-slide {
        overflow: hidden; }
        #special .mv .swiper .swiper-wrapper .swiper-slide img {
          width: 100%;
          height: 100%;
          object-fit: cover; }
    #special .mv .logo {
      position: absolute;
      bottom: 5%;
      left: 50%;
      transform: translateX(-50%);
      z-index: 20;
      text-align: center;
      max-width: 800px;
      width: 100%; }
      @media screen and (max-width: 1080px) {
        #special .mv .logo {
          bottom: 10%; } }
      #special .mv .logo img {
        width: auto;
        height: 60vh; }
        @media screen and (max-width: 1650px) {
          #special .mv .logo img {
            height: 45vh; } }
        @media screen and (max-width: 1080px) {
          #special .mv .logo img {
            height: auto;
            width: 70%; } }
  #special section {
    margin: 0 auto;
    max-width: 1680px; }
    #special section h2 {
      font-size: 3.8em;
      font-weight: 400;
      line-height: 1.5;
      color: #6e9fdd;
      font-family: "minion-pro", serif;
      text-align: center;
      margin-bottom: 3%; }
      @media screen and (max-width: 1080px) {
        #special section h2 {
          font-size: 2.5em; } }
      @media screen and (max-width: 600px) {
        #special section h2 {
          font-size: 5.7vw;
          line-height: 1.2; } }
    #special section#ttl {
      padding: 5% 0 0; }
      @media screen and (max-width: 1700px) {
        #special section#ttl {
          padding: 5% 5% 0; } }
  #special .flexBox {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex-wrap: wrap;
    width: 90%;
    margin: 0 auto; }
    @media screen and (max-width: 1080px) {
      #special .flexBox {
        width: 100%; } }
    @media screen and (max-width: 600px) {
      #special .flexBox {
        width: 85%;
        justify-content: flex-start; } }
    #special .flexBox .box {
      position: relative;
      width: calc(100%/3 - 1.0em);
      margin-bottom: 1.5em; }
      @media screen and (max-width: 1080px) {
        #special .flexBox .box {
          width: calc(100%/3 - .5em);
          margin-bottom: 1.0em; } }
      @media screen and (max-width: 600px) {
        #special .flexBox .box {
          order: 1; } }
      @media screen and (max-width: 600px) {
        #special .flexBox .box.position1 {
          order: 0; } }
      @media screen and (max-width: 600px) {
        #special .flexBox .box.position2 {
          order: 1; } }
      @media screen and (max-width: 600px) {
        #special .flexBox .box.position3 {
          order: 1; } }
      @media screen and (max-width: 600px) {
        #special .flexBox .box {
          width: 50%;
          margin: 0.5em; } }
      @media screen and (max-width: 600px) {
        #special .flexBox .box {
          width: calc(100% - 1.0em); } }
      #special .flexBox .box.box50 {
        width: calc(50% - 1.0em); }
        @media screen and (max-width: 1080px) {
          #special .flexBox .box.box50 {
            width: calc(50% - .5em); } }
        @media screen and (max-width: 600px) {
          #special .flexBox .box.box50 {
            width: calc(100% - 1.0em); } }
      @media screen and (max-width: 600px) {
        #special .flexBox .box.spBox {
          width: calc(50% - 1.0em); } }
      #special .flexBox .box .item {
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 100%;
        z-index: 101;
        background: rgba(0, 0, 0, 0.6);
        color: #fff;
        opacity: 0; }
        @media screen and (max-width: 1080px) {
          #special .flexBox .box .item {
            opacity: 1;
            height: content;
            background: rgba(0, 0, 0, 0); } }
        #special .flexBox .box .item img {
          width: 100%;
          height: auto;
          object-fit: cover;
          object-position: bottom; }
        #special .flexBox .box .item .inner {
          position: absolute;
          bottom: 0;
          left: 0;
          width: 100%;
          height: content;
          font-size: 1.0em;
          line-height: 2.0;
          padding: 1.0em;
          display: flex;
          align-items: flex-start;
          justify-content: flex-end;
          flex-direction: column; }
          @media screen and (max-width: 1080px) {
            #special .flexBox .box .item .inner {
              padding: 0.5em; } }
          #special .flexBox .box .item .inner p {
            font-size: .8em;
            font-weight: 400;
            line-height: 1.3;
            letter-spacing: 0;
            margin: 0; }
            @media screen and (max-width: 1080px) {
              #special .flexBox .box .item .inner p {
                font-size: 0.6em; } }
            @media screen and (max-width: 600px) {
              #special .flexBox .box .item .inner p {
                font-size: 2.5vw; } }
          #special .flexBox .box .item .inner a {
            font-size: 0.8em;
            line-height: 1.2em;
            color: #fff;
            margin-top: 0.5em;
            border-bottom: 1px solid #fff; }
            @media screen and (max-width: 1080px) {
              #special .flexBox .box .item .inner a {
                font-size: 0.6em; } }
            @media screen and (max-width: 600px) {
              #special .flexBox .box .item .inner a {
                font-size: 2.5vw;
                margin-top: 0.2em; } }
            #special .flexBox .box .item .inner a:hover {
              text-decoration: none;
              transition: .4s; }
          #special .flexBox .box .item .inner.flex {
            justify-content: space-between;
            flex-direction: row;
            top: 0;
            bottom: auto; }
            #special .flexBox .box .item .inner.flex .right {
              text-align: right; }
          #special .flexBox .box .item .inner.flex_2 {
            justify-content: space-between;
            flex-direction: row;
            align-items: flex-end; }
            #special .flexBox .box .item .inner.flex_2 .right {
              text-align: right; }
      #special .flexBox .box:hover .item {
        opacity: 1;
        transition: .8s; }
  #special .itemList {
    max-width: 1000px;
    margin: 10% auto; }
    @media screen and (max-width: 1080px) {
      #special .itemList {
        width: 80%; } }
    @media screen and (max-width: 600px) {
      #special .itemList {
        margin-top: 20%; } }
    #special .itemList .block {
      display: flex;
      align-items: center;
      justify-content: space-between;
      flex-wrap: wrap; }
      #special .itemList .block .box {
        width: calc(100%/2 - 2%);
        text-align: center; }
        @media screen and (max-width: 600px) {
          #special .itemList .block .box {
            width: 80%;
            margin: 5% auto; } }
        #special .itemList .block .box img {
          border: 1px solid #e8e8e8; }
        #special .itemList .block .box .swiper3 .swiper-slide img {
          border: none; }
        #special .itemList .block .box p {
          font-size: 1.2em;
          letter-spacing: 0;
          line-height: 1.8; }
          @media screen and (max-width: 600px) {
            #special .itemList .block .box p {
              font-size: 3.5vw; } }
      #special .itemList .block a.buy {
        line-height: 1.0;
        font-size: 1.3em;
        padding: 0.5em 2.0em;
        border: 1px solid #000000;
        border-radius: 50vh;
        display: block;
        max-width: 300px;
        margin: 2.0em auto 0;
        text-align: center; }
        @media screen and (max-width: 600px) {
          #special .itemList .block a.buy {
            font-size: 3.5vw;
            padding: 1.0em;
            max-width: 250px; } }
        #special .itemList .block a.buy:hover {
          background: #6e9fdd;
          color: #ffffff;
          border-color: #6e9fdd; }
      #special .itemList .block.double .box {
        margin-bottom: 4%;
        position: relative; }
        @media screen and (max-width: 600px) {
          #special .itemList .block.double .box {
            width: calc(100%/2 - 2%);
            margin: auto auto 2%; } }
        #special .itemList .block.double .box p {
          font-size: 0.9em;
          position: absolute;
          bottom: 2.0em;
          letter-spacing: 0;
          width: 100%;
          left: 0;
          z-index: 20; }
          @media screen and (max-width: 1080px) {
            #special .itemList .block.double .box p {
              font-size: 0.8em; } }
          @media screen and (max-width: 600px) {
            #special .itemList .block.double .box p {
              font-size: 2.0vw;
              bottom: 1.0em; } }
      #special .itemList .block.double .credit {
        width: 100%;
        margin: 10% auto; }
        #special .itemList .block.double .credit p {
          font-size: 1.2em;
          letter-spacing: 0;
          line-height: 1.8;
          text-align: center; }
          @media screen and (max-width: 600px) {
            #special .itemList .block.double .credit p {
              font-size: 3.5vw; } }
  #special #staff {
    text-align: center;
    margin-bottom: 10%; }
    @media screen and (max-width: 600px) {
      #special #staff {
        margin: 20% auto 25%; } }
    #special #staff h3 {
      font-size: 1.2em;
      color: #6e9fdd;
      font-weight: 400;
      margin: 2.0em auto 1.0em; }
      @media screen and (max-width: 600px) {
        #special #staff h3 {
          font-size: 4.0vw;
          margin: 2.5em auto 0.7em; } }
    #special #staff .flex_box {
      display: flex;
      align-items: center;
      justify-content: space-between;
      flex-wrap: wrap;
      max-width: 300px;
      margin: 0 auto; }
      @media screen and (max-width: 600px) {
        #special #staff .flex_box {
          width: 60%; } }
      #special #staff .flex_box p {
        width: calc(100%/3 - 5%); }
    #special #staff p {
      line-height: 1.5;
      text-align: center;
      font-size: 1.0em; }
      @media screen and (max-width: 600px) {
        #special #staff p {
          font-size: 3.5vw; } }
      #special #staff p span {
        font-size: 100%;
        font-family: "ar-yuangbstd", sans-serif; }
  #special #l_footer {
    background: #a1c3e2;
    padding: 10% 0 14%;
    margin-bottom: 0;
    max-width: 100%; }
    @media screen and (max-width: 600px) {
      #special #l_footer {
        padding: 20% 8% 10%; } }
    #special #l_footer h2 {
      color: #ffffff; }
      @media screen and (max-width: 600px) {
        #special #l_footer h2 {
          font-size: 7.5vw;
          margin-bottom: 1.0em; } }
    #special #l_footer .f_Box {
      display: flex;
      align-items: center;
      justify-content: space-between;
      max-width: 1000px;
      margin: 0 auto; }
      @media screen and (max-width: 1080px) {
        #special #l_footer .f_Box {
          width: 80%;
          flex-wrap: wrap; } }
      @media screen and (max-width: 600px) {
        #special #l_footer .f_Box {
          width: 100%; } }
      #special #l_footer .f_Box div {
        width: 45%; }
        @media screen and (max-width: 1080px) {
          #special #l_footer .f_Box div {
            width: 100%;
            max-width: 500px;
            text-align: center;
            margin: 0 auto; } }
        #special #l_footer .f_Box div:last-child {
          width: calc(55% - 5%); }
          @media screen and (max-width: 1080px) {
            #special #l_footer .f_Box div:last-child {
              width: 100%;
              margin-top: 5%; } }
          @media screen and (max-width: 600px) {
            #special #l_footer .f_Box div:last-child {
              margin: 10% auto 20%; } }
        #special #l_footer .f_Box div p {
          color: #ffffff;
          font-size: 1.0em;
          font-family: "source-han-sans-japanese", sans-serif;
          line-height: 1.8;
          margin-bottom: 2.0em; }
          @media screen and (max-width: 1080px) {
            #special #l_footer .f_Box div p {
              text-align: left; } }
          @media screen and (max-width: 600px) {
            #special #l_footer .f_Box div p {
              font-size: 3.0vw;
              line-height: 2.2; } }
          #special #l_footer .f_Box div p.blue {
            color: #406996; }
        #special #l_footer .f_Box div a {
          color: #ffffff;
          font-size: 1.0em;
          border: 1px solid #ffffff;
          padding: 0.5em 1.5em;
          border-radius: 50vh;
          display: block;
          width: fit-content;
          margin: 2.0em 0 0 auto; }
          @media screen and (max-width: 1080px) {
            #special #l_footer .f_Box div a {
              margin: 4.0em auto 2.0em; } }
          @media screen and (max-width: 600px) {
            #special #l_footer .f_Box div a {
              font-size: 3.5vw; } }
          #special #l_footer .f_Box div a:hover {
            background: #ffffff;
            color: #a1c3e2; }
