@charset "UTF-8";
/*********************************************
*
* 共通パーツ、初期設定
*
*********************************************/
/************************
**ブレイクポイント
************************/
/*min-widthベース、基本*/
/*max-widthベース、特定のクラスを途中まで、の場合*/
/*min-width,max-width混合、特定のクラスを途中から途中まで、の場合*/
/************************
**safari用
************************/
/************************
**全体
************************/
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: "Noto Serif JP", "游明朝", "Yu Mincho", "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "MS P明朝", "MS Mincho", serif;
  /*↑googlefont使用時*/
  font-weight: 500;
  font-feature-settings: "palt";
  font-optical-sizing: auto;
  font-size: 3.75vw;
}
@media screen and (min-width: 768px) {
  body {
    font-size: 1.822vw;
  }
}
@media screen and (min-width: 992px) {
  body {
    font-size: 1.612vw;
  }
}
@media screen and (min-width: 1200px) {
  body {
    font-size: min(1.5vw, 24px);
  }
}
p {
  line-height: 1.5;
  margin: 0;
  padding: 0;
}
p::before, p::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
p::before {
  margin-top: calc((1 - 1.5) * 0.5em);
}
p::after {
  margin-bottom: calc((1 - 1.5) * 0.5em);
}
p {
  display: inline-block;
}

/*画像サイズを要素のwidthに合わせる*/
img {
  width: 100%;
  height: auto;
  vertical-align: middle;
}
img.himg {
  width: auto;
  height: 100%;
}

/*リストのデザインを削除*/
ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

li {
  margin: 0;
  padding: 0;
}

