@charset "UTF-8";

/*//////////////////// 共通 ////////////////////*/
* {
  box-sizing: border-box;
}

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

body #sel-wrapper,
.side-nav {
  letter-spacing: 0.01em;
  font-family: "Yu Gothic", "YuGothic", "Hiragino Kaku Gothic ProN", "Meiryo",
    sans-serif;
  color: #333333;
  font-size: 16px;
  line-height: 1.5;
}

img {
  image-rendering: -webkit-optimize-contrast;
}

.pc_only {
  display: block;
}

.sp_only {
  display: none;
}

.rb2019---main.rb2019---inner {
  min-width: 1230px;
  width: auto;
}

.rb2019---pickup {
  padding-top: 0 !important;
}

.rb2019---pickup > .rb2019---inner {
  height: 44px;
}

html body.rb2019---header-fixed .rb2019---main-nav {
  position: relative;
}

#sel-wrapper {
  text-align: center;
}

#ins-wrapper {
  padding: 0;
}

#ins-mainUpper {
  margin: 0 auto;
  width: 1230px;
}

#sel-wrapper a:hover {
  opacity: 0.75;
  transition: 0.2s ease-in-out;
}

#sel-wrapper h1,
#sel-wrapper h2 {
  font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN",
    "Hiragino Mincho Pro", "ヒラギノ明朝 Pro", "Yu Mincho", "游明朝", "游明朝体",
    sans-serif;
}

#sel-wrapper h2 {
  font-size: 34px;
  color: #555;
  margin-bottom: 30px;
  line-height: 1.5;
  letter-spacing: 2.5px;
}

#sel-wrapper span.subhead {
  font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN",
    "Hiragino Mincho Pro", "ヒラギノ明朝 Pro", "Yu Mincho", "游明朝", "游明朝体",
    sans-serif;
  display: block;
  font-size: 18px;
}

#sel-wrapper span.pink {
  color: #d09898;
  letter-spacing: 1.2px;
}

#sel-wrapper h2 span.title01 {
  display: inline-block;
  position: relative;
}

#sel-wrapper h2 span.title01::before,
h2 span.title01::after {
  content: "";
  width: 50px;
  height: 1px;
  background-color: #d3d3d3;
  position: absolute;
  top: 27px;
}

#sel-wrapper h2 span.title01::before {
  left: -60px;
}

#sel-wrapper h2 span.title01::after {
  right: -55px;
}

#sel-wrapper h2 span:first-of-type {
  display: block;
  font-size: 18px;
}

#sel-wrapper h2.title02 {
  display: inline-block;
  font-family: "Yu Gothic", "YuGothic", "Hiragino Kaku Gothic ProN", "Meiryo",
    sans-serif;
  font-weight: bold;
  color: #888888;
  border-bottom: 1px solid #888888;
}

.content__wrap {
  max-width: 1120px;
  margin: 0 auto;
}

.pageLink-inner {
  padding-top: 50px;
  margin-top: -50px;
}

.pc-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.maker {
  background-color: #d9efec;
}

.section {
  margin-bottom: 100px;
}

/* .page-links {padding-top: 160px;margin-top: -160px;} */

@media only screen and (max-width: 599px) {
  .pc_only {
    display: none;
  }

  .sp_only {
    display: block;
  }

  .rb2019---main.rb2019---inner {
    min-width: 100%;
    width: 100%;
  }

  body {
    font-size: 13px;
    line-height: 1.8;
  }

  address,
  article,
  aside,
  blockquote,
  dd,
  div,
  dl,
  dt,
  fieldset,
  figcaption,
  figure,
  footer,
  form,
  h3,
  h4,
  h5,
  h6,
  header,
  hgroup,
  li,
  nav,
  ol,
  p,
  pre,
  section,
  summary,
  table,
  td,
  th,
  ul {
    font-family: "Yu Gothic", "YuGothic", "Hiragino Kaku Gothic ProN", "Meiryo",
      sans-serif;
  }

  .content__wrap {
    width: 90%;
    margin: 0 auto;
  }

  span.subhead {
    font-size: 14px;
    letter-spacing: 1.2px;
  }

  span.subhead img {
    margin-bottom: 10px;
  }

  #sel-wrapper h2 {
    font-size: 23px;
    margin-bottom: 30px;
    letter-spacing: 1.5px;
  }

  #sel-wrapper h2 span.title01::before,
  #sel-wrapper h2 span.title01::after {
    top: 18px;
  }

  #sel-wrapper h2.title02 {
    font-size: 20px;
  }

  #sel-wrapper h2 span:first-of-type {
    font-size: 14px;
  }

  #sel-wrapper h2.title02 span img {
    width: 15px;
    height: 16px;
  }

  .pc-flex {
    display: block;
  }

  .cutText {
    visibility: hidden;
  }

  .section {
    margin-bottom: 70px;
  }

  /* 長いブランド名の対応 */
  .letter-s {
    letter-spacing: -1.5px;
  }
}

@media only screen and (max-width: 320px) {
  #sel-wrapper h2 {
    font-size: 20px;
  }

  #sel-wrapper h2 span.title01::before,
  h2 span.title01::after {
    width: 30px;
    top: 14px;
  }

  #sel-wrapper h2 span.title01::before {
    left: -37px;
  }

  #sel-wrapper h2 span.title01::after {
    right: -35px;
  }
}

/*//////////////////// ボタン ////////////////////*/
a.product__link,
a.link__btn,
button.link__btn {
  display: block;
  background: -moz-linear-gradient(left, #adeaed, #99d6d9);
  background: -webkit-linear-gradient(left, #adeaed, #99d6d9);
  background: linear-gradient(to right, #adeaed, #99d6d9);
  height: 47px;
  line-height: 47px;
  width: 380px;
  position: relative;
  border-radius: 50px;
  font-size: 18px;
  text-align: center;
  margin: 0 auto;
}
a.product__link,
a.product__link:link,
a.product__link:visited,
a.link__btn,
a.link__btn:link,
a.link__btn:visited,
button.link__btn {
  color: #fff;
}

a.product__link::before {
  content: "";
  background: url("../images/2021/pricerecommend/icon_shopping.svg") no-repeat;
  background-size: 100%;
  width: 24px;
  height: 20px;
  position: absolute;
  top: 13px;
  left: 30px;
}

a.brown {
  background: #cebb90;
}

.down,
.right {
  position: relative;
}

.down::before,
.right::before {
  content: "";
  background: url("../images/2021/common/arrow-down-white.svg") no-repeat;
  background-size: 100%;
  width: 16px;
  height: 10px;
  position: absolute;
  top: 20px;
  right: 20px;
}

.right::before {
  background: url("../images/2021/common/arrow-right-white.svg") no-repeat;
  background-size: 100%;
  width: 8px;
  height: 15px;
  top: 17px;
}

a.catalog__link {
  color: #888888;
  font-size: 16px;
}

a.catalog__link,
a.catalog__link:link,
a.catalog__link:visited {
  color: #888888;
}

a.catalog__link span {
  position: relative;
  top: 4px;
  left: -5px;
}

@media only screen and (max-width: 599px) {
  a.product__link,
  a.link__btn,
  button.link__btn {
    width: 85%;
    font-size: 14px;
    height: 40px;
    line-height: 40px;
  }

  a.product__link::before {
    width: 17px;
    height: 16px;
  }

  a.catalog__link {
    font-size: 14px;
  }

  .down::before {
    width: 10px;
    height: 6px;
    top: 18px;
    right: 20px;
  }

  .right::before {
    width: 6px;
    height: 10px;
    top: 15px;
    right: 20px;
  }
}

/*//////////////////// fvエリア ////////////////////*/
.fvArea {
  background: url("../images/2021/fv/pc-fv.jpg") no-repeat center;
  padding: 40px 0;
  background-size: cover;
}

.fvArea h1 {
  color: #fff;
  font-size: 36px;
  text-shadow: 1px 1px 6px #042d2f;
  margin-bottom: 40px;
}

.fvArea h1 span {
  display: block;
  font-size: 24px;
}

.fvArea__link {
  max-width: 745px;
  width: 90%;
  background: rgba(255, 255, 255, 0.8);
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
  justify-content: space-around;
  padding: 15px 0;
  position: relative;
}

.fvArea__link::before {
  content: "";
  border: 1px solid #fff;
  max-width: 764px;
  width: 103%;
  height: 95px;
  position: absolute;
  top: -8px;
  left: -10px;
}

.fvArea__link-box .detail {
  display: table;
}

.fvArea__link-box .icon,
.fvArea__link-box .text {
  display: table-cell;
  vertical-align: middle;
  text-align: left;
}

.fvArea__link-box .icon {
  padding-right: 10px;
}

.fvArea__link-box .text p {
  font-size: 14px;
  color: #d09898;
  font-weight: bold;
}

a.fvArea-pagelink {
  font-size: 20px;
  font-weight: bold;
  padding-left: 31px;
  padding-right: 25px;
  padding-bottom: 2px;
  border-bottom: 1px solid #707070;
  position: relative;
}
a.fvArea-pagelink,
a.fvArea-pagelink:link,
a.fvArea-pagelink:visited {
  color: #6a6a6a;
}

a.present-icon {
  padding-left: 26px;
}

a.fvArea-pagelink::before {
  content: "";
  background: url("../images/2021/fv/point01-icon.svg") no-repeat;
  background-size: 100%;
  width: 24px;
  height: 16px;
  position: absolute;
  top: 2px;
  left: 0;
}

a.present-icon::before {
  background: url("../images/2021/fv/point02-icon.svg") no-repeat;
  background-size: 100%;
  width: 18px;
  height: 19px;
  top: 0px;
  left: 4px;
}

a.fvArea-pagelink::after {
  content: "";
  background: url("../images/2021/fv/arrow-down.svg") no-repeat;
  background-size: 100%;
  width: 15px;
  height: 16px;
  position: absolute;
  top: 6px;
  right: 3px;
}

@media only screen and (max-width: 599px) {
  .fvArea {
    background: url("../images/2021/fv/sp_fv.jpg") no-repeat center;
    background-size: cover;
    padding: 30px 0;
  }

  .fvArea h1 {
    font-size: 50px;
    margin-bottom: 25px;
    line-height: 1.3;
  }

  .fvArea h1 span {
    font-size: 15px;
  }

  .fvArea__link {
    display: block;
    padding: 15px 15px 10px 10px;
  }

  .fvArea__link::before {
    width: 105%;
    height: 112%;
  }

  .fvArea__link-box .detail {
    margin-bottom: 8px;
    width: 100%;
  }

  .fvArea__link .detail img {
    width: 45px;
    height: 45px;
  }

  .fvArea__link-box .point02 {
    padding-right: 6px;
  }

  .fvArea__link-box .text p {
    font-size: 12px;
  }

  a.fvArea-pagelink {
    font-size: 17px;
    padding-bottom: 0;
    display: block;
    width: 100%;
    padding-left: 25px;
  }

  a.fvArea-pagelink::before {
    top: 8px;
    width: 21px;
    height: 14px;
  }

  a.fvArea-pagelink::after {
    top: 9px;
  }

  a.present-icon::before {
    top: 6px;
    width: 17px;
    height: 19px;
  }

  a.present-icon::after {
    right: 25px;
  }
}

/*//////////////////// イントロエリア ////////////////////*/
#introArea {
  margin-top: 50px;
}

#introArea p {
  line-height: 1.8;
  font-size: 16px;
}

#sel-wrapper h2.introArea-title {
  display: inline-block;
  font-size: 30px;
  position: relative;
  color: #333;
  margin-bottom: 15px;
}

