@charset "UTF-8";
* {
  border: 0;
  outline: none;
  vertical-align: baseline;
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  list-style: none;
  text-decoration: none;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  font-feature-settings: "palt" on;
  line-height: 180%;
  letter-spacing: 0.04em;
}

html {
  height: 100%;
  -webkit-overflow-scrolling: touch;
}

body {
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(calc(16 / 1080 * 100vw), 16px);
  height: 100%;
  -webkit-overflow-scrolling: touch;
  overflow-x: hidden;
}
@media screen and (max-width: 767px) {
  body {
    font-size: calc(30 / 750 * 100vw);
  }
}

h1,
h2 {
  position: relative;
  font-weight: 700;
}

*:focus {
  outline: none;
}

p a {
  word-break: break-all;
  text-decoration: underline;
}

sup {
  vertical-align: top;
  font-size: 50%;
}

sub {
  vertical-align: baseline;
  font-size: 50%;
}

em,
b,
strong,
th {
  font-weight: 700;
}

a {
  color: #333;
  cursor: pointer;
  transition: opacity 0.3s;
}

figcaption,
small {
  font-size: min(calc(12 / 1080 * 100vw), 12px);
}
@media screen and (max-width: 767px) {
  figcaption,
  small {
    font-size: calc(20 / 750 * 100vw);
  }
}

img {
  display: block;
  height: auto;
}

input,
button,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  font: inherit;
  outline: none;
}

textarea {
  resize: vertical;
}

input[type=checkbox],
input[type=radio] {
  display: none;
}

input[type=submit],
input[type=button],
label,
button,
select {
  cursor: pointer;
}

select::-ms-expand {
  display: none;
}

@media screen and (min-width: 768px) {
  .adlp-outer {
    overflow-x: hidden;
    display: flex;
    justify-content: center;
    align-items: flex-start;
  }
}
@media screen and (max-width: 767px) {
  .adlp-outer {
    overflow: hidden;
  }
}

