@charset "UTF-8";
/*import
------------------------------------------*/
/*reset*/
.pre-inc *, .pre-inc *:after, .pre-inc *:before {
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  border: 0; }

html {
  font-size: 100%; }

body {
  line-height: 1; }

.pre-inc {
  /* change colours to suit your needs */
  /* change colours to suit your needs */ }
  .pre-inc div, .pre-inc span, .pre-inc object, .pre-inc iframe,
  .pre-inc h1, .pre-inc h2, .pre-inc h3, .pre-inc h4, .pre-inc h5, .pre-inc h6, .pre-inc p, .pre-inc blockquote, .pre-inc pre,
  .pre-inc abbr, .pre-inc address, .pre-inc cite, .pre-inc code,
  .pre-inc del, .pre-inc dfn, .pre-inc em, .pre-inc ins, .pre-inc kbd, .pre-inc q, .pre-inc samp,
  .pre-inc strong, .pre-inc sub, .pre-inc sup, .pre-inc var,
  .pre-inc b, .pre-inc i,
  .pre-inc dl, .pre-inc dt, .pre-inc dd, .pre-inc ol, .pre-inc ul, .pre-inc li,
  .pre-inc fieldset, .pre-inc form, .pre-inc label, .pre-inc legend,
  .pre-inc table, .pre-inc caption, .pre-inc tbody, .pre-inc tfoot, .pre-inc thead, .pre-inc tr, .pre-inc th, .pre-inc td,
  .pre-inc article, .pre-inc aside, .pre-inc canvas, .pre-inc details, .pre-inc figcaption, .pre-inc figure,
  .pre-inc header, .pre-inc hgroup, .pre-inc menu, .pre-inc nav, .pre-inc section, .pre-inc summary,
  .pre-inc time, .pre-inc mark, .pre-inc audio, .pre-inc video {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent; }
  .pre-inc img {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    background: transparent; }
  .pre-inc article, .pre-inc aside, .pre-inc details, .pre-inc figcaption, .pre-inc figure,
  .pre-inc header, .pre-inc hgroup, .pre-inc menu, .pre-inc nav, .pre-inc section {
    display: block; }
  .pre-inc nav ul {
    list-style: none; }
  .pre-inc blockquote, .pre-inc q {
    quotes: none; }
  .pre-inc blockquote:before, .pre-inc blockquote:after,
  .pre-inc q:before, .pre-inc q:after {
    content: '';
    content: none; }
  .pre-inc a {
    margin: 0;
    padding: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
    outline: none !important; }
  .pre-inc ins {
    background-color: #ff9;
    color: #000;
    text-decoration: none; }
  .pre-inc mark {
    background-color: #ff9;
    color: #000;
    font-style: italic;
    font-weight: 700; }
  .pre-inc del {
    text-decoration: line-through; }
  .pre-inc abbr[title], .pre-inc dfn[title] {
    border-bottom: 1px dotted;
    cursor: help; }
  .pre-inc dfn {
    font-weight: 400;
    font-style: normal; }
  .pre-inc table {
    border-collapse: collapse;
    border-spacing: 0; }
  .pre-inc input, .pre-inc select {
    vertical-align: middle; }
  .pre-inc li {
    list-style: none; }

/*html body setting*/
html {
  overflow-y: scroll;
  font-size: 62.5%;
  padding: 0;
  margin: 0; }

body {
  overflow: hidden; }

.pre-inc {
  position: relative;
  font-weight: 400;
  font-size: 1.4rem;
  line-height: 1.6;
  background: #fff;
  color: #333;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  width: 100%;
  height: 100%;
  margin: auto;
  text-rendering: optimizeLegibility;
  font-kerning: normal;
  font-variant-ligatures: common-ligatures contextual;
  font-feature-settings: "kern", "liga", "clig", "calt"; }

/*px base setting*/
.pre-inc #pxBase sup {
  vertical-align: super;
  font-size: .5em; }
.pre-inc #pxBase a:link,
.pre-inc #pxBase a:visited,
.pre-inc #pxBase a:active,
.pre-inc #pxBase a:hover {
  text-decoration: none; }
.pre-inc #pxBase figure {
  position: relative; }
.pre-inc #pxBase img {
  max-width: 100%;
  width: 100%;
  height: auto; }
  .pre-inc #pxBase img.object-fit {
    object-fit: cover;
    height: 100%; }

/* visible or hidden
--------------------------------------------------------------------------------*/
@media only screen and (max-width: 991px) {
  .pre-inc .visible-pc {
    display: none !important; } }
@media only screen and (max-width: 767px) {
  .pre-inc .visible-pctb {
    display: none !important; } }
@media only screen and (min-width: 992px) {
  .pre-inc .visible-tbsp {
    display: none !important; } }
@media only screen and (min-width: 768px) {
  .pre-inc .visible-sp {
    display: none !important; } }
.pre-inc .visible-xs, .pre-inc .visible-sm, .pre-inc .visible-md, .pre-inc .visible-lg {
  display: none !important; }

@media (max-width: 767px) {
  .pre-inc .hidden-xs {
    display: none !important; }

  .pre-inc .visible-xs {
    display: block !important; } }
/*数値の設定
------------------------------------------*/
/*上記数値の設定を呼び出しているmixin
------------------------------------------*/
/*
よく使用するmixin
------------------------------------------*/
/*	▼	240305 GM追加	*/
/*
使用するフォントを読み込んでください
*/
/*layout
------------------------------------------*/
.pre-inc .column1 {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -15px; }
  .pre-inc .column1 > * {
    margin: 0 15px;
    width: calc(100% - 30px); }
    .pre-inc .column1 > *:nth-child(n+2) {
      margin-top: 40px; }