#sel-wrapper h2.introArea-title::before {
  content: "";
  background: url("../images/2021/intro/wedding.png") no-repeat;
  position: absolute;
  top: -20px;
  left: -40px;
  width: 80px;
  height: 50px;
  background-size: 100%;
  z-index: -1;
}

.introArea__bnr {
  display: table;
  margin: 30px auto 0;
}

.introArea__bnr a {
  display: table-cell;
  vertical-align: middle;
}

@media only screen and (max-width: 599px) {
  #sel-wrapper h2.introArea-title {
    font-size: 18px;
  }

  #sel-wrapper h2.introArea-title::before {
    top: -30px;
    left: -20px;
  }

  #introArea p {
    text-align: left;
    font-size: 14px;
  }

  .introArea__bnr,
  .introArea__bnr a {
    display: block;
  }

  .introArea__bnr a img {
    width: 100%;
    height: auto;
  }
}

/*//////////////////// ページナビ(追尾) ////////////////////*/
#pageNav {
  background: #99d6d9;
  width: 100%;
  position: relative;
  top: 0;
  left: 0;
  margin-bottom: -65px;
}

#pageNav.fixed {
  position: fixed;
  top: 0;
  z-index: 99;
}

.nav--inner {
  max-width: 1120px;
  width: 100%;
  margin: 0 auto;
}

.pageNav__links {
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

a.pageNav__links {
  height: 65px;
  -webkit-align-items: center;
  align-items: center;
  font-size: 14px;
  position: relative;
  width: 170px;
  padding-right: 10px;
}
a.pageNav__links,
a.pageNav__links:link,
a.pageNav__links:visited {
  color: #fff;
}

a.pageNav__links:nth-of-type(5) {
  padding-left: 10px;
}

a.pageNav__links:last-of-type {
  width: 215px;
  background: #ddbf84;
  padding-left: 25px;
  padding-right: 48px;
}

a.pageNav__links::before {
  content: "";
  background: url("../images/2021/common/arrow-down-white.svg") no-repeat;
  background-size: 100%;
  width: 10px;
  height: 10px;
  position: absolute;
  top: 45%;
  right: 13px;
}

a.pageNav__links:last-of-type::before {
  right: 20px;
}

a.pageNav__links::after {
  content: "";
  height: 37px;
  width: 1px;
  background: #fff;
  position: absolute;
  top: 21%;
  right: -3px;
}

a.pageNav__links:nth-of-type(5)::after,
a.pageNav__links:last-of-type::after {
  display: none;
}

img.gift-icon {
  position: relative;
  left: -20px;
}

@media only screen and (max-width: 599px) {
  #pageNav {
    height: 100px;
    margin-bottom: -100px;
  }
  #pageNav.fixed {
    top: 50px;
  }
  a.pageNav__links {
    height: 50px;
    width: -webkit-calc(100% / 3);
    width: calc(100% / 3);
    font-size: 11px;
    border-bottom: 1px solid #fff;
    border-right: 1px solid #fff;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding-right: 7px;
  }

  a.pageNav__links:nth-of-type(5) {
    padding-left: 0;
  }

  a.pageNav__links:last-of-type {
    width: -webkit-calc(100% / 3);
    width: calc(100% / 3);
    line-height: 1.3;
    padding-left: 0;
    padding-right: 10px;
    letter-spacing: -0.5px;
  }

  a.pageNav__links:last-of-type img {
    width: 11px;
    height: 11px;
    margin-right: 6px;
  }

  img.gift-icon {
    left: -3px;
  }

  a.pageNav__links:first-of-type,
  a.pageNav__links:nth-of-type(4) {
    border-left: 1px solid #fff;
  }

  a.pageNav__links:last-of-type::before,
  a.pageNav__links::before {
    right: 6px;
  }

  a.pageNav__links::after {
    display: none;
  }
}
/* SE対応 */
@media only screen and (max-width: 320px) {
  a.pageNav__links {
    font-size: 10px;
  }

  a.pageNav__links::before {
    width: 7px;
    height: 7px;
  }

  a.pageNav__links:nth-of-type(5)::before,
  a.pageNav__links::before {
    right: 5px;
  }
}

/*//////////////////// ポイントエリア ////////////////////*/
#pointArea {
  padding-top: calc(65px + 80px);
}

.pointArea__list {
  text-align: left;
}

.pointArea__list div {
  width: -webkit-calc((100% - 10%) / 3);
  width: calc((100% - 10%) / 3);
}

.pointArea__list div p {
  margin-top: 15px;
  font-size: 14px;
}

@media only screen and (max-width: 599px) {
  #pointArea {
    margin-top: calc(100px + 15%);
    margin-top: 0;
  }

  .pointArea__list div {
    width: 100%;
    margin-bottom: 10%;
  }

  .pointArea__list img {
    width: 100%;
    height: auto;
  }
}

/*//////////////////// 特徴エリア ////////////////////*/
#featuresArea {
  background: url("../images/2021/features/features_bg.jpg") no-repeat center;
  background-size: cover;
  padding: 5% 0 3% 0;
  color: #555;
  position: relative;
  margin-top: 0;
  z-index: 0;
}

.featuresArea__wrap {
  max-width: 1120px;
  width: 100%;
  margin: 0 auto;
}

.featuresArea__block .pc-flex {
  -ms-flex-pack: distribute;
  justify-content: space-around;
}

.featuresArea__block {
  width: 70%;
  text-align: left;
  position: relative;
  padding: 20px 25px 35px 25px;
  border: 1px solid #c6c6c6;
  background: none;
  margin-bottom: 30px;
}

.featuresArea__block::after {
  content: "";
  position: absolute;
  top: -10px;
  left: -10px;
  height: 100%;
  width: 100%;
  z-index: -999;
}

.featuresArea__block:nth-of-type(2)::after {
  left: 10px;
}

.bg-color::after {
  background: #fff;
}

.featuresArea-right {
  margin-left: auto;
}

.featuresArea__text {
  margin-left: 17px;
}

.featuresArea__block h3 {
  font-family: "Yu Mincho", "游明朝", "游明朝体", sans-serif;
  font-size: 20px;
  margin-bottom: 10px;
  line-height: 1.7;
}

.featuresArea__block p {
  line-height: 1.7;
  font-size: 15px;
}

@media only screen and (max-width: 599px) {
  #featuresArea {
    padding: 50px 15px;
    background-size: cover;
  }

  #featuresArea::before {
    width: 110px;
    height: 111px;
    top: -3%;
  }

  #featuresArea h2 {
    font-size: 24px;
  }

  .featuresArea__block {
    width: 100%;
    margin-bottom: 10%;
  }

  .featuresArea__block h3 {
    font-size: 17px;
  }

  .featuresArea__block p {
    font-size: 14px;
  }

  .featuresArea-left {
    margin-left: auto;
  }

  .featuresArea-right {
    margin-right: auto;
    margin-left: 0;
  }

  .featuresArea__block img {
    width: 100%;
    height: auto;
    margin-bottom: 15px;
  }

  .featuresArea-left img {
    margin-left: -34px;
    margin-right: 0;
  }

  .featuresArea-right img {
    margin-right: 0;
    margin-left: 8px;
  }

  img.features-img {
    width: 110px;
    height: 43px;
    margin-bottom: 5px;
  }
}

/*//////////////////// 送り方が選べるリンベルの結婚引出物エリア ////////////////////*/
.choose__block {
  width: 48%;
  border: 4px solid #f4f4f4;
  padding: 20px 35px 25px;
  text-align: left;
}

.choose-title {
  display: table;
  border-bottom: 3px solid #d6eff0;
  width: 100%;
  padding-bottom: 10px;
  margin-bottom: 20px;
}

.title-item01,
.title-item02,
.choose-title p {
  display: table-cell;
  vertical-align: middle;
}

.title-item01 {
  background: #cebb90;
  border-radius: 50%;
  width: 90px;
  height: 90px;
}

.title-item01 p {
  padding-left: 20px;
}

.title-item01 span {
  display: block;
  text-align: center;
  color: #fff;
  position: relative;
  font-size: 20px;
  line-height: 1.2;
  letter-spacing: 2.5px;
}

.title-item01 span::before {
  content: "※";
  font-size: 10px;
  position: absolute;
  top: 0px;
  right: 11px;
}

.title-item02 {
  height: 90px;
  width: 97px;
}

.choose-title p {
  color: #cebb90;
  font-size: 24px;
  font-weight: bold;
  padding-left: 20px;
}

.choose-text p {
  font-size: 16px;
}

.choose-text span {
  display: block;
  font-size: 12px;
  color: #888888;
  margin-top: 10px;
}

.choose-text {
  margin-bottom: 15px;
}

.choose__block .link__btn {
  width: 300px;
}

@media only screen and (max-width: 599px) {
  .choose__block {
    width: 100%;
    padding: 15px 15px 20px;
    margin-bottom: 35px;
  }

  .title-item01 {
    width: 60px;
    height: 60px;
  }

  .title-item01 span {
    font-size: 14px;
  }

  .title-item01 span::before {
    top: -2px;
    right: 4px;
  }

  .choose-title {
    padding-bottom: 5px;
    margin-bottom: 10px;
  }

  .choose-title p {
    font-size: 16px;
    padding-left: 10px;
  }

  .choose-text p {
    font-size: 14px;
  }

  .choose-text span {
    margin-top: 0;
  }

  .choose__block .link__btn {
    width: 230px;
  }

  .title-item02 {
    height: 44px;
    width: 70px;
  }

  img.card-img {
    width: 70px;
    height: 44px;
  }
}

/*//////////////////// 予算別おすすめ定番商品エリア ////////////////////*/
#pricerecommend {
  background: #faffff;
  padding: 80px 0;
}

.pricerecommend__wrap {
  margin-top: 60px;
}

.pricerecommend-title {
  color: #fff;
  font-size: 22px;
  font-weight: bold;
  position: relative;
  display: inline-block;
  margin-bottom: 40px;
  padding: 7px 15px;
  border-radius: 50px;
}

.pricerecommend-title::before {
  content: "";
  position: absolute;
  top: 90%;
  left: 50%;
  margin-left: -6px;
  border: 11px solid transparent;
}

.p-30000 {
  background: #cebb90;
}

.p-30000::before {
  border-top: 15px solid #cebb90;
}

.p-50000 {
  background: #d09898;
}

.p-50000::before {
  border-top: 15px solid #d09898;
}