/*ボタン化(aタグ、buttonタグを親要素に全体化)*/
.ab-a {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.ab-b {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none;
}

/*テキストを一塊にし、途中で改行させない*/
.txtb {
  display: inline-block;
}

/************************
**サイズ別br 使わないものはコメントアウト
************************/
.smartbr {
  display: block;
}
@media screen and (min-width: 576px) {
  .smartbr {
    display: none;
  }
}

/*スマホ(768px未満)*/
.spbr {
  display: block;
}
@media screen and (min-width: 768px) {
  .spbr {
    display: none;
  }
}

.smbr {
  display: none;
}
@media screen and (min-width: 576px) and (max-width: 767px) {
  .smbr {
    display: block;
  }
}

.mdbr {
  display: none;
}
@media screen and (min-width: 768px) and (max-width: 991px) {
  .mdbr {
    display: block;
  }
}

.lgbr {
  display: none;
}
@media screen and (min-width: 992px) and (max-width: 1199px) {
  .lgbr {
    display: block;
  }
}

.xlbr {
  display: none;
}
@media screen and (min-width: 1200px) and (max-width: 1399px) {
  .xlbr {
    display: block;
  }
}

.xxlbr {
  display: none;
}
@media screen and (min-width: 1400px) {
  .xxlbr {
    display: block;
  }
}

.sm-flbr {
  display: none;
}
@media screen and (min-width: 576px) {
  .sm-flbr {
    display: block;
  }
}

.md-flbr,
.pcbr {
  display: none;
}
@media screen and (min-width: 768px) {
  .md-flbr,
  .pcbr {
    display: block;
  }
}

.lg-flbr {
  display: none;
}
@media screen and (min-width: 992px) {
  .lg-flbr {
    display: block;
  }
}

.xl-flbr {
  display: none;
}
@media screen and (min-width: 1200px) {
  .xl-flbr {
    display: block;
  }
}

.xxl-flbr {
  display: none;
}
@media screen and (min-width: 1400px) {
  .xxl-flbr {
    display: block;
  }
}

/************************
**container 使わないものはコメントアウト
************************/
.container {
  width: 100%;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .container {
    width: 720px;
  }
}
@media screen and (min-width: 992px) {
  .container {
    width: 960px;
  }
}
@media screen and (min-width: 1200px) {
  .container {
    width: 1140px;
  }
}
@media screen and (min-width: 1400px) {
  .container {
    width: 1320px;
  }
}

/************************
** pc/sp切り替え
************************/
.sp-only {
  display: block;
}
@media screen and (min-width: 768px) {
  .sp-only {
    display: none;
  }
}

.pc-only {
  display: none;
}
@media screen and (min-width: 768px) {
  .pc-only {
    display: block;
  }
}

/*********************************************
*
*Header
*
*********************************************/
header #longchamp-hdr {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
}
header #longchamp-hdr .hdr-wrapper {
  position: relative;
}
header #longchamp-hdr .hdr-wrapper .hdr-frame {
  width: 100%;
  height: 80px;
  padding: 10px;
  position: relative;
}
@media screen and (min-width: 768px) {
  header #longchamp-hdr .hdr-wrapper .hdr-frame {
    width: 95%;
    margin-inline: auto;
  }
}
@media screen and (min-width: 992px) {
  header #longchamp-hdr .hdr-wrapper .hdr-frame {
    width: 960px;
  }
}
@media screen and (min-width: 1200px) {
  header #longchamp-hdr .hdr-wrapper .hdr-frame {
    width: 1140px;
  }
}
@media screen and (min-width: 1400px) {
  header #longchamp-hdr .hdr-wrapper .hdr-frame {
    width: 1320px;
  }
}
header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box {
  display: flex;
  align-items: center;
  height: 100%;
  gap: 20px;
}
@media screen and (min-width: 768px) {
  header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box {
    justify-content: space-between;
  }
}
@media screen and (min-width: 1200px) {
  header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box {
    gap: 0;
    justify-content: flex-start;
  }
}
header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-logo {
  height: 100%;
}
header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-sns {
  display: flex;
  align-items: center;
  gap: 10px;
  height: 100%;
}
@media screen and (min-width: 768px) {
  header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-sns {
    display: none;
  }
}
header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-sns .sns-item {
  height: 50%;
  position: relative;
}
header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-sns .sns-item .item-image {
  width: 100%;
  height: 100%;
}
header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav {
  position: fixed;
  top: 0;
  right: -275px;
  width: 275px;
  height: 100dvh;
  background-color: rgba(0, 0, 0, 0.8);
  transition: right 0.5s;
}
@media screen and (min-width: 768px) {
  header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav {
    position: static;
    top: inherit;
    right: initial;
    background-color: inherit;
    width: auto;
    height: auto;
  }
}
@media screen and (min-width: 992px) {
  header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav {
    width: calc((100% - 200px) * 0.8);
    margin-inline: auto;
  }
}
header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav .nav-wrap {
  width: 100%;
  height: 100%;
  padding: 40px 10px;
  position: relative;
}
@media screen and (min-width: 768px) {
  header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav .nav-wrap {
    padding: 0;
  }
}
header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav .nav-wrap nav {
  width: 100%;
  height: 100%;
  overflow-y: auto;
  font-size: min(1.5em, 24px);
}
@media screen and (min-width: 768px) {
  header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav .nav-wrap nav {
    font-size: min(1em, 16px);
    overflow-y: unset;
  }
}
@media screen and (min-width: 1200px) {
  header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav .nav-wrap nav {
    font-size: 18px;
  }
}
header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav .nav-wrap nav .nav-list {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 2em;
  color: #a98f52;
}
@media screen and (min-width: 768px) {
  header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav .nav-wrap nav .nav-list {
    flex-direction: row;
    gap: 2em;
  }
}
@media screen and (min-width: 992px) {
  header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav .nav-wrap nav .nav-list {
    justify-content: space-between;
  }
}
header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav .nav-wrap nav .nav-list .list-item {
  width: fit-content;
  position: relative;
}
@media screen and (min-width: 768px) {
  header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav .nav-wrap nav .nav-list .list-item {
    text-shadow: 3px 3px 3px #000;
  }
}
header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav .nav-wrap .hdr-hum {
  position: absolute;
  top: 30px;
  right: calc(100% + 10px);
  width: 30px;
  height: 20px;
}
@media screen and (min-width: 768px) {
  header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav .nav-wrap .hdr-hum {
    display: none;
  }
}
header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav .nav-wrap .hdr-hum .hum-wrap {
  width: 100%;
  height: 100%;
  position: relative;
}
header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav .nav-wrap .hdr-hum .hum-wrap .hum-line {
  position: absolute;
  width: 100%;
  height: 3px;
  background-color: #a98f52;
  transition: all 0.5s;
}
header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav .nav-wrap .hdr-hum .hum-wrap .hum-line:nth-child(1) {
  top: 0;
}
header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav .nav-wrap .hdr-hum .hum-wrap .hum-line:nth-child(2) {
  top: 50%;
  translate: 0 -50%;
}
header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav .nav-wrap .hdr-hum .hum-wrap .hum-line:nth-child(3) {
  bottom: 0%;
}
header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav.nav-active {
  right: 0;
}
header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav.nav-active .nav-wrap .hdr-hum .hum-wrap .hum-line {
  background-color: #fff;
}
header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav.nav-active .nav-wrap .hdr-hum .hum-wrap .hum-line:nth-child(1) {
  top: 50%;
  translate: 0 -50%;
  rotate: 45deg;
}
header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav.nav-active .nav-wrap .hdr-hum .hum-wrap .hum-line:nth-child(2) {
  opacity: 0;
}
header #longchamp-hdr .hdr-wrapper .hdr-frame .hdr-box .hdr-nav.nav-active .nav-wrap .hdr-hum .hum-wrap .hum-line:nth-child(3) {
  bottom: 50%;
  translate: 0 50%;
  rotate: -45deg;
}