.pre-inc .column2 {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -15px; }
  .pre-inc .column2 > * {
    margin: 0 15px;
    width: calc(50% - 30px); }
    .pre-inc .column2 > *:nth-child(n+3) {
      margin-top: 40px; }
.pre-inc .column3 {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -15px; }
  .pre-inc .column3 > * {
    margin: 0 15px;
    width: calc(33.3333% - 30px); }
    .pre-inc .column3 > *:nth-child(n+4) {
      margin-top: 40px; }
.pre-inc .column4 {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -15px; }
  .pre-inc .column4 > * {
    margin: 0 15px;
    width: calc(25% - 30px); }
    .pre-inc .column4 > *:nth-child(n+5) {
      margin-top: 40px; }
.pre-inc .column5 {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -15px; }
  .pre-inc .column5 > * {
    margin: 0 15px;
    width: calc(20% - 30px); }
    .pre-inc .column5 > *:nth-child(n+6) {
      margin-top: 40px; }

/*animation
------------------------------------------*/
/*common
------------------------------------------*/
/*全体のフォント指定*/
.pre-inc {
  font-family: 'Cormorant Garamond','noto serif JP', serif; }

.pre-inc .num-serif {
  font-family: 'Cinzel', serif; }

.pre-inc .inter-sans {
  font-family: 'Inter', sans-serif; }

.pre-inc .jp-serif {
  font-family: 'noto serif JP', serif; }