.pricerecommend__gift {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.pricerecommend__gift > div {
  background: #fff;
  box-shadow: 2px 2px 7px 5px #f6f7f7;
  width: -webkit-calc((100% - 12%) / 3);
  width: calc((100% - 12%) / 3);
}

.pricerecommend__gift-inner {
  padding: 20px;
}

.pricerecommend-item {
  background: #99d6d9;
  color: #fff;
  font-size: 18px;
  padding: 5px 12px 5px 0;
}

.pricerecommend-item img {
  margin-top: 5px;
  margin-right: 5px;
}

.pricerecommend-price,
.pricerecommend-name {
  text-align: left;
  color: #555;
}

.pricerecommend-price {
  font-size: 20px;
  font-weight: bold;
  margin-top: 15px;
}

.pricerecommend-name {
  font-size: 14px;
  min-height: 60px;
}

.pricerecommend__wrap a.product__link {
  width: 100%;
  margin-bottom: 10px;
}

.plus {
  position: relative;
}

.plus::before {
  content: "＋";
  background: #cebb90;
  border-radius: 50%;
  color: #fff;
  font-size: 25px;
  box-shadow: 2px 2px 7px 5px #f6f7f7;
  width: 40px;
  height: 40px;
  position: absolute;
  top: 50%;
  right: -54px;
  line-height: 40px;
}

.plus-pink::before {
  background: #d09898;
}

#pricerecommend .survey {
  width: 844px;
  height: 326px;
  border-radius: 12px;
  border: 1px solid #cbbc95;
  margin: 50px auto 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 50px;
}

#pricerecommend .survey .survey-body {
  width: 300px;
}

#pricerecommend .survey .survey-body h3 {
  color: #cbbc95;
  font-size: 28px;
  line-height: 1.3;
  margin-bottom: 20px;
  text-align: left;
}

#pricerecommend .survey .survey-body p {
  text-align: left;
  font-size: 16px;
  line-height: 1.7;
}

#pricerecommend .survey figure figcaption {
  font-size: 11px;
}

@media only screen and (max-width: 599px) {
  #pricerecommend {
    padding: 45px 0;
  }

  .pricerecommend__wrap {
    margin-top: 40px;
  }

  .pricerecommend-title {
    display: block;
    font-size: 18px;
    line-height: 1.3;
  }

  .pricerecommend__gift {
    overflow-x: auto;
    padding-bottom: 30px;
  }

  .pricerecommend__gift > div {
    width: 80%;
    margin-right: 50px;
    box-shadow: 2px 2px 5px 2px #f6f7f7;
  }

  .pricerecommend-item {
    font-size: 14px;
  }

  .pricerecommend-item img {
    margin-top: 3px;
    margin-right: 5px;
  }

  .pricerecommend__gift-inner {
    padding: 20px 15px;
  }

  .pricerecommend__gift-inner > img {
    width: 200px;
    height: 200px;
  }

  .pricerecommend-price {
    font-size: 16px;
  }

  .pricerecommend-name {
    font-size: 12px;
    line-height: 1.5;
    min-height: 60px;
  }

  .plus::before {
    font-size: 20px;
    width: 30px;
    height: 30px;
    right: -41px;
    line-height: 30px;
  }

  #pricerecommend .survey {
    width: 90vw;
    height: auto;
    border-radius: 12px;
    border: 1px solid #cbbc95;
    margin: 50px auto 0;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 5vw;
    padding: 5vw;
  }

  #pricerecommend .survey figure {
    width: 100%;
  }

  #pricerecommend .survey figure img {
    width: 100%;
    height: auto;
  }

  #pricerecommend .survey figure figcaption {
    font-size: 2.7vw;
    margin-top: 2vw;
    white-space: nowrap;
  }

  #pricerecommend .survey .survey-body {
    width: auto;
  }

  #pricerecommend .survey .survey-body h3 {
    color: #cbbc95;
    font-size: 5vw;
    line-height: 1.3;
    margin-bottom: 2vw;
    text-align: center;
  }

  #pricerecommend .survey .survey-body p {
    text-align: left;
    font-size: 3.6vw;
    line-height: 1.7;
  }
}

/*//////////////////// 予算別リンクエリア ////////////////////*/

.partnerLink__inner {
  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;
  width: 1030px;
  margin: 0 auto;
}

a.partnerLink {
  width: 310px;
  background: #f0f2f1;
  font-size: 13px;
  text-align: center;
  padding: 12px 0;
  border-radius: 50px;
  position: relative;
  font-weight: bold;
  margin: 0 12px 30px;
}

a.partnerLink,
a.partnerLink:link,
a.partnerLink:visited {
  color: #555;
}

a.partnerLink::before {
  content: "";
  background: url("../images/2021/common/arrow-down-gray.svg") no-repeat;
  background-size: 100%;
  width: 9px;
  height: 9px;
  position: absolute;
  top: 21px;
  right: 18px;
}

@media only screen and (max-width: 599px) {
  .partnerLink__inner {
    width: 100%;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }

  a.partnerLink {
    width: -webkit-calc((100% - 5px) / 2);
    width: calc((100% - 5px) / 2);
    font-size: 2.7vw;
    margin: 0 0 5px;
    padding-right: 10px;
    padding-top: 8px;
    padding-bottom: 0;
    height: 47px;
    border-radius: 6px;
    line-height: 1.5;
    letter-spacing: -0.2px;
  }

  a.partnerLink::before {
    width: 7px;
    height: 7px;
    top: 22px;
    right: 8px;
  }

  a.partnerLink:last-of-type {
    line-height: 47px;
    padding-top: 0;
  }
}

@media only screen and (max-width: 320px) {
  a.partnerLink {
    padding-right: 0;
    letter-spacing: -0.8px;
  }
}

/*//////////////////// 金額別お変えしエリア ////////////////////*/

p.price-item {
  font-size: 22px;
}

p.price-item span {
  font-size: 16px;
}

.recommend__inner {
  margin-top: 5%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.catalogArea {
  width: -webkit-calc((100% - 20%) / 4);
  width: calc((100% - 20%) / 4);
  text-align: left;
}

.mark {
  line-height: 23px;
  position: relative;
  display: inline-block;
  height: 23px;
  border-radius: 3px 0 0 3px;
  background: #cebb90;
  color: #fff;
  padding: 0 8px;
  margin-top: 9px;
  margin-bottom: 5px;
  padding-top: 1px;
}

.mark::after {
  position: absolute;
  top: -1px;
  right: -7px;
  width: 0;
  height: 0;
  content: "";
  border-width: 12px 0 13px 8px;
  border-style: solid;
  border-color: transparent transparent transparent #cebb90;
  border-radius: 4px;
}

.mark img {
  margin-top: 4px;
  margin-right: 7px;
}

.catalog-price {
  font-weight: bold;
  color: #555;
  font-size: 16px;
  margin-top: 7px;
}

.catalog-price span {
  font-size: 14px;
}

.catalog-name {
  position: relative;
}

.catalog-name p {
  font-size: 12px;
  padding-right: 20%;
  color: #959595;
}

.catalog-name a {
  position: absolute;
  top: 0;
  right: 0;
}

#recommend a.product__link {
  margin: 30px auto 0;
}

#boss,
#couple {
  background: #faffff;
  padding: 50px 0;
}

#friend,
#boss,
#shinzoku {
  padding-top: 80px;
}

#friend,
#shinzoku {
  margin-bottom: 80px;
}

#couple {
  padding: 50px 0 80px;
}

@media only screen and (max-width: 599px) {
  p.price-item {
    font-size: 15px;
  }

  .recommend__inner {
    overflow-x: auto;
    padding-bottom: 15px;
    margin-bottom: 25px;
  }

  .catalogArea {
    width: 40%;
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
    margin-right: 5%;
    margin-bottom: 5%;
  }

  p.price-item span {
    font-size: 12px;
  }

  .catalogImg {
    width: 100%;
    height: auto;
  }

  .mark {
    font-size: 10px;
    height: 20px;
    line-height: 20px;
    padding-top: 0;
  }

  .mark::after {
    border-width: 12px 0 10px 8px;
  }

  .mark img {
    margin-top: 5px;
    margin-right: 4px;
    width: 8px;
  }

  .catalog-price {
    font-size: 12px;
    line-height: 1.5;
    margin-bottom: 4px;
  }

  .catalog-price span {
    display: block;
    font-size: 10px;
  }

  .catalog-name p {
    font-size: 11px;
    line-height: 1.3;
  }

  .catalog-name img {
    width: 25px;
    height: 25px;
  }

  #friend,
  #boss,
  #shinzoku {
    margin-bottom: 60px;
  }

  #shinzoku {
    padding-top: 0;
  }

  #boss,
  #couple {
    padding: 40px 0 60px;
  }
}

/*//////////////////// セットの贈り物をお探しの方へのオススメギフト ////////////////////*/
#lineup {
  margin-top: -115px;
  padding-top: 115px;
}

.lineup {
  background: url("../images/2021/common/stripe.png") #fafafa;
  padding: 80px 0;
}

.lineup__wrap {
  background: #fff;
  box-shadow: 2px 2px 7px 5px #f6f7f7;
  padding: 60px 40px;
  margin-top: 50px;
}

.stylish-e-gift {
  position: relative;
  margin-bottom: 30px;
}

.balloon {
  position: absolute;
  width: 110px;
  height: 110px;
  text-align: center;
  color: #fff;
  font-size: 18px;
  background: #a5d4d8;
  border-radius: 50%;
  line-height: 110px;
  top: -20px;
  right: 90px;
}

.balloon::before {
  content: "";
  position: absolute;
  bottom: 2px;
  left: -16px;
  margin-top: -15px;
  border: 15px solid transparent;
  border-left: 29px solid #a5d4d8;
  z-index: 0;
  -webkit-transform: rotate(146deg);
  transform: rotate(146deg);
}

.line-bold,
.line-regular {
  display: block;
  width: 100%;
  height: 3px;
  margin-bottom: 5px;
  background: #a5d4d8;
}

.line-regular {
  height: 2px;
}

.stylish-e-gift__title {
  padding: 30px 50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.stylish-e-gift__card {
  padding-right: 40px;
}

.itemArea {
  display: table;
  margin-bottom: 15px;
}

.itemArea .item,
.itemArea span {
  display: table-cell;
  vertical-align: middle;
}

.itemArea .item,
.hikidemono .item,
.item-block .item {
  background: #d09898;
  border-radius: 4px;
  color: #fff;
  font-size: 18px;
  width: 100px;
  height: 28px;
  line-height: 28px;
}
.itemArea .item {
  width: auto;
  min-width: 90px;
  padding: 0 1em;
  font-size: 14px;
}
.itemArea .or {
  display: inline-block;
  margin: 0 0.5em;
}

.itemArea span img {
  padding-top: 4px;
  margin: 0 10px;
}

.itemTitle {
  text-align: left;
  font-weight: bold;
  color: #555;
}

.itemTitle p {
  font-size: 33px;
}

.itemTitle span {
  font-size: 24px;
}

.hikidemono {
  margin-top: 35px;
}

.itemList,
.item-block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: 20px;
  margin-bottom: 40px;
}

.item-block {
  border-bottom: 3px #efefef dashed;
  padding-bottom: 10px;
}

.item-block img {
  margin-right: 10px;
}

.item-block .omatome {
  margin-left: auto;
  margin-right: auto;
}

.item-block .omatome .item {
  width: 160px;
}

