@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@700;900&display=swap");
@import url("https://use.typekit.net/seo8thd.css");
.effect {
  opacity: 0;
}

.font-m1 {
  font-family: hiragino-kaku-gothic-pron, "Hiragino Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
  font-style: normal;
}

.font-futura {
  font-family: "futura-pt-bold", sans-serif;
  font-weight: 700;
  font-style: normal;
}
.font-futura-normal {
  font-family: "futura-pt", sans-serif;
  font-weight: 400;
  font-style: normal;
}

#lp-familysale {
  color: #000;
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
  -webkit-font-smoothing: antialiased;
  margin: 0 auto;
  text-align: left;
  font-size: 14px;
  font-family: hiragino-kaku-gothic-pron, "Hiragino Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
  font-weight: 400;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.1em;
  width: 100%;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  #lp-familysale {
    width: 100%;
    overflow: hidden;
  }
}
@media screen and (max-width: 767px) {
  #lp-familysale .pc {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  #lp-familysale .sp {
    display: none;
  }
}
#lp-familysale img {
  width: 100%;
}
#lp-familysale a {
  display: block;
  cursor: pointer;
  -webkit-transition: opacity 0.3s cubic-bezier(0.33, 1, 0.68, 1);
  transition: opacity 0.3s cubic-bezier(0.33, 1, 0.68, 1);
}
#lp-familysale a:hover {
  opacity: 0.6;
}
#lp-familysale section.sec-main .image {
  width: 100%;
  position: relative;
  z-index: 2;
}
#lp-familysale section.sec-main .image img {
  width: 100%;
  height: auto;
}
#lp-familysale section.sec-main .title {
  width: 60%;
  margin: -8% auto 0;
}
@media screen and (max-width: 767px) {
  #lp-familysale section.sec-main .title {
    width: 98%;
    margin: -7.5% auto 0;
  }
}
#lp-familysale section.sec-main .title img {
  width: 100%;
  height: auto;
}
#lp-familysale section.sec-about {
  position: relative;
  width: 100%;
}
@media screen and (max-width: 767px) {
  #lp-familysale section.sec-about {
    width: 100%;
    padding: 8px 0 0px;
  }
}
#lp-familysale section.sec-about .container {
  width: calc(100% - 100px);
  max-width: 1100px;
  margin: 80px auto 0;
}
@media screen and (max-width: 767px) {
  #lp-familysale section.sec-about .container {
    width: 100%;
    padding: 0 20px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    margin: 52px auto 0;
  }
}
#lp-familysale section.sec-about h2.about-text {
  position: relative;
  color: #60646e;
  font-size: 31px;
  font-weight: 800;
  line-height: 1.8;
}
#lp-familysale section.sec-about .container h3 {
  position: relative;
  color: #dc0816;
  font-size: 38px;
  font-family: hiragino-kaku-gothic-pron, "Hiragino Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
  font-weight: 800;
  font-style: normal;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  text-align: left;
  letter-spacing: -0.02em;
  line-height: 1.6;
  margin-top: 60px;
}
#lp-familysale section.sec-about .date {
  font-weight: 800 !important;
  font-family: "futura-pt-bold", hiragino-kaku-gothic-pron, "Hiragino Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
  font-size: 38px;
  margin-top: 10px;
  letter-spacing: 0em;
  color: #60646e;
}
#lp-familysale section.sec-about .date span.jp {
  position: relative;
  font-size: 0.8em;
  top: -1px;
}
@media screen and (max-width: 767px) {
  #lp-familysale section.sec-about h2.about-text {
    font-size: 19.5px;
    letter-spacing: -0.05em;
    line-height: 1.85;
  }
  #lp-familysale section.sec-about .container h3 {
    font-size: 20px;
    letter-spacing: -0.05em;
    line-height: 1.85;
    margin-top: 50px;
  }
  #lp-familysale section.sec-about .date {
    margin-top: 0;
    font-size: 22px;
  }
}