/*img*/
.pre-inc figure {
  position: relative; }
  .pre-inc figure .imgcap {
    position: absolute;
    bottom: 0;
    right: 0;
    padding: 5px 8px;
    line-height: 1.2;
    font-size: 1.1rem;
    color: #222;
    color: #fff; }
    .pre-inc figure .imgcap.black {
      color: #000; }
    .pre-inc figure .imgcap.white {
      color: #fff; }
    .pre-inc figure .imgcap.with-bg {
      background: rgba(0, 0, 0, 0.5);
      color: #fff; }
.pre-inc .imgcap {
  position: absolute;
  bottom: 0;
  right: 0;
  padding: 5px 8px;
  line-height: 1.2;
  font-size: 1.1rem;
  color: #222;
  color: #fff; }
  .pre-inc .imgcap.black {
    color: #000; }
  .pre-inc .imgcap.white {
    color: #fff; }
  .pre-inc .imgcap.with-bg {
    background: rgba(0, 0, 0, 0.5);
    color: #fff; }
  @media only screen and (max-width: 767px) {
    .pre-inc .imgcap.sp-posleft {
      right: auto;
      left: 0; } }
.pre-inc header {
  width: calc(100% - 20px);
  padding: 20px 20px 20px 90px;
  height: 90px;
  background: rgba(255, 255, 255, 0.7);
  backdrop-filter: blur(10px);
  position: fixed;
  top: 20px;
  z-index: 1000;
  border-radius: 10px;
  right: 10px;
  transition: 0.4s ease;
  display: flex;
  align-items: center;
  justify-content: space-between; }
  .pre-inc header.displaynone {
    display: none; }
  .pre-inc header.nonactive {
    opacity: 0;
    pointer-events: none;
    user-select: none; }
  .pre-inc header.widthmin {
    width: 90px;
    padding: 20px; }
    @media only screen and (max-width: 991px) {
      .pre-inc header.widthmin {
        width: 65px; } }
  @media screen and (max-width: 1500px) {
    .pre-inc header {
      padding: 20px; } }
  @media only screen and (max-width: 991px) {
    .pre-inc header {
      padding: 20px 15px 15px 40px;
      height: 65px;
      width: calc(100% - 10px);
      right: 5px; } }
  @media screen and (max-width: 480px) {
    .pre-inc header {
      top: 10px;
      height: auto;
      padding: 10px 15px 10px 40px; } }
  .pre-inc header .shinhappyou {
    display: none;
    width: 180px;
    padding: 5px 0;
    position: absolute;
    top: 0;
    left: 0;
    background: linear-gradient(to right, #AC9A37, #7C6C25);
    color: #fff;
    text-align: center;
    font-size: 20px;
    transform: translate(-30%, 50%) rotate(-45deg);
    line-height: 1;
    opacity: 1;
    pointer-events: auto; }
    .pre-inc header .shinhappyou.scroll {
      opacity: 0;
      transition: 0.4s ease;
      pointer-events: none; }
    @media only screen and (max-width: 1440px) {
      .pre-inc header .shinhappyou {
        transform: translate(-35%, 50%) rotate(-45deg);
        font-size: 16px; } }
    @media only screen and (max-width: 991px) {
      .pre-inc header .shinhappyou {
        transform: translate(0, 0) rotate(0);
        -ms-writing-mode: tb-rl;
        padding: 5px 8px 5px 5px;
        writing-mode: vertical-rl;
        width: auto;
        height: 100%; } }
  .pre-inc header .humbtn {
    position: absolute;
    top: 50%;
    transform: translate(0, -50%);
    right: 0px;
    display: flex;
    flex-direction: column;
    gap: 7px;
    cursor: pointer;
    transition: 0.4s ease 0s;
    z-index: 100001;
    opacity: 0;
    pointer-events: none;
    z-index: 1002;
    justify-content: center;
    align-items: center;
    width: 90px;
    height: 90px; }
    .pre-inc header .humbtn.scroll {
      opacity: 1;
      pointer-events: auto;
      transition: 0.4s ease 0.4s; }
    .pre-inc header .humbtn span {
      width: 30px;
      height: 3px;
      border-radius: 5px;
      background: #151F41; }
    @media screen and (max-width: 1300px) {
      .pre-inc header .humbtn {
        opacity: 1;
        pointer-events: auto;
        right: 0px;
        gap: 5px;
        width: 65px;
        height: 65px; }
        .pre-inc header .humbtn span {
          width: 20px;
          height: 3px; } }
  .pre-inc header .header-inner {
    display: flex;
    align-items: center;
    width: 100%;
    justify-content: space-between; }
    .pre-inc header .header-inner.scroll h1.logo {
      opacity: 0;
      pointer-events: none; }
    .pre-inc header .header-inner.scroll nav {
      opacity: 0;
      pointer-events: none; }
    .pre-inc header .header-inner h1.logo {
      flex-shrink: 0;
      transition: 0.4s ease;
      line-height: 0;
      width: 150px; }
      @media only screen and (max-width: 1440px) {
        .pre-inc header .header-inner h1.logo {
          width: 150px; } }
      @media only screen and (max-width: 991px) {
        .pre-inc header .header-inner h1.logo {
          margin-right: 0;
          width: 100px; } }
      .pre-inc header .header-inner h1.logo a {
        line-height: 0;
        display: inline-block; }
      .pre-inc header .header-inner h1.logo img {
        width: 100%;
        height: 51px; }
        @media screen and (max-width: 480px) {
          .pre-inc header .header-inner h1.logo img {
            height: auto; } }
    .pre-inc header .header-inner nav {
      display: flex;
      column-gap: 20px;
      justify-content: space-between;
      transition: 0.4s ease; }
      @media screen and (max-width: 1200px) {
        .pre-inc header .header-inner nav {
          column-gap: 18px; } }
      @media screen and (max-width: 1300px) {
        .pre-inc header .header-inner nav.visible-pc {
          display: none;
          pointer-events: none; } }
      .pre-inc header .header-inner nav a {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        text-decoration: none;
        color: #333333;
        position: relative;
        padding-bottom: 3px; }
        .pre-inc header .header-inner nav a.current {
          border-bottom: 3px solid #151F41; }
        .pre-inc header .header-inner nav a.nonactive {
          pointer-events: none;
          user-select: none;
          opacity: 0.2; }
        .pre-inc header .header-inner nav a span {
          display: inline-block; }
        .pre-inc header .header-inner nav a .fireworks_box {
          position: absolute;
          left: -50px;
          right: -50px;
          top: 100%;
          margin: auto;
          text-align: center;
          animation: purun 2s linear 0s infinite; }
        .pre-inc header .header-inner nav a .jp-nav {
          font-size: 12px;
          line-height: 1; }
          @media screen and (max-width: 1500px) {
            .pre-inc header .header-inner nav a .jp-nav {
              font-size: 10px; } }
        .pre-inc header .header-inner nav a .en-nav {
          font-size: 14px;
          line-height: 1;
          padding-top: 2px; }
          @media screen and (max-width: 1500px) {
            .pre-inc header .header-inner nav a .en-nav {
              font-size: 12px; } }
        .pre-inc header .header-inner nav a.cv-btn {
          text-align: center;
          font-size: 14px;
          border-radius: 12px;
          padding: 10px 25px 6px 10px;
          line-height: 1.3;
          position: relative; }
          .pre-inc header .header-inner nav a.cv-btn:after {
            content: "";
            position: absolute;
            right: 10px;
            top: 50%;
            margin-top: -3px;
            width: 7px;
            height: 7px;
            border-top: 1px solid #FFF;
            border-right: 1px solid #FFF;
            transform: rotate(45deg); }
          .pre-inc header .header-inner nav a.cv-btn.entry-btn {
            background: linear-gradient(to right, #002C88, #036983);
            color: #FFF; }
          .pre-inc header .header-inner nav a.cv-btn.reserv-btn {
            background: linear-gradient(to right, #61000f, #80001b);
            color: #FFF;
            /*background: #F7EDA8;
            color: #152041;
            */ }
            .pre-inc header .header-inner nav a.cv-btn.reserv-btn:after {
              border-color: #FFF; }
            .pre-inc header .header-inner nav a.cv-btn.reserv-btn .easy_box {
              display: none; }
          .pre-inc header .header-inner nav a.cv-btn .easy_box {
            position: absolute;
            left: -20px;
            right: -20px;
            top: 100%;
            margin: auto;
            animation: purun 2s linear 0s infinite; }
.pre-inc .imgWrap img {
  max-width: 100%;
  height: auto; }
.pre-inc .header-sp-nav {
  width: 100vw;
  height: 100vh;
  background: linear-gradient(to right, #002C88, #036983);
  position: fixed;
  top: 0;
  opacity: 0;
  pointer-events: none;
  transition: 0.4s ease;
  z-index: 10003;
  overflow-y: auto;
  transform: translateX(100%); }
  .pre-inc .header-sp-nav.active {
    opacity: 1;
    pointer-events: auto;
    transform: translateX(0%); }
  .pre-inc .header-sp-nav .humbtn-sp {
    position: fixed;
    top: 33px;
    right: 25px;
    display: flex;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    transition: 0.4s ease 0s;
    z-index: 100001;
    opacity: 1;
    pointer-events: none;
    z-index: 1002;
    pointer-events: none; }
    .pre-inc .header-sp-nav .humbtn-sp.active {
      opacity: 1;
      pointer-events: auto; }
    .pre-inc .header-sp-nav .humbtn-sp span {
      width: 25px;
      height: 3px;
      background: #fff;
      border-radius: 5px; }
      .pre-inc .header-sp-nav .humbtn-sp span:nth-of-type(1) {
        transform: translateY(4px) rotate(45deg); }
      .pre-inc .header-sp-nav .humbtn-sp span:nth-of-type(2) {
        transform: translateY(-4px) rotate(-45deg); }
  .pre-inc .header-sp-nav .logo {
    flex-shrink: 0;
    margin-right: 13vw;
    transition: 0.4s ease;
    line-height: 0;
    position: fixed;
    top: 20px;
    left: 20px;
    width: 150px; }
    .pre-inc .header-sp-nav .logo a {
      line-height: 0;
      display: inline-block; }
    .pre-inc .header-sp-nav .logo img {
      width: 100%; }
  .pre-inc .header-sp-nav .nav-inner {
    width: 100%;
    margin-top: 100px;
    height: 600px; }
    .pre-inc .header-sp-nav .nav-inner nav {
      display: flex;
      flex-wrap: wrap; }
      .pre-inc .header-sp-nav .nav-inner nav a {
        width: 50%;
        border: 1px solid rgba(255, 255, 255, 0.5);
        background: rgba(255, 255, 255, 0.1);
        padding: 15px;
        text-decoration: none;
        display: flex;
        flex-direction: column;
        position: relative; }
        .pre-inc .header-sp-nav .nav-inner nav a.nonactive {
          pointer-events: none;
          user-select: none;
          opacity: 0.5; }
        .pre-inc .header-sp-nav .nav-inner nav a:before {
          position: absolute;
          right: 20px;
          top: 50%;
          transform: translate(0%, -50%);
          width: 5px;
          height: 10px;
          background: url("../img/elements/nav-arrow-white.svg");
          background-size: contain;
          content: ""; }
        .pre-inc .header-sp-nav .nav-inner nav a .fireworks_box {
          position: absolute;
          right: 40px;
          top: 20%;
          transform: translateY(-50%);
          animation: purun 2s linear 0s infinite; }
          @media screen and (max-width: 480px) {
            .pre-inc .header-sp-nav .nav-inner nav a .fireworks_box {
              width: 50%;
              right: 5px;
              top: 30%; } }
          @media screen and (max-width: 480px) {
            .pre-inc .header-sp-nav .nav-inner nav a .fireworks_box.small {
              width: 25%; } }
        .pre-inc .header-sp-nav .nav-inner nav a .en-nav {
          font-size: 22px;
          line-height: 1;
          color: #fff; }
        .pre-inc .header-sp-nav .nav-inner nav a .jp-nav {
          font-size: 12px;
          line-height: 1;
          color: #fff;
          padding-top: 5px; }
    .pre-inc .header-sp-nav .nav-inner .header-info-sp {
      width: 100%;
      padding: 50px 0; }
      .pre-inc .header-sp-nav .nav-inner .header-info-sp .header-info-inner-sp {
        width: calc(100% - 60px);
        margin: 0 auto;
        display: flex;
        align-items: center;
        flex-direction: column; }
        .pre-inc .header-sp-nav .nav-inner .header-info-sp .header-info-inner-sp .cv-btn-wrap {
          display: flex;
          gap: 20px; }
          @media only screen and (max-width: 991px) {
            .pre-inc .header-sp-nav .nav-inner .header-info-sp .header-info-inner-sp .cv-btn-wrap {
              flex-direction: column;
              align-items: center;
              row-gap: 70px; } }
          .pre-inc .header-sp-nav .nav-inner .header-info-sp .header-info-inner-sp .cv-btn-wrap .cv-btn {
            display: inline-block;
            font-size: 20px;
            line-height: 1;
            padding: 14px 20px;
            text-decoration: none;
            width: 250px;
            text-align: center; }
            @media only screen and (max-width: 991px) {
              .pre-inc .header-sp-nav .nav-inner .header-info-sp .header-info-inner-sp .cv-btn-wrap .cv-btn {
                padding: 15px 20px;
                font-size: 16px; } }
            .pre-inc .header-sp-nav .nav-inner .header-info-sp .header-info-inner-sp .cv-btn-wrap .cv-btn.entry-btn {
              border: 1px solid #fff;
              color: #fff;
              border-radius: 50px;
              position: relative; }
              .pre-inc .header-sp-nav .nav-inner .header-info-sp .header-info-inner-sp .cv-btn-wrap .cv-btn.entry-btn:before {
                content: "";
                position: absolute;
                width: 5px;
                height: 1px;
                background: #fff;
                right: 20px;
                top: calc(50% - 2px);
                transform: rotate(45deg); }
              .pre-inc .header-sp-nav .nav-inner .header-info-sp .header-info-inner-sp .cv-btn-wrap .cv-btn.entry-btn:after {
                content: "";
                position: absolute;
                width: 5px;
                height: 1px;
                background: #fff;
                right: 20px;
                top: calc(50% + 2px);
                transform: rotate(-45deg); }
            .pre-inc .header-sp-nav .nav-inner .header-info-sp .header-info-inner-sp .cv-btn-wrap .cv-btn.reserv-btn {
              border: 1px solid #F7EDA8;
              color: #F7EDA8;
              border-radius: 50px;
              position: relative; }
              .pre-inc .header-sp-nav .nav-inner .header-info-sp .header-info-inner-sp .cv-btn-wrap .cv-btn.reserv-btn:before {
                content: "";
                position: absolute;
                width: 5px;
                height: 1px;
                background: #F7EDA8;
                right: 20px;
                top: calc(50% - 2px);
                transform: rotate(45deg); }
              .pre-inc .header-sp-nav .nav-inner .header-info-sp .header-info-inner-sp .cv-btn-wrap .cv-btn.reserv-btn:after {
                content: "";
                position: absolute;
                width: 5px;
                height: 1px;
                background: #F7EDA8;
                right: 20px;
                top: calc(50% + 2px);
                transform: rotate(-45deg); }
              .pre-inc .header-sp-nav .nav-inner .header-info-sp .header-info-inner-sp .cv-btn-wrap .cv-btn.reserv-btn .easy_box {
                display: none; }
            .pre-inc .header-sp-nav .nav-inner .header-info-sp .header-info-inner-sp .cv-btn-wrap .cv-btn .easy_box {
              position: absolute;
              left: -20px;
              right: -20px;
              top: 100%;
              margin: auto;
              animation: purun 2s linear 0s infinite; }
        .pre-inc .header-sp-nav .nav-inner .header-info-sp .header-info-inner-sp .tel-detail {
          font-size: 12px;
          color: #fff;
          margin-top: 80px;
          text-align: center; }
          @media only screen and (max-width: 991px) {
            .pre-inc .header-sp-nav .nav-inner .header-info-sp .header-info-inner-sp .tel-detail {
              margin-top: 80px; } }
        .pre-inc .header-sp-nav .nav-inner .header-info-sp .header-info-inner-sp .info-detail {
          font-size: 12px;
          color: #fff;
          margin-top: 5px;
          text-align: center; }
        .pre-inc .header-sp-nav .nav-inner .header-info-sp .header-info-inner-sp .tel-num a {
          font-size: 40px;
          text-decoration: none;
          padding-left: 45px;
          font-weight: bold;
          color: #fff;
          background: url("../img/elements/tel.svg") left center no-repeat;
          background-size: 40px 30px;
          font-weight: 400;
          letter-spacing: -0.05em;
          width: 100%;
          display: inline-block; }
.pre-inc .cap-sec {
  width: 100%;
  position: relative; }
  .pre-inc .cap-sec .cap-inner {
    max-width: 1520px;
    margin: 0 auto;
    width: calc(100% - 60px);
    padding: 120px 0; }
    @media only screen and (max-width: 991px) {
      .pre-inc .cap-sec .cap-inner {
        padding: 60px 0; } }
    .pre-inc .cap-sec .cap-inner p {
      font-size: 11px;
      color: #111; }
.pre-inc .footer-info.footer-contact {
  width: 100%;
  background: #152041;
  padding: 100px 0; }
  .pre-inc .footer-info.footer-contact .footer-info-inner {
    width: calc(100% - 60px);
    margin: 0 auto;
    display: flex;
    align-items: center;
    flex-direction: column; }
    .pre-inc .footer-info.footer-contact .footer-info-inner .footer-info-ttl {
      font-size: 20px;
      text-align: center;
      color: #fff; }
    .pre-inc .footer-info.footer-contact .footer-info-inner .cv-btn-wrap {
      margin-top: 30px;
      display: flex;
      gap: 20px; }
      @media only screen and (max-width: 991px) {
        .pre-inc .footer-info.footer-contact .footer-info-inner .cv-btn-wrap {
          flex-direction: column;
          align-items: center; } }
      .pre-inc .footer-info.footer-contact .footer-info-inner .cv-btn-wrap .cv-btn {
        display: inline-block;
        font-size: 20px;
        line-height: 1;
        padding: 14px 20px;
        text-decoration: none;
        width: 250px;
        text-align: center; }
        @media only screen and (max-width: 991px) {
          .pre-inc .footer-info.footer-contact .footer-info-inner .cv-btn-wrap .cv-btn {
            padding: 15px 20px;
            font-size: 16px; } }
        .pre-inc .footer-info.footer-contact .footer-info-inner .cv-btn-wrap .cv-btn.entry-btn {
          border: 1px solid #fff;
          color: #fff;
          border-radius: 50px;
          position: relative; }
          .pre-inc .footer-info.footer-contact .footer-info-inner .cv-btn-wrap .cv-btn.entry-btn:before {
            content: "";
            position: absolute;
            width: 5px;
            height: 1px;
            background: #fff;
            right: 20px;
            top: calc(50% - 2px);
            transform: rotate(45deg); }
          .pre-inc .footer-info.footer-contact .footer-info-inner .cv-btn-wrap .cv-btn.entry-btn:after {
            content: "";
            position: absolute;
            width: 5px;
            height: 1px;
            background: #fff;
            right: 20px;
            top: calc(50% + 2px);
            transform: rotate(-45deg); }
        .pre-inc .footer-info.footer-contact .footer-info-inner .cv-btn-wrap .cv-btn.reserv-btn {
          border: 1px solid #F7EDA8;
          color: #F7EDA8;
          border-radius: 50px;
          position: relative; }
          .pre-inc .footer-info.footer-contact .footer-info-inner .cv-btn-wrap .cv-btn.reserv-btn:before {
            content: "";
            position: absolute;
            width: 5px;
            height: 1px;
            background: #F7EDA8;
            right: 20px;
            top: calc(50% - 2px);
            transform: rotate(45deg); }
          .pre-inc .footer-info.footer-contact .footer-info-inner .cv-btn-wrap .cv-btn.reserv-btn:after {
            content: "";
            position: absolute;
            width: 5px;
            height: 1px;
            background: #F7EDA8;
            right: 20px;
            top: calc(50% + 2px);
            transform: rotate(-45deg); }
.pre-inc .footer-brand {
  width: calc(100% - 60px);
  margin: 0 auto;
  background: #fff;
  padding: 100px 0;
  text-align: center; }
  @media only screen and (max-width: 991px) {
    .pre-inc .footer-brand {
      padding: 60px 0 100px; } }
  .pre-inc .footer-brand .class_bnr {
    display: block;
    max-width: 998px;
    margin: 0 auto 40px; }
    @media only screen and (max-width: 991px) {
      .pre-inc .footer-brand .class_bnr {
        margin: 0 auto 30px; } }
    .pre-inc .footer-brand .class_bnr img {
      max-width: 100%;
      height: auto; }
.pre-inc .btn-footer {
  display: block;
  position: fixed;
  bottom: 30px;
  right: 30px;
  transform: translate(0, 0);
  padding: 10px;
  font-size: 20px;
  background: #224981;
  z-index: 10000;
  color: #fff;
  width: 100%;
  padding: 15px;
  text-align: center;
  max-width: 270px;
  border-radius: 40px;
  line-height: 1;
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  transition: 0.4s ease; }
  .pre-inc .btn-footer.active {
    opacity: 1;
    pointer-events: auto; }
  @media only screen and (max-width: 767px) {
    .pre-inc .btn-footer {
      display: block;
      position: fixed;
      bottom: 20px;
      right: auto;
      left: 50%;
      transform: translate(-50%, 0);
      padding: 10px;
      font-size: 16px;
      background: #224981;
      z-index: 10000;
      color: #fff;
      width: 100%;
      padding: 15px;
      text-align: center;
      max-width: 270px;
      border-radius: 40px;
      line-height: 1;
      cursor: pointer;
      opacity: 0;
      pointer-events: none;
      transition: 0.4s ease; } }
.pre-inc .btn-footer-sec {
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 10000;
  width: 100%;
  opacity: 0;
  transform: translateY(100%);
  transition: 0.4s ease; }
  .pre-inc .btn-footer-sec.active {
    opacity: 1;
    transform: translateY(0%); }
  .pre-inc .btn-footer-sec .closebtn {
    position: fixed;
    top: 33px;
    right: 25px;
    display: flex;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    transition: 0.4s ease 0s;
    z-index: 100001;
    opacity: 1;
    z-index: 1002; }
    .pre-inc .btn-footer-sec .closebtn.active {
      opacity: 1;
      pointer-events: auto; }
    .pre-inc .btn-footer-sec .closebtn span {
      width: 25px;
      height: 3px;
      background: #fff;
      border-radius: 5px; }
      .pre-inc .btn-footer-sec .closebtn span:nth-of-type(1) {
        transform: translateY(4px) rotate(45deg); }
      .pre-inc .btn-footer-sec .closebtn span:nth-of-type(2) {
        transform: translateY(-4px) rotate(-45deg); }
  .pre-inc .btn-footer-sec .footer-info {
    width: 100%;
    background: #224981;
    padding: 50px 0;
    border-radius: 40px 40px 0 0; }
    .pre-inc .btn-footer-sec .footer-info .footer-info-inner {
      width: 100%;
      margin: 0 auto;
      display: flex;
      align-items: center;
      flex-direction: column; }
      .pre-inc .btn-footer-sec .footer-info .footer-info-inner .footer-info-ttl {
        font-size: 20px;
        text-align: center;
        color: #fff; }
      .pre-inc .btn-footer-sec .footer-info .footer-info-inner .cv-btn-wrap {
        margin-top: 30px;
        display: flex;
        gap: 20px; }
        @media only screen and (max-width: 991px) {
          .pre-inc .btn-footer-sec .footer-info .footer-info-inner .cv-btn-wrap {
            flex-direction: column;
            align-items: center; } }
        .pre-inc .btn-footer-sec .footer-info .footer-info-inner .cv-btn-wrap .cv-btn {
          display: inline-block;
          font-size: 20px;
          line-height: 1;
          padding: 14px 20px;
          text-decoration: none;
          width: 250px;
          text-align: center; }
          @media only screen and (max-width: 991px) {
            .pre-inc .btn-footer-sec .footer-info .footer-info-inner .cv-btn-wrap .cv-btn {
              padding: 15px 20px;
              font-size: 16px; } }
          .pre-inc .btn-footer-sec .footer-info .footer-info-inner .cv-btn-wrap .cv-btn.entry-btn {
            border: 1px solid #fff;
            color: #fff;
            border-radius: 50px;
            position: relative; }
            .pre-inc .btn-footer-sec .footer-info .footer-info-inner .cv-btn-wrap .cv-btn.entry-btn:before {
              content: "";
              position: absolute;
              width: 5px;
              height: 1px;
              background: #fff;
              right: 20px;
              top: calc(50% - 2px);
              transform: rotate(45deg); }
            .pre-inc .btn-footer-sec .footer-info .footer-info-inner .cv-btn-wrap .cv-btn.entry-btn:after {
              content: "";
              position: absolute;
              width: 5px;
              height: 1px;
              background: #fff;
              right: 20px;
              top: calc(50% + 2px);
              transform: rotate(-45deg); }
          .pre-inc .btn-footer-sec .footer-info .footer-info-inner .cv-btn-wrap .cv-btn.reserv-btn {
            border: 1px solid #F7EDA8;
            color: #F7EDA8;
            border-radius: 50px;
            position: relative; }
            .pre-inc .btn-footer-sec .footer-info .footer-info-inner .cv-btn-wrap .cv-btn.reserv-btn:before {
              content: "";
              position: absolute;
              width: 5px;
              height: 1px;
              background: #F7EDA8;
              right: 20px;
              top: calc(50% - 2px);
              transform: rotate(45deg); }
            .pre-inc .btn-footer-sec .footer-info .footer-info-inner .cv-btn-wrap .cv-btn.reserv-btn:after {
              content: "";
              position: absolute;
              width: 5px;
              height: 1px;
              background: #F7EDA8;
              right: 20px;
              top: calc(50% + 2px);
              transform: rotate(-45deg); }
      .pre-inc .btn-footer-sec .footer-info .footer-info-inner .tel-detail {
        font-size: 12px;
        color: #fff;
        margin-top: 30px;
        text-align: center; }
        @media only screen and (max-width: 991px) {
          .pre-inc .btn-footer-sec .footer-info .footer-info-inner .tel-detail {
            margin-top: 40px; } }
      .pre-inc .btn-footer-sec .footer-info .footer-info-inner .info-detail {
        font-size: 12px;
        color: #fff;
        margin-top: 5px;
        text-align: center; }
      .pre-inc .btn-footer-sec .footer-info .footer-info-inner .tel-num a {
        font-size: 40px;
        text-decoration: none;
        padding-left: 45px;
        font-weight: bold;
        color: #fff;
        background: url("../img/elements/tel.svg") left center no-repeat;
        background-size: 40px 30px;
        font-weight: 400;
        letter-spacing: -0.05em;
        width: 100%;
        display: inline-block; }
.pre-inc small {
  font-size: 60%; }
.pre-inc .flex {
  display: flex;
  justify-content: space-between; }
.pre-inc .underlayer_area .under_group {
  flex-wrap: wrap; }
  .pre-inc .underlayer_area .under_group a {
    aspect-ratio: 640/420;
    width: calc(100% / 3);
    display: block;
    position: relative;
    overflow: hidden;
    display: flex;
    justify-content: center;
    align-items: center;
    text-decoration: none; }
    @media screen and (max-width: 480px) {
      .pre-inc .underlayer_area .under_group a {
        width: 50%;
        aspect-ratio: 1; } }
    .pre-inc .underlayer_area .under_group a:before {
      content: "";
      position: absolute;
      inset: 0;
      background-position: top center;
      background-repeat: no-repeat;
      background-size: cover;
      transition: 0.3s transform ease-in-out 0s; }
    .pre-inc .underlayer_area .under_group a:after {
      content: "";
      position: absolute;
      inset: 0;
      background: rgba(0, 0, 0, 0.5);
      transition: 0.3s opacity ease-in-out 0s; }
    .pre-inc .underlayer_area .under_group a:hover:before {
      transform: scale(1.1); }
    .pre-inc .underlayer_area .under_group a:hover:after {
      opacity: 0; }
    .pre-inc .underlayer_area .under_group a:hover .link_group .page_name {
      color: #000;
      text-shadow: 0 0 5px rgba(255, 255, 255, 0.9), 0 0 10px rgba(255, 255, 255, 0.9), 0 0 15px rgba(255, 255, 255, 0.9), 0 0 20px rgba(255, 255, 255, 0.9), 0 0 5px rgba(255, 255, 255, 0.9), 0 0 10px rgba(255, 255, 255, 0.9); }
    .pre-inc .underlayer_area .under_group a:hover .link_group .detail {
      color: #000;
      background: rgba(255, 255, 255, 0.8); }
      .pre-inc .underlayer_area .under_group a:hover .link_group .detail:after {
        border-color: #000; }
    .pre-inc .underlayer_area .under_group a.bg_top:before {
      background-image: url("../img/elements/bg_top.jpg"); }
    .pre-inc .underlayer_area .under_group a.bg_loc:before {
      background-image: url("../img/elements/bg_loc.jpg"); }
    .pre-inc .underlayer_area .under_group a.bg_acc:before {
      background-image: url("../img/elements/bg_acc.jpg"); }
    .pre-inc .underlayer_area .under_group a.bg_des:before {
      background-image: url("../img/elements/bg_des.jpg"); }
    .pre-inc .underlayer_area .under_group a.bg_equ:before {
      background-image: url("../img/elements/bg_equ.jpg"); }
    .pre-inc .underlayer_area .under_group a.bg_eva:before {
      background-image: url("../img/elements/bg_eva.jpg"); }
    .pre-inc .underlayer_area .under_group a.bg_int:before {
      background-image: url("../img/elements/bg_int.jpg"); }
    .pre-inc .underlayer_area .under_group a .link_group {
      position: absolute;
      inset: 0;
      z-index: 1;
      margin: auto;
      display: flex;
      justify-content: center;
      flex-direction: column;
      text-align: center;
      row-gap: 20px;
      width: calc(100% - 30px); }
      .pre-inc .underlayer_area .under_group a .link_group .page_name {
        font-size: clamp(20px, 2.5vw, 40px);
        color: #FFF;
        line-height: 1;
        transition: 0.3s all ease-in-out 0s; }
        @media screen and (max-width: 480px) {
          .pre-inc .underlayer_area .under_group a .link_group .page_name {
            font-size: 6.6vw; } }
      .pre-inc .underlayer_area .under_group a .link_group .detail {
        max-width: 240px;
        width: 100%;
        font-size: clamp(10px, 0.75vw, 12px);
        color: #FFF;
        text-align: center;
        margin: 0 auto;
        border-radius: 18px;
        padding: 8px 5px 6px;
        position: relative;
        border: 1px solid #FFF;
        transition: 0.3s all ease-in-out 0s; }
        @media screen and (max-width: 480px) {
          .pre-inc .underlayer_area .under_group a .link_group .detail {
            font-size: 10px; } }
        .pre-inc .underlayer_area .under_group a .link_group .detail:after {
          content: "";
          position: absolute;
          right: 20px;
          top: 50%;
          width: 8px;
          margin-top: -4px;
          height: 8px;
          border-top: 1px solid #FFF;
          border-right: 1px solid #FFF;
          transform: rotate(45deg);
          transition: 0.3s all ease-in-out 0s; }
          @media screen and (max-width: 480px) {
            .pre-inc .underlayer_area .under_group a .link_group .detail:after {
              right: 10px; } }
    .pre-inc .underlayer_area .under_group a .under_cap {
      position: absolute;
      right: 0px;
      bottom: 0;
      font-size: 10px;
      color: #FFF;
      padding: 5px;
      z-index: 2;
      text-align: right; }

@keyframes purun {
  0% {
    transform: translate(0%, 0%); }
  10% {
    transform: translate(0%, 7%); }
  20% {
    transform: translate(0%, 14%); }
  40% {
    transform: translate(0%, -14%); }
  60% {
    transform: translate(0%, 7%); }
  80% {
    transform: translate(0%, 0%); }
  100% {
    transform: translate(0%, 0%); } }
/*	▼	240305 GM追加	*/
@media screen and (max-width: 1900px) {
  .pre-inc .vpc1900 {
    display: none; } }
@media not screen, screen and (min-width: 1901px) {
  .pre-inc .vsp1900 {
    display: none; } }
@media screen and (max-width: 1800px) {
  .pre-inc .vpc1800 {
    display: none; } }
@media not screen, screen and (min-width: 1801px) {
  .pre-inc .vsp1800 {
    display: none; } }
@media screen and (max-width: 1600px) {
  .pre-inc .vpc1600 {
    display: none; } }
@media not screen, screen and (min-width: 1601px) {
  .pre-inc .vsp1600 {
    display: none; } }
@media screen and (max-width: 1500px) {
  .pre-inc .vpc1500 {
    display: none; } }
@media not screen, screen and (min-width: 1501px) {
  .pre-inc .vsp1500 {
    display: none; } }
@media screen and (max-width: 1400px) {
  .pre-inc .vpc1400 {
    display: none; } }
@media not screen, screen and (min-width: 1401px) {
  .pre-inc .vsp1400 {
    display: none; } }
@media screen and (max-width: 1300px) {
  .pre-inc .vpc1300 {
    display: none; } }
@media not screen, screen and (min-width: 1301px) {
  .pre-inc .vsp1300 {
    display: none; } }
@media screen and (max-width: 1200px) {
  .pre-inc .vpc1200 {
    display: none; } }
@media not screen, screen and (min-width: 1201px) {
  .pre-inc .vsp1200 {
    display: none; } }
@media screen and (max-width: 1024px) {
  .pre-inc .vpc1024 {
    display: none; } }
@media not screen, screen and (min-width: 1025px) {
  .pre-inc .vsp1024 {
    display: none; } }
@media screen and (max-width: 960px) {
  .pre-inc .vpc960 {
    display: none; } }
@media not screen, screen and (min-width: 961px) {
  .pre-inc .vsp960 {
    display: none; } }
@media screen and (max-width: 900px) {
  .pre-inc .vpc900 {
    display: none; } }
@media not screen, screen and (min-width: 901px) {
  .pre-inc .vsp900 {
    display: none; } }
@media screen and (max-width: 768px) {
  .pre-inc .vpc768 {
    display: none; } }
@media not screen, screen and (min-width: 769px) {
  .pre-inc .vsp768 {
    display: none; } }
@media screen and (max-width: 767px) {
  .pre-inc .vpc767 {
    display: none; } }
@media not screen, screen and (min-width: 768px) {
  .pre-inc .vsp767 {
    display: none; } }
@media screen and (max-width: 480px) {
  .pre-inc .vpc480 {
    display: none; } }
@media not screen, screen and (min-width: 481px) {
  .pre-inc .vsp480 {
    display: none; } }
@media screen and (max-width: 375px) {
  .pre-inc .vpc375 {
    display: none; } }
@media not screen, screen and (min-width: 376px) {
  .pre-inc .vsp375 {
    display: none; } }
@media screen and (max-width: 360px) {
  .pre-inc .vpc360 {
    display: none; } }
@media not screen, screen and (min-width: 361px) {
  .pre-inc .vsp360 {
    display: none; } }
@media screen and (max-width: 320px) {
  .pre-inc .vpc320 {
    display: none; } }
@media not screen, screen and (min-width: 321px) {
  .pre-inc .vsp320 {
    display: none; } }

/*# sourceMappingURL=px-common.css.map */
