@charset "UTF-8";
/* =========================================================
 Foundation
========================================================= */
/* =========================================================
 Base
========================================================= */
/*==============================
 break point
 ============================== */
/*==============================
 色一覧
 ============================== */
/* ==============================
	base/base
================================= */
/* font settings */
@font-face {
  font-family: 'brown-bold';
  src: url("../fonts/brown/BrownStd-Bold.otf");
}

@font-face {
  font-family: 'brown';
  src: url("../fonts/brown/BrownStd-Regular.otf");
}

html {
  font-size: 62.5%;
  color: #333;
  -webkit-text-size-adjust: 100%;
}

body {
  position: static;
  font-size: 140%;
  font-family: "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial, sans-serif;
  line-height: 1.75;
}

canvas {
  vertical-align: top;
}

ul,
ol,
li {
  margin: 0;
  padding: 0;
  list-style-type: none;
}

a {
  text-decoration: none;
  color: #333;
}

img {
  height: auto;
  width: 100%;
  vertical-align: bottom;
}

img[src$=".svg"] {
  width: 100%;
}

i {
  font-style: normal;
}

button {
  border: none;
  border-color: none;
  background: none;
  cursor: pointer;
}

div {
  line-height: 1.3;
  letter-spacing: 0.05em;
}

p {
  font-size: inherit;
  line-height: 1.3;
  letter-spacing: 0.05em;
}

label {
  font-size: inherit;
  line-height: 1.3;
  letter-spacing: 0.05em;
}

input::-webkit-input-placeholder {
  font-size: inherit;
}

input::-moz-placeholder {
  font-size: inherit;
}

input:-ms-input-placeholder {
  font-size: inherit;
}

input::-ms-input-placeholder {
  font-size: inherit;
}

input::placeholder {
  font-size: inherit;
}

table {
  width: 100%;
  border-collapse: collapse;
}

main {
  display: block;
}

.is-sp {
  display: block !important;
}

.is-pc {
  display: none !important;
}

@media (min-width: 768px) {
  .is-sp {
    display: none !important;
  }
  .is-pc {
    display: block !important;
  }
}

.is-sp-wide {
  display: block !important;
}

.is-pc-wide {
  display: none !important;
}

@media (min-width: 1044px) {
  .is-sp-wide {
    display: none !important;
  }
  .is-pc-wide {
    display: block !important;
  }
}

/* ==============================
	base/ 調整
================================= */
.mt0 {
  margin-top: 0px !important;
}

.mt5 {
  margin-top: 5px !important;
}

.mt10 {
  margin-top: 10px !important;
}

.mt15 {
  margin-top: 15px !important;
}

.mt20 {
  margin-top: 20px !important;
}

.mt25 {
  margin-top: 25px !important;
}

.mt30 {
  margin-top: 30px !important;
}

.mt35 {
  margin-top: 35px !important;
}

.mt40 {
  margin-top: 40px !important;
}

.mt45 {
  margin-top: 45px !important;
}

.mt50 {
  margin-top: 50px !important;
}

.mt55 {
  margin-top: 55px !important;
}

.mb0 {
  margin-bottom: 0px !important;
}

.mb5 {
  margin-bottom: 5px !important;
}

.mb10 {
  margin-bottom: 10px !important;
}