/*********************************************
*
*footer
*
*********************************************/
footer {
  /************************
  **#longchamp-ftrinfo
  ************************/
}
footer #longchamp-ftrinfo .ftrinfo-wrapper {
  padding: 2.5em 0 1.5em;
  position: relative;
}
@media screen and (min-width: 768px) {
  footer #longchamp-ftrinfo .ftrinfo-wrapper {
    padding: min(1.5em, 30px) 0 min(3em, 60px);
  }
}
footer #longchamp-ftrinfo .ftrinfo-wrapper .ftrinfo-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5em;
  font-size: 1em;
  text-align: center;
}
@media screen and (min-width: 576px) {
  footer #longchamp-ftrinfo .ftrinfo-wrapper .ftrinfo-box {
    font-size: 0.65em;
  }
}
@media screen and (min-width: 768px) {
  footer #longchamp-ftrinfo .ftrinfo-wrapper .ftrinfo-box {
    font-size: min(1em, 15px);
  }
}
footer #longchamp-ftrinfo .ftrinfo-wrapper .ftrinfo-box .ftrinfo-logo {
  width: min(75%, 280px);
  margin-bottom: 1em;
}
footer #longchamp-ftrinfo .ftrinfo-wrapper .ftrinfo-box .ftrinfo-tel {
  margin-top: 0.5em;
}
footer #longchamp-ftrinfo .ftrinfo-wrapper .ftrinfo-box .ftrinfo-tel a {
  color: inherit;
  text-decoration: none;
  font-size: 1.5em;
  padding: 0 0.5em;
}
footer #longchamp-ftrinfo .ftrinfo-wrapper .ftrinfo-sns {
  display: none;
}
@media screen and (min-width: 768px) {
  footer #longchamp-ftrinfo .ftrinfo-wrapper .ftrinfo-sns {
    display: block;
    position: absolute;
    bottom: min(3em, 60px);
    right: 1em;
  }
}
@media screen and (min-width: 992px) {
  footer #longchamp-ftrinfo .ftrinfo-wrapper .ftrinfo-sns {
    right: min(3em, 60px);
  }
}
footer #longchamp-ftrinfo .ftrinfo-wrapper .ftrinfo-sns .sns-box {
  display: flex;
  gap: 20px;
}
footer #longchamp-ftrinfo .ftrinfo-wrapper .ftrinfo-sns .sns-box .sns-item {
  width: 30px;
  position: relative;
}
footer #longchamp-ftrinfo .ftrinfo-wrapper .ftrinfo-deco {
  position: absolute;
  bottom: 40%;
  right: -30%;
  width: 60%;
  z-index: 0;
}
@media screen and (min-width: 576px) {
  footer #longchamp-ftrinfo .ftrinfo-wrapper .ftrinfo-deco {
    bottom: 10%;
  }
}
@media screen and (min-width: 768px) {
  footer #longchamp-ftrinfo .ftrinfo-wrapper .ftrinfo-deco {
    right: -10%;
    bottom: 0;
    width: 35%;
  }
}
@media screen and (min-width: 992px) {
  footer #longchamp-ftrinfo .ftrinfo-wrapper .ftrinfo-deco {
    right: -5%;
    width: 30%;
  }
}
@media screen and (min-width: 1200px) {
  footer #longchamp-ftrinfo .ftrinfo-wrapper .ftrinfo-deco {
    right: -2.5%;
    width: min(27.5%, 400px);
  }
}
@media screen and (min-width: 1400px) {
  footer #longchamp-ftrinfo .ftrinfo-wrapper .ftrinfo-deco {
    width: min(24.5%, 350px);
  }
}
footer {
  /************************
  **#longchamp-ftrcopy
  ************************/
}
footer #longchamp-ftrcopy .ftrcopy-wrapper {
  padding: 1em 0;
  font-size: min(0.8em, 12px);
  text-align: center;
  border-top: 1px solid #a98f52;
}

/*********************************************
*
*共通、全体
*
*********************************************/
.wrapper {
  width: 100%;
  min-height: 100vh;
  background-color: #000;
  color: #fff;
  position: relative;
  overflow: hidden;
}
.wrapper main {
  position: relative;
  z-index: 1;
}
.wrapper main .anchor-posi {
  padding-top: 80px;
  margin-top: -80px;
}
.wrapper .title-image {
  height: min(1.8em, 60px);
  width: fit-content;
  margin-inline: auto;
  margin-bottom: 0.5em;
}