#sel-wrapper .package__wrap h2 {
  display: inline-block;
  position: relative;
  margin-top: 3%;
}

#sel-wrapper .package__wrap h2::before,
#sel-wrapper .package__wrap h2::after {
  content: "";
  position: absolute;
  width: 10px;
  height: 52px;
  top: 0;
  border-top: 1px solid #555555;
  border-bottom: 1px solid #555555;
}

#sel-wrapper .package__wrap h2::before {
  border-left: 1px solid #555555;
  left: -15px;
}

#sel-wrapper .package__wrap h2::after {
  border-right: 1px solid #555555;
  right: -15px;
}

.package-tab {
  margin-top: 30px;
}

input[name="packagetab_item"] {
  display: none;
}

.package-tab label {
  display: inline-block;
  margin: 0 50px;
}

#box:checked ~ #box_content,
#futou:checked ~ #futou_content {
  display: block;
}

.packagetab_item {
  width: 230px;
  height: 55px;
  color: #fff;
  background: #a5d4d8;
  position: relative;
  line-height: 55px;
  font-size: 20px;
  margin: 20px auto;
}

.futou_item {
  background: #77979a;
}

.packagetab_item::before {
  content: "";
  width: 0;
  height: 0;
  border-left: 7px solid transparent;
  border-right: 7px solid transparent;
  border-top: 10px solid #fff;
  position: absolute;
  top: 22px;
  right: 20px;
}

.tab_links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-left: 40px;
  width: 810px;
  margin: 0 auto 35px;
}

.tab_links a {
  width: 255px;
  height: 60px;
  padding-top: 7px;
  padding-left: 10px;
  position: relative;
  margin-bottom: 15px;
  margin-right: 15px;
}

.tab_links a p {
  text-align: left;
  font-size: 14px;
  margin: 0;
  line-height: 1.5;
}

.tab_links a p .links_price {
  font-size: 18px;
}

.tab_links a p .links_tax {
  font-size: 12px;
}

.tab_links a::before {
  content: "";
  display: block;
  width: 10px;
  height: 10px;
  transform: rotate(45deg);
  position: absolute;
  right: 8px;
  top: 24px;
}

a.box_links {
  border: 1px solid #a5d4d8;
}

a.futou_links {
  background: #77979a;
}

a.box_links p {
  color: #a5d4d8;
}

a.futou_links p {
  color: #ffffff;
}

.tab_links a.futou_links p span {
  color: #ffffff;
}

.tab_links a p span {
  color: #333333;
}

a.box_links::before {
  border-top: 1px solid #a5d4d8;
  border-right: 1px solid #a5d4d8;
}

a.futou_links::before {
  border-top: 1px solid #ffffff;
  border-right: 1px solid #ffffff;
}

.bridalCard {
  background: #f7f2f2;
  border: 1px solid #d9d0d0;
  padding: 30px;
  max-width: 1120px;
  width: 90%;
  margin: 50px auto;
  border-radius: 5px;
}

.bridalCard__block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.bridalCard__text {
  text-align: left;
  margin-right: 40px;
}

.bridalCard__text-title {
  display: table;
  margin-bottom: 15px;
}

.bridalCard__text-title img,
.bridalCard__text-title p {
  display: table-cell;
  vertical-align: middle;
}

.bridalCard__text-title p {
  font-size: 27px;
  font-weight: bold;
  padding-left: 20px;
}

.bridalCard__link .link__btn {
  width: 215px;
  height: 35px;
  line-height: 35px;
  padding: 0;
  font-size: 14px;
  margin-top: 10px;
}

.bridalCard__link .right::before {
  top: 10px;
}

.hikidemono-image {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  margin-top: 50px;
  border-bottom: 3px #efefef dashed;
  padding-bottom: 80px;
}

.hikidemono-image .hikidemono-images {
  width: 576px;
  height: 237px;
  border: 1px solid #c89a99;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding-top: 10px;
}

.hikidemono-image .hikidemono-images p {
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  color: #c89a99;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hikidemono-image .hikidemono-images p span {
  font-family: "Josefin Sans", sans-serif;
  font-size: 42px;
  font-weight: 400;
  margin: 0 3px;
}

.hikidemono-image .hikidemono-item {
  width: 236px;
  height: 237px;
  border: 1px solid #b7a064;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding-top: 10px;
}

.hikidemono-image .hikidemono-item p {
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  color: #b7a064;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hikidemono-image .hikidemono-item p span {
  font-family: "Josefin Sans", sans-serif;
  font-size: 42px;
  font-weight: 400;
  margin: 0 3px;
}

@media only screen and (max-width: 599px) {
  #lineup {
    padding-top: 0;
    margin-top: 0;
  }

  .lineup__wrap {
    padding: 40px 15px;
  }

  .stylish-e-gift {
    margin-bottom: 20px;
  }

  .stylish-e-gift__title {
    padding: 15px 0;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }

  .stylish-e-gift__card {
    padding-right: 10px;
  }

  .gift__card {
    padding-right: 20px;
  }

  .stylish-e-gift__card img {
    width: 80px;
    height: 50px;
  }

  .itemTitle p {
    font-size: 15px;
    line-height: 1.3;
    margin-bottom: 6px;
  }

  .itemTitle span {
    font-size: 14px;
  }

  .itemArea {
    margin-bottom: 0;
    position: relative;
    padding-bottom: 50px;
  }

  .itemArea .item,
  .hikidemono .item,
  .item-block .item {
    font-size: 12px;
    width: 69px;
    height: 20px;
    line-height: 20px;
  }

  .itemArea .item {
    min-width: 50px;
    width: 50px;
    padding-left: 0;
    padding-right: 0;
    font-size: 10px;
  }
  .itemArea .or {
    position: absolute;
    display: block;
    width: 2em;
    left: 0;
    right: 0;
    top: 25px;
    margin: 0 auto;
  }
  .itemArea .or + .item {
    position: absolute;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 25px;
    width: 90px;
    left: 0;
    right: 0;
    top: 50px;
    margin: 0 auto;
  }

  .itemArea span img {
    height: 12px;
    padding-top: 3px;
    padding-left: 4px;
    padding-right: 4px;
    margin-top: 5px;
  }

  .balloon {
    width: 75px;
    height: 75px;
    font-size: 12px;
    line-height: 75px;
    top: -30px;
    right: -10px;
  }

  .balloon::before {
    bottom: 8px;
    left: -8px;
    border: 6px solid transparent;
    border-left: 14px solid #a5d4d8;
  }

  p.lineup-text {
    text-align: left;
  }

  .itemList,
  .item-block {
    margin-bottom: 25px;
  }

  .hikidemono,
  .hikigashi,
  .engimono,
  .omatome {
    position: relative;
  }

  .hikidemono::before,
  .hikigashi::before,
  .engimono::before,
  .omatome::before {
    content: "";
    width: 100%;
    height: 1px;
    position: absolute;
    top: 10px;
    left: 0;
    background: #d19798;
  }

  .hikidemono .item,
  .hikigashi .item,
  .engimono .item,
  .omatome .item {
    margin: 0 auto;
    font-size: 14px;
    height: 23px;
    line-height: 23px;
    width: 80px;
    position: relative;
  }
  .item-block .omatome .item {
    width: 120px;
  }

  .hikidemono .itemList img {
    width: -webkit-calc((100% - 15px) / 2);
    width: calc((100% - 15px) / 2);
    height: auto;
    margin-bottom: 15px;
    flex-shrink: 0;
  }

  .hikigashi .itemList img,
  .engimono .itemList img {
    width: -webkit-calc((100% - 30px) / 3);
    width: calc((100% - 30px) / 3);
    height: auto;
    flex-shrink: 0;
  }

  .omatome .itemList img {
    width: -webkit-calc((100% - 45px) / 4);
    width: calc((100% - 45px) / 4);
    height: auto;
    flex-shrink: 0;
  }

  #sel-wrapper .package__wrap h2 {
    font-size: 18px;
  }

  .package__wrap > p {
    text-align: left;
  }

  .package-tab label {
    margin: 0;
  }

  .package-tab label img {
    width: 120px;
    height: 120px;
  }

  .packagetab_item {
    width: 130px;
    height: 40px;
    line-height: 40px;
    font-size: 14px;
    margin: 20px 10px 0;
  }

  .packagetab_item::before {
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 7px solid #fff;
    top: 17px;
    right: 13px;
  }

  .tab_links {
    width: 100%;
    margin: 0 auto 20px;
  }

  .tab_links a {
    width: 100%;
    margin-right: 0;
    padding-left: 15px;
  }

  .tab_links a::before {
    right: 20px;
  }

  .tab_links a p .links_price {
    font-size: 16px;
  }

  .sp_bridalCard {
    width: 90%;
    margin: 40px auto;
  }

  .sp_bridalCard img {
    width: 100%;
    height: auto;
    margin-bottom: 10px;
  }

  .sp_bridalCard p {
    text-align: left;
    margin-bottom: 10px;
  }

  p.sp_bridalCard-title {
    font-size: 18px;
    font-weight: bold;
    text-align: center;
  }

  .hikidemono-image {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 3vw;
    margin-top: 50px;
    border-bottom: 3px #efefef dashed;
    padding-bottom: 5vw;
  }

  .hikidemono-image > p {
    width: 10vw;
  }

  .hikidemono-image > p img {
    width: 100%;
    height: auto;
  }

  .hikidemono-image .hikidemono-images {
    width: 90vw;
    height: auto;
    border: 1px solid #c89a99;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    padding: 5vw;
  }

  .hikidemono-image .hikidemono-images > img {
    width: auto;
    height: 20vw;
  }

  .hikidemono-image .hikidemono-images p {
    text-align: center;
    font-size: 4vw;
    font-weight: 700;
    color: #c89a99;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .hikidemono-image .hikidemono-images p span {
    font-family: "Josefin Sans", sans-serif;
    font-size: 7vw;
    font-weight: 400;
    margin: 0 3px;
  }

  .hikidemono-image .hikidemono-item {
    width: 50vw;
    height: auto;
    border: 1px solid #b7a064;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    padding: 3vw 5vw;
  }

  .hikidemono-image .hikidemono-item > img {
    width: auto;
    height: 20vw;
  }

  .hikidemono-image .hikidemono-item p {
    text-align: center;
    font-size: 4vw;
    font-weight: 700;
    color: #b7a064;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .hikidemono-image .hikidemono-item p span {
    font-family: "Josefin Sans", sans-serif;
    font-size: 7vw;
    font-weight: 400;
    margin: 0 3px;
  }
}

/*//////////////////// ベスト3 ////////////////////*/
#top3Area {
  background: #faffff;
  padding: 80px 0;
}

.tab_area {
  margin-top: 3%;
}

.tab_item {
  display: inline-block;
  font-size: 20px;
  color: #cbcbcb;
  width: 156px;
  border-bottom: 2px solid #cbcbcb;
  margin: 0 15px;
}

.tab_item:hover {
  opacity: 0.75;
  transition: 0.2s ease-in-out;
}

input[name="tab_item"] {
  display: none;
}

.tab_content {
  display: none;
  padding-top: 50px;
  clear: both;
  overflow: hidden;
}