.mb15 {
  margin-bottom: 15px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.mb25 {
  margin-bottom: 25px !important;
}

.mb30 {
  margin-bottom: 30px !important;
}

.mb35 {
  margin-bottom: 35px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.mb45 {
  margin-bottom: 45px !important;
}

.mb50 {
  margin-bottom: 50px !important;
}

.mb60 {
  margin-bottom: 60px !important;
}

.mb80 {
  margin-bottom: 80px !important;
}

.mb100 {
  margin-bottom: 100px !important;
}

.mb110 {
  margin-bottom: 110px !important;
}

.mb120 {
  margin-bottom: 120px !important;
}

.ml0 {
  margin-left: 0px !important;
}

.ml5 {
  margin-left: 5px !important;
}

.ml10 {
  margin-left: 10px !important;
}

.ml15 {
  margin-left: 15px !important;
}

.ml20 {
  margin-left: 20px !important;
}

.ml25 {
  margin-left: 25px !important;
}

.ml30 {
  margin-left: 30px !important;
}

.ml35 {
  margin-left: 35px !important;
}

.ml40 {
  margin-left: 40px !important;
}

.ml45 {
  margin-left: 45px !important;
}

.ml50 {
  margin-left: 50px !important;
}

.mr0 {
  margin-right: 0px !important;
}

.mr5 {
  margin-right: 5px !important;
}

.mr10 {
  margin-right: 10px !important;
}

.mr15 {
  margin-right: 15px !important;
}

.mr20 {
  margin-right: 20px !important;
}

.mr25 {
  margin-right: 25px !important;
}

.mr30 {
  margin-right: 30px !important;
}

.mr35 {
  margin-right: 35px !important;
}

.mr40 {
  margin-right: 40px !important;
}

.mr45 {
  margin-right: 45px !important;
}

.mr50 {
  margin-right: 50px !important;
}

.pt0 {
  padding-top: 0px !important;
}

.pt10 {
  padding-top: 10px !important;
}

.pb0 {
  padding-bottom: 0px !important;
}

.ls0 {
  letter-spacing: 0 !important;
}

/* =========================================================
 Layout
========================================================= */
.l-header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  width: 100%;
}

body {
  width: 100%;
}

body.modaal-noscroll {
  width: 100%;
  left: 0;
}

body.is-fixed {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
}

/* =========================================================
 Module
========================================================= */
.about-ttl {
  font-size: 26px;
  line-height: 1;
  letter-spacing: 0.05em;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  text-align: center;
}

@media (min-width: 768px) {
  .about-ttl {
    font-size: 30px;
    letter-spacing: 0.03em;
  }
}

@media (min-width: 768px) {
  .about-ttl-border span {
    position: relative;
  }
  .about-ttl-border span:before {
    content: "";
    border: 1px solid #B2B2B2;
    width: 70px;
    position: absolute;
    top: 50%;
    left: -85px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .about-ttl-border span:after {
    content: "";
    border: 1px solid #B2B2B2;
    width: 70px;
    position: absolute;
    top: 50%;
    right: -85px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}

.about-statement {
  background-color: #F2F2F2;
}

.about-statement-bg {
  background-color: #fff;
}

.about-statement-item {
  padding: 0 15px;
}

@media (min-width: 768px) {
  .about-statement-item {
    padding: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

.about-statement-item-img {
  margin: 0 -15px;
}

@media (min-width: 768px) {
  .about-statement-item-img {
    margin: 0;
    width: 582px;
  }
}

.about-statement-item-txt {
  line-height: 1.714;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .about-statement-item-txt {
    line-height: 1.857;
  }
}

.about-statement-item-txt-wrap {
  margin-top: 52px;
}

@media (min-width: 768px) {
  .about-statement-item-txt-wrap {
    margin-top: 0;
  }
}

.about-statement-item-ttl {
  font-size: 28px;
  line-height: 1.214;
  letter-spacing: 0.06em;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  text-align: center;
}

@media (min-width: 768px) {
  .about-statement-item-ttl {
    font-size: 36px;
    line-height: 1.222;
    text-align: left;
  }
}

.about-statement-item-ttl span {
  letter-spacing: -0.1em;
}

.about-statement-item-subttl {
  margin-top: 3px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1.444;
  letter-spacing: 0.02em;
  text-align: center;
}

@media (min-width: 768px) {
  .about-statement-item-subttl {
    margin-top: 5px;
    text-align: left;
  }
}

.about-statement-item-select {
  margin-top: 31px;
}

@media (min-width: 768px) {
  .about-statement-item-select {
    margin-top: 74px;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
}

@media (min-width: 768px) {
  .about-statement-item-select .about-statement-item-img {
    max-width: 466px;
    width: 45.9%;
  }
}

.about-statement-item-select .about-statement-item-txt {
  margin-top: 38px;
}

@media (min-width: 768px) {
  .about-statement-item-select .about-statement-item-txt-wrap {
    max-width: 520px;
    width: 51.2%;
    margin-right: 30px;
  }
}

.about-statement-item-right {
  margin-top: 96px;
}

@media (min-width: 768px) {
  .about-statement-item-right {
    margin-top: 72px;
  }
}

@media (min-width: 768px) {
  .about-statement-item-right .about-statement-item-img {
    max-width: 510px;
    width: 46.8%;
  }
}

.about-statement-item-right .about-statement-item-txt {
  margin-top: 32px;
}

@media (min-width: 768px) {
  .about-statement-item-right .about-statement-item-txt-wrap {
    padding-top: 11px;
    max-width: 550px;
    width: 50.5%;
    margin-left: 30px;
  }
}

.about-statement-item-gift {
  margin-top: 105px;
}

@media (min-width: 768px) {
  .about-statement-item-gift {
    margin-top: 93px;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
}

@media (min-width: 768px) {
  .about-statement-item-gift .about-statement-item-img {
    max-width: 408px;
    width: 40.9%;
  }
}

.about-statement-item-gift .about-statement-item-txt {
  margin-top: 38px;
}

@media (min-width: 768px) {
  .about-statement-item-gift .about-statement-item-txt-wrap {
    max-width: 560px;
    width: 56.1%;
    margin-right: 30px;
  }
}

.about-statement-item-mission {
  margin-top: 32px;
}

@media (max-width: 979px) {
  .about-statement-item-mission {
    display: block;
  }
}

@media (min-width: 980px) {
  .about-statement-item-mission {
    margin-top: 70px;
  }
}

.about-statement-box {
  border: 1px solid #B2B2B2;
  padding: 18px 16px 23px;
}

@media (min-width: 768px) {
  .about-statement-box {
    width: calc((100% - 40px)/3);
    padding: 25px 16px 34px;
  }
}

.about-statement-box + .about-statement-box {
  margin-top: 26px;
}

@media (min-width: 768px) {
  .about-statement-box + .about-statement-box {
    margin-top: 0;
    margin-left: 30px;
  }
}

.about-statement-box-wrap {
  margin: 32px 15px 40px;
}

@media (min-width: 768px) {
  .about-statement-box-wrap {
    margin: 32px 0 44px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.about-statement-box-ttl {
  font-size: 24px;
  font-weight: bold;
  text-align: center;
}

.about-statement-box-txt {
  margin-top: 12px;
  line-height: 1.714;
}

@media (min-width: 768px) {
  .about-statement-box-txt {
    margin-top: 18px;
  }
}

@media (min-width: 768px) {
  .about-statement-feature {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: baseline;
        -ms-flex-align: baseline;
            align-items: baseline;
  }
}

.about-statement-feature + .about-statement-feature {
  margin-top: 22px;
}

.about-statement-feature-wrap {
  margin: 50px 0 47px;
  text-align: center;
}

@media (min-width: 768px) {
  .about-statement-feature-wrap {
    margin: 57px 0 40px;
    text-align: left;
  }
}

.about-statement-feature-ttl {
  width: 240px;
  margin: 0 auto;
  padding: 5px 10px;
  background-color: #333;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  text-align: center;
}

@media (min-width: 768px) {
  .about-statement-feature-ttl {
    width: 150px;
    margin: 0;
  }
}

@media (min-width: 855px) {
  .about-statement-feature-ttl {
    width: 180px;
  }
}

.about-statement-feature-txt {
  margin-top: 9px;
  font-size: 16px;
  line-height: 1.714;
  font-weight: bold;
}

@media (min-width: 768px) {
  .about-statement-feature-txt {
    margin-top: 0;
    padding-left: 80px;
    position: relative;
  }
}

@media (min-width: 855px) {
  .about-statement-feature-txt {
    padding-left: 100px;
  }
}

@media (min-width: 768px) {
  .about-statement-feature-txt {
    padding-left: 108px;
  }
}

@media (min-width: 768px) {
  .about-statement-feature-txt:before {
    content: '\02022\02022\02022\02022\02022\02022\02022\02022\02022\02022\02022\02022';
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    left: 8px;
    font-weight: 300;
    font-size: 10px;
    letter-spacing: 0.02em;
  }
}

@media (min-width: 855px) {
  .about-statement-feature-txt:before {
    left: 18px;
  }
}

.about-statement-feature-mission {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.about-statement-feature-mission .about-statement-feature-ttl {
  width: 310px;
  font-size: 14px;
  padding: 8px 5px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  letter-spacing: 0.02em;
}

@media (max-width: 340px) {
  .about-statement-feature-mission .about-statement-feature-ttl {
    width: 290px;
  }
}

@media (min-width: 768px) {
  .about-statement-feature-mission .about-statement-feature-ttl {
    font-size: 16px;
    line-height: 1.625;
    width: 216px;
    min-height: 69px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

.about-statement-feature-mission .about-statement-feature-txt {
  letter-spacing: 0.02em;
}

.about-statement-feature-mission .about-statement-feature-txt:before {
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.about-statement-vision {
  padding: 20px 0 69px;
  margin-bottom: 66px;
}

@media (min-width: 768px) {
  .about-statement-vision {
    padding: 26px 0 64px;
    margin-bottom: 58px;
  }
}

.about-statement-vision-inner {
  margin-top: 37px;
}

@media (min-width: 768px) {
  .about-statement-vision-inner {
    margin-top: 21px;
  }
}

.about-statement-vision-txt {
  margin-top: 29px;
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.04em;
  line-height: 1.75;
}

@media (min-width: 768px) {
  .about-statement-vision-txt {
    margin-top: 39px;
  }
}

.about-statement-vision-item {
  padding: 0 15px;
  margin-top: 22px;
}

@media (min-width: 1000px) {
  .about-statement-vision-item {
    padding: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: 49px;
    min-height: 656px;
    padding-right: 10px;
    width: 100%;
    padding-right: 10px;
  }
}

@media (min-width: 1164px) {
  .about-statement-vision-item {
    margin-right: auto;
    max-width: calc(1154px + ((100% - 1154px)/2));
  }
}

@media (min-width: 1321px) {
  .about-statement-vision-item {
    -webkit-transform: translateX(-89px);
            transform: translateX(-89px);
    margin: 49px auto 0;
    max-width: 1321px;
  }
}

.about-statement-vision-item-img {
  margin: 0 -15px;
}

@media (min-width: 1000px) {
  .about-statement-vision-item-img {
    margin: 0;
    max-width: 582px;
    width: 46.5%;
  }
}

@media (min-width: 1000px) {
  .about-statement-vision-item-ttl {
    text-align: center;
  }
}

.about-statement-vision-item-txt-wrap {
  margin-top: 52px;
}

@media (min-width: 1000px) {
  .about-statement-vision-item-txt-wrap {
    margin-top: 0;
    max-width: 639px;
    width: 51.1%;
    margin-left: 30px;
  }
}

@media (min-width: 1164px) {
  .about-statement-vision-item-txt-wrap {
    margin-left: 100px;
  }
}

.about-statement-value {
  padding: 65px 0 101px;
  margin-bottom: 86px;
}

@media (min-width: 768px) {
  .about-statement-value {
    padding: 90px 0 151px;
    margin-bottom: 102px;
  }
}

@media (min-width: 768px) {
  .about-statement-value-inner {
    padding: 0 10px;
    max-width: 1164px;
    margin: 0 auto;
  }
}

.about-statement-store {
  padding: 42px 0 55px;
}

@media (min-width: 768px) {
  .about-statement-store {
    padding: 130px 0 114px;
  }
}

.about-statement-store .heading-1 {
  margin-bottom: 31px;
}

@media (min-width: 768px) {
  .about-statement-store .heading-1 {
    margin-bottom: 43px;
  }
}

.about-statement-mission {
  padding: 65px 0 100px;
  margin-bottom: 66px;
}

@media (min-width: 768px) {
  .about-statement-mission-inner {
    padding: 0 10px;
    max-width: 1164px;
    margin: 0 auto;
  }
}

.about-statement-mission-lead {
  margin-top: 52px;
}

@media (min-width: 768px) {
  .about-statement-mission-lead {
    text-align: center;
    margin-top: 55px;
  }
}

.about-statement-mission .mission-lead-txt {
  font-size: 14px;
  line-height: 1.71429;
  margin-top: 30px;
}

@media (min-width: 768px) {
  .about-statement-mission .mission-lead-txt {
    margin-top: 20px;
  }
}

.about-statement-mission .mission-lead-txt-en {
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  font-size: 18px;
  line-height: 1.5;
  letter-spacing: 0.06em;
  font-weight: bold !important;
}

@media (min-width: 768px) {
  .about-statement-mission .mission-lead-txt-en {
    font-size: 30px;
    line-height: 1.5;
  }
}

.about-statement-mission .mission-detail {
  margin-top: 28px;
}

.about-statement-mission .mission-detail-txt {
  margin-top: 0;
  letter-spacing: 0.02em;
  text-align: left;
}

@media (min-width: 768px) {
  .about-statement-mission .about-statement-item-img {
    width: 100%;
    max-width: 100%;
  }
}

@media (min-width: 980px) {
  .about-statement-mission .about-statement-item-img {
    max-width: 452px;
    margin-right: 20px;
  }
}

@media (min-width: 768px) {
  .about-statement-mission .about-statement-feature-wrap {
    width: 100%;
  }
}

@media (min-width: 980px) {
  .about-statement-mission .about-statement-feature-wrap {
    width: calc(100% - 472px);
    max-width: 608px;
    margin-top: 0;
  }
}

.about-history-mv {
  padding: 20px 0 78px;
}

@media (min-width: 768px) {
  .about-history-mv {
    padding: 26px 0 88px;
  }
}

.about-history-mv-inner {
  margin-top: 37px;
}

@media (min-width: 768px) {
  .about-history-mv-inner {
    padding: 0 10px;
    max-width: 1164px;
    margin: 21px auto 0;
  }
}

.about-history-mv-inner .about-ttl {
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .about-history-mv-inner .about-ttl {
    letter-spacing: 0.03em;
  }
}

.about-history-mv-item {
  margin-top: 22px;
  padding: 0 15px;
}

@media (min-width: 768px) {
  .about-history-mv-item {
    margin-top: 49px;
    padding: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

.about-history-mv-item-img {
  margin: 0 -15px;
}

@media (min-width: 768px) {
  .about-history-mv-item-img {
    margin: 0;
    max-width: 516px;
    width: 48.4%;
  }
}

.about-history-mv-item-txt {
  margin-top: 53px;
  font-weight: 500;
  line-height: 1.714;
  letter-spacing: 0.02em;
  margin-top: 52px;
}

@media (min-width: 768px) {
  .about-history-mv-item-txt {
    margin-top: 0;
    max-width: 520px;
    width: 48.8%;
    margin-left: 30px;
    line-height: 1.857;
  }
}

.about-history-list {
  margin-top: 59px;
  padding-left: 43px;
  margin-left: 8px;
  position: relative;
}

@media (min-width: 768px) {
  .about-history-list {
    margin-top: 56px;
    margin-left: 0;
    padding-left: 81px;
  }
}

.about-history-list:before {
  content: "";
  border-left: 8px solid #4C4948;
  position: absolute;
  left: 0;
  top: -29px;
  height: calc(100% + 206px);
}

@media (min-width: 768px) {
  .about-history-list:before {
    border-left: 10px solid #4C4948;
    top: -134px;
    height: calc(100% + 372px);
  }
}

@media (min-width: 768px) {
  .about-history-list li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

.about-history-list li + li {
  margin-top: 65px;
}

@media (min-width: 768px) {
  .about-history-list li + li {
    margin-top: 70px;
  }
}

.about-history-list-wrap {
  background-color: #F2F2F2;
  padding: 60px 0 140px;
}

@media (min-width: 768px) {
  .about-history-list-wrap {
    padding: 93px 0 155px;
  }
}

.about-history-list-subttl {
  margin-bottom: 10px;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  font-size: 22px;
  font-weight: bold;
  letter-spacing: 0.04em;
  line-height: 1.23;
  text-align: center;
}

@media (min-width: 768px) {
  .about-history-list-subttl {
    margin-bottom: 13px;
    font-size: 24px;
    line-height: 1.21;
  }
}

.about-history-list-heading {
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  font-size: 30px;
  font-weight: bold;
  letter-spacing: 0.02em;
  line-height: 1.23;
  text-align: center;
}

@media (min-width: 768px) {
  .about-history-list-heading {
    font-size: 38px;
    letter-spacing: 0.04em;
    line-height: 1.21;
  }
}

.about-history-list-period {
  position: relative;
  color: #4C4948;
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.04em;
  line-height: 1.6666;
}

@media (min-width: 768px) {
  .about-history-list-period {
    font-size: 20px;
  }
}

.about-history-list-period span {
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  margin-right: 8px;
  color: #8D6B0D;
  font-size: 40px;
  letter-spacing: 0;
  line-height: 1.2;
}

@media (min-width: 768px) {
  .about-history-list-period span {
    font-size: 50px;
  }
}

.about-history-list-period:before {
  content: "";
  width: 24px;
  height: 24px;
  border: 4px solid #4C4948;
  background-color: #8D6B0D;
  border-radius: 50%;
  position: absolute;
  left: -51px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  z-index: 3;
}

@media (min-width: 768px) {
  .about-history-list-period:before {
    width: 28px;
    height: 28px;
    left: -90px;
  }
}

.about-history-list-period:after {
  content: "";
  width: 20px;
  border-top: 2px solid #4C4948;
  position: absolute;
  left: -28px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  z-index: 2;
}

@media (min-width: 768px) {
  .about-history-list-period:after {
    width: 35px;
    left: -64px;
  }
}

.about-history-list-ttl {
  margin-top: 26px;
  color: #8D6B0D;
  font-size: 16px;
  letter-spacing: 0.04em;
  line-height: 1.625;
}

@media (min-width: 768px) {
  .about-history-list-ttl {
    margin-top: 22px;
    font-size: 18px;
  }
}

.about-history-list-txt {
  margin-top: 10px;
  letter-spacing: 0.02em;
  line-height: 1.714;
}

@media (min-width: 768px) {
  .about-history-list-txt {
    line-height: 1.857;
  }
}

@media (min-width: 768px) {
  .about-history-list-txt-wrap {
    margin-right: 30px;
    width: 62.2%;
    max-width: 552px;
  }
}

.about-history-list-img {
  margin: 0 auto;
}

@media (min-width: 768px) {
  .about-history-list-img {
    margin: 0 0 0 auto;
    width: 34.4%;
    max-width: 305px;
  }
}

.about-history-list-img + .about-history-list-img {
  margin-top: 24px;
}

.about-history-list-img-wrap {
  margin-top: 40px;
}

@media (min-width: 768px) {
  .about-history-list-img-wrap {
    margin-top: 0;
  }
}

.about-history-list-img.period-1920 {
  width: 153px;
}

@media (min-width: 768px) {
  .about-history-list-img.period-1920 {
    width: 262px;
  }
}

.about-history-list-img.period-1960 {
  width: 146px;
}

@media (min-width: 768px) {
  .about-history-list-img.period-1960 {
    width: 201px;
  }
}

.about-history-list-img.period-1970 {
  width: 222px;
}

@media (min-width: 768px) {
  .about-history-list-img.period-1970 {
    width: 295px;
  }
}

@media (min-width: 768px) {
  .about-history-list-img.period-1970 + .about-history-list-img.period-1970 {
    margin-top: 92px;
  }
}

.about-history-list-img.period-1980:first-child {
  width: 222px;
}

@media (min-width: 768px) {
  .about-history-list-img.period-1980:first-child {
    width: 295px;
  }
}

.about-history-list-img.period-1980:last-child {
  width: 173px;
}

@media (min-width: 768px) {
  .about-history-list-img.period-1980:last-child {
    width: 230px;
  }
}

@media (min-width: 768px) {
  .about-history-list-img.period-1980 + .about-history-list-img.period-1980 {
    margin-top: 77px;
  }
}

.about-history-list-img.period-1990 {
  width: 221px;
}

@media (min-width: 768px) {
  .about-history-list-img.period-1990 {
    width: 305px;
  }
}

.about-history-list-img.period-2000 {
  width: 198px;
}

@media (min-width: 768px) {
  .about-history-list-img.period-2000 {
    width: 261px;
  }
}

.about-history-list-select {
  margin-top: 30px;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  color: #8D6B0D;
  font-size: 39px;
  line-height: 1.23;
  letter-spacing: 0.03em;
  position: relative;
  display: inline-block;
}

@media (min-width: 768px) {
  .about-history-list-select {
    margin-top: 77px;
    font-size: 54px;
    line-height: 1.185;
  }
}

.about-history-list-select span {
  margin-top: 5px;
  display: block;
  color: #333;
  font-size: 13px;
  font-weight: bold;
  letter-spacing: 0.02em;
  line-height: 1.46;
}

@media (min-width: 768px) {
  .about-history-list-select span {
    margin-top: 0;
    display: inline-block;
    font-size: 17px;
    position: absolute;
    top: 19px;
    right: -10px;
  }
}

.about-history-logo {
  background-color: #333;
  color: #fff;
  padding: 66px 0 117px;
}

@media (min-width: 768px) {
  .about-history-logo {
    padding: 83px 0 121px;
  }
}

.about-history-logo-inner {
  margin: 0 auto;
  padding: 0 15px;
}

@media (min-width: 768px) {
  .about-history-logo-inner {
    max-width: 1072px;
    padding: 0 10px;
  }
}

.about-history-logo-inner .about-ttl {
  letter-spacing: 0.04em;
}

@media (min-width: 768px) {
  .about-history-logo-inner .about-ttl {
    letter-spacing: 0.03em;
  }
}

.about-history-logo-item {
  margin-top: 40px;
}

@media (min-width: 768px) {
  .about-history-logo-item {
    margin-top: 49px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

@media (min-width: 1206px) {
  .about-history-logo-item {
    -webkit-transform: translateX(51px);
            transform: translateX(51px);
  }
}

.about-history-logo-item-img {
  width: 90.1%;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .about-history-logo-item-img {
    margin: 0 0 0 30px;
    width: 47.4%;
    max-width: 436px;
  }
}

.about-history-logo-item-txt {
  margin-top: 52px;
  letter-spacing: 0.02em;
  line-height: 1.714;
}

@media (min-width: 768px) {
  .about-history-logo-item-txt {
    margin-top: 0;
    max-width: 516px;
    width: 52.5%;
    line-height: 1.857;
  }
}

.about-info-inner {
  margin: 33px auto 114px;
}

@media (min-width: 768px) {
  .about-info-inner {
    margin: 41px auto 164px;
  }
}

.about-info-list {
  margin-top: 46px;
}

@media (min-width: 768px) {
  .about-info-list {
    margin-top: 54px;
  }
}

.about-info-list-item {
  border-top: 1px solid #B2B2B2;
  padding: 15px 0;
}

.about-info-list-item:last-child {
  border-bottom: 1px solid #B2B2B2;
}

@media (min-width: 768px) {
  .about-info-list-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: baseline;
        -ms-flex-align: baseline;
            align-items: baseline;
  }
}

.about-info-list-item .txt-note {
  margin-top: 4px;
}

@media (min-width: 768px) {
  .about-info-list-item .txt-note {
    margin-top: 0;
    margin-left: 30px;
    white-space: nowrap;
  }
}

.about-info-list-ttl {
  font-size: 14px;
  letter-spacing: 0.02em;
  font-weight: bold;
}

@media (min-width: 768px) {
  .about-info-list-ttl {
    font-size: 16px;
    width: 140px;
    margin-right: 25px;
  }
}

.about-info-list-txt {
  margin-top: 5px;
  line-height: 1.714;
}

@media (min-width: 768px) {
  .about-info-list-txt {
    margin-top: 0;
    width: calc(100% - 165px);
    -webkit-box-align: baseline;
        -ms-flex-align: baseline;
            align-items: baseline;
    line-height: 1.857;
  }
}

.about-info-store {
  margin-top: 94px;
}

.about-info-store .heading-4.heading-4-square {
  margin-bottom: 33px;
  font-weight: bold !important;
}

@media (min-width: 768px) {
  .about-info-store .heading-4.heading-4-square {
    margin-bottom: 25px;
  }
}

.app-mv-subttl {
  margin-top: 7px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.04em;
}

@media (min-width: 768px) {
  .app-mv-subttl {
    margin-top: 97px;
    font-size: 28px;
  }
}

.app-lead-wrap {
  padding: 43px 15px 79px;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .app-lead-wrap {
    padding: 86px 10px 60px;
    max-width: 1044px;
  }
}

.app-lead-ttl {
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  font-size: 24px;
  line-height: 1.5;
  letter-spacing: 0.03em;
  font-weight: bold !important;
}

@media (min-width: 768px) {
  .app-lead-ttl {
    font-size: 26px;
  }
}

.app-lead-ttl-wrap span {
  display: block;
  text-align: center;
}

.app-lead-ttl-sub {
  margin-bottom: 3px;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.03em;
  color: #333;
}

@media (min-width: 768px) {
  .app-lead-ttl-sub {
    font-size: 18px;
  }
}

.app-lead-txt {
  margin: 32px auto 31px;
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.02em;
  line-height: 1.625;
}

@media (min-width: 768px) {
  .app-lead-txt {
    margin: 38px auto 50px;
    margin-top: 38px;
    text-align: center;
  }
}

.app-btn {
  -webkit-transition: .3s;
  transition: .3s;
}

.app-btn + .app-btn {
  margin-left: 14px;
}

@media (min-width: 768px) {
  .app-btn:hover {
    opacity: 0.7;
  }
}

.app-btn-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.app-btn-apple {
  width: 136px;
}

.app-btn-google {
  width: 171px;
}

@media (min-width: 768px) {
  .app-feature.feature01 .app-feature-contents-ttl {
    top: 20px;
    left: -100px;
  }
}

@media (min-width: 1044px) {
  .app-feature.feature01 .app-feature-contents-ttl {
    top: 71px;
    left: -130px;
  }
}

@media (min-width: 768px) {
  .app-feature.feature01 .app-feature-contents-detail {
    max-width: 500px;
  }
}

@media (min-width: 1044px) {
  .app-feature.feature01 .app-feature-contents-detail {
    max-width: 645px;
  }
}

.app-feature.feature01 .app-feature-img {
  width: calc(100% - 22px);
  margin-right: auto;
}

@media (min-width: 768px) {
  .app-feature.feature01 .app-feature-img {
    margin-right: -81px;
    width: calc(100% + 81px);
    max-width: 315px;
  }
}

@media (min-width: 1044px) {
  .app-feature.feature01 .app-feature-img {
    margin-right: -70px;
    width: calc(100% + 162px);
    max-width: 323px;
  }
}

@media (min-width: 768px) {
  .app-feature.feature02 .app-feature-contents-ttl {
    top: -65px;
    left: auto;
    right: 15px;
  }
}

@media (min-width: 950px) {
  .app-feature.feature02 .app-feature-contents-ttl {
    top: 58px;
    right: -62px;
  }
}

@media (min-width: 1044px) {
  .app-feature.feature02 .app-feature-contents-ttl {
    right: -42px;
  }
}

@media (min-width: 768px) {
  .app-feature.feature02 .app-feature-contents-img {
    margin-right: 10px;
  }
}

@media (min-width: 768px) {
  .app-feature.feature02 .app-feature-img {
    width: calc(100% + 30px);
    margin-left: -30px;
    max-width: 352px;
  }
}

@media (min-width: 1044px) {
  .app-feature.feature02 .app-feature-img {
    width: calc(100% + 59px);
    margin-left: -59px;
    max-width: 452px;
  }
}

@media (min-width: 768px) {
  .app-feature.feature03 .app-feature-contents-ttl {
    bottom: auto;
    top: 30px;
    left: 60px;
  }
}

@media (min-width: 1044px) {
  .app-feature.feature03 .app-feature-contents-ttl {
    top: 77px;
    left: 131px;
  }
}

.app-feature.feature03 .app-feature-img {
  padding-bottom: 0;
}

@media (min-width: 768px) {
  .app-feature.feature03 .app-feature-img {
    margin-bottom: 0;
    margin-right: -35px;
    width: calc(100% + 35px);
    max-width: 501px;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@media (min-width: 1044px) {
  .app-feature.feature03 .app-feature-img {
    margin-right: -70px;
    width: calc(100% + 70px);
    max-width: 612px;
  }
}

.app-feature.feature03 .app-feature-item-col {
  max-width: 463px;
}

@media (min-width: 768px) {
  .app-feature.feature04 .app-feature-contents-ttl {
    top: -65px;
    left: auto;
    right: 15px;
  }
}

@media (min-width: 800px) {
  .app-feature.feature04 .app-feature-contents-ttl {
    top: 50px;
    right: 10px;
  }
}

@media (min-width: 1044px) {
  .app-feature.feature04 .app-feature-contents-ttl {
    top: 63px;
    right: 38px;
  }
}

@media (min-width: 768px) {
  .app-feature.feature04 .app-feature-img {
    margin-left: -30px;
    width: calc(100% + 30px);
    max-width: 399px;
  }
}

@media (min-width: 1044px) {
  .app-feature.feature04 .app-feature-img {
    margin-left: -59px;
    width: calc(100% + 59px);
    max-width: 499px;
  }
}

.app-feature.feature04 .app-feature-item-col {
  max-width: 486px;
}

.app-feature-wrap {
  overflow: hidden;
}

.app-feature-inner {
  margin: 0 auto;
  padding: 60px 15px;
}

@media (min-width: 768px) {
  .app-feature-inner {
    max-width: 1044px;
    padding: 0 10px;
  }
}

.app-feature:nth-child(odd) {
  background-color: #EFEFEF;
}

.app-feature:nth-child(even) {
  background-color: #fff;
}

@media (min-width: 768px) {
  .app-feature-contents {
    padding: 38px 0;
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .app-feature-contents-reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
}

.app-feature-contents-img {
  position: relative;
}

@media (min-width: 768px) {
  .app-feature-contents-img {
    margin-top: auto;
    margin-bottom: -38px;
  }
}

.app-feature-contents-ttl {
  position: absolute;
  bottom: 0;
  left: 0;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  font-size: 40px;
  font-weight: bold;
  letter-spacing: 0.04em;
  line-height: 1.15;
}

@media (min-width: 768px) {
  .app-feature-contents-ttl {
    bottom: auto;
  }
}

@media (max-width: 374px) {
  .app-feature-contents-ttl {
    font-size: 35px;
  }
}

.app-feature-contents-detail {
  margin-top: 10px;
}

@media (min-width: 768px) {
  .app-feature-contents-detail {
    margin-top: 0;
    min-height: 390px;
    max-width: 500px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.app-feature-heading {
  text-align: center;
}

@media (min-width: 768px) {
  .app-feature-heading {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    text-align: left;
  }
}

.app-feature-num {
  padding: 0 18px;
  width: 72px;
  text-align: center;
  font-family: "Barlow";
  color: #8D6B0D;
  font-size: 52px;
  letter-spacing: 0.04em;
  line-height: 1.192;
  position: relative;
}

.app-feature-num::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 100%;
  height: 77%;
  border-left: 1px solid #B2B2B2;
  border-right: 1px solid #B2B2B2;
}

.app-feature-num-wrap {
  display: inline-block;
  text-align: center;
}

@media (min-width: 768px) {
  .app-feature-num-wrap {
    margin-right: 28px;
  }
}

.app-feature-num-txt {
  color: #4C4948;
  font-size: 14px;
  letter-spacing: 0.04em;
  line-height: 1.429;
}

.app-feature-ttl {
  margin-top: 10px;
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.04em;
  line-height: 1.667;
}

@media (min-width: 768px) {
  .app-feature-ttl {
    margin-top: 0;
  }
}

.app-feature-img {
  margin: 0 auto 0;
  padding-bottom: 5px;
  width: calc(100% + 4px);
}

@media (min-width: 768px) {
  .app-feature-img {
    margin-right: auto;
    margin: 0;
    padding: 0;
    width: 100%;
  }
}

.app-feature-txt {
  letter-spacing: 0.02em;
  line-height: 1.857;
}

@media (min-width: 768px) {
  .app-feature-txt {
    margin-top: 37px;
    max-width: 500px;
  }
}

.app-feature-item + .app-feature-item {
  margin-top: 26px;
}

@media (min-width: 768px) {
  .app-feature-item + .app-feature-item {
    margin-top: 22px;
  }
}

.app-feature-item-col {
  margin-top: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.app-feature-item-col2-img {
  width: calc((100% - 9px)/2);
}

@media (min-width: 768px) {
  .app-feature-item-col2-img {
    width: calc(50% - 13px);
  }
}

.app-feature-item-col2-img + .app-feature-item-col2-img {
  margin-left: 9px;
}

@media (min-width: 768px) {
  .app-feature-item-col2-img + .app-feature-item-col2-img {
    margin-left: 26px;
  }
}

.app-feature-item-col3-img {
  width: calc((100% - 20px)/3);
}

@media (min-width: 768px) {
  .app-feature-item-col3-img {
    width: calc((100% - 48px)/3);
  }
}

.app-feature-item-col3-img:not(:nth-child(3n+1)) {
  margin-left: 10px;
}

@media (min-width: 768px) {
  .app-feature-item-col3-img:not(:nth-child(3n+1)) {
    margin-left: 24px;
  }
}

.app-feature-item-row2-img {
  width: calc((100% - 20px)/3);
}

.app-feature-item-row2-img:not(:nth-child(3n+1)) {
  margin-left: 10px;
}

.app-feature-item-row2-img:not(:nth-child(-n+3)) {
  margin-top: 12px;
}

.app-feature-status {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  max-width: 500px;
}

.app-feature-status-color {
  margin-top: 14px;
  width: 59px;
  height: 59px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  font-size: 13px;
  letter-spacing: 0.04em;
  font-weight: bold;
}

@media (max-width: 374px) {
  .app-feature-status-color {
    width: 50px;
    height: 50px;
    font-size: 12px;
  }
}

@media (min-width: 768px) {
  .app-feature-status-color {
    margin-top: 12px;
    width: 76px;
    height: 76px;
    font-size: 14px;
  }
}

.app-feature-status-color.silver {
  color: #fff;
  background-color: #A0A5AA;
}

.app-feature-status-color.black {
  color: #fff;
  background-color: #000;
}

.app-feature-status-color.red {
  color: #fff;
  background-color: #C11B32;
}

.app-feature-status-color.white {
  background-color: #fff;
  border: 1px solid #B2B2B2;
}

.app-feature-status-color.green {
  color: #fff;
  background-color: #5AB245;
}

.app-feature-status-point {
  margin-top: 40px;
}

@media (min-width: 768px) {
  .app-feature-status-point {
    margin-top: 24px;
  }
}

@media (min-width: 768px) {
  .app-feature-point {
    max-width: 500px;
  }
}

.app-feature-point-head {
  margin-top: 9px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

@media (min-width: 768px) {
  .app-feature-point-head {
    margin-top: 4px;
  }
}

.app-feature-point-txt {
  font-size: 12px;
  font-weight: bold;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .app-feature-point-cumulative {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

.app-feature-point-cumulative-num {
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  font-size: 22px;
  font-weight: 500;
  letter-spacing: 0.04em;
}

@media (min-width: 768px) {
  .app-feature-point-cumulative-num {
    margin-left: 12px;
  }
}

.app-feature-point-status {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.app-feature-point-status-num {
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  margin-left: 4px;
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.04em;
}

@media (min-width: 768px) {
  .app-feature-point-status-num {
    margin-left: 10px;
  }
}

.app-feature-point-img {
  margin-top: 6px;
  width: 100%;
}

@media (min-width: 768px) {
  .app-feature-point-img {
    margin-top: 4px;
  }
}

.app-download {
  padding: 25px 10px 29px;
  margin: 0 auto;
  max-width: 720px;
  background-color: #000;
  text-align: center;
  color: #fff;
}

@media (min-width: 768px) {
  .app-download {
    padding: 26px 10px 21px;
  }
}

.app-download-wrap {
  padding: 35px 0;
  background-color: #333;
  margin-bottom: 72px;
}

@media (min-width: 768px) {
  .app-download-wrap {
    padding: 46px 10px 44px;
    margin-bottom: 100px;
  }
}

.app-download-txt {
  margin-bottom: 10px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.625;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .app-download-txt {
    margin-bottom: 13px;
  }
}

.article-item.def-item-wrap {
  padding: 42px 0;
  position: relative;
  width: 100vw;
  margin: 0 -15px;
}

@media (min-width: 768px) {
  .article-item.def-item-wrap {
    width: 100%;
    padding: 42px 0;
    margin: 0;
  }
}

.article-item-swiper {
  overflow: hidden;
  width: 100%;
}

.article-item-swiper .def-item {
  width: 320px;
  height: auto;
}

.article-item-swiper .def-item + .def-item {
  margin-top: 0;
}

@media (min-width: 768px) {
  .article-item-swiper .def-item + .def-item {
    margin-left: 32px;
  }
}

@media (min-width: 768px) {
  .article-item-swiper .def-item {
    width: calc((100% - 64px)/3);
    max-width: 320px;
  }
  .article-item-swiper .def-item:nth-child(-n+3) {
    margin-top: 0;
  }
}

.article-item-border {
  border-top: 1px solid #B2B2B2;
  border-bottom: 1px solid #B2B2B2;
}

.article-item-border-top {
  border-top: 1px solid #B2B2B2;
}

.article-item-border-bottom {
  border-bottom: 1px solid #B2B2B2;
}

.article-item-link {
  margin-top: 32px;
}

@media (min-width: 768px) {
  .article-item-link {
    margin-top: 50px;
  }
}

.article-item .swiper-wrapper-center {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media (min-width: 768px) {
  .article-item .swiper-wrapper-center {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
}

.article-item-breakpoint2 .def-item {
  max-width: 320px;
  width: calc(100% - 25px);
}

@media (min-width: 768px) {
  .article-item-breakpoint2 .def-item {
    width: calc((100% - 64px) / 3);
  }
  .article-item-breakpoint2 .def-item + .def-item {
    margin-left: 32px;
  }
}

@media (min-width: 768px) {
  .article-item-breakpoint3 .def-item {
    width: calc((100% - 32px) / 2);
  }
  .article-item-breakpoint3 .def-item + .def-item {
    margin-top: 30px;
  }
  .article-item-breakpoint3 .def-item:not(:nth-child(3n+1)) {
    margin-left: 0;
  }
  .article-item-breakpoint3 .def-item:not(:nth-child(2n+1)) {
    margin-left: 32px;
  }
  .article-item-breakpoint3 .def-item:nth-child(-n+2) {
    margin-top: 0;
  }
}

@media (min-width: 968px) {
  .article-item-breakpoint3 .def-item {
    max-width: 320px;
    width: calc((100% - 64px) / 3);
  }
  .article-item-breakpoint3 .def-item:not(:nth-child(2n+1)) {
    margin-left: 0;
  }
  .article-item-breakpoint3 .def-item:not(:nth-child(3n+1)) {
    margin-left: 32px;
  }
  .article-item-breakpoint3 .def-item:nth-child(-n+3) {
    margin-top: 0;
  }
}

@media (min-width: 968px) {
  .article-item-breakpoint3:not(.article-item) .def-item:not(.def-item-border) {
    max-width: none;
    margin-left: 47px;
    width: calc((100% - 47px)/2);
  }
  .article-item-breakpoint3:not(.article-item) .def-item:not(.def-item-border):nth-child(2n+1) {
    margin-left: 0;
  }
  .article-item-breakpoint3:not(.article-item) .def-item:not(.def-item-border):nth-child(-n+3) {
    margin-top: 30px;
  }
}

@media (min-width: 1044px) {
  .article-item-breakpoint3:not(.article-item) .def-item:not(.def-item-border) {
    max-width: 310px;
  }
  .article-item-breakpoint3:not(.article-item) .def-item:not(.def-item-border):nth-child(2n+1) {
    margin-left: 47px;
  }
  .article-item-breakpoint3:not(.article-item) .def-item:not(.def-item-border):nth-child(-n+3) {
    margin-top: 0;
  }
  .article-item-breakpoint3:not(.article-item) .def-item:not(.def-item-border):nth-child(3n+1) {
    margin-left: 0;
  }
}

.blog .index-heading-wrap {
  padding: 15px 15px 30px;
}

@media (min-width: 768px) {
  .blog .index-heading-wrap {
    padding: 86px 10px 50px;
  }
}

.blog .index-article-list-wrap {
  padding: 60px 0 115px;
}

.bridal-index {
  overflow: hidden;
}

.bridal-index .index-heading-wrap {
  padding-bottom: 33px;
}

@media (min-width: 768px) {
  .bridal-index .index-heading-wrap {
    padding-bottom: 41px;
  }
}

.bridal-index .index-lead-txt {
  margin-top: 19px;
}

@media (min-width: 768px) {
  .bridal-index .index-lead-txt {
    margin-top: 24px;
  }
}

.bridal-index .index-article-list-wrap {
  padding-top: 60px;
  padding-bottom: 109px;
}

@media (min-width: 768px) {
  .bridal-index .index-article-list-wrap {
    padding-top: 75px;
    padding-bottom: 104px;
  }
}

.bridal-index-img-wrap {
  padding: 53px 0 86px;
  position: relative;
}

@media (min-width: 768px) {
  .bridal-index-img-wrap {
    padding: 69px 0 104px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

@media (min-width: 768px) {
  .bridal-index-img-wrap > .bridal-index-img {
    width: calc((100% - 10px)/3);
  }
}

.bridal-index-img-wrap::after {
  content: "";
  background-image: url("../images/bridal/bridal_index_04.png");
  background-size: cover;
  width: 136px;
  height: 86px;
  position: absolute;
  bottom: 16px;
  right: -19px;
}

@media (min-width: 768px) {
  .bridal-index-img-wrap::after {
    width: 225px;
    height: 145px;
    bottom: 31px;
    right: -50px;
  }
}

@media (min-width: 1248px) {
  .bridal-index-img-wrap::after {
    right: -112px;
  }
}

.bridal-index-img-col2 {
  margin-top: 26px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

@media (min-width: 768px) {
  .bridal-index-img-col2 .bridal-index-img {
    width: calc((100% - 5px)/2);
  }
}

.bridal-index-img-col2 .bridal-index-img + .bridal-index-img {
  margin-left: 11px;
}

@media (min-width: 768px) {
  .bridal-index-img-col2 .bridal-index-img + .bridal-index-img {
    margin-left: 5px;
  }
}

@media (min-width: 768px) {
  .bridal-index-img-col2 {
    margin-top: 0;
    margin-left: 5px;
    width: calc(((100% - 10px)/3*2) + 5px);
  }
}

.bridal-index-lead-ttl {
  font-size: 24px;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  text-align: center;
}

@media (min-width: 768px) {
  .bridal-index-lead-ttl {
    font-size: 28px;
  }
}

.bridal-index-lead-txt {
  margin: 18px 0 46px;
}

@media (min-width: 768px) {
  .bridal-index-lead-txt {
    margin: 28px 0 49px;
  }
}

.bridal-service {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

@media (min-width: 768px) {
  .bridal-service {
    margin: 0 auto -24px;
    max-width: 1025px;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

.bridal-service-wrap {
  background-color: #DEF2FD;
  padding: 54px 15px 50px;
  text-align: center;
}

@media (min-width: 768px) {
  .bridal-service-wrap {
    padding: 74px 10px 70px;
  }
}

.bridal-service-wrap .heading-4 {
  color: #fff;
  line-height: 1.875;
}

@media (min-width: 768px) {
  .bridal-service-wrap .heading-4 {
    line-height: 1.5;
  }
}

.bridal-service-item {
  margin-top: 24px;
  background-color: #DEF2FD;
  border: 1px solid #9F8E64;
  padding: 22px 10px;
  text-align: center;
  width: calc((100% - 25px) / 2);
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 768px) {
  .bridal-service-item:hover {
    background-color: #9F8E64;
  }
  .bridal-service-item:hover .bridal-service-icon svg {
    color: #fff;
  }
  .bridal-service-item:hover .bridal-service-ttl {
    color: #fff;
  }
  .bridal-service-item:hover .bridal-service-num {
    color: #fff;
  }
  .bridal-service-item:hover:after {
    border-bottom: 1px solid #fff;
    border-right: 1px solid #fff;
  }
}

.bridal-service-item:nth-child(even) {
  margin-left: 25px;
}

@media (min-width: 768px) {
  .bridal-service-item:nth-child(even) {
    margin-left: 0;
  }
}

.bridal-service-item:nth-child(-n+2) {
  margin-top: 0;
}

@media (max-width: 374px) {
  .bridal-service-item {
    width: calc((100% - 25px)/2);
    height: auto;
  }
}

@media (min-width: 768px) {
  .bridal-service-item {
    margin-top: 0;
    margin-bottom: 24px;
    padding: 18px 10px;
    width: 156px;
    height: 156px;
  }
}

.bridal-service-icon {
  margin: 0 auto;
}

.bridal-service-icon svg {
  width: 45px;
  color: #9F8E64;
  -webkit-transition: .3s;
  transition: .3s;
}

.bridal-service-ttl {
  margin-top: 5px;
  margin-bottom: 18px;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  color: #9F8E64;
  font-size: 18px;
  line-height: 1.16;
  letter-spacing: 0.04em;
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 768px) {
  .bridal-service-ttl {
    margin-bottom: 0;
    line-height: 1.27;
  }
}

.bridal-service-num {
  font-family: "Barlow";
  color: #8D6B0D;
  font-size: 32px;
  line-height: 0.98;
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 768px) {
  .bridal-service-num {
    font-size: 42px;
  }
}

.bridal-service-num-txt {
  font-size: 12px;
  letter-spacing: 0.02em;
  color: #D9D9D9;
}

@media (min-width: 768px) {
  .bridal-service-num-txt {
    font-size: 14px;
  }
}

.bridal-heading-wrap {
  margin-top: 28px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media (min-width: 768px) {
  .bridal-heading-wrap {
    margin-top: 45px;
  }
}

.bridal-heading-num {
  font-family: "Barlow";
  color: #8D6B0D;
  font-size: 32px;
  line-height: 0.85;
}

@media (min-width: 768px) {
  .bridal-heading-num {
    font-size: 40px;
  }
}

.bridal-heading-num-txt {
  font-size: 11px;
  line-height: 1.46;
  color: #D9D9D9;
}

@media (min-width: 768px) {
  .bridal-heading-num-txt {
    font-size: 13px;
  }
}

.bridal-heading-num-wrap {
  margin-right: 12px;
  padding: 4px;
  background-color: #DEF2FD;
  width: 56px;
  height: 56px;
  text-align: center;
  border: 1px solid #9F8E64;
}

@media (min-width: 768px) {
  .bridal-heading-num-wrap {
    padding: 6px;
    margin-right: 34px;
    width: 68px;
    height: 68px;
  }
}

.bridal-heading-num-wrap svg {
  color: #9F8E64;
  height: 100%;
}

.bridal-heading-ttl.heading-1 {
  font-size: 26px;
}

@media (min-width: 768px) {
  .bridal-heading-ttl.heading-1 {
    font-size: 30px;
  }
}

.bridal-heading-ttl.heading-1 span {
  line-height: 1.3;
  text-align: left;
}

.bridal-heading-ttl.heading-1 .heading-1-sub {
  margin-top: 2px;
  font-size: 16px;
  text-align: left;
}

@media (min-width: 768px) {
  .bridal-heading-ttl.heading-1 .heading-1-sub {
    margin-top: 5px;
    font-size: 18px;
  }
}

.bridal-detail-inner.index-inner {
  padding: 20px 15px 81px;
}

@media (min-width: 768px) {
  .bridal-detail-inner.index-inner {
    padding: 26px 10px 119px;
  }
}

.bridal-detail-main-img {
  margin: 28px -15px 40px;
}

@media (min-width: 768px) {
  .bridal-detail-main-img {
    margin: 28px 0 30px;
  }
}

.bridal-detail-ttl {
  margin-bottom: 20px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.44;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .bridal-detail-ttl {
    margin-bottom: 24px;
    font-size: 18px;
  }
}

.bridal-detail-subttl {
  margin: 7px 0 25px;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.714;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .bridal-detail-subttl {
    margin: 4px 0 22px;
    font-size: 16px;
  }
}

.bridal-detail-txt {
  margin-top: 20px;
  line-height: 1.714;
}

@media (min-width: 768px) {
  .bridal-detail-txt {
    margin-top: 25px;
  }
}

.bridal-detail-txt + .txt-note {
  margin-top: 12px;
}

@media (min-width: 768px) {
  .bridal-detail-txt + .txt-note {
    margin-top: 10px;
  }
}

.bridal-detail-contents {
  margin: 61px auto 0;
}

@media (min-width: 768px) {
  .bridal-detail-contents {
    margin: 94px auto 0;
  }
}

.bridal-detail-tab {
  display: block;
}

.bridal-detail-tab a,
.bridal-detail-tab .tab-btn {
  width: 100%;
  height: 48px;
  padding: 5px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border: 1px solid #B2B2B2;
  background-color: #fff;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  color: #333;
  font-size: 16px;
  font-weight: bold;
  text-align: center;
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 768px) {
  .bridal-detail-tab a,
  .bridal-detail-tab .tab-btn {
    cursor: pointer;
  }
}

@media (min-width: 768px) {
  .bridal-detail-tab a:hover,
  .bridal-detail-tab .tab-btn:hover {
    background-color: #333;
    color: #fff;
  }
}

.bridal-detail-tab.is-active-tab a,
.bridal-detail-tab.is-active-tab .tab-btn {
  background-color: #333;
  color: #fff;
}

.bridal-detail-tab-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media (min-width: 768px) {
  .bridal-detail-tab-wrap {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

.bridal-detail-tab-wrap.tab-scroll {
  padding: 26px 15px;
  margin: 0 -15px;
  background-color: #808080;
  overflow-x: scroll;
}

@media (min-width: 768px) {
  .bridal-detail-tab-wrap.tab-scroll {
    padding: 0;
    margin: 0 auto;
    background-color: transparent;
    overflow: visible;
  }
}

.bridal-detail-tab-wrap.bridal-tab-col2 .bridal-detail-tab {
  width: calc((100% - 13px) / 2);
}

@media (min-width: 768px) {
  .bridal-detail-tab-wrap.bridal-tab-col2 .bridal-detail-tab {
    width: 240px;
  }
}

.bridal-detail-tab-wrap.bridal-tab-col2 .bridal-detail-tab + .bridal-detail-tab {
  margin-left: 25px;
}

@media (min-width: 768px) {
  .bridal-detail-tab-wrap.bridal-tab-col2 .bridal-detail-tab + .bridal-detail-tab {
    margin-left: 40px;
  }
}

@media (min-width: 768px) {
  .bridal-detail-tab-wrap.bridal-tab-col4 .bridal-detail-tab {
    width: calc((100% - 63px) / 4);
  }
}

.bridal-detail-tab-wrap.bridal-tab-col4 .bridal-detail-tab a, .bridal-detail-tab-wrap.bridal-tab-col4 .bridal-detail-tab .tab-btn {
  width: 220px;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  letter-spacing: 0.1em;
}

@media (min-width: 768px) {
  .bridal-detail-tab-wrap.bridal-tab-col4 .bridal-detail-tab a, .bridal-detail-tab-wrap.bridal-tab-col4 .bridal-detail-tab .tab-btn {
    width: 100%;
  }
}

.bridal-detail-tab-wrap.bridal-tab-col4 .bridal-detail-tab + .bridal-detail-tab {
  margin-left: 12px;
}

@media (min-width: 768px) {
  .bridal-detail-tab-wrap.bridal-tab-col4 .bridal-detail-tab + .bridal-detail-tab {
    margin-left: 21px;
  }
}

@media (min-width: 768px) {
  .bridal-detail-tab-wrap.bridal-tab-col6 .bridal-detail-tab {
    width: calc((100% - 72px) / 7);
  }
}

.bridal-detail-tab-wrap.bridal-tab-col6 .bridal-detail-tab a, .bridal-detail-tab-wrap.bridal-tab-col6 .bridal-detail-tab .tab-btn {
  width: 136px;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  letter-spacing: 0.1em;
}

@media (min-width: 768px) {
  .bridal-detail-tab-wrap.bridal-tab-col6 .bridal-detail-tab a, .bridal-detail-tab-wrap.bridal-tab-col6 .bridal-detail-tab .tab-btn {
    width: 100%;
  }
}

@media (min-width: 768px) and (max-width: 950px) {
  .bridal-detail-tab-wrap.bridal-tab-col6 .bridal-detail-tab a, .bridal-detail-tab-wrap.bridal-tab-col6 .bridal-detail-tab .tab-btn {
    font-size: 13px;
  }
}

.bridal-detail-tab-wrap.bridal-tab-col6 .bridal-detail-tab + .bridal-detail-tab {
  margin-left: 12px;
}

.bridal-detail-scroll {
  border-bottom: 1px solid #B2B2B2;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: relative;
  width: 50%;
  min-height: 52px;
  padding: 5px 16px;
  background-color: #fff;
  color: #333;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-weight: bold;
  line-height: 1.14;
  letter-spacing: 0.02em;
  text-align: center;
  word-break: break-word;
}

.bridal-detail-scroll [class*="icon-"] {
  font-size: 19px;
  position: absolute;
  top: 50%;
  right: 8px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.bridal-detail-scroll:nth-child(odd) {
  border-right: 1px solid #B2B2B2;
}

.bridal-detail-scroll-wrap {
  margin-top: 44px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  border-top: 1px solid #B2B2B2;
  position: relative;
}

.bridal-detail-scroll-wrap:after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  height: 1px;
  width: 100%;
  background-color: #B2B2B2;
}

@media (min-width: 768px) {
  .bridal-detail-scroll-wrap {
    display: none;
  }
}

.bridal-detail-contact {
  margin-top: 13px;
  text-align: center;
  padding: 23px 25px;
  background-color: #F2F2F2;
}

@media (min-width: 768px) {
  .bridal-detail-contact {
    margin-top: 17px;
    padding: 35px 20px 37px;
  }
}

.bridal-detail-contact-wrap {
  margin: 93px auto 54px;
  width: 100%;
}

@media (min-width: 768px) {
  .bridal-detail-contact-wrap {
    margin: 107px auto 70px;
    max-width: 1024px;
  }
}

.bridal-detail-contact-txt {
  font-size: 15px;
  font-weight: bold;
  line-height: 1.6;
  letter-spacing: 0.01em;
}

@media (min-width: 768px) {
  .bridal-detail-contact-txt {
    font-size: 16px;
    letter-spacing: 0.02em;
  }
}

.bridal-detail-contact-name {
  font-size: 18px;
  font-weight: bold;
  line-height: 1.44;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .bridal-detail-contact-name {
    font-size: 20px;
  }
}

.bridal-detail-contact-tel {
  margin-top: 9px;
  font-size: 22px;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.04em;
}

@media (min-width: 768px) {
  .bridal-detail-contact-tel {
    font-size: 24px;
  }
}

.bridal-detail-contact-time {
  margin: 8px 0 5px;
  font-size: 14px;
  font-weight: bold;
  line-height: 1.714;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .bridal-detail-contact-time {
    font-size: 16px;
    margin: 10px 0 6px;
  }
}

.bridal-detail-contact .txt-note {
  letter-spacing: 0.02em;
}

.bridal-detail-service {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  margin: 0 auto;
  max-width: 345px;
}

@media (min-width: 768px) {
  .bridal-detail-service {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin: 24px auto 0;
    max-width: 600px;
  }
}

@media (min-width: 1045px) {
  .bridal-detail-service {
    max-width: 1025px;
  }
}

.bridal-detail-service-bg {
  padding-bottom: 70px;
}

@media (min-width: 768px) {
  .bridal-detail-service-bg {
    padding-bottom: 100px;
  }
}

.bridal-detail-service-wrap {
  padding: 41px 15px 61px;
  text-align: center;
}

@media (min-width: 768px) {
  .bridal-detail-service-wrap {
    padding: 29px 10px 42px;
  }
}

.bridal-detail-service-wrap .heading-4 {
  color: #fff;
  line-height: 1.875;
}

@media (min-width: 768px) {
  .bridal-detail-service-wrap .heading-4 {
    line-height: 1.5;
  }
}

.bridal-detail-service-heading {
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  color: #9F8E64;
  font-size: 24px;
  line-height: 1.367;
  margin-bottom: 27px;
  letter-spacing: 0.04em;
}

@media (min-width: 768px) {
  .bridal-detail-service-heading {
    margin-bottom: 14px;
  }
}

.bridal-detail-service-item {
  margin-top: 24px;
  background-color: #DEF2FD;
  border: 1px solid #9F8E64;
  padding: 20px 10px;
  text-align: center;
  width: 160px;
  height: 160px;
  -webkit-transition: .3s;
  transition: .3s;
  position: relative;
}

.bridal-detail-service-item:after {
  content: "";
  width: 65px;
  height: 10px;
  border-bottom: 1px solid #9F8E64;
  border-right: 1px solid #9F8E64;
  position: absolute;
  bottom: 22px;
  left: 50%;
  -webkit-transform: translateX(-50%) skew(30deg);
          transform: translateX(-50%) skew(30deg);
}

@media (min-width: 1044px) {
  .bridal-detail-service-item:after {
    width: 98px;
    right: 0;
  }
}

.bridal-detail-service-item:nth-child(even) {
  margin-left: 25px;
}

@media (min-width: 768px) {
  .bridal-detail-service-item:nth-child(even) {
    margin-left: 0;
  }
}

.bridal-detail-service-item:nth-child(-n+2) {
  margin-top: 0;
}

@media (max-width: 374px) {
  .bridal-detail-service-item {
    width: calc((100% - 25px)/2);
  }
}

@media (min-width: 768px) {
  .bridal-detail-service-item {
    margin: 0;
    width: 156px;
    height: 156px;
  }
  .bridal-detail-service-item + .bridal-detail-service-item {
    margin-left: 61px;
  }
  .bridal-detail-service-item:not(:nth-child(-n+3)) {
    margin-top: 20px;
  }
}

@media (min-width: 768px) and (min-width: 1045px) {
  .bridal-detail-service-item:not(:nth-child(-n+3)) {
    margin-top: 0;
  }
}

@media (min-width: 768px) and (max-width: 1045px) {
  .bridal-detail-service-item:nth-child(3n+1) {
    margin-left: 0;
  }
}

.bridal-detail-service-item.is-active-bridal-service {
  background-color: #9F8E64;
}

.bridal-detail-service-item.is-active-bridal-service .bridal-detail-service-icon svg {
  color: #fff;
}

.bridal-detail-service-item.is-active-bridal-service .bridal-detail-service-ttl {
  color: #fff;
}

.bridal-detail-service-item.is-active-bridal-service .bridal-detail-service-num {
  color: #fff;
}

.bridal-detail-service-item.is-active-bridal-service:after {
  border-bottom: 1px solid #fff;
  border-right: 1px solid #fff;
}

@media (min-width: 768px) {
  .bridal-detail-service-item:hover {
    background-color: #9F8E64;
  }
  .bridal-detail-service-item:hover .bridal-detail-service-icon svg {
    color: #fff;
  }
  .bridal-detail-service-item:hover .bridal-detail-service-ttl {
    color: #fff;
  }
  .bridal-detail-service-item:hover .bridal-detail-service-num {
    color: #fff;
  }
  .bridal-detail-service-item:hover:after {
    border-bottom: 1px solid #fff;
    border-right: 1px solid #fff;
  }
}

.bridal-detail-service-icon svg {
  -webkit-transition: .3s;
  transition: .3s;
  color: #9F8E64;
}

.bridal-detail-service-ttl {
  margin-top: 4px;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  color: #9F8E64;
  font-size: 18px;
  line-height: 1.16;
  -webkit-transition: .3s;
  transition: .3s;
  letter-spacing: 0.04em;
}

@media (min-width: 768px) {
  .bridal-detail-service-ttl {
    margin-top: 5px;
    line-height: 1.27;
  }
}

.bridal-detail-service-num {
  font-family: "Barlow";
  color: #8D6B0D;
  font-size: 32px;
  line-height: 0.98;
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 768px) {
  .bridal-detail-service-num {
    font-size: 28px;
  }
}

.bridal-detail-service-num-wrap {
  padding-bottom: 5px;
  position: relative;
}

.bridal-detail-service-num-wrap:after {
  content: "";
  width: 65px;
  height: 10px;
  border-bottom: 1px solid #fff;
  border-right: 1px solid #fff;
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%) skew(30deg);
          transform: translateX(-50%) skew(30deg);
}

@media (min-width: 768px) {
  .bridal-detail-service-num-wrap:after {
    width: 70px;
    height: 9px;
    right: 0;
  }
}

@media (min-width: 768px) {
  .bridal-detail-service-num-wrap {
    padding-bottom: 9px;
  }
}

.bridal-detail-service-num-txt {
  font-size: 12px;
  letter-spacing: 0.02em;
  color: #D9D9D9;
}

@media (min-width: 768px) {
  .bridal-detail-service-num-txt {
    font-size: 12px;
  }
}

.bridal-detail-brand-name {
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.02em;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
}

.bridal-detail-item + .bridal-detail-item {
  margin-top: 60px;
}

@media (min-width: 768px) {
  .bridal-detail-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}

.bridal-detail-item-wrap {
  margin-top: 60px;
}

@media (min-width: 768px) {
  .bridal-detail-item-wrap {
    margin-top: 96px;
  }
}

.bridal-detail-item-img {
  position: relative;
  border: 1px solid #B2B2B2;
}

@media (min-width: 768px) {
  .bridal-detail-item-img {
    width: 300px;
  }
}

.bridal-detail-item-txt {
  font-size: 13px;
  line-height: 1.692;
  letter-spacing: 0.02em;
}

.bridal-detail-item-txt-wrap {
  margin-top: 10px;
}

@media (min-width: 768px) {
  .bridal-detail-item-txt-wrap {
    width: calc(100% - 340px);
    margin-top: 0;
    margin-left: 60px;
  }
}

.bridal-detail-item-top + .bridal-detail-item-bottom {
  margin-top: 6px;
}

.bridal-detail-item-name {
  font-size: 14px;
  line-height: 1.57143;
  font-weight: bold;
  letter-spacing: 0.02em;
}

.bridal-detail-item-supplement {
  font-size: 14px;
  font-weight: bold;
  line-height: 1.52;
  letter-spacing: 0.02em;
}

.bridal-detail-item-link {
  width: calc(50% - 12px);
}

@media (min-width: 768px) {
  .bridal-detail-item-link {
    width: 160px;
    margin-right: 24px;
  }
}

.bridal-detail-item-link + .bridal-detail-item-link {
  margin-left: 24px;
}

@media (min-width: 768px) {
  .bridal-detail-item-link + .bridal-detail-item-link {
    margin-left: 0;
  }
}

.bridal-detail-item-link:nth-of-type(odd) {
  margin-left: 0;
}

.bridal-detail-item-link-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

@media (min-width: 768px) {
  .bridal-detail-item-link-wrap {
    margin-right: -24px;
  }
}

.bridal-detail-item-link-ttl {
  margin-top: 17px;
  font-size: 12px;
  margin-bottom: 5px;
}

.bridal-detail-item-link-ttl + .bridal-detail-item-link-btn {
  margin-top: 0;
}

.bridal-detail-item-link-btn {
  margin-top: 22px;
}

@media (min-width: 768px) {
  .bridal-detail-item-link-btn {
    margin-top: 28px;
  }
}

.bridal-detail-store {
  margin-top: 69px;
  margin-bottom: 6px;
}

@media (min-width: 768px) {
  .bridal-detail-store {
    margin-top: 84px;
    margin-bottom: 0;
  }
}

.bridal-detail-store-txt {
  line-height: 1.714;
}

.bridal-detail-store-ttl {
  margin-top: 20px;
  font-size: 15px;
  font-weight: bold;
}

@media (min-width: 768px) {
  .bridal-detail-store-ttl {
    font-size: 16px;
  }
}

.bridal-detail-store-link {
  margin-top: 9px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

@media (min-width: 768px) {
  .bridal-detail-store-link {
    margin-top: 8px;
  }
}

.bridal-detail-store-link-col2 {
  max-width: 250px;
}

@media (min-width: 768px) {
  .bridal-detail-store-link-col2 {
    max-width: 100%;
  }
}

.bridal-detail-store-link-col2 .link-more {
  width: 100px;
}

.bridal-detail-store-link-col2 .link-more + .link-more {
  margin-top: 0;
}

.bridal-detail-store-link-col2 .link-more:nth-child(even) {
  margin-left: 27px;
}

.bridal-detail-store-link-col2 .link-more:not(:nth-child(-n+2)) {
  margin-top: 9px;
}

@media (min-width: 768px) {
  .bridal-detail-store-link-col2 .link-more:not(:nth-child(-n+2)) {
    margin-top: 0;
  }
}

.bridal-detail-store-link .link-more [class*="icon-"] {
  margin-left: 6px;
}

@media (min-width: 768px) {
  .bridal-detail-store-link .link-more + .link-more {
    margin-left: 27px;
  }
}

.bridal-detail-new {
  margin-left: 4px;
  padding: 0 11px;
  background-color: #000;
  font-size: 11px;
  font-weight: bold;
  letter-spacing: 0.07em;
  line-height: 1.455;
  color: #fff;
  width: 48px;
}

.bridal-jewelry-ttl.heading-4.heading-4-square {
  margin-bottom: 14px;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
}

.bridal-jewelry-lead {
  font-size: 14px;
  line-height: 1.85714;
}

.bridal-jewelry-item + .bridal-jewelry-item {
  margin-top: 108px;
}

@media (min-width: 768px) {
  .bridal-jewelry-item + .bridal-jewelry-item {
    margin-top: 84px;
  }
}

.bridal-jewelry-item-wrap {
  margin-top: 64px;
}

@media (min-width: 768px) {
  .bridal-jewelry-item-wrap {
    margin-top: 92px;
  }
}

.bridal-jewelry-kinds {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.bridal-jewelry-kinds.bridal-item-name-label {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  margin-top: 4px;
}

.bridal-jewelry-ring {
  width: calc((100% - 21px)/2);
  margin-top: 20px;
}

.bridal-jewelry-ring:nth-child(even) {
  margin-left: 21px;
}

@media (min-width: 768px) {
  .bridal-jewelry-ring:nth-child(even) {
    margin-left: 0;
  }
}

.bridal-jewelry-ring:nth-child(-n+2) {
  margin-top: 0;
}

@media (min-width: 768px) {
  .bridal-jewelry-ring {
    width: calc((100% - 180px)/4);
    margin-top: 18px;
  }
  .bridal-jewelry-ring:not(:nth-child(4n+1)) {
    margin-left: 60px;
  }
  .bridal-jewelry-ring:nth-child(-n+4) {
    margin-top: 0;
  }
}

.bridal-jewelry-ring a {
  color: #333;
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 768px) {
  .bridal-jewelry-ring a:hover {
    opacity: 0.7;
  }
}

.bridal-jewelry-ring-wrap {
  margin-top: 18px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

@media (min-width: 768px) {
  .bridal-jewelry-ring-wrap {
    margin-top: 24px;
  }
}

.bridal-jewelry-ring-img {
  position: relative;
}

.bridal-jewelry-ring-img .def-item-new {
  width: 36px;
  height: 36px;
  padding: 8px 0 11px;
  font-size: 12px;
}

@media (min-width: 768px) {
  .bridal-jewelry-ring-img .def-item-new {
    width: 48px;
    height: 48px;
    padding: 13px 0 15px;
    font-size: 13px;
  }
}

.bridal-jewelry-ring-name {
  font-size: 12px;
  font-weight: bold;
  line-height: 1.428;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .bridal-jewelry-ring-name {
    font-size: 14px;
  }
}

.bridal-jewelry-ring-name-wrap {
  margin-top: 12px;
}

.bridal-jewelry-ring-circle {
  width: 15px;
  height: 15px;
  margin-right: 4px;
}

@media (min-width: 768px) {
  .bridal-jewelry-ring-circle {
    width: 20px;
    height: 20px;
  }
}

.bridal-jewelry-ring-circle img {
  vertical-align: baseline;
}

.bridal-jewelry-ring-money {
  font-size: 12px;
  font-weight: bold;
  line-height: 1.428;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .bridal-jewelry-ring-money {
    font-size: 14px;
  }
}

.bridal-jewelry-ring-money-wrap {
  margin-top: 1px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media (min-width: 768px) {
  .bridal-jewelry-ring-money-wrap {
    margin-top: 3px;
  }
}

.bridal-jewelry-ring-scroll {
  border-top: 1px solid #B2B2B2;
  padding: 24px 0 9px;
  border-bottom: 1px solid #B2B2B2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

@media (min-width: 768px) {
  .bridal-jewelry-ring-scroll {
    padding: 18px 0 4px;
  }
}

.bridal-jewelry-ring-scroll .link-more {
  display: block;
  margin: 0 30px 15px 0;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
}

.bridal-jewelry-ring-scroll .link-more:before {
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
}

@media (min-width: 768px) {
  .bridal-jewelry-ring-scroll .link-more {
    margin: 0 54px 14px 0;
  }
}

.bridal-jewelry-ring-scroll .link-more + .link-more {
  margin-top: 0;
}

.bridal-jewelry-bnr {
  display: block;
  position: relative;
  width: 100%;
  margin: 60px auto 0;
  padding: 20px 28px 22px 5px;
  border: 1px solid #B2B2B2;
  background-color: #fff;
  background-image: url("../images/bridal/bridal_bnr.jpg");
  background-size: 150px;
  background-position: top 8px left 8px;
  text-align: right;
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 768px) {
  .bridal-jewelry-bnr {
    width: 620px;
    margin: 79px auto 0;
    padding: 32px 18px 29px 5px;
    background-size: 234px;
    background-position: bottom 1px left 43px;
  }
}

@media (max-width: 360px) {
  .bridal-jewelry-bnr {
    padding: 20px 15px 25px 5px;
    background-size: 124px;
    background-position: bottom 14px left 8px;
  }
}

.bridal-jewelry-bnr:after {
  content: "";
  width: 70px;
  height: 12px;
  border-bottom: 1px solid #666464;
  border-right: 1px solid #666464;
  position: absolute;
  bottom: 11px;
  right: 14px;
  -webkit-transform: skew(38deg);
          transform: skew(38deg);
  text-align: center;
}

@media (min-width: 1044px) {
  .bridal-jewelry-bnr:after {
    width: 98px;
    height: 16px;
    bottom: 17px;
    right: 28px;
  }
}

@media (min-width: 768px) {
  .bridal-jewelry-bnr:hover {
    opacity: 0.7;
    cursor: pointer;
  }
}

.bridal-jewelry-bnr-txt {
  display: inline-block;
  font-size: 18px;
  line-height: 1.25;
  letter-spacing: 0.04em;
  font-weight: bold;
  text-align: left;
}

@media (min-width: 768px) {
  .bridal-jewelry-bnr-txt {
    font-size: 24px;
  }
}

@media (max-width: 360px) {
  .bridal-jewelry-bnr-txt {
    font-size: 16px;
  }
}

.bridal-gift {
  margin: 70px auto 81px;
  border-top: 1px solid #B2B2B2;
  padding: 32px 0 33px;
  border-bottom: 1px solid #B2B2B2;
}

@media (min-width: 768px) {
  .bridal-gift {
    margin: 70px auto 81px;
    padding: 32px 0 28px;
  }
}

.bridal-gift-ttl {
  text-align: center;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  font-size: 24px;
  font-weight: bold;
  line-height: 1.25;
  letter-spacing: 0.03em;
}

.bridal-gift-txt {
  margin-top: 19px;
  line-height: 1.714;
}

@media (min-width: 768px) {
  .bridal-gift-txt {
    margin-top: 20px;
    line-height: 1.857;
  }
}

.bridal-gift-list {
  display: block;
}

@media (min-width: 768px) {
  .bridal-gift-list {
    width: calc((100% - 60px) / 3);
    -webkit-transition: .3s;
    transition: .3s;
  }
}

@media (min-width: 768px) {
  .bridal-gift-list:hover {
    opacity: 0.8;
  }
}

.bridal-gift-list + .bridal-gift-list {
  margin-top: 24px;
}

@media (min-width: 768px) {
  .bridal-gift-list + .bridal-gift-list {
    margin-top: 0;
    margin-left: 30px;
  }
}

.bridal-gift-list-wrap {
  margin-top: 50px;
}

@media (min-width: 768px) {
  .bridal-gift-list-wrap {
    margin-top: 20px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.bridal-gift-list-ttl {
  font-weight: bold;
  letter-spacing: 0.02em;
  text-align: center;
}

.bridal-gift-list-img {
  margin-top: 12px;
}

.bridal-gift-list-money {
  margin-top: 11px;
  font-size: 12px;
  font-weight: bold;
  letter-spacing: 0.02em;
  text-align: center;
}

.bridal-gift-list-money + .bridal-gift-list-money {
  margin-top: 0;
}

@media (min-width: 768px) {
  .bridal-gift-list-money a {
    -webkit-transition: .3s;
    transition: .3s;
  }
}

@media (min-width: 768px) {
  .bridal-gift-list-money a:hover {
    opacity: 0.7;
  }
}

.bridal-gift-detail {
  margin-top: 43px;
}

@media (min-width: 768px) {
  .bridal-gift-detail {
    margin-top: 34px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}

.bridal-gift-detail + .bridal-gift-detail {
  margin-top: 38px;
}

@media (min-width: 768px) {
  .bridal-gift-detail + .bridal-gift-detail {
    margin-top: 17px;
  }
}

.bridal-gift-detail-ttl {
  font-size: 12px;
  padding: 9px;
  background-color: #333;
  color: #fff;
  text-align: center;
}

@media (min-width: 768px) {
  .bridal-gift-detail-ttl {
    padding: 10px;
    width: 103px;
  }
}

.bridal-gift-detail-txt {
  margin-top: 11px;
  line-height: 1.714;
  font-size: 12px;
}

@media (min-width: 768px) {
  .bridal-gift-detail-txt {
    width: calc(100% - 121px);
    margin-top: 0;
    margin-left: 18px;
  }
}

.bridal-gift .txt-note {
  margin-top: 26px;
}

@media (min-width: 768px) {
  .bridal-gift .txt-note {
    margin-top: 20px;
  }
}

.bridal-gift .txt-note + .txt-note {
  margin-top: 2px;
}

.bridal-dress-brand {
  margin-top: 42px;
}

@media (min-width: 768px) {
  .bridal-dress-brand {
    margin-top: 57px;
  }
}

.bridal-dress-brand-ttl {
  font-size: 14px;
  font-weight: bold;
  line-height: 1.714;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .bridal-dress-brand-ttl {
    font-size: 16px;
  }
}

.bridal-dress-brand-txt {
  margin-top: 9px;
  font-weight: bold;
  line-height: 1.571;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .bridal-dress-brand-txt {
    margin-top: 13px;
  }
}

.bridal-dress-ttl.heading-4.heading-4-square {
  margin-bottom: 7px;
}

@media (min-width: 768px) {
  .bridal-dress-ttl.heading-4.heading-4-square {
    margin-bottom: 17px;
  }
}

.bridal-dress-item + .bridal-dress-item {
  margin-top: 63px;
}

@media (min-width: 768px) {
  .bridal-dress-item + .bridal-dress-item {
    margin-top: 65px;
  }
}

.bridal-dress-item-wrap {
  margin: 66px 0 63px;
}

@media (min-width: 768px) {
  .bridal-dress-item-wrap {
    margin: 81px 0 112px;
  }
}

.bridal-dress-costume {
  width: 100%;
}

.bridal-dress-costume + .bridal-dress-costume {
  margin-top: 37px;
}

@media (min-width: 768px) {
  .bridal-dress-costume + .bridal-dress-costume {
    margin-top: 22px;
  }
}

@media (min-width: 768px) {
  .bridal-dress-costume {
    width: calc((100% - 44px)/3);
    margin-top: 22px;
  }
  .bridal-dress-costume:not(:nth-child(3n+1)) {
    margin-left: 40px;
  }
  .bridal-dress-costume:nth-child(-n+3) {
    margin-top: 0;
  }
}

@media (min-width: 1044px) {
  .bridal-dress-costume {
    width: calc((100% - 96px)/3);
  }
  .bridal-dress-costume:not(:nth-child(3n+1)) {
    margin-left: 48px;
  }
}

@media (min-width: 768px) {
  .bridal-dress-costume-wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

.bridal-dress-costume-img {
  position: relative;
  padding: 7px 40px;
  max-width: 100%;
  text-align: center;
}

@media (min-width: 768px) {
  .bridal-dress-costume-img {
    padding: 20px 10px;
  }
}

@media (min-width: 768px) {
  .bridal-dress-costume-img img {
    height: 275px;
    width: auto;
  }
}

@media (min-width: 1044px) {
  .bridal-dress-costume-img img {
    height: 345px;
  }
}

.bridal-dress-costume-money {
  font-size: 14px;
  font-weight: bold;
  line-height: 1.428;
  letter-spacing: 0.02em;
  width: calc(100% - 52px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

@media (min-width: 768px) {
  .bridal-dress-costume-money {
    font-size: 16px;
  }
}

.bridal-dress-costume-money-wrap {
  margin-top: 9px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}

.bridal-men-contents .bridal-detail-store {
  margin: 51px 0 0;
}

@media (min-width: 768px) {
  .bridal-men-contents .bridal-detail-store {
    margin: 80px 0 0;
  }
}

.bridal-men-contents .bridal-detail-contact-wrap {
  margin-top: 60px;
}

@media (min-width: 768px) {
  .bridal-men-contents .bridal-detail-contact-wrap {
    margin-top: 100px;
  }
}

.bridal-men-item + .bridal-men-item {
  margin-top: 70px;
}

@media (min-width: 768px) {
  .bridal-men-item + .bridal-men-item {
    margin-top: 0;
  }
}

@media (min-width: 768px) {
  .bridal-men-item {
    width: calc((100% - 124px)/3);
    margin-top: 22px;
    padding-bottom: 13px;
    border-bottom: 1px solid #B2B2B2;
  }
  .bridal-men-item:not(:nth-child(3n+1)) {
    margin-left: 62px;
  }
  .bridal-men-item:nth-child(-n+3) {
    margin-top: 0;
  }
}

@media (min-width: 768px) {
  .bridal-men-item-wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

.bridal-men-item-ttl.heading-4.heading-4-square {
  margin-bottom: 7px;
}

@media (min-width: 768px) {
  .bridal-men-item-ttl.heading-4.heading-4-square {
    margin-bottom: 13px;
  }
}

.bridal-men-item-img {
  border-top: 1px solid #B2B2B2;
  border-bottom: 1px solid #B2B2B2;
  padding: 20px 10px;
  text-align: center;
}

@media (min-width: 768px) {
  .bridal-men-item-img {
    padding: 22px 10px 14px;
  }
}

.bridal-men-item-img img {
  width: 146px;
}

.bridal-men-item-txt {
  font-size: 14px;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.02em;
}

.bridal-men-item-name-wrap {
  margin-top: 16px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.bridal-men-item-money-wrap {
  margin-top: 7px;
}

@media (min-width: 768px) {
  .bridal-men-item-money-wrap {
    margin-top: 13px;
  }
}

.bridal-list-btn.btn-wrap-col {
  margin: 80px auto 0;
}

@media (min-width: 768px) {
  .bridal-list-btn.btn-wrap-col {
    margin: 85px auto 0;
  }
}

.bridal-event-special-page {
  margin-bottom: 30px;
  padding: 0 15px;
}

@media (min-width: 768px) {
  .bridal-event-special-page {
    padding: 0 10px;
    max-width: 1044px;
    margin: 0 auto 60px;
  }
}

.bridal-event-special-link {
  display: block;
  background-color: #DEF2FD;
  border: 1px solid #9F8E64;
  -webkit-transition: .3s;
  transition: .3s;
}

.bridal-event-special-link:hover {
  background-color: #9F8E64;
}

.bridal-event-special-link:hover .bridal-event-special-txt {
  color: #fff;
}

.bridal-event-special-inner {
  padding: 20px 10px;
}

@media (min-width: 768px) {
  .bridal-event-special-inner {
    padding: 38px 10px;
  }
}

.bridal-event-special-txt {
  color: #9F8E64;
  font-weight: 700;
  text-align: center;
  font-size: 16px;
  line-height: 1.25;
  letter-spacing: 0.02em;
  font-size: 12px;
}

@media (min-width: 768px) {
  .bridal-event-special-txt {
    font-size: 14px;
  }
}

.bridal-event-special-txt.medium {
  font-size: 14px;
  margin-top: 12px;
}

@media (min-width: 768px) {
  .bridal-event-special-txt.medium {
    margin-top: 14px;
  }
}

.bridal-event-special-txt.large {
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  font-size: 20px;
  line-height: 1.1;
  letter-spacing: 0.02em;
  margin-top: 12px;
}

@media (min-width: 768px) {
  .bridal-event-special-txt.large {
    font-size: 24px;
    margin-top: 20px;
  }
}

.bridal-detail-ring .modaal-container {
  max-width: 500px;
}

.bridal-detail-ring .modaal-content {
  border: 1px solid #B2B2B2;
}

.bridal-detail-ring .modaal-container .modaal-content-container {
  padding: 45px 18px 30px;
}

@media (min-width: 768px) {
  .bridal-detail-ring .modaal-container .modaal-content-container {
    padding: 55px 28px 33px;
  }
}

.bridal-detail-ring .modal-ring-img {
  max-width: 440px;
}

.bridal-detail-ring .modal-ring-name {
  margin-top: 9px;
  font-size: 15px;
  font-weight: bold;
  line-height: 1.428;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .bridal-detail-ring .modal-ring-name {
    margin-top: 13px;
    font-size: 16px;
  }
}

.bridal-detail-ring .modal-ring-name-wrap {
  margin-top: 9px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

@media (min-width: 768px) {
  .bridal-detail-ring .modal-ring-name-wrap {
    margin-top: 9px;
  }
}

.bridal-detail-ring .modal-ring-circle {
  margin-right: 3px;
  border: 1px solid #333;
  border-radius: 50%;
  width: 18px;
  height: 18px;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0;
}

@media (min-width: 768px) {
  .bridal-detail-ring .modal-ring-circle {
    width: 20px;
    height: 20px;
    font-size: 11px;
  }
}

.bridal-detail-ring .modal-ring-money {
  font-size: 13px;
  font-weight: bold;
  line-height: 1.428;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .bridal-detail-ring .modal-ring-money {
    font-size: 14px;
  }
}

.bridal-detail-ring .modal-ring-money-wrap {
  margin-top: 6px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

@media (min-width: 768px) {
  .bridal-detail-ring .modal-ring-money-wrap {
    margin-top: 5px;
  }
}

.brandlist .primary-ttl-wrap {
  margin-bottom: 30px;
}

@media (min-width: 768px) {
  .brandlist .primary-ttl-wrap {
    margin-bottom: 20px;
  }
}

.brandlist-txt {
  text-align: left;
}

@media (min-width: 768px) {
  .brandlist-txt {
    text-align: center;
  }
}

.brandlist.primary {
  padding: 45px 15px 135px 15px;
}

@media (min-width: 768px) {
  .brandlist.primary {
    padding: 95px 15px 180px 15px;
  }
}

.brandlist.bridal {
  padding: 45px 15px 81px;
}

@media (min-width: 768px) {
  .brandlist.bridal {
    padding: 114px 10px 119px;
    max-width: 1044px;
    margin: 0 auto;
  }
}

.brandlist.bridal .heading-1 {
  line-height: 1.266;
  text-align: center;
}

.brandlist .primary-content-wrap {
  margin-bottom: 0;
}

.brandlist .heading-4-border {
  margin-bottom: 10px;
}

@media (min-width: 768px) {
  .brandlist .heading-4-border {
    margin-bottom: 15px;
  }
}

.brandlist .store-detail-list {
  border-top: 1px solid #B2B2B2;
}

.brandlist .primary-content + .primary-content {
  margin-top: 40px;
}

.brandlist .primary-ttl-content {
  margin-bottom: 45px;
}

@media (min-width: 768px) {
  .brandlist .primary-ttl-content {
    margin-bottom: 50px;
  }
}

.brandlist .primary-def {
  font-size: 14px;
  line-height: 1.571;
  font-weight: 500;
}

@media (min-width: 768px) {
  .brandlist .primary-def {
    font-size: 15px;
    line-height: 1.6;
  }
}

.brandlist .heading-1 {
  font-size: 26px;
  line-height: 1.231;
}

@media (min-width: 768px) {
  .brandlist .heading-1 {
    font-size: 30px;
    line-height: 0.933;
  }
}

.brandlist .common-default {
  font-weight: 500;
}

@media (min-width: 768px) {
  .brandlist .common-default {
    line-height: 1.571;
  }
}

.brandlist .store-detail-wrap {
  padding: 0;
}

.brandlist .store-detail-list .list-wrap {
  padding: 15px 0 20px;
  font-weight: 500;
}

@media (min-width: 768px) {
  .brandlist .store-detail-list .list-wrap {
    padding: 15px 0;
  }
}

.brandlist .store-detail-list .list-block {
  margin-top: 0;
  letter-spacing: 0;
  line-height: 1.571;
}

.brandlist .store-detail-list .list-block .brand-list {
  position: relative;
  display: inline-block;
  padding-right: 13px;
  color: #333;
}

.brandlist .store-detail-list .list-block .brand-list::after {
  content: "/";
  position: absolute;
  right: 4px;
  color: #333;
}

.brandlist .store-detail-list .list-block .brand-list:nth-last-child(-n+2) {
  padding-right: 0;
}

.brandlist .store-detail-list .list-block .brand-list:nth-last-child(-n+2)::after {
  content: "";
}

.brandlist .store-detail-list .list-block a.brand-list {
  cursor: pointer;
  -webkit-transition: .3s;
  transition: .3s;
}

.brandlist .store-detail-list .list-block a.brand-list::before {
  -webkit-transition: .3s;
  transition: .3s;
  display: block;
  content: "";
  width: calc(100% - 13px);
  position: absolute;
  bottom: 1px;
  left: 0;
  border-bottom: 1px solid #333;
  opacity: 0;
}

.brandlist .store-detail-list .list-block a.brand-list:hover::before {
  opacity: 1;
}

.brandlist .store-detail-list .list-block a.brand-list.disabled {
  pointer-events: none;
}

.brandlist .store-detail-floor {
  margin-top: 40px;
}

.brandlist .heading-4-square {
  margin-bottom: 10px;
}

@media (min-width: 768px) {
  .brandlist .heading-4-square {
    margin-bottom: 15px;
  }
}

.brand-anchor {
  margin-right: 6px;
  margin-bottom: 6px;
  min-width: 28px;
  text-align: center;
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 768px) {
  .brand-anchor {
    margin-right: 10px;
    margin-bottom: 10px;
    min-width: 36px;
  }
}

.brand-anchor:last-of-type {
  width: 64px;
}

@media (min-width: 768px) {
  .brand-anchor:last-of-type {
    width: 82px;
  }
}

@media (min-width: 768px) {
  .brand-anchor:hover {
    opacity: 0.7;
  }
}

.brand-anchor-block {
  max-width: 635px;
  margin: 0 auto;
}

.brand-anchor-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-right: -6px;
  margin-bottom: -6px;
}

@media (min-width: 768px) {
  .brand-anchor-list {
    margin-right: -10px;
    margin-bottom: -10px;
  }
}

.brand-anchor-link {
  background-color: #333;
  color: #fff;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  padding: 8px 4px;
  display: block;
  font-size: 14px;
}

@media (min-width: 768px) {
  .brand-anchor-link {
    padding: 10px 8px;
  }
}

.btn {
  display: inline-block;
  text-align: center;
  padding: 12px 15px 14px;
  width: 240px;
  -webkit-transition: all .3s;
  transition: all .3s;
  position: relative;
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.05em;
  cursor: pointer;
}

@media (min-width: 768px) {
  .btn {
    padding: 12px 20px 14px;
    width: 300px;
    font-size: 16px;
  }
}

.btn [class*="icon-"] {
  -webkit-transition: all .3s;
  transition: all .3s;
}

@media (min-width: 768px) {
  .btn-short {
    width: 240px;
  }
}

@media (min-width: 768px) {
  .btn-long {
    width: 320px;
  }
}

.btn-black {
  background-color: #333;
  color: #fff;
  border: 1px solid #808080;
  padding: 12px 25px 14px 15px;
}

@media (min-width: 768px) {
  .btn-black {
    padding: 12px 30px 14px 20px;
  }
}

.btn-black [class*="icon-"] {
  color: #fff;
  font-size: 12px;
  position: absolute;
  top: 50%;
  right: 15px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

@media (min-width: 768px) {
  .btn-black [class*="icon-"] {
    right: 20px;
  }
}

@media (min-width: 768px) {
  .btn-black:hover {
    color: #333;
    background-color: #D9D9D9;
  }
  .btn-black:hover [class*="icon-"] {
    color: #333;
  }
}

.btn-white {
  background-color: #fff;
  color: #333;
  border: 1px solid #808080;
  padding: 12px 15px 14px 25px;
}

@media (min-width: 768px) {
  .btn-white {
    padding: 12px 20px 14px 30px;
  }
}

.btn-white [class*="icon-"] {
  color: #4C4948;
  font-size: 12px;
  position: absolute;
  top: 50%;
  left: 15px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

@media (min-width: 768px) {
  .btn-white [class*="icon-"] {
    left: 20px;
  }
}

@media (min-width: 768px) {
  .btn-white:hover {
    color: #333;
    background-color: #D9D9D9;
  }
  .btn-white:hover [class*="icon-"] {
    color: #333;
  }
}

.btn-white.pad {
  padding: 14px 10px;
}

@media (min-width: 768px) {
  .btn-white.pad {
    padding: 12px 20px 14px 30px;
  }
}

.btn-gray {
  background-color: #F2F2F2;
  color: #333;
  border: 1px solid #B2B2B2;
  padding: 8px 22px;
  width: 100%;
  font-size: 14px;
  letter-spacing: 0.02em;
}

@media (max-width: 360px) {
  .btn-gray {
    font-size: 11px;
  }
}

@media (min-width: 768px) {
  .btn-gray {
    width: 160px;
  }
}

.btn-gray [class*="icon-"] {
  color: #333;
  font-size: 11px;
  position: absolute;
  top: 50%;
  right: 10px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

@media (min-width: 768px) {
  .btn-gray [class*="icon-"] {
    font-size: 12px;
    right: 9px;
  }
}

@media (min-width: 768px) {
  .btn-gray:hover {
    color: #fff;
    background-color: #333;
  }
  .btn-gray:hover [class*="icon-"] {
    color: #fff;
  }
}

.btn-icon-down {
  width: 260px;
}

@media (min-width: 768px) {
  .btn-icon-down {
    width: 300px;
  }
}

.btn-icon-down [class*="icon-"] {
  font-size: 22px;
  left: auto;
  right: 15px;
}

@media (min-width: 768px) {
  .btn-icon-down [class*="icon-"] {
    right: 16px;
  }
}

.btn-wrap-center {
  margin: 0 auto;
  text-align: center;
}

.btn-wrap-middle {
  margin-top: 57px;
}

@media (min-width: 768px) {
  .btn-wrap-middle {
    margin-top: 82px;
  }
}

.btn-wrap-col {
  margin: 70px auto 0;
  text-align: center;
}

@media (min-width: 768px) {
  .btn-wrap-col {
    margin-top: 100px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

.btn-wrap-col .btn + .btn {
  margin-top: 24px;
}

@media (min-width: 768px) {
  .btn-wrap-col .btn + .btn {
    margin-top: 0;
    margin-left: 40px;
  }
}

.common-default {
  font-size: 14px;
  line-height: 1.75;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .common-default {
    line-height: 1.857;
  }
}

.common-default.bold {
  font-weight: bold;
}

.common-default.info {
  margin-top: 4px;
}

@media (min-width: 768px) {
  .common-default.info {
    margin-top: 12px;
  }
}

.common-default.info p {
  line-height: 1.714;
}

.common-default.info.bold {
  line-height: 1.714;
  font-weight: bold;
}

.common-default.hight {
  line-height: 1.714;
}

.common-wrap {
  padding: 45px 15px 115px 15px;
}

@media (min-width: 768px) {
  .common-wrap {
    width: 100%;
    padding: 86px 15px 125px 15px;
    max-width: 1054px;
    margin: 0 auto;
  }
}

.common-ttl {
  font-size: 16px;
  line-height: 1.875;
  font-weight: 500;
  letter-spacing: 0.04em;
  padding-bottom: 5px;
}

@media (min-width: 768px) {
  .common-ttl {
    font-size: 18px;
    line-height: 1.667;
    letter-spacing: 0.04em;
    padding-bottom: 8px;
  }
}

.common-ttl-txt {
  font-size: 16px;
  font-weight: bold;
  line-height: 1.8;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .common-ttl-txt {
    line-height: 1.875;
  }
}

.common-ttl-txt.hight {
  line-height: 1.75;
}

.common-ttl-txt.info {
  line-height: 1.75;
}

.common-ttl-wrap {
  margin-bottom: 30px;
  text-align: center;
}

@media (min-width: 768px) {
  .common-ttl-wrap {
    margin-bottom: 52px;
  }
}

.common-ttl-wrap .ttl-h2 {
  font-size: 26px;
  font-weight: bold;
  line-height: 1.154;
  letter-spacing: 0.03em;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
}

.common-ttl-wrap .ttl-h2 span {
  display: block;
  margin-top: 10px;
  font-size: 16px;
  color: #808080;
}

@media (min-width: 768px) {
  .common-ttl-wrap .ttl-h2 {
    font-size: 30px;
    line-height: 1;
    letter-spacing: 0.03em;
  }
}

.common-ttl-wrap .ttl-h2.info {
  font-size: 24px;
  line-height: 1.25;
}

@media (min-width: 768px) {
  .common-ttl-wrap .ttl-h2.info {
    font-size: 30px;
    line-height: 1;
    letter-spacing: 0.03em;
  }
}

@media (min-width: 768px) {
  .common-ttl-wrap.rule {
    margin-bottom: 50px;
  }
}

.common-content-wrap {
  margin-bottom: 30px;
}

@media (min-width: 768px) {
  .common-content-wrap {
    text-align: center;
    margin-bottom: 60px;
  }
}

.common-txt {
  font-size: 16px;
  font-weight: bold;
  line-height: 1.8;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .common-txt {
    font-size: 18px;
    line-height: 1.5;
  }
}

.common-txt.hight {
  line-height: 1.75;
}

.common-txt-note {
  position: relative;
  font-size: 12px;
  line-height: 1.75;
  letter-spacing: 0.02em;
  padding-left: 1em;
}

.common-txt-note::before {
  content: "※";
  position: absolute;
  top: 0;
  left: 0;
}

.common-txt-note-wrap {
  margin-top: 12px;
}

.common-txt.normal {
  font-weight: normal;
  line-height: 1.625;
}

@media (min-width: 768px) {
  .common-txt.normal {
    font-size: 16px;
    line-height: 1.875;
  }
}

.common-txt.question {
  position: relative;
  padding-left: 40px;
}

.common-txt.question::before {
  content: "";
  width: 30px;
  height: 30px;
  position: absolute;
  background-size: 100%;
  top: 0;
  left: 0;
  background-image: url("../images/common/Q_batch.svg");
}

@media (min-width: 768px) {
  .common-txt.question {
    padding-left: 70px;
  }
}

.common-tab {
  color: #333;
  text-align: center;
}

@media (min-width: 768px) {
  .common-tab {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    line-height: 1.625;
  }
}

.common-tab-txt {
  font-size: 16px;
  font-weight: bold;
  line-height: 1.625;
  letter-spacing: 0.02em;
}

.common-tab-txt.question-txt {
  line-height: 1.5;
}

.common-tab .tab-link {
  width: 100%;
  position: relative;
  border: 1px solid #B2B2B2;
  padding: 10px 0;
  color: #333;
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 768px) {
  .common-tab .tab-link:hover {
    background-color: #333;
    color: #fff;
  }
}

@media (min-width: 768px) {
  .common-tab .tab-link {
    padding: 10px 35px;
  }
}

.common-tab .tab-link-item {
  margin-bottom: 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  position: relative;
  color: #333;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media (min-width: 768px) {
  .common-tab .tab-link-item {
    width: calc(100% / 3);
    max-width: 255px;
    margin-bottom: 0;
    margin-right: 10px;
  }
  .common-tab .tab-link-item:last-child {
    margin-right: 0;
  }
}

.common-tab .tab-link.is-active {
  color: #fff;
  background-color: #333;
}

.common-tab .common-tab-list {
  font-size: 14px;
  font-weight: bold;
  line-height: 1.625;
  letter-spacing: 0.02em;
  cursor: pointer;
  margin-bottom: 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  position: relative;
  border: 1px solid #B2B2B2;
  padding: 10px 0;
  color: #333;
  -webkit-transition: .3s;
  transition: .3s;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media (min-width: 768px) {
  .common-tab .common-tab-list {
    width: calc(100% / 3);
    max-width: 255px;
    margin-bottom: 0;
    margin-right: 10px;
    padding: 10px 35px;
  }
  .common-tab .common-tab-list:last-child {
    margin-right: 0;
  }
}

@media (min-width: 768px) {
  .common-tab .common-tab-list:hover {
    color: #fff;
    background-color: #333;
  }
}

.common-tab .common-tab-list.is-active-tab {
  color: #fff;
  background-color: #333;
}

.common-tab-number {
  font-size: 24px;
  font-weight: 500;
  font-family: "Barlow";
  line-height: 1.083;
  letter-spacing: 0.02em;
  position: absolute;
  top: 10px;
  left: 20px;
}

.common-tab-wrap {
  width: 100%;
  max-width: 840px;
  margin: 0 auto;
}

.common .sub-ttl {
  font-size: 16px;
  font-weight: bold;
  line-height: 1.875;
  letter-spacing: 0.04em;
  color: #808080;
  margin-top: 5px;
}

@media (min-width: 768px) {
  .common .sub-ttl {
    margin-top: 10px;
  }
}

.common .txt-wrap {
  margin-top: 10px;
}

@media (min-width: 768px) {
  .common .txt-wrap {
    margin-top: 25px;
  }
}

.square-block + .square-block {
  margin-top: 40px;
}

@media (min-width: 768px) {
  .square-block + .square-block {
    margin-top: 20px;
  }
}

.answer {
  position: relative;
  padding-left: 40px;
  margin-top: 20px;
}

.answer::before {
  content: "";
  width: 30px;
  height: 30px;
  position: absolute;
  background-size: 100%;
  top: 0;
  left: 0;
  background-image: url("../images/common/A_batch.svg");
}

@media (min-width: 768px) {
  .answer {
    padding-left: 70px;
    margin-top: 30px;
  }
}

.button-wrap {
  margin: 55px auto 0 auto;
  text-align: center;
}

@media (min-width: 768px) {
  .button-wrap {
    margin: 65px auto 0 auto;
  }
}

.sup {
  font-size: 0.5em;
  vertical-align: top;
}

.enquiry-block {
  margin-top: 55px;
}

@media (min-width: 768px) {
  .enquiry-block {
    margin-top: 70px;
  }
}

.link-more {
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: 0.013em;
  font-weight: bold;
  position: relative;
  display: inline-block;
  padding-left: 22px;
  vertical-align: middle;
  color: #333;
  -webkit-transition: all .3s;
  transition: all .3s;
}

.link-more::before {
  content: "";
  position: absolute;
  top: 4px;
  left: 0;
  width: 14px;
  height: 14px;
  background-image: url("../images/common/arrow_bottom.svg");
  background-size: 100%;
}

@media (min-width: 768px) {
  .link-more:hover {
    opacity: 0.7;
  }
}

.link-more + .link-more {
  display: block;
  margin-top: 10px;
}

@media (min-width: 768px) {
  .link-more + .link-more {
    margin-top: 5px;
  }
}

.link-more-wrap {
  margin-top: 15px;
}

@media (min-width: 768px) {
  .link-more-wrap {
    margin-top: 20px;
  }
}

@media (min-width: 768px) {
  .link-more-wrap.narrow {
    margin-top: 10px;
  }
}

.link-pdf {
  position: relative;
  padding-right: 24px;
}

.link-pdf::after {
  content: "";
  position: absolute;
  top: -1px;
  right: 0;
  width: 20px;
  height: 20px;
  background-image: url("../images/common/pdf.svg");
  background-size: 100%;
}

@media (min-width: 768px) {
  .rule {
    width: 100%;
    max-width: 1054px;
  }
}

.rule-wrap + .rule-wrap {
  margin-top: 30px;
}

@media (min-width: 768px) {
  .rule-wrap + .rule-wrap {
    margin-top: 20px;
  }
}

.detail-inner {
  padding: 20px 15px 63px;
}

@media (min-width: 768px) {
  .detail-inner {
    max-width: 1044px;
    margin: 0 auto;
    padding: 63px 10px 84px;
  }
}

.detail-inner .btn-wrap-col {
  margin-top: 72px;
}

@media (min-width: 768px) {
  .detail-inner .btn-wrap-col {
    margin-top: 100px;
  }
}

.detail-inner-narrow {
  max-width: 790px;
  margin: 0 auto;
}

.detail-inner-narrow img {
  width: 100%;
}

.detail-inner table {
  margin-top: 20px;
  border: 1px solid #333;
}

.detail-inner table th {
  background-color: #333;
  color: #fff;
  vertical-align: middle;
  padding: 2px 4px;
  border: 1px solid #fff;
}

.detail-inner table td {
  padding: 2px 4px;
  border: 1px solid #333;
}

.detail-heading-wrap {
  margin-bottom: 15px;
  text-align: center;
}

@media (min-width: 768px) {
  .detail-heading-wrap {
    margin-bottom: 37px;
  }
}

.detail-heading-wrap .detail-event-time-wrap {
  display: none;
}

.detail-heading-detail {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.detail-heading-date {
  font-size: 12px;
  letter-spacing: 0.02em;
  margin-left: 15px;
}

@media (min-width: 768px) {
  .detail-heading-date {
    font-size: 14px;
  }
}

.detail-ttl {
  margin-top: 10px;
  font-size: 20px;
  letter-spacing: 0.04em;
  line-height: 1.5;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  font-weight: bold !important;
}

@media (min-width: 768px) {
  .detail-ttl {
    font-size: 24px;
  }
}

.detail-subttl {
  margin-top: 2px;
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.04em;
  line-height: 1.5;
}

@media (min-width: 768px) {
  .detail-subttl {
    font-size: 20px;
  }
}

.detail-mv {
  margin: 0 -15px 40px;
}

@media (min-width: 768px) {
  .detail-mv {
    margin: 0 0 30px;
  }
}

.detail-lead {
  margin-bottom: 38px;
  font-weight: bold;
  letter-spacing: 0.02em;
  line-height: 1.625;
}

@media (min-width: 768px) {
  .detail-lead {
    margin-bottom: 48px;
    line-height: 1.875;
  }
}

.detail-lead p {
  margin-bottom: 38px;
  font-weight: bold;
  letter-spacing: 0.02em;
  line-height: 1.625;
}

@media (min-width: 768px) {
  .detail-lead p {
    margin-bottom: 48px;
    line-height: 1.875;
  }
}

.detail-lead.event-detail-lead p {
  font-weight: normal;
  font-size: 14px;
  margin-bottom: 0;
}

.detail-lead.event-detail-lead p + p {
  margin-top: 14px;
}

.detail-lead.event-detail-lead-add p + p {
  margin-top: 14px;
  margin-bottom: 0;
}

.detail-lead-normal {
  font-size: 14px;
  font-weight: normal;
}

.detail-item {
  margin: 0 auto;
}

.detail-item + .detail-item {
  margin-top: 86px;
}

@media (min-width: 768px) {
  .detail-item + .detail-item {
    margin-top: 60px;
  }
}

.detail-item.detail-item-sub {
  margin-top: 20px;
}

@media (min-width: 768px) {
  .detail-item.detail-item-sub {
    margin-top: 30px;
  }
}

.detail-item.detail-item-sub h3 {
  margin-top: 0;
}

.detail-item h2 {
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.02em;
  line-height: 1.5;
  margin-bottom: 15px;
  padding: 0;
  text-align: left;
  border-top: none;
  border-bottom: none;
}

@media (min-width: 768px) {
  .detail-item h2 {
    font-size: 20px;
    margin-bottom: 20px;
  }
}

.detail-item h3 {
  margin-top: 18px;
  font-size: 14px;
  font-weight: bold;
  line-height: 1.714;
}

.detail-item h3 span:after {
  content: "/";
}

.detail-item h3 span:last-child:after {
  content: "";
}

@media (min-width: 768px) {
  .detail-item h3 {
    margin-top: 26px;
  }
}

.detail-item p {
  letter-spacing: 0.02em;
  line-height: 1.857;
  font-size: 14px;
}

.detail-item .small {
  margin-top: 10px;
  display: block;
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: 0.04em;
}

@media (min-width: 768px) {
  .detail-item .small {
    margin-top: 18px;
  }
}

.detail-item-img img {
  margin: 0 auto;
  display: block;
  width: auto;
  max-width: 100%;
}

@media (min-width: 768px) {
  .detail-item-flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

@media (min-width: 768px) {
  .detail-item-flex-img {
    width: calc(50% - 30px);
  }
}

.detail-item-flex-txt {
  margin-top: 24px;
}

@media (min-width: 768px) {
  .detail-item-flex-txt {
    margin-top: 0;
    margin-left: 60px;
    width: calc(50% - 30px);
  }
}

.detail-item-profile {
  margin: 100px auto 0;
  padding: 23px;
  border: 1px solid #B2B2B2;
  max-width: 750px;
}

.detail-item-profile + .detail-item-profile {
  margin: 50px auto 0;
}

.detail-item-profile-ttl {
  color: #666464;
  font-size: 15px;
  font-weight: 500;
  text-align: center;
}

@media (min-width: 768px) {
  .detail-item-profile-ttl {
    text-align: left;
  }
}

.detail-item-profile-ttl-wrap {
  margin-left: 31px;
  width: calc(100% - 153px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

@media (min-width: 768px) {
  .detail-item-profile-ttl-wrap {
    display: none;
  }
}

.detail-item-profile-contents {
  margin-top: 12px;
}

@media (min-width: 768px) {
  .detail-item-profile-contents {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-top: 7px;
  }
}

.detail-item-profile-contents-txt {
  margin-top: 12px;
}

@media (min-width: 768px) {
  .detail-item-profile-contents-txt {
    margin-top: 0;
    margin-left: 40px;
    width: calc(100% - 176px);
  }
}

.detail-item-profile-img {
  width: 136px;
  margin: 0 auto;
}

.detail-item-profile-profession {
  margin-bottom: 3px;
  font-size: 13px;
  font-weight: 500;
  line-height: 1.4615;
  text-align: center;
}

@media (min-width: 768px) {
  .detail-item-profile-profession {
    text-align: left;
  }
}

.detail-item-profile-name {
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1.5;
  text-align: center;
}

@media (min-width: 768px) {
  .detail-item-profile-name {
    text-align: left;
  }
}

.detail-item-profile-txt {
  font-size: 12px;
  letter-spacing: 0.02em;
  line-height: 1.666;
  margin-top: 12px;
}

@media (min-width: 768px) {
  .detail-item-profile-txt {
    margin-top: 11px;
  }
}

.detail-item-explanation {
  margin-top: 40px;
  padding: 30px 22px;
  border: 1px solid #B2B2B2;
}

@media (min-width: 768px) {
  .detail-item-explanation {
    margin-top: 50px;
    padding: 34px 54px;
  }
}

@media (min-width: 768px) {
  .detail-item-explanation-fl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 31px 32px;
  }
}

.detail-item-explanation-img {
  margin-bottom: 20px;
}

@media (min-width: 768px) {
  .detail-item-explanation-img {
    margin-bottom: 0;
    margin-right: 41px;
    width: 280px;
  }
}

@media (min-width: 768px) {
  .detail-item-explanation-txt {
    width: calc(100% - 321px);
  }
}

.detail-item-explanation h2 {
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.02em;
  line-height: 1.5;
  margin-bottom: 15px;
  padding: 0;
  text-align: left;
  border-top: none;
  border-bottom: none;
}

@media (min-width: 768px) {
  .detail-item-explanation h2 {
    margin-bottom: 14px;
  }
}

.detail-item-explanation p {
  letter-spacing: 0.02em;
  line-height: 1.714;
}

.detail-item-explanation a {
  font-size: 14px;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.02em;
  position: relative;
  display: inline-block;
  padding-left: 22px;
  color: #333;
  -webkit-transition: all .3s;
  transition: all .3s;
}

.detail-item-explanation a::before {
  content: "";
  position: absolute;
  top: 4px;
  left: 0;
  width: 14px;
  height: 14px;
  background-image: url("../images/common/arrow_bottom.svg");
  background-size: 100%;
}

@media (min-width: 768px) {
  .detail-item-explanation a:hover {
    opacity: 0.7;
  }
}

.detail-item-link {
  margin-top: 21px;
}

@media (min-width: 768px) {
  .detail-item-link {
    margin-top: 24px;
  }
}

.detail-item-link + .detail-item-link {
  margin-top: 9px;
}

@media (min-width: 768px) {
  .detail-item-link + .detail-item-link {
    margin-top: 13px;
  }
}

.detail-item.detail-item-flex .detail-item-flex-txt .detail-item a {
  font-size: 12px;
}

.detail-item-column {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  grid-gap: 60px;
  margin-top: 50px;
}

@media (min-width: 768px) {
  .detail-item-column {
    margin-top: 50px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: 60px;
  }
}

.detail-item-column-img {
  -o-object-fit: contain;
     object-fit: contain;
}

@media (min-width: 768px) {
  .detail-item-column-img {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.detail-item-column-img img {
  -o-object-fit: contain;
     object-fit: contain;
}

@media (min-width: 768px) {
  .detail-item-column-img img {
    height: 345px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.detail-item-text {
  margin-top: 18px;
}

@media (min-width: 768px) {
  .detail-item-text {
    margin-top: 26px;
  }
}

.detail-item .detail-img-grid {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 20px;
}

@media (min-width: 768px) {
  .detail-item .detail-img-grid {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}

.detail-img-grid-col3 {
  display: grid;
  gap: 20px;
}

@media (min-width: 768px) {
  .detail-img-grid-col3 {
    grid-template-columns: repeat(3, 1fr);
  }
}

.detail-img-grid-col4 {
  display: grid;
  gap: 20px;
}

@media (min-width: 768px) {
  .detail-img-grid-col4 {
    grid-template-columns: repeat(4, 1fr);
  }
}

.detail-pager {
  margin-top: 61px;
  position: relative;
  text-align: center;
}

@media (min-width: 768px) {
  .detail-pager {
    margin-top: 53px;
  }
}

.detail-pager-txt {
  line-height: 1.428;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  color: #333;
  -webkit-transition: .3s;
  transition: .3s;
}

.detail-pager-txt [class*="icon-"] {
  font-size: 32px;
  color: #B2B2B2;
}

@media (min-width: 768px) {
  .detail-pager-txt {
    min-height: 50px;
  }
  .detail-pager-txt [class*="icon-"] {
    font-size: 51px;
  }
}

@media (min-width: 768px) {
  .detail-pager-txt:hover {
    opacity: 0.7;
  }
}

.detail-pager-txt.prev {
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

@media (min-width: 768px) {
  .detail-pager-txt.prev [class*="icon-"] {
    margin-right: 10px;
  }
}

.detail-pager-txt.next {
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

@media (min-width: 768px) {
  .detail-pager-txt.next [class*="icon-"] {
    margin-left: 10px;
  }
}

.detail-event-time {
  font-size: 14px;
  font-weight: bold;
}

@media (min-width: 768px) {
  .detail-event-time {
    font-size: 16px;
  }
}

.detail-event-time + .detail-event-time {
  position: relative;
  padding-left: 20px;
}

.detail-event-time + .detail-event-time:before {
  content: "-";
  position: absolute;
  left: 3px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.detail-event-time-wrap {
  margin-top: 10px;
}

.detail-event-time-wrap.small-time .detail-event-time {
  font-size: 12px;
}

.detail-blog-inner .detail-ttl {
  font-weight: 700 !important;
  letter-spacing: 0.04em;
}

.detail-blog-inner .detail-item-img img {
  width: 100%;
}

.event-detail-lead:not(:last-of-type) {
  margin-bottom: 48px;
}

.event-detail-lead-add p {
  line-height: 1.625;
}

.event-detail-lead-add p + p {
  margin-top: 14px;
}

.events .index-inner {
  margin: 0 auto;
  padding: 45px 15px 40px;
}

@media (min-width: 768px) {
  .events .index-inner {
    max-width: 1064px;
    padding: 86px 20px 50px;
  }
}

.events .common-ttl-wrap {
  margin-bottom: 22px;
}

.events-calender {
  margin: 30px -15px 35px;
  font-family: "Barlow",'Myriad Pro','Helvetica','Arial',sans-serif;
  font-weight: 500;
  text-align: center;
}

@media (min-width: 768px) {
  .events-calender {
    margin: 45px auto;
  }
}

.events-calender-heading {
  background-color: #000;
}

.events-calender-heading ul {
  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;
}

.events-calender-heading ul li {
  color: #FFF;
  font-size: 20px;
}

@media (min-width: 768px) {
  .events-calender-heading ul li {
    font-size: 26px;
  }
}

.events-calender-heading ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 11px 20px;
  color: #FFF;
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 768px) {
  .events-calender-heading ul li a {
    padding: 20px 20px;
  }
}

.events-calender-heading ul li a img {
  -webkit-transition: opacity ease 0.2s;
  transition: opacity ease 0.2s;
}

@media (min-width: 768px) {
  .events-calender-heading ul li a:hover img {
    -ms-filter: "alpha(opacity=70)";
    opacity: 0.70;
  }
}

.events-calender-heading ul li.prev img, .events-calender-heading ul li.next img {
  width: 18px;
  height: auto;
}

@media (min-width: 768px) {
  .events-calender-heading ul li.prev img, .events-calender-heading ul li.next img {
    width: initial;
  }
}

.events-calender-date {
  background-color: #EFEFEF;
  border-bottom: 1px solid #B2B2B2;
}

.events-calender-date ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: relative;
  overflow-x: auto;
  overflow-y: hidden;
}

.events-calender-date ul li {
  width: 14.33333%;
  min-width: 60px;
}

@media (min-width: 1044px) {
  .events-calender-date ul li {
    width: 9.04977%;
  }
}

.events-calender-date ul li a {
  display: block;
  padding: 13px 8.26667%;
  height: 100%;
  width: 100%;
  font-size: 20px;
  color: #666464;
  white-space: nowrap;
  line-height: 1;
  -webkit-transition: ease 0.2s;
  transition: ease 0.2s;
}

@media (min-width: 768px) {
  .events-calender-date ul li a {
    font-size: 26px;
  }
}

.events-calender-date ul li a span {
  font-size: 10px;
  padding-left: 4px;
}

@media (min-width: 768px) {
  .events-calender-date ul li a span {
    font-size: 13px;
  }
}

@media (min-width: 768px) {
  .events-calender-date ul li a:hover {
    background-color: #D9D9D9;
  }
  .events-calender-date ul li a:hover img {
    -ms-filter: "alpha(opacity=70)";
    opacity: 0.70;
  }
}

.events-calender-date ul li.is-current {
  background-color: #D9D9D9;
}

.events-calender-date ul li.prev, .events-calender-date ul li.next {
  display: block;
  position: absolute;
  top: 0;
  width: 9.86667%;
  height: 100%;
}

@media (min-width: 768px) {
  .events-calender-date ul li.prev, .events-calender-date ul li.next {
    width: 6.83594%;
  }
}

.events-calender-date ul li.prev a, .events-calender-date ul li.next a {
  padding: 13px 0;
}

.events-calender-date ul li.prev img, .events-calender-date ul li.next img {
  width: 18px;
  height: auto;
}

@media (min-width: 768px) {
  .events-calender-date ul li.prev img, .events-calender-date ul li.next img {
    width: initial;
  }
}

.events-calender-date ul li.prev {
  left: 0;
}

.events-calender-date ul li.next {
  right: 0;
}

.events-calender-date ul li.sat a span {
  color: #0091FF;
}

.events-calender-date ul li.sun a span {
  color: #EA5D6E;
}

.events-search {
  text-align: center;
}

.events-search .btn {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: initial;
  min-width: 180px;
  height: 40px;
  padding: 0 1em;
  line-height: 40px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  -webkit-transition: background-color 0.1s ease;
  transition: background-color 0.1s ease;
  font-size: 1.3rem;
  font-weight: normal;
  letter-spacing: 0.1em;
  color: #333;
  text-decoration: none !important;
  text-align: center;
  border: 1px solid #B2B2B2;
  border-radius: 0;
  background-color: transparent;
  word-break: break-word;
  cursor: pointer;
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 768px) {
  .events-search .btn {
    min-width: 240px;
    height: 50px;
    font-size: 1.6rem;
    line-height: 50px;
  }
}

.events-search .btn.btn-a {
  color: #333;
  border-color: #B2B2B2 !important;
}

@media (min-width: 768px) {
  .events-search .btn.btn-a:hover {
    color: #FFF;
    background-color: #333;
    border-color: #333 !important;
  }
}

.events-list {
  background-color: #F2F2F2;
}

.events-list-inner {
  padding: 60px 15px 80px;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .events-list-inner {
    max-width: 1064px;
    padding: 80px 20px 160px;
  }
}

.events-list-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 30px 0 45px;
  border-bottom: 1px solid #B2B2B2;
}

@media (min-width: 768px) {
  .events-list-item {
    padding: 30px 0;
  }
}

.events-list-item:first-child {
  padding-top: 0;
}

.events-list-item-thumb {
  position: relative;
  width: 100%;
  margin-bottom: 15px;
}

@media (min-width: 768px) {
  .events-list-item-thumb {
    width: 310px;
    margin-bottom: 0;
  }
}

.events-list-item-thumb a {
  display: block;
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 768px) {
  .events-list-item-thumb a:hover {
    opacity: 0.7;
  }
}

.events-list-item-thumb .label {
  display: block;
  position: absolute;
  top: 0;
  left: 10px;
  width: 48px;
  height: 48px;
  background-color: #D92114;
  color: #FFF;
  font-weight: bold;
  line-height: 48px;
  text-align: center;
  letter-spacing: 0.07em;
}

.events-list-item-content {
  width: 100%;
}

@media (min-width: 768px) {
  .events-list-item-content {
    width: calc(100% - 362px);
  }
}

.events-list-item-content > p {
  margin-bottom: 1.3em;
  line-height: calc(24 / 14);
}

@media (min-width: 768px) {
  .events-list-item-content > p {
    line-height: calc(26 / 14);
  }
}

.events-list-item-content .date {
  margin-bottom: 5px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.3;
  display: none;
}

.events-list-item-content .title {
  margin-bottom: 2px;
  font-size: 18px;
  line-height: calc(28 / 18);
}

.events-list-item-content .sub-title {
  margin-bottom: 20px;
  font-size: 16px;
  color: #B18710;
  line-height: calc(26 / 16);
}

.events-list-item-content .list-stores {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-bottom: 7px;
}

.events-list-item-content .list-stores li {
  margin: 0 8px 8px 0;
}

.events-list-item-content .list-stores li a {
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 768px) {
  .events-list-item-content .list-stores li a:hover {
    opacity: 0.7;
  }
}

.events-list-item-content .notes {
  font-size: 12px;
  line-height: calc(20 / 12);
}

.events-list-item-content .notes p {
  font-size: 12px;
  line-height: calc(20 / 12);
}

.events-list-item-content .more {
  margin-bottom: 0;
}

.events-list-item-content .more a {
  position: relative;
  padding: 0 0 0 22px;
  line-height: 1.3;
  color: #333;
  -webkit-transition: all .3s;
  transition: all .3s;
}

.events-list-item-content .more a:before {
  position: absolute;
  top: 3px;
  left: 0;
  display: block;
  content: "";
  width: 14px;
  height: 14px;
  background: url(../images/common/arrow_right_02.svg) no-repeat 0 0;
}

.events-list-item-content .more a:hover, .events-list-item-content .more a:active {
  opacity: 0.7;
}

.form-wrap-label {
  position: relative;
  cursor: pointer;
}

.form-wrap-label input[type="radio"],
.form-wrap-label input[type="checkbox"] {
  position: absolute;
  top: 0;
  left: 0;
  overflow: hidden;
  width: 0;
  height: 0;
  margin: 0;
  opacity: 0;
  z-index: -1;
}

.form-wrap-label input[type="radio"] + span,
.form-wrap-label input[type="checkbox"] + span {
  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;
  height: 100%;
  padding: 12px 4px;
  font-size: 12px;
  border: 1px solid #38332E;
  background-color: #FFF;
  word-break: break-word;
  text-align: center;
}

@media (min-width: 768px) {
  .form-wrap-label input[type="radio"] + span,
  .form-wrap-label input[type="checkbox"] + span {
    padding: 12px 10px;
    font-size: 18px;
  }
}

.form-wrap-label input[type="radio"]:checked + span,
.form-wrap-label input[type="checkbox"]:checked + span {
  background-color: #EFEFEF;
  outline: 3px solid #38332E;
  outline-offset: -3px;
}

.form-wrap-label input[type="checkbox"]:checked ~ .modal-events-search-check-dummy {
  background-color: #FFF;
}

.form-wrap-label input[type="checkbox"]:checked ~ .modal-events-search-check-dummy::before {
  content: "";
  display: block;
  background: url(../images/events/check.svg) no-repeat 0 0;
  background-size: contain;
  width: 14px;
  height: 14px;
  position: absolute;
  top: 5px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}

.form-wrap-label input[type="checkbox"]:checked ~ .modal-events-search-check-dummy _::-webkit-full-page-media, .form-wrap-label input[type="checkbox"]:checked ~ .modal-events-search-check-dummy _:future, :root .form-wrap-label input[type="checkbox"]:checked ~ .modal-events-search-check-dummy {
  top: -22px;
}

@media (min-width: 768px) {
  .form-wrap-label input[type="checkbox"]:checked ~ .modal-events-search-check-dummy _::-webkit-full-page-media, .form-wrap-label input[type="checkbox"]:checked ~ .modal-events-search-check-dummy _:future, :root .form-wrap-label input[type="checkbox"]:checked ~ .modal-events-search-check-dummy {
    top: -26px;
  }
}

.modal-events-search-title {
  margin-bottom: 24px;
  text-align: center;
}

@media (min-width: 768px) {
  .modal-events-search-title {
    margin-bottom: 40px;
  }
}

.modal-events-search-check-input {
  opacity: 0;
}

.modal-events-search-check-dummy {
  position: absolute;
  width: 24px;
  height: 24px;
  border: solid 2px #38332E;
  top: 50%;
  left: 13px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.modal-events-search-check-dummy _::-webkit-full-page-media, .modal-events-search-check-dummy _:future, :root .modal-events-search-check-dummy {
  top: -20px;
}

@media (min-width: 768px) {
  .modal-events-search-check-dummy _::-webkit-full-page-media, .modal-events-search-check-dummy _:future, :root .modal-events-search-check-dummy {
    top: -25px;
  }
}

.modal-events-search-sex {
  display: block;
  margin-bottom: 24px;
}

@media (min-width: 768px) {
  .modal-events-search-sex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-bottom: 35px;
  }
}

.modal-events-search-sex li {
  width: 100%;
  margin-bottom: 12px;
}

@media (min-width: 768px) {
  .modal-events-search-sex li {
    width: 48.79288%;
    margin-bottom: 0;
  }
}

.modal-events-search-sub-title {
  position: relative;
  margin-bottom: 24px;
  font-size: 18px;
  font-weight: 500;
  text-align: center;
}

@media (min-width: 768px) {
  .modal-events-search-sub-title {
    margin-bottom: 30px;
    font-size: 20px;
  }
}

.modal-events-search-sub-title span {
  position: relative;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  padding: 0 30px;
  background-color: #fff;
  z-index: 2;
}

.modal-events-search-sub-title:after {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #B2B2B2;
  z-index: 1;
}

.modal-events-search-stores {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-bottom: 25px;
  padding-bottom: 15px;
  border-bottom: 1px solid #B2B2B2;
}

@media (min-width: 768px) {
  .modal-events-search-stores {
    margin-bottom: 35px;
    padding-bottom: 18px;
  }
}

.modal-events-search-stores li {
  width: 100%;
  margin-bottom: 16px;
}

@media (min-width: 768px) {
  .modal-events-search-stores li {
    width: 48.91995%;
    margin: 0 1.90597% 17px 0;
  }
  .modal-events-search-stores li:nth-child(2n) {
    margin-right: 0;
  }
}

@media (min-width: 1044px) {
  .modal-events-search-stores li {
    width: 31.7662%;
    margin: 0 1.90597% 17px 0;
  }
  .modal-events-search-stores li:nth-child(2n) {
    margin-right: 17px;
  }
  .modal-events-search-stores li:nth-child(3n) {
    margin-right: 0;
  }
}

.modal-events-search-submit {
  text-align: center;
}

.footer {
  padding: 0 10px;
  background-color: #000;
  color: #fff;
}

.footer a {
  cursor: pointer;
  color: #fff;
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 768px) {
  .footer a:hover {
    color: #B18710;
    opacity: 0.7;
  }
}

@media (min-width: 768px) {
  .footer a.footer-blog-link:hover {
    opacity: 0.7;
    color: #fff;
  }
}

.footer-wrap {
  max-width: 1043px;
  padding: 56px 15px 19px 15px;
  position: relative;
}

@media (min-width: 1044px) {
  .footer-wrap {
    padding: 48px 0 20px 0;
    max-width: 1024px;
    margin: 0 auto;
  }
}

.footer-outer {
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
}

.footer-outer + .footer-outer {
  margin-top: 36px;
}

@media (min-width: 1044px) {
  .footer-outer {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .footer-outer + .footer-outer {
    margin-top: 60px;
  }
}

.footer-outer-block {
  margin-bottom: 23px;
}

.footer-outer-block:last-child {
  margin-bottom: 0;
}

.footer-accordion-block {
  font-size: 15px;
  color: #BFBFBF;
  margin-top: 0;
  background-image: url("../images/common/accordion.svg");
  background-position: right;
  margin-bottom: 0;
  padding-bottom: 9px;
  border-bottom: 1px solid #808080;
}

@media (min-width: 1044px) {
  .footer-accordion-block {
    font-size: 15px;
    font-weight: bold;
    margin-bottom: 24px;
    letter-spacing: 0.04em;
    background-image: none;
    padding-bottom: 0;
    border: none;
  }
}

.footer-accordion-block.is-active {
  background-image: url("../images/common/accordion_open.svg");
  background-position: right;
}

.footer-content {
  margin-top: 13px;
  display: inline-block;
}

@media (min-width: 1044px) {
  .footer-content {
    font-family: 'brown', 'Lucida Grande';
    font-weight: normal !important;
    letter-spacing: 0.2em;
    font-weight: bold !important;
    font-size: 12px;
    display: block;
    letter-spacing: 0.2em;
    margin-top: 0;
  }
  .footer-content + .footer-content {
    margin-top: 15px;
  }
}

.footer-content::before {
  content: "";
  background-image: url("../images/common/border_arrow_right.svg");
  padding-left: 20px;
  vertical-align: middle;
}

@media (min-width: 1044px) {
  .footer-content::before {
    background: none;
    padding: 0;
  }
}

@media (min-width: 1044px) {
  .footer-hight {
    line-height: 1.385;
  }
}

.footer-block-part {
  font-size: 12px;
  vertical-align: middle;
  padding-left: 16px;
  position: relative;
}

@media (max-width: 1043px) {
  .footer-block-part {
    display: block;
    font-size: 13px;
    margin-top: 11px;
    letter-spacing: 0.01em;
  }
}

@media (min-width: 1044px) {
  .footer-block-part {
    display: inline-block;
  }
}

.footer-block-part::before {
  content: "";
  position: absolute;
  background-image: url("../images/common/arrow_right.svg");
  background-size: contain;
  background-repeat: no-repeat;
  top: 2px;
  left: 0;
  width: 10px;
  height: 10px;
  display: block;
}

.footer-block-part + .footer-block-part {
  margin-top: 10px;
}

@media (min-width: 1044px) {
  .footer-block-part + .footer-block-part {
    margin-top: 0;
  }
}

.footer-block-part-local {
  margin-top: 6px;
}

@media (min-width: 1044px) {
  .footer-block-part-local {
    margin-top: 0;
  }
}

.footer-link {
  width: 100%;
}

@media (min-width: 1044px) {
  .footer-link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 0 14px;
  }
}

.footer-icon {
  width: 100%;
  max-width: 47px;
}

.footer-icon + .footer-icon {
  margin-left: 14px;
}

@media (min-width: 1044px) {
  .footer-icon {
    max-width: 36px;
  }
}

.footer-icon-column {
  display: grid;
  margin-top: 36px;
}

@media (min-width: 1044px) {
  .footer-icon-column {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 20px;
    margin-top: 0;
  }
}

.footer-icon-block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  margin-top: 12px;
}

@media (min-width: 1044px) {
  .footer-icon-block {
    -webkit-box-pack: normal;
        -ms-flex-pack: normal;
            justify-content: normal;
    margin-top: 0;
  }
}

.footer-icon-heading {
  font-size: 16px;
}

.footer-multi {
  padding: 0 8px;
  margin-top: 10px;
  display: inline-block;
  font-size: 13px;
}

.footer-multi + .footer-multi {
  border-left: 1px solid #fff;
}

.footer-multi:first-child {
  border-left: 1px solid #fff;
}

.footer-multi:last-child {
  padding: 0 4px;
  border-right: 1px solid #fff;
}

.footer-multi.has-icon {
  position: relative;
  padding-right: 20px;
}

.footer-multi.has-icon [class*="icon-"] {
  position: absolute;
  right: 5px;
  top: 0;
}

@media (min-width: 1044px) {
  .footer-multi {
    font-size: 12px;
    display: inline-block;
    padding: 0 0 0 4px;
  }
}

.footer-multi-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
}

@media (min-width: 1044px) {
  .footer-multi-wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

.footer-multi-block {
  margin-top: 14px;
  width: 100%;
}

@media (max-width: 1043px) {
  .footer-multi-block {
    margin-top: 34px;
  }
}

.footer-multi-block + .footer-multi-block {
  margin-top: 9px;
}

.footer-logo {
  max-width: 208px;
  margin: auto;
}

@media (min-width: 1044px) {
  .footer-logo {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
  }
}

@media (min-width: 1044px) {
  .footer-logo-block {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    width: 208px;
  }
}

.footer-copyright {
  margin-top: 24px;
  text-align: center;
}

@media (min-width: 1044px) {
  .footer-copyright {
    font-size: 12px;
    text-align: center;
    margin-top: 24px;
  }
}

@media (min-width: 1044px) {
  .footer-blog {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    border: 1px solid #808080;
    padding: 20px 48px 17px 28px;
    margin: auto;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .footer-blog-link {
    width: 270px;
  }
  .footer-blog-ttl {
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 0.06em;
    min-width: 110px;
  }
  .footer-blog-ttl.red {
    color: #E02020;
    margin: 0;
  }
  .footer-blog-wrap {
    display: inline-block;
    padding: 10px 18px 11px 25px;
  }
  .footer-blog-txt {
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.02em;
    line-height: 1.8;
  }
  .footer-blog-txt-middle {
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.02em;
    width: calc(100% - 110px);
  }
}

@media (min-width: 1044px) {
  .footer-info-block {
    max-width: 556px;
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 16px;
  }
}

.footer-instagram {
  padding: 21px 0 46px;
  background-color: #F8F5EB;
}

@media (min-width: 1044px) {
  .footer-instagram {
    padding: 35px 20px 70px;
  }
}

.footer-instagram-logo {
  width: 162px;
  margin: 0 auto;
}

.footer-instagram-img {
  margin-top: 14px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  overflow: hidden;
}

@media (min-width: 1044px) {
  .footer-instagram-img {
    margin: 24px auto 0;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    max-width: 1044px;
  }
}

.footer-instagram-img img {
  width: 92px;
}

@media (min-width: 1044px) {
  .footer-instagram-img img {
    width: 115px;
  }
}

@media (min-width: 1044px) {
  .footer-add {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

.footer-add-inner {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
}

@media (min-width: 1044px) {
  .footer-add-inner {
    max-width: 637px;
  }
}

.footer-add-inner:after {
  content: "";
  width: 82px;
  height: 14px;
  border-bottom: solid 1px;
  border-right: solid 1px;
  position: absolute;
  bottom: 2px;
  right: 15px;
  -webkit-transform: skew(38deg);
          transform: skew(38deg);
  text-align: center;
}

@media (min-width: 1044px) {
  .footer-add-inner:after {
    width: 98px;
    height: 16px;
    bottom: 0;
    right: 0;
  }
}

@media (min-width: 1324px) {
  .footer-add-ttl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

.footer-add-txt {
  margin: 8px 0 10px;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.5;
}

@media (min-width: 1044px) {
  .footer-add-txt {
    font-size: 14px;
  }
}

.footer-add-membership {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  background-color: #4C4948;
  padding: 10px 15px;
  -webkit-transition: all .3s;
  transition: all .3s;
  min-height: 142px;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}

@media (max-width: 350px) {
  .footer-add-membership {
    min-height: 110px;
  }
}

@media (min-width: 768px) {
  .footer-add-membership:hover {
    opacity: 0.7;
  }
}

@media (min-width: 1044px) {
  .footer-add-membership {
    width: 50%;
    padding: 15px 30px 20px 10px;
  }
}

@media (min-width: 1324px) {
  .footer-add-membership {
    padding: 15px 62px 20px 44px;
  }
}

.footer-add-membership-img {
  width: calc(100% - 243px);
  min-width: 80px;
  max-width: 130px;
}

@media (min-width: 1044px) {
  .footer-add-membership-img {
    width: 138px;
    margin-right: 46px;
  }
}

.footer-add-membership-txt {
  color: #fff;
  width: 220px;
  margin-left: 23px;
}

@media (min-width: 1044px) {
  .footer-add-membership-txt {
    width: calc(100% - 197px);
    max-width: 445px;
    margin-left: 0;
  }
}

.footer-add-membership-ttl {
  display: inline-block;
  font-size: 22px;
  font-weight: bold;
  width: 100%;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
}

@media (max-width: 350px) {
  .footer-add-membership-ttl {
    font-size: 18px;
  }
}

.footer-add-membership-ttl-sub {
  display: inline-block;
  font-size: 12px;
  font-weight: bold;
}

@media (min-width: 1044px) {
  .footer-add-membership-ttl-sub {
    font-size: 14px;
  }
}

.footer-add-membership .footer-add-inner:after {
  border-color: #fff;
}

.footer-add-app {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  background-color: #BFBFBF;
  padding: 10px 15px;
  position: relative;
  -webkit-transition: all .3s;
  transition: all .3s;
  min-height: 142px;
}

@media (max-width: 350px) {
  .footer-add-app {
    min-height: 110px;
  }
}

@media (min-width: 768px) {
  .footer-add-app:hover {
    opacity: 0.7;
  }
}

@media (min-width: 1044px) {
  .footer-add-app {
    width: 50%;
    padding: 15px 30px 20px 10px;
  }
}

@media (min-width: 1324px) {
  .footer-add-app {
    padding: 15px 62px 20px 44px;
  }
}

.footer-add-app-img {
  width: calc(100% - 243px);
  min-width: 80px;
  max-width: 130px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}

@media (min-width: 1044px) {
  .footer-add-app-img {
    width: 138px;
  }
}

.footer-add-app-txt {
  color: #333;
  margin-left: 23px;
  width: 223px;
}

@media (min-width: 1044px) {
  .footer-add-app-txt {
    margin-left: 29px;
    width: calc(100% - 178px);
    max-width: 447px;
  }
}

.footer-add-app-ttl {
  display: inline-block;
  font-size: 18px;
  font-weight: bold;
}

@media (max-width: 350px) {
  .footer-add-app-ttl {
    font-size: 16px;
  }
}

@media (min-width: 1044px) {
  .footer-add-app-ttl {
    font-size: 17px;
  }
}

@media (min-width: 1324px) {
  .footer-add-app-ttl {
    margin-left: 10px;
  }
}

.footer-add-app-ttl-sub {
  font-size: 12px;
}

@media (min-width: 1044px) {
  .footer-add-app-ttl-sub {
    font-size: 14px;
  }
}

.footer-add-app-ttl-en {
  display: inline-block;
  font-size: 18px;
  font-weight: bold;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  letter-spacing: 0.06em;
}

@media (max-width: 350px) {
  .footer-add-app-ttl-en {
    font-size: 16px;
  }
}

@media (min-width: 1044px) {
  .footer-add-app-ttl-en {
    font-size: 22px;
  }
}

@media (min-width: 1044px) {
  .footer-add-app .footer-add-inner {
    margin-right: auto;
  }
}

.footer-add-app .footer-add-inner:after {
  border-color: #666464;
}

.footer-scroll {
  z-index: 30;
  width: 48px;
  height: 48px;
  padding: 6px;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  border: 1px solid #fff;
  color: #fff;
  font-family: 'Barlow';
  font-size: 13px;
  position: absolute;
  top: 690px;
  right: 15px;
}

@media (min-width: 1044px) {
  .footer-scroll {
    padding: 5px;
    width: 38px;
    height: 38px;
    font-size: 11px;
    top: 420px;
    right: 0;
  }
}

@media (min-width: 1170px) {
  .footer-scroll {
    top: 420px;
    right: -53px;
  }
}

.giftcard {
  margin-top: 45px;
}

@media (min-width: 768px) {
  .giftcard {
    margin-top: 75px;
  }
}

.giftcard-ttl-wrap {
  margin-bottom: 20px;
}

.giftcard-content-wrap + .giftcard-content-wrap {
  margin-top: 60px;
}

@media (min-width: 768px) {
  .giftcard-content-wrap:last-child {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-top: 75px;
  }
}

@media (min-width: 768px) {
  .giftcard-content-wrap .common-txt-note {
    margin-top: 70px;
  }
}

@media (min-width: 768px) {
  .giftcard-content-text {
    width: 100%;
    max-width: 480px;
    margin-right: 50px;
  }
}

.giftcard-content-img {
  margin-bottom: 25px;
}

@media (min-width: 768px) {
  .giftcard-content-img {
    width: calc((100% - 115px)/ 2);
  }
}

.giftcard-content-gray {
  background-color: #EFEFEF;
  padding: 50px 15px 87px 15px;
}

.giftcard-img {
  width: 100%;
  max-width: 223px;
  margin: 42px auto;
}

@media (min-width: 768px) {
  .giftcard-img {
    width: 100%;
    max-width: 285px;
    margin: 0;
  }
}

.giftcard-block + .giftcard-block {
  margin-top: 50px;
}

@media (min-width: 768px) {
  .giftcard-block + .giftcard-block {
    margin-top: 70px;
  }
}

.giftcard-block .btn-link {
  margin-top: 45px;
}

@media (min-width: 768px) {
  .giftcard-block .btn-link {
    margin-top: 70px;
  }
}

.giftcard-block .btn-black {
  padding: 12px 26px 14px 8px;
}

@media (min-width: 768px) {
  .giftcard-block .question {
    padding-left: 40px;
  }
}

.giftcard-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

@media (min-width: 768px) {
  .giftcard-flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    align-items: flex-end;
  }
}

@media (min-width: 768px) {
  .giftcard-flex .square-block-wrap {
    margin-top: 35px;
    margin-right: 15px;
    width: calc(100% - 300px);
  }
}

.giftcard-list {
  margin-top: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}

@media (min-width: 768px) {
  .giftcard-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin-top: 15px;
    margin-bottom: -10px;
    margin-right: -36px;
  }
}

.giftcard-list li {
  width: calc((100% - 15px)/2);
  background-color: #fff;
  color: #666464;
  border: 1px solid #BFBFBF;
  padding: 17px 21px 19px 21px;
  text-align: center;
}

@media (min-width: 768px) {
  .giftcard-list li {
    width: 154px;
    padding: 17px 10px 19px;
    margin-right: 36px;
    margin-bottom: 10px;
  }
  .giftcard-list li:nth-child(2n) {
    margin-right: 36px;
  }
}

.giftcard-list li:nth-of-type(n+3) {
  margin-top: 10px;
}

@media (min-width: 768px) {
  .giftcard-list li:nth-of-type(n+3) {
    margin-top: 0;
  }
}

.giftcard-list li:nth-child(odd) {
  margin-right: 15px;
}

@media (min-width: 768px) {
  .giftcard-list li:nth-child(odd) {
    margin-right: 36px;
  }
}

.giftcard-list li span {
  display: block;
  font-size: 23px;
  font-weight: bold;
  line-height: 1.13;
  margin-top: 5px;
  color: #333;
  letter-spacing: 0;
}

@media (min-width: 768px) {
  .giftcard .index-mv {
    text-align: center;
  }
}

.giftcard .index-article-list-wrap {
  padding: 50px 0 87px;
}

.giftcard .common-wrap {
  padding: 40px 15px 60px 15px;
}

@media (min-width: 768px) {
  .giftcard .common-wrap {
    padding: 25px 15px 80px 15px;
  }
}

.giftcard .index-inner .heading-4-square {
  margin-bottom: 15px;
}

.giftcard .common-txt-note-wrap {
  margin-top: 15px;
}

@media (min-width: 768px) {
  .giftcard .common-txt-note-wrap {
    margin-right: 10px;
  }
}

@media (min-width: 768px) {
  .giftcard .common-txt.normal {
    text-align: center;
  }
}

@media (min-width: 768px) {
  .giftcard .common-ttl-wrap {
    margin-bottom: 30px;
  }
}

.giftcard-square-block {
  margin-block: 40px;
}

@media (min-width: 768px) {
  .giftcard-square-block {
    margin-bottom: 0;
  }
}

.header-inner {
  height: 100%;
  width: 100%;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
}

.header-inner-wrap {
  margin: 0 auto;
  position: relative;
}

@media (min-width: 1044px) {
  .header-inner-wrap {
    max-width: 1028px;
    height: 99px;
  }
}

@media (min-width: 1190px) {
  .header-inner-wrap {
    max-width: 1120px;
  }
}

.header-inner.is-header-open .header-hamburger-border span:nth-child(1) {
  top: 50%;
  -webkit-transform: translateY(-50%) rotate(-45deg);
          transform: translateY(-50%) rotate(-45deg);
}

.header-inner.is-header-open .header-hamburger-border span:nth-child(2) {
  opacity: 0;
}

.header-inner.is-header-open .header-hamburger-border span:nth-child(3) {
  top: 50%;
  -webkit-transform: translateY(-50%) rotate(45deg);
          transform: translateY(-50%) rotate(45deg);
}

.header-sp {
  background-color: #000;
  padding: 8px 8px 9px;
  position: relative;
  z-index: 80;
  text-align: center;
  border-bottom: 1px solid #808080;
}

.header-hamburger {
  cursor: pointer;
  width: 44px;
  height: 43px;
  -webkit-transition: .3s;
  transition: .3s;
  background-color: #4C4948;
  position: absolute;
  top: 0;
  right: 0;
}

.header-hamburger-border {
  position: absolute;
  width: 24px;
  height: 20px;
  display: block;
  margin: 0 auto;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

.header-hamburger-border > span {
  display: block;
  width: 100%;
  height: 2px;
  background-color: #fff;
  position: absolute;
  right: 0;
  -webkit-transition: .3s;
  transition: .3s;
}

.header-hamburger-border > span:nth-child(1) {
  top: 0;
}

.header-hamburger-border > span:nth-child(2) {
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.header-hamburger-border > span:nth-child(3) {
  bottom: 0;
}

.header-logo {
  display: inline-block;
  width: 104px;
  height: 26px;
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 1044px) {
  .header-logo {
    width: 173px;
    height: auto;
    margin: 34px 7px 26px;
  }
}

@media (min-width: 1099px) {
  .header-logo {
    margin: 29px 7px 26px;
  }
}

@media (min-width: 768px) {
  .header-logo:hover {
    opacity: 0.7;
  }
}

.header-content {
  display: none;
  padding: 74px 20px 30px;
  background-color: #333;
  position: absolute;
  top: 0;
  z-index: 50;
  overflow-y: auto;
  height: 100vh;
  width: 100vw;
}

@media (min-width: 1044px) {
  .header-content {
    display: block;
    padding: 0;
    overflow: visible;
    width: 100%;
    height: auto;
  }
}

@media (min-width: 1044px) {
  .header-menu {
    padding: 0 10px;
    border: none;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    background-color: #000;
    margin: 0 calc(50% - 50vw);
    width: 100vw;
    gap: 28px;
    padding-inline: 15px;
  }
}

@media (min-width: 1190px) {
  .header-menu {
    gap: 42px;
  }
}

.header-menu > li {
  border-bottom: 1px solid #808080;
}

.header-menu > li:first-of-type {
  border-top: 1px solid #808080;
}

@media (min-width: 1044px) {
  .header-menu > li:first-of-type {
    border: none;
  }
}

@media (min-width: 1044px) {
  .header-menu > li {
    border: none;
    cursor: pointer;
  }
}

@media (min-width: 1044px) {
  .header-menu > li:hover > .header-menu-btn {
    color: #B18710;
  }
  .header-menu > li:hover > .header-menu-sub-wrap {
    height: auto;
    opacity: 1;
    visibility: visible;
  }
}

.header-menu-btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 100%;
  color: #D9D9D9;
  padding: 16px 0;
  font-size: 15px;
  -webkit-transition: .3s;
  transition: .3s;
  letter-spacing: 0.04em;
}

@media (min-width: 1044px) {
  .header-menu-btn {
    color: #fff;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding: 10px 0 20px;
  }
}

.header-menu-btn.accordion-block.is-active .header-accordion-icon::after {
  -webkit-transform: translateY(-50%) rotate(0);
          transform: translateY(-50%) rotate(0);
}

.header-menu-sub {
  border-top: 1px solid #808080;
  padding: 18px 10px;
}

@media (min-width: 1044px) {
  .header-menu-sub {
    padding: 0;
    border: none;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 1024px;
    margin: 0 auto;
  }
  .header-menu-sub [class*="icon-"] {
    font-size: 12px;
    margin: 0 3px;
    color: #808080;
  }
  .header-menu-sub.equality-list {
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

.header-menu-sub-wrap {
  display: none;
}

@media (min-width: 1044px) {
  .header-menu-sub-wrap {
    -webkit-transition: .3s;
    transition: .3s;
    display: block;
    height: 0;
    opacity: 0;
    visibility: hidden;
    padding: 16px 10px;
    background-color: #323232;
    position: absolute;
    top: 100%;
    left: 0;
    margin: 0 calc(50% - 50vw);
    width: 100vw;
  }
}

.header-menu-sub > li {
  min-width: 73px;
}

.header-menu-sub > li + li {
  padding-top: 15px;
}

@media (min-width: 1044px) {
  .header-menu-sub > li + li {
    padding: 0;
    padding-left: 30px;
  }
}

.header-menu-sub-link {
  font-family: 'brown', 'Lucida Grande';
  font-weight: normal !important;
  letter-spacing: 0.2em;
  color: #fff;
  font-size: 13px;
  letter-spacing: 0.02em;
}

@media (min-width: 1044px) {
  .header-menu-sub-link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-transition: .3s;
    transition: .3s;
    font-size: 12px;
    letter-spacing: 0.2em;
  }
  .header-menu-sub-link:hover {
    color: #B18710;
  }
}

.header-external {
  margin-top: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 10px;
}

@media (min-width: 1044px) {
  .header-external {
    margin-top: 0;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    border-left: 1px solid #9b9b9b;
    border-right: 1px solid #9b9b9b;
    gap: 0;
  }
}

@media (min-width: 1044px) {
  .header-external-wrap {
    width: 1028px;
    position: absolute;
    top: 22px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

@media (min-width: 1190px) {
  .header-external-wrap {
    width: 1120px;
  }
}

.header-external-link {
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  padding: 8px 4px;
  color: #fff;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border: 1px solid #fff;
  -webkit-transition: .3s;
  transition: .3s;
  text-align: center;
  font-size: 12px;
  letter-spacing: 0;
}

@media (min-width: 1044px) {
  .header-external-link {
    padding: 0 10px 0 12px;
    border: none;
    letter-spacing: 0.02em;
  }
}

.header-external-link span {
  font-size: 11px;
}

.header-external-link:nth-of-type(1) {
  width: calc(50% - 5px);
  background-color: #000;
}

@media (min-width: 1044px) {
  .header-external-link:nth-of-type(1) {
    display: inline-block;
    border-right: 1px solid #9b9b9b;
  }
}

.header-external-link:nth-child(2) {
  width: calc(50% - 5px);
  background-color: #000;
}

@media (min-width: 1044px) {
  .header-external-link:nth-child(2) {
    width: auto;
    background-color: transparent;
  }
}

.header-external-link:nth-child(3) {
  width: calc(50% - 5px);
  background-color: #000;
}

@media (min-width: 1044px) {
  .header-external-link:nth-child(3) {
    margin-left: 0;
    width: auto;
    background-image: none;
  }
}

.header-external-link:nth-child(4) {
  padding: 16px;
  width: calc(50% - 5px);
  background-color: #000;
}

@media (min-width: 1044px) {
  .header-external-link:nth-child(4) {
    padding: 0 10px 0 12px;
    margin-top: 0;
    width: auto;
    background-image: none;
    border-left: 1px solid #9b9b9b;
  }
}

.header-external-link:nth-child(4) [class*="icon-"] {
  font-size: 11px;
  margin-left: 6px;
}

@media (min-width: 1044px) {
  .header-external-link:hover {
    color: #B18710;
  }
}

@media (max-width: 360px) {
  .header-external-link {
    padding: 8px 2px;
  }
  .header-external-link span {
    font-size: 10px;
  }
  .header-external-link:nth-child(2) {
    width: calc(50% - 3px);
  }
  .header-external-link:nth-child(3) {
    width: calc(50% - 3px);
    margin-left: 6px;
  }
}

.header-accordion-icon {
  position: relative;
  width: 20px;
  height: 20px;
}

.header-accordion-icon::before, .header-accordion-icon::after {
  content: '';
  display: block;
  width: 20px;
  height: 1px;
  background: #fff;
  position: absolute;
  right: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.header-accordion-icon::after {
  -webkit-transform: translateY(-50%) rotate(90deg);
          transform: translateY(-50%) rotate(90deg);
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.header-search {
  width: 44px;
  height: 43px;
  color: #fff;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-transition: .3s;
  transition: .3s;
  border-left: 1px solid #B2B2B2;
  text-align: center;
}

@media (min-width: 1044px) {
  .header-search {
    font-family: 'brown-bold', 'Lucida Grande';
    font-weight: normal !important;
    letter-spacing: 0.2em;
    height: auto;
    width: auto;
    border: none;
    font-size: 12px;
    letter-spacing: 0.02em;
    padding: 0 12px 0 26px;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    border-right: 1px solid #B2B2B2;
  }
}

.header-search [class*="icon-"] {
  font-size: 16px;
}

@media (min-width: 768px) {
  .header-search [class*="icon-"] {
    font-size: 14px;
    margin-right: 5px;
  }
}

.header-search-wrap {
  position: absolute;
  top: 0;
  right: 44px;
  z-index: 82;
}

@media (min-width: 1044px) {
  .header-search-wrap {
    top: 22px;
    left: 25px;
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
  }
}

@media (min-width: 1044px) {
  .header-search-wrap span {
    font-size: 12px;
    font-family: 'brown', 'Lucida Grande';
    font-weight: normal !important;
    letter-spacing: 0.2em;
  }
}

@media (min-width: 1044px) {
  .icon-search {
    position: absolute;
    left: 10px;
    top: 0;
  }
}

.modal-search-title {
  font-size: 24px;
  margin-bottom: 25px;
  text-align: center;
  letter-spacing: 0.2em;
}

@media (min-width: 768px) {
  .modal-search-title {
    margin-bottom: 28px;
  }
}

.modal-search-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.modal-search-input {
  width: calc(100% - 70px);
  border-top: 1px solid #B2B2B2;
  border-left: 1px solid #B2B2B2;
  border-bottom: 1px solid #B2B2B2;
  color: #333;
  padding: 8px 12px;
}

@media (min-width: 1044px) {
  .modal-search-input {
    max-width: 500px;
  }
}

.modal-search-input::-webkit-input-placeholder {
  color: #808080;
}

.modal-search-input::-moz-placeholder {
  color: #808080;
}

.modal-search-input:-ms-input-placeholder {
  color: #808080;
}

.modal-search-input::-ms-input-placeholder {
  color: #808080;
}

.modal-search-input::placeholder {
  color: #808080;
}

.modal-search-input:focus {
  outline: none;
}

.modal-search-btn {
  padding: 3px 10px;
  width: 70px;
  background-color: #333;
  color: #fff;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.modal-search-btn [class*="icon-"] {
  font-size: 24px;
}

@media (min-width: 1044px) {
  .modal-search-btn [class*="icon-"] {
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
}

.modal-header .modaal-container .modaal-content-container {
  padding: 39px 12px 65px;
}

@media (min-width: 1044px) {
  .modal-header .modaal-container .modaal-content-container {
    padding: 45px 20px 78px;
  }
}

/* ティザー */
.holiday2023-teaser-contents {
  width: 100%;
  min-height: 100vh;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media (min-width: 768px) {
  .holiday2023-teaser-contents.nomal {
    min-height: 1000px;
  }
}

.holiday2023-teaser-contents.holiday2023-teaser-front {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 100;
}

.holiday2023-teaser-inner {
  max-width: calc(100% - 50px);
}

.holiday2023-teaser-movie {
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 175.6007393vh;
  /* 例：16:9 の幅→16 ÷ 9＝ 177.77% */
  height: 56.9473684vw;
  /* 例：16:9の幅 → 9 ÷ 16 = 56.25% */
  min-height: 100%;
  min-width: 100%;
}

.holiday2023-teaser-logo {
  margin: 0 auto;
  width: 380px;
  max-width: 100%;
  -webkit-animation: fadeIn 3s;
          animation: fadeIn 3s;
}

.holiday2023-teaser-input {
  margin-top: 25px;
  padding: 12px 10px 12px 22px;
  height: 64px;
  width: 100%;
  background-color: #fff;
  -webkit-box-shadow: 0 0 6px #000;
          box-shadow: 0 0 6px #000;
  border-radius: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

@media (min-width: 768px) {
  .holiday2023-teaser-input {
    padding: 20px;
  }
}

.holiday2023-teaser-input-wrap {
  opacity: 0;
  width: 600px;
  max-width: 100%;
}

.holiday2023-teaser-input-wrap.is-input-open {
  -webkit-animation: fadeUp;
          animation: fadeUp;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  -webkit-animation-duration: .5s;
          animation-duration: .5s;
}

.holiday2023-teaser-input-txt {
  font-size: 20px;
  line-height: calc(24/20);
}

.holiday2023-teaser-input-icon {
  margin-left: 8px;
  width: 20px;
}

.holiday2023-teaser-input-icon.is-scaleDown {
  -webkit-animation: scaleAnimation;
          animation: scaleAnimation;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-delay: 1s;
          animation-delay: 1s;
}

.holiday2023-teaser-answer {
  margin-top: 25px;
  margin-top: 20px;
  width: 100%;
  background-color: #fff;
  -webkit-box-shadow: 0 0 6px #000;
          box-shadow: 0 0 6px #000;
  border-radius: 10px 15px;
  padding: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

@media (min-width: 768px) {
  .holiday2023-teaser-answer {
    padding: 20px;
  }
}

.holiday2023-teaser-answer-wrap {
  opacity: 0;
  width: 600px;
  max-width: 100%;
}

.holiday2023-teaser-answer-icon {
  width: 60px;
}

@media (min-width: 768px) {
  .holiday2023-teaser-answer-icon {
    width: 80px;
  }
}

.holiday2023-teaser-answer-txt {
  width: calc(100% - 80px);
  margin-left: 20px;
  font-family: 'Kiwi Maru', "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial, sans-serif;
  font-size: 14px;
  line-height: calc(24/16);
}

@media (min-width: 768px) {
  .holiday2023-teaser-answer-txt {
    width: calc(100% - 100px);
    font-size: 16px;
  }
}

.holiday2023-teaser-site-contents {
  display: none;
  width: 100%;
  min-height: 100vh;
}

.holiday2023-teaser-site-contents.holiday2023-teaser-front {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 100;
}

.holiday2023-teaser-site-inner {
  width: 100%;
  height: 100%;
  background: #000;
  background-size: 100% 100%;
  opacity: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.holiday2023-teaser-site-logo {
  width: 500px;
  max-width: calc(100% - 50px);
}

.holiday2023-teaser-site-btn {
  margin-top: 50px;
  text-align: center;
}

.holiday2023-teaser-typing-txt span {
  display: none;
}

.holiday2023-teaser-typing-txt::after {
  -webkit-animation: typinganime .8s ease infinite;
          animation: typinganime .8s ease infinite;
}

.is-move.holiday2023-teaser-answer-wrap {
  -webkit-animation: fadeUp;
          animation: fadeUp;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  -webkit-animation-duration: .5s;
          animation-duration: .5s;
}

.is-logo-move .holiday2023-teaser-inner .holiday2023-teaser-input {
  display: none;
}

.is-logo-move .holiday2023-teaser-inner .holiday2023-teaser-answer {
  display: none;
}

.is-site-open.holiday2023-teaser-front.holiday2023-teaser-site-contents {
  display: block;
}

.is-site-open.holiday2023-teaser-front.holiday2023-teaser-site-contents .holiday2023-teaser-site-inner {
  -webkit-animation: fadeIn;
          animation: fadeIn;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  -webkit-animation-duration: 5s;
          animation-duration: 5s;
}

@-webkit-keyframes bggradient {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

@keyframes bggradient {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

@-webkit-keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@-webkit-keyframes fadeUp {
  from {
    opacity: 0;
    -webkit-transform: translateY(50px);
            transform: translateY(50px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes fadeUp {
  from {
    opacity: 0;
    -webkit-transform: translateY(50px);
            transform: translateY(50px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@-webkit-keyframes scaleAnimation {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  50% {
    -webkit-transform: scale(0.8);
            transform: scale(0.8);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

@keyframes scaleAnimation {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  50% {
    -webkit-transform: scale(0.8);
            transform: scale(0.8);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

@-webkit-keyframes typinganime {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes typinganime {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

/* GIFT */
[class^="holiday_2023_"] h2.holiday2023-gift-ttl {
  margin-bottom: 0;
  padding: 0px;
  text-align: inherit;
  border-top: none;
  border-bottom: none;
  letter-spacing: inherit;
}

.holiday_2023_chat_bny .l-header {
  background-color: #000;
}

.holiday2023-gift-container {
  background: url(../images/holiday2023/holiday_bg_common.png) no-repeat;
  background-color: rgba(255, 255, 255, 0.2);
  background-blend-mode: lighten;
  background-size: 100% 100%;
  overflow: hidden;
  position: relative;
}

@media (min-width: 768px) {
  .holiday2023-gift-container a {
    -webkit-transition: .3s;
    transition: .3s;
  }
}

@media (min-width: 768px) {
  .holiday2023-gift-container a:hover {
    opacity: 0.7;
  }
}

.holiday2023-gift-container .js-fade {
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateY(50px);
          transform: translateY(50px);
  -webkit-transition: opacity 1.5s,visibility 1s, -webkit-transform 1s;
  transition: opacity 1.5s,visibility 1s, -webkit-transform 1s;
  transition: opacity 1.5s,visibility 1s, transform 1s;
  transition: opacity 1.5s,visibility 1s, transform 1s,-webkit-transform 1s;
}

.holiday2023-gift-container .js-fade.scroll {
  opacity: 1;
  visibility: visible;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

.holiday2023-gift-scroll {
  overflow: hidden;
}

.holiday2023-gift-scroll-content {
  position: relative;
}

.holiday2023-gift-scroll-content .swiper-pagination {
  color: red;
  position: absolute;
  left: 50%;
  bottom: 10px;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  z-index: 1;
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-content .swiper-pagination {
    display: none;
  }
}

.holiday2023-gift-scroll-content .swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  background-color: #B7B7B7;
  border-radius: 50%;
  display: block;
}

.holiday2023-gift-scroll-content .swiper-pagination-bullet:not(:last-child) {
  margin-right: 30px;
}

.holiday2023-gift-scroll-content .swiper-pagination-bullet-active {
  background-color: #D61618;
}

.holiday2023-gift-inner {
  padding: 15px 20px 40px;
  position: relative;
  z-index: 1;
}

@media (min-width: 768px) {
  .holiday2023-gift-inner {
    padding-top: 20px;
  }
}

.holiday2023-gift-scroll {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 500%;
  overflow: hidden;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
}

.holiday2023-gift-scroll-block {
  width: 500%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}

.holiday2023-gift-scroll-item {
  width: 100%;
  overflow: hidden;
  position: relative;
}

.holiday2023-gift-scroll-item:before {
  opacity: 0.2;
  display: none;
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-item:before {
    opacity: 0.3;
  }
}

.holiday2023-gift-scroll-item.show:before {
  display: block;
}

.holiday2023-gift-scroll-item.item-heart {
  background: url(../images/holiday2023/holiday_bg_heart.png) no-repeat;
  background-size: 100% 100%;
}

.holiday2023-gift-scroll-item.item-heart:before {
  content: '';
  position: absolute;
  background: url(../images/holiday2023/character_hearty.png) no-repeat;
  background-size: contain;
  width: 56vw;
  height: 72vw;
  top: 10px;
  left: -10px;
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-item.item-heart:before {
    top: -60px;
    left: -80px;
    width: 40.891vw;
    height: 51.9534vw;
    max-width: 520px;
    max-height: 660px;
  }
}

.holiday2023-gift-scroll-item.item-heart .holiday2023-gift-slide-character {
  position: relative;
}

.holiday2023-gift-scroll-item.item-heart .holiday2023-gift-slide-character:before {
  content: '';
  position: absolute;
  background: url(../images/holiday2023/holiday_heart_double.png) no-repeat;
  background-size: contain;
  width: 56px;
  height: 72px;
  top: -2px;
  right: 32px;
  -webkit-animation: rotate 6s ease-in-out infinite;
          animation: rotate 6s ease-in-out infinite;
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-item.item-heart .holiday2023-gift-slide-character:before {
    width: 96px;
    height: 141px;
    right: -85px;
    top: -70px;
  }
}

.holiday2023-gift-scroll-item.item-heart .holiday2023-gift-slide-character:after {
  content: '';
  position: absolute;
  background: url(../images/holiday2023/holiday_heart_single.png) no-repeat;
  background-size: contain;
  width: 30px;
  height: 29px;
  top: 126px;
  right: 32px;
  -webkit-animation: rotate 6s ease-in-out infinite;
          animation: rotate 6s ease-in-out infinite;
  -webkit-animation-delay: 2.8s;
          animation-delay: 2.8s;
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-item.item-heart .holiday2023-gift-slide-character:after {
    width: 74px;
    height: 73px;
    top: 300px;
    right: 0;
  }
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-item.item-heart .holiday2023-gift-slide-character-img {
    width: auto;
    -ms-flex-preferred-size: 37.105%;
        flex-basis: 37.105%;
    margin-top: 20px;
  }
}

.holiday2023-gift-scroll-item.item-heart .detail-block {
  background: url(../images/holiday2023/holiday_heart_blowing_sp.png) no-repeat;
  background-size: 100% 100%;
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-item.item-heart .detail-block {
    background: url(../images/holiday2023/holiday_heart_blowing_pc.png) no-repeat;
    background-size: 100% 100%;
  }
}

.holiday2023-gift-scroll-item.item-barba {
  background: url(../images/holiday2023/holiday_bg_barba.png) no-repeat;
  background-size: 100% 100%;
}

.holiday2023-gift-scroll-item.item-barba:before {
  content: '';
  position: absolute;
  background: url(../images/holiday2023/character_barba.png) no-repeat;
  background-size: contain;
  width: 56vw;
  height: 72vw;
  top: 20px;
  left: 0;
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-item.item-barba:before {
    top: -20px;
    left: -100px;
    width: 40.891vw;
    height: 51.9534vw;
    max-width: 520px;
    max-height: 660px;
  }
}

.holiday2023-gift-scroll-item.item-barba .holiday2023-gift-slide-character {
  position: relative;
}

.holiday2023-gift-scroll-item.item-barba .holiday2023-gift-slide-character:before {
  content: '';
  position: absolute;
  background: url(../images/holiday2023/holiday_barba_double.png) no-repeat;
  background-size: contain;
  width: 68px;
  height: 68px;
  top: -10px;
  right: 10px;
  -webkit-transform: rotate(-25deg);
          transform: rotate(-25deg);
  -webkit-animation: rotate_25 8s ease-in-out infinite;
          animation: rotate_25 8s ease-in-out infinite;
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-item.item-barba .holiday2023-gift-slide-character:before {
    -webkit-transform: rotate(0);
            transform: rotate(0);
    -webkit-animation: rotate 8s ease-in-out infinite;
            animation: rotate 8s ease-in-out infinite;
    width: 122px;
    height: 122px;
    top: -100px;
    right: -80px;
  }
}

.holiday2023-gift-scroll-item.item-barba .holiday2023-gift-slide-character:after {
  content: '';
  position: absolute;
  background: url(../images/holiday2023/holiday_barba_double.png) no-repeat;
  background-size: contain;
  width: 50px;
  height: 50px;
  top: 130px;
  right: 12px;
  -webkit-transform: rotate(125deg);
          transform: rotate(125deg);
  -webkit-animation: rotate_125 6s ease-in-out infinite;
          animation: rotate_125 6s ease-in-out infinite;
  -webkit-animation-delay: 2.8s;
          animation-delay: 2.8s;
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-item.item-barba .holiday2023-gift-slide-character:after {
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
    -webkit-animation: rotate_90 6s ease-in-out infinite;
            animation: rotate_90 6s ease-in-out infinite;
    width: 95px;
    height: 87px;
    top: 270px;
    right: 40px;
  }
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-item.item-barba .holiday2023-gift-slide-character-img {
    width: auto;
    -ms-flex-preferred-size: 37.105%;
        flex-basis: 37.105%;
    margin-bottom: 20px;
  }
}

.holiday2023-gift-scroll-item.item-barba .detail-block {
  background: url(../images/holiday2023/holiday_barba_blowing_sp.png) no-repeat;
  background-size: 100% 100%;
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-item.item-barba .detail-block {
    background: url(../images/holiday2023/holiday_barba_blowing_pc.png) no-repeat;
    background-size: 100% 100%;
  }
}

.holiday2023-gift-scroll-item.item-humor {
  background: url(../images/holiday2023/holiday_bg_humor.png) no-repeat;
  background-size: 100% 100%;
}

.holiday2023-gift-scroll-item.item-humor:before {
  content: '';
  position: absolute;
  background: url(../images/holiday2023/character_humor.png) no-repeat;
  background-size: contain;
  width: 56vw;
  height: 72vw;
  top: 65px;
  left: 0;
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-item.item-humor:before {
    top: 0px;
    left: -50px;
    width: 40.891vw;
    height: 51.9534vw;
    max-width: 520px;
    max-height: 660px;
  }
}

.holiday2023-gift-scroll-item.item-humor .holiday2023-gift-slide-character {
  position: relative;
}

.holiday2023-gift-scroll-item.item-humor .holiday2023-gift-slide-character:before {
  content: '';
  position: absolute;
  background: url(../images/holiday2023/holiday_heart_double_02.png) no-repeat;
  background-size: contain;
  width: 56px;
  height: 72px;
  top: 0px;
  right: 36px;
  -webkit-transform: rotate(15deg);
          transform: rotate(15deg);
  -webkit-animation: rotate_15 8s ease-in-out infinite;
          animation: rotate_15 8s ease-in-out infinite;
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-item.item-humor .holiday2023-gift-slide-character:before {
    width: 76px;
    height: 121px;
    top: -110px;
    right: -80px;
    -webkit-transform: rotate(0);
            transform: rotate(0);
    -webkit-animation: rotate 8s ease-in-out infinite;
            animation: rotate 8s ease-in-out infinite;
  }
}

.holiday2023-gift-scroll-item.item-humor .holiday2023-gift-slide-character:after {
  content: '';
  position: absolute;
  background: url(../images/holiday2023/holiday_heart_single.png) no-repeat;
  background-size: contain;
  width: 38px;
  height: 37px;
  top: 140px;
  right: 32px;
  -webkit-animation: rotate 6s ease-in-out infinite;
          animation: rotate 6s ease-in-out infinite;
  -webkit-animation-delay: 2.8s;
          animation-delay: 2.8s;
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-item.item-humor .holiday2023-gift-slide-character:after {
    width: 80px;
    height: 80px;
    top: 235px;
    right: 15px;
  }
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-item.item-humor .holiday2023-gift-slide-character-img {
    width: auto;
    -ms-flex-preferred-size: 37.105%;
        flex-basis: 37.105%;
  }
}

.holiday2023-gift-scroll-item.item-humor .detail-block {
  background: url(../images/holiday2023/holiday_humor_blowing_sp.png) no-repeat;
  background-size: 100% 100%;
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-item.item-humor .detail-block {
    background: url(../images/holiday2023/holiday_humor_blowing_pc.png) no-repeat;
    background-size: 100% 100%;
  }
}

.holiday2023-gift-scroll-item.item-postman {
  background: url(../images/holiday2023/holiday_bg_postman.png) no-repeat;
  background-size: 100% 100%;
}

.holiday2023-gift-scroll-item.item-postman:before {
  content: '';
  position: absolute;
  background: url(../images/holiday2023/character_postman.png) no-repeat;
  background-size: contain;
  width: 56vw;
  height: 72vw;
  top: 20px;
  left: 0;
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-item.item-postman:before {
    top: 0;
    left: -20px;
    width: 40.891vw;
    height: 51.9534vw;
    max-width: 520px;
    max-height: 660px;
  }
}

.holiday2023-gift-scroll-item.item-postman .holiday2023-gift-slide-character {
  position: relative;
}

.holiday2023-gift-scroll-item.item-postman .holiday2023-gift-slide-character:before {
  content: '';
  position: absolute;
  background: url(../images/holiday2023/holiday_postman_double_sp.png) no-repeat;
  background-size: contain;
  width: 93px;
  height: 98px;
  top: 0px;
  right: 20px;
  -webkit-animation: rotate 8s ease-in-out infinite;
          animation: rotate 8s ease-in-out infinite;
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-item.item-postman .holiday2023-gift-slide-character:before {
    background: url(../images/holiday2023/holiday_postman_double_pc.png) no-repeat;
    background-size: contain;
    width: 206px;
    height: 100px;
    top: -120px;
    right: -90px;
  }
}

.holiday2023-gift-scroll-item.item-postman .holiday2023-gift-slide-character:after {
  content: '';
  position: absolute;
  background: url(../images/holiday2023/holiday_postman_single.png) no-repeat;
  background-size: contain;
  width: 37px;
  height: 38px;
  top: 160px;
  right: 32px;
  -webkit-animation: rotate 6s ease-in-out infinite;
          animation: rotate 6s ease-in-out infinite;
  -webkit-animation-delay: 2.8s;
          animation-delay: 2.8s;
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-item.item-postman .holiday2023-gift-slide-character:after {
    width: 85px;
    height: 88px;
    top: 270px;
    right: 62px;
  }
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-item.item-postman .holiday2023-gift-slide-character-img {
    width: auto;
    -ms-flex-preferred-size: 37.105%;
        flex-basis: 37.105%;
  }
}

.holiday2023-gift-scroll-item.item-postman .detail-block {
  background: url(../images/holiday2023/holiday_postman_blowing_sp.png) no-repeat;
  background-size: 100% 100%;
}

@media (min-width: 768px) {
  .holiday2023-gift-scroll-item.item-postman .detail-block {
    background: url(../images/holiday2023/holiday_postman_blowing_pc.png) no-repeat;
    background-size: 100% 100%;
  }
}

.holiday2023-gift-ttl {
  margin: 0 calc(50% - 48vw);
  width: 96vw;
  position: relative;
  z-index: 1;
}

@media (min-width: 768px) {
  .holiday2023-gift-ttl {
    width: 100%;
    max-width: 532px;
    margin: 0 auto;
  }
}

.holiday2023-gift-ttl-main {
  background: url(../images/holiday2023/holiday_ttl_bg_common.png) no-repeat;
  background-size: 100% 100%;
  margin: -15px calc(50% - 50vw) 0;
  width: 100vw;
}

@media (min-width: 768px) {
  .holiday2023-gift-ttl-main {
    max-width: 980px;
    margin: 0 auto;
    width: 100%;
  }
}

.holiday2023-gift-ttl-main-inner {
  padding: 20px;
}

@media (min-width: 768px) {
  .holiday2023-gift-ttl-main-inner {
    padding: 30px 35px;
  }
}

.holiday2023-gift-ttl-main-block {
  background-color: #fff;
  border-radius: 25px;
  padding: 15px 6px 30px;
}

@media (min-width: 768px) {
  .holiday2023-gift-ttl-main-block {
    border-radius: 45px;
    padding: 15px 10px 18px;
  }
}

.holiday2023-gift-ttl-main-block.narrow {
  padding: 20px 10px;
}

@media (min-width: 768px) {
  .holiday2023-gift-ttl-main-block.narrow {
    padding: 30px 10px 14px;
  }
}

.holiday2023-gift-ttl-main-block .holiday2023-gift-ttl {
  margin: 0 calc(50% - 46vw);
  width: 92vw;
}

@media (min-width: 768px) {
  .holiday2023-gift-ttl-main-block .holiday2023-gift-ttl {
    margin: 0 auto;
    max-width: 532px;
    width: 100%;
  }
}

.holiday2023-gift-concept {
  margin-top: 20px;
}

@media (min-width: 768px) {
  .holiday2023-gift-concept {
    max-width: 980px;
    margin: 30px auto 0;
    width: 100%;
  }
}

.holiday2023-gift-concept-txt {
  letter-spacing: 0.02em;
  font-size: 12px;
  line-height: 1.66667;
}

@media (min-width: 768px) {
  .holiday2023-gift-concept-txt {
    font-size: 14px;
    line-height: 1.71429;
    text-align: center;
    line-height: 1.7;
  }
}

.holiday2023-gift-concept-txt:not(:first-child) {
  margin-top: 14px;
}

.holiday2023-gift-concept-txt.center {
  text-align: center;
}

.holiday2023-gift-concept-window {
  margin-top: 40px;
}

@media (min-width: 768px) {
  .holiday2023-gift-concept-window {
    margin-top: 80px;
  }
}

.holiday2023-gift-img-concept {
  max-width: 550px;
  margin: 5px auto 0;
}

@media (min-width: 768px) {
  .holiday2023-gift-img-concept {
    margin-top: 0;
  }
}

.holiday2023-gift-img-logo {
  width: 38.934vw;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .holiday2023-gift-img-logo {
    width: 226px;
  }
}

.holiday2023-gift-img-icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 10px;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin: 10px auto;
  width: 80%;
}

@media (min-width: 768px) {
  .holiday2023-gift-img-icon {
    width: 388px;
  }
}

.holiday2023-gift-img-icon li {
  width: calc((100% - 60px) / 4);
}

@media (min-width: 768px) {
  .holiday2023-gift-img-icon li {
    width: calc((100% - 138px) / 4);
  }
}

.holiday2023-gift-slide-character {
  position: relative;
  z-index: 1;
}

@media (min-width: 768px) {
  .holiday2023-gift-slide-character {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    max-width: 1000px;
    margin: 80px auto 20px;
  }
}

.holiday2023-gift-slide-character-img {
  margin: 0 auto;
  width: 44.8vw;
  max-width: 420px;
}

.holiday2023-gift-slide-character-img img {
  -webkit-animation: airy 8s ease 0s infinite;
          animation: airy 8s ease 0s infinite;
}

.holiday2023-gift-slide-character-detail {
  max-width: 500px;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .holiday2023-gift-slide-character-detail {
    -ms-flex-preferred-size: 62.178%;
        flex-basis: 62.178%;
    max-width: 100%;
    margin-left: 18px;
    margin-right: 0;
  }
}

.holiday2023-gift-slide-character-detail .detail-block-inner {
  padding: 25px 20px 20px;
}

@media (min-width: 768px) {
  .holiday2023-gift-slide-character-detail .detail-block-inner {
    padding: 40px 20px 40px 50px;
  }
}

.holiday2023-gift-slide-character-detail .detail-block-ttl {
  width: 220px;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .holiday2023-gift-slide-character-detail .detail-block-ttl {
    width: 312px;
  }
}

.holiday2023-gift-slide-character-detail .detail-block-txt {
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: 0.02em;
  margin-top: 12px;
  font-family: 'Kiwi Maru', "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial, sans-serif;
}

@media (min-width: 768px) {
  .holiday2023-gift-slide-character-detail .detail-block-txt {
    font-size: 18px;
    max-width: 500px;
    margin: 20px auto 0;
  }
}

.holiday2023-gift-slide-character-detail .more-link {
  margin-top: 10px;
  text-align: right;
}

@media (min-width: 768px) {
  .holiday2023-gift-slide-character-detail .more-link {
    text-align: left;
    margin-top: 95px;
    margin-left: 50px;
  }
}

.holiday2023-gift-slide-character-detail .more-link a {
  display: inline-block;
  width: 113px;
}

@media (min-width: 768px) {
  .holiday2023-gift-slide-character-detail .more-link a {
    width: 160px;
  }
}

.holiday2023-gift-slide-character-detail .more-link img {
  vertical-align: middle;
}

.holiday2023-gift-common-content {
  max-width: 1020px;
  margin: 60px auto 0;
}

@media (min-width: 768px) {
  .holiday2023-gift-common-content {
    margin-top: 130px;
  }
}

.holiday2023-gift-common-content:last-of-type {
  margin-bottom: 40px;
}

@media (min-width: 768px) {
  .holiday2023-gift-common-content:last-of-type {
    margin-bottom: 140px;
  }
}

.holiday2023-gift-common-content-inner {
  padding: 0 20px;
}

.holiday2023-gift-common-character-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 20px 10px;
}

@media (min-width: 768px) {
  .holiday2023-gift-common-character-link {
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    gap: 0 34px;
  }
}

.holiday2023-gift-common-character-link li {
  width: calc((100% - 10px) / 2);
}

@media (min-width: 768px) {
  .holiday2023-gift-common-character-link li {
    width: calc((100% - 72px) / 4);
  }
}

.holiday2023-gift-common-character-link a {
  display: block;
}

@media (min-width: 768px) {
  .holiday2023-gift-common-character-link a {
    position: relative;
    top: 0;
    -webkit-transition: all .3s;
    transition: all .3s;
  }
}

@media (min-width: 768px) {
  .holiday2023-gift-common-character-link a:hover {
    opacity: 1;
    top: -15px;
  }
}

.holiday2023-gift-detail-link {
  margin: 5px auto 0;
  max-width: 700px;
}

@media (min-width: 768px) {
  .holiday2023-gift-detail-link {
    margin-top: 15px;
  }
}

.holiday2023-gift-detail-link a {
  display: block;
}

.holiday2023-gift-detail-link-wrap {
  margin-top: 45px;
}

@media (min-width: 768px) {
  .holiday2023-gift-detail-link-wrap {
    margin-top: 100px;
  }
}

.holiday2023-gift-detail-inner {
  padding: 0 20px;
  max-width: 1020px;
  margin: 0 auto;
}

.holiday2023-gift-detail-section:not(:first-of-type) {
  margin-top: 40px;
}

.holiday2023-gift-item-container {
  position: relative;
  padding-top: 20.267vw;
  padding-bottom: 27.16vw;
}

.holiday2023-gift-item-container:before {
  content: "";
  position: absolute;
  background: url(../images/holiday2023/gift_head_img.png) no-repeat;
  background-size: 100%;
  width: 100%;
  height: 20.267vw;
  top: 0;
  left: 0;
}

.holiday2023-gift-item-container:after {
  content: "";
  position: absolute;
  background: url(../images/holiday2023/gift_footer_img.png) no-repeat;
  background-size: 100%;
  width: 100%;
  height: 27.16vw;
  bottom: 0;
  left: 0;
}

.holiday2023-gift-item-container .logo-wrap {
  width: 180px;
  margin: 10px auto 0;
}

@media (min-width: 768px) {
  .holiday2023-gift-item-container .logo-wrap {
    width: 290px;
    margin-top: 30px;
  }
}

.holiday2023-gift-item-container .main-ttl {
  margin: 20px auto 0;
  max-width: 740px;
}

@media (min-width: 768px) {
  .holiday2023-gift-item-container .main-ttl {
    margin-top: 40px;
  }
}

.holiday2023-gift-item-container .main-block {
  margin-top: 40px;
}

.holiday2023-gift-item-container .main-txt {
  font-size: 12px;
  line-height: 1.41667;
  text-align: center;
  font-size: 12px;
  font-weight: 700;
}

@media (min-width: 768px) {
  .holiday2023-gift-item-container .main-txt {
    font-size: 14px;
    line-height: 1.5;
  }
}

.holiday2023-gift-item-container .main-txt:not(:first-child) {
  margin-top: 20px;
}

@media (min-width: 768px) {
  .holiday2023-gift-item-container .main-txt:not(:first-child) {
    margin-top: 6px;
  }
}

.holiday2023-gift-item-container .main-txt-wrap {
  margin-top: 40px;
}

@media (min-width: 768px) {
  .holiday2023-gift-item-container .main-txt-wrap {
    margin-top: 60px;
  }
}

.holiday2023-gift-item-container .sub-ttl {
  margin-top: 30px;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.1em;
  line-height: 1.5;
  text-align: center;
}

@media (min-width: 768px) {
  .holiday2023-gift-item-container .sub-ttl {
    font-size: 18px;
  }
}

.holiday2023-gift-item-blowing {
  background: url(../images/holiday2023/humanity/humanity_blowing_sp.png) no-repeat;
  background-size: 100% 100%;
  padding: 10px 10px 10px 36px;
  -webkit-transform: scale(-1, 1);
          transform: scale(-1, 1);
  width: calc(100% - 71px);
  max-width: 500px;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .holiday2023-gift-item-blowing {
    background: url(../images/holiday2023/humanity/gift_humanity_blowing_pc.png) no-repeat;
    background-size: 100% 100%;
    padding: 30px 70px 30px 40px;
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    width: calc(100% - 120px);
    max-width: 100%;
  }
}

.holiday2023-gift-item-blowing-comment {
  -webkit-transform: scale(-1, 1);
          transform: scale(-1, 1);
  font-family: 'Kiwi Maru', "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial, sans-serif;
  font-size: 14px;
  line-height: 1.42857;
}

@media (min-width: 768px) {
  .holiday2023-gift-item-blowing-comment {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    font-size: 18px;
    line-height: 1.5;
    line-height: 1.7;
  }
}

.holiday2023-gift-item-blowing-icon {
  width: 67px;
  margin-left: 4px;
}

@media (min-width: 768px) {
  .holiday2023-gift-item-blowing-icon {
    width: 100px;
    margin-left: 20px;
  }
}

.holiday2023-gift-item-blowing-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 20px;
  max-width: 450px;
}

@media (min-width: 768px) {
  .holiday2023-gift-item-blowing-wrap {
    max-width: 756px;
    margin: 30px auto 0;
  }
}

.holiday2023-gift-item-blowing-wrap + .holiday2023-gift-detail-link {
  margin-top: 50px;
}

@media (min-width: 768px) {
  .holiday2023-gift-item-blowing-wrap + .holiday2023-gift-detail-link {
    margin-top: 80px;
  }
}

.holiday2023-gift-item-contents {
  margin-top: 60px;
}

@media (min-width: 768px) {
  .holiday2023-gift-item-inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.holiday2023-gift-item-img a {
  pointer-events: none;
}

@media (min-width: 768px) {
  .holiday2023-gift-item-img {
    -ms-flex-preferred-size: 47.95%;
        flex-basis: 47.95%;
  }
}

.holiday2023-gift-item-common {
  letter-spacing: 0.02em;
  margin-top: 20px;
}

.holiday2023-gift-item-brand {
  font-size: 20px;
  line-height: 1.3;
  font-family: 'brown-bold', 'Lucida Grande';
  letter-spacing: 0.05em;
}

@media (min-width: 768px) {
  .holiday2023-gift-item-brand {
    letter-spacing: 0.2em;
    margin-top: 10px;
  }
}

.holiday2023-gift-item-lead {
  font-size: 16px;
  line-height: 1.5625;
  font-weight: 700;
}

@media (min-width: 768px) {
  .holiday2023-gift-item-lead {
    font-size: 14px;
    line-height: 1.57143;
    margin-top: 40px;
  }
}

.holiday2023-gift-item-txt {
  font-size: 12px;
  line-height: 1.66667;
}

@media (min-width: 768px) {
  .holiday2023-gift-item-txt-wrap {
    font-size: 13px;
    margin-left: 60px;
    -ms-flex-preferred-size: 52%;
        flex-basis: 52%;
  }
}

.holiday2023-gift-item-credit {
  font-size: 12px;
  line-height: 1.66667;
}

@media (min-width: 768px) {
  .holiday2023-gift-item-credit {
    margin-top: 40px;
  }
}

.holiday2023-gift-item-credit a[href=""] {
  pointer-events: none;
}

.holiday2023-gift-item-credit a img {
  width: 15px;
  display: inline-block;
  vertical-align: text-bottom;
  margin-left: 2px;
}

.holiday2023-gift-item-list {
  margin-top: 60px;
}

.holiday2023-gift-item-thumb {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 10px 8px;
}

@media (min-width: 768px) {
  .holiday2023-gift-item-thumb {
    gap: 10px 10px;
  }
}

.holiday2023-gift-item-thumb li {
  width: calc((100% - 16px) / 3);
}

@media (min-width: 768px) {
  .holiday2023-gift-item-thumb li {
    width: calc((100% - 50px) / 6);
  }
}

@media (min-width: 768px) {
  .holiday2023-gift-item-thumb li:hover {
    cursor: pointer;
  }
}

.holiday2023-gift-item-thumb li.thumbnail-current {
  position: relative;
}

.holiday2023-gift-item-thumb li.thumbnail-current:after {
  content: "";
  background-color: rgba(0, 0, 0, 0.5);
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 1;
  -webkit-transition: 0.3s opacity linear;
  transition: 0.3s opacity linear;
}

@media (min-width: 768px) {
  .holiday2023-gift-window-section {
    max-width: 1020px;
    margin: 0 auto;
  }
}

.holiday2023-gift-window-section:not(:first-of-type) {
  margin-top: 70px;
}

.holiday2023-gift-window-section .holiday2023-gift-inner {
  padding-bottom: 20px;
}

.holiday2023-gift-window-main-img {
  margin-top: 20px;
}

@media (min-width: 768px) {
  .holiday2023-gift-window-main-img {
    margin-top: 40px;
  }
}

@media (min-width: 768px) {
  .holiday2023-gift-window-block {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

@media (min-width: 768px) {
  .holiday2023-gift-window-block.reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
}

@media (min-width: 768px) {
  .holiday2023-gift-window-block.reverse .holiday2023-gift-window-img {
    margin-right: 0;
    margin-left: 40px;
  }
}

.holiday2023-gift-window-block.reverse .holiday2023-gift-window-blowing {
  padding-left: 40px;
  padding-right: 6px;
}

@media (min-width: 768px) {
  .holiday2023-gift-window-block.reverse .holiday2023-gift-window-blowing {
    padding-left: 48px;
    padding-right: 12px;
  }
}

.holiday2023-gift-window-img {
  margin-top: 10px;
}

@media (min-width: 768px) {
  .holiday2023-gift-window-img {
    margin-right: 40px;
    margin-top: 0;
    -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
  }
}

.holiday2023-gift-window-txt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 10px;
  max-width: 400px;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}

@media (min-width: 768px) {
  .holiday2023-gift-window-txt {
    margin-top: 0;
    -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
    max-width: 100%;
  }
}

.holiday2023-gift-window-txt-icon {
  width: 67px;
  margin-right: 4px;
}

@media (min-width: 768px) {
  .holiday2023-gift-window-txt-icon {
    width: 80px;
    margin-right: 12px;
  }
}

.holiday2023-gift-window-txt.right-icon {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  margin-right: 0;
  margin-left: auto;
}

@media (min-width: 768px) {
  .holiday2023-gift-window-txt.right-icon {
    margin-left: 0;
  }
}

.holiday2023-gift-window-txt.right-icon .holiday2023-gift-window-blowing {
  -webkit-transform: scale(-1, 1);
          transform: scale(-1, 1);
}

.holiday2023-gift-window-txt.right-icon .holiday2023-gift-window-comment {
  -webkit-transform: scale(-1, 1);
          transform: scale(-1, 1);
}

.holiday2023-gift-window-txt.right-icon .holiday2023-gift-window-txt-icon {
  margin-left: 4px;
  margin-right: 0;
}

@media (min-width: 768px) {
  .holiday2023-gift-window-txt.right-icon .holiday2023-gift-window-txt-icon {
    margin-left: 12px;
    margin-right: 0;
  }
}

.holiday2023-gift-window-blowing {
  width: calc(100% - 4px);
  padding: 10px 10px 10px 36px;
}

@media (min-width: 768px) {
  .holiday2023-gift-window-blowing {
    width: calc(100% - 92px);
    padding: 20px 18px 20px 48px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
}

.holiday2023-gift-window-blowing.heart {
  background: url(../images/holiday2023/heart/heart_blowing_sp.png) no-repeat;
  background-size: 100% 100%;
}

@media (min-width: 768px) {
  .holiday2023-gift-window-blowing.heart {
    background: url(../images/holiday2023/heart/heart_blowing_pc.png) no-repeat;
    background-size: 100% 100%;
  }
}

.holiday2023-gift-window-blowing.heat {
  background: url(../images/holiday2023/heat/heat_blowing_sp.png) no-repeat;
  background-size: 100% 100%;
}

@media (min-width: 768px) {
  .holiday2023-gift-window-blowing.heat {
    background: url(../images/holiday2023/heat/heat_blowing_pc.png) no-repeat;
    background-size: 100% 100%;
  }
}

.holiday2023-gift-window-blowing.humor {
  background: url(../images/holiday2023/humor/humor_blowing_sp.png) no-repeat;
  background-size: 100% 100%;
}

@media (min-width: 768px) {
  .holiday2023-gift-window-blowing.humor {
    background: url(../images/holiday2023/humor/humor_blowing_pc.png) no-repeat;
    background-size: 100% 100%;
  }
}

.holiday2023-gift-window-blowing.humanity {
  background: url(../images/holiday2023/humanity/humanity_blowing_sp.png) no-repeat;
  background-size: 100% 100%;
}

@media (min-width: 768px) {
  .holiday2023-gift-window-blowing.humanity {
    background: url(../images/holiday2023/humanity/humanity_blowing_pc.png) no-repeat;
    background-size: 100% 100%;
  }
}

.holiday2023-gift-window-comment {
  font-family: 'Kiwi Maru', "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial, sans-serif;
  font-size: 14px;
  line-height: 1.42857;
}

@media (min-width: 768px) {
  .holiday2023-gift-window-comment {
    font-size: 16px;
    line-height: 1.375;
  }
}

@media (min-width: 768px) {
  .holiday2023-gift-window-block {
    margin-top: 40px;
  }
}

.holiday2023-gift-window-block:not(:first-of-type) {
  margin-top: 40px;
}

@media (min-width: 768px) {
  .holiday2023-gift-window-block:not(:first-of-type) {
    margin-top: 60px;
  }
}

.holiday2023-gift-window-humanity {
  margin-top: 40px;
}

@media (min-width: 768px) {
  .holiday2023-gift-window-humanity {
    margin-top: 110px;
  }
}

.holiday2023-gift-window-humanity .sub-ttl {
  max-width: 756px;
  margin: 50px auto 0;
}

@media (min-width: 768px) {
  .holiday2023-gift-window-humanity .sub-ttl {
    margin-top: 60px;
  }
}

@-webkit-keyframes airy {
  0% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
  50% {
    -webkit-transform: translate(0, -10%);
            transform: translate(0, -10%);
  }
  100% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
}

@keyframes airy {
  0% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
  50% {
    -webkit-transform: translate(0, -10%);
            transform: translate(0, -10%);
  }
  100% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
}

@-webkit-keyframes rotate {
  0%, 4%, 8%, 100% {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }
  2%, 6% {
    -webkit-transform: rotate(14deg);
            transform: rotate(14deg);
  }
}

@keyframes rotate {
  0%, 4%, 8%, 100% {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }
  2%, 6% {
    -webkit-transform: rotate(14deg);
            transform: rotate(14deg);
  }
}

@media (min-width: 768px) {
  @-webkit-keyframes rotate {
    0%, 4%, 8%, 100% {
      -webkit-transform: rotate(0);
              transform: rotate(0);
    }
    2%, 6% {
      -webkit-transform: rotate(10deg);
              transform: rotate(10deg);
    }
  }
  @keyframes rotate {
    0%, 4%, 8%, 100% {
      -webkit-transform: rotate(0);
              transform: rotate(0);
    }
    2%, 6% {
      -webkit-transform: rotate(10deg);
              transform: rotate(10deg);
    }
  }
}

@-webkit-keyframes rotate_15 {
  0%, 4%, 8%, 100% {
    -webkit-transform: rotate(15deg);
            transform: rotate(15deg);
  }
  2%, 6% {
    -webkit-transform: rotate(25deg);
            transform: rotate(25deg);
  }
}

@keyframes rotate_15 {
  0%, 4%, 8%, 100% {
    -webkit-transform: rotate(15deg);
            transform: rotate(15deg);
  }
  2%, 6% {
    -webkit-transform: rotate(25deg);
            transform: rotate(25deg);
  }
}

@-webkit-keyframes rotate_25 {
  0%, 4%, 8%, 100% {
    -webkit-transform: rotate(-25deg);
            transform: rotate(-25deg);
  }
  2%, 6% {
    -webkit-transform: rotate(-15deg);
            transform: rotate(-15deg);
  }
}

@keyframes rotate_25 {
  0%, 4%, 8%, 100% {
    -webkit-transform: rotate(-25deg);
            transform: rotate(-25deg);
  }
  2%, 6% {
    -webkit-transform: rotate(-15deg);
            transform: rotate(-15deg);
  }
}

@-webkit-keyframes rotate_90 {
  0%, 4%, 8%, 100% {
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
  }
  2%, 6% {
    -webkit-transform: rotate(105deg);
            transform: rotate(105deg);
  }
}

@keyframes rotate_90 {
  0%, 4%, 8%, 100% {
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
  }
  2%, 6% {
    -webkit-transform: rotate(105deg);
            transform: rotate(105deg);
  }
}

@-webkit-keyframes rotate_125 {
  0%, 4%, 8%, 100% {
    -webkit-transform: rotate(125deg);
            transform: rotate(125deg);
  }
  2%, 6% {
    -webkit-transform: rotate(139deg);
            transform: rotate(139deg);
  }
}

@keyframes rotate_125 {
  0%, 4%, 8%, 100% {
    -webkit-transform: rotate(125deg);
            transform: rotate(125deg);
  }
  2%, 6% {
    -webkit-transform: rotate(139deg);
            transform: rotate(139deg);
  }
}

.home {
  overflow: hidden;
}

.home .home-item-link {
  margin-top: 50px;
}

.home-carousel {
  position: relative;
  margin: 0 auto;
}

.home-carousel .home-carousel-swiper-container {
  overflow: hidden;
  background-color: #000;
}

.home-carousel .home-carousel-swiper {
  position: relative;
  margin: 0 auto;
}

@media screen and (min-width: 1320px) {
  .home-carousel .home-carousel-swiper {
    max-width: 1235px;
  }
}

.home-carousel .swiper-slide {
  position: relative;
  width: 100%;
}

.home-carousel .swiper-slide a {
  display: block;
}

.home-carousel .swiper-slide:before {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  width: 100%;
  height: 100%;
  display: block;
  background: rgba(0, 0, 0, 0.6);
  opacity: 0;
  visibility: hidden;
  -webkit-transition: all ease 1s;
  transition: all ease 1s;
}

.home-carousel .swiper-slide-next:before, .home-carousel .swiper-slide-prev:before {
  opacity: 1;
  visibility: visible;
}

.home-carousel .swiper-button-prev,
.home-carousel .swiper-button-next {
  display: none;
  width: 36px;
  height: 70px;
  cursor: pointer;
  -webkit-transition: .3s;
  transition: .3s;
  position: absolute;
  top: 50%;
  background-image: url("../images/icon/swiper_arrow_top.svg");
  background-size: cover;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  z-index: 1;
}

@media (min-width: 768px) {
  .home-carousel .swiper-button-prev:hover,
  .home-carousel .swiper-button-next:hover {
    opacity: 0.7;
  }
}

.home-carousel .swiper-button-prev {
  left: 0px;
  -webkit-transform: translateY(-50%) rotate(180deg);
          transform: translateY(-50%) rotate(180deg);
}

@media (min-width: 768px) {
  .home-carousel .swiper-button-prev {
    left: 20px;
    background-size: cover;
    left: 4.5%;
  }
}

.home-carousel .swiper-button-next {
  right: 0px;
}

@media (min-width: 768px) {
  .home-carousel .swiper-button-next {
    right: 20px;
    background-size: cover;
    right: 4.5%;
  }
}

.home-carousel .swiper-pagination {
  position: absolute;
  bottom: -10px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  display: none;
  width: 100%;
  max-width: calc(100% - 30px);
  z-index: 2;
}

@media (min-width: 768px) {
  .home-carousel .swiper-pagination {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    max-width: 1044px;
    padding: 0 10px;
  }
}

.home-carousel .swiper-pagination-bullet {
  background-color: #BFBFBF;
  background-repeat: no-repeat;
  background-size: contain;
  border-radius: 0;
  width: 13px;
  height: 13px;
  opacity: 1;
  margin-right: 6px;
}

@media (min-width: 768px) {
  .home-carousel .swiper-pagination-bullet {
    width: 20px;
    height: 5px;
    margin-right: 5px;
  }
}

.home-carousel .swiper-pagination-bullet:last-child {
  margin-right: 0;
}

.home-carousel .swiper-pagination-bullet-active {
  background-color: #000;
}

.home-events {
  padding: 45px 0 80px;
  background-color: #F2F2F2;
}

@media (min-width: 768px) {
  .home-events {
    padding: 65px 0 80px;
  }
}

.home-events .heading-1 {
  margin: 0 auto;
  max-width: 1024px;
}

.home-events .home-event-swiper {
  overflow: hidden;
}

.home-events .home-event-swiper .def-item {
  margin: 0;
  max-width: initial;
  width: 100%;
}

.home-events .home-event-swiper .def-item + .def-item {
  margin-left: 0;
}

.home-events .home-inner {
  padding: 0 15px;
}

@media (min-width: 768px) {
  .home-events .home-inner {
    margin: 0 auto;
    max-width: 1184px;
    padding: 0 10px;
  }
}

.home-events .article-item {
  padding: 30px 0 15px;
  position: relative;
  max-width: 100vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media (min-width: 768px) {
  .home-events .article-item {
    padding: 42px 34px;
  }
}

@media screen and (min-width: 1092px) {
  .home-events .article-item {
    padding: 42px 70px;
  }
}

.home-events .article-item .swiper-slide {
  width: 100%;
}

@media (min-width: 768px) {
  .home-events .article-item .swiper-event-button-prev,
  .home-events .article-item .swiper-event-button-next {
    width: 34px;
    height: 34px;
    cursor: pointer;
    -webkit-transition: .3s;
    transition: .3s;
    background-image: url("../images/icon/swiper_arrow.svg");
    background-size: cover;
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    z-index: 1;
  }
  .home-events .article-item .swiper-event-button-prev:hover,
  .home-events .article-item .swiper-event-button-next:hover {
    opacity: 0.7;
  }
}

.home-events .article-item .swiper-event-button-prev {
  left: 10px;
  -webkit-transform: translateY(-50%) rotate(180deg);
          transform: translateY(-50%) rotate(180deg);
}

@media (min-width: 768px) {
  .home-events .article-item .swiper-event-button-prev {
    left: 0;
  }
}

.home-events .article-item .swiper-event-button-next {
  right: 10px;
}

@media (min-width: 768px) {
  .home-events .article-item .swiper-event-button-next {
    right: 0;
  }
}

.home-events .article-item-link {
  padding-top: 32px;
  margin: 0 auto;
  max-width: 1024px;
}

@media (min-width: 768px) {
  .home-events .article-item-link {
    padding-top: 50px;
  }
}

.home-fashion-heading {
  padding: 45px 0 65px;
  color: #FFF;
  background-color: #000;
  text-align: center;
}

@media (min-width: 768px) {
  .home-fashion-heading {
    padding-bottom: 80px;
  }
}

.home-fashion-heading .heading-1 {
  margin-bottom: 30px;
}

.home-fashion-heading .heading-1 span {
  color: #FFF;
}

.home-fashion-heading .heading-1 .heading-1-sub {
  color: #808080;
}

.home-fashion-heading-title {
  margin-bottom: 30px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1.66667;
  letter-spacing: 0.2em;
  text-align: left;
}

@media (min-width: 768px) {
  .home-fashion-heading-title {
    margin-bottom: 45px;
    text-align: center;
  }
}

.home-fashion-heading-thumbnail {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 0 -16px 15px;
}

@media (min-width: 768px) {
  .home-fashion-heading-thumbnail {
    margin: 0 -68px 45px;
  }
}

.home-fashion-heading-thumbnail li {
  width: 47.53623%;
  padding: 0 8px;
  margin-bottom: 20px;
}

@media (min-width: 768px) {
  .home-fashion-heading-thumbnail li {
    width: 20%;
    padding: 0 11px;
    margin-bottom: 0;
  }
}

.home-fashion-heading-thumbnail li:last-child {
  display: none;
}

@media (min-width: 768px) {
  .home-fashion-heading-thumbnail li:last-child {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
  }
}

.home-fashion-heading-lead {
  margin: 0 auto;
  line-height: 1.85714;
  text-align: left;
}

@media (min-width: 768px) {
  .home-fashion-heading-lead {
    max-width: 720px;
    text-align: center;
  }
}

.home-fashion-article {
  padding: 10px 0 80px;
  background-color: #F2F2F2;
}

@media (min-width: 768px) {
  .home-fashion-article {
    padding: 50px 0 80px;
  }
}

.home-gift {
  padding: 45px 15px 80px;
}

.home-gift .heading-1 {
  margin-bottom: 30px;
}

@media (min-width: 968px) {
  .home-gift .heading-1 {
    margin-bottom: 45px;
  }
}

.home-gift-heading {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: relative;
}

.home-gift-heading-image {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
  width: calc(100% + 30px);
  margin: 0 -15px 52px;
}

@media (min-width: 968px) {
  .home-gift-heading-image {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    width: 46%;
    min-height: initial;
    margin: 0;
    padding: 0;
    padding-left: 8%;
  }
}

.home-gift-heading-image img {
  margin-bottom: -61px;
}

@media (min-width: 968px) {
  .home-gift-heading-image img {
    margin: auto;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}

.home-gift-heading-contents {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
  width: 100%;
  padding: 0;
}

@media (min-width: 968px) {
  .home-gift-heading-contents {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    width: 54%;
    padding: 0 10.66667% 0 8%;
  }
}

.home-gift-heading-contents-title {
  margin-bottom: 20px;
  font-size: 18px;
  line-height: 1.66667;
}

@media (min-width: 968px) {
  .home-gift-heading-contents-title {
    margin-bottom: 25px;
  }
}

.home-gift-heading-contents-lead {
  margin-bottom: 28px;
  line-height: 1.85714;
}

@media (min-width: 968px) {
  .home-gift-heading-contents-lead {
    margin-bottom: 35px;
  }
}

.home-gift-heading-contents-thumbnail {
  display: none;
}

@media (min-width: 968px) {
  .home-gift-heading-contents-thumbnail {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

.home-gift-heading-contents-thumbnail li {
  width: calc( 100% / 3);
}

@media (min-width: 968px) {
  .home-gift-heading-contents-thumbnail li {
    width: 31.13208%;
  }
}

.home-gift-heading-thumbnail-sp {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
  margin: 0 -15px;
}

@media (min-width: 968px) {
  .home-gift-heading-thumbnail-sp {
    display: none;
  }
}

.home-gift-heading-thumbnail-sp li {
  width: 50%;
}

.home-gift .home-item-link {
  margin-top: 50px;
}

@media (min-width: 968px) {
  .home-gift .home-item-link {
    margin-top: 100px;
  }
}

.home-bridal {
  margin-bottom: 30px;
  padding: 45px 0 70px;
  background-color: #DEF2FD;
}

@media (min-width: 768px) {
  .home-bridal {
    margin-bottom: 60px;
    padding-bottom: 80px;
  }
}

.home-bridal .heading-1 {
  margin-bottom: 30px;
}

@media (min-width: 768px) {
  .home-bridal .heading-1 {
    margin-bottom: 40px;
  }
}

@media (min-width: 768px) {
  .home-bridal .index-caption-img {
    width: 430px;
    margin: 0 0 0 30px;
  }
}

@media (min-width: 968px) {
  .home-bridal .index-caption-img {
    width: 450px;
    margin: 0 0 0 110px;
  }
}

.home-bridal .bridal-service-wrap {
  padding-bottom: 0;
}

@media (min-width: 768px) {
  .home-bridal .bridal-service-wrap {
    padding-bottom: 50px;
  }
}

.home-bridal .bridal-detail-service {
  margin-top: 0;
}

.home-bridal .bridal-detail-service-bg {
  padding-bottom: 0;
}

.home-bridal-heading {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-bottom: 50px;
}

.home-bridal-heading-menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 100%;
  border-top: 1px solid #BFBFBF;
}

@media (min-width: 768px) {
  .home-bridal-heading-menu {
    width: 60%;
  }
}

.home-bridal-heading-menu-item {
  width: 50%;
  min-height: 128px;
  border-right: 1px solid #9F8E64;
  border-bottom: 1px solid #9F8E64;
}

@media (min-width: 768px) {
  .home-bridal-heading-menu-item {
    width: 50%;
    min-height: 140px;
  }
}

@media screen and (min-width: 1300px) {
  .home-bridal-heading-menu-item {
    width: 33.33333%;
    min-height: initial;
  }
}

.home-bridal-heading-menu-item:last-child {
  background: url(../images/home/home_bridal_bg_01.jpg) no-repeat 50% 50%;
  background-size: cover;
}

.home-bridal-heading-menu-item a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-line-pack: center;
      align-content: center;
  position: relative;
  width: 100%;
  height: 100%;
  padding: 0 10px;
  color: #9F8E64;
  -webkit-transition: all .3s;
  transition: all .3s;
}

.home-bridal-heading-menu-item .label {
  position: absolute;
  top: 5px;
  left: 5px;
  font-family: "Barlow";
  font-size: 28px;
  text-align: center;
  line-height: 1;
  color: #8D6B0D;
}

@media (min-width: 768px) {
  .home-bridal-heading-menu-item .label {
    top: 10px;
    left: 20px;
    font-size: 34px;
  }
}

.home-bridal-heading-menu-item .label span {
  display: block;
  margin-top: 5px;
  font-size: 11px;
  font-family: "Noto Sans JP", YuGothic, "游ゴシック体", "Yu Gothic Medium", "游ゴシック Medium", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
  line-height: 1;
  color: #FFF;
}

@media (min-width: 768px) {
  .home-bridal-heading-menu-item .label span {
    font-size: 12px;
  }
}

.home-bridal-heading-menu-item svg {
  width: 48px;
  margin-bottom: 12px;
  color: #9F8E64;
}

@media (min-width: 768px) {
  .home-bridal-heading-menu-item svg {
    margin-top: -20px;
  }
}

@media screen and (min-width: 1300px) {
  .home-bridal-heading-menu-item svg {
    margin-top: -30px;
  }
}

@media screen and (max-width: 768px) {
  .home-bridal-heading-menu-item svg.icon-bridal-01 {
    width: 31px;
    height: auto;
  }
  .home-bridal-heading-menu-item svg.icon-bridal-02 {
    width: 36px;
    height: auto;
  }
  .home-bridal-heading-menu-item svg.icon-bridal-03 {
    width: 27px;
    height: auto;
  }
  .home-bridal-heading-menu-item svg.icon-bridal-04 {
    width: 31px;
    height: auto;
  }
  .home-bridal-heading-menu-item svg.icon-bridal-05 {
    width: 30px;
    height: auto;
  }
}

.home-bridal-heading-menu-item .title {
  position: relative;
  width: 100%;
  font-size: 16px;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .home-bridal-heading-menu-item .title {
    font-size: 20px;
  }
}

.home-bridal-heading-menu-item .title:after {
  content: "";
  width: 68px;
  height: 9px;
  border-bottom: 1px solid #9F8E64;
  border-right: 1px solid #9F8E64;
  position: absolute;
  top: 30px;
  left: 50%;
  -webkit-transform: translateX(-50%) skew(30deg);
          transform: translateX(-50%) skew(30deg);
}

@media (min-width: 768px) {
  .home-bridal-heading-menu-item .title:after {
    top: 30px;
    width: 90px;
    height: 11px;
  }
}

@media screen and (min-width: 1300px) {
  .home-bridal-heading-menu-item .title:after {
    top: 40px;
  }
}

.home-bridal-heading-menu-item a:hover,
.home-bridal-heading-menu-item a:active {
  background-color: #9F8E64;
}

.home-bridal-heading-menu-item a:hover .label,
.home-bridal-heading-menu-item a:active .label {
  color: #FFF;
}

.home-bridal-heading-menu-item a:hover .title,
.home-bridal-heading-menu-item a:active .title {
  color: #FFF;
}

.home-bridal-heading-menu-item a:hover .title:after,
.home-bridal-heading-menu-item a:active .title:after {
  border-color: #FFF;
}

.home-bridal-heading-menu-item a:hover svg,
.home-bridal-heading-menu-item a:active svg {
  color: #FFF;
}

.home-bridal-heading-thumbnail {
  display: none;
  width: 100%;
  border-top: 1px solid #BFBFBF;
  border-bottom: 1px solid #BFBFBF;
}

.home-bridal-heading-thumbnail img {
  -o-object-fit: cover;
     object-fit: cover;
}

@media (min-width: 768px) {
  .home-bridal-heading-thumbnail {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    width: 40%;
  }
}

.home-bridal-title {
  margin-bottom: 20px;
  font-size: 18px;
  line-height: 1.66667;
}

.home-bridal-lead {
  max-width: 720px;
  margin: 0 auto 50px;
  line-height: 1.85714;
}

.home-bridal-lead-wrap {
  padding: 0 15px;
}

@media (min-width: 768px) {
  .home-bridal-lead-wrap {
    width: calc(100% - 450px);
    padding: 0;
  }
}

@media (min-width: 968px) {
  .home-bridal-lead-wrap {
    width: calc(100% - 560px);
  }
}

.home-bridal-txt-sp {
  margin-bottom: 45px;
  padding: 0 15px;
}

.home-bridal-txt-sp-title {
  margin-bottom: 25px;
  font-size: 18px;
  line-height: 1.55556;
}

.home-bridal-txt-sp-thumbnail {
  margin: 0 -15px 35px;
}

.home-bridal-txt-sp-lead {
  line-height: 1.85714;
}

@media (min-width: 768px) {
  .home-bridal-head-content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    max-width: 1055px;
    margin: 0 auto;
    padding: 0 15px;
  }
}

.home-culture {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 50px 15px 80px;
  background-color: #000;
}

@media (min-width: 768px) {
  .home-culture {
    padding: 0;
  }
}

.home-culture-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-flex-line-pack: center;
      align-content: center;
  position: relative;
  width: 100%;
  padding: 0;
  color: #FFF;
}

@media (min-width: 768px) {
  .home-culture-content {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    width: 60%;
    padding: 60px 40px 60px 90px;
  }
}

@media screen and (min-width: 1300px) {
  .home-culture-content {
    width: 50%;
    padding: 60px 6.66667% 60px 15.86667%;
  }
}

.home-culture-content:before {
  display: none;
}

@media (min-width: 768px) {
  .home-culture-content:before {
    display: block;
    content: "";
    width: 40px;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background-size: cover;
  }
}

@media screen and (min-width: 1300px) {
  .home-culture-content:before {
    width: 18.66667%;
  }
}

.home-culture-content-title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  margin-bottom: 30px;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  line-height: 1.5;
  letter-spacing: 0.2em;
  font-size: 24px;
  font-weight: bold;
  color: #808080;
  text-align: center;
}

@media (min-width: 768px) {
  .home-culture-content-title {
    margin-bottom: 25px;
    font-size: 30px;
    text-align: left;
  }
}

.home-culture-content-title span {
  width: 100%;
}

@media (min-width: 768px) {
  .home-culture-content-title span {
    width: initial;
  }
}

.home-culture-content-title span.sub {
  margin-top: 5px;
  color: #FFF;
  font-size: 16px;
  font-weight: bold;
}

@media (min-width: 768px) {
  .home-culture-content-title span.sub {
    margin-top: initial;
    margin-left: 40px;
  }
}

.home-culture-content-sub-title {
  margin-bottom: 25px;
  font-size: 18px;
  line-height: 1.66667;
}

.home-culture-content-sp-image {
  margin: 0 -15px 40px;
}

.home-culture-content-lead {
  margin-bottom: 40px;
  line-height: 1.85714;
}

.home-culture-content-thumbnail {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.home-culture-content-thumbnail li {
  width: 50%;
}

@media (min-width: 768px) {
  .home-culture-content-thumbnail li {
    width: calc( 50% - 13px / 2);
  }
}

.home-culture-image {
  width: 50%;
  background: url(../images/home/home_culture_01_pc.jpg) no-repeat 0% 100%;
  background-size: cover;
}

@media (min-width: 768px) {
  .home-culture-image {
    width: 40%;
  }
}

@media screen and (min-width: 1300px) {
  .home-culture-image {
    width: 50%;
  }
}

.home-stores {
  padding: 50px 0 70px;
}

@media (min-width: 768px) {
  .home-stores {
    padding: 45px 0 75px;
  }
}

.home-stores .heading-1 {
  margin-bottom: 28px;
}

.home-stores-lead {
  margin-bottom: 50px;
  text-align: center;
  line-height: 1.66667;
  text-align: left;
}

@media (min-width: 768px) {
  .home-stores-lead {
    text-align: center;
  }
}

.home-stores-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px 0;
  margin-bottom: 40px;
}

@media (min-width: 768px) {
  .home-stores-list {
    grid-template-columns: 1fr 1fr 1fr;
    gap: 45px 41px;
    margin-bottom: 80px;
  }
}

.home-stores-list-item {
  text-align: center;
}

.home-stores-list-item a {
  display: block;
  color: #333333;
  -webkit-transition: all .3s;
  transition: all .3s;
}

@media (min-width: 768px) {
  .home-stores-list-item a:hover {
    opacity: 0.7;
  }
}

.home-stores-list-item-thumb {
  position: relative;
  margin-bottom: 10px;
}

.home-stores-list-item-thumb .tag {
  position: absolute;
  top: 11px;
  left: 8px;
  padding: 4px 2px;
  background-color: #8D6B0D;
  font-size: 12px;
  color: #fff;
  text-align: center;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
}

.home-stores-list-item-title-en {
  font-size: 20px;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  margin-bottom: 7px;
  color: #B2B2B2;
}

.home-stores-list-item-title {
  position: relative;
  padding-bottom: 25px;
  font-size: 16px;
  line-height: 1.5;
}

.home-stores-list-item-title:after {
  content: "";
  width: 132px;
  height: 12px;
  border-bottom: 1px solid #B2B2B2;
  border-right: 1px solid #B2B2B2;
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%) skew(38deg);
          transform: translateX(-50%) skew(38deg);
}

.home-stores-outlets {
  margin: 50px auto 0;
  text-align: center;
}

.home-stores-outlets a {
  position: relative;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  justify-self: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-width: 250px;
  padding: 14px 10px 27px;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.1em;
  color: #333333;
  border: 1px solid #B2B2B2;
}

@media (min-width: 768px) {
  .home-stores-outlets a {
    width: 58.59375%;
    padding: 20px 20px 39px;
    font-size: 20px;
  }
}

.home-stores-outlets a:after {
  content: "";
  width: 120px;
  height: 12px;
  border-bottom: 1px solid #808080;
  border-right: 1px solid #808080;
  position: absolute;
  bottom: 12px;
  left: 50%;
  -webkit-transform: translateX(-50%) skew(30deg);
          transform: translateX(-50%) skew(30deg);
}

@media (min-width: 768px) {
  .home-stores-outlets a:after {
    bottom: 20px;
  }
}

.index-mv {
  position: relative;
}

.index-mv-content {
  width: 100vw;
  margin: 0 calc(50% - 50vw);
}

@media (min-width: 768px) {
  .index-mv-content {
    width: 100%;
    margin: 0;
  }
}

.index-mv-block + .index-item-wrap {
  margin-top: 50px;
}

.index-mv-lead {
  font-size: 16px;
  line-height: 1.6;
  letter-spacing: 0.02em;
}

.index-mv-lead-bold {
  font-weight: bold;
}

.index-mv-lead-wrap {
  margin-top: 40px;
}

@media (min-width: 768px) {
  .index-mv-lead-wrap {
    margin-top: 30px;
  }
}

.index-mv-ttl {
  position: absolute;
  top: 20px;
  left: 15px;
}

@media (min-width: 768px) {
  .index-mv-ttl {
    top: 30px;
    max-width: 1044px;
    width: 100%;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    padding: 0 20px;
  }
}

.index-mv-bg img {
  -o-object-fit: cover;
     object-fit: cover;
  height: 150px;
}

@media (min-width: 768px) {
  .index-mv-bg img {
    height: 300px;
  }
}

.index-inner {
  padding: 0 15px;
}

@media (min-width: 768px) {
  .index-inner {
    max-width: 1044px;
    margin: 0 auto;
    padding: 0 10px;
  }
}

.index-inner .heading-4-square {
  margin-bottom: 12px;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
}

@media (min-width: 768px) {
  .index-inner .heading-4-square {
    margin-bottom: 15px;
  }
}

.index-inner .heading-4-square.txt-jp {
  font-weight: bold !important;
}

.index-caption {
  margin: 33px 0 25px;
  font-size: 18px;
  line-height: 1.555;
}

@media (min-width: 768px) {
  .index-caption {
    margin: 24px 0 22px;
    text-align: center;
  }
}

.index-caption-wrap {
  padding: 45px 15px 70px;
}

@media (min-width: 768px) {
  .index-caption-wrap {
    padding: 86px 10px 72px;
  }
}

.index-caption-wrap-narrow {
  padding-bottom: 30px;
}

@media (min-width: 768px) {
  .index-caption-wrap-narrow {
    padding-bottom: 60px;
  }
}

@media (min-width: 768px) {
  .index-caption-wrap-narrow .index-caption-img {
    margin-bottom: 0;
  }
}

.index-caption-txt {
  line-height: 1.857;
  text-align: center;
}

.index-caption-img {
  margin: 58px -15px 0;
}

@media (min-width: 768px) {
  .index-caption-img {
    margin: 70px 0 75px;
  }
}

@media (min-width: 768px) {
  .index-lead-ttl {
    text-align: center;
  }
  .index-lead-ttl.heading-3 {
    line-height: 1.7;
  }
}

.index-lead-txt {
  margin-top: 24px;
  line-height: 1.857;
}

@media (min-width: 768px) {
  .index-lead-txt {
    margin-top: 35px;
    text-align: center;
  }
}

.index-sub-ttl {
  font-size: 24px;
  line-height: 1.5;
  letter-spacing: 0.04em;
  font-weight: bold;
  text-align: center;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
}

@media (min-width: 768px) {
  .index-sub-ttl {
    font-size: 26px;
  }
}

.index-heading-wrap {
  padding: 45px 15px 35px;
}

@media (min-width: 768px) {
  .index-heading-wrap {
    padding: 86px 10px 50px;
  }
}

.index-article-item-wrap {
  background-color: #F2F2F2;
  padding: 40px 0 61px;
}

@media (min-width: 768px) {
  .index-article-item-wrap {
    padding: 59px 0 49px;
  }
}

.index-article-list-wrap {
  background-color: #F2F2F2;
  padding: 40px 0 47px;
}

@media (min-width: 768px) {
  .index-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}

.index-item + .index-item {
  margin-top: 50px;
}

@media (min-width: 768px) {
  .index-item + .index-item {
    margin-top: 64px;
  }
}

.index-item.index-item-img-right {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}

.index-item.index-item-img-right .index-item-txt-wrap {
  margin-top: 25px;
}

@media (min-width: 768px) {
  .index-item.index-item-img-right .index-item-txt-wrap {
    margin-top: 0;
    margin-right: 60px;
  }
}

.index-item.index-item-img-left .index-item-txt-wrap {
  margin-top: 25px;
}

@media (min-width: 768px) {
  .index-item.index-item-img-left .index-item-txt-wrap {
    margin-top: 0;
    margin-left: 60px;
  }
}

.index-item-wrap {
  margin: 60px auto 62px;
}

@media (min-width: 768px) {
  .index-item-wrap {
    margin: 100px auto 138px;
  }
}

@media (min-width: 768px) {
  .index-item-img {
    width: calc(50% - 30px);
  }
}

.index-item-img .index-item-img-item {
  width: calc((100% - 30px)/3);
}

@media (min-width: 768px) {
  .index-item-img .index-item-img-item {
    width: calc((100% - 44px)/3);
  }
}

.index-item-img .index-item-img-item + .index-item-img-item {
  margin-left: 15px;
}

@media (min-width: 768px) {
  .index-item-img .index-item-img-item + .index-item-img-item {
    margin-left: 22px;
  }
}

.index-item-img .index-item-img-item.item-2 {
  width: calc(((100% - 30px)/3*2) + 15px);
}

@media (min-width: 768px) {
  .index-item-img .index-item-img-item.item-2 {
    width: calc(((100% - 44px)/3*2) + 22px);
  }
}

.index-item-img-bottom {
  margin-top: 20px;
}

.index-item-img-bottom .index-item-img-item {
  width: calc((100% - 24px)/3);
}

@media (min-width: 768px) {
  .index-item-img-bottom .index-item-img-item {
    width: calc((100% - 36px)/3);
  }
}

.index-item-img-bottom .index-item-img-item + .index-item-img-item {
  margin-left: 12px;
}

@media (min-width: 768px) {
  .index-item-img-bottom .index-item-img-item + .index-item-img-item {
    margin-left: 18px;
  }
}

@media (min-width: 768px) {
  .index-item-img-bottom {
    margin-top: 40px;
  }
}

.index-item-img-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.index-item-txt {
  line-height: 1.857;
  margin-top: 15px;
}

@media (min-width: 768px) {
  .index-item-txt {
    margin-top: 20px;
  }
}

.index-item-txt-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

@media (min-width: 768px) {
  .index-item-txt-wrap {
    width: calc(50% - 30px);
  }
}

@media (min-width: 768px) {
  .info .common-ttl-wrap {
    margin-bottom: 70px;
  }
}

.info.common-default {
  background-color: #F4F4F4;
  padding: 20px;
}

.info-wrap {
  margin-top: 50px;
  margin-bottom: 40px;
}

@media (min-width: 768px) {
  .info-wrap {
    margin-top: 75px;
    width: 100%;
    max-width: 1054px;
  }
}

.info-wrap.none-mb {
  margin-bottom: 0;
}

.info-content + .info-content {
  margin-top: 70px;
}

@media (min-width: 768px) {
  .info-content + .info-content {
    margin-top: 85px;
  }
}

.info-block {
  border-top: 1px solid #D9D9D9;
  padding: 24px 16px;
  line-height: 1.714;
}

.info-block + .info-block {
  margin-top: 20px;
}

@media (min-width: 768px) {
  .info-block + .info-block {
    margin-top: 15px;
  }
}

.info-block:last-child {
  border-bottom: 1px solid #D9D9D9;
  padding-bottom: 20px;
}

.info-block-list {
  margin-top: 30px;
}

.info-block.none-border:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

@media (min-width: 768px) {
  .info-block.none-border:last-child {
    padding-top: 25px;
  }
}

.info-tab-list .tab-link {
  padding: 10px 32px;
  font-weight: bold;
}

@media (min-width: 768px) {
  .info-tab-list .tab-link {
    padding-right: 8px;
    padding-left: 20px;
  }
}

.info-tab-list .common-tab-number {
  font-size: 18px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

@media (min-width: 768px) {
  .info-tab-list .common-tab-number {
    font-size: 20px;
    left: 10px;
  }
}

.membership-mv-ttl {
  font-size: 20px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  position: absolute;
  top: 20px;
  left: 15px;
}

@media (min-width: 768px) {
  .membership-mv-ttl {
    font-size: 24px;
    line-height: 1.25;
    top: 30px;
    max-width: 1044px;
    width: 100%;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    padding: 0 20px;
  }
}

.membership-alert {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 50px;
  margin-bottom: 5px;
}

@media (min-width: 768px) {
  .membership-alert {
    display: none;
  }
}

.membership-alert-txt {
  font-size: 12px;
  line-height: 1.75;
  letter-spacing: 0.02em;
}

.membership-icon {
  width: 16px;
  height: 16px;
  margin-right: 5px;
}

.membership-tab-panel-wrap {
  margin-top: 50px;
}

@media (min-width: 768px) {
  .membership-tab-panel-wrap {
    margin-top: 88px;
  }
}

.membership-table {
  width: 772px;
  overflow: hidden;
  table-layout: fixed;
}

@media (min-width: 768px) {
  .membership-table {
    width: 100%;
    max-width: 1054px;
  }
}

.membership-table-wrap {
  overflow: auto;
  width: calc(100vw - 15px);
}

@media (min-width: 768px) {
  .membership-table-wrap {
    width: 100%;
  }
}

.membership-table th {
  background-color: #F0F0F0;
  border: 1px solid #B2B2B2;
  font-size: 14px;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .membership-table th {
    font-size: 16px;
    line-height: 1.688;
  }
}

.membership-table th.price {
  width: 155px;
  padding: 30px 14px 29px 14px;
}

@media (min-width: 768px) {
  .membership-table th.price {
    width: 200px;
    height: 110px;
  }
}

.membership-table th.price .sub {
  font-size: 14px;
  font-weight: 500;
}

@media (min-width: 768px) {
  .membership-table th.price .sub {
    font-size: 16px;
    line-height: 1.688;
  }
}

.membership-table th.status {
  width: 130px;
  padding: 40px 24px;
}

@media (min-width: 768px) {
  .membership-table th.status {
    width: 200px;
    height: 110px;
  }
}

.membership-table th.point {
  width: 140px;
  padding: 30px 14px 29px 14px;
}

@media (min-width: 768px) {
  .membership-table th.point {
    width: 200px;
    height: 110px;
  }
}

.membership-table th.outlet {
  width: 200px;
  padding: 20px;
  vertical-align: middle;
}

.membership-table th.outlet .sub {
  display: inline-block;
  font-size: 12px;
  line-height: 1.33333;
  letter-spacing: .02em;
  padding-bottom: 3px;
}

@media (min-width: 768px) {
  .membership-table th.outlet {
    width: 210px;
    height: 110px;
    padding-inline: 5px;
  }
}

.membership-table th.sale {
  width: 200px;
  padding: 32px 14px;
}

@media (min-width: 768px) {
  .membership-table th.sale {
    width: 210px;
    height: 110px;
  }
}

.membership-table td {
  border: 1px solid #B2B2B2;
  font-size: 12px;
  line-height: 2.167;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .membership-table td {
    font-size: 14px;
    line-height: 1.857;
  }
}

.membership-table td.price {
  width: 155px;
  height: 65px;
  padding: 10px 20px;
}

@media (min-width: 768px) {
  .membership-table td.price {
    width: 200px;
    height: 110px;
    text-align: center;
  }
}

.membership-table td.price.single {
  padding: 20px;
}

.membership-table td.price .bold {
  font-size: 18px;
  font-weight: bold;
  line-height: 1.667;
  letter-spacing: 0.02em;
  padding-right: 4px;
}

@media (min-width: 768px) {
  .membership-table td.price .bold {
    font-size: 20px;
    line-height: 1.5;
  }
}

.membership-table td.color {
  width: 130px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.875;
  letter-spacing: 0.02em;
  text-align: center;
}

@media (min-width: 768px) {
  .membership-table td.color {
    width: 200px;
    height: 110px;
    font-size: 18px;
    line-height: 1.667;
  }
}

.membership-table td.color.silver {
  background-color: #A0A5AA;
}

.membership-table td.color.black {
  background-color: #323232;
}

.membership-table td.color.red {
  background-color: #EA3323;
}

.membership-table td.color.white {
  color: #323232;
}

.membership-table td.color.white .status-label {
  color: #323232;
}

.membership-table td.color.green {
  background-color: #048E09;
}

.membership-table td.color .status-label {
  display: inline-block;
  color: #fff;
  padding: 6px 10px;
  min-width: 90px;
}

@media (min-width: 768px) {
  .membership-table td.color .status-label {
    min-width: 138px;
  }
}

.membership-table td.color .status-label.silver {
  background-color: #A0A5AA;
}

.membership-table td.color .status-label.black {
  background-color: #323232;
}

.membership-table td.color .status-label.red {
  background-color: #EA3323;
}

.membership-table td.color .status-label.white {
  border: 1px solid #B2B2B2;
  color: #323232;
}

.membership-table td.color .status-label.green {
  background-color: #048E09;
}

.membership-table td.point {
  width: 140px;
  font-size: 14px;
  line-height: 1.857;
  letter-spacing: 0.02em;
  text-align: center;
}

@media (min-width: 768px) {
  .membership-table td.point {
    width: 200px;
    height: 110px;
  }
}

.membership-table td.point .bold {
  font-size: 18px;
  font-weight: bold;
  line-height: 1.667;
  letter-spacing: 0.02em;
  padding-right: 4px;
}

@media (min-width: 768px) {
  .membership-table td.point .bold {
    font-size: 20px;
    line-height: 1.5;
  }
}

.membership-table td.outlet {
  width: 200px;
  font-size: 14px;
  line-height: 1.857;
  letter-spacing: 0.02em;
  text-align: center;
}

@media (min-width: 768px) {
  .membership-table td.outlet {
    width: 210px;
    height: 110px;
  }
}

.membership-table td.outlet .bold {
  font-size: 18px;
  font-weight: bold;
  line-height: 1.667;
  letter-spacing: 0.02em;
  padding-right: 4px;
}

@media (min-width: 768px) {
  .membership-table td.outlet .bold {
    font-size: 20px;
    line-height: 1.5;
  }
}

.membership-table td.sale {
  width: 140px;
  text-align: center;
  padding: 32px 14px;
}

@media (min-width: 768px) {
  .membership-table td.sale {
    width: 210px;
    height: 110px;
  }
}

.membership-table td.sale .bold {
  font-size: 15px;
  font-weight: bold;
  line-height: 2;
}

.membership-note-wrap {
  margin-top: 5px;
  margin-bottom: 55px;
}

@media (min-width: 768px) {
  .membership-note-wrap {
    margin-top: 20px;
    margin-bottom: 60px;
  }
}

.membership-content-ttl {
  margin-bottom: 20px;
}

.membership-content-ttl.info {
  margin-bottom: 5px;
}

@media (min-width: 768px) {
  .membership-content-ttl.info {
    margin-bottom: 10px;
  }
}

.membership-content + .membership-content {
  margin-top: 55px;
}

@media (min-width: 768px) {
  .membership-content + .membership-content {
    margin-top: 45px;
  }
}

.membership-content-border {
  border: 1px solid #B2B2B2;
  padding: 25px 20px 30px 20px;
}

@media (min-width: 768px) {
  .membership-content-border {
    padding: 45px 60px 45px 65px;
  }
}

.membership-content-border-wrap {
  margin-top: 45px;
}

@media (min-width: 768px) {
  .membership-content-border-wrap {
    margin-top: 65px;
  }
}

.membership-content-border-ttl {
  font-size: 16px;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.02em;
}

.membership-content-border-txt {
  font-size: 14px;
  line-height: 1.714;
  letter-spacing: 0.02em;
  position: relative;
  padding-left: 1em;
}

.membership-content-border-txt::before {
  content: "・";
  position: absolute;
  top: 0;
  left: 0;
}

.membership-content-border-txt-wrap {
  margin-top: 10px;
}

.membership-content-border-block + .membership-content-border-block {
  margin-top: 40px;
}

@media (min-width: 768px) {
  .membership-content-border-block + .membership-content-border-block {
    margin-top: 35px;
  }
}

.membership-content-indent-list > li {
  font-size: 14px;
  line-height: 1.857;
  padding-left: 14px;
  text-indent: -14px;
}

.membership-attention-wrap {
  margin-bottom: 62px;
  background-color: #4C4948;
  color: #fff;
  text-align: center;
  padding: 30px;
}

.membership-attention-heading {
  font-size: 16px;
  font-weight: bold;
  line-height: 1.875;
  margin-bottom: 20px;
}

@media (min-width: 768px) {
  .membership-attention-heading {
    font-size: 18px;
    line-height: 1.667;
  }
}

.membership-attention-block {
  max-width: 800px;
  width: 100%;
  margin-inline: auto;
  display: grid;
  grid-template-columns: auto;
  gap: 64px;
  margin-top: 36px;
  position: relative;
}

@media (min-width: 768px) {
  .membership-attention-block {
    grid-template-columns: repeat(2, 1fr);
  }
}

.membership-attention-item {
  padding: 15px 12px 16px;
  text-align: center;
  border: 1px solid #fff;
}

.membership-attention-item.before-item::after {
  content: '';
  display: block;
  width: 18px;
  height: 11px;
  clip-path: polygon(50% 100%, 0 0, 100% 0);
  background-color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

@media (min-width: 768px) {
  .membership-attention-item.before-item::after {
    -webkit-transform: translate(-50%, -50%) rotate(-90deg);
            transform: translate(-50%, -50%) rotate(-90deg);
  }
}

.membership-attention-item.after-item {
  background-color: #fff;
  color: #4C4948;
}

.membership-attention-item.after-item .membership-attention-item-ttl::after {
  background-color: #4C4948;
}

.membership-attention-item-ttl {
  display: inline-block;
  font-weight: bold;
  line-height: 1.5714;
  padding-bottom: 6px;
  position: relative;
}

.membership-attention-item-ttl::after {
  content: '';
  display: block;
  width: 100%;
  height: 1px;
  background-color: #fff;
  position: absolute;
  left: 0;
  bottom: 0;
}

.membership-attention-data {
  margin-top: 14px;
}

.membership-attention-data-txt {
  font-size: 16px;
  font-weight: bold;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  gap: 4px;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  padding-top: 7px;
}

.membership-attention-data-txt.strong-txt {
  font-size: 20px;
}

.membership-attention-data-txt .unit-txt {
  font-weight: normal;
  font-size: 14px;
}

.border {
  border-top: 1px solid #B2B2B2;
  padding-top: 20px;
}

@media (min-width: 768px) {
  .border {
    padding-top: 35px;
  }
}

.border-block {
  margin-top: 50px;
}

.border-block:first-of-type {
  margin-top: 0;
}

@media (min-width: 768px) {
  .border-block-wrap {
    width: 100%;
    max-width: 1054px;
  }
}

.border + .border {
  margin-top: 20px;
}

.border-note {
  position: relative;
  font-size: 13px;
  line-height: 1.615;
  letter-spacing: 0.02em;
  margin-top: 10px;
  padding-left: 18px;
}

@media (min-width: 768px) {
  .border-note {
    margin-top: 5px;
  }
}

.border-note::before {
  content: "※";
  position: absolute;
  top: 0;
  left: 0;
}

.border:last-child {
  border-bottom: 1px solid #B2B2B2;
  padding-bottom: 20px;
}

@media (min-width: 768px) {
  .border:last-child {
    padding-bottom: 35px;
  }
}

.accordion-content {
  display: none;
}

@media (min-width: 1044px) {
  .accordion-content {
    display: block;
  }
}

.breadcrumb-list {
  padding: 10px 15px 12px;
  width: 100%;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow-x: auto;
}

@media (min-width: 768px) {
  .breadcrumb-list {
    padding: 10px 20px;
    max-width: 1044px;
  }
}

.breadcrumb-list-wrap {
  background-color: #F6F6F6;
}

.breadcrumb-list > li {
  margin-right: 15px;
  display: inline-block;
  position: relative;
  font-size: 10px;
  color: #333;
  font-weight: 500;
  white-space: nowrap;
}

@media (min-width: 768px) {
  .breadcrumb-list > li {
    margin-right: 24px;
    font-size: 11px;
  }
}

.breadcrumb-list > li:after {
  font-family: "myfont";
  content: "\EA04";
  position: absolute;
  right: -14px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  color: #808080;
  font-size: 10px;
}

@media (min-width: 768px) {
  .breadcrumb-list > li:after {
    right: -20px;
    font-size: 12px;
  }
}

.breadcrumb-list > li:last-child {
  margin-right: 0;
}

.breadcrumb-list > li:last-child:after {
  content: none;
}

.breadcrumb-list > li a {
  color: #333;
}

.breadcrumb-list > li a::after {
  -webkit-transition: .3s;
  transition: .3s;
  display: block;
  content: "";
  width: 100%;
  position: absolute;
  bottom: 1px;
  right: 0;
  border-bottom: 1px solid #333;
  opacity: 0;
}

.breadcrumb-list > li a:hover::after {
  opacity: 1;
}

.def-item {
  position: relative;
}

@media (min-width: 768px) {
  .def-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.def-item + .def-item {
  margin-top: 30px;
}

.def-item a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  color: #333;
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 768px) {
  .def-item a {
    width: 100%;
  }
}

@media (min-width: 768px) {
  .def-item a:hover {
    opacity: 0.7;
  }
}

.def-item-wrap {
  padding: 34px 0;
  margin: 0 auto;
  max-width: 1024px;
}

@media (min-width: 768px) {
  .def-item-wrap {
    padding: 50px 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

.def-item-new {
  width: 60px;
  padding: 5px 0;
  font-size: 11px;
  font-weight: bold;
  line-height: 1.455;
  text-align: center;
  color: #fff;
  background-color: #000;
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 5;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
}

.def-item-img {
  width: 100%;
  background-color: #fff;
  position: relative;
}

.def-item-img:before {
  display: block;
  content: "";
  width: 100%;
  padding-top: 56.776%;
}

.def-item-img img {
  position: absolute;
  top: 50%;
  left: 50%;
  right: 50%;
  bottom: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: auto;
  max-width: 100%;
  max-height: 100%;
}

.def-item-detail {
  margin-top: 17px;
}

.def-item-detail-head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 14px;
}

.def-item-detail-date {
  font-size: 13px;
  padding-top: 8px;
  margin-top: 8px;
}

.def-item-detail-txt {
  margin-left: 11px;
  font-size: 13px;
  font-weight: 500;
  color: #666464;
  letter-spacing: 0.1em;
}

.def-item-tag {
  display: inline-block;
  padding: 2px 8px 2px;
  font-size: 11px;
  line-height: 1.455;
  min-width: 78px;
  text-align: center;
  color: #fff;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  font-weight: 500;
  background-color: #4C4948;
  letter-spacing: 0.1em;
}

.def-item-tag.event {
  background-color: #ED5163;
}

.def-item-tag.designer-interview {
  background-color: #808080;
}

.def-item-tag.fashion {
  background-color: #4C4948;
}

.def-item-tag.gift {
  background-color: #7B584D;
}

.def-item-tag.bridal {
  background-color: #569819;
}

.def-item-tag.window-display {
  background-color: #BC8EB1;
}

.def-item-tag.art-and-design {
  background-color: #A36575;
}

.def-item-tag.food {
  background-color: #183C7C;
}

.def-item-tag.activities {
  background-color: #78A095;
}

.def-item-tag.tag-store {
  width: 74px;
  background-color: #333;
}

.def-item-tag.tag-long {
  width: 128px;
}

.def-item-ttl {
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.def-item-txt {
  margin-top: 10px;
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: 0;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-top: 2px;
  font-size: 12px;
}

.def-item-detail {
  margin-top: 10px;
}

.def-item-detail-head {
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  letter-spacing: 0.1em;
  margin-bottom: 10px;
}

.def-item-detail-tag, .def-item-detail-txt {
  font-size: 11px;
}

.def-item-detail-date {
  font-size: 10px;
  color: #999;
  border: none;
  padding: 0;
  margin-top: 10px;
}

.def-item-border {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.def-item-border + .def-item-border {
  margin-top: 44px;
}

@media (min-width: 768px) {
  .def-item-border + .def-item-border {
    margin-top: 54px;
  }
}

@media (min-width: 768px) {
  .def-item-border:nth-child(-n+3) {
    margin-top: 0;
  }
}

.def-item-border a {
  border: 1px solid #B2B2B2;
  padding: 28px 25px 17px;
  background-color: #fff;
  width: 100%;
}

.def-item-border .def-item-ttl {
  font-size: 16px;
  -webkit-line-clamp: initial;
  word-break: break-word;
}

.def-item-border .def-item-ttl.small-ttl {
  font-size: 14px;
  margin-bottom: 5px;
}

.def-item-border .def-item-txt {
  -webkit-line-clamp: 2;
}

.def-item-border .def-item-new {
  left: 17px;
}

.def-item-border .def-item-detail-date {
  border-top: none;
  padding-top: 0;
  margin-top: 7px;
}

.modal-target {
  display: none;
}

.modaal-container .modaal-content-container {
  padding: 37px 4.1791%;
}

@media (min-width: 768px) {
  .modaal-container .modaal-content-container {
    padding: 50px 11.52344%;
  }
}

.modaal-container .modaal-close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 20px;
  height: 20px;
  z-index: 2;
}

@media (min-width: 768px) {
  .modaal-container .modaal-close {
    top: 10px;
    right: 10px;
  }
}

.modaal-container .modaal-close:before {
  display: none;
}

.modaal-container .modaal-close:after {
  position: absolute;
  top: 0;
  left: 0;
  content: url(../images/common/close_01.svg);
  -webkit-transform: none;
          transform: none;
}

.modaal-container .modaal-close:hover:after {
  background: none;
}

.tab-content .tab-panel {
  display: none;
}

.tab-content .tab-panel.is-show {
  display: block;
}

/* カテゴリ */
.category-list {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background-color: #fff;
}

.category-list + .category-list {
  margin-left: 18px;
}

.category-list a {
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  display: block;
  padding: 4px 10px;
  height: 48px;
  border: 1px solid #B2B2B2;
  color: #333;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transition: .3s;
  transition: .3s;
  font-size: 12px;
}

.category-list a:hover {
  color: #fff;
  background-color: #333;
}

.category-list a.is-current {
  color: #fff;
  background-color: #333;
}

.category-list-container {
  margin: 0 -15px 20px;
}

@media (min-width: 768px) {
  .category-list-container {
    overflow: hidden;
    text-align: center;
    margin: 0 0 40px;
  }
}

.category-list-block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 26px 15px;
  background-color: #808080;
  overflow-x: scroll;
  width: 100%;
}

@media (min-width: 768px) {
  .category-list-block {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    padding: 0 0 10px 0;
    background-color: #F2F2F2;
    -ms-overflow-style: none;
  }
  .category-list-block::-webkit-scrollbar {
    width: 4px;
    height: 4px;
  }
  .category-list-block::-webkit-scrollbar-thumb {
    border-radius: 10px;
  }
  .category-list-block::-webkit-scrollbar-thumb {
    --bg-opacity: 1;
    background-color: #B2B2B2;
  }
}

.category-list-parent {
  display: block;
}

_:lang(x)::-moz-placeholder, .category-list-block {
  scrollbar-width: thin;
  scrollbar-color: #B2B2B2;
}

.modal-map {
  font-size: 12px;
}

.modal-map-ttl {
  padding: 8px 0px 9px;
}

@media (min-width: 768px) {
  .modal-map-ttl {
    font-size: 16px;
  }
}

.modal-map-info {
  padding-bottom: 20px;
  color: #DA2128;
}

.modal-map .roppongi-map {
  margin: 15px 0;
}

.modal-map .google-maps {
  padding-bottom: 24px;
  margin: 0;
  font-size: 13px;
}

.modal-map table {
  width: 100%;
  font-size: 10px;
}

@media (min-width: 768px) {
  .modal-map table {
    font-size: 12px;
  }
}

.modal-map table.parking-service {
  margin: 10px 0;
  font-size: 0.8em;
}

@media (min-width: 768px) {
  .modal-map table.parking-service {
    margin-bottom: 20px;
  }
}

.modal-map table.parking-service td {
  border: 1px solid #939598;
  padding: 5px;
  width: 25%;
  text-align: center;
}

@media (min-width: 768px) {
  .modal-map table.parking-service td {
    vertical-align: middle;
  }
}

.modal-map table.parking-service td.n-lr {
  border-left: none;
  border-right: none;
}

.modal-map table.parking-service td.n-l {
  border-left: none;
}

.modal-map table.parking-service td.n-tb {
  border-top: none;
  border-bottom: none;
}

.modal-map table.parking-service td.n-t {
  border-top: none;
}

.modal-map table.parking-service td.n-b {
  border-bottom: none;
}

.modal-map table.parking-service td.n-r {
  border-right: none;
}

.modal-map table.parking-service td.t-l {
  text-align: center;
  padding-left: 0;
}

.modal-map .txt-link {
  color: #EA3323;
}

.modal-map .txt-link:after {
  border-color: #EA3323;
}

.error-ttl {
  letter-spacing: 0.03em;
}

.error-txt {
  letter-spacing: 0.02em;
  font-size: 14px;
  line-height: 1.71429;
}

@media (min-width: 768px) {
  .error-txt {
    font-size: 14px;
    line-height: 1.85714;
  }
}

.error-txt-wrap {
  margin-top: 54px;
  text-align: center;
}

@media (min-width: 768px) {
  .error-txt-wrap {
    margin-top: 60px;
  }
}

.movie-item {
  position: relative;
  width: 100%;
}

.movie-item:before {
  display: block;
  content: "";
  width: 100%;
  padding-top: 56.776%;
}

.movie-item iframe {
  position: absolute;
  top: 50%;
  left: 50%;
  right: 50%;
  bottom: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  max-width: 560px;
  max-height: 315px;
}

.public-notice-block {
  margin-top: 50px;
}

@media (min-width: 768px) {
  .public-notice-block {
    margin-top: 75px;
  }
}

.public-notice-list li {
  padding-top: 20px;
  padding-bottom: 20px;
  border-top: 1px solid #B2B2B2;
}

@media (min-width: 768px) {
  .public-notice-list li {
    padding-top: 16px;
  }
}

.public-notice-list li:last-of-type {
  border-bottom: 1px solid #B2B2B2;
}

.public-notice-list .link-more:before {
  top: 2px;
}

.public-notice-date {
  margin-bottom: 5px;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .public-notice-date {
    margin-bottom: 12px;
  }
}

.public-notice-ttl {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.public-notice-ttl.has-icon {
  font-size: 12px;
  line-height: 1.75;
  padding-right: 18px;
  padding-left: 0;
  font-weight: 700;
}

@media (min-width: 768px) {
  .public-notice-ttl.has-icon {
    font-size: 14px;
  }
}

.public-notice-ttl.has-icon [class*="icon-"] {
  font-size: 12px;
  position: absolute;
  right: 0;
  top: 4px;
}

.public-notice-ttl.has-icon .public-notice-size {
  font-weight: 500;
}

@media (min-width: 768px) {
  .public-notice-ttl.has-icon .public-notice-size {
    font-size: 14px;
  }
}

.public-notice-size {
  font-size: 14px;
  font-weight: 400;
  display: inline-block;
  padding-left: 8px;
}

.text-center {
  text-align: center;
}

.concierge-kv-txt {
  font-size: 14px;
  font-weight: 700;
}

.concierge-list {
  margin-top: 60px !important;
}

.concierge-list-img {
  width: 60px;
  height: 60px;
  margin: 0 auto;
}

.concierge-list-name {
  font-size: 14px;
  text-align: left;
}

.concierge-list-name-en {
  font-family: 'brown-bold',"Lucida Grande","Hiragino Kaku Gothic Pro",Verdana,メイリオ,Meiryo,"MS PGothic","MS UI Gothic",Arial,  sans-serif;
  font-size: 22px;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.12em;
}

.concierge-list-name-wrap {
  margin-top: 20px;
}

.concierge-list-border {
  width: 100%;
  height: 2px;
  background-color: #251E1C;
  margin: 20px 0 26px;
}

@media (min-width: 768px) {
  .text-center {
    text-align: center;
  }
  .concierge-kv-txt {
    font-size: 16px;
  }
  .concierge-list {
    margin-top: 42px !important;
  }
  .concierge-list:nth-of-type(3), .concierge-list:nth-of-type(4) {
    margin-top: 100px !important;
  }
  .concierge-list-img {
    width: 88px;
    height: 88px;
    margin: 0 auto;
  }
  .concierge-list-name {
    font-size: 14px;
    text-align: center;
  }
  .concierge-list-name-en {
    font-family: 'brown-bold',"Lucida Grande","Hiragino Kaku Gothic Pro",Verdana,メイリオ,Meiryo,"MS PGothic","MS UI Gothic",Arial,  sans-serif;
    font-size: 29px;
    font-weight: bold;
    text-align: center;
    letter-spacing: 0.12em;
  }
  .concierge-list-name-wrap {
    margin-top: 20px;
  }
  .concierge-list-border {
    width: 100%;
    height: 2px;
    background-color: #251E1C;
    margin: 26px 0 30px;
  }
}

.link-wrapper-block {
  display: block;
}

@media (min-width: 768px) {
  .link-wrapper-block {
    -webkit-transition: .3s;
    transition: .3s;
  }
}

@media (min-width: 768px) {
  .link-wrapper-block:hover {
    opacity: 0.7;
  }
}

.grid-item-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px 10px;
}

@media (min-width: 768px) {
  .grid-item-list {
    grid-template-columns: repeat(3, 1fr);
  }
}

.grid-item-ring .credit {
  margin-top: 4px;
  text-align: center;
}

.bg-gray {
  background-color: #F2F2F2;
  padding: 14px;
}

@media (min-width: 768px) {
  .bg-gray {
    padding: 24px;
  }
}

.group-item {
  margin-inline: auto;
  margin-top: auto;
}

.group-item .btn {
  width: 200px;
  font-size: 14px;
}

@media (min-width: 768px) {
  .group-item .btn {
    width: 240px;
    font-size: 16px;
  }
}

.group-item .btn-black {
  padding-bottom: 12px;
}

.group-logo {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 100%;
}

.group-logo + .group-logo {
  margin-top: 85px;
}

@media (min-width: 768px) {
  .group-logo + .group-logo {
    margin-top: 0;
  }
}

.group-logo a {
  display: block;
}

.group-logo-img {
  width: 36%;
  max-width: 220px;
  margin-inline: auto;
  padding-bottom: 20px;
}

@media (min-width: 768px) {
  .group-logo-img {
    width: 100%;
    max-width: 160px;
    padding-bottom: 30px;
  }
}

.group-logo-img a {
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 768px) {
  .group-logo-img a:hover {
    opacity: 0.7;
  }
}

@media (min-width: 768px) {
  .group-logo-container {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    place-content: center;
    place-items: center;
    grid-row-gap: 60px;
  }
}

.group-logo-container .btn {
  padding-right: 20px;
}

.group-logo-center {
  grid-column: 1 / span 3;
}

.group-logo-center .group-logo-img {
  padding-bottom: 0;
  width: 50%;
  max-width: 300px;
}

@media (min-width: 768px) {
  .group-logo-center .group-logo-img {
    width: 100%;
    max-width: 160px;
  }
}

/*ページャ*/
.nav-links {
  margin: 35px auto 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-transform: .3s;
          transform: .3s;
}

@media (min-width: 768px) {
  .nav-links {
    margin: 41px auto 0;
  }
}

.nav-links .page-numbers {
  width: 80px;
  text-align: center;
  font-size: 16px;
  letter-spacing: 0.04em;
  font-weight: 500;
}

.nav-links .prev, .nav-links .next {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.nav-links [class*="icon-"] {
  color: #333;
  font-size: 15px;
}

@media (min-width: 768px) {
  .nav-links a:hover {
    opacity: 0.7;
  }
}

.nav-heading {
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
}

.nav-years {
  margin-top: 30px;
  margin-bottom: -10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media (min-width: 768px) {
  .nav-years {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
}

.nav-years-block {
  margin-top: 50px;
}

.nav-years li {
  margin-bottom: 10px;
  padding: 0 21px;
  border-left: 1px solid #808080;
}

.nav-years li:last-child {
  border-right: 1px solid #808080;
}

.nav-years li a {
  color: #333;
  font-size: 12px;
  letter-spacing: 0.04em;
  font-weight: 500;
  position: relative;
}

.nav-years li a::after {
  -webkit-transition: .3s;
  transition: .3s;
  display: block;
  content: "";
  width: 100%;
  position: absolute;
  bottom: 1px;
  right: 0;
  border-bottom: 1px solid #333;
  opacity: 0;
}

.nav-years li a:hover::after {
  opacity: 1;
}

/* 
ユニークな記事詳細ページのCSS
*/
.unique-inner h2.section-ttl {
  border: none;
  margin-bottom: 0;
  padding: 0;
}

.unique-inner .detail-heading-wrap {
  text-align: center;
}

.unique-inner .detail-ttl {
  font-size: 24px;
  line-height: 1.25;
  letter-spacing: 0.03em;
}

@media (min-width: 768px) {
  .unique-inner .detail-ttl {
    font-size: 30px;
  }
}

.unique-inner .detail-subttl {
  font-size: 16px;
  color: #808080;
}

.unique-inner .detail-mv {
  margin-bottom: 32px;
}

.unique-inner .detail-lead {
  font-size: 12px;
  margin-bottom: 40px;
}

@media (min-width: 768px) {
  .unique-inner .detail-lead {
    margin-bottom: 30px;
  }
}

.unique-inner .event-schedule {
  text-align: center;
  margin-bottom: 18px;
}

@media (min-width: 768px) {
  .unique-inner .event-schedule {
    margin-bottom: 45px;
  }
}

.unique-inner .event-schedule-date {
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  font-weight: 700 !important;
  font-size: 28px;
  letter-spacing: 0.02em;
  color: #9F8E64;
  margin-bottom: 8px;
}

@media (min-width: 768px) {
  .unique-inner .event-schedule-date {
    margin-bottom: 20px;
  }
}

.unique-inner .event-schedule-place {
  margin-bottom: 10px;
}

.unique-inner .event-schedule-place a {
  font-size: 12px;
  position: relative;
}

.unique-inner .event-schedule-place a + a {
  padding-left: 10px;
}

.unique-inner .event-schedule-place a + a:before {
  content: "/";
  position: absolute;
  top: -1px;
  left: 0px;
}

.unique-inner .event-schedule-att {
  font-size: 10px;
  line-height: 1.9;
  letter-spacing: 0.02em;
}

.unique-inner .bridal-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-bottom: -5px;
}

@media (min-width: 768px) {
  .unique-inner .bridal-list {
    max-width: 790px;
    margin: 0 auto;
  }
}

.unique-inner .bridal-list.is-fixed {
  position: fixed;
  top: 45px;
  left: 0;
  z-index: 10;
  background-color: #fff;
}

@media (min-width: 1044px) {
  .unique-inner .bridal-list.is-fixed {
    top: 99px;
  }
}

.unique-inner .bridal-list li {
  display: block;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: calc((100% - 5px) / 2);
  margin-bottom: 5px;
}

@media (min-width: 768px) {
  .unique-inner .bridal-list li {
    width: calc((100% - 10px) / 3);
    margin-bottom: 0;
  }
}

.unique-inner .bridal-list li:nth-of-type(2) {
  margin-left: 5px;
}

.unique-inner .bridal-list li:nth-of-type(2) a {
  font-size: 10px;
}

@media (min-width: 768px) {
  .unique-inner .bridal-list li:nth-of-type(2) a {
    font-size: 12px;
  }
}

.unique-inner .bridal-list li:last-of-type {
  width: 100%;
}

@media (min-width: 768px) {
  .unique-inner .bridal-list li:last-of-type {
    margin-left: 5px;
    width: calc((100% - 10px) / 3);
  }
}

.unique-inner .bridal-list li:last-of-type a {
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
}

.unique-inner .bridal-list a {
  background-color: #DEF2FD;
  color: #9F8E64;
  display: block;
  font-size: 12px;
  font-weight: 700;
  height: 100%;
  min-height: 44px;
  padding: 7px 6px;
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 768px) {
  .unique-inner .bridal-list a {
    min-height: 68px;
    padding: 11px 10px 10px;
  }
}

@media (min-width: 768px) {
  .unique-inner .bridal-list a:hover {
    background-color: #9F8E64;
    color: #fff;
    position: relative;
  }
  .unique-inner .bridal-list a:hover:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    border-style: solid;
    border-color: transparent transparent #fff transparent;
    border-width: 0 7.5px 7px 7.5px;
  }
}

.unique-inner .bridal-list a span {
  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;
  height: 100%;
  letter-spacing: 0.02em;
  font-weight: 700;
}

.unique-inner .bridal-list-wrap {
  margin-bottom: 40px;
}

.unique-inner .bridal-event-section + .bridal-event-section {
  margin-top: 80px;
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-section + .bridal-event-section {
    margin-top: 100px;
  }
}

.unique-inner .bridal-event-section-lead {
  font-size: 12px;
  line-height: 1.58333;
  letter-spacing: 0.02em;
  margin-top: 30px;
}

.unique-inner .bridal-event-section-wrap {
  padding: 0 10px;
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-section-wrap {
    padding: 0;
    max-width: 790px;
    margin: 0 auto;
  }
}

.unique-inner .bridal-event-section .section-ttl {
  color: #9F8E64;
  font-size: 18px;
  line-height: 1.44444;
  font-weight: bold;
  letter-spacing: 0.02em;
  text-align: center;
}

.unique-inner .bridal-event-section .section-ttl-wrap {
  background-color: #DEF2FD;
  padding: 12px;
  margin-bottom: 30px;
}

.unique-inner .bridal-event-section .section-ttl-en {
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  letter-spacing: 0.02em;
  font-weight: 700 !important;
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-section .section-ttl-en {
    letter-spacing: 0.12em;
  }
}

.unique-inner .bridal-event-label {
  background-color: #53A4DB;
  padding: 12px;
  text-align: center;
  width: 220px;
}

.unique-inner .bridal-event-label span {
  color: #fff;
  font-size: 16px;
  line-height: 1;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  font-weight: 700 !important;
  letter-spacing: 0.02em;
}

.unique-inner .bridal-event-label + .bridal-event-block {
  margin-top: 40px;
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-label + .bridal-event-block {
    margin-top: 32px;
  }
}

.unique-inner .bridal-event-block + .bridal-event-block {
  margin-top: 40px;
}

.unique-inner .bridal-event-block-border {
  padding-top: 30px;
  border-top: 1px dotted #B7DBF6;
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-block-border {
    margin-top: 60px;
    padding-top: 40px;
  }
}

.unique-inner .bridal-event-block-ttl {
  color: #53A4DB;
  font-size: 20px;
  line-height: 1.3;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  font-weight: 700 !important;
  letter-spacing: 0.12em;
  margin-bottom: 25px;
}

.unique-inner .bridal-event-block .sub-ttl {
  display: block;
  color: #9F8E64;
  font-size: 12px;
  line-height: 1.75;
  font-weight: 500;
  letter-spacing: 0.02em;
  margin-top: 5px;
}

.unique-inner .bridal-event-block .sub-ttl-under {
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  font-size: 16px;
  margin-bottom: 10px;
  margin-top: 0;
  letter-spacing: 0.12em;
}

.unique-inner .bridal-event-intro {
  font-size: 12px;
  line-height: 1.58333;
  letter-spacing: 0.02em;
  margin-top: 24px;
}

.unique-inner .bridal-event-intro + .bridal-event-intro {
  margin-top: 18px;
}

.unique-inner .bridal-event-intro-small {
  font-size: 10px;
  letter-spacing: 0.02em;
  margin-top: 24px;
}

.unique-inner .bridal-event-another {
  margin-top: 40px;
}

.unique-inner .bridal-event-another-link {
  display: block;
  background-color: #fff;
  font-size: 12px;
  line-height: 1.75;
  letter-spacing: 0.02em;
  border: 1px solid #53A4DB;
  padding: 19px 10px 18px;
  text-align: center;
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-another-link {
    -webkit-transition: .3s;
    transition: .3s;
    padding-top: 29px;
    padding-bottom: 29px;
  }
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-another-link:hover {
    opacity: 0.7;
  }
}

.unique-inner .bridal-event-another-link.no-border {
  border: none;
  padding-top: 15px;
  padding-bottom: 14px;
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-another-link.no-border {
    max-width: 340px;
    margin: 0 auto;
  }
}

.unique-inner .bridal-event-another-link span {
  color: #53A4DB;
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-swiper-set {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    position: relative;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

.unique-inner .bridal-event-swiper-container {
  overflow: hidden;
}

.unique-inner .bridal-event-swiper-main {
  position: relative;
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-swiper-main {
    width: calc(100% - 395px);
    position: unset;
  }
}

.unique-inner .bridal-event-swiper-main .swiper-item-img {
  position: relative;
}

.unique-inner .bridal-event-swiper-main .swiper-item-img:before {
  display: block;
  content: "";
  width: 100%;
  padding-top: 85.233%;
}

.unique-inner .bridal-event-swiper-main .swiper-item-img img {
  position: absolute;
  top: 50%;
  left: 50%;
  right: 50%;
  bottom: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: auto;
  max-width: 100%;
  max-height: 100%;
}

.unique-inner .bridal-event-swiper-detail {
  margin-top: 24px;
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-swiper-detail {
    width: 350px;
  }
}

.unique-inner .bridal-event-swiper-detail .product-brand {
  font-size: 16px;
  line-height: 1.625;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  font-weight: 700 !important;
  letter-spacing: 0.12em;
  text-align: center;
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-swiper-detail .product-brand {
    text-align: left;
  }
}

.unique-inner .bridal-event-swiper-detail .product-name {
  font-size: 12px;
  line-height: 1.75;
  font-weight: 700;
  color: #585858;
  margin-top: 25px;
  text-align: center;
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-swiper-detail .product-name {
    text-align: left;
  }
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-swiper-detail .bridal-event-intro {
    margin-top: 22px;
  }
}

.unique-inner .bridal-event-swiper-thumbnail {
  margin-top: 30px;
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-swiper-thumbnail {
    margin-top: 45px;
  }
}

.unique-inner .bridal-event-swiper-thumbnail .swiper-wrapper {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding-bottom: 2px;
}

.unique-inner .bridal-event-swiper-thumbnail .swiper-slide-thumb-active:after {
  content: "";
  position: absolute;
  background-color: rgba(223, 242, 252, 0.5);
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

.unique-inner .bridal-event-swiper-thumbnail .swiper-item-img {
  position: relative;
  border: 1px solid #AAAAAA;
  width: calc((100% - 18px) / 4);
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-swiper-thumbnail .swiper-item-img {
    width: calc((100% - 84px) / 4);
    cursor: pointer;
  }
}

.unique-inner .bridal-event-swiper-thumbnail .swiper-item-img + .swiper-item-img {
  margin-left: 6px;
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-swiper-thumbnail .swiper-item-img + .swiper-item-img {
    margin-left: 28px;
  }
}

.unique-inner .bridal-event-swiper-thumbnail .swiper-item-img:before {
  display: block;
  content: "";
  width: 100%;
  padding-top: 98%;
}

.unique-inner .bridal-event-swiper-thumbnail .swiper-item-img img {
  position: absolute;
  top: 50%;
  left: 50%;
  right: 50%;
  bottom: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: auto;
  max-width: 96%;
  max-height: 96%;
}

.unique-inner .bridal-event-present-block {
  margin-top: 30px;
}

.unique-inner .bridal-event-present-inner {
  background-color: #F0F0F0;
  padding: 20px 15px;
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-present-inner {
    padding: 30px 25px;
  }
}

.unique-inner .bridal-event-present-txt {
  font-size: 12px;
  line-height: 1.58333;
  letter-spacing: 0.02em;
  margin-bottom: 25px;
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-present-txt {
    margin-bottom: 0;
  }
}

.unique-inner .bridal-event-present-txt:last-of-type {
  margin-bottom: 0;
}

.unique-inner .bridal-event-present-txt .present-txt-bold {
  font-weight: 700;
  color: #9F8E64;
}

.unique-inner .bridal-event-present-item {
  margin-top: 40px;
}

.unique-inner .bridal-event-present-item-inner {
  border: 1px solid #009BDF;
  padding: 20px 14px 30px;
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-present-item-inner {
    padding: 20px 20px 38px;
  }
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-present-item-inner .bridal-event-present-inner {
    padding: 11px 15px;
  }
}

.unique-inner .bridal-event-present-item .present-item-block {
  margin-top: 20px;
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-present-item .present-item-block {
    margin: 40px auto 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    max-width: 615px;
  }
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-present-item .present-item-block.present-item-block-vertical {
    display: block;
  }
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-present-item .present-item-block .bridal-event-present-txt {
    width: calc(100% - 250px);
  }
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-present-item .present-item-block .bridal-event-gift-card {
    width: 215px;
    margin-left: 35px;
  }
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-present-item .present-item-block-separate {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    max-width: 615px;
  }
}

.unique-inner .bridal-event-present-item .present-item-block-separate + .present-item-block-separate {
  margin-top: 40px;
  padding-top: 40px;
  border-top: 1px dotted #B7DBF6;
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-present-item .present-item-block-separate + .present-item-block-separate {
    display: block;
  }
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-present-item .present-item-block-separate .bridal-event-present-txt {
    width: 100%;
    margin-bottom: 25px;
  }
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-present-item .present-item-block-separate .bridal-event-present-txt:last-of-type {
    margin-bottom: 0;
  }
}

.unique-inner .bridal-event-present-item .present-item-block-separate .bridal-event-present-txt-wrap {
  margin-bottom: 25px;
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-present-item .present-item-block-separate .bridal-event-present-txt-wrap {
    margin-bottom: 0;
    width: calc(100% - 250px);
  }
}

.unique-inner .bridal-event-list {
  padding-bottom: 0;
}

@media (min-width: 768px) {
  .unique-inner .bridal-event-list .def-item {
    width: calc((100% - 40px) / 3);
    margin-right: 20px;
  }
  .unique-inner .bridal-event-list .def-item + .def-item {
    margin-top: 0;
  }
  .unique-inner .bridal-event-list .def-item:nth-of-type(3n) {
    margin-right: 0;
  }
  .unique-inner .bridal-event-list .def-item:nth-of-type(n+4) {
    margin-top: 30px;
  }
}

/* 
swiper fade
*/
.swiper-fade.swiper-free-mode .swiper-slide {
  -webkit-transition-timing-function: ease-out;
          transition-timing-function: ease-out;
}

.swiper-fade .swiper-slide {
  pointer-events: none;
  -webkit-transition-property: opacity;
  transition-property: opacity;
}

.swiper-fade .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-fade .swiper-slide-active,
.swiper-fade .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.primary {
  padding: 45px 15px 80px 15px;
}

@media (min-width: 768px) {
  .primary {
    margin: 0 auto;
    width: 100%;
    max-width: 1054px;
    padding: 75px 15px 140px 15px;
  }
}

@media (min-width: 768px) {
  .primary.noenquiry {
    padding: 75px 15px 310px 15px;
  }
}

.primary-ttl {
  font-size: 18px;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .primary-ttl {
    font-size: 20px;
  }
}

.primary-ttl-wrap {
  text-align: center;
  margin-bottom: 30px;
}

@media (min-width: 768px) {
  .primary-ttl-wrap {
    margin-bottom: 65px;
  }
}

.primary-ttl-content {
  margin-bottom: 30px;
}

@media (min-width: 768px) {
  .primary-ttl-content {
    margin-bottom: 55px;
  }
}

@media (min-width: 768px) {
  .primary-ttl-content.privacy {
    margin-bottom: 65px;
  }
}

.primary-content + .primary-content {
  margin-top: 30px;
}

@media (min-width: 768px) {
  .primary-content + .primary-content {
    margin-top: 40px;
  }
}

@media (min-width: 768px) {
  .primary-content + .primary-content.privacy {
    margin-top: 30px;
  }
}

.primary-content-ttl {
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.02em;
  line-height: 1.5;
}

@media (min-width: 768px) {
  .primary-content-ttl {
    font-size: 18px;
  }
}

.primary-content-ttl a {
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 768px) {
  .primary-content-ttl a:hover {
    opacity: 0.7;
  }
}

.primary-content-ttl.border {
  padding: 15px 0;
  margin-bottom: 20px;
  border-top: 1px solid #B2B2B2;
  border-bottom: 1px solid #B2B2B2;
}

.primary-content-wrap {
  margin-bottom: 50px;
}

@media (min-width: 768px) {
  .primary-content-wrap {
    margin-bottom: 116px;
  }
}

.primary-content-list > li {
  position: relative;
  padding-left: 1em;
  line-height: 1.85;
}

.primary-content-list > li:before {
  content: "・";
  position: absolute;
  top: 0;
  left: 0;
}

.primary-content-list-number {
  margin-top: 12px;
  counter-reset: my-counter;
}

.primary-content-list-number > li {
  font-size: 14px;
  line-height: 1.714;
  letter-spacing: 0.02em;
  padding-left: 1em;
  position: relative;
}

.primary-content-list-number > li:before {
  content: counter(my-counter);
  counter-increment: my-counter;
  position: absolute;
  top: 5px;
  left: 0;
  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;
  font-size: 50%;
  height: 14px;
  width: 14px;
  border: 0.5px solid;
  border-radius: 50%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  letter-spacing: -0.04em;
}

.primary-content-list-link {
  margin-top: 15px;
}

@media (min-width: 768px) {
  .primary-content-list-link {
    margin-top: 30px;
  }
}

.primary-content-list-link > li {
  text-decoration: underline;
  padding-bottom: 24px;
  line-height: 1.714;
  letter-spacing: 0.02em;
}

.primary-content-list-link > li:last-child {
  padding-bottom: 0;
}

@media (min-width: 768px) {
  .primary-content-list-link > li {
    padding-bottom: 0;
    line-height: 1.857;
  }
}

.primary-content-list-link a {
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 768px) {
  .primary-content-list-link a:hover {
    opacity: 0.7;
  }
}

.primary-content-sign {
  margin-top: 40px;
  text-align: right;
}

.primary-def {
  font-size: 14px;
  line-height: 1.714;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .primary-def {
    line-height: 1.857;
  }
}

.primary-def.list {
  padding-top: 35px;
}

.primary-def.wrap {
  margin-top: 12px;
}

.enquiry-ttl {
  font-size: 16px;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.02em;
}

.enquiry-content {
  background-color: #F2F2F2;
  padding: 35px 25px;
}

.enquiry-content-wrap {
  text-align: center;
  margin-top: 20px;
}

@media (min-width: 768px) {
  .enquiry-content-wrap {
    margin-top: 17px;
  }
}

.enquiry-content-ttl {
  font-size: 22px;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.04em;
}

@media (min-width: 768px) {
  .enquiry-content-ttl {
    font-size: 24px;
  }
}

.enquiry-content-subttl {
  font-size: 18px;
  font-weight: bold;
  line-height: 1.444;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .enquiry-content-subttl {
    font-size: 20px;
  }
}

.enquiry-content-detail {
  font-size: 14px;
  font-weight: bold;
  margin-top: 10px;
  line-height: 1.571;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .enquiry-content-detail {
    font-size: 16px;
  }
}

.enquiry-content-annotation {
  font-size: 12px;
  line-height: 1.75;
  letter-spacing: 0.02em;
  margin-top: 5px;
}

@media (min-width: 768px) {
  .link {
    padding: 75px 15px 195px 15px;
  }
}

.link a {
  color: #333;
}

.link-block {
  display: block;
}

@media (min-width: 768px) {
  .link-block {
    display: inline;
  }
}

.search-results-wrap {
  padding: 37px 15px 260px;
  max-width: 1054px;
  margin: 0 auto;
}

.search-results-ttl-txt {
  padding-left: 7.5px;
}

.search-results-ttl-wrap {
  margin-bottom: 32px;
}

.search-results-hit {
  margin-bottom: 60px;
}

.search-results-hit-txt {
  padding-left: 3.5px;
}

.search-results-block {
  border-bottom: 1px solid #B2B2B2;
  padding-bottom: 29.5px;
}

.search-results-block:not(:last-child) {
  margin-bottom: 30.5px;
}

.search-results-txt {
  font-size: 18px;
  margin-bottom: 10px;
  line-height: 1.6;
}

.search-results-default-txt {
  font-size: 15px;
  line-height: 1.6;
}

.loader {
  position: fixed;
  width: 50px;
  height: 50px;
  top: 30%;
  left: 50%;
  right: 50%;
  -webkit-transform: translate(-50%);
          transform: translate(-50%);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  opacity: 1;
  visibility: visible;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  z-index: 10;
}

.loader.hide {
  opacity: 0;
  visibility: hidden;
}

.service-section {
  padding-top: 40px;
  margin-bottom: 113px;
}

@media (min-width: 768px) {
  .service-section {
    padding-top: 80px;
    margin-bottom: 120px;
  }
}

.service-heading-wrap {
  text-align: center;
  margin-bottom: 25px;
}

.service-heading-wrap .heading-1 {
  font-size: 26px;
  letter-spacing: 0.03em;
  line-height: 1.2;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
}

@media (min-width: 768px) {
  .service-heading-wrap .heading-1 {
    font-size: 30px;
    line-height: 1;
  }
}

.service-heading-wrap .heading-1-sub {
  color: #808080;
  font-size: 16px;
  letter-spacing: 0.04em;
  line-height: 1.87;
  margin-top: 5px;
}

@media (min-width: 768px) {
  .service-heading-wrap .heading-1-sub {
    font-size: 18px;
    margin-top: 7px;
    line-height: 1.6;
  }
}

.service-item .service-item-img-col2 .service-item-img-item {
  width: 50%;
}

@media (min-width: 768px) {
  .service-item .service-item-img-col2 .service-item-img-item {
    width: calc((100% - 40px) / 2);
  }
}

@media (min-width: 768px) {
  .service-item .service-item-img-col2 .service-item-img-item + .service-item-img-item {
    margin-left: 40px;
  }
}

.service-space-img {
  position: relative;
}

@media (min-width: 768px) {
  .service-space-img {
    width: calc((100% - 60px) / 2);
  }
}

.service-space-img + .service-space-img {
  margin-top: 26px;
}

@media (min-width: 768px) {
  .service-space-img + .service-space-img {
    margin-top: 0;
    margin-left: 60px;
  }
}

@media (min-width: 768px) {
  .service-space-img-wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.service-space-img-label {
  position: absolute;
  top: 18px;
  left: 0;
  z-index: 1;
  background: rgba(76, 73, 72, 0.85);
  padding: 8px 10px;
  color: #fff;
  font-weight: bold;
  letter-spacing: 0;
  line-height: 1;
  text-align: center;
  min-width: 110px;
}

.service-space-img-txt {
  margin-top: 20px;
}

@media (min-width: 768px) {
  .service-space-img-txt {
    margin-top: 26px;
  }
}

.service-list-wrap {
  margin-top: 24px;
}

@media (min-width: 768px) {
  .service-list-wrap {
    margin-top: 40px;
  }
}

.service-list > li {
  position: relative;
}

@media (min-width: 768px) {
  .service-list > li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

.service-list > li + li {
  margin-top: 12px;
}

@media (min-width: 768px) {
  .service-list > li + li {
    margin-top: 15px;
    padding-top: 35px;
  }
}

.service-list > li + li:before {
  content: "";
  position: absolute;
  top: 12px;
  left: 40px;
  background: url(../images/service/line_arrow.svg) no-repeat;
  background-size: 100%;
  width: 12px;
  height: 24px;
}

@media (min-width: 768px) {
  .service-list > li + li:before {
    top: 0;
    left: 50%;
  }
}

.service-list-num {
  color: #8D6B0D;
  font-size: 46px;
  line-height: 1;
  font-family: 'Barlow';
}

@media (min-width: 768px) {
  .service-list-num {
    font-size: 50px;
  }
}

.service-list-num-wrap {
  text-align: center;
}

@media (min-width: 768px) {
  .service-list-num-wrap {
    width: 40px;
  }
}

.service-list-sub-txt {
  color: #4C4948;
  font-size: 15px;
  line-height: 1;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .service-list-sub-txt {
    font-size: 16px;
  }
}

.service-list-block {
  background-color: #F4F4F4;
  padding: 18px 23px;
  margin-top: 8px;
  min-height: 80px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media (min-width: 768px) {
  .service-list-block {
    padding: 18px 32px;
    margin-left: 30px;
    width: calc(100% - 70px);
  }
}

.service-list-block-main {
  margin-bottom: 18px;
}

@media (min-width: 768px) {
  .service-list-block-main {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    margin-bottom: 24px;
  }
}

.service-list-block-center {
  text-align: center;
  margin-top: 4px;
}

@media (min-width: 768px) {
  .service-list-block-center {
    text-align: left;
    margin-top: 0;
    margin-left: 15px;
    width: calc(100% - 75px);
  }
}

.service-list-block-ttl {
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.02em;
  line-height: 1.3;
}

.service-list-block-num {
  font-size: 22px;
  font-weight: bold;
  line-height: 1.5;
}

@media (min-width: 768px) {
  .service-list-block-num {
    font-size: 18px;
    margin-top: 2px;
  }
}

.service-list-block-sub {
  font-size: 13px;
  margin-top: 4px;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .service-list-block-sub {
    font-size: 14px;
    margin-top: 2px;
  }
}

@media (min-width: 768px) {
  .service-list-block-info {
    display: inline-block;
  }
}

@media (min-width: 768px) {
  .service-list-block-info + .service-list-block-info {
    margin-left: 24px;
  }
}

.service-list-block-txt {
  line-height: 1.57;
}

.service-list-label {
  background-color: #808080;
  color: #fff;
  font-size: 12px;
  font-weight: bold;
  letter-spacing: 0;
  line-height: 1;
  display: inline-block;
  padding: 5px 12px;
}

.service-info-table {
  width: 600px;
}

@media (min-width: 768px) {
  .service-info-table {
    max-width: 800px;
    width: 100%;
  }
}

.service-info-table th, .service-info-table td {
  padding: 10px;
  text-align: center;
}

.service-info-table-min {
  width: 100%;
  margin-inline: auto;
}

@media (min-width: 768px) {
  .service-info-table-min {
    max-width: 600px;
  }
}

.service-info-table-min th {
  width: 80px;
}

@media (min-width: 768px) {
  .service-info-table-min th {
    width: 160px;
    font-size: 14px;
  }
}

.service-info-table-min td {
  text-align: left;
}

@media (min-width: 768px) {
  .service-info-table-min td {
    padding-inline: 40px;
  }
}

.service-info-table-min td span {
  word-break: keep-all;
}

.store-inner {
  margin-top: 87px;
}

@media (min-width: 768px) {
  .store-inner {
    margin-top: 92px;
  }
}

.store-index-inner {
  padding: 33px 15px 80px;
}

@media (min-width: 768px) {
  .store-index-inner {
    padding: 41px 20px 140px;
  }
}

.store-list {
  margin-top: 36px;
}

@media (min-width: 768px) {
  .store-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    max-width: 1024px;
    margin: 55px auto 0;
  }
}

.store-list li {
  margin-top: 42px;
}

@media (min-width: 768px) {
  .store-list li {
    margin-top: 53px;
    width: calc(50% - 54px);
  }
}

.store-list li:first-child {
  margin-top: 0;
}

@media (min-width: 768px) {
  .store-list li:nth-child(2) {
    margin-top: 0;
  }
}

@media (min-width: 768px) {
  .store-list li:nth-child(even) {
    margin-left: 104px;
  }
}

.store-list li a {
  -webkit-transition: all .3s;
  transition: all .3s;
}

@media (min-width: 768px) {
  .store-list li a:hover {
    opacity: 0.7;
  }
}

.store-list-img {
  position: relative;
}

.store-list-tag {
  padding: 10px 2px 6px;
  background-color: #8D6B0D;
  color: #fff;
  position: absolute;
  top: 15px;
  left: 15px;
  text-align: center;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
}

.store-list-name {
  font-size: 16px;
  color: #333;
  letter-spacing: 0;
}

.store-list-name-wrap {
  margin-top: 15px;
  padding-bottom: 22px;
  position: relative;
  line-height: 1.5;
  letter-spacing: 0.04em;
  font-weight: bold;
  text-align: center;
}

@media (min-width: 768px) {
  .store-list-name-wrap {
    margin-top: 14px;
  }
}

.store-list-name-wrap:after {
  content: "";
  width: 132px;
  height: 12px;
  border-bottom: 1px solid #B2B2B2;
  border-right: 1px solid #B2B2B2;
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%) skew(38deg);
          transform: translateX(-50%) skew(38deg);
}

.store-list-name-en {
  font-size: 20px;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  margin-bottom: 7px;
  color: #B2B2B2;
}

.store-link {
  display: inline-block;
  margin-top: 48px;
  padding: 14px 10px 30px;
  border: 1px solid #B2B2B2;
  position: relative;
  width: 250px;
  text-align: center;
  font-size: 18px;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  color: #333;
  -webkit-transition: all .3s;
  transition: all .3s;
}

@media (min-width: 768px) {
  .store-link {
    margin-top: 73px;
    padding: 21px 10px 41px;
    width: 600px;
    font-size: 20px;
  }
}

@media (min-width: 768px) {
  .store-link:hover {
    color: #333;
    background-color: #D9D9D9;
  }
}

.store-link:after {
  content: "";
  width: 120px;
  height: 12px;
  border-bottom: 1px solid #B2B2B2;
  border-right: 1px solid #B2B2B2;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  position: absolute;
  bottom: 13px;
  left: 50%;
  -webkit-transform: translateX(-50%) skew(38deg);
          transform: translateX(-50%) skew(38deg);
  text-align: center;
}

@media (min-width: 768px) {
  .store-link:after {
    bottom: 18px;
  }
}

.store-link-wrap {
  text-align: center;
}

.store-link-wrap .txt-note {
  margin-top: 44px;
}

@media (min-width: 768px) {
  .store-link-wrap .txt-note {
    margin-top: 35px;
  }
}

.store-link-note {
  text-align: left;
}

@media (min-width: 768px) {
  .store-link-note {
    text-align: center;
  }
}

.store-detail-inner {
  padding: 20px 0 56px;
}

@media (min-width: 768px) {
  .store-detail-inner {
    padding: 56px 0 76px;
  }
}

.store-detail-inner .heading-4-square {
  margin-bottom: 12px;
}

@media (min-width: 768px) {
  .store-detail-inner .heading-4-square {
    margin-bottom: 15px;
  }
}

.store-detail-txt {
  line-height: 1.857;
  letter-spacing: 0.02em;
}

.store-detail-wrap {
  margin: 0 auto;
  padding: 0 15px;
}

@media (min-width: 768px) {
  .store-detail-wrap {
    max-width: 1044px;
    padding: 0 10px;
  }
}

.store-detail-content {
  width: 100%;
  margin-top: 10px;
}

@media (min-width: 768px) {
  .store-detail-content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    row-gap: 44px;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-top: 20px;
  }
}

.store-detail-content .store-detail-list-block ul br {
  display: none;
}

.store-detail-content .store-detail-list-block ul + br {
  display: none;
}

.store-detail-content .store-detail-list-block ul > li {
  list-style-type: disc;
}

.store-detail-content .store-detail-list-block li {
  margin-left: 18px;
  line-height: 1.5;
  margin-bottom: 8px;
}

@media (min-width: 768px) {
  .store-detail-content .store-detail-list-block {
    width: calc(50% - 12px);
  }
}

@media (min-width: 768px) {
  .store-detail-content .store-detail-list-img {
    width: calc(50% - 32px);
  }
}

.store-detail-content-wrapper {
  margin-top: 43px;
}

@media (min-width: 768px) {
  .store-detail-content-wrapper {
    margin-top: 65px;
  }
}

.store-detail-content-ttl {
  font-size: 16px;
  line-height: 1.5;
  font-weight: bold;
  letter-spacing: .1em;
}

@media (min-width: 768px) {
  .store-detail-content-ttl {
    font-size: 20px;
  }
}

.store-detail-mv {
  margin: 31px 0 20px;
  position: relative;
}

@media (min-width: 768px) {
  .store-detail-mv {
    max-width: 100%;
    margin: auto;
  }
}

.store-detail-mv-swiper {
  position: relative;
  margin: 0 auto;
  padding-bottom: 27px;
  overflow: hidden;
}

@media (min-width: 768px) {
  .store-detail-mv-swiper {
    width: 100%;
    padding-bottom: 37px;
  }
}

.store-detail-mv-subttl {
  margin-top: 22px;
  font-size: 18px;
  font-weight: bold;
}

@media (min-width: 768px) {
  .store-detail-mv-subttl {
    font-size: 22px;
    margin-top: 42px;
  }
}

.store-detail-mv-heading {
  font-size: 18px;
  letter-spacing: 0.02em;
  line-height: 1.444;
  font-weight: bold;
  margin-bottom: 22px;
}

@media (min-width: 768px) {
  .store-detail-mv-heading {
    margin-bottom: 21px;
  }
}

.store-detail-mv .swiper-slide {
  width: 100%;
}

.store-detail-mv .swiper-button-prev,
.store-detail-mv .swiper-button-next {
  display: none;
  width: 36px;
  height: 36px;
  cursor: pointer;
  -webkit-transition: .3s;
  transition: .3s;
  background-image: url("../images/icon/swiper_arrow.svg");
  background-size: cover;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  z-index: 1;
}

@media (min-width: 768px) {
  .store-detail-mv .swiper-button-prev:hover,
  .store-detail-mv .swiper-button-next:hover {
    opacity: 0.7;
  }
}

@media (min-width: 768px) {
  .store-detail-mv .swiper-button-prev,
  .store-detail-mv .swiper-button-next {
    width: 50px;
    height: 50px;
  }
}

.store-detail-mv .swiper-button-prev {
  left: 10px;
  -webkit-transform: translateY(-50%) rotate(180deg);
          transform: translateY(-50%) rotate(180deg);
}

.store-detail-mv .swiper-button-next {
  right: 10px;
}

.store-detail-mv .swiper-pagination {
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  width: 100%;
}

@media (min-width: 768px) {
  .store-detail-mv .swiper-pagination {
    max-width: 1024px;
  }
}

.store-detail-mv .swiper-pagination-bullet {
  background-color: #BFBFBF;
  background-repeat: no-repeat;
  background-size: contain;
  border-radius: 0;
  width: 13px;
  height: 13px;
  opacity: 1;
  margin-right: 6px;
}

@media (min-width: 768px) {
  .store-detail-mv .swiper-pagination-bullet {
    width: 16px;
    height: 16px;
    margin-right: 8px;
  }
}

.store-detail-mv .swiper-pagination-bullet:last-child {
  margin-right: 0;
}

.store-detail-mv .swiper-pagination-bullet-active {
  background-color: #B18710;
}

.store-detail-list {
  border-bottom: 1px solid #d9d9d9;
}

.store-detail-list-note {
  margin-top: 8px;
}

@media (min-width: 768px) {
  .store-detail-list-note {
    margin-top: 5px;
  }
}

.store-detail-list tr {
  display: block;
  border-top: 1px solid #d9d9d9;
  padding: 15px 0 17px;
  line-height: 1.857;
}

@media (min-width: 768px) {
  .store-detail-list tr {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.store-detail-list th {
  display: block;
  text-align: left;
}

.store-detail-list td {
  display: block;
  margin-top: 5px;
}

@media (min-width: 768px) {
  .store-detail-list td {
    margin-top: 0;
  }
}

.store-detail-list.list-access tr {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding-left: 10px;
}

@media (min-width: 768px) {
  .store-detail-list.list-access tr {
    padding-inline: 21px 10px;
  }
}

.store-detail-list.list-access th {
  padding-bottom: 5px;
}

.store-detail-list.list-floor {
  margin-top: 20px;
}

.store-detail-list.list-floor tr {
  padding-inline: 10px;
}

.store-detail-list.list-floor th {
  width: 42px;
  margin-right: 20px;
}

.store-detail-list.list-floor td {
  -ms-flex-negative: 1;
      flex-shrink: 1;
}

.store-detail-list.list-floor td .txt-link {
  position: relative;
  padding-right: 13px;
}

.store-detail-list.list-floor td .txt-link:before {
  content: "/";
  position: absolute;
  right: 4px;
  color: #333333;
}

.store-detail-list.list-floor td .txt-link:after {
  width: calc(100% - 13px);
  bottom: 5px;
}

.store-detail-list.list-floor td .txt-link:last-child {
  padding: 0;
}

.store-detail-list.list-floor td .txt-link:last-child:before {
  content: "";
}

.store-detail-list.list-floor td .txt-link:last-child::after {
  width: 100%;
}

.store-detail-list.list-floor td .txt-link.no-link {
  pointer-events: none;
}

.store-detail-list.list-indent {
  border: none;
  font-size: 14px;
  line-height: 1.57;
  padding-left: 14px;
  text-indent: -14px;
}

.store-detail-list-floor-att {
  margin-top: 21px;
  vertical-align: baseline;
  width: auto;
}

.store-detail-list-floor-att tr:not(:first-of-type) th {
  margin-top: 10px;
}

@media (min-width: 768px) {
  .store-detail-list-floor-att tr:not(:first-of-type) th {
    margin-top: 0;
  }
}

.store-detail-list-floor-att tr:not(:last-of-type) th, .store-detail-list-floor-att tr:not(:last-of-type) td {
  padding-bottom: 8px;
}

@media (min-width: 768px) {
  .store-detail-list-floor-att tr th:not(:last-child), .store-detail-list-floor-att tr td:not(:last-child) {
    padding-right: 20px;
  }
}

@media screen and (max-width: 767px) {
  .store-detail-list-floor-att tr th, .store-detail-list-floor-att tr td {
    display: block;
  }
}

.store-detail-list-floor-att th {
  text-align: left;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 5px;
  padding-bottom: 8px;
}

@media (min-width: 768px) {
  .store-detail-list-floor-att th {
    padding-bottom: 0;
  }
}

.store-detail-list-floor-att .sup-num {
  font-weight: normal;
}

.store-detail-list-floor-att td a {
  white-space: nowrap;
}

.store-detail-list-floor-att .col-shop-info {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

@media (min-width: 768px) {
  .store-detail-map {
    margin-top: 50px;
  }
}

.store-detail-map iframe {
  width: 100%;
  height: 100%;
}

.store-detail-map-img {
  width: 100%;
  aspect-ratio: 16 / 9;
}

@media (min-width: 768px) {
  .store-detail-map-img:hover {
    opacity: 0.7;
  }
}

.store-detail-map-txt {
  font-size: 12px;
  margin-top: 13px;
}

.store-detail-map-txt .txt-link {
  color: #EA3323;
}

.store-detail-map-txt .txt-link:after {
  border-color: #EA3323;
}

.store-detail-map-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  gap: 4px;
  font-size: 12px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.store-detail-map-link [class*="icon-"] {
  font-size: 18px;
}

.store-detail-map-link-txt {
  text-decoration: underline;
  -webkit-transition: all .3s;
  transition: all .3s;
}

.store-detail-map-link:hover .store-detail-map-link-txt, .store-detail-map-link:active .store-detail-map-link-txt {
  -webkit-text-decoration-color: transparent;
          text-decoration-color: transparent;
}

.store-detail-hp {
  margin: 67px auto 0;
}

@media (min-width: 768px) {
  .store-detail-hp {
    margin: 109px auto 0;
  }
}

.store-detail-hp-img {
  width: 100%;
  display: block;
  border: 1px solid #B2B2B2;
}

@media (min-width: 768px) {
  .store-detail-hp-img:hover {
    opacity: 0.7;
  }
}

.store-detail-event {
  background-color: #F2F2F2;
  margin-top: 60px;
  padding-block: 34px 30px;
  display: none;
}

.store-detail-event:has(.store-detail-event-txt) {
  display: block;
}

@media (min-width: 768px) {
  .store-detail-event {
    padding-block: 67px 60px;
  }
}

.store-detail-event-article {
  margin-top: 10px;
}

@media (min-width: 768px) {
  .store-detail-event-article {
    margin-top: 18px;
  }
}

@media (min-width: 768px) {
  .store-detail-event-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 62px;
  }
}

.store-detail-event-list > li {
  width: 320px;
  font-weight: bold;
  line-height: 1.54;
}

@media (min-width: 768px) {
  .store-detail-event-list > li {
    width: calc((100% - 124px) / 3);
  }
}

@media (min-width: 768px) {
  .store-detail-event-list > li a {
    -webkit-transition: .3s;
    transition: .3s;
  }
}

@media (min-width: 768px) {
  .store-detail-event-list > li a:hover {
    opacity: 0.7;
  }
}

.store-detail-event-item {
  margin-top: 13px;
  line-height: 1.54;
}

.store-detail-event-date, .store-detail-event-txt-en, .store-detail-event-txt-jp {
  display: block;
  letter-spacing: 0.02em;
}

.store-detail-event-date:not(:last-child), .store-detail-event-txt-en:not(:last-child), .store-detail-event-txt-jp:not(:last-child) {
  margin-bottom: 3px;
}

.store-detail-event-txt-jp {
  color: #B18710;
}

.store-detail-event-txt {
  margin-top: 10px;
}

.store-detail-event-img {
  width: 100%;
  background-color: #F2F2F2;
  position: relative;
}

.store-detail-event-img:before {
  display: block;
  content: "";
  width: 100%;
  padding-top: 61.25%;
}

@media (min-width: 768px) {
  .store-detail-event-img:before {
    padding-top: 56.67%;
  }
}

.store-detail-event-img img {
  position: absolute;
  top: 50%;
  left: 50%;
  right: 50%;
  bottom: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: auto;
  max-width: 100%;
  max-height: 100%;
}

.store-detail-collection {
  margin-top: 56px;
}

@media (min-width: 768px) {
  .store-detail-collection {
    margin-top: 58px;
  }
}

.store-detail-collection-item + .store-detail-collection-item {
  margin-top: 44px;
}

@media (min-width: 768px) {
  .store-detail-collection-item + .store-detail-collection-item {
    margin-top: 34px;
  }
}

@media (min-width: 768px) {
  .store-detail-img {
    width: calc(50% - 31px);
  }
}

.store-detail-img + .store-detail-img {
  margin-top: 43px;
}

@media (min-width: 768px) {
  .store-detail-img + .store-detail-img {
    margin-top: 0;
    margin-left: 31px;
  }
}

.store-detail-img-wrap {
  margin-top: 74px;
}

@media (min-width: 768px) {
  .store-detail-img-wrap {
    margin-top: 102px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

.store-detail-img-txt {
  margin-top: 8px;
  font-size: 12px;
}

@media (min-width: 768px) {
  .store-detail-img-txt {
    margin-top: 10px;
  }
}

.store-detail-floor {
  margin-top: 54px;
}

@media (min-width: 768px) {
  .store-detail-floor {
    margin-top: 67px;
  }
}

.store-detail-article-item-wrap {
  display: none;
}

.store-detail-article-item-wrap:has(.def-item) {
  display: block;
  padding: 0 15px;
  margin: 89px auto 0;
}

@media (min-width: 768px) {
  .store-detail-article-item-wrap:has(.def-item) {
    max-width: 1044px;
    padding: 0 10px;
    margin: 113px auto 0;
  }
}

.store-detail-article-item-wrap .def-item-border .store-detail-related-blog {
  padding: 0;
  width: 100%;
  border-color: #d9d9d9;
}

.store-detail-article-item-wrap .def-item-border .store-detail-related-blog .def-item-tag {
  margin-right: 12px;
}

.store-detail-article-item-wrap .def-item-border .store-detail-related-blog .def-item-detail {
  padding: 14px 25px 13px;
  margin-top: 0;
}

.store-detail-article-item-wrap .def-item-border .store-detail-related-blog .def-item-detail-head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.store-detail-article-item-wrap .def-item-border .store-detail-related-blog .def-item-detail-date {
  color: #333;
  font-size: 13px;
}

.store-detail-article-item-wrap .def-item-border .store-detail-related-blog .def-item-img:before {
  padding-top: 61.01%;
}

.store-detail-tax-free-img {
  margin-top: 10px;
  max-width: 100px;
  width: 100%;
  height: auto;
}

.store-detail-payment img {
  max-width: 338px;
}

.store-detail-external {
  margin-top: 60px;
  margin-inline: auto;
  padding: 0 15px;
  display: none;
}

.store-detail-external:has(li) {
  display: block;
}

@media (min-width: 768px) {
  .store-detail-external {
    margin-top: 80px;
    max-width: 1044px;
    padding: 0 10px;
  }
}

.store-detail-external-list {
  display: grid;
  gap: 20px;
  margin-top: 20px;
}

@media (min-width: 768px) {
  .store-detail-external-list {
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
  }
}

.store-detail-external-list a {
  display: block;
  -webkit-transition: .3s;
  transition: .3s;
}

.store-detail-external-list a:hover {
  opacity: 0.7;
}

.store-detail-external-txt {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  margin-top: 10px;
}

@media (min-width: 768px) {
  .store-detail-external-txt {
    margin-top: 16px;
  }
}

.store-insta {
  background-color: #D9D9D9;
  padding: 40px 0;
}

@media (min-width: 768px) {
  .store-insta {
    padding: 60px 0;
  }
}

.store-insta-inner {
  display: block;
  margin: 0 auto;
  max-width: 1024px;
  position: relative;
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 768px) {
  .store-insta-inner:hover {
    opacity: 0.7;
  }
}

.store-insta-txt {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  background: rgba(0, 0, 0, 0.85);
  border: 1px solid #fff;
  text-align: center;
  width: 156px;
  height: 156px;
  padding: 15px 5px;
  color: #fff;
}

@media (min-width: 768px) {
  .store-insta-txt {
    width: 130px;
    height: 130px;
    padding: 10px 5px;
  }
}

.store-insta-txt-icon {
  width: 35px;
  fill: #fff;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .store-insta-txt-icon {
    width: 30px;
  }
}

.store-insta-txt-store {
  margin-top: 7px;
  font-size: 12px;
  font-weight: bold;
}

@media (min-width: 768px) {
  .store-insta-txt-store {
    margin-top: 6px;
    font-size: 13px;
  }
}

.store-insta-txt-store-name {
  margin-top: 8px;
  font-size: 14px;
  font-weight: bold;
  word-break: keep-all;
}

@media (min-width: 768px) {
  .store-insta-txt-store-name {
    margin-top: 1px;
  }
}

.store-insta-txt:after {
  content: "";
  width: 77px;
  height: 9px;
  border-bottom: 1px solid #fff;
  border-right: 1px solid #fff;
  position: absolute;
  bottom: 12px;
  left: 50%;
  -webkit-transform: translateX(-50%) skew(38deg);
          transform: translateX(-50%) skew(38deg);
}

@media (min-width: 768px) {
  .store-insta-txt:after {
    width: 65px;
    height: 8px;
  }
}

.store-connection-inner {
  padding: 70px 15px 76px;
  margin: 0 auto;
  text-align: center;
}

@media (min-width: 768px) {
  .store-connection-inner {
    max-width: 1044px;
    padding: 70px 10px 92px;
  }
}

.store-connection-list {
  display: grid;
  gap: 40px 20px;
  grid-template-columns: repeat(2, 1fr);
  margin-top: 20px;
}

@media (min-width: 768px) {
  .store-connection-list {
    grid-template-columns: repeat(6, 1fr);
  }
}

.store-connection-list li:first-child {
  margin-top: 0;
}

@media (min-width: 768px) {
  .store-connection-list li:first-child {
    margin-top: 0;
    margin-left: 0;
  }
}

.store-connection-list li a {
  -webkit-transition: all .3s;
  transition: all .3s;
}

@media (min-width: 768px) {
  .store-connection-list li a:hover {
    opacity: 0.7;
  }
}

.store-connection-list-name {
  margin-top: 10px;
  font-size: 13px;
  color: #333;
  letter-spacing: 0;
  font-weight: bold;
  line-height: 1.53;
  text-align: center;
  word-break: keep-all;
  padding-bottom: 12px;
  position: relative;
}

.store-connection-list-name:after {
  content: "";
  width: 96px;
  height: 10px;
  border-bottom: 1px solid #B2B2B2;
  border-right: 1px solid #B2B2B2;
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%) skew(38deg);
          transform: translateX(-50%) skew(38deg);
}

.store-connection-link {
  display: inline-block;
  margin-top: 36px;
  padding-bottom: 17px;
  position: relative;
  text-align: center;
  font-size: 16px;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  color: #333;
  -webkit-transition: all .3s;
  transition: all .3s;
}

@media (min-width: 768px) {
  .store-connection-link {
    margin-top: 41px;
  }
}

@media (min-width: 768px) {
  .store-connection-link:hover {
    opacity: 0.7;
  }
}

.store-connection-link:after {
  content: "";
  width: 96px;
  height: 10px;
  border-bottom: 1px solid #B2B2B2;
  border-right: 1px solid #B2B2B2;
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%) skew(38deg);
          transform: translateX(-50%) skew(38deg);
}

.store-outlet-wrap {
  padding: 20px 15px 105px;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .store-outlet-wrap {
    padding: 26px 10px 167px;
    max-width: 1044px;
  }
}

.store-outlet-ttl {
  margin-top: 38px;
  font-size: 24px;
  font-weight: bold;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
  text-align: center;
}

@media (min-width: 768px) {
  .store-outlet-ttl {
    margin-top: 61px;
    font-size: 26px;
  }
}

.store-outlet-subttl {
  margin: 37px 0 17px;
}

@media (min-width: 768px) {
  .store-outlet-subttl {
    margin: 40px 0 21px;
  }
}

.store-outlet li + li {
  margin-top: 42px;
}

@media (min-width: 768px) {
  .store-outlet li + li {
    margin-top: 56px;
  }
}

.store-outlet-item {
  padding: 25px 20px 29px;
  border: 1px solid #B2B2B2;
}

@media (min-width: 768px) {
  .store-outlet-item {
    padding: 25px 34px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}

@media (min-width: 768px) {
  .store-outlet-item-img {
    margin-top: 10px;
    width: 310px;
  }
}

.store-outlet-detail {
  margin-top: 13px;
}

@media (min-width: 768px) {
  .store-outlet-detail {
    margin-top: 0;
    margin-left: 46px;
    width: calc(100% - 376px);
  }
}

.store-outlet-detail-ttl {
  margin-bottom: 10px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .store-outlet-detail-ttl {
    font-size: 18px;
  }
}

.store-outlet-detail-address {
  margin-bottom: 20px;
  font-size: 14px;
  letter-spacing: 0.02em;
  line-height: 1.57;
}

@media (min-width: 768px) {
  .store-outlet-detail-address {
    margin-bottom: 10px;
    font-size: 15px;
  }
}

.store-outlet-detail-item + .store-outlet-detail-item {
  margin-top: 12px;
}

.store-outlet-detail-item-ttl {
  margin-bottom: 2px;
  font-size: 14px;
  font-weight: bold;
  letter-spacing: 0.02em;
}

.store-outlet-detail-item-txt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  line-height: 1.571;
}

.store-outlet-detail-item-txt span {
  display: inline-block;
  padding-right: 13px;
  position: relative;
}

.store-outlet-detail-item-txt span:after {
  content: "/";
  position: absolute;
  right: 4px;
}

.store-outlet-detail-item-txt span:last-child {
  padding: 0;
}

.store-outlet-detail-item-txt span:last-child:after {
  content: "";
}

.store-outlet-note {
  margin-top: 12px;
  font-size: 13px;
  letter-spacing: 0.02em;
  line-height: 1.61;
  text-indent: -1em;
  padding-left: 1em;
}

@media (min-width: 768px) {
  .store-outlet-note {
    margin-top: 8px;
    font-size: 14px;
  }
}

.store-outlet-note .txt-link {
  display: inline;
  color: #EA3323;
}

.store-outlet-note .txt-link:after {
  border-color: #EA3323;
}

.heading-1 {
  font-size: 24px;
  line-height: 1.5;
  letter-spacing: 0.04em;
  font-weight: bold;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
}

@media (min-width: 768px) {
  .heading-1 {
    font-size: 30px;
  }
}

.heading-1 .heading-1-sub {
  font-size: 16px;
  letter-spacing: 0.04em;
  color: #808080;
  font-weight: bold;
}

@media (min-width: 768px) {
  .heading-1 .heading-1-sub {
    margin-top: 3px;
  }
}

.heading-1 span {
  display: block;
  text-align: center;
  letter-spacing: 0.03em;
}

.heading-1 span.heading-long {
  letter-spacing: 0;
}

@media (min-width: 768px) {
  .heading-1 span.heading-long {
    letter-spacing: 0.03em;
  }
}

.heading-1 span.heading-long .is-sp-ttl {
  display: block;
}

@media (min-width: 360px) {
  .heading-1 span.heading-long .is-sp-ttl {
    display: none;
  }
}

.heading-2 {
  font-size: 20px;
  line-height: 1.5;
  letter-spacing: 0.04em;
  font-weight: bold;
  font-family: 'brown-bold', "Lucida Grande", "Hiragino Kaku Gothic Pro", Verdana, メイリオ, Meiryo, "MS PGothic", "MS UI Gothic", Arial,  sans-serif;
  font-weight: normal !important;
  letter-spacing: 0.2em;
  -webkit-font-smoothing: antialiased;
}

@media (min-width: 768px) {
  .heading-2 {
    font-size: 22px;
  }
}

.heading-3 {
  font-size: 18px;
  line-height: 1.5;
  letter-spacing: 0.02em;
  font-weight: bold;
}

@media (min-width: 768px) {
  .heading-3 {
    font-size: 20px;
  }
}

.heading-4 {
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: 0.02em;
  font-weight: bold;
  position: relative;
}

@media (min-width: 768px) {
  .heading-4 {
    font-size: 18px;
  }
}

.heading-4-square {
  padding-left: 20px;
}

.heading-4-square:before {
  content: "";
  background-color: #333;
  width: 12px;
  height: 12px;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

@media (min-width: 768px) {
  .heading-4-square {
    padding-left: 22px;
  }
  .heading-4-square:before {
    width: 14px;
    height: 14px;
  }
}

.heading-4-square.paragraph::before {
  content: "";
  background-color: #333;
  width: 12px;
  height: 12px;
  position: absolute;
  top: 30%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

@media (min-width: 768px) {
  .heading-4-square.paragraph::before {
    top: 50%;
  }
}

.txt-note {
  font-size: 12px;
  line-height: 1.5;
  text-indent: -1em;
  padding-left: 1em;
}

.txt-link {
  display: inline-block;
  color: #333;
  position: relative;
}

.txt-link::after {
  -webkit-transition: .3s;
  transition: .3s;
  display: block;
  content: "";
  width: 100%;
  position: absolute;
  bottom: 1px;
  left: 0;
  border-bottom: 1px solid #333;
  opacity: 0;
}

.txt-link:hover::after {
  opacity: 1;
}

.txt-link-underline {
  text-decoration: underline;
  -webkit-transition: .3s;
  transition: .3s;
}

@media (min-width: 768px) {
  .txt-link-underline:hover {
    opacity: 0.7;
  }
}

.txt-small {
  font-size: 13px;
}

.ta-center {
  text-align: center;
}

.ta-right {
  text-align: right;
}

.ta-left {
  text-align: left;
}

.txt-white {
  color: #fff;
}

@media (min-width: 768px) {
  .txt-white.sp {
    color: #333;
  }
}

.txt-gray {
  color: #B2B2B2;
}

.fw-bold {
  font-weight: bold;
}

/* =========================================================
 State
========================================================= */

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