/*********************************************
*
*#longchamp-mainv
*
*********************************************/
#longchamp-mainv .mainv-wrapper {
  position: relative;
}
@media screen and (min-width: 768px) {
  #longchamp-mainv .mainv-wrapper {
    padding-bottom: 2em;
  }
}
@media screen and (min-width: 1920px) {
  #longchamp-mainv .mainv-wrapper {
    padding-bottom: 4em;
  }
}
#longchamp-mainv .mainv-wrapper .mainv-deco {
  position: absolute;
}
#longchamp-mainv .mainv-wrapper .mainv-deco.deco01 {
  top: 0;
  right: 0;
  width: 70%;
  z-index: 1;
  mix-blend-mode: screen;
}
@media screen and (min-width: 768px) {
  #longchamp-mainv .mainv-wrapper .mainv-deco.deco01 {
    width: 40%;
  }
}
@media screen and (min-width: 992px) {
  #longchamp-mainv .mainv-wrapper .mainv-deco.deco01 {
    width: 30%;
  }
}
#longchamp-mainv .mainv-wrapper .mainv-deco.deco02 {
  top: 80px;
  left: 0;
  width: 60%;
}
@media screen and (min-width: 768px) {
  #longchamp-mainv .mainv-wrapper .mainv-deco.deco02 {
    top: 20%;
    width: 35%;
  }
}
@media screen and (min-width: 992px) {
  #longchamp-mainv .mainv-wrapper .mainv-deco.deco02 {
    width: 28%;
  }
}
#longchamp-mainv .mainv-wrapper .mainv-deco.deco03 {
  top: 165vw;
  right: 0;
  width: 90%;
}
@media screen and (min-width: 768px) {
  #longchamp-mainv .mainv-wrapper .mainv-deco.deco03 {
    top: inherit;
    bottom: 0;
    width: 42%;
  }
}
@media screen and (min-width: 1400px) {
  #longchamp-mainv .mainv-wrapper .mainv-deco.deco03 {
    width: 38%;
  }
}
@media screen and (min-width: 1920px) {
  #longchamp-mainv .mainv-wrapper .mainv-deco.deco03 {
    width: 42%;
  }
}
#longchamp-mainv .mainv-wrapper .mainv-frame {
  position: relative;
  padding: 40vw 0 45vw;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  #longchamp-mainv .mainv-wrapper .mainv-frame {
    padding: 50px 0 0;
  }
}
#longchamp-mainv .mainv-wrapper .mainv-frame .mainv-logo {
  width: 80%;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  #longchamp-mainv .mainv-wrapper .mainv-frame .mainv-logo {
    width: 35%;
  }
}
@media screen and (min-width: 992px) {
  #longchamp-mainv .mainv-wrapper .mainv-frame .mainv-logo {
    width: 30%;
  }
}
@media screen and (min-width: 992px) {
  #longchamp-mainv .mainv-wrapper .mainv-frame .mainv-logo {
    width: 30%;
  }
}
@media screen and (min-width: 1400px) {
  #longchamp-mainv .mainv-wrapper .mainv-frame .mainv-logo {
    width: 25%;
  }
}
#longchamp-mainv .mainv-wrapper .mainv-frame .mainv-message {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1em;
}
#longchamp-mainv .mainv-wrapper .mainv-frame .mainv-message .message {
  width: fit-content;
  text-align: center;
}
#longchamp-mainv .mainv-wrapper .mainv-frame .mainv-message .message.m-01 {
  font-size: 1.8em;
  position: relative;
}
@media screen and (min-width: 768px) {
  #longchamp-mainv .mainv-wrapper .mainv-frame .mainv-message .message.m-01 {
    font-size: 2.4em;
  }
}
@media screen and (min-width: 1400px) {
  #longchamp-mainv .mainv-wrapper .mainv-frame .mainv-message .message.m-01 {
    font-size: 2.8em;
  }
}
#longchamp-mainv .mainv-wrapper .mainv-frame .mainv-message .message.m-01 .message-deco {
  position: absolute;
  bottom: calc(100% - 1.8em);
  left: calc(100% - 1.75em);
  width: 18.75vw;
  z-index: -1;
  mix-blend-mode: saturation;
}
@media screen and (min-width: 768px) {
  #longchamp-mainv .mainv-wrapper .mainv-frame .mainv-message .message.m-01 .message-deco {
    bottom: calc(100% - 1.25em);
    left: calc(100% - 1.5em);
    width: 7.85vw;
  }
}
@media screen and (min-width: 992px) {
  #longchamp-mainv .mainv-wrapper .mainv-frame .mainv-message .message.m-01 .message-deco {
    bottom: calc(100% - 1.5em);
    left: calc(100% - 1.5em);
    width: 9.5vw;
  }
}
@media screen and (min-width: 1200px) {
  #longchamp-mainv .mainv-wrapper .mainv-frame .mainv-message .message.m-01 .message-deco {
    bottom: calc(100% - 1.8em);
    left: calc(100% - 1.25em);
    width: 10vw;
  }
}
@media screen and (min-width: 768px) {
  #longchamp-mainv .mainv-wrapper .mainv-frame .mainv-message .message.m-02 {
    font-size: 1.25em;
  }
}
#longchamp-mainv .mainv-wrapper .mainv-frame .mainv-message .message.m-03 {
  font-size: 1.2em;
  color: #a98f52;
}
@media screen and (min-width: 768px) {
  #longchamp-mainv .mainv-wrapper .mainv-frame .mainv-message .message.m-03 {
    font-size: 1.5em;
  }
}