#hikigashi:checked ~ #hikigashi_content,
#guzzu:checked ~ #guzzu_content,
#engimono:checked ~ #engimono_content,
#puchigift:checked ~ #puchigift_content {
  display: block;
}

.tabs input:checked + .tab_item {
  color: #555;
  border-bottom: 2px solid #555;
  position: relative;
}

.tabs input:checked + .tab_item::before {
  content: "";
  width: 0;
  height: 0;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-top: 10px solid #555;
  position: absolute;
  left: 67px;
  top: 31px;
}

.tab_content_title {
  width: 900px;
  margin: 0 auto;
}

.tab_content_title h3 {
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 10px;
}

.tab_content_title p {
  line-height: 1.8;
}

.tab_content_block {
  background: #fff;
  box-shadow: 2px 2px 7px 5px #f6f7f7;
  margin-top: 3%;
  padding: 4% 3%;
  text-align: left;
}

.tab_content_block .best-wrap {
  width: -webkit-calc((100% - 10%) / 3);
  width: calc((100% - 10%) / 3);
}

.tab_content_block .name {
  color: #87c7cc;
  font-weight: bold;
  margin-bottom: 10px;
  font-size: 15px;
}

.tab_content_block .name span {
  display: block;
  font-size: 14px;
}

.detail img {
  display: block;
  margin: 0 auto;
}

.detail a img:hover {
  opacity: 0.8;
  transition: 0.2s ease-in-out;
}

.tab_content_block .text {
  margin-top: 15px;
  color: #555;
}

.tab_content_block .text .price {
  font-weight: bold;
  margin-bottom: 10px;
}

.tab_content_block .text .price .tax {
  display: block;
  font-size: 13px;
  font-weight: 400;
}

.tab_content_block .text p:nth-of-type(2) {
  font-size: 13px;
  color: #959595;
}

.tab_content_block .link__btn {
  margin: 45px auto 0;
}

@media only screen and (max-width: 599px) {
  #top3Area {
    padding: 60px 0;
  }

  #sel-wrapper h2 span.best3Area {
    font-size: 22px;
  }

  #sel-wrapper h2 span.best3Area::before,
  #sel-wrapper h2 span.best3Area::after {
    width: 35px;
    top: 15px;
  }

  #sel-wrapper h2 span.best3Area::before {
    left: -42px;
  }

  #sel-wrapper h2 span.best3Area::after {
    right: -42px;
  }

  .tab_item {
    width: -webkit-calc((100% - 20px) / 4);
    width: calc((100% - 20px) / 4);
    margin: 0;
    font-size: 13px;
  }

  .tabs input:checked + .tab_item::before {
    border-left: 7px solid transparent;
    border-right: 7px solid transparent;
    border-top: 7px solid #555;
    left: 45%;
    top: 24px;
  }

  .tab_content {
    padding-top: 35px;
  }

  .tab_content_title {
    width: 100%;
  }

  .tab_content_title h3 {
    font-size: 16px;
  }

  .tab_content_title p {
    font-size: 13px;
    text-align: left;
  }

  .tab_content_block {
    margin-top: 25px;
    padding: 20px 15px;
  }

  .tab_content_block .best-wrap {
    width: 100%;
  }

  .tab_content_block .name {
    font-size: 14px;
  }

  .tab_content_block .detail {
    display: table;
    margin-bottom: 25px;
  }

  .tab_content_block .detail a,
  .tab_content_block .detail .text {
    display: table-cell;
    vertical-align: top;
  }

  .detail img {
    width: 115px;
    height: auto;
  }

  .tab_content_block .detail .text {
    padding-left: 15px;
    line-height: 1.5;
  }

  .tab_content_block .text .price {
    margin-bottom: 5px;
  }

  .tab_content_block .text p:nth-of-type(2) {
    font-size: 12px;
    line-height: 1.5;
  }
}

@media only screen and (max-width: 320px) {
  #sel-wrapper h2 span.best3Area {
    font-size: 18px;
  }
}

/*//////////////////// アンケートエリア ////////////////////*/
#voiceArea {
  padding: 80px 0;
  background: url("../images/2021/common/bg.jpg");
}

#voiceArea h2 {
  display: inline-block;
  position: relative;
}

#voiceArea h2::before,
#voiceArea h2::after {
  content: "";
  position: absolute;
  width: 10px;
  height: 52px;
  top: 0;
  border-top: 1px solid #707070;
  border-bottom: 1px solid #707070;
}

#voiceArea h2::before {
  border-left: 1px solid #707070;
  left: -15px;
}

#voiceArea h2::after {
  border-right: 1px solid #707070;
  right: -15px;
}

.voiceArea__graph {
  display: table;
  width: 810px;
  margin: 0 auto;
}

.voiceArea__graph img,
.voiceArea__graph-text {
  display: table-cell;
  vertical-align: middle;
}

.voiceArea__graph img {
  padding-right: 30px;
}

.voiceArea__graph-text {
  font-size: 14px;
  color: #555;
  width: 59%;
}

.voiceArea__graph-text .catch {
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 15px;
}

.voiceArea__graph-text small {
  font-size: 12px;
  text-align: right;
  display: block;
  margin-top: 10px;
}

.voiceArea__video {
  margin-top: 5%;
}

@media only screen and (max-width: 599px) {
  #voiceArea {
    padding: 60px 0;
  }

  #voiceArea h2 {
    font-size: 22px;
    margin-bottom: 25px;
  }

  #voiceArea h2::before,
  #voiceArea h2::after {
    top: 5px;
  }

  #voiceArea h2::before {
    left: -22px;
  }

  #voiceArea h2::after {
    right: -22px;
  }

  .voiceArea__graph {
    width: 100%;
    display: block;
  }

  .voiceArea__graph img {
    padding-right: 0;
    margin: 0 auto 20px;
  }

  .voiceArea__graph img,
  .voiceArea__graph-text {
    display: block;
  }

  .voiceArea__graph-text {
    text-align: left;
    width: 100%;
  }

  .voiceArea__graph-text .catch {
    font-size: 16px;
    text-align: center;
    margin-bottom: 5px;
  }

  .voiceArea__video {
    margin-top: 10%;
  }

  .voiceArea__video iframe {
    width: 100%;
  }
}

/*//////////////////// ランキングエリア ////////////////////*/
#rankingArea {
  padding-top: 100px;
}

.rankingArea__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-top: 3%;
}

#rankingArea .catalogArea {
  width: -webkit-calc((100% - 15%) / 5);
  width: calc((100% - 15%) / 5);
}

@media only screen and (max-width: 599px) {
  #rankingArea {
    padding-top: 60px;
  }

  .rankingArea__inner {
    overflow-x: auto;
    padding-bottom: 15px;
  }

  #rankingArea .catalogArea {
    width: 40%;
  }
}

/*//////////////////// カテゴリから選ぶ ////////////////////*/
#category {
  padding-top: 100px;
}

.mainItem {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.mainItem a {
  width: -webkit-calc((100% - 15%) / 5);
  width: calc((100% - 15%) / 5);
}

.mainItem a .catalogImg {
  margin-bottom: 5px;
}

.mainItem a p {
  color: #555;
  font-weight: bold;
  font-size: 15px;
}

@media only screen and (max-width: 599px) {
  #category {
    padding-top: 60px;
  }

  .mainItem a {
    width: -webkit-calc((100% - 20px) / 2);
    width: calc((100% - 20px) / 2);
    margin-bottom: 20px;
  }

  .mainItem a p {
    font-size: 13px;
  }
}

/*//////////////////// かんたん検索エリア ////////////////////*/
#kekkon-search {
  padding: 80px 0;
  background: url("../images/2021/common/bg.jpg");
}

.section-lead {
  color: #555;
  font-size: 16px;
  margin-bottom: 3%;
}

.search__inner {
  padding: 5% 0;
  background: #fff;
  box-shadow: 2px 2px 7px 5px #f6f7f7;
}

.search__fields {
  -webkit-align-items: center;
  align-items: center;
  -webkit-box-align: center;
  -webkit-box-pack: center;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
}

.form-select {
  -webkit-align-items: center;
  align-items: center;
  -webkit-box-align: center;
  -webkit-box-pack: start;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
  line-height: 1;
  position: relative;
}

.search .form-select {
  height: 80px;
  width: 370px;
}

.form-select__element {
  color: #e0cda7;
  display: block;
  height: 100%;
  outline: 0;
  position: relative;
  width: 100%;
  font-size: 18px;
  font-weight: bold;
  padding: 0 2em 0 2.5em;
  padding-left: 74px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: #fff;
  box-shadow: 0 0 10px #dedede, 0 0 10px #dedede;
  border: none;
}

.form-select__icon {
  bottom: 0;
  height: 1.25em;
  left: 0.75em;
  margin: auto 0;
  pointer-events: none;
  position: absolute;
  top: 0;
  width: 1.25em;
}

.search .form-select__icon:nth-of-type(1) {
  height: auto;
  left: 20px;
  width: 20px;
}

.search .form-select__icon:nth-of-type(2) {
  height: auto;
  left: auto;
  right: 24px;
  width: 14px;
}

.search__cross {
  margin: 0 30px;
}

#kekkon-search button {
  margin: 40px auto 0;
}

.form-button:disabled {
  cursor: default;
  opacity: 0.6;
  border: none;
}

@media only screen and (max-width: 599px) {
  #kekkon-search {
    padding: 60px 0;
  }

  .section-lead {
    font-size: 14px;
    margin-bottom: 5%;
  }

  .search__inner {
    padding: 25px 0 35px;
  }

  .search .form-select {
    margin: 1em;
    height: 60px;
  }

  .search__fields {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }

  .search__cross {
    margin: 0;
  }

  .search .form-button {
    width: 80%;
    font-size: 15px;
  }

  .form-select__element {
    font-size: 15px;
    padding-left: 103px;
  }

  #kekkon-search button {
    margin: 25px auto 0;
  }
}

/*//////////////////// ご予算から選ぶ ////////////////////*/
#priceLink-choose a.priceLink {
  width: 220px;
  margin: 0 10px 3%;
  border-radius: 10px;
}

#priceLink-choose a.priceLink::before {
  background: url("../images/2021/common/arrow-right-glay.svg") no-repeat;
  top: 17px;
  right: 9px;
  background-size: 100%;
  width: 8px;
  height: 14px;
}

@media only screen and (max-width: 599px) {
  #priceLink-choose a.priceLink {
    width: -webkit-calc((100% - 5px) / 2);
    width: calc((100% - 5px) / 2);
    margin: 0 0 5px;
    line-height: 47px;
    padding-top: 0;
  }
}

/*//////////////////// ブランドから選ぶ ////////////////////*/
.brandArea__inner {
  width: 100%;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 20px;
}
.brandArea__inner li {
  width: calc((100% - 20px * 2) / 3);
}
.brandArea__inner a {
  display: block;
}
.brandArea__inner a img {
  width: 100%;
  height: auto;
}
.brandArea__inner p {
  font-size: 14px;
  color: #333;
  margin-top: 0.5em;
}
@media only screen and (max-width: 599px) {
  .brandArea__inner {
    gap: 10px;
  }
  .brandArea__inner li {
    width: calc((100% - 10px) / 2);
  }
  .brandArea__inner p {
    font-size: 11px;
  }
}