@media screen and (min-width: 768px) {
  .adlp-wrapper {
    min-width: min(calc(1920 / 1080 * 100vw), 1920px);
    max-width: 1920px;
    margin: 0 auto;
  }
}
.adlp-wrapper .relative {
  position: relative;
}
.adlp-wrapper .w100 {
  width: 100% !important;
  display: block;
}
.adlp-wrapper .center {
  text-align: center;
}
@media screen and (min-width: 768px) {
  .adlp-wrapper .sp {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .pc {
    display: none !important;
  }
}
.adlp-wrapper .text__txt {
  color: #333 !important;
}
.adlp-wrapper .text__white {
  color: #fff !important;
}
.adlp-wrapper .text__silver {
  color: #f1f1f1 !important;
}
.adlp-wrapper .text__accent {
  color: #E75B18 !important;
}
.adlp-wrapper .bg__txt {
  background: #333 !important;
}
.adlp-wrapper .bg__white {
  background: #fff !important;
}
.adlp-wrapper .bg__silver {
  background: #f1f1f1 !important;
}
.adlp-wrapper .bg__accent {
  background: #E75B18 !important;
}
.adlp-wrapper .line__top__txt {
  border-top: 1px solid #333;
}
.adlp-wrapper .line__top.--w2 {
  border-width: min(calc(2 / 1080 * 100vw), 2px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line__top.--w2 {
    border-width: calc(2 / 750 * 100vw);
  }
}
.adlp-wrapper .line__top.--w3 {
  border-width: min(calc(3 / 1080 * 100vw), 3px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line__top.--w3 {
    border-width: calc(3 / 750 * 100vw);
  }
}
.adlp-wrapper .line__top.--w4 {
  border-width: min(calc(4 / 1080 * 100vw), 4px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line__top.--w4 {
    border-width: calc(4 / 750 * 100vw);
  }
}
.adlp-wrapper .line__top__white {
  border-top: 1px solid #fff;
}
.adlp-wrapper .line__top.--w2 {
  border-width: min(calc(2 / 1080 * 100vw), 2px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line__top.--w2 {
    border-width: calc(2 / 750 * 100vw);
  }
}
.adlp-wrapper .line__top.--w3 {
  border-width: min(calc(3 / 1080 * 100vw), 3px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line__top.--w3 {
    border-width: calc(3 / 750 * 100vw);
  }
}
.adlp-wrapper .line__top.--w4 {
  border-width: min(calc(4 / 1080 * 100vw), 4px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line__top.--w4 {
    border-width: calc(4 / 750 * 100vw);
  }
}
.adlp-wrapper .line__top__silver {
  border-top: 1px solid #f1f1f1;
}
.adlp-wrapper .line__top.--w2 {
  border-width: min(calc(2 / 1080 * 100vw), 2px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line__top.--w2 {
    border-width: calc(2 / 750 * 100vw);
  }
}
.adlp-wrapper .line__top.--w3 {
  border-width: min(calc(3 / 1080 * 100vw), 3px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line__top.--w3 {
    border-width: calc(3 / 750 * 100vw);
  }
}
.adlp-wrapper .line__top.--w4 {
  border-width: min(calc(4 / 1080 * 100vw), 4px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line__top.--w4 {
    border-width: calc(4 / 750 * 100vw);
  }
}
.adlp-wrapper .line__top__accent {
  border-top: 1px solid #E75B18;
}
.adlp-wrapper .line__top.--w2 {
  border-width: min(calc(2 / 1080 * 100vw), 2px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line__top.--w2 {
    border-width: calc(2 / 750 * 100vw);
  }
}
.adlp-wrapper .line__top.--w3 {
  border-width: min(calc(3 / 1080 * 100vw), 3px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line__top.--w3 {
    border-width: calc(3 / 750 * 100vw);
  }
}
.adlp-wrapper .line__top.--w4 {
  border-width: min(calc(4 / 1080 * 100vw), 4px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line__top.--w4 {
    border-width: calc(4 / 750 * 100vw);
  }
}
.adlp-wrapper .marker__txt {
  background: linear-gradient(transparent 60%, #333 60%);
}
.adlp-wrapper .marker__white {
  background: linear-gradient(transparent 60%, #fff 60%);
}
.adlp-wrapper .marker__silver {
  background: linear-gradient(transparent 60%, #f1f1f1 60%);
}
.adlp-wrapper .marker__accent {
  background: linear-gradient(transparent 60%, #E75B18 60%);
}
.adlp-wrapper .line__txt {
  border-bottom: 1px solid #333;
}
.adlp-wrapper .line.--w2 {
  border-width: min(calc(2 / 1080 * 100vw), 2px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line.--w2 {
    border-width: calc(2 / 750 * 100vw);
  }
}
.adlp-wrapper .line.--w3 {
  border-width: min(calc(3 / 1080 * 100vw), 3px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line.--w3 {
    border-width: calc(3 / 750 * 100vw);
  }
}
.adlp-wrapper .line.--w4 {
  border-width: min(calc(4 / 1080 * 100vw), 4px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line.--w4 {
    border-width: calc(4 / 750 * 100vw);
  }
}
.adlp-wrapper .line__white {
  border-bottom: 1px solid #fff;
}
.adlp-wrapper .line.--w2 {
  border-width: min(calc(2 / 1080 * 100vw), 2px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line.--w2 {
    border-width: calc(2 / 750 * 100vw);
  }
}
.adlp-wrapper .line.--w3 {
  border-width: min(calc(3 / 1080 * 100vw), 3px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line.--w3 {
    border-width: calc(3 / 750 * 100vw);
  }
}
.adlp-wrapper .line.--w4 {
  border-width: min(calc(4 / 1080 * 100vw), 4px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line.--w4 {
    border-width: calc(4 / 750 * 100vw);
  }
}
.adlp-wrapper .line__silver {
  border-bottom: 1px solid #f1f1f1;
}
.adlp-wrapper .line.--w2 {
  border-width: min(calc(2 / 1080 * 100vw), 2px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line.--w2 {
    border-width: calc(2 / 750 * 100vw);
  }
}
.adlp-wrapper .line.--w3 {
  border-width: min(calc(3 / 1080 * 100vw), 3px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line.--w3 {
    border-width: calc(3 / 750 * 100vw);
  }
}
.adlp-wrapper .line.--w4 {
  border-width: min(calc(4 / 1080 * 100vw), 4px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line.--w4 {
    border-width: calc(4 / 750 * 100vw);
  }
}
.adlp-wrapper .line__accent {
  border-bottom: 1px solid #E75B18;
}
.adlp-wrapper .line.--w2 {
  border-width: min(calc(2 / 1080 * 100vw), 2px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line.--w2 {
    border-width: calc(2 / 750 * 100vw);
  }
}
.adlp-wrapper .line.--w3 {
  border-width: min(calc(3 / 1080 * 100vw), 3px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line.--w3 {
    border-width: calc(3 / 750 * 100vw);
  }
}
.adlp-wrapper .line.--w4 {
  border-width: min(calc(4 / 1080 * 100vw), 4px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .line.--w4 {
    border-width: calc(4 / 750 * 100vw);
  }
}
.adlp-wrapper .pad10 {
  padding: min(calc(10 / 1080 * 100vw), 10px) 0;
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .pad10 {
    padding-top: calc(10 / 750 * 100vw) !important;
    padding-bottom: calc(10 / 750 * 100vw) !important;
  }
}
.adlp-wrapper .pad20 {
  padding: min(calc(20 / 1080 * 100vw), 20px) 0;
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .pad20 {
    padding-top: calc(20 / 750 * 100vw) !important;
    padding-bottom: calc(20 / 750 * 100vw) !important;
  }
}
.adlp-wrapper .pad30 {
  padding: min(calc(30 / 1080 * 100vw), 30px) 0;
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .pad30 {
    padding-top: calc(30 / 750 * 100vw) !important;
    padding-bottom: calc(30 / 750 * 100vw) !important;
  }
}
.adlp-wrapper .pad40 {
  padding: min(calc(40 / 1080 * 100vw), 40px) 0;
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .pad40 {
    padding-top: calc(40 / 750 * 100vw) !important;
    padding-bottom: calc(40 / 750 * 100vw) !important;
  }
}
.adlp-wrapper .pad50 {
  padding: min(calc(50 / 1080 * 100vw), 50px) 0;
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .pad50 {
    padding-top: calc(50 / 750 * 100vw) !important;
    padding-bottom: calc(50 / 750 * 100vw) !important;
  }
}
.adlp-wrapper .pad60 {
  padding: min(calc(60 / 1080 * 100vw), 60px) 0;
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .pad60 {
    padding-top: calc(60 / 750 * 100vw) !important;
    padding-bottom: calc(60 / 750 * 100vw) !important;
  }
}
.adlp-wrapper .mt10 {
  margin-top: min(calc(10 / 1080 * 100vw), 10px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .mt10 {
    margin-top: calc(10 / 750 * 100vw);
  }
}
.adlp-wrapper .mt20 {
  margin-top: min(calc(20 / 1080 * 100vw), 20px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .mt20 {
    margin-top: calc(20 / 750 * 100vw);
  }
}
.adlp-wrapper .mt30 {
  margin-top: min(calc(30 / 1080 * 100vw), 30px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .mt30 {
    margin-top: calc(30 / 750 * 100vw);
  }
}
.adlp-wrapper .mt40 {
  margin-top: min(calc(40 / 1080 * 100vw), 40px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .mt40 {
    margin-top: calc(40 / 750 * 100vw);
  }
}
.adlp-wrapper .mt50 {
  margin-top: min(calc(50 / 1080 * 100vw), 50px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .mt50 {
    margin-top: calc(50 / 750 * 100vw);
  }
}
.adlp-wrapper .mt60 {
  margin-top: min(calc(60 / 1080 * 100vw), 60px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .mt60 {
    margin-top: calc(60 / 750 * 100vw);
  }
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .sp-mt10 {
    margin-top: calc(10 / 750 * 100vw) !important;
  }
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .sp-mt20 {
    margin-top: calc(20 / 750 * 100vw) !important;
  }
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .sp-mt30 {
    margin-top: calc(30 / 750 * 100vw) !important;
  }
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .sp-mt40 {
    margin-top: calc(40 / 750 * 100vw) !important;
  }
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .sp-mt50 {
    margin-top: calc(50 / 750 * 100vw) !important;
  }
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .sp-mt60 {
    margin-top: calc(60 / 750 * 100vw) !important;
  }
}
.adlp-wrapper .wrap500 {
  margin: auto;
  width: min(calc(500 / 1080 * 100vw), 500px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .wrap500 {
    width: 100%;
    padding: 0 calc(30 / 750 * 100vw);
  }
}
.adlp-wrapper .wrap600 {
  margin: auto;
  width: min(calc(600 / 1080 * 100vw), 600px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .wrap600 {
    width: 100%;
    padding: 0 calc(30 / 750 * 100vw);
  }
}
.adlp-wrapper .wrap700 {
  margin: auto;
  width: min(calc(700 / 1080 * 100vw), 700px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .wrap700 {
    width: 100%;
    padding: 0 calc(30 / 750 * 100vw);
  }
}
.adlp-wrapper .wrap800 {
  margin: auto;
  width: min(calc(800 / 1080 * 100vw), 800px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .wrap800 {
    width: 100%;
    padding: 0 calc(30 / 750 * 100vw);
  }
}
.adlp-wrapper .wrap900 {
  margin: auto;
  width: min(calc(900 / 1080 * 100vw), 900px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .wrap900 {
    width: 100%;
    padding: 0 calc(30 / 750 * 100vw);
  }
}
.adlp-wrapper .wrap920 {
  margin: auto;
  width: min(calc(920 / 1080 * 100vw), 920px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .wrap920 {
    width: 100%;
    padding: 0 calc(30 / 750 * 100vw);
  }
}
.adlp-wrapper .wrap1000 {
  margin: auto;
  width: min(calc(1000 / 1080 * 100vw), 1000px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .wrap1000 {
    width: 100%;
    padding: 0 calc(30 / 750 * 100vw);
  }
}
.adlp-wrapper .wrap1080 {
  margin: auto;
  width: min(calc(1080 / 1080 * 100vw), 1080px);
}
@media screen and (max-width: 767px) {
  .adlp-wrapper .wrap1080 {
    width: 100%;
    padding: 0 calc(30 / 750 * 100vw);
  }
}

.adlp-header {
  width: 100%;
  position: fixed;
  top: 0;
  left: 0;
  background: transparent;
  z-index: 100;
  background: white;
}
.adlp-header__inner {
  max-width: min(calc(1000 / 1080 * 100vw), 1000px);
  padding: min(calc(12 / 1080 * 100vw), 12px) min(calc(40 / 1080 * 100vw), 40px) min(calc(10 / 1080 * 100vw), 10px);
  margin: auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.adlp-header__logo {
  width: min(calc(171 / 1080 * 100vw), 171px);
}
.adlp-header__btn {
  width: min(calc(280 / 1080 * 100vw), 280px);
  position: relative;
}
.adlp-header__link {
  display: flex;
  align-items: center;
  background: linear-gradient(180deg, #a3095c 0%, #d52665 100%);
  color: #fff;
  padding: min(calc(10 / 1080 * 100vw), 10px) 0 min(calc(11 / 1080 * 100vw), 11px) min(calc(27 / 1080 * 100vw), 27px);
  border-radius: min(calc(3 / 1080 * 100vw), 3px);
}
.adlp-header__link:hover {
  opacity: 0.8;
}
.adlp-header__link::before {
  position: absolute;
  right: min(calc(10 / 1080 * 100vw), 10px);
  top: 50%;
  transform: translateY(-50%);
  content: "";
  display: block;
  width: min(calc(20 / 1080 * 100vw), 20px);
  height: min(calc(5 / 1080 * 100vw), 5px);
  background: url("../img/common/btn_arrow.svg") no-repeat center center/contain;
}
.adlp-header__link span {
  font-size: min(calc(18 / 1080 * 100vw), 18px);
  font-weight: 500;
  font-family: "Noto Serif JP", serif;
  text-decoration: none;
  transition: all 0.3s ease;
  line-height: 1.6;
  letter-spacing: 0.01em;
}

@media screen and (max-width: 767px) {
  .adlp-header__inner {
    padding: calc(16 / 750 * 100vw) 0;
  }
  .adlp-header__logo {
    width: calc(237 / 750 * 100vw);
  }
  .adlp-header__btn {
    width: calc(390 / 750 * 100vw);
  }
  .adlp-header__link {
    padding: calc(12 / 750 * 100vw) 0 calc(14 / 750 * 100vw) calc(33 / 750 * 100vw);
    border-radius: calc(4 / 750 * 100vw);
  }
  .adlp-header__link::before {
    right: calc(10 / 750 * 100vw);
    width: calc(24 / 750 * 100vw);
    height: calc(4 / 750 * 100vw);
  }
  .adlp-header__link span {
    font-size: calc(26 / 750 * 100vw);
  }
}
.adlp-floating {
  visibility: hidden;
  opacity: 0;
  transition: 0.3s;
  background: #fff;
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: min(calc(1920 / 1080 * 100vw), 1920px);
  padding: min(calc(10 / 1080 * 100vw), 10px) 0;
  z-index: 90;
}
.adlp-floating.--show {
  visibility: visible;
  opacity: 1;
}
@media screen and (max-width: 767px) {
  .adlp-floating {
    width: 100%;
    padding: calc(10 / 750 * 100vw) 0;
  }
}
.adlp-floating__inner {
  margin: auto;
  width: min(calc(1080 / 1080 * 100vw), 1080px);
  padding: min(calc(16 / 1080 * 100vw), 16px) 0;
  position: relative;
}
@media screen and (max-width: 767px) {
  .adlp-floating__inner {
    width: 90%;
    padding: calc(20 / 750 * 100vw);
  }
}
.adlp-floating__close {
  width: min(calc(50 / 1080 * 100vw), 50px);
  height: min(calc(50 / 1080 * 100vw), 50px);
  border-radius: 50%;
  background-image: url("data:image/svg+xml,%3Csvg width='211' height='211' viewBox='0 0 211 211' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M188.696 0L105.13 83.575L21.574 0L0 21.583L83.556 105.139L0 188.695L21.574 210.278L105.13 126.713L188.696 210.278L210.269 188.705L126.704 105.139L210.269 21.583L188.696 0Z' fill='%234B4B4B'/%3E%3C/svg%3E%0A");
  background-size: min(calc(20 / 1080 * 100vw), 20px) min(calc(20 / 1080 * 100vw), 20px);
  background-repeat: no-repeat;
  background-position: center;
  border: min(calc(2 / 1080 * 100vw), 2px) solid #4B4B4B;
  transition: 0.15s all;
  position: absolute;
  top: 0;
  right: 0;
  cursor: pointer;
  z-index: 10;
}
@media screen and (min-width: 768px) {
  .adlp-floating__close:hover {
    background-image: url("data:image/svg+xml,%3Csvg width='211' height='211' viewBox='0 0 211 211' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M188.696 0L105.13 83.575L21.574 0L0 21.583L83.556 105.139L0 188.695L21.574 210.278L105.13 126.713L188.696 210.278L210.269 188.705L126.704 105.139L210.269 21.583L188.696 0Z' fill='%23fff'/%3E%3C/svg%3E%0A");
    background-color: #E75B18;
    border-color: transparent;
  }
}
@media screen and (max-width: 767px) {
  .adlp-floating__close {
    width: calc(50 / 750 * 100vw);
    height: calc(50 / 750 * 100vw);
    background-size: calc(20 / 750 * 100vw) calc(20 / 750 * 100vw);
    border-width: calc(2 / 750 * 100vw);
  }
  .adlp-floating__close:active {
    background-image: url("data:image/svg+xml,%3Csvg width='211' height='211' viewBox='0 0 211 211' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M188.696 0L105.13 83.575L21.574 0L0 21.583L83.556 105.139L0 188.695L21.574 210.278L105.13 126.713L188.696 210.278L210.269 188.705L126.704 105.139L210.269 21.583L188.696 0Z' fill='%23fff'/%3E%3C/svg%3E%0A");
    background-color: #E75B18;
    border-color: transparent;
  }
}
.adlp-floating__text {
  text-align: center;
  font-size: min(calc(20 / 1080 * 100vw), 20px);
  margin: 0 auto min(calc(15 / 1080 * 100vw), 15px);
}
@media screen and (max-width: 767px) {
  .adlp-floating__text {
    font-size: calc(26 / 750 * 100vw);
    margin: 0 auto calc(15 / 750 * 100vw);
  }
}

.adlp-main {
  padding-top: min(calc(72 / 1080 * 100vw), 72px);
}
@media screen and (max-width: 767px) {
  .adlp-main {
    padding-top: calc(100 / 750 * 100vw);
  }
}

.adlp-btn {
  border-radius: 200px;
  height: min(calc(80 / 1080 * 100vw), 80px);
  width: min(calc(420 / 1080 * 100vw), 420px);
  transition: all 0.3s;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
.adlp-btn__wrapper {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: min(calc(30 / 1080 * 100vw), 30px);
}
@media screen and (max-width: 767px) {
  .adlp-btn__wrapper {
    flex-direction: column;
    align-items: center;
    gap: calc(30 / 750 * 100vw);
  }
}
.adlp-btn__text {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .adlp-btn {
    height: calc(98 / 750 * 100vw);
    width: calc(630 / 750 * 100vw);
  }
}
.adlp-btn p {
  text-align: center;
  z-index: 1;
  line-height: 120%;
}
.adlp-btn p span {
  line-height: 120%;
}
.adlp-btn p span.text01 {
  font-size: min(calc(24 / 1080 * 100vw), 24px);
}
@media screen and (max-width: 767px) {
  .adlp-btn p span.text01 {
    font-size: calc(20 / 750 * 100vw);
  }
}
.adlp-btn p span.text02 {
  font-size: min(calc(20 / 1080 * 100vw), 20px);
}
@media screen and (max-width: 767px) {
  .adlp-btn p span.text02 {
    font-size: calc(28 / 750 * 100vw);
  }
}
.adlp-btn.--free {
  padding-left: min(calc(9 / 1080 * 100vw), 9px);
}
.adlp-btn.--free::before {
  content: "無料";
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  background: #fff;
  color: #1883EC;
  font-size: min(calc(18 / 1080 * 100vw), 18px);
  font-weight: 700;
  width: min(calc(70 / 1080 * 100vw), 70px);
  height: min(calc(70 / 1080 * 100vw), 70px);
  top: min(calc(5 / 1080 * 100vw), 5px);
  left: min(calc(5 / 1080 * 100vw), 5px);
}
@media screen and (max-width: 767px) {
  .adlp-btn.--free::before {
    width: calc(82 / 750 * 100vw);
    height: calc(82 / 750 * 100vw);
    font-size: calc(28 / 750 * 100vw);
    top: calc(8 / 750 * 100vw);
    left: calc(8 / 750 * 100vw);
  }
}
.adlp-btn.--btn01 {
  background: #1883EC;
  color: #fff;
}
.adlp-btn.--btn01::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  transition: all 0.3s;
  background-image: url("data:image/svg+xml,%3Csvg width='13' height='18' viewBox='0 0 13 18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11.5 12.5L6.5 16.5L1.5 12.5' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M6.5 9.5L6.5 1.5' stroke='white' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E%0A");
  background-size: 100% 100%;
  width: min(calc(13 / 1080 * 100vw), 13px);
  height: min(calc(18 / 1080 * 100vw), 18px);
  right: min(calc(33 / 1080 * 100vw), 33px);
}
@media screen and (max-width: 767px) {
  .adlp-btn.--btn01::after {
    width: calc(13 / 750 * 100vw);
    height: calc(18 / 750 * 100vw);
    right: calc(33 / 750 * 100vw);
  }
}
@media screen and (min-width: 768px) {
  .adlp-btn.--btn01:hover {
    background: #5AB0FF;
  }
}
@media screen and (max-width: 767px) {
  .adlp-btn.--btn01:active {
    background: #5AB0FF;
  }
}
.adlp-btn.--btn02-a {
  background: #fff;
  border: min(calc(4 / 1080 * 100vw), 4px) solid #f69809;
  color: #f69809;
}
@media screen and (max-width: 767px) {
  .adlp-btn.--btn02-a {
    border-width: calc(4 / 750 * 100vw);
  }
}
.adlp-btn.--btn02-a::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  transition: all 0.3s;
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='18' viewBox='0 0 10 18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L9 9L1 17' stroke='%23F79809' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A");
  background-size: 100% 100%;
  width: min(calc(13 / 1080 * 100vw), 13px);
  height: min(calc(18 / 1080 * 100vw), 18px);
  right: min(calc(33 / 1080 * 100vw), 33px);
}
@media screen and (max-width: 767px) {
  .adlp-btn.--btn02-a::after {
    width: calc(13 / 750 * 100vw);
    height: calc(18 / 750 * 100vw);
    right: calc(33 / 750 * 100vw);
  }
}
@media screen and (min-width: 768px) {
  .adlp-btn.--btn02-a:hover {
    background: #f69809;
    color: #fff;
  }
  .adlp-btn.--btn02-a:hover::after {
    background-image: url("data:image/svg+xml,%3Csvg width='10' height='18' viewBox='0 0 10 18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L9 9L1 17' stroke='%23FFF' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A");
  }
}
@media screen and (max-width: 767px) {
  .adlp-btn.--btn02-a:active {
    background: #f69809;
    color: #fff;
  }
  .adlp-btn.--btn02-a:active::after {
    background-image: url("data:image/svg+xml,%3Csvg width='10' height='18' viewBox='0 0 10 18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L9 9L1 17' stroke='%23FFF' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A");
  }
}
.adlp-btn.--btn02-b {
  color: #fff;
  overflow: hidden;
  border: 1px solid transparent;
}
.adlp-btn.--btn02-b::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: linear-gradient(90deg, #FF98AC 0%, #FF6683 100%);
  opacity: 1;
  transition: all 0.3s;
}
.adlp-btn.--btn02-b::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  transition: all 0.3s;
  background-image: url("data:image/svg+xml,%3Csvg width='8' height='16' viewBox='0 0 8 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 16L-6.99382e-07 0L8 7.99999L0 16Z' fill='white'/%3E%3C/svg%3E%0A");
  background-size: 100% 100%;
  width: min(calc(8 / 1080 * 100vw), 8px);
  height: min(calc(16 / 1080 * 100vw), 16px);
  right: min(calc(33 / 1080 * 100vw), 33px);
}
@media screen and (max-width: 767px) {
  .adlp-btn.--btn02-b::after {
    width: calc(8 / 750 * 100vw);
    height: calc(16 / 750 * 100vw);
    right: calc(33 / 750 * 100vw);
  }
}
@media screen and (min-width: 768px) {
  .adlp-btn.--btn02-b:hover {
    color: #ff6683;
    border-color: #ff6683;
    background-color: #fff;
  }
  .adlp-btn.--btn02-b:hover::before {
    opacity: 0;
  }
  .adlp-btn.--btn02-b:hover::after {
    background-image: url("data:image/svg+xml,%3Csvg width='8' height='16' viewBox='0 0 8 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 16L-6.99382e-07 0L8 7.99999L0 16Z' fill='%23FF6683'/%3E%3C/svg%3E%0A");
  }
}
@media screen and (max-width: 767px) {
  .adlp-btn.--btn02-b:active {
    color: #ff6683;
    border-color: #ff6683;
    background-color: #fff;
  }
  .adlp-btn.--btn02-b:active::before {
    opacity: 0;
  }
  .adlp-btn.--btn02-b:active::after {
    background-image: url("data:image/svg+xml,%3Csvg width='8' height='16' viewBox='0 0 8 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 16L-6.99382e-07 0L8 7.99999L0 16Z' fill='%23FF6683'/%3E%3C/svg%3E%0A");
  }
}
.adlp-btn.--btn03 {
  color: #C80012;
  background: #fff;
  box-shadow: min(calc(4 / 1080 * 100vw), 4px) min(calc(6 / 1080 * 100vw), 6px) 0 0 rgba(0, 0, 0, 0.3);
}
@media screen and (max-width: 767px) {
  .adlp-btn.--btn03 {
    box-shadow: calc(4 / 750 * 100vw) calc(6 / 750 * 100vw) 0 0 rgba(0, 0, 0, 0.3);
  }
}
.adlp-btn.--btn03::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  transition: all 0.3s;
  background-image: url("data:image/svg+xml,%3Csvg width='9' height='15' viewBox='0 0 9 15' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 1.07324e-07L9 7.50412L1.78873e-07 15L2.47836 7.44633L0 1.07324e-07Z' fill='%23C80012'/%3E%3C/svg%3E%0A");
  background-size: 100% 100%;
  width: min(calc(8 / 1080 * 100vw), 8px);
  height: min(calc(16 / 1080 * 100vw), 16px);
  right: min(calc(33 / 1080 * 100vw), 33px);
}
@media screen and (max-width: 767px) {
  .adlp-btn.--btn03::after {
    width: calc(8 / 750 * 100vw);
    height: calc(16 / 750 * 100vw);
    right: calc(33 / 750 * 100vw);
  }
}
@media screen and (min-width: 768px) {
  .adlp-btn.--btn03:hover {
    transform: translateY(min(calc(4 / 1080 * 100vw), 4px));
    box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.3);
  }
}
@media screen and (min-width: 768px) and (max-width: 767px) {
  .adlp-btn.--btn03:hover {
    transform: translateY(calc(4 / 750 * 100vw));
  }
}
@media screen and (max-width: 767px) {
  .adlp-btn.--btn03:active {
    transform: translateY(min(calc(4 / 1080 * 100vw), 4px));
    box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.3);
  }
}
@media screen and (max-width: 767px) and (max-width: 767px) {
  .adlp-btn.--btn03:active {
    transform: translateY(calc(4 / 750 * 100vw));
  }
}
.adlp-btn.--btn04 {
  color: #fff;
  background: #FFA800;
  box-shadow: 0 min(calc(14 / 1080 * 100vw), 14px) min(calc(24 / 1080 * 100vw), 24px) 0 rgba(0, 0, 0, 0.4);
}
@media screen and (max-width: 767px) {
  .adlp-btn.--btn04 {
    box-shadow: 0 calc(14 / 750 * 100vw) calc(24 / 750 * 100vw) 0 rgba(0, 0, 0, 0.4);
  }
}
.adlp-btn.--btn04::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  transition: all 0.3s;
  background-image: url("data:image/svg+xml,%3Csvg width='9' height='15' viewBox='0 0 9 15' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.16602L7 7.16602L1 13.166' stroke='white' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E%0A");
  background-size: 100% 100%;
  width: min(calc(8 / 1080 * 100vw), 8px);
  height: min(calc(16 / 1080 * 100vw), 16px);
  right: min(calc(33 / 1080 * 100vw), 33px);
}
@media screen and (max-width: 767px) {
  .adlp-btn.--btn04::after {
    width: calc(8 / 750 * 100vw);
    height: calc(16 / 750 * 100vw);
    right: calc(33 / 750 * 100vw);
  }
}
@media screen and (min-width: 768px) {
  .adlp-btn.--btn04:hover {
    background: #F48400;
  }
  .adlp-btn.--btn04:hover::after {
    transform: translate(min(calc(10 / 1080 * 100vw), 10px), -50%);
  }
}
@media screen and (max-width: 767px) {
  .adlp-btn.--btn04:active {
    background: #F48400;
  }
  .adlp-btn.--btn04:active::after {
    transform: translate(min(calc(10 / 1080 * 100vw), 10px), -50%);
  }
}

.adlp-modal {
  visibility: hidden;
  opacity: 0;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  z-index: 100;
  transition: 0.3s;
}
.adlp-modal.--open {
  visibility: visible;
  opacity: 1;
}
.adlp-modal__base {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.8);
}
.adlp-modal__content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  width: min(calc(1000 / 1080 * 100vw), 1000px);
  min-height: min(calc(200 / 1080 * 100vw), 200px);
  max-height: 90vh;
  background: #fff;
  padding: min(calc(30 / 1080 * 100vw), 30px);
  overflow-y: scroll;
  overscroll-behavior-y: contain;
}
@media screen and (max-width: 767px) {
  .adlp-modal__content {
    width: calc(630 / 750 * 100vw);
    padding: calc(50 / 750 * 100vw) calc(30 / 750 * 100vw);
  }
}
.adlp-modal__content__close {
  width: min(calc(27 / 1080 * 100vw), 27px);
  height: min(calc(27 / 1080 * 100vw), 27px);
  position: absolute;
  top: min(calc(30 / 1080 * 100vw), 30px);
  right: min(calc(30 / 1080 * 100vw), 30px);
  cursor: pointer;
  z-index: 10;
}
@media screen and (max-width: 767px) {
  .adlp-modal__content__close {
    width: calc(38 / 750 * 100vw);
    height: calc(38 / 750 * 100vw);
    top: calc(30 / 750 * 100vw);
    right: calc(30 / 750 * 100vw);
  }
}
.adlp-modal__content__close svg {
  width: 100%;
  height: 100%;
}
.adlp-modal__content__title {
  text-align: center;
  font-size: min(calc(26 / 1080 * 100vw), 26px);
}
@media screen and (max-width: 767px) {
  .adlp-modal__content__title {
    font-size: calc(40 / 750 * 100vw);
  }
}
.adlp-modal__content__body {
  margin: min(calc(30 / 1080 * 100vw), 30px) auto 0;
  font-size: min(calc(18 / 1080 * 100vw), 18px);
}
@media screen and (max-width: 767px) {
  .adlp-modal__content__body {
    margin: calc(30 / 750 * 100vw) auto 0;
    font-size: calc(20 / 750 * 100vw);
  }
}
.adlp-modal__content__img {
  margin: min(calc(30 / 1080 * 100vw), 30px) auto 0;
  width: 80%;
}
@media screen and (max-width: 767px) {
  .adlp-modal__content__img {
    margin: calc(30 / 750 * 100vw) auto 0;
  }
}

.adlp-section {
  margin: 0 auto;
  position: relative;
}
@media screen and (max-width: 767px) {
  .adlp-section {
    width: 100%;
    padding: 0 calc(30 / 750 * 100vw);
  }
}
@media screen and (max-width: 767px) {
  .adlp-section.--pd0 {
    padding: 0;
  }
}
@media screen and (max-width: 767px) {
  .adlp-section.--pd30 {
    padding: 0 calc(30 / 750 * 100vw);
  }
}
@media screen and (max-width: 767px) {
  .adlp-section.--pd60 {
    padding: 0 calc(60 / 750 * 100vw);
  }
}

.cv02 {
  background-color: #eaeef2;
  padding: min(calc(40 / 1080 * 100vw), 40px) 0;
}
.cv02__frame {
  width: fit-content;
  margin: 0 auto min(calc(12 / 1080 * 100vw), 12px);
  padding: min(calc(3 / 1080 * 100vw), 3px) min(calc(23 / 1080 * 100vw), 23px) min(calc(4 / 1080 * 100vw), 4px);
  border: min(calc(0.72 / 1080 * 100vw), 0.72px) solid #333333;
}
.cv02__title {
  color: #333333;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: min(calc(22 / 1080 * 100vw), 22px);
  line-height: 1.6;
  letter-spacing: 0.08em;
  text-align: center;
}
.cv02__heading {
  color: #333333;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-size: min(calc(32 / 1080 * 100vw), 32px);
  line-height: 1.6;
  letter-spacing: 0.08em;
  text-align: center;
  margin-bottom: min(calc(20 / 1080 * 100vw), 20px);
}
@media screen and (max-width: 767px) {
  .cv02 {
    padding: calc(60 / 750 * 100vw) 0;
  }
  .cv02__frame {
    margin: 0 auto calc(20 / 750 * 100vw);
    padding: calc(4 / 750 * 100vw) calc(30 / 750 * 100vw) calc(6 / 750 * 100vw);
    border: calc(1 / 750 * 100vw) solid #333333;
  }
  .cv02__title {
    font-size: calc(32 / 750 * 100vw);
  }
  .cv02__heading {
    font-size: calc(40 / 750 * 100vw);
    margin-bottom: calc(40 / 750 * 100vw);
  }
}

.cv {
  background-color: #eaeef2;
  padding: min(calc(40 / 1080 * 100vw), 40px) 0;
}
.cv__btn-container {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}
.cv__btn {
  position: relative;
  display: flex;
  width: min(calc(454 / 1080 * 100vw), 454px);
  height: min(calc(86 / 1080 * 100vw), 86px);
  margin: 0 auto;
  border-radius: min(calc(3 / 1080 * 100vw), 3px);
  padding: min(calc(4 / 1080 * 100vw), 4px) min(calc(5 / 1080 * 100vw), 5px);
  background: var(--accent02, linear-gradient(180deg, #a3095c 0%, #d52665 100%));
  overflow: hidden;
  box-shadow: 0px 0px min(calc(11.52 / 1080 * 100vw), 11.52px) rgba(21, 21, 21, 0.15);
  transition: opacity 0.3s;
  gap: min(calc(38 / 1080 * 100vw), 38px);
}
.cv__btn-outer {
  position: relative;
  width: fit-content;
}
.cv__btn-outer::before {
  display: block;
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  height: min(calc(32 / 1080 * 100vw), 32px);
  background-color: #fff;
  border-radius: 100%;
  background: rgba(0, 0, 0, 0.4);
  filter: blur(18px);
}
.cv__btn:hover {
  opacity: 0.8;
}
.cv__btn::before {
  position: absolute;
  right: min(calc(17 / 1080 * 100vw), 17px);
  top: 50%;
  transform: translateY(-50%);
  content: "";
  display: block;
  width: min(calc(37 / 1080 * 100vw), 37px);
  height: min(calc(8 / 1080 * 100vw), 8px);
  background: url("../img/common/btn_arrow.svg") no-repeat center center/contain;
}
.cv__btn-left {
  display: flex;
  justify-content: center;
  align-items: center;
  width: min(calc(90 / 1080 * 100vw), 90px);
  height: 100%;
  background: linear-gradient(180deg, #ffffff 61.68%, #e6e6e6 100%);
  box-shadow: 0px 0px min(calc(4.32 / 1080 * 100vw), 4.32px) rgba(0, 0, 0, 0.2);
  border-radius: min(calc(3 / 1080 * 100vw), 3px);
}
.cv__btn-text {
  color: #a3095c;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: min(calc(20 / 1080 * 100vw), 20px);
  line-height: 1.3;
  letter-spacing: 0.08em;
  text-align: center;
}
.cv__btn-right {
  position: relative;
  display: flex;
  align-items: center;
  width: calc(100% - min(calc(90 / 1080 * 100vw), 90px));
  height: 100%;
  padding-right: min(calc(40 / 1080 * 100vw), 40px);
}
.cv__btn-text-main {
  color: #ffffff;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: min(calc(22 / 1080 * 100vw), 22px);
  line-height: 1.3;
  letter-spacing: 0.08em;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .cv {
    padding: calc(56 / 750 * 100vw) 0;
  }
  .cv__btn-container {
    width: 100%;
  }
  .cv__btn {
    width: calc(630 / 750 * 100vw);
    height: calc(120 / 750 * 100vw);
    border-radius: calc(4 / 750 * 100vw);
    padding: calc(6 / 750 * 100vw);
    gap: calc(46 / 750 * 100vw);
  }
  .cv__btn-outer {
    width: 100%;
  }
  .cv__btn-outer::before {
    height: calc(100 / 750 * 100vw);
    filter: blur(calc(25 / 750 * 100vw));
    width: 90%;
  }
  .cv__btn::before {
    right: calc(24 / 750 * 100vw);
    width: calc(50 / 750 * 100vw);
    height: calc(10 / 750 * 100vw);
  }
  .cv__btn-left {
    width: calc(126 / 750 * 100vw);
    border-radius: calc(3 / 750 * 100vw);
    box-shadow: 0px 0px calc(6 / 750 * 100vw) rgba(0, 0, 0, 0.2);
  }
  .cv__btn-text {
    font-size: calc(30 / 750 * 100vw);
  }
  .cv__btn-right {
    width: calc(100% - calc(120 / 750 * 100vw));
    padding-right: calc(50 / 750 * 100vw);
  }
  .cv__btn-text-main {
    font-size: calc(32 / 750 * 100vw);
  }
}

.fv {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.fv__main {
  position: relative;
}
.fv__main__inner {
  position: absolute;
  inset: 0;
  width: min(calc(1080 / 1080 * 100vw), 1080px);
  margin: 0 auto;
  padding: 0 min(calc(80 / 1080 * 100vw), 80px);
}
.fv__title {
  position: relative;
  width: fit-content;
  color: #1b3b82;
  font-weight: 500;
  font-family: "Noto Serif JP", serif;
  line-height: 1.7;
  z-index: 2;
  margin-top: min(calc(40 / 1080 * 100vw), 40px);
  text-align: center;
}
.fv__title__line1, .fv__title__line2 {
  display: block;
  font-size: min(calc(50 / 1080 * 100vw), 50px);
  letter-spacing: 0.18em;
}
.fv__title__line1 small, .fv__title__line2 small {
  font-size: min(calc(36 / 1080 * 100vw), 36px);
}
.fv__title__dots {
  position: absolute;
  top: 0;
  left: min(calc(47 / 1080 * 100vw), 47px);
  width: 100%;
  display: flex;
  gap: min(calc(54 / 1080 * 100vw), 54px);
  z-index: 2;
}
.fv__title__dot {
  width: min(calc(7 / 1080 * 100vw), 7px);
  height: min(calc(7 / 1080 * 100vw), 7px);
  background-color: #1b3b82;
  border-radius: 50%;
}
.fv__bottom {
  color: #fff;
  padding: min(calc(140 / 1080 * 100vw), 140px) 0 0;
}
.fv__bottom__inner {
  margin: 0 auto;
}
.fv__text {
  text-align: center;
  margin-bottom: min(calc(20 / 1080 * 100vw), 20px);
  font-family: "Noto Serif JP", serif;
}
.fv__text span {
  position: relative;
  line-height: 1.6;
}
.fv__text__line1 {
  font-size: min(calc(21.6 / 1080 * 100vw), 21.6px);
  line-height: 1;
  margin-bottom: min(calc(5 / 1080 * 100vw), 5px);
  letter-spacing: 0.08em;
  font-weight: 400;
}
.fv__text__line2 {
  font-size: min(calc(20 / 1080 * 100vw), 20px);
  line-height: 1.2;
  letter-spacing: 0.08em;
  font-weight: 400;
}
.fv__text__line3 {
  font-size: min(calc(38 / 1080 * 100vw), 38px);
  line-height: 1.2;
  margin-bottom: min(calc(5 / 1080 * 100vw), 5px);
  letter-spacing: 0.12em;
  font-weight: 400;
}
.fv__text__line3 small {
  font-size: min(calc(23 / 1080 * 100vw), 23px);
}
.fv__text__emphasis {
  font-size: min(calc(32 / 1080 * 100vw), 32px);
  font-weight: 500;
  line-height: 1;
}
.fv__text sup {
  position: absolute;
  top: 0;
  right: 0;
  font-size: min(calc(12 / 1080 * 100vw), 12px);
  transform: translateY(-70%);
}
.fv__text sup.note1 {
  right: 2em;
}
.fv__text sup.note2 {
  right: 4.5em;
}
.fv__text__quote {
  color: #f2d06b;
  font-weight: 400;
  font-size: min(calc(38 / 1080 * 100vw), 38px);
  background: var(--Linear, linear-gradient(284deg, #e9ca50 0%, #f3ecbf 49.15%, #e9ca50 103.63%));
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-family: "Noto Serif JP";
}
.fv__text__quote span {
  color: #f2d06b;
  font-weight: 400;
  font-size: min(calc(38 / 1080 * 100vw), 38px);
  background: var(--Linear, linear-gradient(284deg, #e9ca50 0%, #f3ecbf 49.15%, #e9ca50 103.63%));
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-family: "Noto Serif JP";
}
.fv__text__quote span:first-child {
  scale: -1 1;
  display: inline-block;
}
.fv__shop {
  background: #fff url("../img/pc/shop_bg.webp") center min(calc(86 / 1080 * 100vw), 86px)/95% no-repeat;
  padding: min(calc(23 / 1080 * 100vw), 23px) min(calc(40 / 1080 * 100vw), 40px);
  max-width: min(calc(748 / 1080 * 100vw), 748px);
  margin: 0 auto min(calc(20 / 1080 * 100vw), 20px);
  text-align: center;
  box-shadow: 0px 0px min(calc(11.52 / 1080 * 100vw), 11.52px) rgba(21, 21, 21, 0.15);
}
.fv__shop__title {
  color: #1b3b82;
  font-size: min(calc(28.8 / 1080 * 100vw), 28.8px);
  font-weight: 600;
  margin-bottom: min(calc(30 / 1080 * 100vw), 30px);
  font-family: "Noto Sans JP", sans-serif;
  letter-spacing: 0.08em;
  line-height: 1.8;
}
.fv__shop__logo {
  width: min(calc(370 / 1080 * 100vw), 370px);
  margin: 0 auto;
}
.fv__notes {
  text-align: center;
  font-size: min(calc(12 / 1080 * 100vw), 12px);
  color: #666666;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 300;
  letter-spacing: 0.06em;
  line-height: 1.5;
}
.fv__notes__text {
  line-height: 1.5;
}
.fv__notes__mark {
  margin-right: min(calc(5 / 1080 * 100vw), 5px);
}
.fv__notes__mark:not(:first-child) {
  margin-left: min(calc(15 / 1080 * 100vw), 15px);
}

@media screen and (max-width: 767px) {
  .fv__main {
    position: relative;
  }
  .fv__main picture {
    display: block;
    width: 100%;
    height: auto;
  }
  .fv__main__inner {
    width: 100%;
    padding: 0 calc(20 / 750 * 100vw);
  }
  .fv__title {
    margin-top: calc(64 / 750 * 100vw);
    width: 100%;
    text-align: center;
  }
  .fv__title-inner {
    position: relative;
    display: inline-block;
  }
  .fv__title__line1, .fv__title__line2 {
    font-size: calc(76 / 750 * 100vw);
    letter-spacing: 0.18em;
    line-height: 1.7;
  }
  .fv__title__line1 small, .fv__title__line2 small {
    font-size: calc(50 / 750 * 100vw);
  }
  .fv__title__dots {
    position: absolute;
    top: calc(-20 / 750 * 100vw);
    left: 50%;
    transform: translateX(-60%);
    width: auto;
    display: flex;
    gap: calc(78 / 750 * 100vw);
  }
  .fv__title__dot {
    width: calc(10 / 750 * 100vw);
    height: calc(10 / 750 * 100vw);
  }
  .fv__bottom {
    padding: calc(426 / 750 * 100vw) 0 0;
  }
  .fv__bottom__inner {
    padding: 0;
  }
  .fv__text {
    margin-bottom: calc(30 / 750 * 100vw);
  }
  .fv__text span {
    position: relative;
    line-height: 1.6;
  }
  .fv__text__line1 {
    font-size: calc(30 / 750 * 100vw);
    line-height: 1.4;
    margin-bottom: calc(10 / 750 * 100vw);
    letter-spacing: 0.08em;
  }
  .fv__text__line2 {
    font-size: calc(30 / 750 * 100vw);
    line-height: 1.4;
    margin-bottom: calc(10 / 750 * 100vw);
  }
  .fv__text__line3 {
    font-size: calc(48 / 750 * 100vw);
    line-height: 1.4;
    margin-bottom: calc(10 / 750 * 100vw);
  }
  .fv__text__line3 small {
    font-size: calc(30 / 750 * 100vw);
  }
  .fv__text__emphasis {
    font-size: calc(40 / 750 * 100vw);
  }
  .fv__text sup {
    font-size: calc(20 / 750 * 100vw);
    transform: translateY(-70%);
  }
  .fv__text sup.note1 {
    right: 1.5em;
  }
  .fv__text sup.note2 {
    right: 3.5em;
  }
  .fv__text__quote {
    font-size: calc(48 / 750 * 100vw);
  }
  .fv__text__quote span {
    font-size: calc(48 / 750 * 100vw);
  }
  .fv__text__quote span:first-child {
    scale: -1 1;
    display: inline-block;
  }
  .fv__shop {
    padding: calc(32 / 750 * 100vw) calc(20 / 750 * 100vw);
    border-radius: 0;
    margin: 0 auto calc(20 / 750 * 100vw);
    max-width: calc(100% - calc(60 / 750 * 100vw));
    box-shadow: 0px 0px 16px 0px rgba(21, 21, 21, 0.15);
    background: #fff url("../img/sp/shop_bg.webp") center calc(120 / 750 * 100vw)/95% no-repeat;
  }
  .fv__shop__title {
    font-size: calc(40 / 750 * 100vw);
    margin-bottom: calc(50 / 750 * 100vw);
  }
  .fv__shop__logo {
    width: calc(518 / 750 * 100vw);
  }
  .fv__notes {
    font-size: calc(20 / 750 * 100vw);
    padding: 0 calc(35 / 750 * 100vw);
  }
  .fv__notes__text {
    text-align: left;
  }
  .fv__notes__mark {
    margin-right: calc(3 / 750 * 100vw);
    display: inline-block;
  }
  .fv__notes__mark:not(:first-child) {
    margin-left: calc(10 / 750 * 100vw);
  }
}
.sec01 {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.sec01__main {
  position: relative;
}
.sec01__main__inner {
  position: absolute;
  inset: 0;
  width: min(calc(1080 / 1080 * 100vw), 1080px);
  margin: 0 auto;
  padding: 0 min(calc(80 / 1080 * 100vw), 80px);
}
.sec01__content {
  position: relative;
  margin-top: min(calc(140 / 1080 * 100vw), 140px);
  color: #fff;
  z-index: 2;
}
.sec01__label {
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-size: min(calc(56 / 1080 * 100vw), 56px);
  line-height: 1.4;
  letter-spacing: 0.08em;
  margin-left: min(calc(63 / 1080 * 100vw), 63px);
  position: relative;
  display: flex;
  align-items: baseline;
  gap: min(calc(13 / 1080 * 100vw), 13px);
}
.sec01__label::after {
  content: "";
  display: block;
  height: min(calc(1 / 1080 * 100vw), 1px);
  width: min(calc(127 / 1080 * 100vw), 127px);
  background: #fff;
}
.sec01__title {
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-size: min(calc(32 / 1080 * 100vw), 32px);
  line-height: 1.6;
  letter-spacing: 0.08em;
  margin-bottom: min(calc(40 / 1080 * 100vw), 40px);
  margin-left: min(calc(63 / 1080 * 100vw), 63px);
}
.sec01__text p {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: min(calc(18 / 1080 * 100vw), 18px);
  line-height: 2.4;
  letter-spacing: 0.08em;
  margin-bottom: min(calc(40 / 1080 * 100vw), 40px);
  margin-left: min(calc(63 / 1080 * 100vw), 63px);
}
.sec01__message {
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-size: min(calc(25.92 / 1080 * 100vw), 25.92px);
  line-height: 1.3;
  letter-spacing: 0.08em;
  text-align: center;
  margin-bottom: min(calc(60 / 1080 * 100vw), 60px);
  margin-top: min(calc(220 / 1080 * 100vw), 220px);
}
.sec01__message span {
  background: var(--accent01, linear-gradient(270deg, #deba3a 0%, #f3ecbf 44.48%, #e5bf3e 93.78%));
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-size: min(calc(40 / 1080 * 100vw), 40px);
  line-height: 1.3;
}

@media screen and (max-width: 767px) {
  .sec01 {
    position: relative;
    z-index: 10;
  }
  .sec01__main__inner {
    width: 100%;
    padding: 0 calc(60 / 750 * 100vw);
  }
  .sec01__content {
    margin-top: calc(220 / 750 * 100vw);
    color: #fff;
  }
  .sec01__label {
    font-size: calc(64 / 750 * 100vw);
    display: flex;
    align-items: baseline;
    gap: calc(15 / 750 * 100vw);
    margin: 0;
  }
  .sec01__label::after {
    content: "";
    display: block;
    height: calc(1 / 750 * 100vw);
    width: calc(176 / 750 * 100vw);
    background: #fff;
  }
  .sec01__title {
    font-size: calc(40 / 750 * 100vw);
    margin-bottom: calc(50 / 750 * 100vw);
    margin-left: 0;
  }
  .sec01__text p {
    font-size: calc(26 / 750 * 100vw);
    margin-left: 0;
  }
  .sec01__message {
    font-size: calc(36 / 750 * 100vw);
    line-height: 1.3;
    margin-bottom: calc(80 / 750 * 100vw);
    margin-top: calc(370 / 750 * 100vw);
  }
  .sec01__message span {
    background: var(--accent01, linear-gradient(270deg, #deba3a 0%, #f3ecbf 44.48%, #e5bf3e 93.78%));
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    font-size: calc(50 / 750 * 100vw);
    line-height: 1.3;
  }
}
.sec02 {
  position: relative;
  background-color: #f1f1f1;
  overflow: hidden;
}
.sec02__inner {
  position: absolute;
  inset: 0;
  max-width: min(calc(1080 / 1080 * 100vw), 1080px);
  margin: 0 auto;
  padding: 0 min(calc(40 / 1080 * 100vw), 40px);
  display: flex;
  flex-direction: column;
  align-items: center;
}
.sec02__label {
  margin-top: min(calc(46 / 1080 * 100vw), 46px);
  padding: min(calc(2.88 / 1080 * 100vw), 2.88px) min(calc(17.28 / 1080 * 100vw), 17.28px);
  background-color: #333333;
  border: min(calc(0.72 / 1080 * 100vw), 0.72px) solid #f1f1f1;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: min(calc(20 / 1080 * 100vw), 20px);
  line-height: 1.6;
  letter-spacing: 0.08em;
  text-align: center;
  color: #ffffff;
  margin-bottom: min(calc(40 / 1080 * 100vw), 40px);
}
.sec02__title {
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-size: min(calc(34.56 / 1080 * 100vw), 34.56px);
  line-height: 1.6;
  letter-spacing: 0.08em;
  text-align: center;
  color: #333333;
  margin-bottom: min(calc(20 / 1080 * 100vw), 20px);
}
.sec02__title span {
  font-size: min(calc(48 / 1080 * 100vw), 48px);
}
.sec02__list {
  width: 100%;
  max-width: min(calc(454 / 1080 * 100vw), 454px);
  display: flex;
  flex-direction: column;
  gap: min(calc(17.28 / 1080 * 100vw), 17.28px);
}
.sec02__list-item {
  display: flex;
  align-items: center;
  gap: min(calc(17.28 / 1080 * 100vw), 17.28px);
  padding-bottom: min(calc(11.64 / 1080 * 100vw), 11.64px);
  border-bottom: min(calc(0.72 / 1080 * 100vw), 0.72px) solid #666666;
}
.sec02__check {
  flex-shrink: 0;
  width: min(calc(21 / 1080 * 100vw), 21px);
  height: min(calc(21 / 1080 * 100vw), 21px);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background: url(../img/common/rect_check.svg) no-repeat center center/contain;
}
.sec02__text {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: min(calc(16 / 1080 * 100vw), 16px);
  line-height: 1.8;
  letter-spacing: 0.04em;
  color: #333333;
}
.sec02__text span {
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .sec02__inner {
    padding: calc(60 / 750 * 100vw) calc(60 / 750 * 100vw) calc(80 / 750 * 100vw);
  }
  .sec02__label {
    margin-top: 0;
    padding: calc(4 / 750 * 100vw) calc(24 / 750 * 100vw);
    border: calc(1 / 750 * 100vw) solid #f1f1f1;
    font-size: calc(30 / 750 * 100vw);
    margin-bottom: calc(46 / 750 * 100vw);
  }
  .sec02__title {
    font-size: calc(40 / 750 * 100vw);
    margin-bottom: calc(20 / 750 * 100vw);
  }
  .sec02__title span {
    font-size: calc(56 / 750 * 100vw);
  }
  .sec02__list {
    max-width: 100%;
    gap: calc(24 / 750 * 100vw);
  }
  .sec02__list-item {
    gap: calc(24 / 750 * 100vw);
    padding-bottom: calc(12 / 750 * 100vw);
    border-bottom: calc(1 / 750 * 100vw) solid #666666;
  }
  .sec02__check {
    width: calc(28 / 750 * 100vw);
    height: calc(28 / 750 * 100vw);
  }
  .sec02__text {
    font-size: calc(26 / 750 * 100vw);
  }
}

.sec03 {
  position: relative;
  width: 100%;
  background: url("../img/pc/sec03_bg_top.webp") no-repeat center top/contain, url("../img/pc/sec03_bg_bottom.webp") no-repeat center bottom/contain;
}
.sec03__inner {
  width: min(calc(1080 / 1080 * 100vw), 1080px);
  margin: 0 auto;
  padding: min(calc(135 / 1080 * 100vw), 135px) min(calc(40 / 1080 * 100vw), 40px) min(calc(54 / 1080 * 100vw), 54px);
  display: flex;
  flex-direction: column;
  align-items: center;
}
.sec03__main-title {
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-size: min(calc(48 / 1080 * 100vw), 48px);
  line-height: 1.6;
  letter-spacing: 0.08em;
  text-align: center;
  color: #333333;
  margin-bottom: min(calc(40 / 1080 * 100vw), 40px);
}
.sec03__main-title span {
  font-size: min(calc(32 / 1080 * 100vw), 32px);
}
.sec03__company {
  width: 100%;
  max-width: min(calc(540 / 1080 * 100vw), 540px);
  background: var(--main02, linear-gradient(118deg, #132754 15.73%, #1463ac 100%));
  padding: min(calc(37 / 1080 * 100vw), 37px) 0;
}
.sec03__company-header {
  text-align: center;
}
.sec03__company-header-line {
  display: inline-flex;
  align-items: center;
}
.sec03__company-header-line::before, .sec03__company-header-line::after {
  content: "";
  height: min(calc(1 / 1080 * 100vw), 1px);
  width: min(calc(40 / 1080 * 100vw), 40px);
  background-color: #fff;
  display: block;
}
.sec03__company-header-text {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: min(calc(20 / 1080 * 100vw), 20px);
  line-height: 1.6;
  letter-spacing: 0.08em;
  color: #fff;
  padding: 0 min(calc(16 / 1080 * 100vw), 16px);
}
.sec03__company-text {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: min(calc(20 / 1080 * 100vw), 20px);
  line-height: 1.6;
  letter-spacing: 0.08em;
  color: #fff;
  margin-top: min(calc(10 / 1080 * 100vw), 10px);
}
.sec03__shop {
  padding: min(calc(20 / 1080 * 100vw), 20px) min(calc(40 / 1080 * 100vw), 40px) 0;
  text-align: center;
  background: url("../img/pc/sec03_company_line.svg") no-repeat center bottom min(calc(70 / 1080 * 100vw), 70px)/contain;
}
.sec03__shop-title {
  color: #1b3b82;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-size: min(calc(32 / 1080 * 100vw), 32px);
  line-height: 1.6;
  letter-spacing: 0.08em;
  margin-bottom: min(calc(20 / 1080 * 100vw), 20px);
  background: linear-gradient(284deg, #e9ca50 0%, #f3ecbf 49.15%, #e9ca50 103.63%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: min(calc(22 / 1080 * 100vw), 22px);
}
.sec03__shop-logo {
  width: min(calc(392 / 1080 * 100vw), 392px);
  margin: 0 auto;
}
.sec03__top {
  margin-top: min(calc(77 / 1080 * 100vw), 77px);
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  z-index: 2;
}
.sec03__circle {
  width: min(calc(115 / 1080 * 100vw), 115px);
  height: min(calc(115 / 1080 * 100vw), 115px);
  background: url(../img/common/sec03_bg_title.svg) no-repeat center/contain;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: min(calc(30 / 1080 * 100vw), 30px);
}
.sec03__circle-text {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: min(calc(20 / 1080 * 100vw), 20px);
  line-height: 1.6;
  letter-spacing: 0.08em;
  color: #333333;
}
.sec03__title {
  text-align: center;
  margin-bottom: min(calc(32 / 1080 * 100vw), 32px);
}
.sec03__title-line1, .sec03__title-line2 {
  display: block;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-size: min(calc(34 / 1080 * 100vw), 34px);
  line-height: 1.6;
  letter-spacing: 0.08em;
  color: #1b3b82;
}
.sec03__maker-logos {
  width: 100%;
  max-width: min(calc(964 / 1080 * 100vw), 964px);
  margin-bottom: min(calc(57 / 1080 * 100vw), 57px);
}
.sec03__maker-logos-row {
  display: flex;
  justify-content: center;
  gap: min(calc(16 / 1080 * 100vw), 16px);
  margin-bottom: min(calc(20 / 1080 * 100vw), 20px);
}
.sec03__maker-logos-row:last-child {
  margin-bottom: 0;
}
.sec03__line {
  position: relative;
}
.sec03__line-text {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: min(calc(22 / 1080 * 100vw), 22px);
  line-height: 1.6;
  letter-spacing: 0.08em;
  color: #333333;
  white-space: nowrap;
  padding: 0 min(calc(6 / 1080 * 100vw), 6px) min(calc(18 / 1080 * 100vw), 18px);
  background: url(../img/pc/sec03_title_line.svg) no-repeat center bottom/contain;
}
.sec03__content {
  text-align: center;
}
.sec03__content-title {
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  margin-bottom: min(calc(8 / 1080 * 100vw), 8px);
}
.sec03__content-title-line1, .sec03__content-title-line2 {
  display: block;
  font-size: min(calc(38 / 1080 * 100vw), 38px);
  line-height: 1.2;
  letter-spacing: 0.08em;
  color: #1b3b82;
}
.sec03__content-title-line1 span, .sec03__content-title-line2 span {
  line-height: 1.4;
}
.sec03__content-title-emphasis {
  font-size: min(calc(56 / 1080 * 100vw), 56px);
  font-weight: 700;
}
.sec03__content-title-note {
  font-size: min(calc(14 / 1080 * 100vw), 14px);
  vertical-align: middle;
}
.sec03__note {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 300;
  font-size: min(calc(12 / 1080 * 100vw), 12px);
  line-height: 1.5;
  letter-spacing: 0.06em;
  color: #666666;
}
@media screen and (max-width: 767px) {
  .sec03 {
    background: url("../img/sp/sec03_bg_top.webp") no-repeat center top/contain, url("../img/sp/sec03_bg_bottom.webp") no-repeat center bottom/contain;
  }
  .sec03__inner {
    width: 100%;
    padding: calc(160 / 750 * 100vw) 0 calc(64 / 750 * 100vw);
  }
  .sec03__main-title {
    font-size: calc(56 / 750 * 100vw);
    margin-bottom: calc(40 / 750 * 100vw);
  }
  .sec03__main-title span {
    font-size: calc(40 / 750 * 100vw);
  }
  .sec03__company {
    max-width: calc(630 / 750 * 100vw);
    padding: calc(30 / 750 * 100vw) 0 calc(52 / 750 * 100vw);
  }
  .sec03__company-header-line::before, .sec03__company-header-line::after {
    width: calc(40 / 750 * 100vw);
  }
  .sec03__company-header-text {
    font-size: calc(30 / 750 * 100vw);
    padding: 0 calc(16 / 750 * 100vw);
  }
  .sec03__company-text {
    font-size: calc(30 / 750 * 100vw);
    margin-top: calc(16 / 750 * 100vw);
  }
  .sec03__shop {
    padding: calc(30 / 750 * 100vw) calc(20 / 750 * 100vw) 0;
    background: url("../img/sp/sec03_company_line.svg") no-repeat center bottom calc(100 / 750 * 100vw)/contain;
  }
  .sec03__shop-title {
    font-size: calc(40 / 750 * 100vw);
    margin-bottom: calc(32 / 750 * 100vw);
  }
  .sec03__shop-logo {
    width: calc(554 / 750 * 100vw);
  }
  .sec03__top {
    margin-top: calc(80 / 750 * 100vw);
  }
  .sec03__circle {
    width: calc(160 / 750 * 100vw);
    height: calc(160 / 750 * 100vw);
    margin-bottom: calc(40 / 750 * 100vw);
  }
  .sec03__circle-text {
    font-size: calc(30 / 750 * 100vw);
  }
  .sec03__title {
    margin-bottom: calc(30 / 750 * 100vw);
  }
  .sec03__title-line1, .sec03__title-line2 {
    font-size: calc(48 / 750 * 100vw);
    letter-spacing: 0.01em;
  }
  .sec03 .sec03__maker-logos {
    margin-bottom: 0;
  }
  .sec03 .adlp-logo {
    width: calc(1343 / 750 * 100vw);
    animation-duration: 15s;
  }
  .sec03__line {
    margin: calc(80 / 750 * 100vw) 0 0;
  }
  .sec03__line-text {
    font-size: calc(32 / 750 * 100vw);
    padding: 0 calc(5 / 750 * 100vw) calc(24 / 750 * 100vw);
    background: url(../img/sp/sec03_title_line.svg) no-repeat center bottom/contain;
  }
  .sec03__content {
    margin-bottom: calc(0 / 750 * 100vw);
  }
  .sec03__content-title {
    margin-bottom: calc(8 / 750 * 100vw);
  }
  .sec03__content-title-line1, .sec03__content-title-line2 {
    font-size: calc(48 / 750 * 100vw);
    line-height: 1.4;
  }
  .sec03__content-title-emphasis {
    font-size: calc(64 / 750 * 100vw);
  }
  .sec03__content-title-note {
    font-size: calc(20 / 750 * 100vw);
  }
  .sec03__note {
    font-size: calc(20 / 750 * 100vw);
  }
}

.sec04 {
  position: relative;
  width: 100%;
  background-color: #071732;
  color: #fff;
  z-index: 10;
}
.sec04::before {
  content: "";
  display: block;
  height: min(calc(60 / 1080 * 100vw), 60px);
  width: min(calc(2 / 1080 * 100vw), 2px);
  background: #000;
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, -50%);
  z-index: 10;
}
.sec04::after {
  content: "";
  display: block;
  height: min(calc(30 / 1080 * 100vw), 30px);
  width: min(calc(2 / 1080 * 100vw), 2px);
  background: #fff;
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translate(-50%, 0);
  z-index: 10;
}
.sec04__content {
  position: absolute;
  inset: 0;
  width: min(calc(1080 / 1080 * 100vw), 1080px);
  margin: 0 auto;
  padding: 0 min(calc(40 / 1080 * 100vw), 40px);
  text-align: center;
  z-index: 2;
}
.sec04__title-box {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  background: rgba(7, 23, 50, 0.3);
  border: min(calc(1.44 / 1080 * 100vw), 1.44px) solid #dddddd;
  padding: min(calc(1.44 / 1080 * 100vw), 1.44px) min(calc(14.4 / 1080 * 100vw), 14.4px) min(calc(4.32 / 1080 * 100vw), 4.32px);
  margin-top: min(calc(320 / 1080 * 100vw), 320px);
  margin-bottom: min(calc(6 / 1080 * 100vw), 6px);
}
.sec04__title {
  color: #fff;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-size: min(calc(32 / 1080 * 100vw), 32px);
  line-height: 1.6;
  letter-spacing: 0.08em;
  text-align: center;
}
.sec04__title span {
  background: var(--accent01, linear-gradient(270deg, #deba3a 0%, #f3ecbf 44.48%, #e5bf3e 93.78%));
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.sec04__heading {
  color: #fff;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-size: min(calc(38 / 1080 * 100vw), 38px);
  line-height: 1.4;
  letter-spacing: 0.08em;
  text-align: center;
  margin: 0;
}

@media screen and (max-width: 767px) {
  .sec04::before {
    height: calc(80 / 750 * 100vw);
    width: calc(2 / 750 * 100vw);
  }
  .sec04::after {
    height: calc(40 / 750 * 100vw);
    width: calc(2 / 750 * 100vw);
  }
  .sec04__content {
    width: 100%;
    padding: 0 calc(20 / 750 * 100vw);
  }
  .sec04__title-box {
    border: calc(2 / 750 * 100vw) solid #dddddd;
    padding: calc(2 / 750 * 100vw) calc(20 / 750 * 100vw) calc(6 / 750 * 100vw);
    margin-top: calc(413 / 750 * 100vw);
    margin-bottom: calc(8 / 750 * 100vw);
  }
  .sec04__title {
    font-size: calc(40 / 750 * 100vw);
  }
  .sec04__heading {
    font-size: calc(48 / 750 * 100vw);
    line-height: 1.6;
    white-space: pre-line;
  }
}
.sec05 {
  position: relative;
  width: 100%;
  color: #fff;
}
.sec05::before {
  content: "";
  display: block;
  height: min(calc(30 / 1080 * 100vw), 30px);
  width: min(calc(2 / 1080 * 100vw), 2px);
  background: var(--text01, #333);
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, 0);
  z-index: 10;
}
.sec05__content {
  position: absolute;
  inset: 0;
  width: min(calc(1080 / 1080 * 100vw), 1080px);
  margin: 0 auto;
  text-align: center;
}
.sec05__title {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  font-size: min(calc(48 / 1080 * 100vw), 48px);
  line-height: 1.8;
  letter-spacing: 0.05em;
  margin-top: min(calc(30 / 1080 * 100vw), 30px);
  margin-bottom: min(calc(40 / 1080 * 100vw), 40px);
  color: var(--main01, #1b3b82);
  font-weight: 600;
}
.sec05__title-number {
  font-family: "Noto Serif JP";
  color: #ad8112;
  font-weight: 600;
  font-size: min(calc(56 / 1080 * 100vw), 56px);
}
.sec05__title-number span {
  font-size: min(calc(48 / 1080 * 100vw), 48px);
}
.sec05__title-text {
  color: var(--main01, #1b3b82);
  font-family: "Noto Serif JP";
  font-size: min(calc(48 / 1080 * 100vw), 48px);
}
.sec05__title-text2 {
  color: var(--main01, #1b3b82);
  font-family: "Noto Serif JP";
  font-size: min(calc(38 / 1080 * 100vw), 38px);
}
.sec05__title-mark {
  font-size: min(calc(12 / 1080 * 100vw), 12px);
  color: var(--base-666, #666);
  vertical-align: middle;
  margin-left: min(calc(2 / 1080 * 100vw), 2px);
  font-family: "Noto Serif JP";
}
.sec05__buttons {
  display: flex;
  justify-content: center;
  gap: min(calc(23 / 1080 * 100vw), 23px);
  margin-top: min(calc(417 / 1080 * 100vw), 417px);
  margin-bottom: min(calc(10 / 1080 * 100vw), 10px);
}
.sec05__button {
  position: relative;
  width: min(calc(80 / 1080 * 100vw), 80px);
  height: min(calc(42 / 1080 * 100vw), 42px);
  border: 1px solid #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: min(calc(3 / 1080 * 100vw), 3px);
}
.sec05__button::after {
  content: "";
  display: block;
  height: min(calc(14 / 1080 * 100vw), 14px);
  width: min(calc(2 / 1080 * 100vw), 2px);
  background: rgba(255, 255, 255, 0.7);
  border-right: 2px solid #133c72;
  border-left: 2px solid #133c72;
  position: absolute;
  overflow: hidden;
  left: 50%;
  bottom: 0;
  transform: translate(-50%, 70%);
  z-index: 1;
}
.sec05__button-text {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: min(calc(20 / 1080 * 100vw), 20px);
  letter-spacing: 0.08em;
  color: #fff;
}
.sec05__subtitle {
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-size: min(calc(32 / 1080 * 100vw), 32px);
  line-height: 1.6;
  letter-spacing: 0.08em;
  margin-bottom: min(calc(7 / 1080 * 100vw), 7px);
}
.sec05__message {
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-size: min(calc(48 / 1080 * 100vw), 48px);
  line-height: 1.6;
  letter-spacing: 0.08em;
}
.sec05__message span {
  display: inline-block;
  line-height: inherit;
}
.sec05__message small {
  font-size: min(calc(32 / 1080 * 100vw), 32px);
  line-height: inherit;
}
.sec05__message strong {
  background: var(--accent01, linear-gradient(270deg, #deba3a 0%, #f3ecbf 44.48%, #e5bf3e 93.78%));
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-feature-settings: "palt" on;
  line-height: inherit;
  font-weight: 600;
}
.sec05__note {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 300;
  font-size: min(calc(12 / 1080 * 100vw), 12px);
  line-height: 1.5;
  letter-spacing: 0.06em;
  color: #eee;
}

@media screen and (max-width: 767px) {
  .sec05 {
    position: relative;
  }
  .sec05::before {
    height: calc(40 / 750 * 100vw);
    width: calc(2 / 750 * 100vw);
  }
  .sec05__content {
    width: 100%;
  }
  .sec05__title {
    font-size: calc(40 / 750 * 100vw);
    margin-top: calc(50 / 750 * 100vw);
    margin-bottom: calc(30 / 750 * 100vw);
  }
  .sec05__title-number {
    font-size: calc(64 / 750 * 100vw);
  }
  .sec05__title-number span {
    font-size: calc(48 / 750 * 100vw);
  }
  .sec05__title-text {
    font-size: calc(48 / 750 * 100vw);
  }
  .sec05__title-text2 {
    font-size: calc(48 / 750 * 100vw);
  }
  .sec05__title-mark {
    font-size: calc(20 / 750 * 100vw);
  }
  .sec05__buttons {
    display: flex;
    justify-content: center;
    gap: calc(32 / 750 * 100vw);
    margin-top: calc(575 / 750 * 100vw);
    margin-bottom: calc(20 / 750 * 100vw);
  }
  .sec05__button {
    width: calc(110 / 750 * 100vw);
    height: calc(60 / 750 * 100vw);
    margin-bottom: calc(6 / 750 * 100vw);
    border: 1px solid #fff;
  }
  .sec05__button::after {
    height: calc(20 / 750 * 100vw);
    width: 2px;
    transform: translate(-50%, 80%);
  }
  .sec05__button-text {
    font-size: calc(30 / 750 * 100vw);
    font-weight: 500;
  }
  .sec05__subtitle {
    font-size: calc(40 / 750 * 100vw);
    margin-bottom: calc(10 / 750 * 100vw);
  }
  .sec05__message {
    font-size: calc(56 / 750 * 100vw);
    line-height: 1.5;
    margin-bottom: calc(30 / 750 * 100vw);
  }
  .sec05__message small {
    font-size: calc(40 / 750 * 100vw);
  }
  .sec05__note {
    font-size: calc(20 / 750 * 100vw);
    padding: 0 calc(20 / 750 * 100vw);
  }
}
.sec06 {
  position: relative;
  width: 100%;
  background: #eaeef2 url("../img/pc/sec06_bg.webp") center/contain no-repeat;
  padding: min(calc(144 / 1080 * 100vw), 144px) 0 min(calc(178 / 1080 * 100vw), 178px);
  overflow: hidden;
}
.sec06__inner {
  width: min(calc(1080 / 1080 * 100vw), 1080px);
  margin: 0 auto;
  padding: 0 min(calc(40 / 1080 * 100vw), 40px);
  position: relative;
}
.sec06__head {
  text-align: center;
  margin-bottom: min(calc(40 / 1080 * 100vw), 40px);
}
.sec06__head__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: min(calc(12 / 1080 * 100vw), 12px);
}
.sec06__head__title-small {
  font-family: "Noto Serif JP", serif;
  font-size: min(calc(24 / 1080 * 100vw), 24px);
  font-weight: 600;
  color: #333;
  letter-spacing: 0.08em;
  display: flex;
  align-items: center;
  gap: min(calc(18 / 1080 * 100vw), 18px);
  line-height: 1;
}
.sec06__head__title-small:before, .sec06__head__title-small::after {
  content: "";
  display: block;
  width: min(calc(65 / 1080 * 100vw), 65px);
  height: min(calc(1 / 1080 * 100vw), 1px);
  background-color: #333;
}
.sec06__head__title-main {
  font-family: "Noto Serif JP", serif;
  font-size: min(calc(56 / 1080 * 100vw), 56px);
  font-weight: 600;
  color: #1b3b82;
  line-height: 1.4;
  letter-spacing: 0.08em;
}
.sec06__head__title-main span {
  font-size: min(calc(38 / 1080 * 100vw), 38px);
  line-height: inherit;
}
.sec06__reasons {
  display: flex;
  flex-direction: column;
  gap: min(calc(80 / 1080 * 100vw), 80px);
}
.sec06__reason {
  position: relative;
}
.sec06__reason__circle {
  width: min(calc(115 / 1080 * 100vw), 115px);
  height: min(calc(115 / 1080 * 100vw), 115px);
  position: relative;
  z-index: 2;
  margin: 0 auto max(calc(-57.5 / 1080 * 100vw), -57.5px);
}
.sec06__reason__circle-inner {
  width: 100%;
  height: 100%;
  background: url(../img/common/sec03_bg_title.svg) center/cover no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}
.sec06__reason__number {
  font-family: "Noto Serif JP", serif;
  font-size: min(calc(46 / 1080 * 100vw), 46px);
  font-weight: 600;
  color: #1b3b82;
  line-height: 1.1;
  text-align: center;
  letter-spacing: 0.08em;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.sec06__reason__number span {
  font-family: "Noto Sans JP";
  font-size: min(calc(16 / 1080 * 100vw), 16px);
  line-height: inherit;
}
.sec06__reason__number br {
  margin-bottom: min(calc(5 / 1080 * 100vw), 5px);
}
.sec06__reason__content {
  flex: 1;
  padding: min(calc(90 / 1080 * 100vw), 90px) min(calc(40 / 1080 * 100vw), 40px) min(calc(40 / 1080 * 100vw), 40px);
  background: var(--base01, #fff);
  box-shadow: 0px 0px 11.52px 0px rgba(21, 21, 21, 0.15);
}
.sec06__reason--01 .sec06__reason__content {
  padding: min(calc(90 / 1080 * 100vw), 90px) 0 min(calc(40 / 1080 * 100vw), 40px);
}
.sec06__reason .note {
  color: var(--base-666, #666);
  font-family: "Noto Sans JP";
  font-size: min(calc(12 / 1080 * 100vw), 12px);
  font-style: normal;
  font-weight: 300;
  line-height: 1.5; /* 18px */
  text-align: center;
  margin-bottom: min(calc(40 / 1080 * 100vw), 40px);
}
.sec06__reason__card {
  background-color: #fff;
  border-radius: min(calc(4 / 1080 * 100vw), 4px);
  overflow: hidden;
}
.sec06__reason__card-inner {
  display: flex;
  gap: min(calc(40 / 1080 * 100vw), 40px);
}
.sec06__reason__card-img {
  width: min(calc(440 / 1080 * 100vw), 440px);
  flex-shrink: 0;
}
.sec06__reason__card-text {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.sec06__reason__card-title {
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(calc(23 / 1080 * 100vw), 23px);
  font-weight: 700;
  color: #333;
  margin-bottom: min(calc(24 / 1080 * 100vw), 24px);
  line-height: 1.6;
  letter-spacing: 0.08em;
}
.sec06__reason__card-desc {
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(calc(18.7 / 1080 * 100vw), 18.7px);
  font-weight: 400;
  color: #333;
  line-height: 1.8;
  letter-spacing: 0.08em;
  text-align: justify;
}
.sec06__reason__slider {
  position: relative;
  margin-bottom: min(calc(80 / 1080 * 100vw), 80px);
}
.sec06__reason__slider .swiper-buttons {
  position: absolute;
  bottom: max(calc(-37 / 1080 * 100vw), -37px);
  left: 50%;
  transform: translateX(-50%);
  width: min(calc(480 / 1080 * 100vw), 480px);
  z-index: 5;
}
.sec06__reason__slider .swiper-button-next,
.sec06__reason__slider .swiper-button-prev {
  width: min(calc(29 / 1080 * 100vw), 29px);
  height: min(calc(29 / 1080 * 100vw), 29px);
  background: url(../img/common/arrow-sli.svg) no-repeat center center/contain;
}
.sec06__reason__slider .swiper-button-next::after,
.sec06__reason__slider .swiper-button-prev::after {
  display: none;
}
.sec06__reason__slider .swiper-button-next {
  transform: scale(-1, 1);
}
.sec06__reason__slider .swiper-pagination {
  bottom: max(calc(-44 / 1080 * 100vw), -44px);
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  width: fit-content;
}
.sec06__reason__slider .swiper-pagination .swiper-pagination-bullet {
  width: min(calc(9 / 1080 * 100vw), 9px);
  height: min(calc(9 / 1080 * 100vw), 9px);
  background-color: #dddddd;
  opacity: 1;
  margin: 0 min(calc(6 / 1080 * 100vw), 6px);
}
.sec06__reason__slider .swiper-pagination .swiper-pagination-bullet-active {
  background-color: #1b3b82;
}
.sec06__reason__slide {
  display: flex;
  flex-direction: column;
  padding: 0 min(calc(28 / 1080 * 100vw), 28px);
}
.sec06__reason__slide__img {
  width: 100%;
  height: min(calc(300 / 1080 * 100vw), 300px);
  overflow: hidden;
}
.sec06__reason__slide__img img {
  width: 100%;
  height: 100%;
}
.sec06__reason__slide__info {
  background-color: #f1f1f1;
  padding: min(calc(14 / 1080 * 100vw), 14px) min(calc(20 / 1080 * 100vw), 20px) min(calc(30 / 1080 * 100vw), 30px);
}
.sec06__reason__slide__title {
  font-family: "Noto Serif JP", serif;
  font-size: min(calc(20 / 1080 * 100vw), 20px);
  font-weight: 500;
  color: #333;
  line-height: 1.6;
  letter-spacing: -0.14em;
  min-height: 2.2em;
  display: flex;
  align-items: center;
  width: 100%;
  min-height: 3.2em;
}
.sec06__reason__slide__content {
  display: flex;
  align-items: center;
  gap: min(calc(16 / 1080 * 100vw), 16px);
}
.sec06__reason__slide__price-tag {
  display: inline-block;
  border: min(calc(0.7 / 1080 * 100vw), 0.7px) solid #333;
  padding: min(calc(2 / 1080 * 100vw), 2px) min(calc(6 / 1080 * 100vw), 6px) min(calc(3 / 1080 * 100vw), 3px);
  margin-bottom: min(calc(5 / 1080 * 100vw), 5px);
}
.sec06__reason__slide__price-label {
  font-family: "Noto Serif JP", serif;
  font-size: min(calc(20 / 1080 * 100vw), 20px);
  font-weight: 500;
  color: #333;
  letter-spacing: 0.08em;
}
.sec06__reason__slide__price {
  margin-bottom: min(calc(5 / 1080 * 100vw), 5px);
  position: relative;
}
.sec06__reason__slide__price-amount {
  color: var(--accent03, #d52665);
  font-feature-settings: "palt" on;
  font-family: "Noto Serif JP";
  font-size: min(calc(56 / 1080 * 100vw), 56px);
  font-style: normal;
  font-weight: 600;
  line-height: 1; /* 89.6px */
  letter-spacing: 0.05em;
}
.sec06__reason__slide__price-amount span {
  font-size: min(calc(20 / 1080 * 100vw), 20px);
  color: var(--text01, #333);
  line-height: inherit;
  font-weight: 500;
}
.sec06__reason__slide__price-tax {
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(calc(12 / 1080 * 100vw), 12px);
  font-weight: 300;
  color: #333;
  letter-spacing: 0.06em;
  margin-left: min(calc(5 / 1080 * 100vw), 5px);
  position: absolute;
  right: 0;
  bottom: min(calc(30 / 1080 * 100vw), 30px);
}
.sec06__reason__slide__detail {
  font-family: "Noto Serif JP", serif;
  font-size: min(calc(20 / 1080 * 100vw), 20px);
  font-weight: 500;
  color: #333;
  letter-spacing: 0.04em;
}
.sec06__reason__note {
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(calc(12 / 1080 * 100vw), 12px);
  font-weight: 300;
  color: #666;
  letter-spacing: 0.06em;
  text-align: center;
  margin-bottom: min(calc(40 / 1080 * 100vw), 40px);
}
.sec06__reason__text {
  display: flex;
  gap: min(calc(40 / 1080 * 100vw), 40px);
  padding: 0 min(calc(40 / 1080 * 100vw), 40px);
}
.sec06__reason--01 .sec06__reason__text {
  margin-top: min(calc(80 / 1080 * 100vw), 80px);
}
.sec06__reason__text-inner {
  display: flex;
  flex-direction: row-reverse;
  gap: min(calc(40 / 1080 * 100vw), 40px);
}
.sec06__reason__text-main {
  flex: 1;
  width: min(calc(440 / 1080 * 100vw), 440px);
}
.sec06__reason__text-title {
  color: var(--text01, #333);
  font-family: "Noto Serif JP";
  font-size: min(calc(22 / 1080 * 100vw), 22px);
  font-style: normal;
  font-weight: 500;
  line-height: 1.4; /* 35.2px */
  letter-spacing: 0.04em;
  margin-bottom: min(calc(12 / 1080 * 100vw), 12px);
}
.sec06__reason__text-title span {
  color: var(--main01, #1b3b82);
  font-size: min(calc(38 / 1080 * 100vw), 38px);
  line-height: inherit;
}
.sec06__reason__text-title sup {
  color: var(--base-666, #666);
  font-size: min(calc(12 / 1080 * 100vw), 12px);
}
.sec06__reason__text-desc {
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(calc(16 / 1080 * 100vw), 16px);
  font-weight: 400;
  color: #333;
  line-height: 1.8;
  letter-spacing: 0.08em;
  margin-bottom: min(calc(12 / 1080 * 100vw), 12px);
}
.sec06__reason__text-note {
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(calc(12 / 1080 * 100vw), 12px);
  font-weight: 300;
  color: #666;
  letter-spacing: 0.06em;
}
.sec06__reason__badge {
  width: min(calc(440 / 1080 * 100vw), 440px);
  height: auto;
  position: relative;
}
.sec06__reason__badge::before, .sec06__reason__badge::after {
  content: "";
  display: block;
  width: min(calc(40 / 1080 * 100vw), 40px);
  height: min(calc(102 / 1080 * 100vw), 102px);
  background: url(../img/common/sec06_badge.svg) no-repeat center center/cover;
  position: absolute;
  top: min(calc(70 / 1080 * 100vw), 70px);
  z-index: 5;
}
.sec06__reason__badge::before {
  left: min(calc(35 / 1080 * 100vw), 35px);
}
.sec06__reason__badge::after {
  right: min(calc(35 / 1080 * 100vw), 35px);
  scale: -1 1;
}
.sec06__reason__badge-inner {
  background: linear-gradient(to bottom right, #132754, #1463ac);
  padding: min(calc(30 / 1080 * 100vw), 30px) min(calc(20 / 1080 * 100vw), 20px);
  border-radius: min(calc(4 / 1080 * 100vw), 4px);
  text-align: center;
  position: relative;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
.sec06__reason__badge-title {
  font-family: "Noto Serif JP", serif;
  font-size: min(calc(24 / 1080 * 100vw), 24px);
  font-weight: 600;
  color: #fff;
  letter-spacing: 0.08em;
}
.sec06__reason__badge-number {
  font-family: "Noto Serif JP", serif;
  font-size: min(calc(29.4 / 1080 * 100vw), 29.4px);
  font-weight: 400;
  color: #003888;
  letter-spacing: 0.08em;
  line-height: 1.4;
  margin-bottom: min(calc(5 / 1080 * 100vw), 5px);
  color: #fff;
}
.sec06__reason__badge-number-text {
  font-weight: 700;
  background: linear-gradient(to bottom right, #ab7e25, #eae2b9, #a9863f);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-family: "Noto Serif JP", serif;
  font-size: min(calc(48 / 1080 * 100vw), 48px);
}
.sec06__reason__badge-number-text small {
  font-size: min(calc(24 / 1080 * 100vw), 24px);
}
.sec06__reason__badge-number .sec06__reason__badge-mark {
  font-size: min(calc(12 / 1080 * 100vw), 12px);
  font-weight: 300;
  color: #fff;
  letter-spacing: 0.06em;
  position: static;
}
.sec06__reason__badge-mark {
  position: absolute;
  top: min(calc(70 / 1080 * 100vw), 70px);
  right: min(calc(45 / 1080 * 100vw), 45px);
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(calc(12 / 1080 * 100vw), 12px);
  font-weight: 300;
  color: #eee;
  letter-spacing: 0.06em;
}
.sec06__reason__badge-note {
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(calc(12 / 1080 * 100vw), 12px);
  font-weight: 300;
  color: #eee;
  letter-spacing: 0.06em;
}
.sec06__reason--01 .sec06__reason__number {
  color: #1b3b82;
}
.sec06__reason--02 .sec06__reason__number {
  color: #1b3b82;
}
.sec06__reason--03 .sec06__reason__number {
  color: #1b3b82;
}

@media screen and (max-width: 767px) {
  .sec06 {
    padding: calc(200 / 750 * 100vw) 0 calc(240 / 750 * 100vw);
    background: #eaeef2 url("../img/sp/sec06_bg.webp") center/contain no-repeat;
  }
  .sec06__inner {
    width: 100%;
    padding: 0 calc(30 / 750 * 100vw);
  }
  .sec06__head {
    margin-bottom: calc(51 / 750 * 100vw);
  }
  .sec06__head__line {
    gap: calc(24 / 750 * 100vw);
    margin-bottom: calc(16 / 750 * 100vw);
  }
  .sec06__head__line span {
    width: calc(120 / 750 * 100vw);
    height: calc(1 / 750 * 100vw);
  }
  .sec06__head__title {
    gap: calc(16 / 750 * 100vw);
  }
  .sec06__head__title-small {
    font-size: calc(36 / 750 * 100vw);
    gap: calc(24 / 750 * 100vw);
  }
  .sec06__head__title-small:before, .sec06__head__title-small::after {
    width: calc(91 / 750 * 100vw);
    height: calc(2 / 750 * 100vw);
  }
  .sec06__head__title-main {
    font-size: calc(64 / 750 * 100vw);
  }
  .sec06__head__title-main span {
    font-size: calc(48 / 750 * 100vw);
  }
  .sec06__reasons {
    gap: calc(55 / 750 * 100vw);
  }
  .sec06__reason {
    flex-direction: column;
    align-items: center;
    gap: calc(40 / 750 * 100vw);
  }
  .sec06__reason__content {
    padding: 0;
  }
  .sec06__reason .note {
    font-size: calc(20 / 750 * 100vw);
  }
  .sec06__reason__circle {
    width: calc(160 / 750 * 100vw);
    height: calc(160 / 750 * 100vw);
    margin-bottom: calc(-80 / 750 * 100vw);
  }
  .sec06__reason__circle-inner::after {
    border-width: calc(1 / 750 * 100vw);
  }
  .sec06__reason__number {
    font-size: calc(64 / 750 * 100vw);
  }
  .sec06__reason__number span {
    font-size: calc(24 / 750 * 100vw);
  }
  .sec06__reason--01 .sec06__reason__content {
    padding-top: calc(120 / 750 * 100vw);
  }
  .sec06__reason__card {
    width: 100%;
  }
  .sec06__reason__card-inner {
    flex-direction: column;
    padding: calc(120 / 750 * 100vw) calc(30 / 750 * 100vw) calc(56 / 750 * 100vw);
    gap: calc(40 / 750 * 100vw);
  }
  .sec06__reason__card-img {
    width: 100%;
  }
  .sec06__reason__card-title {
    font-size: calc(32 / 750 * 100vw);
    margin-bottom: calc(24 / 750 * 100vw);
  }
  .sec06__reason__card-desc {
    font-size: calc(26 / 750 * 100vw);
  }
  .sec06__reason__slider {
    margin-bottom: calc(112 / 750 * 100vw);
  }
  .sec06__reason__slider .swiper-buttons {
    width: 100%;
    padding: 0 calc(30 / 750 * 100vw);
    bottom: calc(-80 / 750 * 100vw);
  }
  .sec06__reason__slider .swiper-button-next,
  .sec06__reason__slider .swiper-button-prev {
    width: calc(40 / 750 * 100vw);
    height: calc(40 / 750 * 100vw);
  }
  .sec06__reason__slider .swiper-button-next::after,
  .sec06__reason__slider .swiper-button-prev::after {
    font-size: calc(24 / 750 * 100vw);
  }
  .sec06__reason__slider .swiper-button-next {
    right: calc(30 / 750 * 100vw);
  }
  .sec06__reason__slider .swiper-button-prev {
    left: calc(30 / 750 * 100vw);
  }
  .sec06__reason__slider .swiper-pagination {
    bottom: calc(-80 / 750 * 100vw);
  }
  .sec06__reason__slider .swiper-pagination .swiper-pagination-bullet {
    width: calc(12 / 750 * 100vw);
    height: calc(12 / 750 * 100vw);
    margin: 0 calc(8 / 750 * 100vw);
  }
  .sec06__reason__slide {
    padding: 0 calc(30 / 750 * 100vw);
  }
  .sec06__reason__slide__img {
    height: calc(400 / 750 * 100vw);
  }
  .sec06__reason__slide__info {
    padding: calc(8 / 750 * 100vw) calc(20 / 750 * 100vw) calc(28 / 750 * 100vw);
  }
  .sec06__reason__slide__title {
    font-size: calc(30 / 750 * 100vw);
    margin-bottom: calc(4 / 750 * 100vw);
  }
  .sec06__reason__slide__content {
    gap: calc(24 / 750 * 100vw);
  }
  .sec06__reason__slide__price-tag {
    border-width: calc(1 / 750 * 100vw);
    padding: 0 calc(8 / 750 * 100vw) calc(2 / 750 * 100vw);
    margin-bottom: calc(10 / 750 * 100vw);
  }
  .sec06__reason__slide__price-label {
    font-size: calc(30 / 750 * 100vw);
  }
  .sec06__reason__slide__price {
    margin-bottom: calc(10 / 750 * 100vw);
  }
  .sec06__reason__slide__price-amount {
    font-size: calc(80 / 750 * 100vw);
  }
  .sec06__reason__slide__price-amount span {
    font-size: calc(30 / 750 * 100vw);
  }
  .sec06__reason__slide__price-tax {
    font-size: calc(20 / 750 * 100vw);
    bottom: calc(40 / 750 * 100vw);
  }
  .sec06__reason__slide__detail {
    font-size: calc(30 / 750 * 100vw);
  }
  .sec06__reason__note {
    font-size: calc(20 / 750 * 100vw);
    margin-bottom: calc(48 / 750 * 100vw);
  }
  .sec06__reason__text {
    flex-direction: column;
    gap: calc(40 / 750 * 100vw);
    padding: 0 calc(30 / 750 * 100vw);
  }
  .sec06__reason__text-inner {
    flex-direction: column-reverse;
    gap: calc(40 / 750 * 100vw);
  }
  .sec06__reason__text-title {
    font-size: calc(32 / 750 * 100vw);
    margin-bottom: calc(24 / 750 * 100vw);
    line-height: 1.6;
  }
  .sec06__reason__text-title span {
    font-size: calc(48 / 750 * 100vw);
    line-height: inherit;
  }
  .sec06__reason__text-title sup {
    font-size: calc(20 / 750 * 100vw);
    vertical-align: middle;
  }
  .sec06__reason__text-desc {
    font-size: calc(26 / 750 * 100vw);
  }
  .sec06__reason__text-note {
    font-size: calc(20 / 750 * 100vw);
  }
  .sec06__reason__text-main {
    width: 100%;
  }
  .sec06__reason__badge {
    width: 100%;
    margin-top: 0;
  }
  .sec06__reason__badge::before, .sec06__reason__badge::after {
    width: calc(53 / 750 * 100vw);
    height: calc(148 / 750 * 100vw);
    top: calc(40 / 750 * 100vw);
  }
  .sec06__reason__badge-inner {
    padding: calc(30 / 750 * 100vw) calc(0 / 750 * 100vw) calc(17 / 750 * 100vw);
    border-radius: calc(4 / 750 * 100vw);
  }
  .sec06__reason__badge-title {
    font-size: calc(36 / 750 * 100vw);
    margin-bottom: 0;
  }
  .sec06__reason__badge-number {
    font-size: calc(36 / 750 * 100vw);
    line-height: 1.3;
  }
  .sec06__reason__badge-number span {
    line-height: inherit;
  }
  .sec06__reason__badge-number .sec06__reason__badge-mark {
    font-size: calc(20 / 750 * 100vw);
  }
  .sec06__reason__badge-number-text {
    font-size: calc(56 / 750 * 100vw);
  }
  .sec06__reason__badge-number-text small {
    font-size: calc(36 / 750 * 100vw);
  }
  .sec06__reason__badge-note {
    font-size: calc(20 / 750 * 100vw);
    margin-top: calc(4 / 750 * 100vw);
  }
}
.sec07 {
  position: relative;
  width: 100%;
  background-color: #fff;
  padding: min(calc(15 / 1080 * 100vw), 15px) 0 min(calc(64 / 1080 * 100vw), 64px);
  overflow: hidden;
}
.sec07__inner {
  width: min(calc(1080 / 1080 * 100vw), 1080px);
  margin: 0 auto;
  padding: 0 min(calc(80 / 1080 * 100vw), 80px);
}
.sec07__header {
  text-align: center;
  margin-bottom: max(calc(-18 / 1080 * 100vw), -18px);
  position: relative;
  z-index: 2;
}
.sec07__header__label {
  display: inline-block;
  background-color: #1b3b82;
  color: #fff;
  font-size: min(calc(20 / 1080 * 100vw), 20px);
  font-weight: 700;
  padding: min(calc(4 / 1080 * 100vw), 4px) min(calc(18 / 1080 * 100vw), 18px);
  font-family: "Noto Serif JP";
}
.sec07__content {
  position: relative;
  background: var(--base03, #eaeef2);
  padding: min(calc(64 / 1080 * 100vw), 64px) 0;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: min(calc(38 / 1080 * 100vw), 38px);
}
.sec07__badge {
  position: relative;
  text-align: center;
  width: min(calc(228 / 1080 * 100vw), 228px);
}
.sec07__badge__inner {
  position: relative;
  display: inline-block;
  width: 100%;
  aspect-ratio: 1/1;
  background: url("../img/common/sec07_badge.svg") no-repeat center/contain;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
.sec07__badge__title {
  font-family: "Noto Serif JP", serif;
  font-size: min(calc(24 / 1080 * 100vw), 24px);
  font-weight: 600;
  color: #333;
}
.sec07__badge__number {
  font-family: "Noto Serif JP", serif;
  font-size: min(calc(56 / 1080 * 100vw), 56px);
  font-weight: 600;
  line-height: 1.2;
  color: #333;
  position: relative;
  width: fit-content;
  margin: 0 auto;
}
.sec07__badge__decimal {
  font-size: min(calc(24 / 1080 * 100vw), 24px);
}
.sec07__badge__percent {
  font-size: min(calc(24 / 1080 * 100vw), 24px);
}
.sec07__badge__note {
  font-size: min(calc(12 / 1080 * 100vw), 12px);
  vertical-align: super;
  position: absolute;
  bottom: min(calc(30 / 1080 * 100vw), 30px);
  right: 0;
  color: #666;
}
.sec07__guarantee {
  text-align: center;
  position: relative;
  width: min(calc(454 / 1080 * 100vw), 454px);
}
.sec07__guarantee__title {
  font-family: "Noto Serif JP", serif;
  font-size: min(calc(38 / 1080 * 100vw), 38px);
  font-weight: 500;
  color: #1b3b82;
  margin-bottom: min(calc(20 / 1080 * 100vw), 20px);
  position: relative;
}
.sec07__guarantee__title::before {
  content: "";
  position: absolute;
  bottom: max(calc(-10 / 1080 * 100vw), -10px);
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  height: min(calc(1 / 1080 * 100vw), 1px);
  background: linear-gradient(to right, rgba(27, 59, 130, 0), rgb(27, 59, 130), rgba(27, 59, 130, 0));
}
.sec07__guarantee__text {
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(calc(16 / 1080 * 100vw), 16px);
  line-height: 2.5;
  color: #333;
  width: min(calc(390 / 1080 * 100vw), 390px);
  margin: 0 auto;
}
.sec07__guarantee__text span {
  font-size: min(calc(24 / 1080 * 100vw), 24px);
  font-family: "Noto Serif JP";
}

@media screen and (max-width: 767px) {
  .sec07 {
    padding: calc(20 / 750 * 100vw) 0 calc(80 / 750 * 100vw);
  }
  .sec07__inner {
    width: 100%;
    padding: 0 calc(30 / 750 * 100vw);
  }
  .sec07__header {
    margin-bottom: calc(-25 / 750 * 100vw);
    position: relative;
    z-index: 2;
  }
  .sec07__header__label {
    font-size: calc(30 / 750 * 100vw);
    padding: calc(6 / 750 * 100vw) calc(24 / 750 * 100vw);
    font-family: "Noto Serif JP";
  }
  .sec07__content {
    flex-direction: column;
    padding: calc(60 / 750 * 100vw) calc(20 / 750 * 100vw) calc(60 / 750 * 100vw);
    gap: calc(50 / 750 * 100vw);
  }
  .sec07__badge {
    width: calc(272 / 750 * 100vw);
    margin: 0 auto;
  }
  .sec07__badge__inner {
    width: 100%;
    aspect-ratio: 1/1;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
  }
  .sec07__badge__title {
    font-size: calc(36 / 750 * 100vw);
    margin-top: calc(20 / 750 * 100vw);
    line-height: 1;
  }
  .sec07__badge__number {
    font-size: calc(86 / 750 * 100vw);
    position: relative;
    width: fit-content;
    margin: 0 auto;
  }
  .sec07__badge__decimal {
    font-size: calc(40 / 750 * 100vw);
  }
  .sec07__badge__percent {
    font-size: calc(40 / 750 * 100vw);
  }
  .sec07__badge__note {
    font-size: calc(20 / 750 * 100vw);
    position: absolute;
    bottom: calc(50 / 750 * 100vw);
    right: calc(6 / 750 * 100vw);
  }
  .sec07__guarantee {
    width: 100%;
    background: url("../img/sp/shop_bg.webp") center calc(100 / 750 * 100vw)/95% no-repeat;
  }
  .sec07__guarantee__title {
    font-size: calc(48 / 750 * 100vw);
    margin-bottom: calc(30 / 750 * 100vw);
  }
  .sec07__guarantee__title::before {
    bottom: calc(-15 / 750 * 100vw);
    height: calc(1 / 750 * 100vw);
  }
  .sec07__guarantee__text {
    font-size: calc(24 / 750 * 100vw);
    line-height: 2;
    width: 100%;
  }
  .sec07__guarantee__text span {
    font-size: calc(36 / 750 * 100vw);
  }
}
.sec08 {
  position: relative;
  width: 100%;
  background-color: #f1f1f1;
  padding: min(calc(64 / 1080 * 100vw), 64px) 0;
  overflow: hidden;
}
.sec08__inner {
  width: min(calc(1080 / 1080 * 100vw), 1080px);
  margin: 0 auto;
  padding: 0 min(calc(40 / 1080 * 100vw), 40px);
}
.sec08__longterm__text {
  font-family: "Noto Serif JP";
  font-size: min(calc(22 / 1080 * 100vw), 22px);
  text-align: center;
  color: #333;
  line-height: 1.3;
}
.sec08__longterm__title {
  font-family: "Noto Serif JP", serif;
  font-size: min(calc(38 / 1080 * 100vw), 38px);
  font-weight: 500;
  text-align: center;
  margin-bottom: min(calc(40 / 1080 * 100vw), 40px);
  color: #333;
}
.sec08__longterm__title sup {
  font-size: min(calc(12 / 1080 * 100vw), 12px);
  vertical-align: middle;
  color: var(--base-666, #666);
}
.sec08__longterm__note {
  font-size: min(calc(12 / 1080 * 100vw), 12px);
  vertical-align: super;
  margin-left: min(calc(2 / 1080 * 100vw), 2px);
}
.sec08__longterm__subtitle {
  font-family: "Noto Serif JP", serif;
  font-size: min(calc(32 / 1080 * 100vw), 32px);
  font-weight: 600;
  text-align: center;
  margin-bottom: min(calc(30 / 1080 * 100vw), 30px);
  color: #333;
}
.sec08__longterm {
  background-color: #fff;
  padding: min(calc(36 / 1080 * 100vw), 36px) min(calc(40 / 1080 * 100vw), 40px) min(calc(4 / 1080 * 100vw), 4px);
  box-shadow: 0px 0px min(calc(11.52 / 1080 * 100vw), 11.52px) rgba(21, 21, 21, 0.15);
  margin-bottom: min(calc(35 / 1080 * 100vw), 35px);
}
.sec08__services {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: min(calc(19 / 1080 * 100vw), 19px);
}
.sec08__service {
  width: min(calc(137 / 1080 * 100vw), 137px);
  margin-bottom: min(calc(30 / 1080 * 100vw), 30px);
  text-align: center;
}
.sec08__service__icon {
  width: 100%;
  aspect-ratio: 1/1;
  margin: 0 auto min(calc(8 / 1080 * 100vw), 8px);
}
.sec08__service__icon img {
  width: 100%;
  height: auto;
}
.sec08__service__title {
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(calc(14 / 1080 * 100vw), 14px);
  line-height: 1.8;
  color: #333;
}
.sec08__description {
  margin-bottom: min(calc(20 / 1080 * 100vw), 20px);
  padding: 0 min(calc(40 / 1080 * 100vw), 40px);
}
.sec08__description p {
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(calc(16 / 1080 * 100vw), 16px);
  line-height: 1.8;
  color: #333;
  text-align: justify;
}
.sec08__notes {
  padding: 0 min(calc(40 / 1080 * 100vw), 40px);
}
.sec08__notes__text {
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(calc(12 / 1080 * 100vw), 12px);
  line-height: 1.5;
  color: #666;
  font-weight: 300;
}

@media screen and (max-width: 767px) {
  .sec08 {
    padding: calc(64 / 750 * 100vw) 0 calc(56 / 750 * 100vw);
    background-color: #f1f1f1;
  }
  .sec08__inner {
    width: 100%;
  }
  .sec08__longterm__text {
    font-size: calc(32 / 750 * 100vw);
    text-align: center;
    padding: 0 calc(20 / 750 * 100vw);
  }
  .sec08__longterm__title {
    font-size: calc(48 / 750 * 100vw);
    text-align: center;
    margin-bottom: calc(40 / 750 * 100vw);
    padding: 0 calc(20 / 750 * 100vw);
  }
  .sec08__longterm__title sup {
    font-size: calc(20 / 750 * 100vw);
    vertical-align: middle;
  }
  .sec08__longterm__note {
    font-size: calc(20 / 750 * 100vw);
  }
  .sec08__longterm__subtitle {
    font-size: calc(40 / 750 * 100vw);
    margin-bottom: calc(20 / 750 * 100vw);
  }
  .sec08__longterm {
    background-color: #fff;
    padding: calc(56 / 750 * 100vw) calc(30 / 750 * 100vw) calc(30 / 750 * 100vw);
    box-shadow: 0px 0px calc(16 / 750 * 100vw) rgba(21, 21, 21, 0.15);
    margin: 0 0 calc(40 / 750 * 100vw);
  }
  .sec08__services {
    gap: calc(30 / 750 * 100vw);
  }
  .sec08__service {
    width: calc(190 / 750 * 100vw);
  }
  .sec08__service__icon {
    width: 100%;
    margin: 0 auto calc(10 / 750 * 100vw);
  }
  .sec08__service__title {
    font-size: calc(24 / 750 * 100vw);
    line-height: 1.5;
  }
  .sec08__description {
    margin-bottom: calc(24 / 750 * 100vw);
    padding: 0;
  }
  .sec08__description p {
    font-size: calc(26 / 750 * 100vw);
    line-height: 1.8;
  }
  .sec08__notes {
    padding: 0;
  }
  .sec08__notes__text {
    font-size: calc(20 / 750 * 100vw);
    line-height: 1.5;
  }
}
.sec09 {
  position: relative;
  width: 100%;
  overflow: hidden;
  background-color: #fff;
  padding: min(calc(80 / 1080 * 100vw), 80px) 0;
}
.sec09__inner {
  position: relative;
  width: min(calc(1080 / 1080 * 100vw), 1080px);
  margin: 0 auto;
  padding: 0 min(calc(80 / 1080 * 100vw), 80px);
}
.sec09__title {
  color: #1b3b82;
  font-weight: 600;
  font-family: "Noto Serif JP", serif;
  font-size: min(calc(48 / 1080 * 100vw), 48px);
  line-height: 1.6;
  letter-spacing: 0.08em;
  text-align: center;
  margin-bottom: min(calc(40 / 1080 * 100vw), 40px);
}
.sec09__comments {
  display: flex;
  flex-direction: column;
  gap: min(calc(64 / 1080 * 100vw), 64px);
  width: min(calc(750 / 1080 * 100vw), 750px);
  margin: 0 auto;
}
.sec09__comment {
  display: flex;
  width: 100%;
  margin: 0 auto;
  gap: min(calc(23 / 1080 * 100vw), 23px);
}
.sec09__comment:nth-child(2) {
  flex-direction: row-reverse;
}
.sec09__comment__img {
  flex-shrink: 0;
  width: min(calc(86 / 1080 * 100vw), 86px);
  height: min(calc(86 / 1080 * 100vw), 86px);
}
.sec09__comment__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.sec09__comment__txt {
  position: relative;
  display: flex;
}
.sec09__comment__balloon {
  position: absolute;
  left: max(calc(-17 / 1080 * 100vw), -17px);
  top: min(calc(40 / 1080 * 100vw), 40px);
  width: min(calc(20 / 1080 * 100vw), 20px);
  height: min(calc(20 / 1080 * 100vw), 20px);
  background-color: #fff;
  clip-path: polygon(0 0, 100% 0, 100% 100%);
}
.sec09__comment__balloon--right {
  left: auto;
  right: max(calc(-17 / 1080 * 100vw), -17px);
  scale: -1 1;
}
.sec09__comment__content {
  background-color: #fff;
  border-radius: min(calc(12 / 1080 * 100vw), 12px);
  padding: min(calc(24 / 1080 * 100vw), 24px) min(calc(40 / 1080 * 100vw), 40px);
  box-shadow: 0px 0px min(calc(11.52 / 1080 * 100vw), 11.52px) rgba(21, 21, 21, 0.15);
  width: min(calc(640 / 1080 * 100vw), 640px);
}
.sec09__comment__text {
  color: #333;
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(calc(16 / 1080 * 100vw), 16px);
  font-weight: 400;
  line-height: 1.8;
  letter-spacing: 0.08em;
  text-align: justify;
  margin-bottom: min(calc(8 / 1080 * 100vw), 8px);
}
.sec09__comment__car {
  color: #1b3b82;
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(calc(16 / 1080 * 100vw), 16px);
  font-weight: 400;
  line-height: 1.8;
  letter-spacing: 0.08em;
  text-align: right;
}

@media screen and (max-width: 767px) {
  .sec09 {
    padding: calc(80 / 750 * 100vw) 0;
  }
  .sec09__inner {
    width: 100%;
    padding: 0 calc(60 / 750 * 100vw);
  }
  .sec09__title {
    font-size: calc(56 / 750 * 100vw);
    margin-bottom: calc(56 / 750 * 100vw);
  }
  .sec09__comments {
    gap: calc(56 / 750 * 100vw);
    width: 100%;
  }
  .sec09__comment {
    width: 100%;
    gap: calc(32 / 750 * 100vw);
  }
  .sec09__comment__img {
    width: calc(120 / 750 * 100vw);
    height: calc(120 / 750 * 100vw);
  }
  .sec09__comment__txt {
    width: calc(100% - calc(156 / 750 * 100vw));
  }
  .sec09__comment__balloon {
    left: calc(-24 / 750 * 100vw);
    top: calc(58 / 750 * 100vw);
    width: calc(30 / 750 * 100vw);
    height: calc(30 / 750 * 100vw);
  }
  .sec09__comment__balloon--right {
    left: auto;
    right: calc(-24 / 750 * 100vw);
  }
  .sec09__comment__content {
    border-radius: calc(16 / 750 * 100vw);
    padding: calc(24 / 750 * 100vw) calc(40 / 750 * 100vw);
    box-shadow: 0px 0px calc(16 / 750 * 100vw) rgba(21, 21, 21, 0.15);
    width: 100%;
  }
  .sec09__comment__text {
    font-size: calc(26 / 750 * 100vw);
    margin-bottom: calc(8 / 750 * 100vw);
  }
  .sec09__comment__car {
    font-size: calc(26 / 750 * 100vw);
  }
}
.sec10 {
  position: relative;
  width: 100%;
  background-color: #eaeef2;
  padding: min(calc(80 / 1080 * 100vw), 80px) 0;
  overflow: hidden;
}
.sec10__title {
  color: #1b3b82;
  font-size: min(calc(48 / 1080 * 100vw), 48px);
  font-weight: 600;
  font-family: "Noto Serif JP", serif;
  line-height: 1.6;
  letter-spacing: 0.08em;
  text-align: center;
  margin-bottom: min(calc(40 / 1080 * 100vw), 40px);
}
.sec10__contents {
  width: min(calc(720 / 1080 * 100vw), 720px);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: min(calc(16 / 1080 * 100vw), 16px);
}
.sec10__inner {
  width: 100%;
  display: flex;
  justify-content: center;
  gap: min(calc(24 / 1080 * 100vw), 24px);
}
.sec10__img {
  position: relative;
  width: min(calc(115 / 1080 * 100vw), 115px);
  height: min(calc(115 / 1080 * 100vw), 115px);
}
.sec10__img img {
  width: 100%;
  height: auto;
}
.sec10__detail {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: min(calc(8 / 1080 * 100vw), 8px);
}
.sec10__step {
  color: #1b3b82;
  font-size: min(calc(32 / 1080 * 100vw), 32px);
  font-weight: 600;
  font-family: "Noto Serif JP";
  line-height: 1.6;
  letter-spacing: 0.08em;
  margin-top: max(calc(-20 / 1080 * 100vw), -20px);
}
.sec10__step span {
  color: #333333;
  font-size: min(calc(20 / 1080 * 100vw), 20px);
  line-height: inherit;
  font-weight: 500;
}
.sec10__text {
  color: #333333;
  font-size: min(calc(16 / 1080 * 100vw), 16px);
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.8;
  letter-spacing: 0.08em;
}
.sec10__arrow {
  width: 100%;
  height: min(calc(40 / 1080 * 100vw), 40px);
  display: flex;
  justify-content: center;
  align-items: center;
}
.sec10__arrow img {
  width: min(calc(22 / 1080 * 100vw), 22px);
  height: auto;
}

@media screen and (max-width: 767px) {
  .sec10 {
    padding: calc(80 / 750 * 100vw) calc(30 / 750 * 100vw) calc(40 / 750 * 100vw);
  }
  .sec10__title {
    font-size: calc(56 / 750 * 100vw);
    margin-bottom: calc(56 / 750 * 100vw);
  }
  .sec10__contents {
    width: 100%;
    gap: calc(40 / 750 * 100vw);
  }
  .sec10__inner {
    width: calc(630 / 750 * 100vw);
    gap: calc(32 / 750 * 100vw);
  }
  .sec10__img {
    width: calc(160 / 750 * 100vw);
    height: calc(160 / 750 * 100vw);
  }
  .sec10__detail {
    gap: calc(16 / 750 * 100vw);
  }
  .sec10__step {
    font-size: calc(40 / 750 * 100vw);
    margin-top: calc(-20 / 750 * 100vw);
  }
  .sec10__step span {
    font-size: calc(30 / 750 * 100vw);
  }
  .sec10__text {
    font-size: calc(26 / 750 * 100vw);
    letter-spacing: 0.06em;
  }
  .sec10__arrow {
    height: calc(28 / 750 * 100vw);
  }
  .sec10__arrow img {
    width: calc(32 / 750 * 100vw);
  }
}
.sec11 {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.sec11__main {
  position: relative;
}
.sec11__main__inner {
  position: absolute;
  inset: 0;
  width: min(calc(1080 / 1080 * 100vw), 1080px);
  margin: 0 auto;
  padding: 0 min(calc(80 / 1080 * 100vw), 80px);
}
.sec11__title {
  color: #333333;
  font-weight: 600;
  font-family: "Noto Serif JP", serif;
  font-size: min(calc(20 / 1080 * 100vw), 20px);
  line-height: 1.8;
  letter-spacing: 0.08em;
  margin-top: min(calc(145 / 1080 * 100vw), 145px);
  margin-left: min(calc(28 / 1080 * 100vw), 28px);
  margin-bottom: min(calc(8 / 1080 * 100vw), 8px);
}
.sec11__content {
  position: relative;
  margin-bottom: min(calc(140 / 1080 * 100vw), 140px);
}
.sec11__content__line1 {
  color: #1b3b82;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-size: min(calc(54 / 1080 * 100vw), 54px);
  line-height: 1.6;
  letter-spacing: 0.18em;
  margin-bottom: min(calc(10 / 1080 * 100vw), 10px);
}
.sec11__content__dots {
  display: flex;
  justify-content: space-between;
  margin: min(calc(10 / 1080 * 100vw), 10px) 0 0 min(calc(160 / 1080 * 100vw), 160px);
  width: min(calc(205 / 1080 * 100vw), 205px);
}
.sec11__content__dot {
  width: min(calc(7 / 1080 * 100vw), 7px);
  height: min(calc(7 / 1080 * 100vw), 7px);
  background-color: #1b3b82;
  border-radius: 50%;
}
.sec11__content__line2 {
  color: #1b3b82;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-size: min(calc(54 / 1080 * 100vw), 54px);
  line-height: 1.6;
  letter-spacing: 0.18em;
  margin-left: min(calc(140 / 1080 * 100vw), 140px);
}
.sec11__content__line2 small {
  font-size: min(calc(32 / 1080 * 100vw), 32px);
  line-height: inherit;
}
.sec11__features {
  display: flex;
  justify-content: center;
  gap: min(calc(23 / 1080 * 100vw), 23px);
  margin-bottom: min(calc(20 / 1080 * 100vw), 20px);
}
.sec11__features__item {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.sec11__features__box {
  width: min(calc(80 / 1080 * 100vw), 80px);
  height: min(calc(42 / 1080 * 100vw), 42px);
  display: flex;
  justify-content: center;
  align-items: center;
  border: min(calc(0.7 / 1080 * 100vw), 0.7px) solid #ffffff;
  color: #ffffff;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: min(calc(20 / 1080 * 100vw), 20px);
  line-height: 1.6;
  letter-spacing: 0.08em;
  padding: min(calc(2.8 / 1080 * 100vw), 2.8px) min(calc(17.3 / 1080 * 100vw), 17.3px) min(calc(4.3 / 1080 * 100vw), 4.3px);
  position: relative;
}
.sec11__features__box::after {
  content: "";
  display: block;
  height: min(calc(14 / 1080 * 100vw), 14px);
  width: min(calc(2 / 1080 * 100vw), 2px);
  background: rgba(255, 255, 255, 0.7);
  border-right: 2px solid #133c72;
  border-left: 2px solid #133c72;
  position: absolute;
  overflow: hidden;
  left: 50%;
  bottom: 0;
  transform: translate(-50%, 70%);
  z-index: 1;
}
.sec11__tagline {
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-size: min(calc(32 / 1080 * 100vw), 32px);
  line-height: 1.6;
  letter-spacing: 0.08em;
  text-align: center;
  margin-bottom: min(calc(40 / 1080 * 100vw), 40px);
  background: linear-gradient(284deg, #e9ca50 0%, #f3ecbf 49.15%, #e9ca50 103.63%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.sec11__shop {
  padding: min(calc(24 / 1080 * 100vw), 24px) min(calc(40 / 1080 * 100vw), 40px) min(calc(20 / 1080 * 100vw), 20px);
  max-width: min(calc(748 / 1080 * 100vw), 748px);
  margin: 0 auto;
  text-align: center;
  box-shadow: 0px 0px min(calc(11.52 / 1080 * 100vw), 11.52px) rgba(21, 21, 21, 0.15);
  background: #fff url("../img/pc/shop_bg.webp") center min(calc(86 / 1080 * 100vw), 86px)/95% no-repeat;
}
.sec11__shop__title {
  color: #1b3b82;
  font-size: min(calc(28.8 / 1080 * 100vw), 28.8px);
  font-weight: 600;
  margin-bottom: min(calc(30 / 1080 * 100vw), 30px);
  font-family: "Noto Sans JP", sans-serif;
  letter-spacing: 0.08em;
  line-height: 1.8;
}
.sec11__shop__logo {
  width: min(calc(370 / 1080 * 100vw), 370px);
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .sec11__main {
    position: relative;
  }
  .sec11__main picture {
    display: block;
    width: 100%;
    height: auto;
  }
  .sec11__main__inner {
    width: 100%;
    padding: 0;
  }
  .sec11__title {
    font-size: calc(30 / 750 * 100vw);
    margin: calc(200 / 750 * 100vw) auto 0;
    text-align: center;
  }
  .sec11__content {
    width: calc(590 / 750 * 100vw);
    margin: 0 auto calc(346 / 750 * 100vw);
  }
  .sec11__content__line1 {
    font-size: calc(76 / 750 * 100vw);
    margin-bottom: 0;
  }
  .sec11__content__dots {
    gap: calc(30 / 750 * 100vw);
    width: calc(280 / 750 * 100vw);
    margin-left: calc(216 / 750 * 100vw);
  }
  .sec11__content__dot {
    width: calc(10 / 750 * 100vw);
    height: calc(10 / 750 * 100vw);
  }
  .sec11__content__line2 {
    font-size: calc(76 / 750 * 100vw);
    margin-left: calc(179 / 750 * 100vw);
  }
  .sec11__content__line2 small {
    font-size: calc(50 / 750 * 100vw);
  }
  .sec11__features {
    gap: calc(32 / 750 * 100vw);
    margin-bottom: calc(30 / 750 * 100vw);
  }
  .sec11__features__box {
    width: calc(120 / 750 * 100vw);
    height: calc(60 / 750 * 100vw);
    font-size: calc(30 / 750 * 100vw);
    border-width: calc(1 / 750 * 100vw);
    padding: calc(4 / 750 * 100vw) calc(24 / 750 * 100vw) calc(6 / 750 * 100vw);
  }
  .sec11__features__box::after {
    height: calc(20 / 750 * 100vw);
    width: 2px;
    transform: translate(-50%, 80%);
  }
  .sec11__tagline {
    font-size: calc(40 / 750 * 100vw);
    margin-bottom: calc(20 / 750 * 100vw);
  }
  .sec11__shop {
    padding: calc(36 / 750 * 100vw) calc(20 / 750 * 100vw) calc(44 / 750 * 100vw);
    max-width: calc(650 / 750 * 100vw);
    box-shadow: 0px 0px 16px 0px rgba(21, 21, 21, 0.15);
    background: #fff url("../img/sp/shop_bg.webp") center calc(120 / 750 * 100vw)/95% no-repeat;
  }
  .sec11__shop__title {
    font-size: calc(40 / 750 * 100vw);
    margin-bottom: calc(30 / 750 * 100vw);
  }
  .sec11__shop__logo {
    width: calc(518 / 750 * 100vw);
  }
}
.sec12 {
  position: relative;
  width: 100%;
  overflow: hidden;
  background-color: #eaeef2;
  padding: min(calc(80 / 1080 * 100vw), 80px) 0;
}
.sec12__main {
  position: relative;
}
.sec12__container {
  width: min(calc(1080 / 1080 * 100vw), 1080px);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: min(calc(40 / 1080 * 100vw), 40px);
}
.sec12__title {
  color: #333333;
  font-weight: 600;
  font-family: "Noto Serif JP", serif;
  font-size: min(calc(38 / 1080 * 100vw), 38px);
  line-height: 1.4;
  letter-spacing: 0.08em;
  text-align: center;
}
.sec12__tabs {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: min(calc(16 / 1080 * 100vw), 16px);
  width: 100%;
  margin-bottom: min(calc(20 / 1080 * 100vw), 20px);
}
.sec12__tab {
  color: #1b3b82;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: min(calc(22 / 1080 * 100vw), 22px);
  line-height: 1.6;
  letter-spacing: 0.08em;
  padding: min(calc(4 / 1080 * 100vw), 4px) min(calc(24 / 1080 * 100vw), 24px);
  border: min(calc(0.7 / 1080 * 100vw), 0.7px) solid #1b3b82;
  background-color: #fff;
  cursor: pointer;
  text-align: center;
  text-decoration: none;
  display: inline-block;
}
.sec12__tab:hover {
  background-color: #f5f7fa;
}
.sec12__tab.active {
  background-color: #1b3b82;
  color: #fff;
}
.sec12__shops {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: min(calc(40 / 1080 * 100vw), 40px);
}
.sec12__shop {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #fff;
}
.sec12__shop__header {
  width: 100%;
  padding: min(calc(14 / 1080 * 100vw), 14px) min(calc(28 / 1080 * 100vw), 28px);
  margin-bottom: min(calc(40 / 1080 * 100vw), 40px);
  border-bottom: min(calc(1.44 / 1080 * 100vw), 1.44px) solid #1b3b82;
}
.sec12__shop__title {
  color: #1b3b82;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-size: min(calc(24 / 1080 * 100vw), 24px);
  line-height: 1.6;
  letter-spacing: 0.08em;
  text-align: center;
}
.sec12__shop__content {
  width: 100%;
  display: flex;
  justify-content: center;
  gap: min(calc(40 / 1080 * 100vw), 40px);
  padding: 0 min(calc(80 / 1080 * 100vw), 80px);
  margin-bottom: min(calc(40 / 1080 * 100vw), 40px);
}
.sec12__shop__image {
  width: min(calc(441 / 1080 * 100vw), 441px);
  overflow: hidden;
}
.sec12__shop__image img {
  width: 100%;
}
.sec12__shop__info {
  width: min(calc(439 / 1080 * 100vw), 439px);
  display: flex;
  flex-direction: column;
  gap: min(calc(24 / 1080 * 100vw), 24px);
}
.sec12__shop__info__item {
  display: flex;
  gap: min(calc(16 / 1080 * 100vw), 16px);
}
.sec12__shop__info__label {
  width: min(calc(109 / 1080 * 100vw), 109px);
  height: min(calc(37 / 1080 * 100vw), 37px);
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #eaeef2;
  padding: min(calc(1.44 / 1080 * 100vw), 1.44px) min(calc(14.4 / 1080 * 100vw), 14.4px);
  color: #1b3b82;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  font-size: min(calc(16 / 1080 * 100vw), 16px);
  line-height: 1.8;
  letter-spacing: 0.08em;
}
.sec12__shop__info__text {
  color: #333333;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: min(calc(16 / 1080 * 100vw), 16px);
  line-height: 1.8;
  letter-spacing: 0.08em;
}
.sec12__shop__button {
  margin-top: auto;
  align-self: center;
  width: 100%;
}
.sec12__shop__link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: min(calc(76 / 1080 * 100vw), 76px);
  background: linear-gradient(180deg, #a3095c 0%, #d52665 100%);
  color: #fff;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-size: min(calc(24 / 1080 * 100vw), 24px);
  line-height: 1.6;
  letter-spacing: 0.08em;
  text-decoration: none;
  border-radius: min(calc(2 / 1080 * 100vw), 2px);
  position: relative;
  box-shadow: 0 0 min(calc(28.8 / 1080 * 100vw), 28.8px) rgba(0, 0, 0, 0.2);
}
.sec12__shop__link::after {
  position: absolute;
  right: min(calc(17 / 1080 * 100vw), 17px);
  top: 50%;
  transform: translateY(-50%);
  content: "";
  display: block;
  width: min(calc(37 / 1080 * 100vw), 37px);
  height: min(calc(8 / 1080 * 100vw), 8px);
  background: url("../img/common/btn_arrow.svg") no-repeat center center/contain;
}
.sec12__shop__link:hover {
  opacity: 0.9;
}

@media screen and (max-width: 767px) {
  .sec12 {
    padding: calc(80 / 750 * 100vw) calc(30 / 750 * 100vw);
  }
  .sec12__container {
    width: 100%;
    gap: calc(56 / 750 * 100vw);
  }
  .sec12__title {
    font-size: calc(48 / 750 * 100vw);
    line-height: 1.6;
  }
  .sec12__tabs {
    flex-wrap: wrap;
    gap: calc(20 / 750 * 100vw);
    margin-bottom: 0;
  }
  .sec12__tab {
    font-size: calc(32 / 750 * 100vw);
    padding: calc(6 / 750 * 100vw) calc(36 / 750 * 100vw) calc(8 / 750 * 100vw);
    border-width: calc(1 / 750 * 100vw);
  }
  .sec12__shops {
    gap: calc(56 / 750 * 100vw);
  }
  .sec12__shop__header {
    padding: calc(20 / 750 * 100vw) calc(40 / 750 * 100vw);
    margin-bottom: calc(32 / 750 * 100vw);
  }
  .sec12__shop__title {
    font-size: calc(36 / 750 * 100vw);
  }
  .sec12__shop__content {
    flex-direction: column;
    align-items: center;
    gap: calc(32 / 750 * 100vw);
    padding: 0 calc(40 / 750 * 100vw);
    margin-bottom: calc(40 / 750 * 100vw);
  }
  .sec12__shop__image {
    width: 100%;
    height: auto;
    border-top-width: calc(2 / 750 * 100vw);
  }
  .sec12__shop__info {
    width: 100%;
    gap: calc(24 / 750 * 100vw);
  }
  .sec12__shop__info__item {
    gap: calc(24 / 750 * 100vw);
    align-items: flex-start;
  }
  .sec12__shop__info__label {
    width: calc(151 / 750 * 100vw);
    height: auto;
    padding: calc(2 / 750 * 100vw) 0;
    text-align: center;
    font-size: calc(26 / 750 * 100vw);
  }
  .sec12__shop__info__text {
    font-size: calc(26 / 750 * 100vw);
    width: calc(100% - calc(171 / 750 * 100vw));
    letter-spacing: 0.04em;
  }
  .sec12__shop__button {
    margin-top: calc(16 / 750 * 100vw);
    width: 100%;
  }
  .sec12__shop__link {
    width: calc(610 / 750 * 100vw);
    height: auto;
    padding: calc(24 / 750 * 100vw) calc(40 / 750 * 100vw);
    font-size: calc(36 / 750 * 100vw);
    box-shadow: 0 0 calc(40 / 750 * 100vw) rgba(0, 0, 0, 0.2);
  }
  .sec12__shop__link::after {
    right: calc(40 / 750 * 100vw);
    width: calc(50 / 750 * 100vw);
    height: calc(10 / 750 * 100vw);
  }
}
/*# sourceMappingURL=fv.css.map */