/*********************************************
*
*#longchamp-greeting
*
*********************************************/
#longchamp-greeting .greeting-wrapper {
  padding: 1.5em 0;
}
@media screen and (min-width: 992px) {
  #longchamp-greeting .greeting-wrapper {
    padding: 2.5em 0 1.25em;
  }
}
@media screen and (min-width: 1400px) {
  #longchamp-greeting .greeting-wrapper {
    padding: min(2.5em, 80px) 0 min(1.25em, 40px);
  }
}
#longchamp-greeting .greeting-wrapper .greeting-frame {
  width: 95%;
  margin-inline: auto;
}
@media screen and (min-width: 1200px) {
  #longchamp-greeting .greeting-wrapper .greeting-frame {
    width: min(95%, 1300px);
  }
}
@media screen and (min-width: 1400px) {
  #longchamp-greeting .greeting-wrapper .greeting-frame {
    width: min(95%, 1600px);
  }
}
#longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3em;
  position: relative;
  padding-bottom: 17.5vw;
}
@media screen and (min-width: 768px) {
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box {
    flex-direction: row;
    align-items: flex-start;
    gap: 1em;
    padding-bottom: 0;
  }
}
#longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-photo {
  width: 60%;
  order: 1;
}
@media screen and (min-width: 576px) {
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-photo {
    width: 50%;
  }
}
@media screen and (min-width: 768px) {
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-photo {
    width: 31.5%;
    order: 0;
    flex-shrink: 0;
  }
}
#longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-message {
  order: 0;
}
@media screen and (min-width: 768px) {
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-message {
    flex: 1 0 0;
  }
}
#longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-message .message-title {
  margin-inline: 0;
  margin-bottom: 1.5em;
}
@media screen and (min-width: 768px) {
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-message .message-title {
    margin-bottom: 0.75em;
  }
}
#longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-message .message-text {
  font-size: 1em;
}
#longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-message .message-text p::before, #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-message .message-text p::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
#longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-message .message-text p::before {
  margin-top: calc((1 - 2.5) * 0.5em);
}
#longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-message .message-text p::after {
  margin-bottom: calc((1 - 2.5) * 0.5em);
}
#longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-message .message-text p {
  line-height: 2.5;
}
@media screen and (min-width: 768px) {
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-message .message-text p::before, #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-message .message-text p::after {
    content: "";
    display: block;
    width: 0;
    height: 0;
  }
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-message .message-text p::before {
    margin-top: calc((1 - 2.2) * 0.5em);
  }
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-message .message-text p::after {
    margin-bottom: calc((1 - 2.2) * 0.5em);
  }
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-message .message-text p {
    line-height: 2.2;
  }
}
@media screen and (min-width: 576px) {
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-message .message-text {
    font-size: 0.7em;
  }
}
@media screen and (min-width: 768px) {
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-message .message-text {
    font-size: 0.825em;
  }
}
@media screen and (min-width: 992px) {
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-message .message-text {
    font-size: min(0.92em, 16px);
  }
}
@media screen and (min-width: 1200px) {
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-message .message-text {
    font-size: min(1em, 20px);
  }
}
@media screen and (min-width: 1400px) {
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-message .message-text {
    font-size: min(0.9em, 24px);
  }
}
#longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-name {
  order: 2;
}
@media screen and (min-width: 576px) {
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-name {
    font-size: 0.7em;
  }
}
@media screen and (min-width: 768px) {
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-name {
    position: absolute;
    bottom: 0;
    left: 50%;
    font-size: 0.825em;
  }
}
@media screen and (min-width: 992px) {
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-name {
    font-size: min(0.92em, 16px);
  }
}
@media screen and (min-width: 1200px) {
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-name {
    bottom: 2.5%;
    font-size: min(1em, 20px);
  }
}
@media screen and (min-width: 1400px) {
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-name {
    font-size: min(1em, 24px);
  }
}
#longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-name span {
  font-size: 1.2em;
  margin-left: 1em;
}
#longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-sign {
  position: absolute;
  bottom: 1em;
  left: 50%;
  width: 45%;
}
@media screen and (min-width: 768px) {
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-sign {
    top: 65%;
    bottom: inherit;
    left: 72.5%;
    width: 22.5%;
  }
}
@media screen and (min-width: 992px) {
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-sign {
    top: 68%;
    width: 20%;
  }
}
@media screen and (min-width: 1200px) {
  #longchamp-greeting .greeting-wrapper .greeting-frame .greeting-box .greeting-sign {
    left: 72.5%;
  }
}

