@charset "UTF-8";
/****************************************

目次 
1.ベース
2.ヘッダー
3.フッター
4.トップページ

*****************************************/
/*レスポンシブ*/
/*フォントサイズ*/
/*Webフォント*/
@import url("https://use.typekit.net/mta2dsg.css");
@import url("https://fonts.googleapis.com/css?family=Noto+Sans+JP:100,300,400,500,700,900&display=swap");
/****************************************


1.ベース


*****************************************/
body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, figure {
  border: 0 none;
  font-style: normal;
  margin: 0;
  outline: 0 none;
  padding: 0;
  vertical-align: top;
  font-family: "Noto Sans JP","Noto Sans","Yu Gothic",YuGothic,"游ゴシック体","メイリオ",Meiryo,"ヒラギノ角ゴシック Pro","Hiragino Kaku Gothic Pro",Osaka,"ＭＳ Ｐゴシック","MS PGothic",sans-serif;
  text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  font-smoothing: antialiased;
  text-rendering: auto;
  font-size: clamp(16px, 1.6vw, 16px);
  color: #1A282E;
  -webkit-text-size-adjust: none; }

body {
  overflow-x: hidden; }

.inner {
  width: 85%;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box; }
  @media all and (max-width: 1280px) {
    .inner {
      width: 90%; } }
  @media all and (max-width: 768px) {
    .inner {
      width: 100%;
      padding-left: clamp(20px, 6vw, 32px);
      padding-right: clamp(20px, 6vw, 32px); } }

.innerS {
  width: 70%;
  max-width: 1000px;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box; }
  @media all and (max-width: 1280px) {
    .innerS {
      width: 90%;
      max-width: 90%; } }
  @media all and (max-width: 768px) {
    .innerS {
      width: 100%;
      max-width: 100%;
      padding-left: clamp(20px, 6vw, 32px);
      padding-right: clamp(20px, 6vw, 32px); } }

.innerL {
  width: 100%;
  padding-left: 80px;
  padding-right: 80px;
  box-sizing: border-box; }
  @media all and (max-width: 1280px) {
    .innerL {
      padding-left: 50px;
      padding-right: 50px; } }
  @media all and (max-width: 768px) {
    .innerL {
      padding-left: clamp(20px, 5vw, 32px);
      padding-right: clamp(20px, 5vw, 32px); } }

/*ボタン速度関係*/
a,
input[type=submit],
button {
  transition: all .5s ease-in; }
  a:before, a:after,
  input[type=submit]:before,
  input[type=submit]:after,
  button:before,
  button:after {
    transition: inherit; }
  a *,
  input[type=submit] *,
  button * {
    transition: inherit; }
    a *:before, a *:after,
    input[type=submit] *:before,
    input[type=submit] *:after,
    button *:before,
    button *:after {
      transition: inherit; }

.pc {
  display: block; }
  @media all and (max-width: 1024px) {
    .pc {
      display: none !important; } }

.sp {
  display: none !important; }
  @media all and (max-width: 1024px) {
    .sp {
      display: block !important; } }

/*インビュー関連*/
.inview {
  opacity: 0;
  transition: all 3000ms cubic-bezier(0.165, 0.84, 0.44, 1);
  transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
  transition-property: transform,opacity; }
  .inview.left {
    transform: translateX(-30px); }
  .inview.right {
    transform: translateX(30px); }
  .inview.bottom {
    transform: translateY(20px); }
  .inview.action {
    opacity: 1;
    transform: translate(0px); }

/*テキスト関連*/
.center {
  text-align: center; }

.under {
  text-decoration: underline; }

b, stlong, .bold {
  font-weight: bold; }