/*//////////////////// 特別な贈り物エリア ////////////////////*/
#specialArea {
  background: #fbffff;
  padding: 80px 0;
}

.specialArea__bnr {
  margin: 0 auto;
  background: #fff;
  border: 1px solid #cebb90;
  display: table;
  padding: 25px;
}

.specialArea__bnr img,
.specialArea__bnr .specialArea__bnr-text {
  display: table-cell;
  vertical-align: middle;
}

.specialArea__bnr-text {
  padding-left: 25px;
}

.specialArea__bnr-text img {
  margin: 0 auto 15px;
}

.specialArea__bnr .link__btn {
  width: 430px;
  margin: 20px auto 0;
}

@media only screen and (max-width: 599px) {
  #specialArea {
    padding: 60px 0;
  }

  .specialArea__bnr,
  .specialArea__bnr img,
  .specialArea__bnr .specialArea__bnr-text {
    display: block;
  }

  .specialArea__bnr img {
    width: 100%;
    height: auto;
  }

  .specialArea__bnr-text {
    padding-left: 0;
    text-align: left;
  }

  .specialArea__bnr .link__btn {
    width: 100%;
    font-size: 13px;
  }

  .specialArea__bnr .link__btn.right::before {
    right: 11px;
  }
}

/*//////////////////// 引出物にまよったらエリア ////////////////////*/
#catalogBridal {
  background: url("../images/2021/common/catalog-bg.jpg") no-repeat center;
  background-size: cover;
  padding: 80px 0;
}

.catalogBridal__block {
  background: rgba(255, 255, 255, 0.8);
  max-width: 1000px;
  margin: 0 auto;
  padding: 50px;
}

#sel-wrapper .catalogBridal__block h2 {
  font-size: 28px;
  display: inline-block;
  position: relative;
  line-height: 52px;
}

#sel-wrapper .catalogBridal__block h2::before,
#sel-wrapper .catalogBridal__block h2::after {
  content: "";
  position: absolute;
  width: 10px;
  height: 52px;
  top: 0;
  border-top: 1px solid #707070;
  border-bottom: 1px solid #707070;
}

#sel-wrapper .catalogBridal__block h2::before {
  border-left: 1px solid #707070;
  left: -15px;
}

#sel-wrapper .catalogBridal__block h2::after {
  border-right: 1px solid #707070;
  right: -15px;
}

.catalogBridal__detail p {
  text-align: left;
  color: #555;
  font-weight: bold;
}

p.catalogBridal-title {
  font-size: 22px;
  color: #d09898;
  margin-bottom: 10px;
}

p.catalogBridal-price {
  font-size: 25px;
}

p.catalogBridal-price span {
  font-size: 22px;
}

p.catalogBridal-tax {
  font-size: 22px;
}

.catalogBridal__detail .link__btn {
  margin: 50px auto 0;
}

#catalogBridal .bridalCard {
  width: 100%;
}

@media only screen and (max-width: 599px) {
  #catalogBridal {
    padding: 60px 0;
  }

  .catalogBridal__block {
    padding: 35px 15px;
  }

  .catalogBridal-pic {
    width: 220px;
    height: 220px;
    margin-bottom: 25px;
  }

  #sel-wrapper .catalogBridal__block h2 {
    font-size: 21px;
    line-height: 1.5;
    margin-bottom: 25px;
  }

  p.catalogBridal-title {
    font-size: 16px;
    margin-bottom: 0px;
    text-align: center;
    border-bottom: 1px solid #d09898;
  }

  p.catalogBridal-price {
    font-size: 18px;
  }

  p.catalogBridal-price span,
  p.catalogBridal-tax {
    font-size: 14px;
  }

  .catalogBridal__detail .link__btn {
    margin: 20px auto 0;
  }
}

/*//////////////////// カタログギフトから選ぶ ////////////////////*/
#catalog-giftArea {
  padding: 80px 0;
  background: url("../images/2021/common/bg.jpg");
}

.catalog-gift__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: 5%;
}

.catalog-gift__block {
  width: -webkit-calc((100% - 5%) / 2);
  width: calc((100% - 5%) / 2);
  box-shadow: 5px 5px 7px #f5f5f5, -5px -5px 7px #f5f5f5;
  padding: 0 20px 3%;
  margin-bottom: 70px;
  background: #fff;
}

.catalog-gift__block:last-of-type {
  /* margin-bottom: 0; */
}

.catalog-gift__title {
  margin-top: -21px;
  margin-bottom: 20px;
}

.catalog-gift__detail {
  display: table;
  color: #555;
}

.catalog-gift__detail a,
.catalog-gift__detail .text {
  display: table-cell;
  vertical-align: top;
}

.catalog-gift__detail img {
  display: block;
  width: 150px;
}

.catalog-gift__detail .text {
  padding-left: 15px;
}

.catalog-gift__detail .text p:first-of-type {
  text-align: left;
  margin-bottom: 10px;
  font-size: 14px;
}

#catalog-giftArea a.product__link {
  display: block;
  width: 100%;
  height: 40px;
  line-height: 40px;
  font-size: 16px;
}

#catalog-giftArea a.product__link::before {
  background: url("../images/2021/common/arrow-right-white.svg") no-repeat;
  background-size: 100%;
  width: 6px;
  height: 10px;
  right: 20px;
  left: auto;
  top: 13px;
}

.catalog-gift__detail .text p:last-of-type {
  margin-top: 5px;
  font-size: 12px;
}

.catalog-gift__detail .text p:last-of-type .price {
  font-size: 16px;
  font-weight: bold;
}

.catalog-gift__detail .text p:last-of-type .tax {
  font-size: 12px;
}

@media only screen and (max-width: 599px) {
  #catalog-giftArea {
    padding: 60px 0;
  }

  .catalog-gift__inner {
    overflow-x: auto;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    padding-top: 5%;
  }

  .catalog-gift__block {
    width: 85%;
    flex: 0 0 auto;
    margin-right: 30px;
    margin-bottom: 50px;
  }

  .catalog-gift__block:first-of-type {
    margin-left: 10px;
  }

  .catalog-gift__block:last-of-type {
    margin-right: 10px;
    margin-bottom: 50px;
  }

  .catalog-gift__title {
    margin-top: -15px;
  }

  .catalog-gift__title img {
    width: 110%;
    position: relative;
    left: -5%;
  }

  .catalog-gift__detail,
  .catalog-gift__detail a,
  .catalog-gift__detail .text {
    display: block;
  }

  .catalog-gift__detail img {
    width: 85%;
    height: auto;
    margin: 0 auto;
  }

  .catalog-gift__detail .text {
    padding: 0;
    margin-top: 15px;
    margin-bottom: 15px;
  }

  #catalog-giftArea a.product__link {
    width: 100%;
  }

  .catalog-gift__detail .text p:last-of-type {
    font-size: 11px;
    margin-top: 15px;
    line-height: 1.5;
  }

  .catalog-gift__detail .text p:last-of-type .price {
    font-size: 14px;
  }

  .catalog-gift__detail .text p:last-of-type .tax {
    display: block;
    font-size: 12px;
  }
}

/*//////////////////// 選べる体験ギフト ////////////////////*/
#taikenGift {
  padding: 80px 0 0;
}

.taikenGift__block {
  background: #fff;
  box-shadow: 5px 5px 10px #ededed, -5px -5px 10px #ededed;
  padding: 20px 25px;
  width: -webkit-calc((100% - 6%) / 3);
  width: calc((100% - 6%) / 3);
  margin-bottom: 50px;
}

.taikenGift__block p {
  text-align: left;
  color: #555;
}

.taikenGift__block-title {
  margin-bottom: 15px;
}

.taikenGift__block-title .line-bold {
  height: 2px;
}

.taikenGift__block-title .line-regular {
  height: 1px;
}

.taikenGift__block-title p {
  font-size: 18px;
  color: #99d6d9;
  font-weight: bold;
  line-height: 1.8;
  margin-bottom: 4px;
  text-align: center;
}

.taikenGift-price {
  margin-top: 10px;
  font-size: 20px;
  font-weight: bold;
}

.taikenGift-tax {
  margin-bottom: 10px;
}

.taikenGift-text {
  font-size: 14px;
}

@media only screen and (max-width: 599px) {
  #taikenGift {
    padding: 60px 0 0;
  }

  .taikenGift__block {
    width: 100%;
  }

  .taikenGift__block-title p {
    font-size: 16px;
  }

  .taikenGift-price {
    font-size: 16px;
  }
}

/*//////////////////// ご注文からお届けまでの流れ ////////////////////*/
#flow {
  padding-top: 100px;
  margin-top: -100px;
}

.flow {
  background: url("../images/2021/common/stripe.png") #fafafa;
  padding: 80px 0;
}

.flow__wrap {
  max-width: 960px;
  margin: 0 auto;
  background: url("../images/2021/flow/line.png") no-repeat center 100px;
  background-size: 570px;
}

.flow-block {
  background: #fff;
  border-radius: 5px;
  box-shadow: 5px 5px 10px #ededed, -5px -5px 10px #ededed;
  width: 400px;
  margin: 0 auto 50px;
  display: table;
  padding: 15px;
}

.flow-icon,
.flow-text {
  display: table-cell;
  vertical-align: middle;
  text-align: left;
}

.flow-icon {
  width: 70px;
}

.flow-text p:first-of-type {
  display: inline-block;
  background: #f4f4f4;
  color: #6a6a6a;
  font-size: 12px;
  font-weight: bold;
  padding: 1px 10px;
  margin-bottom: 5px;
}

p.step-beige,
p.step-greeeen,
p.step-pink {
  font-size: 18px;
  font-weight: bold;
  color: #cebb90;
}

p.step-greeeen {
  color: #99d6d9;
}

p.step-pink {
  color: #d09898;
}

.flow-text p:last-of-type {
  color: #666666;
  font-size: 18px;
}

.flow-inner {
  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-top: 80px;
}

.flow-inner .flow-block {
  margin: 0;
}

.flow__wrap .flow-block:nth-last-child(3) {
  height: 85px;
}

@media only screen and (max-width: 599px) {
  .flow {
    padding: 60px 0;
  }

  .flow__wrap {
    background: url("../images/2021/flow/sp-line.png") no-repeat center 30px;
    background-size: 190px;
  }

  .flow-block {
    width: 100%;
    padding: 10px 5px;
    margin: 0 auto 30px;
    box-shadow: 3px 3px 4px #ededed, -3px -3px 4px #ededed;
  }

  .flow-inner {
    margin-top: 30px;
  }

  .flow-inner .flow-block {
    width: 48%;
  }

  .flow-icon {
    width: 45px;
  }

  .flow-icon img {
    width: 35px;
    height: 35px;
  }

  .flow-inner .flow-block .flow-icon {
    width: 35px;
  }

  .flow-inner .flow-block .flow-icon img {
    width: 25px;
    height: 25px;
  }

  p.step-beige,
  p.step-greeeen,
  p.step-pink,
  .flow-text p:last-of-type {
    font-size: 14px;
    line-height: 1.5;
  }
}