/*********************************************
*
*#longchamp-info
*
*********************************************/
#longchamp-info .info-wrapper {
  padding: min(1.25em, 40px) 0;
}
@media screen and (min-width: 1200px) {
  #longchamp-info .info-wrapper {
    padding: min(2em, 80px) 0;
  }
}
#longchamp-info .info-wrapper .info-frame {
  width: 95%;
  margin-inline: auto;
}
@media screen and (min-width: 576px) {
  #longchamp-info .info-wrapper .info-frame {
    width: 90%;
  }
}
@media screen and (min-width: 768px) {
  #longchamp-info .info-wrapper .info-frame {
    width: 95%;
  }
}
@media screen and (min-width: 1200px) {
  #longchamp-info .info-wrapper .info-frame {
    width: min(95%, 1300px);
  }
}
@media screen and (min-width: 1400px) {
  #longchamp-info .info-wrapper .info-frame {
    width: min(95%, 1600px);
  }
}
#longchamp-info .info-wrapper .info-frame .info-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5em;
  position: relative;
}
@media screen and (min-width: 768px) {
  #longchamp-info .info-wrapper .info-frame .info-box {
    flex-direction: row;
    gap: 0.75em;
  }
}
#longchamp-info .info-wrapper .info-frame .info-box .info-item {
  flex: 1 0 0;
}
#longchamp-info .info-wrapper .info-frame .info-box .info-item .info-wrap {
  display: flex;
  border: 1px solid #a98f52;
}
#longchamp-info .info-wrapper .info-frame .info-box .info-item .info-wrap .info-image {
  width: 38%;
  flex-shrink: 0;
}
@media screen and (min-width: 576px) {
  #longchamp-info .info-wrapper .info-frame .info-box .info-item .info-wrap .info-image {
    width: 35%;
  }
}
@media screen and (min-width: 768px) {
  #longchamp-info .info-wrapper .info-frame .info-box .info-item .info-wrap .info-image {
    width: 32%;
  }
}
#longchamp-info .info-wrapper .info-frame .info-box .info-item .info-wrap .info-detail {
  flex: 1 0 0;
  padding: 0.75em 0.5em;
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 576px) {
  #longchamp-info .info-wrapper .info-frame .info-box .info-item .info-wrap .info-detail {
    padding: 1em 0.5em;
  }
}
@media screen and (min-width: 768px) {
  #longchamp-info .info-wrapper .info-frame .info-box .info-item .info-wrap .info-detail {
    padding: 0.75em 0.5em;
  }
}
@media screen and (min-width: 1200px) {
  #longchamp-info .info-wrapper .info-frame .info-box .info-item .info-wrap .info-detail {
    padding: 1em 0.5em;
  }
}
@media screen and (min-width: 1400px) {
  #longchamp-info .info-wrapper .info-frame .info-box .info-item .info-wrap .info-detail {
    padding: 30px 10px;
  }
}
@media screen and (max-width: 575px) {
  #longchamp-info .info-wrapper .info-frame .info-box .info-item .info-wrap .info-detail .detail-title {
    height: 1.7em;
  }
}
#longchamp-info .info-wrapper .info-frame .info-box .info-item .info-wrap .info-detail .detail-sentence {
  text-align: center;
  font-size: 0.85em;
}
@media screen and (min-width: 576px) {
  #longchamp-info .info-wrapper .info-frame .info-box .info-item .info-wrap .info-detail .detail-sentence {
    font-size: 0.65em;
  }
}
@media screen and (min-width: 768px) {
  #longchamp-info .info-wrapper .info-frame .info-box .info-item .info-wrap .info-detail .detail-sentence {
    font-size: 0.72em;
  }
}
@media screen and (min-width: 992px) {
  #longchamp-info .info-wrapper .info-frame .info-box .info-item .info-wrap .info-detail .detail-sentence {
    font-size: min(0.85em, 16px);
  }
}
@media screen and (min-width: 1200px) {
  #longchamp-info .info-wrapper .info-frame .info-box .info-item .info-wrap .info-detail .detail-sentence {
    font-size: min(0.9em, 18px);
  }
}
@media screen and (min-width: 1400px) {
  #longchamp-info .info-wrapper .info-frame .info-box .info-item .info-wrap .info-detail .detail-sentence {
    font-size: min(0.85em, 20px);
  }
}