.postCn {
  font-size: clamp(16px, 1.6vw, 16px);
  line-height: 2; }
  .postCn * {
    font-size: clamp(16px, 1.6vw, 16px);
    line-height: 2; }
  .postCn h1 {
    font-size: 2em;
    line-height: 1.2;
    font-weight: bold;
    margin: 0 0 .75rem; }
  .postCn h2 {
    font-size: 1.5em;
    font-weight: bold;
    line-height: 1.6;
    margin: 0 0 .66rem 0; }
  .postCn h3 {
    font-size: 1.17em;
    line-height: 1.8;
    font-weight: bold;
    margin: 0 0 .66rem 0; }
  .postCn h4 {
    font-size: 0.83em;
    line-height: 2;
    font-weight: bold;
    margin: 0 0 .66rem 0; }
  .postCn h5 {
    font-size: 0.83em;
    line-height: 2;
    font-weight: bold;
    margin: 0 0 .66rem 0; }
  .postCn h6 {
    font-size: 0.67em;
    line-height: 2;
    font-weight: bold;
    margin: 0 0 .66rem 0; }
  .postCn p {
    margin-bottom: 20px; }
  .postCn strong {
    font-weight: bold; }
    .postCn strong * {
      font-weight: bold; }
  .postCn em {
    font-style: italic; }
    .postCn em * {
      font-style: italic; }
  .postCn a {
    color: #e94b4b;
    display: inline;
    transition: 0.5s; }
    .postCn a * {
      color: #e94b4b; }
    .postCn a:hover {
      color: #e94b4b;
      text-decoration: underline; }
  .postCn img {
    margin-bottom: 20px; }
  .postCn iframe {
    margin-bottom: 20px; }
  .postCn ul {
    margin-bottom: 20px; }
    .postCn ul li {
      list-style: circle;
      list-style-position: inside; }
  .postCn ol {
    margin-bottom: 20px; }
    .postCn ol li {
      list-style-type: decimal;
      list-style-position: inside; }
  .postCn table {
    margin-bottom: 20px; }

/*フォント*/
.en1 {
  font-family: "the-seasons", sans-serif;
  font-weight: 700;
  font-style: normal; }

.en2 {
  font-family: "gotham", sans-serif;
  font-weight: 400;
  font-style: normal; }

/*フォーム関連*/
input[type=password],
input[type=text],
input[type=date],
input[type=email],
input[type=number],
input[type=url],
input[type=tel],
textarea,
select {
  border: 0;
  background: #F7F8F9;
  border-radius: 5px;
  color: #3F484C;
  padding: 18px 18px 18px;
  width: 100%;
  box-sizing: border-box;
  -webkit-appearance: none;
  font-size: 16px;
  font-family: 'Noto Serif JP', '游明朝', 'Yu Mincho', 'ヒラギノ明朝 ProN', 'Hiragino Mincho ProN', 'MS P明朝', 'MS PMincho', serif; }

.wpcf7-checkbox {
  display: flex;
  flex-direction: column; }
  .wpcf7-checkbox span {
    margin-left: 0;
    margin-bottom: 10px; }
  .wpcf7-checkbox label {
    margin-left: 0; }

textarea {
  min-height: 100%; }

input, select, textarea {
  outline: none; }

input:disabled {
  background: none;
  font-weight: bold; }

input[type="checkbox"] {
  width: 26px;
  height: 26px;
  -webkit-appearance: none;
  -moz-appearance: none;
  -ms-appearance: none;
  -o-appearance: none;
  appearance: none;
  position: relative;
  transition: all .15s ease-out 0s;
  color: #46ADDF;
  cursor: pointer;
  display: inline-block;
  outline: none;
  border-radius: 0;
  vertical-align: -0.5rem;
  margin: 0 10px 0 0; }

input[type=checkbox]:before,
input[type=checkbox]:after {
  position: absolute;
  content: "";
  background: #fff;
  transition: all .2s ease-in-out; }

input[type=checkbox]:before {
  left: 2px;
  top: 6px;
  width: 0;
  height: 2px;
  transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  -o-transform: rotate(45deg); }

input[type=checkbox]:after {
  right: 9px;
  bottom: 3px;
  width: 2px;
  height: 0;
  transform: rotate(40deg);
  -webkit-transform: rotate(40deg);
  -moz-transform: rotate(40deg);
  -ms-transform: rotate(40deg);
  -o-transform: rotate(40deg);
  transition-delay: .2s; }

input[type=checkbox]:checked:before {
  left: 1px;
  top: 12px;
  width: 11px;
  height: 3px; }

input[type=checkbox]:checked:after {
  right: 6px;
  bottom: 2px;
  width: 3px;
  height: 17px; }

input[type=checkbox]:indeterminate:before,
input[type=checkbox]:indeterminate:after {
  width: 10px;
  height: 2px;
  transform: rotate(0);
  -webkit-transform: rotate(0);
  -moz-transform: rotate(0);
  -ms-transform: rotate(0);
  -o-transform: rotate(0); }

input[type=checkbox]:indeterminate:before {
  left: 1px;
  top: 7px; }

input[type=checkbox]:indeterminate:after {
  right: 1px;
  bottom: 7px; }

input[type=checkbox] {
  border: 2px solid #ABABAB; }

input[type=checkbox]:checked,
input[type=checkbox]:checked {
  border: 2px solid #E52D2D; }

input[type=checkbox]:checked:after,
input[type=checkbox]:checked:before,
input[type=checkbox]:indeterminate:after,
input[type=checkbox]:indeterminate:before {
  background: #E52D2D; }

label {
  margin-left: 10px; }

.mailform {
  max-width: 600px;
  width: 90%;
  margin: 0 auto; }
  .mailform dl {
    display: flex;
    flex-direction: column;
    padding-top: 10px;
    padding-bottom: 10px; }
    .mailform dl dt {
      width: 100%;
      display: flex;
      margin-bottom: 10px; }
    .mailform dl > dt p span {
      font-size: 16px;
      font-weight: bold; }
    .mailform dl dd {
      width: 100%;
      box-sizing: border-box;
      display: flex;
      justify-content: space-between; }
      .mailform dl dd p {
        width: 100%; }
      .mailform dl dd .wrap {
        width: calc( ( 100% - 20px ) / 2 ); }
        @media all and (max-width: 1024px) {
          .mailform dl dd .wrap {
            width: calc( ( 100% - 10px ) / 2 ); } }
        .mailform dl dd .wrap span {
          width: 100%;
          padding-bottom: 5px;
          display: block; }
        .mailform dl dd .wrap > div {
          display: flex;
          margin-bottom: 5px; }
          .mailform dl dd .wrap > div p {
            display: inline-block;
            width: auto; }
      @media all and (max-width: 1024px) {
        .mailform dl dd.kibo .wrap:nth-child(1) {
          width: calc( 60% - 10px ); } }
      @media all and (max-width: 1024px) {
        .mailform dl dd.kibo .wrap:nth-child(2) {
          width: 40%; } }
  .mailform input[type="submit"] {
    border: 0;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    -webkit-appearance: none;
    background: #E52D2D;
    padding: 15px 30px;
    border-radius: 100px;
    margin-top: 40px;
    color: #FFF;
    cursor: pointer; }
  .mailform input[type="submit"][disabled] {
    background-color: #ccc;
    cursor: not-allowed;
    opacity: 0.6; }
  .mailform .wpcf7-not-valid-tip {
    margin-top: 10px; }
    .mailform .wpcf7-not-valid-tip span {
      color: #E91C24;
      font-size: 14px;
      display: block; }
  .mailform .naiyo + p {
    display: flex;
    justify-content: center; }
  .mailform .wpcf7-acceptance {
    text-align: center; }
    .mailform .wpcf7-acceptance .wpcf7-list-item {
      margin: 0; }
      .mailform .wpcf7-acceptance .wpcf7-list-item span {
        width: calc( 100% - 36px );
        display: inline-block;
        margin-left: 0;
        font-size: 14px;
        font-weight: bold;
        text-align: left; }
      .mailform .wpcf7-acceptance .wpcf7-list-item label {
        margin-left: 0;
        display: flex;
        align-items: center;
        justify-content: center; }
      .mailform .wpcf7-acceptance .wpcf7-list-item input[type=checkbox] {
        margin-right: 10px; }
  .mailform .naiyo {
    margin-bottom: 40px; }
  .mailform .textarea dt {
    align-items: flex-start;
    margin-top: 10px; }
  .mailform .hissu p {
    color: #eb3e41; }
  .mailform .cf7-hidden {
    position: absolute !important;
    left: -10000px !important;
    width: 1px !important;
    height: 1px !important;
    opacity: 0 !important;
    pointer-events: none !important; }
  .mailform .alert {
    font-size: 13px;
    margin-bottom: 20px;
    display: flex; }
  .mailform .select-wrap {
    position: relative;
    display: inline-block;
    width: 100%; }
    .mailform .select-wrap:after {
      content: "";
      position: absolute;
      right: 15px;
      top: 50%;
      width: 7px;
      height: 7px;
      border-right: 1px solid #959595;
      border-bottom: 1px solid #959595;
      transform: translateY(-50%) rotate(45deg);
      transition: transform 0.3s ease;
      pointer-events: none; }
    .mailform .select-wrap p {
      width: 100% !important; }
  .mailform input::placeholder {
    color: #959595; }

.cnTit {
  font-family: "the-seasons", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: clamp(26px, 3vw, 32px);
  letter-spacing: 0.1em;
  line-height: 0.8;
  text-align: center;
  position: relative;
  margin-bottom: clamp(130px, 15vw, 165px); }
  .cnTit::after {
    content: "";
    position: absolute;
    top: 55px;
    left: 50%;
    transform: translateX(-50%);
    width: 1px;
    height: 100px;
    background: #000; }
    @media all and (max-width: 1024px) {
      .cnTit::after {
        top: 45px;
        height: 75px; } }

.circleBtn {
  display: inline-block;
  padding: 5px 15px;
  border: 1px solid #000;
  border-radius: 9999px;
  background: #FFF;
  cursor: pointer; }
  .circleBtn span {
    display: flex;
    align-items: center;
    font-size: clamp(14px, 1.4vw, 14px);
    letter-spacing: 0.025em;
    line-height: 1.2; }
    .circleBtn span::after {
      content: "";
      display: block;
      width: 6px;
      height: 6px;
      border-top: 1.5px solid currentColor;
      border-right: 1.5px solid currentColor;
      transform: rotate(45deg);
      margin-left: 15px; }
  .circleBtn:hover {
    border: 1px solid #FFF;
    background: #000; }
    .circleBtn:hover span {
      color: #FFF; }

.bnrBtn {
  position: fixed;
  bottom: 25%;
  right: 0;
  z-index: 2000;
  background: #D90D0D;
  border-radius: 10px 0 0 10px;
  border: 1px solid #FFF;
  width: 62px;
  height: 162px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center; }
  @media all and (max-width: 1024px) {
    .bnrBtn {
      bottom: 20px;
      right: 50%;
      transform: translateX(50%);
      width: 328px;
      height: 67px;
      border-radius: 10px;
      border: none; } }
  .bnrBtn:hover {
    background: #AC0A0A; }
  .bnrBtn .bnrInner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    transform: rotate(-90deg); }
    @media all and (max-width: 1024px) {
      .bnrBtn .bnrInner {
        transform: rotate(0deg);
        gap: 2px; } }
  .bnrBtn .bnrTxt {
    color: #FFF;
    white-space: nowrap;
    line-height: 1.2; }
    .bnrBtn .bnrTxt.en1 {
      font-size: clamp(18px, 3vw, 20px);
      font-weight: bold;
      letter-spacing: 0.05em; }
    .bnrBtn .bnrTxt.ja {
      font-size: clamp(14px, 1.4vw, 14px);
      letter-spacing: 0.1em; }

.toTop {
  opacity: 0;
  visibility: hidden;
  transition: 0.8s;
  width: 55px;
  height: 55px;
  background-color: rgba(255, 255, 255, 0.3);
  backdrop-filter: blur(12px);
  border-radius: 99px;
  border: 1px solid #000;
  position: fixed;
  bottom: 45px;
  right: 50px;
  z-index: 999;
  display: flex;
  align-items: center;
  justify-content: center; }
  @media all and (max-width: 1024px) {
    .toTop {
      display: none; } }
  .toTop.show {
    opacity: 1;
    visibility: visible; }
  .toTop span {
    position: relative;
    width: 27px;
    height: 20px; }
    .toTop span::before, .toTop span::after {
      content: "";
      position: absolute;
      top: 8px;
      width: 16px;
      height: 1px;
      background: #000; }
    .toTop span::before {
      left: 0;
      transform: rotate(-45deg); }
    .toTop span::after {
      right: 0;
      transform: rotate(45deg); }
  .toTop:hover {
    background-color: rgba(0, 0, 0, 0.3); }
    .toTop:hover::before, .toTop:hover::after {
      background: #FFF; }

/****************************************


2.ヘッダー


*****************************************/
.logo {
  position: absolute;
  left: 80px;
  top: 30px;
  z-index: 1000; }
  @media all and (max-width: 1024px) {
    .logo {
      width: 38%;
      position: absolute;
      top: 30px;
      left: 6vw; } }
  .logo.open {
    position: fixed; }

header {
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 999;
  display: flex;
  gap: 60px; }
  @media all and (max-width: 1024px) {
    header {
      background: rgba(0, 0, 0, 0.8);
      height: 0; } }
  header .innerL {
    display: flex;
    justify-content: center;
    align-items: center;
    padding-top: 30px;
    padding-bottom: 30px;
    box-sizing: border-box; }
    @media all and (max-width: 1024px) {
      header .innerL {
        flex-direction: column;
        justify-content: flex-start;
        padding: 0; } }
  header .navBtn {
    position: absolute;
    right: 6vw;
    top: 30px;
    z-index: 1001;
    width: 40px;
    height: 40px;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    background: #000;
    border: 1px solid #FFF;
    border-radius: 100px;
    display: none; }
    @media all and (max-width: 1024px) {
      header .navBtn {
        display: inline-flex; } }
    header .navBtn span {
      position: absolute;
      left: 10px;
      right: 10px;
      height: 1px;
      background: #FFFCF4;
      transition: transform .6s, opacity .6s;
      transform-origin: center; }
      header .navBtn span:nth-child(1) {
        transform: translateY(-7px); }
      header .navBtn span:nth-child(2) {
        transform: translateY(0); }
      header .navBtn span:nth-child(3) {
        transform: translateY(7px); }
    header .navBtn.open {
      background: rgba(0, 0, 0, 0);
      border: none; }
      header .navBtn.open span {
        background: #FFF;
        left: 0;
        right: 0;
        height: 2px; }
        header .navBtn.open span:nth-child(1) {
          transform: translateY(0) rotate(32deg); }
        header .navBtn.open span:nth-child(2) {
          opacity: 0; }
        header .navBtn.open span:nth-child(3) {
          transform: translateY(0) rotate(-32deg); }
  header nav {
    backdrop-filter: blur(12px);
    background-color: rgba(255, 255, 255, 0.35);
    border-radius: 80px;
    padding: 5px 10px;
    box-sizing: border-box; }
    @media all and (max-width: 1024px) {
      header nav {
        backdrop-filter: blur(0);
        background-color: rgba(255, 255, 255, 0);
        padding: 0;
        opacity: 0;
        transition: opacity .25s, visibility .25s;
        visibility: hidden; } }
    header nav ul {
      display: flex;
      align-items: center;
      gap: 20px; }
      @media all and (max-width: 1024px) {
        header nav ul {
          flex-direction: column;
          align-items: baseline;
          gap: 10px;
          margin-bottom: 30px; } }
      header nav ul li a {
        background-color: rgba(0, 0, 0, 0);
        padding: 5px 10px;
        box-sizing: border-box;
        border-radius: 99px; }
        @media all and (max-width: 1024px) {
          header nav ul li a {
            font-size: clamp(20px, 2.2vw, 24px);
            letter-spacing: 0.05em;
            line-height: 2.4;
            color: #FFF;
            display: flex;
            align-items: center;
            gap: 25px; }
            header nav ul li a::before {
              content: "";
              display: inline-block;
              border-bottom: 1px solid #FFF;
              width: 50px;
              height: 1px; } }
        header nav ul li a:hover {
          background-color: #000;
          color: #FFF; }
  header .headSns {
    opacity: 1;
    transition: opacity .25s, visibility .25s;
    position: fixed;
    top: 30px;
    right: 80px; }
    @media all and (max-width: 1024px) {
      header .headSns {
        opacity: 0;
        visibility: hidden;
        position: relative;
        top: auto;
        right: auto; } }
    header .headSns ul {
      display: flex;
      align-items: center;
      gap: 15px; }
      @media all and (max-width: 1024px) {
        header .headSns ul {
          gap: 25px; } }
      header .headSns ul li a {
        width: 33px;
        height: 33px;
        background-position: center;
        background-repeat: no-repeat;
        background-size: auto; }
        @media all and (max-width: 1024px) {
          header .headSns ul li a {
            width: 50px;
            height: 50px; } }
      header .headSns ul li .telIcon {
        background-image: url("img/iconTel.svg"); }
        @media all and (max-width: 1024px) {
          header .headSns ul li .telIcon {
            background-image: url("img/iconTelSp.svg"); } }
        header .headSns ul li .telIcon:hover {
          background-image: url("img/iconTelW.svg"); }
          @media all and (max-width: 1024px) {
            header .headSns ul li .telIcon:hover {
              background-image: url("img/iconTelSp.svg"); } }
      header .headSns ul li .mailIcon {
        background-image: url("img/iconMail.svg"); }
        @media all and (max-width: 1024px) {
          header .headSns ul li .mailIcon {
            background-image: url("img/iconMailSp.svg"); } }
        header .headSns ul li .mailIcon:hover {
          background-image: url("img/iconMailW.svg"); }
          @media all and (max-width: 1024px) {
            header .headSns ul li .mailIcon:hover {
              background-image: url("img/iconMailSp.svg"); } }
      header .headSns ul li .instaIcon {
        background-image: url("img/iconInstagram.svg"); }
        @media all and (max-width: 1024px) {
          header .headSns ul li .instaIcon {
            background-image: url("img/iconInstagramSp.svg"); } }
        header .headSns ul li .instaIcon:hover {
          background-image: url("img/iconInstagramW.svg"); }
          @media all and (max-width: 1024px) {
            header .headSns ul li .instaIcon:hover {
              background-image: url("img/iconInstagramSp.svg"); } }
      header .headSns ul li .youtubeIcon {
        background-image: url("img/iconYoutube.svg"); }
        @media all and (max-width: 1024px) {
          header .headSns ul li .youtubeIcon {
            background-image: url("img/iconYoutubeSp.svg"); } }
        header .headSns ul li .youtubeIcon:hover {
          background-image: url("img/iconYoutubeW.svg"); }
          @media all and (max-width: 1024px) {
            header .headSns ul li .youtubeIcon:hover {
              background-image: url("img/iconYoutubeSp.svg"); } }
  @media all and (max-width: 1024px) {
    header.open {
      width: 100%;
      height: 100vh; } }
  @media all and (max-width: 1024px) {
    header.open nav {
      opacity: 1;
      padding-top: 140px;
      visibility: visible; } }
  @media all and (max-width: 1024px) {
    header.open .headSns {
      opacity: 1;
      margin-top: 25px;
      visibility: visible; } }

/****************************************


3.フッター


*****************************************/
footer {
  background-color: #000;
  padding: 60px 0; }
  @media all and (max-width: 1024px) {
    footer {
      padding: 100px 0 140px; } }
  footer .wrap {
    display: flex;
    justify-content: space-between;
    align-items: center; }
    @media all and (max-width: 1024px) {
      footer .wrap {
        flex-direction: column;
        justify-content: center; } }
    @media all and (max-width: 1024px) {
      footer .wrap .footLogo {
        margin-bottom: 80px; } }
    @media all and (max-width: 1024px) {
      footer .wrap .footerSub {
        width: 100%;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center; } }
    footer .wrap .footerSub .actions {
      margin-bottom: 30px; }
      @media all and (max-width: 1024px) {
        footer .wrap .footerSub .actions {
          margin-bottom: 40px; } }
      footer .wrap .footerSub .actions .actionsBtn {
        display: flex;
        align-items: center;
        margin-bottom: 10px; }
        footer .wrap .footerSub .actions .actionsBtn::before {
          content: "";
          width: 14px;
          height: 14px;
          background-position: center;
          background-repeat: no-repeat;
          background-size: 100%; }
          @media all and (max-width: 1024px) {
            footer .wrap .footerSub .actions .actionsBtn::before {
              width: 13px;
              height: 13px; } }
        footer .wrap .footerSub .actions .actionsBtn span {
          line-height: 1.4;
          color: #FFF;
          padding-left: 15px; }
          @media all and (max-width: 1024px) {
            footer .wrap .footerSub .actions .actionsBtn span {
              font-size: clamp(12px, 1.2vw, 12px); } }
        footer .wrap .footerSub .actions .actionsBtn.insta::before {
          background-image: url("img/iconInstagramWFooter.svg"); }
        footer .wrap .footerSub .actions .actionsBtn.tel::before {
          background-image: url("img/iconTelWFooter.svg"); }
        footer .wrap .footerSub .actions .actionsBtn.mail::before {
          background-image: url("img/icoMailWFooter.svg"); }
    footer .wrap .footerSub .privacy {
      display: block;
      margin-bottom: 20px; }
      @media all and (max-width: 1024px) {
        footer .wrap .footerSub .privacy {
          margin-bottom: 50px; } }
      footer .wrap .footerSub .privacy span {
        line-height: 1;
        color: #FFF;
        border-bottom: 1px solid #FFF; }
    @media all and (max-width: 1024px) {
      footer .wrap .footerSub .weddingCircusLogo {
        margin-bottom: 10px; } }
    footer .wrap .footerSub .copy {
      line-height: 1;
      color: #FFF;
      font-size: clamp(11px, 1.1vw, 11px); }

/****************************************


4.トップページ


*****************************************/
.mv {
  margin-bottom: clamp(100px, 10vw, 165px);
  width: 100%;
  height: 100vh;
  position: relative;
  z-index: 1; }
  .mv video {
    width: 100%;
    height: 100%;
    object-fit: cover; }

.cn1 {
  padding-bottom: clamp(30px, 6.5vw, 150px); }
  .cn1 .inner {
    display: flex;
    flex-direction: column;
    align-items: center; }
  .cn1 .heroTit {
    text-align: center;
    margin-bottom: clamp(112px, 12vw, 145px); }
    .cn1 .heroTit span {
      display: block; }
    .cn1 .heroTit .en1 {
      font-size: clamp(42px, 5.2vw, 60px);
      line-height: 1;
      letter-spacing: 0.05em;
      margin-bottom: 25px; }
    .cn1 .heroTit .en2 {
      font-size: clamp(18px, 2.5vw, 26px);
      letter-spacing: 0.05em; }
  .cn1 .img {
    margin-bottom: clamp(80px, 10vw, 100px); }
  .cn1 .txtWrap {
    text-align: center; }
    .cn1 .txtWrap p {
      letter-spacing: 0.1em;
      line-height: 2.5;
      margin-bottom: 40px; }
      @media all and (max-width: 1024px) {
        .cn1 .txtWrap p {
          font-size: clamp(14px, 1.4vw, 14px);
          line-height: 1.9; } }
      .cn1 .txtWrap p:nth-child(1) {
        margin-bottom: 0; }
        @media all and (max-width: 1024px) {
          .cn1 .txtWrap p:nth-child(1) {
            margin-bottom: 15px; } }
    .cn1 .txtWrap h3 {
      font-size: clamp(30px, 3.5vw, 40px);
      letter-spacing: 0.05em;
      line-height: 1.5;
      margin-bottom: 30px; }
      @media all and (max-width: 1024px) {
        .cn1 .txtWrap h3 {
          line-height: 1.2;
          margin-bottom: 20px; } }
    .cn1 .txtWrap .moreText {
      max-height: 0;
      overflow: hidden;
      opacity: 0;
      transition: max-height .8s ease, opacity .8s ease; }
    .cn1 .txtWrap .moreText.is-open {
      max-height: 3000px;
      opacity: 1; }

.cn2 {
  padding-top: clamp(60px, 6.5vw, 150px);
  padding-bottom: clamp(60px, 6.5vw, 150px); }
  .cn2 .cn2Swiper {
    height: 564px;
    margin-bottom: 60px; }
    .cn2 .cn2Swiper .swiper-wrapper {
      height: 100%; }
      .cn2 .cn2Swiper .swiper-wrapper .swiper-slide {
        height: 100%; }
        .cn2 .cn2Swiper .swiper-wrapper .swiper-slide a {
          position: relative;
          height: 100%;
          width: 100%;
          background-size: cover;
          background-position: center;
          background-repeat: no-repeat;
          overflow: hidden;
          border-radius: 20px;
          display: flex;
          justify-content: center;
          align-items: center; }
          .cn2 .cn2Swiper .swiper-wrapper .swiper-slide a.sp {
            display: none !important; }
            @media all and (max-width: 1024px) {
              .cn2 .cn2Swiper .swiper-wrapper .swiper-slide a.sp {
                display: flex !important; } }
          .cn2 .cn2Swiper .swiper-wrapper .swiper-slide a:before {
            content: "";
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background: rgba(0, 0, 0, 0.3);
            pointer-events: none; }
          .cn2 .cn2Swiper .swiper-wrapper .swiper-slide a span {
            position: relative;
            z-index: 2;
            color: #FFF;
            font-size: clamp(20px, 4.2vw, 34px);
            line-height: 1.6;
            letter-spacing: 0.05em;
            text-align: center; }
    .cn2 .cn2Swiper .swiper-button-next,
    .cn2 .cn2Swiper .swiper-button-prev {
      position: absolute;
      width: 30px;
      height: 30px;
      background-repeat: no-repeat;
      background-position: center;
      background-size: contain;
      z-index: 10;
      transition: 0.8s; }
      .cn2 .cn2Swiper .swiper-button-next:hover,
      .cn2 .cn2Swiper .swiper-button-prev:hover {
        opacity: 0.8; }
    .cn2 .cn2Swiper .swiper-button-next {
      right: 75px;
      background-image: url("img/iconNext.svg"); }
      @media all and (max-width: 1024px) {
        .cn2 .cn2Swiper .swiper-button-next {
          right: 30px; } }
    .cn2 .cn2Swiper .swiper-button-prev {
      left: 75px;
      background-image: url("img/iconPrev.svg"); }
      @media all and (max-width: 1024px) {
        .cn2 .cn2Swiper .swiper-button-prev {
          left: 30px; } }
    .cn2 .cn2Swiper .swiper-button-next::after,
    .cn2 .cn2Swiper .swiper-button-prev::after {
      display: none; }
  .cn2 .venueList .box + .box {
    margin-top: 60px; }
  .cn2 .venueList .box .info {
    background: #000;
    padding-top: clamp(60px, 6.5vw, 80px);
    padding-bottom: clamp(10px, 4.5vw, 80px); }
    @media all and (max-width: 1024px) {
      .cn2 .venueList .box .info {
        padding-top: 0; } }
    .cn2 .venueList .box .info .innerL {
      display: flex;
      align-items: center;
      gap: 80px; }
      @media all and (max-width: 1024px) {
        .cn2 .venueList .box .info .innerL {
          flex-direction: column;
          padding: 0;
          gap: 0; } }
      .cn2 .venueList .box .info .innerL .img {
        width: 45%;
        max-width: 552px;
        height: 296px; }
        @media all and (max-width: 1024px) {
          .cn2 .venueList .box .info .innerL .img {
            width: 100%;
            max-width: 100%;
            height: auto; } }
        .cn2 .venueList .box .info .innerL .img img {
          height: 100%;
          width: 100%;
          object-fit: cover; }
      .cn2 .venueList .box .info .innerL .txtWrap * {
        color: #FFFFFF; }
      @media all and (max-width: 1024px) {
        .cn2 .venueList .box .info .innerL .txtWrap {
          text-align: center;
          padding: 0 5%;
          transform: translateY(-19px); } }
      .cn2 .venueList .box .info .innerL .txtWrap h3 {
        font-size: clamp(30px, 4.2vw, 34px);
        letter-spacing: 0.05em;
        margin-bottom: 30px; }
      .cn2 .venueList .box .info .innerL .txtWrap .txt {
        line-height: 1.7;
        letter-spacing: 0.1em;
        margin-bottom: 50px; }
        @media all and (max-width: 1024px) {
          .cn2 .venueList .box .info .innerL .txtWrap .txt p {
            font-size: clamp(14px, 1.4vw, 14px); } }
      @media all and (max-width: 1024px) {
        .cn2 .venueList .box .info .innerL .txtWrap .infoItem {
          margin-bottom: 50px; } }
      .cn2 .venueList .box .info .innerL .txtWrap .infoItem dl {
        display: flex;
        gap: 20px; }
        @media all and (max-width: 1024px) {
          .cn2 .venueList .box .info .innerL .txtWrap .infoItem dl {
            flex-direction: column;
            justify-content: center;
            align-items: center;
            gap: 0;
            margin-bottom: 15px; } }
        .cn2 .venueList .box .info .innerL .txtWrap .infoItem dl dt {
          letter-spacing: 0.1em;
          width: 100px; }
          @media all and (max-width: 1024px) {
            .cn2 .venueList .box .info .innerL .txtWrap .infoItem dl dt {
              width: 100%;
              position: relative; }
              .cn2 .venueList .box .info .innerL .txtWrap .infoItem dl dt::before {
                content: "";
                border-bottom: 1px solid #FFF;
                width: 85%;
                height: 1px;
                display: block;
                position: absolute;
                bottom: 50%;
                left: 50%;
                transform: translateX(-50%); } }
          @media all and (max-width: 1024px) {
            .cn2 .venueList .box .info .innerL .txtWrap .infoItem dl dt span {
              background-color: #000;
              padding: 0 10px;
              position: sticky; } }
        .cn2 .venueList .box .info .innerL .txtWrap .infoItem dl dd {
          letter-spacing: 0.1em;
          width: calc( 100% - 100px );
          position: relative; }
          @media all and (max-width: 1024px) {
            .cn2 .venueList .box .info .innerL .txtWrap .infoItem dl dd {
              width: 100%;
              text-align: center; } }
          .cn2 .venueList .box .info .innerL .txtWrap .infoItem dl dd::before {
            content: ": ";
            position: absolute;
            left: 0;
            top: 0.55em;
            transform: translateY(-50%); }
            @media all and (max-width: 1024px) {
              .cn2 .venueList .box .info .innerL .txtWrap .infoItem dl dd::before {
                display: none; } }
          .cn2 .venueList .box .info .innerL .txtWrap .infoItem dl dd span {
            display: block;
            padding-left: 30px; }
            @media all and (max-width: 1024px) {
              .cn2 .venueList .box .info .innerL .txtWrap .infoItem dl dd span {
                padding-left: 0; } }
          .cn2 .venueList .box .info .innerL .txtWrap .infoItem dl dd a {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 10px;
            padding: 6px 15px;
            color: #fff;
            text-decoration: none;
            border: 1px solid #fff;
            border-radius: 999px;
            background: transparent;
            transition: background-color .8s ease-in-out;
            font-size: 13px;
            line-height: 1.2;
            margin-left: 30px;
            margin-top: 10px; }
            @media all and (max-width: 1024px) {
              .cn2 .venueList .box .info .innerL .txtWrap .infoItem dl dd a {
                margin-left: 0; } }
            .cn2 .venueList .box .info .innerL .txtWrap .infoItem dl dd a::after {
              content: "";
              width: 6px;
              height: 6px;
              border-top: 1.5px solid currentColor;
              border-right: 1.5px solid currentColor;
              transform: rotate(45deg);
              margin-top: 1px; }
            .cn2 .venueList .box .info .innerL .txtWrap .infoItem dl dd a:hover {
              background-color: rgba(255, 255, 255, 0.15); }
      .cn2 .venueList .box .info .innerL .txtWrap .backToList {
        display: flex;
        justify-content: flex-end;
        align-items: center; }
        .cn2 .venueList .box .info .innerL .txtWrap .backToList:hover {
          opacity: 0.7; }
        .cn2 .venueList .box .info .innerL .txtWrap .backToList::before {
          content: "";
          background-image: url("img/iconUpperArrow.svg");
          background-repeat: no-repeat;
          background-size: cover;
          width: 24px;
          height: 24px;
          display: inline-block; }
        .cn2 .venueList .box .info .innerL .txtWrap .backToList span {
          padding-left: 10px; }
  .cn2 .venueList .box .boxSwiper {
    background: linear-gradient(to bottom, #000 0%, #000 60%, #fff 60%, #fff 100%);
    padding-left: 80px; }
    .cn2 .venueList .box .boxSwiper .swiper-wrapper {
      height: 100%; }
      .cn2 .venueList .box .boxSwiper .swiper-wrapper .swiper-slide {
        height: 100%; }
        .cn2 .venueList .box .boxSwiper .swiper-wrapper .swiper-slide a {
          position: relative;
          height: 100%;
          width: 100%;
          background-size: cover;
          background-position: center;
          background-repeat: no-repeat;
          overflow: hidden;
          border-radius: 20px;
          display: flex;
          justify-content: center;
          align-items: center; }
    .cn2 .venueList .box .boxSwiper .swiper-button-next,
    .cn2 .venueList .box .boxSwiper .swiper-button-prev {
      position: absolute;
      width: 30px;
      height: 30px;
      background-repeat: no-repeat;
      background-position: center;
      background-size: contain;
      z-index: 10;
      transition: 0.8s; }
      .cn2 .venueList .box .boxSwiper .swiper-button-next:hover,
      .cn2 .venueList .box .boxSwiper .swiper-button-prev:hover {
        opacity: 0.8; }
    .cn2 .venueList .box .boxSwiper .swiper-button-next {
      right: 75px;
      background-image: url("img/iconNext.svg"); }
      @media all and (max-width: 1024px) {
        .cn2 .venueList .box .boxSwiper .swiper-button-next {
          right: 30px; } }
    .cn2 .venueList .box .boxSwiper .swiper-button-prev {
      left: 75px;
      background-image: url("img/iconPrev.svg"); }
      @media all and (max-width: 1024px) {
        .cn2 .venueList .box .boxSwiper .swiper-button-prev {
          left: 30px; } }
    .cn2 .venueList .box .boxSwiper .swiper-button-next::after,
    .cn2 .venueList .box .boxSwiper .swiper-button-prev::after {
      display: none; }

.cn3 {
  padding-top: clamp(80px, 6.5vw, 150px);
  padding-bottom: clamp(60px, 6.5vw, 150px); }
  .cn3 .innerL {
    padding-bottom: clamp(55px, 5.3vw, 75px); }
    @media all and (max-width: 1024px) {
      .cn3 .innerL {
        display: flex;
        flex-direction: column;
        align-items: center; } }
  .cn3 .tit {
    font-size: clamp(26px, 3vw, 32px);
    letter-spacing: 0.1em;
    line-height: 0.8;
    text-align: center;
    padding-bottom: 50px; }
  .cn3 .innerS {
    display: flex;
    flex-direction: column;
    align-items: center; }
    .cn3 .innerS .circleBtn {
      margin-top: 50px; }

.cn4 .cnTit {
  margin-bottom: clamp(140px, 14vw, 165px); }
  .cn4 .cnTit span {
    display: block; }
  .cn4 .cnTit .en {
    font-family: "the-seasons", sans-serif;
    font-weight: 700;
    font-style: normal;
    font-size: clamp(26px, 3vw, 32px);
    letter-spacing: 0.1em;
    line-height: 1.8;
    margin-bottom: 15px; }
    @media all and (max-width: 1024px) {
      .cn4 .cnTit .en {
        margin-bottom: 0; } }
  .cn4 .cnTit .ja1 {
    font-size: clamp(14px, 1.6vw, 18px);
    font-weight: normal;
    letter-spacing: 0.05em;
    line-height: 1.8; }
  .cn4 .cnTit .ja2 {
    font-size: clamp(12px, 1.4vw, 15px);
    font-weight: normal;
    letter-spacing: 0.05em;
    line-height: 1.8; }
  .cn4 .cnTit::after {
    top: 160px; }
    @media all and (max-width: 1024px) {
      .cn4 .cnTit::after {
        top: 120px; } }
.cn4 .wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 110px; }
  @media all and (max-width: 1024px) {
    .cn4 .wrap {
      flex-direction: column;
      gap: 60px; } }
  .cn4 .wrap .txtWrap {
    width: 30%; }
    @media all and (max-width: 1024px) {
      .cn4 .wrap .txtWrap {
        width: 100%;
        text-align: center; } }
    .cn4 .wrap .txtWrap .tit {
      font-size: clamp(26px, 3vw, 32px);
      letter-spacing: 0.1em;
      line-height: 0.8;
      padding-bottom: clamp(30px, 4vw, 50px); }
    .cn4 .wrap .txtWrap p {
      letter-spacing: 0.05em;
      line-height: 1.5;
      padding-bottom: 20px; }
      @media all and (max-width: 1024px) {
        .cn4 .wrap .txtWrap p {
          font-size: clamp(14px, 1.4vw, 14px); } }
      .cn4 .wrap .txtWrap p:nth-child(3) {
        font-size: clamp(12px, 1.3vw, 14px); }
    .cn4 .wrap .txtWrap .tel {
      display: block;
      margin-bottom: 30px; }
      .cn4 .wrap .txtWrap .tel span {
        letter-spacing: 0.05em;
        line-height: 1.5; }
  .cn4 .wrap .map {
    width: calc(70% - 110px);
    aspect-ratio: 550 / 370; }
    @media all and (max-width: 1024px) {
      .cn4 .wrap .map {
        width: 100%; } }
    .cn4 .wrap .map iframe {
      height: 100%;
      width: 100%; }

.cn5 .reservation .tit3 .en {
  font-family: "the-seasons", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: clamp(28px, 3vw, 32px);
  letter-spacing: 0.1em; }

/*# sourceMappingURL=style.css.map */
