/* ***************************************************
 SP
*************************************************** */
@media screen and (max-width:1099px) {
  @-webkit-keyframes show {
    from {
      bottom: -150px;
    }
    to {
      bottom: 0;
    }
  }
  @keyframes show {
    from {
      bottom: -150px;
    }
    to {
      bottom: 0;
    }
  }
  .lp-winter2025 {
    width: 1099px;
    max-width: 100%;
    margin: 0 auto;
    overflow-x: hidden;
    font-family: "Zen Kaku Gothic Antique", sans-serif;
  }
  .lp-winter2025 .winter-mv {
    display: grid;
    place-items: center;
    width: 1099px;
    max-width: 100%;
    aspect-ratio: 75/134;
    margin: 0 auto;
    background-color: #DDD3C7;
  }
  .lp-winter2025 .winter-mv h1 {
    width: 100%;
    height: 100%;
  }
  .lp-winter2025 .winter-mv h1 img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .lp-winter2025 .winter-intro {
    width: 1099px;
    max-width: 100%;
    margin: 0 auto;
    padding: 100px 0;
    background-color: #DDD3C7;
  }
  .lp-winter2025 .winter-intro .inner {
    position: relative;
    background-color: #F4EFE9;
    padding: 70px 0 40px;
  }
  .lp-winter2025 .winter-intro .inner::before {
    content: "";
    position: absolute;
    top: -76px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 1099px;
    height: 110px;
    max-width: 100%;
    background-image: url(../images/intro-before__sp.png);
    background-repeat: no-repeat;
    background-position: center bottom;
    background-size: 392px auto;
  }
  .lp-winter2025 .winter-intro .text {
    margin-bottom: 30px;
    padding-bottom: 130px;
    background-image: url(../images/intro-after__sp.png);
    background-repeat: no-repeat;
    background-position: center bottom;
    background-size: 327px auto;
  }
  .lp-winter2025 .winter-intro .text h2 {
    display: block;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 0 auto;
    padding-bottom: 30px;
    font-size: clamp(16px, 4.2vw, 20px);
    font-weight: 900;
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    line-height: 1.5em;
    text-align: center;
    color: #834220;
    background-image: url(../images/intro-title-bg__sp.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    background-position: center bottom;
  }
  .lp-winter2025 .winter-intro .text p {
    font-size: clamp(13px, 3.46vw, 16px);
    color: #242C3C;
    color: #834220;
    text-align: center;
    line-height: 2em;
  }
  .lp-winter2025 .winter-intro .text p b {
    font-size: 900;
  }
  .lp-winter2025 .winter-intro .text p b.red {
    color: #C15757;
  }
  .lp-winter2025 .winter-intro .text p b.purple {
    color: #575D8E;
  }
  .lp-winter2025 .winter-intro .text p b.blue {
    color: #416F90;
  }
  .lp-winter2025 .winter-nav-wrapper {
    position: relative;
    width: 100%;
    margin: 0 auto;
  }
  .lp-winter2025 .winter-nav-wrapper ul {
    list-style: none;
    width: 100%;
  }
  .lp-winter2025 .winter-nav-wrapper ul li {
    display: block;
    width: 220px;
    margin: 0 auto 15px;
  }
  .lp-winter2025 .winter-nav-wrapper ul li:last-child {
    margin-bottom: 0;
  }
  .lp-winter2025 .winter-nav-wrapper ul li a {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .lp-winter2025 .winter-nav-wrapper ul li .fix {
    display: none;
  }
  .lp-winter2025 .winter-nav-wrapper ul.float {
    -webkit-animation: show 0.3s ease 0s;
            animation: show 0.3s ease 0s;
    position: fixed;
    top: auto;
    left: 50%;
    bottom: 0;
    z-index: 100;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 10px;
    width: 100vw;
    padding: 10px;
    border-bottom: none;
    background-color: rgba(255, 255, 255, 0.85);
    -webkit-backdrop-filter: blur(30px);
            backdrop-filter: blur(30px);
  }
  .lp-winter2025 .winter-nav-wrapper ul.float li {
    max-width: clamp(110px, 29vw, 170px);
    margin: 0;
  }
  .lp-winter2025 .winter-nav-wrapper ul.float li a {
    text-align: center;
  }
  .lp-winter2025 .winter-nav-wrapper ul.float li .def {
    display: none;
  }
  .lp-winter2025 .winter-nav-wrapper ul.float li .fix {
    display: inline-block;
  }
  .lp-winter2025 .section-gourmet,
  .lp-winter2025 .section-hotel,
  .lp-winter2025 .section-experience {
    position: relative;
    z-index: 1;
    width: 1099px;
    max-width: 100%;
    margin: 0 auto;
    padding: 30px 0 100px;
  }
  .lp-winter2025 .section-gourmet::before,
  .lp-winter2025 .section-hotel::before,
  .lp-winter2025 .section-experience::before {
    content: "";
    position: absolute;
    top: -30px;
    left: 50%;
    right: 0;
    z-index: -1;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 120%;
    height: 60px;
    border-radius: 50%;
  }
  .lp-winter2025 .section-gourmet .section-intro,
  .lp-winter2025 .section-hotel .section-intro,
  .lp-winter2025 .section-experience .section-intro {
    margin-bottom: 30px;
    padding: 0 6vw;
    text-align: center;
    background-repeat: no-repeat;
    background-position: center bottom;
  }
  .lp-winter2025 .section-gourmet .section-intro .section-title,
  .lp-winter2025 .section-hotel .section-intro .section-title,
  .lp-winter2025 .section-experience .section-intro .section-title {
    max-width: 500px;
    margin: 0 auto 30px;
  }
  .lp-winter2025 .section-gourmet .section-intro p,
  .lp-winter2025 .section-hotel .section-intro p,
  .lp-winter2025 .section-experience .section-intro p {
    margin: 0 auto;
    font-size: 14px;
    font-weight: 500;
    color: #FFFFFF;
    text-align: center;
  }
  .lp-winter2025 .section-gourmet .section-intro p b,
  .lp-winter2025 .section-hotel .section-intro p b,
  .lp-winter2025 .section-experience .section-intro p b {
    font-weight: 900;
  }
  .lp-winter2025 .section-gourmet {
    z-index: 1;
    padding-bottom: 100px;
    background-color: #DD7E7E;
  }
  .lp-winter2025 .section-gourmet::before {
    background-color: #DD7E7E;
  }
  .lp-winter2025 .section-gourmet .section-intro {
    padding-bottom: 80px;
    background-image: url(../images/gourmet-text__sp.png);
    background-size: 338px auto;
    background-position: center bottom;
  }
  .lp-winter2025 .section-gourmet .plan .item {
    background-color: #FFEFBA;
  }
  .lp-winter2025 .section-gourmet .plan .title {
    color: #953737;
    border-bottom: 5px solid #953737;
  }
  .lp-winter2025 .section-gourmet .plan .hotel {
    color: #953737;
    background-image: url(../images/gourmet-line.png);
  }
  .lp-winter2025 .section-hotel {
    z-index: 2;
    padding-bottom: 100px;
    background-color: #6D74AC;
  }
  .lp-winter2025 .section-hotel::before {
    background-color: #6D74AC;
  }
  .lp-winter2025 .section-hotel .section-intro {
    padding-bottom: 80px;
    background-image: url(../images/hotel-text__sp.png);
    background-size: 335px auto;
    background-position: center bottom;
  }
  .lp-winter2025 .section-hotel .plan .item {
    background-color: #FFE2E2;
  }
  .lp-winter2025 .section-hotel .plan .title {
    color: #403A7C;
    border-bottom: 5px solid #403A7C;
  }
  .lp-winter2025 .section-hotel .plan .hotel {
    color: #403A7C;
    background-image: url(../images/hotel-line.png);
  }
  .lp-winter2025 .section-experience {
    z-index: 3;
    background-color: #6A99BC;
  }
  .lp-winter2025 .section-experience::before {
    background-color: #6A99BC;
  }
  .lp-winter2025 .section-experience .section-intro {
    padding-bottom: 130px;
    background-image: url(../images/experience-text__sp.png);
    background-size: 331px auto;
    background-position: center bottom;
  }
  .lp-winter2025 .section-experience .plan .item {
    background-color: #FDD5C0;
  }
  .lp-winter2025 .section-experience .plan .title {
    color: #255476;
    border-bottom: 5px solid #255476;
  }
  .lp-winter2025 .section-experience .plan .hotel {
    color: #255476;
    background-image: url(../images/experience-line.png);
  }
  .lp-winter2025 .plan {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(calc(50% - clamp(15px, 4vw, 20px)), 1fr));
    gap: 20px clamp(15px, 4vw, 20px);
    width: 1099px;
    max-width: 100%;
    padding: 0 5vw 10px;
    overflow: hidden;
  }
  .lp-winter2025 .plan .item a {
    display: block;
  }
  .lp-winter2025 .plan .img {
    overflow: hidden;
  }
  .lp-winter2025 .plan .img img {
    width: 100%;
    aspect-ratio: 63/50;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .lp-winter2025 .plan .title {
    margin: 0;
    padding: 0.8em 10px;
    font-size: clamp(14px, 3.7vw, 16px);
    font-weight: 700;
    word-break: break-all;
    text-align: center;
    line-height: 1.5em;
  }
  .lp-winter2025 .plan .hotel {
    margin: 0;
    padding: 1em 10px 2em;
    font-size: clamp(12px, 3.2vw, 14px);
    font-weight: 700;
    word-break: break-all;
    background-repeat: no-repeat;
    background-size: 100% auto;
    background-position: center bottom;
  }
  .lp-winter2025 .plan .comment {
    margin: 0;
    padding: 1em 10px;
    font-size: clamp(12px, 3.2vw, 14px);
    font-weight: 500;
    color: #242C3C;
    line-height: 1.75em;
  }
  .lp-winter2025 .plan-more {
    position: relative;
    width: clamp(250px, 66.5vw, 500px);
    margin: 40px auto 0;
    padding: 1em;
    font-size: 18px;
    font-weight: 600;
    text-align: center;
    color: #FFFFFF;
    border: 2px solid #FFFFFF;
  }
  .lp-winter2025 .plan-more::before, .lp-winter2025 .plan-more::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 5vw;
    width: clamp(17px, 4.6vw, 25px);
    height: 2px;
    background-color: #FFFFFF;
  }
  .lp-winter2025 .plan-more::after {
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
  }
  .last-banner {
    width: 100%;
    margin-top: 40px;
    padding: 0 6vw;
    text-align: center;
  }
  .last-banner a {
    max-width: 100%;
  }
}
/* ***************************************************
 PC
*************************************************** */
@media all and (min-width:1100px) {
  @-webkit-keyframes show {
    from {
      bottom: -150px;
    }
    to {
      bottom: 0;
    }
  }
  @keyframes show {
    from {
      bottom: -150px;
    }
    to {
      bottom: 0;
    }
  }
  .lp-winter2025 {
    width: 1920px;
    max-width: 100%;
    margin: 0 auto;
    overflow-x: hidden;
    font-family: "Zen Kaku Gothic Antique", sans-serif;
  }
  .lp-winter2025 .winter-mv {
    display: grid;
    place-items: center;
    width: 1920px;
    max-width: 100%;
    height: 1000px;
    margin: 0 auto;
    background-color: #DDD3C7;
  }
  .lp-winter2025 .winter-mv h1 {
    width: 100%;
    height: 100%;
  }
  .lp-winter2025 .winter-mv h1 img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .lp-winter2025 .winter-intro {
    width: 2020px;
    max-width: 100%;
    margin: 0 auto;
    padding: 280px 0;
    background-color: #DDD3C7;
  }
  .lp-winter2025 .winter-intro .inner {
    position: relative;
    background-color: #F4EFE9;
    padding: 125px 50px 70px;
    background-image: url(../images/intro-after.png);
    background-repeat: no-repeat;
    background-position: calc(50% + 20px) bottom;
    background-size: 1702px auto;
  }
  .lp-winter2025 .winter-intro .inner::before {
    content: "";
    position: absolute;
    top: -165px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 1920px;
    height: 226px;
    max-width: 100%;
    background-image: url(../images/intro-before.png);
    background-repeat: no-repeat;
    background-position: center bottom;
    background-size: contain;
  }
  .lp-winter2025 .winter-intro .text h2 {
    display: block;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 0 auto 100px;
    padding-bottom: 30px;
    font-size: clamp(22px, 2.2vw, 28px);
    font-weight: 900;
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
    line-height: 1em;
    color: #834220;
    background-image: url(../images/intro-title-bg.png);
    background-repeat: no-repeat;
    background-size: 100% auto;
    background-position: center bottom;
  }
  .lp-winter2025 .winter-intro .text p {
    font-size: 24px;
    font-weight: 500;
    color: #834220;
    text-align: center;
    line-height: 1.75em;
  }
  .lp-winter2025 .winter-intro .text p b {
    font-size: 900;
  }
  .lp-winter2025 .winter-intro .text p b.red {
    color: #C15757;
  }
  .lp-winter2025 .winter-intro .text p b.purple {
    color: #575D8E;
  }
  .lp-winter2025 .winter-intro .text p b.blue {
    color: #416F90;
  }
  .lp-winter2025 .winter-nav-wrapper {
    position: relative;
    width: 100%;
    height: 160px;
    margin: 0 auto;
  }
  .lp-winter2025 .winter-nav-wrapper ul {
    list-style: none;
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 100;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: clamp(20px, 2vw, 40px);
    width: 100%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
  .lp-winter2025 .winter-nav-wrapper ul li {
    width: 400px;
    height: 160px;
  }
  .lp-winter2025 .winter-nav-wrapper ul li a {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .lp-winter2025 .winter-nav-wrapper ul li a:hover {
    opacity: 0.8;
  }
  .lp-winter2025 .winter-nav-wrapper ul li .fix {
    display: none;
  }
  .lp-winter2025 .winter-nav-wrapper ul.float {
    -webkit-animation: show 0.3s ease 0s;
            animation: show 0.3s ease 0s;
    position: fixed;
    top: auto;
    bottom: 0;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 100vw;
    padding: 20px;
    border-bottom: none;
    background-color: rgba(255, 255, 255, 0.85);
    -webkit-backdrop-filter: blur(30px);
            backdrop-filter: blur(30px);
  }
  .lp-winter2025 .winter-nav-wrapper ul.float li {
    height: 110px;
  }
  .lp-winter2025 .winter-nav-wrapper ul.float li a {
    text-align: center;
  }
  .lp-winter2025 .winter-nav-wrapper ul.float li .def {
    display: none;
  }
  .lp-winter2025 .winter-nav-wrapper ul.float li .fix {
    display: inline-block;
  }
  .lp-winter2025 .section-gourmet,
  .lp-winter2025 .section-hotel,
  .lp-winter2025 .section-experience {
    position: relative;
    z-index: 1;
    width: 1920px;
    max-width: 100%;
    margin: 0 auto;
    padding: 30px 0 160px;
  }
  .lp-winter2025 .section-gourmet::before,
  .lp-winter2025 .section-hotel::before,
  .lp-winter2025 .section-experience::before {
    content: "";
    position: absolute;
    top: -128px;
    left: 50%;
    right: 0;
    z-index: -1;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 120%;
    height: 260px;
    border-radius: 50%;
  }
  .lp-winter2025 .section-gourmet .section-intro,
  .lp-winter2025 .section-hotel .section-intro,
  .lp-winter2025 .section-experience .section-intro {
    margin-bottom: 100px;
    text-align: center;
    background-repeat: no-repeat;
    background-position: center bottom;
  }
  .lp-winter2025 .section-gourmet .section-intro .section-title,
  .lp-winter2025 .section-hotel .section-intro .section-title,
  .lp-winter2025 .section-experience .section-intro .section-title {
    margin-bottom: 50px;
  }
  .lp-winter2025 .section-gourmet .section-intro p,
  .lp-winter2025 .section-hotel .section-intro p,
  .lp-winter2025 .section-experience .section-intro p {
    margin: 0 auto;
    font-size: 20px;
    font-weight: 500;
    color: #FFFFFF;
    text-align: center;
  }
  .lp-winter2025 .section-gourmet .section-intro p b,
  .lp-winter2025 .section-hotel .section-intro p b,
  .lp-winter2025 .section-experience .section-intro p b {
    font-weight: 900;
  }
  .lp-winter2025 .section-gourmet {
    z-index: 1;
    padding-bottom: 290px;
    background-color: #DD7E7E;
  }
  .lp-winter2025 .section-gourmet::before {
    background-color: #DD7E7E;
  }
  .lp-winter2025 .section-gourmet .section-intro {
    padding-bottom: 40px;
    background-image: url(../images/gourmet-text.png);
    background-size: 1284px auto;
    background-position: calc(50% + 30px) bottom;
  }
  .lp-winter2025 .section-gourmet .plan .item {
    background-color: #FFEFBA;
  }
  .lp-winter2025 .section-gourmet .plan .title {
    color: #953737;
    border-bottom: 5px solid #953737;
  }
  .lp-winter2025 .section-gourmet .plan .hotel {
    color: #953737;
    background-image: url(../images/gourmet-line.png);
  }
  .lp-winter2025 .section-hotel {
    z-index: 2;
    padding-bottom: 290px;
    background-color: #6D74AC;
  }
  .lp-winter2025 .section-hotel::before {
    background-color: #6D74AC;
  }
  .lp-winter2025 .section-hotel .section-intro {
    padding-bottom: 20px;
    background-image: url(../images/hotel-text.png);
    background-size: 1297px auto;
    background-position: calc(50% + 10px) bottom;
  }
  .lp-winter2025 .section-hotel .plan .item {
    background-color: #FFE2E2;
  }
  .lp-winter2025 .section-hotel .plan .title {
    color: #403A7C;
    border-bottom: 5px solid #403A7C;
  }
  .lp-winter2025 .section-hotel .plan .hotel {
    color: #403A7C;
    background-image: url(../images/hotel-line.png);
  }
  .lp-winter2025 .section-experience {
    z-index: 3;
    background-color: #6A99BC;
  }
  .lp-winter2025 .section-experience::before {
    background-color: #6A99BC;
  }
  .lp-winter2025 .section-experience .section-intro {
    padding-bottom: 10px;
    background-image: url(../images/experience-text.png);
    background-size: 1246px auto;
    background-position: calc(50% + 20px) bottom;
  }
  .lp-winter2025 .section-experience .plan .item {
    background-color: #FDD5C0;
  }
  .lp-winter2025 .section-experience .plan .title {
    color: #255476;
    border-bottom: 5px solid #255476;
  }
  .lp-winter2025 .section-experience .plan .hotel {
    color: #255476;
    background-image: url(../images/experience-line.png);
  }
  .lp-winter2025 .plan {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(calc(33% - 40px), 1fr));
    gap: 48px 40px;
    width: 1380px;
    max-width: 100%;
    margin: 0 auto;
    padding: 0 50px;
  }
  .lp-winter2025 .plan .item a {
    display: block;
  }
  .lp-winter2025 .plan .item a:hover .img img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
  .lp-winter2025 .plan .img {
    margin-bottom: 15px;
    overflow: hidden;
  }
  .lp-winter2025 .plan .img img {
    width: 100%;
    aspect-ratio: 63/50;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: -webkit-transform 0.6s;
    transition: -webkit-transform 0.6s;
    transition: transform 0.6s;
    transition: transform 0.6s, -webkit-transform 0.6s;
  }
  .lp-winter2025 .plan .title {
    margin: 0;
    padding: 1em 15px;
    font-size: clamp(22px, 2.15vw, 26px);
    font-weight: 700;
    word-break: break-all;
    text-align: center;
    line-height: 1.5em;
  }
  .lp-winter2025 .plan .hotel {
    margin: 0;
    padding: 1em 15px 2em;
    font-size: clamp(15px, 1.5vw, 18px);
    font-weight: 700;
    word-break: break-all;
    background-repeat: no-repeat;
    background-size: 100% auto;
    background-position: center bottom;
  }
  .lp-winter2025 .plan .comment {
    margin: 0;
    padding: 1em 15px;
    font-size: 16px;
    font-weight: 500;
    color: #242C3C;
    line-height: 1.75em;
  }
  .last-banner {
    width: 100%;
    margin-top: 60px;
    padding: 0 50px;
    text-align: center;
  }
  .last-banner a {
    max-width: 100%;
  }
}