/************************
**#longchamp-pricing
************************/
#longchamp-pricing .pricing-item {
  display: flex;
  flex-direction: column;
  gap: 0.5em;
  margin-top: 1em;
  height: 100%;
  text-align: center;
}
#longchamp-pricing .pricing-item .item-title,
#longchamp-pricing .pricing-item .item-unit {
  font-size: 1em;
}
@media screen and (min-width: 576px) {
  #longchamp-pricing .pricing-item .item-title,
  #longchamp-pricing .pricing-item .item-unit {
    font-size: 0.75em;
  }
}
@media screen and (min-width: 768px) {
  #longchamp-pricing .pricing-item .item-title,
  #longchamp-pricing .pricing-item .item-unit {
    font-size: 0.9em;
  }
}
@media screen and (min-width: 992px) {
  #longchamp-pricing .pricing-item .item-title,
  #longchamp-pricing .pricing-item .item-unit {
    font-size: min(1em, 20px);
  }
}
@media screen and (min-width: 1200px) {
  #longchamp-pricing .pricing-item .item-title,
  #longchamp-pricing .pricing-item .item-unit {
    font-size: min(1em, 24px);
  }
}
@media screen and (min-width: 1400px) {
  #longchamp-pricing .pricing-item .item-title,
  #longchamp-pricing .pricing-item .item-unit {
    font-size: min(1em, 28px);
  }
}
#longchamp-pricing .pricing-item .item-val {
  font-size: 1.5em;
}
@media screen and (min-width: 992px) {
  #longchamp-pricing .pricing-item .item-val {
    font-size: min(1.75em, 34px);
  }
}
#longchamp-pricing .pricing-item .item-note {
  font-size: 0.75em;
  margin-top: auto;
}
@media screen and (min-width: 576px) {
  #longchamp-pricing .pricing-item .item-note {
    font-size: 0.6em;
  }
}
@media screen and (min-width: 992px) {
  #longchamp-pricing .pricing-item .item-note {
    font-size: min(0.75em, 16px);
  }
}

/************************
**#longchamp-access
************************/
#longchamp-access .access-item {
  display: flex;
  flex-direction: column;
  gap: 0.5em;
  height: 100%;
  text-align: center;
}
#longchamp-access .access-item .item-title {
  font-size: 1em;
  margin-block: 1em;
}
@media screen and (min-width: 576px) {
  #longchamp-access .access-item .item-title {
    font-size: 0.75em;
  }
}
@media screen and (min-width: 992px) {
  #longchamp-access .access-item .item-title {
    font-size: 1em;
  }
}
#longchamp-access .access-item .item-button {
  width: 80%;
  margin-inline: auto;
  padding: 0.5em 0 0.75em;
  border: 1px solid #a98f52;
  position: relative;
}
#longchamp-access .access-item .item-button .button-text {
  font-size: 1.5em;
}
@media screen and (min-width: 768px) {
  #longchamp-access .access-item .item-button .button-text {
    font-size: 1.25em;
  }
}