#lp-familysale section.sec-info {
  position: relative;
  width: 100%;
}
@media screen and (max-width: 767px) {
  #lp-familysale section.sec-info {
    width: 100%;
    padding: 8px 0 0px;
  }
}
#lp-familysale section.sec-info .container {
  width: calc(100% - 100px);
  max-width: 1100px;
  margin: 60px auto 0;
}
@media screen and (max-width: 767px) {
  #lp-familysale section.sec-info .container {
    width: 100%;
    padding: 0 15px;
    margin: 30px auto 0;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
}
#lp-familysale section.sec-info .sec-info-block {
  padding-bottom: 60px;
}
@media screen and (max-width: 767px) {
  #lp-familysale section.sec-info .sec-info-block {
    padding-bottom: 40px;
  }
}
#lp-familysale section.sec-info .sec-info-block .title {
  display: inline-block;
  text-align: center;
  color: #fff;
  background: #dc0816;
  border-radius: 20px;
  padding: 3px 15px;
  font-weight: 600;
  font-size: 16px;
  line-height: 1.53;
  margin-bottom: 1vw;
  min-width: 100px;
}
#lp-familysale section.sec-info .sec-info-block .note li {
  position: relative;
  padding-left: 15px;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.55;
  letter-spacing: -0.02em;
  color: #60646e;
  padding-top: 15px;
}
#lp-familysale section.sec-info .sec-info-block .note li:before {
  position: absolute;
  content: "・";
  top: 15px;
  left: 0;
}
@media screen and (max-width: 820px) {
  #lp-familysale section.sec-info .sec-info-block .note li br.pc {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  #lp-familysale section.sec-info .sec-info-block .note li {
    font-size: 12px;
    padding-left: 10px;
    line-height: 1.35;
    letter-spacing: 0em;
    padding-top: 8px;
  }
  #lp-familysale section.sec-info .sec-info-block .note li:before {
    top: 8px;
  }
}
@media screen and (max-width: 767px) {
  #lp-familysale section.sec-info .sec-info-block .title {
    padding: 5px 15px;
    font-size: 14px;
    line-height: 14px;
    margin-bottom: 4vw;
  }
}
#lp-familysale section.sec-info .sec-info-block p {
  font-size: 24px;
  font-weight: 600;
  line-height: 2;
  letter-spacing: 0em;
  color: #60646e;
}
#lp-familysale section.sec-info .sec-info-block p.large {
  font-size: 28px;
}
#lp-familysale section.sec-info .sec-info-block p.small {
  font-size: 20px;
}
#lp-familysale section.sec-info .sec-info-block .underline {
  border-bottom: 2px solid;
  padding-bottom: 2px;
}
@media screen and (max-width: 767px) {
  #lp-familysale section.sec-info .sec-info-block p {
    font-size: 14px;
  }
  #lp-familysale section.sec-info .sec-info-block p.large {
    font-size: 16px;
  }
  #lp-familysale section.sec-info .sec-info-block p.small {
    font-size: 12px;
  }
}
#lp-familysale section.sec-info .sec-info-block .btn-map a {
  display: block;
  width: 120px;
  height: 40px;
  background: #60646e;
  text-align: center;
  border-radius: 50px;
  color: #fff;
  padding: 11px 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  letter-spacing: 0.02em;
  font-size: 17px;
}
@media screen and (max-width: 767px) {
  #lp-familysale section.sec-info .sec-info-block .btn-map a {
    width: 75px;
    height: 30px;
    font-size: 10px;
    padding: 10px 0;
  }
}
#lp-familysale section.sec-info .sec-info-block .btn-map a span {
  position: relative;
  padding-right: 18px;
}
@media screen and (max-width: 767px) {
  #lp-familysale section.sec-info .sec-info-block .btn-map a span {
    padding-right: 10px;
  }
}
#lp-familysale section.sec-info .sec-info-block .btn-map a span:before {
  position: absolute;
  content: "";
  top: -1px;
  right: -5px;
  background: url("https://cf.graniph.com/banner/other/familysale/icon_blank.png") center center no-repeat;
  width: 18px;
  height: 18px;
  background-size: contain;
}
@media screen and (max-width: 767px) {
  #lp-familysale section.sec-info .sec-info-block .btn-map a span:before {
    top: -1px;
    width: 12px;
    height: 12px;
  }
}
#lp-familysale section.sec-info .sec-info-block .place {
  display: flex;
  gap: 80px;
  align-items: center;
  padding-bottom: 10px;
}
@media screen and (max-width: 767px) {
  #lp-familysale section.sec-info .sec-info-block .place {
    gap: 10px;
  }
}
#lp-familysale section.sec-info .sec-info-block .payment li {
  padding-bottom: 30px;
}
#lp-familysale section.sec-info .sec-info-block .payment li:first-child {
  padding-bottom: 20px;
}
#lp-familysale section.sec-info .sec-info-block .payment .payment-img {
  width: 60%;
}
#lp-familysale section.sec-info .sec-info-block .inquiry {
  padding-bottom: 20px;
}
#lp-familysale section.sec-info .sec-info-block .inquiry a {
  display: inline-block;
}
@media screen and (max-width: 767px) {
  #lp-familysale section.sec-info .sec-info-block .payment li {
    padding-bottom: 20px;
  }
  #lp-familysale section.sec-info .sec-info-block .payment li:first-child {
    padding-bottom: 10px;
  }
  #lp-familysale section.sec-info .sec-info-block .payment .payment-img {
    width: 100%;
  }
  #lp-familysale section.sec-info .sec-info-block .inquiry {
    padding-bottom: 10px;
  }
  #lp-familysale section.sec-info .sec-info-block .inquiry a {
    font-size: 12px;
  }
}

#lp-familysale section.sec-info .invitation {
  max-width: 380px;
  margin: 0 auto;
  padding: 30px 0 80px;
}
#lp-familysale section.sec-info .invitation .button {
  position: relative;
  width: 100%;
  height: 100%;
  display: block;
  background: #dc0816;
  color: #fff;
  text-align: center;
  font-weight: bold;
  padding: 25px 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  font-size: 20px;
  border-radius: 100px;
  letter-spacing: 0.05em;
}
#lp-familysale section.sec-info .invitation .button::after {
  content: "";
  position: absolute;
  width: 12px;
  height: 12px;
  top: 50%;
  right: 12%;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: translateY(-50%) rotate(45deg);
}
@media screen and (max-width: 767px) {
  #lp-familysale section.sec-info .invitation {
    max-width: 280px;
    padding: 20px 0 50px;
  }
  #lp-familysale section.sec-info .invitation .button {
    font-size: 14px;
    padding: 20px 0;
  }
  #lp-familysale section.sec-info .invitation .button::after {
    width: 10px;
    height: 10px;
    right: 12%;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
  }
}