/*//////////////////// 3つの理由エリア ////////////////////*/
#reasonsArea {
  background: #faffff;
  margin-top: 0;
  padding: 80px 0;
}

.reasonsArea__block {
  background: #fff;
  width: -webkit-calc((100% - 5%) / 3);
  width: calc((100% - 5%) / 3);
  padding: 3%;
  color: #555;
  position: relative;
  box-shadow: 5px 5px 10px #ededed, -5px -5px 10px #ededed;
}

.reasonsArea__block::after {
  content: "";
  background: url("../images/2021/reasons/reasons01.svg") no-repeat;
  background-size: 100%;
  width: 50px;
  height: 50px;
  position: absolute;
  left: 0;
  top: 0;
}

.reasonsArea__block:nth-of-type(2)::after {
  background: url("../images/2021/reasons/reasons02.svg") no-repeat;
  background-size: 100%;
}

.reasonsArea__block:nth-of-type(3)::after {
  background: url("../images/2021/reasons/reasons03.svg") no-repeat;
  background-size: 100%;
}

.reasonsArea__block dd:first-of-type {
  font-size: 15px;
  font-weight: bold;
  margin-top: 10px;
}

.reasonsArea__block dd:last-of-type {
  margin-top: 10px;
  text-align: left;
  font-size: 13px;
}

.reasonsArea__block dd:last-of-type .note {
  display: block;
  font-size: 12px;
  text-align: right;
  margin-top: 10px;
}

.reasonsArea__block dd:last-of-type .note.time {
  text-align: left;
}

@media only screen and (max-width: 599px) {
  #reasonsArea {
    padding: 60px 0;
  }

  .reasonsArea__block {
    width: 100%;
    padding: 5%;
    margin-bottom: 10%;
  }

  .reasonsArea__block:last-of-type {
    margin-bottom: 0;
  }

  .reasonsArea__block dd:last-of-type {
    margin-top: 5px;
  }

  .reasonsArea__block img {
    width: 100%;
    height: auto;
  }
}

/*//////////////////// 充実のサービスエリア ////////////////////*/
.serviceArea__inner-pc {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.serviceArea__inner-sp {
  display: none;
}

.serviceArea__inner-pc dl {
  width: -webkit-calc((100% - 10%) / 3);
  width: calc((100% - 10%) / 3);
}

#serviceArea dl dt {
  margin-bottom: 20px;
}

#serviceArea dl dd:first-of-type {
  font-size: 18px;
  font-weight: bold;
  color: #99d6d9;
  margin-bottom: 10px;
}

#serviceArea dl dd:last-of-type {
  text-align: left;
  font-size: 16px;
}

@media only screen and (max-width: 599px) {
  #serviceArea::before {
    width: 110px;
    height: 50px;
    top: -14%;
  }

  #serviceArea::after {
    width: 73px;
    height: 90px;
    bottom: -14%;
  }

  .serviceArea__inner-pc {
    display: none;
  }

  #serviceArea dl {
    padding: 0 15px;
    margin-bottom: 5px;
  }

  #serviceArea dl dd:first-of-type {
    font-size: 15px;
  }

  #serviceArea dl dd:last-of-type {
    font-size: 14px;
    line-height: 1.5;
  }

  .slick-dots li button:before {
    color: #9d9d9d !important;
  }

  .slick-dots li.slick-active button:before {
    color: #d99ca3 !important;
  }

  .slick-prev:before,
  .slick-next:before {
    content: "" !important;
    background: url("../images/2021/service/slider-left.svg") no-repeat;
    background-size: 100%;
    width: 15px;
    height: 40px;
    position: absolute;
    top: 30px;
  }

  .slick-prev:before {
    left: -8px;
  }

  .slick-next:before {
    background: url("../images/2021/service/slider-right.svg") no-repeat;
    background-size: 100%;
    right: -8px;
  }

  .slick-prev {
    left: 0 !important;
  }

  .slick-next {
    right: 0 !important;
  }
}

/*//////////////////// 記事エリア ////////////////////*/
#articleArea {
  background: url("../images/2021/common/stripe.png") #fafafa;
  padding: 80px 0;
}

.articleArea__text {
  font-size: 16px;
  color: #555;
  line-height: 1.8;
}

.articleArea__inner {
  background: #fff;
  box-shadow: 5px 5px 6px #ebebeb, -5px -5px 6px #ebebeb;
  margin: 5% auto 0;
  padding: 3% 5%;
  width: 950px;
}

.articleArea__block {
  display: table;
  text-align: left;
  margin-bottom: 7%;
}

.articleArea__block img,
.articleArea__block div {
  display: table-cell;
  vertical-align: middle;
}

.articleArea__block div {
  padding-left: 5%;
}

.articleArea__block .heading {
  display: block;
  color: #e0bbbb;
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 15px;
}

.articleArea__block p {
  font-size: 16px;
  color: #555;
  margin-bottom: 20px;
}

#articleArea a.product__link {
  width: 380px;
  margin: 0 auto;
}

#articleArea a.product__link::before {
  background: url("../images/2021/common/arrow-right-white.svg") no-repeat;
  background-size: 100%;
  width: 8px;
  height: 16px;
  right: 20px;
  left: auto;
  top: 16px;
}

.gift-concierge {
  margin-top: 80px;
}

img.gift-concierge__title {
  width: 360px;
  height: auto;
}

.gift-concierge p {
  font-size: 16px;
  margin: 15px 0;
}

a.gift-concierge__link {
  display: block;
  border: 1px solid #888888;
  padding: 10px 0;
  width: 380px;
  position: relative;
  border-radius: 50px;
  font-size: 18px;
  margin: 0 auto 25px;
  position: relative;
}

a.gift-concierge__link,
a.gift-concierge__link:link,
a.gift-concierge__link:visited {
  color: #888888;
}

a.gift-concierge__link::before {
  content: "";
  background: url("../images/2021/article/arrow-right-glay.svg") no-repeat;
  background-size: 100%;
  width: 8px;
  height: 16px;
  position: absolute;
  right: 20px;
  top: 16px;
}

.sns-link a {
  display: inline-block;
  margin: 0 5px;
}

.twitter img {
  margin-top: 3px;
}

@media only screen and (max-width: 599px) {
  #articleArea {
    padding: 60px 0;
  }

  .articleArea__inner {
    padding: 3% 5% 10%;
  }

  .articleArea__text {
    font-size: 13px;
    text-align: left;
  }

  .articleArea__inner {
    width: 100%;
  }

  .articleArea__block,
  .articleArea__block img,
  .articleArea__block div {
    display: block;
  }

  .articleArea__block img {
    margin: 0 auto 10px;
    width: 100%;
    height: auto;
  }

  .articleArea__block div {
    padding-left: 0;
    margin-bottom: 15%;
    line-height: 1.5;
  }

  .articleArea__block .heading {
    font-size: 16px;
  }

  .articleArea__block p {
    font-size: 14px;
  }

  #articleArea a.product__link {
    width: 80%;
  }

  img.gift-concierge__title {
    width: 100%;
  }

  .gift-concierge p {
    font-size: 14px;
  }

  a.gift-concierge__link {
    width: 80%;
    font-size: 14px;
  }
}

/*//////////////////// FAQエリア ////////////////////*/
#faqArea {
  padding-top: 165px;
  margin-top: -165px;
}

.faq-list {
  text-align: left;
  font-size: 16px;
  color: #555;
}

.faq-q-text {
  padding-left: 54px;
  position: relative;
  top: -32px;
}

.faq-q > span,
.faq-a > span {
  background: #99d6d9;
  display: inline-block;
  color: #fff;
  height: 35px;
  width: 35px;
  border-radius: 50%;
  margin-right: 10px;
  text-align: center;
  line-height: 35px;
}

.faq-a > span {
  background: #e0bbbb;
}

.faq-a-text {
  padding-left: 54px;
  position: relative;
  top: -35px;
  line-height: 1.8;
}

.faq-address {
  margin-top: 15px;
  line-height: 1.5;
  padding-left: 0;
}

#sel-wrapper #faq a {
  display: inline-block;
}

@media only screen and (max-width: 599px) {
  #faqArea {
    padding-top: 80px;
    margin-top: -80px;
  }

  .faq-list {
    font-size: 14px;
  }

  .faq-q {
    height: 70px;
  }
}

/*//////////////////// 問い合わせエリア ////////////////////*/
.contact {
  background: #99d6d9;
  color: #fff;
  padding: 50px 0 55px;
}

.rb2019---main .rb2019---inner {
  padding-left: 56px;
  padding-right: 56px;
}

.contact__title {
  font-family: "Yu Gothic", "YuGothic", "Hiragino Kaku Gothic ProN", "Meiryo",
    sans-serif;
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 1.5em;
  color: #fff;
}

.contact__body {
  max-width: 1200px;
  -webkit-align-items: stretch;
  align-items: stretch;
  -webkit-box-align: stretch;
  -webkit-box-pack: justify;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  -ms-flex-pack: distribute;
  justify-content: space-around;
  margin: 0 auto;
}

.contact__left,
.contact__right {
  width: 480px;
  background: #fff;
  border-radius: 5px;
  box-shadow: 6px 6px 9px #81ccd0, -6px -6px 9px #81ccd0;
  padding: 20px;
}

.contact__text {
  font-size: 18px;
  color: #333;
}

.tel__link,
.tel__link:link,
.tel__link:visited {
  color: #fff;
}

.tel__link img {
  position: relative;
  top: 15px;
  left: -12px;
}

.contact .tel > a {
  color: #99d6d9;
  font-size: 39px;
  font-weight: bold;
}

.contact__tel-info {
  color: #333333;
  font-size: 14px;
  text-align: center;
}

a.contact__button {
  display: block;
  width: 90%;
  height: 50px;
  line-height: 50px;
  border: 2px solid #99d6d9;
  border-radius: 50px;
  text-align: center;
  margin: 20px auto 0;
  font-weight: bold;
  position: relative;
}

a.contact__button,
a.contact__button:link,
a.contact__button:visited {
  color: #99d6d9;
}

a.contact__button::before {
  content: "";
  background: url("../images/2021/common/mail.svg") no-repeat;
  background-size: 100%;
  width: 36px;
  height: 25px;
  position: absolute;
  top: 10px;
  left: 57px;
}

@media only screen and (max-width: 599px) {
  .contact {
    padding: 25px 0;
  }

  .rb2019---main .rb2019---inner {
    padding-left: 15px;
    padding-right: 15px;
  }

  .contact__title {
    font-size: 18px;
    margin-bottom: 20px;
  }

  .contact__body {
    display: block;
  }

  .contact__left,
  .contact__right {
    width: 100%;
    margin-bottom: 25px;
  }

  .contact__text {
    font-size: 14px;
  }

  .contact .tel > a {
    height: 30px;
    font-size: 30px;
  }

  .tel__link img {
    top: 13px;
    left: -7px;
  }

  .tel-info,
  .tel-info small {
    line-height: 1.4;
  }

  .contact__tel-info {
    border-radius: 8px;
  }

  .contact__button {
    width: 100%;
    font-size: 14px;
    border-radius: 3px;
  }

  a.contact__button::before {
    width: 28px;
    height: 20px;
    top: 14px;
    left: 36px;
  }

  .rb2019---footer {
    margin-top: 0;
  }

  a.contact__button {
    width: 100%;
  }
}