/*********************************************
*
*#longchamp-history
*
*********************************************/
#longchamp-history .history-wrapper {
  padding: min(1.25em, 40px) 0;
}
#longchamp-history .history-wrapper .history-frame {
  width: 95%;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  #longchamp-history .history-wrapper .history-frame {
    width: 90%;
  }
}
@media screen and (min-width: 1200px) {
  #longchamp-history .history-wrapper .history-frame {
    width: min(90%, 1140px);
  }
}
@media screen and (min-width: 1400px) {
  #longchamp-history .history-wrapper .history-frame {
    width: min(90%, 1320px);
  }
}
#longchamp-history .history-wrapper .history-frame .history-title {
  position: relative;
}
@media screen and (min-width: 768px) {
  #longchamp-history .history-wrapper .history-frame .history-title {
    padding-bottom: min(1.5em, 80px);
  }
}
#longchamp-history .history-wrapper .history-frame .history-title .title-deco {
  width: 50%;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  #longchamp-history .history-wrapper .history-frame .history-title .title-deco {
    width: min(30%, 250px);
  }
}
#longchamp-history .history-wrapper .history-frame .history-title .title-main {
  position: absolute;
  bottom: 1em;
  width: 100%;
}
#longchamp-history .history-wrapper .history-frame .history-box {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 1.5em 1em;
}
@media screen and (min-width: 768px) {
  #longchamp-history .history-wrapper .history-frame .history-box {
    flex-wrap: nowrap;
    gap: 3.5em;
  }
}
@media screen and (min-width: 1200px) {
  #longchamp-history .history-wrapper .history-frame .history-box {
    gap: 4.5em;
  }
}
#longchamp-history .history-wrapper .history-frame .history-box .history-item {
  width: calc(50% - 0.5em);
}
@media screen and (min-width: 768px) {
  #longchamp-history .history-wrapper .history-frame .history-box .history-item {
    width: auto;
    flex: 1 0 0;
  }
}
#longchamp-history .history-wrapper .history-frame .history-box .history-item .item-info {
  margin-top: 0.5em;
  text-align: center;
}
#longchamp-history .history-wrapper .history-frame .history-box .history-item .item-info .info-title {
  color: #a98f52;
  margin-bottom: 0.5em;
  font-size: 1.15em;
}
#longchamp-history .history-wrapper .history-frame .history-box .history-item .item-info .info-sentence {
  font-size: min(0.85em, 18px);
}
@media screen and (min-width: 576px) {
  #longchamp-history .history-wrapper .history-frame .history-box .history-item .item-info .info-sentence {
    font-size: min(0.65em, 18px);
  }
}
@media screen and (min-width: 768px) {
  #longchamp-history .history-wrapper .history-frame .history-box .history-item .item-info .info-sentence {
    font-size: 0.72em;
  }
}
@media screen and (min-width: 992px) {
  #longchamp-history .history-wrapper .history-frame .history-box .history-item .item-info .info-sentence {
    font-size: min(0.85em, 16px);
  }
}
@media screen and (min-width: 1200px) {
  #longchamp-history .history-wrapper .history-frame .history-box .history-item .item-info .info-sentence {
    font-size: min(0.9em, 18px);
  }
}
@media screen and (min-width: 1400px) {
  #longchamp-history .history-wrapper .history-frame .history-box .history-item .item-info .info-sentence {
    font-size: min(0.75em, 20px);
  }
}
#longchamp-history .history-wrapper .history-frame .history-box .history-item:nth-child(1) .item-wrap02, #longchamp-history .history-wrapper .history-frame .history-box .history-item:nth-child(2) .item-wrap02 {
  margin-top: 1.5em;
}
#longchamp-history .history-wrapper .history-frame .history-box .history-item:nth-child(1) .item-wrap02 .info-sentence, #longchamp-history .history-wrapper .history-frame .history-box .history-item:nth-child(2) .item-wrap02 .info-sentence {
  display: flex;
  text-align: center;
  margin-top: 0.5em;
}
#longchamp-history .history-wrapper .history-frame .history-box .history-item:nth-child(1) .item-wrap02 .info-sentence .sentence01,
#longchamp-history .history-wrapper .history-frame .history-box .history-item:nth-child(1) .item-wrap02 .info-sentence .sentence02 {
  flex: 1 0 0;
}
#longchamp-history .history-wrapper .history-frame .history-box .history-item:nth-child(2) .item-wrap02 .info-sentence .sentence01 {
  width: 35%;
  flex-shrink: 0;
}
#longchamp-history .history-wrapper .history-frame .history-box .history-item:nth-child(2) .item-wrap02 .info-sentence .sentence02 {
  flex: 1 0 0;
}
@media screen and (max-width: 767px) {
  #longchamp-history .history-wrapper .history-frame .history-box .history-item:nth-last-child(1) {
    width: 70%;
  }
}
#longchamp-history .history-wrapper .history-frame .history-box .history-item:nth-last-child(1) .item-wrap02 {
  margin-top: 1.5em;
}
@media screen and (max-width: 767px) {
  #longchamp-history .history-wrapper .history-frame .history-box .history-item:nth-last-child(1) .item-wrap02 {
    display: none;
  }
}
#longchamp-history .history-wrapper .history-frame .history-box .history-item:nth-last-child(1) .item-wrap02 .info-sentence {
  text-align: center;
  margin-top: 0.5em;
}
#longchamp-history .history-wrapper .history-frame .history-message {
  padding: 2.5em 0;
  font-size: 1em;
  text-align: center;
}
@media screen and (min-width: 576px) {
  #longchamp-history .history-wrapper .history-frame .history-message {
    font-size: 0.7em;
  }
}
@media screen and (min-width: 768px) {
  #longchamp-history .history-wrapper .history-frame .history-message {
    font-size: 0.825em;
    padding: min(3.5em, 60px) 0;
  }
}
@media screen and (min-width: 992px) {
  #longchamp-history .history-wrapper .history-frame .history-message {
    font-size: min(0.9em, 16px);
  }
}
@media screen and (min-width: 1200px) {
  #longchamp-history .history-wrapper .history-frame .history-message {
    font-size: min(0.9em, 20px);
  }
}
@media screen and (min-width: 1400px) {
  #longchamp-history .history-wrapper .history-frame .history-message {
    font-size: min(0.9em, 24px);
  }
}/*# sourceMappingURL=style.css.map */