/*//////////////////// サイドナビエリア ////////////////////*/
a.side-nav__trigger,
a.side-nav__trigger:link {
  color: #fff;
}

.rb2019---header-fixed .side-nav__trigger {
  opacity: 1;
  pointer-events: auto;
  z-index: 99;
}

.side-nav__trigger {
  -webkit-align-items: center;
  align-items: center;
  -webkit-animation: side-nav-trigger-swing infinite 2s linear;
  animation: side-nav-trigger-swing infinite 2s linear;
  background: #cebb90;
  border-radius: 50px;
  -webkit-box-align: center;
  -webkit-box-direction: normal;
  -webkit-box-orient: vertical;
  -webkit-box-pack: center;
  display: -webkit-box !important;
  display: -webkit-flex !important;
  display: flex !important;
  -webkit-flex-direction: column;
  flex-direction: column;
  font-size: 13px;
  height: 100px;
  -webkit-justify-content: center;
  justify-content: center;
  line-height: 1.2;
  opacity: 0;
  position: fixed;
  right: 16px;
  text-align: center;
  bottom: 50px;
  -webkit-transition: opacity 0.3s ease;
  -webkit-transition: opacity 0.2s ease;
  transition: opacity 0.3s ease;
  transition: opacity 0.2s ease;
  width: 100px;
  z-index: 0;
}

.rb2019---icon.rb2019---icon__search::before {
  content: "";
  background: url("../images/2021/common/search.png") no-repeat;
  display: block;
  width: 35px;
  height: 41px;
  background-size: 100%;
}

.side-nav__trigger i {
  font-size: 48px;
}

.side-nav.rb2019---dialog {
  z-index: 1100;
}

.rb2019---header-fixed .side-nav__trigger:hover {
  opacity: 0.6;
}

.rb2019---header-fixed .side-nav__trigger.hidden {
  opacity: 0;
}

@-webkit-keyframes side-nav-trigger-swing {
  0% {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
  }
  50% {
    -webkit-transform: translate(0, 16px);
    transform: translate(0, 16px);
  }
}

@keyframes side-nav-trigger-swing {
  0% {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
  }
  50% {
    -webkit-transform: translate(0, 16px);
    transform: translate(0, 16px);
  }
}

.side-nav__inner {
  -webkit-animation: side-nav-open-bg 0.3s ease 1 forwards;
  animation: side-nav-open-bg 0.3s ease 1 forwards;
  background: rgba(0, 0, 0, 0);
  bottom: 0;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
}

.is-closing .side-nav__inner {
  -webkit-animation: side-nav-close-bg 0.3s ease 1;
  animation: side-nav-close-bg 0.3s ease 1;
}

.side-nav__body {
  -webkit-animation: side-nav-open 0.3s ease 1 forwards;
  animation: side-nav-open 0.3s ease 1 forwards;
  background: rgba(255, 255, 255, 0.9);
  bottom: 0;
  box-shadow: 0 0 10px 5px rgba(0, 0, 0, 0.2);
  overflow-x: hidden;
  overflow-y: auto;
  position: absolute;
  right: 0;
  top: 0;
  -webkit-transform: translate(400px, 0);
  transform: translate(400px, 0);
  width: 400px;
}

.is-closing .side-nav__body {
  -webkit-animation: side-nav-close 0.3s ease 1;
  animation: side-nav-close 0.3s ease 1;
}

@-webkit-keyframes side-nav-open-bg {
  0% {
    background: rgba(0, 0, 0, 0);
  }
  100% {
    background: rgba(0, 0, 0, 0.5);
  }
}

@keyframes side-nav-open-bg {
  0% {
    background: rgba(0, 0, 0, 0);
  }
  100% {
    background: rgba(0, 0, 0, 0.5);
  }
}

@-webkit-keyframes side-nav-close-bg {
  0% {
    background: rgba(0, 0, 0, 0.5);
  }
  100% {
    background: rgba(0, 0, 0, 0);
  }
}

@keyframes side-nav-close-bg {
  0% {
    background: rgba(0, 0, 0, 0.5);
  }
  100% {
    background: rgba(0, 0, 0, 0);
  }
}

@-webkit-keyframes side-nav-open {
  0% {
    -webkit-transform: translate(400px, 0);
    transform: translate(400px, 0);
  }
  100% {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
  }
}

@keyframes side-nav-open {
  0% {
    -webkit-transform: translate(400px, 0);
    transform: translate(400px, 0);
  }
  100% {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
  }
}

@-webkit-keyframes side-nav-close {
  0% {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
  }
  100% {
    -webkit-transform: translate(400px, 0);
    transform: translate(400px, 0);
  }
}

@keyframes side-nav-close {
  0% {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
  }
  100% {
    -webkit-transform: translate(400px, 0);
    transform: translate(400px, 0);
  }
}

.side-nav__close {
  font-size: 32px;
  position: absolute;
  right: 10px;
  top: 10px;
}

.side-nav__content {
  padding: 50px 16px 0;
}

.side-nav__group {
  margin-bottom: 16px;
}

.side-nav__group + .side-nav__group {
  border-top: 1px solid #ccc;
  padding-top: 16px;
}

.side-nav__group-name {
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 16px;
  text-align: center;
}

.side-nav__search form {
  -webkit-align-items: center;
  align-items: center;
  -webkit-box-align: center;
  -webkit-box-pack: justify;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}

.side-nav__search input[type="text"] {
  border: 1px solid #999;
  font-size: 16px;
  height: 40px;
  padding: 0 0.5em;
  width: 70%;
}

.side-nav__search button {
  background: #99d6d9;
  border-radius: 4px;
  color: #fff;
  font-weight: bold;
  height: 40px;
  width: -webkit-calc(30% - 8px);
  width: calc(30% - 8px);
}

.side-nav__form .form-select {
  height: 40px;
  width: -webkit-calc(50% - 14px);
  width: calc(50% - 14px);
}

.side-nav__form .form-select__element {
  font-size: 14px;
  font-weight: bold;
  padding-left: 32px;
}

.side-nav__form .form-select__icon:nth-of-type(1) {
  height: auto;
  left: 8px;
  width: 16px;
}

.side-nav__form .form-select__icon:nth-of-type(2) {
  height: auto;
  left: auto;
  right: 8px;
  width: 16px;
}

.side-nav__form .search__fields {
  margin-bottom: 16px;
}

.side-nav__form .search__cross {
  height: auto;
  margin: 0 8px;
  width: 12px;
}

.side-nav__form .form-button {
  font-size: 16px;
  font-weight: bold;
  margin: 0 auto;
  width: 100%;
}

.side-nav__links {
  -webkit-align-items: center;
  align-items: center;
  -webkit-box-align: center;
  -webkit-box-pack: start;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
}

.side-nav__links a,
.side-nav__links a:link,
.side-nav__links a:visited,
.side-nav__links a:hover,
.side-nav__links a:focus,
.side-nav__links a:active {
  color: #333;
}

.side-nav__links a {
  -webkit-align-items: center;
  align-items: center;
  -webkit-box-align: center;
  -webkit-box-pack: center;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-basis: -webkit-calc(100% / 2);
  flex-basis: calc(100% / 2);
  font-size: 14px;
  font-weight: bold;
  -webkit-justify-content: center;
  justify-content: center;
  width: -webkit-calc(100% / 2);
  width: calc(100% / 2);
  margin-bottom: 8px;
}

.side-nav .rb2019---icon.rb2019---icon__times::before {
  content: "";
  background: url("../images/2021/common/close.png") no-repeat;
  display: block;
  width: 20px;
  height: 20px;
  background-size: 100%;
  position: relative;
  top: 7px;
}

/* スクロールナビ */
.fixed-nav {
  position: fixed;
  right: 0;
  top: 0;
  cursor: pointer;
  transition: 0.3s;
  display: none;
  background: #d8c0d4;
  color: #fff;
  width: 100%;
  height: 60px;
  z-index: 999;
}
/*このクラスが付与されると表示する*/
.active {
  display: block;
}

.fixed-nav-inner {
  width: 1230px;
  margin: 0 auto;
}

.fixed-nav-list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-align-items: stretch;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  border-right: 1px solid #fff;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.fixed-nav-list li {
  font-size: 14px;
  -webkit-flex: 1;
  -ms-flex: 1;
  -webkit-box-flex: 1;
  flex: 1;
  border-left: 1px solid #fff;
}

#sel-wrapper nav .fixed-nav-list li a {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-align-items: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-justify-content: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  height: 60px;
  color: #fff;
}

@media only screen and (max-width: 599px) {
  .side-nav__close {
    border: none;
  }

  .side-nav__close:focus,
  .side-nav__search button:focus,
  .side-nav__form .form-button:focus,
  .side-nav__search input[type="text"]:focus {
    outline: 0;
  }

  .side-nav__inner {
    padding: 0;
  }

  .side-nav__body {
    width: 100%;
  }

  span.form-select {
    width: calc(100% - 14px) !important;
    margin: 1em;
  }

  .side-nav__trigger {
    height: 80px;
    width: 80px;
    font-size: 11px;
    top: auto;
    bottom: 6rem;
    right: 4px;
    opacity: 1;
    pointer-events: all;
    z-index: 1;
  }

  .rb2019---icon__search::before {
    width: 90%;
    height: 34px;
    background-position: center top;
    background-size: auto 90%;
  }

  .side-nav__inner {
    position: fixed;
    z-index: 999;
  }

  .side-nav__search button,
  .side-nav__form .form-button {
    border: none;
  }

  .side-nav .rb2019---icon__times::before {
    right: 0;
  }

  body .rb2019---header {
    position: relative;
  }

  body .rb2019---base {
    padding-top: 0;
  }

  .fixed-nav-inner {
    width: 100%;
  }

  .fixed-nav-list {
    background: #d8c0d4;
  }

  .fixed-nav-list li {
    width: 20%;
    flex: none;
    border-bottom: 1px solid #fff;
  }

  #sel-wrapper nav .fixed-nav-list li a {
    font-size: 12px;
  }

  .side-nav__form .form-select__element {
    font-size: 15px;
    padding-left: 103px;
  }
}

img:not([width]) {
  box-shadow: 0 0 0 4px red;
}

.no1 {
  margin: 40px 0 0 auto;
  width: 501px;
}

.no1__banner {
  display: block;
}
.no1__banner img {
  width: 100%;
  height: auto;
  padding: 0;
}

.no1__note {
  font-size: 9px;
  margin-top: 10px;
}

.no1__note a,
.no1__note a:link,
.no1__note a:visited {
  color: inherit;
  text-decoration: underline;
}

@media only screen and (max-width: 599px) {
  .no1 {
    margin: 2rem 0 0;
    width: auto;
  }
  .no1__banner img {
    margin-bottom: 0;
  }
  .no1__note {
    margin-top: 0.5rem;
    font-size: 0.8rem;
  }
}
