@charset "utf-8";
/* ダブルタップによるズームを禁止 */
html {
  touch-action: manipulation;
}

.pc {
  display: none !important;
}

.sp {
  display: block !important;
}


h1,
h2,
h3,
h4,
h5,
p,
li {
  line-height: 1.48;
  color: #3d3d3d;
}

*,
*:before,
*:after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

h2 {
  font-size: 8vw;
  line-height: 1.5;
  text-align: center;
  margin-bottom: 8.53333vw;
  font-weight: 700;
}

p {
  font-size: 4.27vw;
  font-weight: 300;
}

a {
  color: #CC0000;
  text-decoration: none;
}

a:hover {
  opacity: 0.8;
}

a.link {
  text-decoration: underline;
  font-weight: 600;
  position: relative;
}

a.link {
  text-decoration: underline;
}

a.link.icon.icon_type4 {
  font-weight: 400;
  padding-right: 4.8vw;
}

a.link.icon::after {
  content: '';
  background-size: 100%;
  background-repeat: no-repeat;
  width: 0.92307692307em;
  height: 0.92307692307em;
  position: absolute;
  font-size: inherit;
  margin-left: 0.25em;
  bottom: 0.21428571428em;
  display: inline;
}

a.link.icon.icon_type1::after {
  background-image: url(../images/link_type1.png);
}

img {
  width: 100%;
  height: auto;
}

ul.note li,
ol.note li,
ul.dot li,
ol.num li {
  margin-top: 1.06666vw;
  font-weight: 300;
}

span.bold {
  font-weight: 600;
}

/* ul.note */
ul.note li {
  color: #707070;
  font-size: 2.93333vw;
  text-indent: -1.5em;
  padding-left: 1.5em;
}

ul.note li::before {
  content: '※';
  font-size: inherit;
  margin-right: 0.5em;
}

/* ol.note */
ol.note {
  counter-reset: number 0;
}

ol.note li {
  color: #707070;
  font-size: 2.93333vw;
  text-indent: -2em;
  padding-left: 2em;
}

ol.note li::before {
  counter-increment: number 1;
  content: '※' counter(number);
  font-size: inherit;
  margin-right: 0.5em;
}

/* ul.note center */
ul.note.center {
  width: fit-content;
  margin: 0 auto;
}

ul.note.center li {
  text-indent: 0;
  padding: 0;
}

/* ul.dot */
ul.dot li {
  color: #707070;
  font-size: 2.93333vw;
  text-indent: -1.5em;
  padding-left: 1.5em;
}

ul.dot>li::before {
  content: '・';
  font-size: inherit;
  margin-right: 0.5em;
}

/* ol.num */
ol.num {
  counter-reset: number 0;
}

ol.num li {
  color: #707070;
  font-size: 2.93333vw;
  text-indent: -1.5em;
  padding-left: 1.5em;
}

ol.num li::before {
  counter-increment: number 1;
  content: counter(number)'.';
  font-size: inherit;
  margin-right: 0.5em;
}

/* .btn */
.btn {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 70.13333vw;
  height: 14.93333vw;
  border-radius: 9999px;
  background-color: #FCFCFC;
  position: relative;
  margin: auto;
}

.btn_text {
  font-size: 4.26666vw;
  color: #4D4639;
  text-align: center !important;
  line-height: 1.32;
  font-weight: 600;
}

.btn::after {
  content: '';
  background-position: center;
  background-size: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 4vw;
  margin: auto 0;
}

/* .btn.btn_type1 */
.btn.btn_type1 {
  box-sizing: border-box;
  background: #FCFCFC;
  border: 2px solid #E0DFDD;
  box-shadow: 0px 1vw 0px 0px #B3B3B3;
}

/* .btn.btn_type2 */
.btn.btn_type2 {
  background-color: #CC0000;
}

.btn.btn_type2 .btn_text {
  color: #ffffff;
}

/* .btn.btn_type3 */
.btn_type3 {
  background: linear-gradient(180deg, #FACB32 50%, #F7BD00 50%);
  border: 2px solid #FCF16E;
  box-shadow: 0px 1vw 0px 0px #CB9700;
  }


/* .btn.icon_type1 */
a.link.icon.icon_type1 {
  padding-right: 4.8vw;
  padding-top: 1.6vw;
  font-weight: 300;
}

.btn.icon_type1::after {
  background-image: url(../images/link_type2.png);
  width: 3.2vw;
  height: 3.2vw;
}

.btn.icon_type1 .btn_text {
  margin-right: 4.26666vw;
}

/* .btn.icon_type2 */
.btn.icon_type2::after {
  background-image: url(../images/link_type2.png);
  width: 3.2vw;
  height: 3.2vw;
}

.btn.icon_type2 .btn_text {
  margin-right: 3.2vw;
}

/* .btn.icon_type3 */
.btn.icon_type3::after {
  background-image: url(../images/link_type3.png);
  width: 3.2vw;
  height: 3.2vw;
}

.btn.icon_type3 .btn_text {
  margin-right: 3.2vw;
}

/* .btn.icon_type4 */

a.link.icon.icon_type4::after {
  background-image: url(../images/link_type4.png);
  display: inline-block;
  bottom: 0;
}

/* .btn.icon_type5 */
.btn.icon_type5::after {
  background-image: url(../images/link_type5.png);
  width: 4.8vw;
  height: 4.8vw;
}

.btn.icon_type5 .btn_text {
  margin-right: 3.2vw;
}

/* .btn.icon_type6 */
.icon_type6::after {
  background-image: url(../images/icon_type6.png);
  width: 4.266vw;
  height: 4.266vw;
}

/* .bubble */
.bubble_wrap {
  text-align: center;
  position: relative;
  padding-bottom: 2.13vw;
}

.lead_area .bubble_wrap {
  padding-bottom: 3.2vw;
}
.bubble {
  display: inline-block;
  background-color: #0054AD;
  border-radius: 1.07vw;
}

.bubble_text {
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: bold;
  height: 8vw;
  color: #ffffff;
  font-size: 3.733vw;
  padding-left: 2.93vw;
}

.bubble::after {
  content: '';
  background-image: url(../images/tail.svg);
  background-size: contain;
  background-repeat: no-repeat;
  width: 3.73333vw;
  height: 3.2vw;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  margin: 0 auto;
}

/* .accordion */
.accordion {
  border: 0.2666666vw solid #E0DEDC;
  background-color: #FCFCFC;
  border-radius: 2.133333vw;
}

.accordion_title {
  cursor: pointer;
  position: relative;
}

.accordion_title * {
  font-size: 4.27vw;
}

.accordion_title::before,
.accordion_title::after {
  content: '';
  position: absolute;
  border-radius: 9999px;
  background-color: #2B2B2B;
  width: 2.66666vw;
  height: 0.53333vw;
  top: 0;
  bottom: 0;
  right: 5.86666vw;
  margin: auto 0;
  transition: 0.25s;
}

.accordion_title.active::after {
  transform: rotate(90deg);
}

.accordion_title::after {
  transform: none;
}

/* .slash */
.slash_wrap {
  text-align: center;
}

.slash_wrap .slash {
  position: relative;
  display: inline-block;
}

.slash_wrap .slash::before,
.slash_wrap .slash::after {
  content: '';
  background-color: #0054AD;
  width: 0.5vw;
  height: 5.33333vw;
  border-radius: 9999px;
  position: absolute;
  bottom: 0;
}

.chart_area_wrap .slash_wrap .slash::before,
.chart_area_wrap .slash_wrap .slash::after {
  background-color: #2B2B2B;
}

.simulator_area_inner02 .slash_wrap {
  display: none;
}
.simulator_area_inner02 .slash_wrap .slash::before,
.simulator_area_inner02 .slash_wrap .slash::after {
  background-color: #3d3d3d;
}

.slash_wrap .slash::before {
  transform: rotate(-20deg);
  left: -0.6em;
}

.slash_wrap .slash::after {
  transform: rotate(20deg);
  right: -0.6em;
}

.slash_wrap .slash p {
  font-size: 3.73333vw;
  font-weight: 600;
}

/* border */
.border {
  background-image: linear-gradient(to right, #9E9E9E, #9E9E9E 0.533333vw, transparent 0);
  background-size: 1.6vw 0.333333vw;
  background-repeat: repeat-x;
  background-position: right top;
  text-align: left;
}

.about .border+.border {
  margin-top: 8.53vw;
  padding-top: 8.53vw;
}


/* .header */
.header {
  background-color: #ffffff;
}

.header .inner {
  max-width: 1280px;
  padding: 8px 0;
  box-sizing: border-box;
  text-align: center;
  margin: 0 auto;
}

.header a {
  display: inline-block;
}

.header img {
  width: 74.667vw;
}


/* .fv */

.fv {
  background-color: #E0ECFF;
}


.fv .btn_area img {
  display: block;
  margin: 0 auto;
  width: 92vw;
}

.fv .btn_area ul {
  margin: 2.133vw auto;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.fv .btn_area ul li {
  width: 45.867vw;
}

.fv .btn_area .btn {
  width: 100%;
  height: 14.933vw;
  margin: 0 auto;
}

.fv ol.note {
  margin-top: 4.266vw;
  /* ※1から始める処理 */
  counter-reset: number 0;
}

.fv .inner .notice{
  background: #FFFFFF;
  border-left: solid 3px #E06666;
  padding: 2.3% 2.5% 3.5%;
  line-height: 1.4;
  margin: 4.6% 0 3.5%;
}

.fv .inner .notice p{
  font-size: 3.2vw;
}

.fv .inner .notice p:first-of-type{
  font-weight: bold;
  display: flex;
  align-items: center;
  padding-bottom: 2.5%;
}

.fv .inner .notice p:first-of-type::before{
  width: 18px;
  height: 18px;
  display: inline-block;
  content: "";
  background: url(../images/info-icon-red.svg) no-repeat;
  background-size: cover;
  background-position: center;
}

.news {
  max-width: 1020px;
  display: block;
  margin: 0 auto 4.27vw;
}

.news p {
  font-size: 3.733vw;
  font-weight: 500;
  color: #3d3d3d;
  line-height: 1.48;
  border: solid 0.266666vw #3d3d3d;
  padding: 4vw;
  text-align: left;
}
.news p span {
  font-size: 4.27vw;
  font-weight: 600;
  display: block;
  margin-bottom: 8px;
}

.news a.link {
  color: #CC0000;
  text-decoration: underline;
  font-weight: 600;
}

/* .text_info */
.text_info {
  background-color: #F5E1A1;
}

.text_info .inner {
  padding: 4.26666vw 0;
}

.text_info .inner>p {
  width: 88vw;
  margin: auto;
  text-align: center;
  font-size: 2.93333vw;
}

.text_info .btn_wrap {
  margin: 0 auto;
  width: 93.86666vw;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.text_info .btn {
  width: 45.86666vw;
  height: 12.8vw;
}

.text_info .btn_text {
  font-size: 3.73333vw;
}

/* anchor_simulation */
.anchor_simulation_area {
  padding: 9.6vw 0 4.267vw;
}
.anchor_simulation {
  display: flex;
  width: 100%;
  max-width: 91.467vw;
  margin: auto;
  padding: 6.4vw 4.267vw 5.333vw;
  border-width: 0.533vw;
  border: 0.533vw solid #E06666;
  background: #FCF2F2;
  border-radius: 2.133vw;
  align-items: center;
  position: relative;
  justify-content: center;
} 

.anchor_simulation .btn_text {
  font-size: 4.8vw;
  margin-left: 10.667vw;
}

.anchor_simulation .bubble_wrap {
  position: absolute;
  top: -4.8vw;
  left: 50%;
  transform: translateX(-50%);
  width: max-content;
}

.anchor_simulation::before,
.anchor_simulation::after {
  content: '';
  background-position: center;
  background-size: 100%;
  background-repeat: no-repeat;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 4vw;
  margin: auto 0;
  background-image: url(../images/btn_arrow.png);
  width: 4.26666vw;
  height: 4.26666vw;
}

.anchor_simulation::before {
  background-image: url(../images/icon_simulation.png);
  width: 15.467vw;
  height: 15.467vw;
  left: 4.267vw;
}

.anchor_simulation::after {
  background-image: url(../images/icon_arrow_under.png);
  width: 4.8vw;
  height: 4.8vw;
  right: 4.267vw;
}

/* about */
.about {
  background-color: #F7F5F5;
  padding: 15.47vw 0 64px;
}

.about h2 span {
  font-size: 4.26666vw;
  line-height: 1.48;
  color: #CC0000;
  display: block;
}

.about .condition-list {
  display: flex;
  flex-direction: column;
  background-color: #FCF5E0;
  border: 0.533vw solid #FACB32;
  border-radius: 2.13vw;
  padding: 3.2vw 4.267vw;
  margin: 4.266vw auto;
  position: relative;
}

.about .condition-list:last-of-type::after {
  content: '';
  background-position: center;
  background-size: 100%;
  display: flex;
  position: absolute;
  top: -30%;
  left: 50%;
  transform: translateX(-50%);
  margin: auto;
  background-image: url(../images/icon-plus-circle-yellow.png);
  width: 8vw;
  height: 8vw;
}

.about .condition-list li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 2.133vw 0;
  background-image: linear-gradient(to left, #9E9E9E, #9E9E9E 0.533333vw, transparent 0);
  background-size: 1.6vw 0.533333vw;
  background-repeat: repeat-x;
  background-position: right bottom;
  text-align: left;
}

.about .condition-list li:first-of-type {
  padding-top: 0;
}

.about .condition-list li:last-of-type {
  background: none;
  padding-bottom: 0;
}

.about .condition-list-inner {
  display: flex;
  align-items: center;
}

.about .condition-list-inner img {
  width: 10.667vw;
  margin-right: 2.133vw;
}

.about .condition-list-inner p {
  font-size: 4.267vw;
  font-weight: 600;
}

.about .condition-list-inner span {
  font-size: 3.2vw;
  vertical-align: text-top;
}

.about .condition-list li>img {
  width: 15.467vw;
}

.about .arrow {
  display: block;
  width: 5.333vw;
  margin: 4.266vw auto;
}

.about .image_compare {
  margin-top: 2.133vw;
}

.about .inner>.btn {
  margin: 4.266vw auto;
}

.about .inner>ul.note {
  margin-top: 0;
}

.about .inner>.note .link {
  color: #CC0000;
}

.about h3 {
  text-align: center;
  font-weight: 600;
  font-size: 6.4vw;
}

/* .grant-accordion */
.grant-accordion {
  margin-top: 16px;
}

.grant-accordion .accordion_title {
  padding: 4.26666vw 0 4.26666vw 4.26666vw;
  text-align: left;
}

.grant-accordion .accordion_title * {
  font-weight: 600;
}

.grant-accordion .accordion_content {
  padding: 0 4.26666vw 4.26666vw;
}

.grant-accordion .accordion_content p {
  font-size: 3.2vw;
}

.grant-accordion .accordion_content dl dt h4 {
  font-size: 3.2vw;
  font-weight: 600;
  margin-top: 5.33333vw;
}

.grant-accordion .accordion_content .box {
  margin-top: 5.33333vw;
  background-color: #F7F5F3;
  border-radius: 3.2vw;
  padding: 6.4vw 4vw;
}

.grant-accordion .accordion_content .box .lead {
  width: fit-content;
  font-size: 4.26666vw;
  line-height: 1;
  border-radius: 2666.4vw;
  color: #ffffff;
  background-color: #E06666;
  display: inline-block;
  margin-bottom: 4.26666vw;
  padding: 1.06666vw 4.8vw;
}

.grant-accordion .accordion_content .box .down_type2 {
  width: 3.2vw;
  margin: 2.133333vw auto;
  display: block;
}

.grant-accordion .accordion_content .box img {
  margin-top: 4.26666vw;
}

.grant-accordion+a {
  margin-top: 10.67vw;
}

/* nisa-campaign */
.nisa-campaign {
  display: flex;
  flex-direction: column;
  background-color: #FCF5E0;
  border-radius: 2.13vw;
  margin: 0 auto 0;
  overflow: hidden;
}

.nisa-campaign-laed.bubble_wrap {
  padding-bottom: 4.8vw;
}

.nisa-campaign-laed .bubble {
  width: 100%;
  padding: 3.2vw 7.467vw;
  border-radius: 2.133vw;
  background: #FACB32;
}

.nisa-campaign-laed .bubble::after {
  background-image: url(../images/tail_yellow.png);
  width: 5.333vw;
  height: 4.8vw;
}

.nisa-campaign-laed .bubble_text {
  font-size: 5.333vw;
  font-weight: bold;
  height: min-content;
  color: #3D3D3D;
}

.nisa-campaign-inner {
  padding: 6.4vw 4.267vw 7.467vw;
}

.nisa-campaign-inner .bubble_wrap {
  margin-bottom: 2.667vw;
}

.nisa-campaign-text {
  margin: 5.33vw auto 2.133vw;
  padding-top: 3.733vw;
}

.nisa-campaign .btn_wrap {
  width: 100%;
  padding: 7.467vw 4.267vw 4.267vw;
  border-radius: 2.133vw;
  background: #FEFDF7;
  margin: auto;
  margin-top: 14.933vw;
  position: relative;
}

.nisa-campaign .btn_wrap .bubble_wrap {
  margin-top: -11.733vw;
  margin-bottom: 3.2vw;
}

.nisa-campaign .btn_wrap .bubble_wrap .bubble {
  padding-top: 0.533vw;
  padding-bottom: 0.533vw;
}

.nisa-campaign .btn_wrap .bubble_wrap .bubble_text::before {
  content: '';
  background-image: url(../images/icon_bulb.png);
  background-size: 100%;
  background-repeat: no-repeat;
  font-size: inherit;
  display: inline-block;
  width: 4.267vw;
  height: 4.267vw;
}

.nisa-campaign .bnr_area {
  display: flex;
  flex-direction: column-reverse;
  padding: 5.333vw 4.267vw 17.066vw;
  border-radius: 2.13vw;
  background: #FFFFFF;
  position: relative;
}

.nisa-campaign .bnr_area .btn {
  width: 37.867vw;
  height: 8.533vw;
  background: #F7F5F3;
  color: #3D3D3D;
  position: absolute;
  margin-top: 2.133vw;
  border-radius: 5.333vw;
  padding: 1.067vw 5.333vw;
  bottom: 7.333vw;
  left: 50%;
  transform: translateX(-50%);
}

.nisa-campaign .bnr_area img {
  margin-bottom: 4.267vw;
}

.nisa-campaign .bnr_area p {
  margin-bottom: 3.2vw;
  font-size: 4.267vw;
  font-weight: 600;
}

.step .inner>.btn.btn_type1 {
  width: 100%;
  margin-top: 4.267vw;
}

.step .inner>ol.note {
  margin-top: 4.27vw;
}

.step .inner>ul.note {
  margin-top: 0;
}

/* dcard */
.dcard {
  background: #F7F5F5;
  padding: 9.87vw 0 5.33vw;
}

/* summary */
.summary h3 {
  font-size: 8.533vw;
  text-align: center;
  margin-bottom: 8.533vw;
}

.summary .border>h3 {
  font-size: 6.4vw;
}

.summary .border {
  padding-top: 8.533vw;
}

.summary h3 span {
  color: #CC0000;
}

.summary-img-wrapper {
  margin-bottom: 6.4vw;
}

.summary>p {
  margin-bottom: 4.266vw;
}

.tab_label {
  display: flex;
  align-items: flex-end;
  margin-top: 8.53333vw;
}

.tab_label li {
  background-color: #E0DFDD;
  border-radius: 2.13vw 2.13vw 0 0;
  padding: 3.13vw 0;
  width: 50%;
  font-size: 3.2vw;
  font-weight: 600;
  text-align: center;
  cursor: pointer;
}

.tab_label .tab_label-platinum._active {
  background-color: #46433D;
  color: #FFF;
  padding: 5.2vw 0;
}

.tab_label .tab_label-gold {
  padding: 0.8vw 0;
}

.tab_label .tab_label-gold._active {
  background-color: #BE980F;
  color: #FFF;
  padding: 2.8vw 0;
}

.tab_inner>div {
  display: none;
  padding: 8.53vw 4.266vw;
  background-color: #FFF;
}

.tab_inner>div.tab_platinum {
  border: 0.53vw solid #46433D;
  position: relative;
}

.tab_inner>div.tab_gold {
  position: relative;
  border: 0.53vw solid #BE980F;
}

.tab_inner>div._active {
  display: block;
}

.tab_inner h4 {
  font-size: 12px;
  font-weight: 600;
  text-align: left;
}

.tab_inner .h4_outer>h4 {
  font-size: 4.27vw;
  text-align: center;
}

.tab_inner .h4_outer+img {
  display: block;
  width: 41.87vw;
  margin: 14.933vw auto 2.133vw;
}

.tab_inner p {
  text-align: center;
  font-weight: 400;
}

.tab_inner .price_area span {
  font-size: 3.2vw;
}

.tab_inner .price_area span.price_number {
  font-size: 5.333vw;
  margin-left: 1.066vw;
}

/* SPのカードネームの表示箇所調整 */
.tab_inner .price_area.sp .card_name {
  position: absolute;
  margin: 0;
  top: 19.2vw;
  left: 50%;
  transform: translateX(-50%);
}

.tab_inner .tab_gold .price_area.sp .card_name {
  top: 19.2vw;
}

.tab_inner .tab_platinum .price_area.sp .card_name {
  top: 25.6vw;
}

.tab_inner>div>p.lead {
  margin: 4.266vw auto 8.5333vw;
  font-weight: 300;
}

.tab_inner .goldu_area_wrap {
  padding-top: 5.333vw;
}

.tab_inner .goldu_area {
  position: relative;
  margin-bottom: 2.133vw;
  background: #FDFAEF;
  padding: 8.533vw 3.733vw 6.4vw;
  border-radius: 2.133vw;
}

.tab_inner .goldu_area .card_image_area.sp .card_name {
  position: absolute;
  margin: 0;
  top: 19.2vw;
  left: 50%;
  transform: translateX(-50%);
}

.tab_inner .goldu_area .card_image_wrap {
  position: relative;
}

.tab_inner .goldu_area .card_image_wrap::before {
  content: '';
  background-position: center;
  background-size: 100%;
  background-repeat: no-repeat;
  position: absolute;
  top: -126%;
  left: 50%;
  transform: translateX(-50%);
  margin: auto;
  background-image: url(../images/recommend-bubble.png);
  width: 30.93vw;
  height: 10.66vw;
}

.tab_inner .goldu_area .card_image {
  display: block;
  width: 42.667vw;
  margin: 14.933vw auto 2.133vw;
}

.tab_inner .goldu_area .price_area {
  margin: 2.133vw auto 4.266vw;
}

.tab_inner .goldu_area .price_area .price_text {
  color: #B07E04;
}

.tab_inner .goldu_area .price_area span {
  font-size: 4.267vw;
}

.tab_inner .goldu_area .price_area .price_number {
  font-size: 6.933vw;
  line-height: 1;
}

.tab_inner .goldu_area .goldu_text {
  font-weight: 300;
}

.summary p.table_title {
  font-size: 4.267vw;
  font-weight: bold;
  margin-bottom: 3.2vw;
  margin-top: 8.533vw;
}

.summary p.caption {
  font-size: 2.933vw;
  text-align: center;
}

.summary p.caption span {
  color: #CC0000;
}

.summary .image-container {
  width: 100%;
  overflow-x: auto;
  white-space: nowrap;
  margin: 1.066vw auto 4.266vw;
}

.summary .tab_inner .summary-accordion {
  margin-top: 5.333vw;
}

.scroll-image {
  display: inline-block;
  width: 120vw;
}

.tab_inner div>.link {
  display: block;
  font-size: 3.2vw;
  margin: 4.266vw auto;
  line-height: 1.3;
  font-weight: 400;
}

.bg_yellow {
  position: relative;
  background-color: #FCF5E0;
  padding: 6.4vw 4.67vw;
  border-radius: 2.13vw;
  z-index: 0;
}

.bg_yellow::before {
  content: '';
  position: absolute;
  background-image: url(../images/bg_yellow.png);
  background-size: contain;
  background-repeat: no-repeat;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: -1;
}

.bg_yellow h5 {
  text-align: center;
  font-weight: 600;
  color: #CC0000;
  font-size: 4.27vw;
}

.bg_yellow .bubble_wrap {
  margin: 3.73vw auto 3.2vw;
}


.bg_yellow .cp_period {
  width: 100%;
  font-weight: 600;
  color: #E06666;
  text-align: center;
  margin-top: 4.27vw;
}

.bg_yellow .cp_period>span {
  font-size: 3.2vw;
}

.bg_yellow .cp_period+.note {
  margin-top: 2.13vw;
}

.bg_gray {
  background-color: #F7F5F5;
  border-radius: 2.13vw;
  padding: 6.4vw 4.266vw;
  margin-top: 8.53vw;
}

.bg_gray .slash_wrap {
  margin-top: -8.8vw;
}

.bg_gray h5 {
  text-align: center;
  font-weight: 600;
  font-size: 4.27vw;
}

.bg_gray h5+img {
  margin: 4.27vw auto 0;
}

.bg_gray .lead {
  background-color: #FFF;
  padding: 3.06666vw 0;
  border-radius: 2666.4vw;
  font-size: 4.266vw;
  font-weight: 600;
  text-align: center;
  margin-top: 4.27vw;
}

.bg_gray .lead span {
  color: #CC0000;
}

.bg_gray img.dots {
  width: 0.8vw;
  height: 2.667vw;
  margin: 2.133333vw auto;
  display: block;
}


.bg_gray>div {
  width: 100%;
  margin: 4.266vw auto;
}

.bg_gray>div a.link.icon {
  padding-right: 0;
}

.bg_gray p {
  text-align: center;
}

.bg_gray p span {
  font-weight: 600;
}

.bg_gray img:nth-of-type(3) {
  margin-top: 4.27vw;
}

.bg_gray .note:first-of-type {
  margin-top: 4.27vw;
}

.tab_inner .tab_gold .btn_area {
  margin: 8.533vw auto;
}

.tab_inner .tab_platinum .btn_area {
  margin: 8.533vw auto 0;
}

.tab_inner .btn_area .slash_wrap {
  margin: 8.53vw auto 2.13vw;
}

.tab_inner .btn_area p {
  font-weight: bold;
}

/* .summary-accordion */
.summary-accordion {
  color: #3d3d3d;
  margin-top: 8.53333vw;
}

.summary-accordion p.table_title {
  font-size: 3.2vw;
  margin-top: 0;
  font-weight: bold;
  text-align: center;
}

.summary-accordion .accordion_title {
  padding: 4.26666vw 0 4.26666vw 4.26666vw;
  text-align: left;
}

.summary-accordion .accordion_title h5 {
  font-weight: 600;
  display: inline-block;
  width: 58.667vw;
}

.summary-accordion .accordion_content {
  padding: 0 4.26666vw 4.53333vw;
}

.summary-accordion .accordion_content ol.note {
  margin-bottom: 5.333vw;
}

.summary-accordion img {
  width: 54.67vw;
  margin: 4vw auto 2.133333vw;
  display: block;
}

.summary-accordion img.scroll-image {
  width: 120vw;
}

.summary-accordion img.img_goldtab_card {
  width: 64vw;
  margin-bottom: 3.2vw;
}

.summary-accordion p {
  font-size: 3.73vw;
  text-align: left;
  font-weight: 400;
}

.summary-accordion p span {
  color: #CC0000;
  font-weight: 600;
}

.summary-accordion .btn {
  width: 65.87vw;
  margin: 4.26666vw auto 0;
}


/* .return-accordion */

.return-accordion .accordion {
  margin-top: 0;
}

.return-accordion .accordion_title {
  padding: 4.26666vw 0 4.26666vw 4.26666vw;
  text-align: left;
}

.return-accordion .accordion_title h5 {
  font-weight: 600;
}

.return-accordion .accordion_content {
  padding: 0 4.26666vw 4.53333vw;
}

.return-accordion ._scroll {
  overflow-y: scroll;
}

.return-accordion ._scroll img {
  width: 118.47vw;
}

.return-accordion .list_wrap {
  margin-top: 4.27vw;
}

.about-point{
  margin-top: 8.53vw;
}

.about-point img {
  display: block;
  width: 77.6vw;
  margin: 0 auto;
}

.about-point img.bottom{
  width: 100%;
  margin-bottom: 7.467vw;
}

.about-point p.-caution{
  font-size: 2.93vw;
  color: #707070;
  text-align: left;
  margin: 3.2vw auto;
  text-indent: -1em;
  padding-left: 1em;
  width: 77.6vw;
}

.about-point a {
  margin-top: 5.07vw;
}

.about-point a .btn_text {
  font-weight: bold;
}

.about-point ul.note {
  text-align: center;
}

/* merit */
.merit h3 {
  margin-top: 10.67vw;
}

.merit-list {
  margin-bottom: 8.533vw;
}

.merit-list li {
  display: flex;
  justify-content: space-between;
  background-color: #ffffff;
  border-radius: 2.13vw;
  padding: 4.27vw;
  margin-top: 4.27vw;
}

.merit-list li div p {
  font-weight: 600;
}

.merit-list li div img {
  width: 16vw;
}

.merit-list li>img {
  width: 25.6vw;
}

.merit-list+img {
  margin-top: 10.67vw;
}

/* simulator_area */
section.dcard .inner.simulator_header_inner {
  padding: 0;
}
section.dcard .inner.simulator_area_inner {
  padding: 0 16px;
}
.simulator_area {
  text-align: center;
  padding-bottom: 0;
}
.simulator_area a.link {
  font-weight: 400;
}
.simulator_area.title_wrap {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top;
  width: 100%;
  height: 35.467vw;
  margin: auto;
  margin-bottom: 3.2vw;
}

.simulator_area.title_wrap .bubble_wrap {
  display: flex;
  justify-content: center;
  flex-direction: column;
}

.simulator_area.title_wrap .bubble {
  width: 55.47vw;
  margin: 0 auto;
}
.simulator_area.title_wrap .bubble_text {
  font-size: 3.73vw;
  font-weight: 600;
  height: auto;
  padding: 5.8px 5px 4.9px 11px;
}
.simulator_area.title_wrap .triangle {
  background: #0054AD;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  width: 3.2vw;
  height: 2.4vw;
  margin: 0 auto;
}
.simulator_area.title_wrap h2 {
  font-size: 8.53vw;
  line-height: 1.25;
}
.simulator_area button {
  cursor: pointer;
  color: #3D3D3D;
  text-decoration: none;
}
.simulator_area .text-red {
  color: #cc0000;
  font-weight: bolder;
}

.simulator_area_inner01 {
  background: #ffffff;
  margin: auto;
  border-radius: 0.53vw;
  padding: 8.533vw 4.267vw 9.6vw;
}

.chart-container {
  width: 100%;
  margin-top: 5.333vw;
  display: none;
  position: relative;
}
#addBarsButton {
  display: none;
  font-weight: bold;
  width: 100%;
  font-size: 4.267vw;
}
#backYourSettingButton {
  display: none;
  font-weight: bold;
  justify-content: center;
  width: 100%;
  font-size: 4.267vw;
}
#amountInput::-webkit-inner-spin-button,
#amountInput::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
  -moz-appearance: textfield;
}
#displayGraphDescription {
  display: none;
}
/* グラフ生成後に表示するコンテンツ */
.graph_content {
  display: none;
}
/* 数字入力項目 */
.simulator_area .input-group p {
  font-size: 5.333vw;
  font-weight: bold;
  line-height: 1.7;
}
.simulator_area .input-group p .text-red {
  font-weight: bold;
}
.simulator_area .input-group p sup {
  font-size: 3.2vw;
}
.simulator_input {
  width: 17.067vw;
  height: 10.933vw;
  border-radius: 1.067vw;
  font-size: 7.467vw;
  border: 0.533vw solid #F0EEEC;
  font-weight: bold;
  vertical-align: text-bottom;
  color: #d0d0d0;
  text-align: center;
}
.simulator_input::placeholder {
    color: #d0d0d0;
  }
.simulator_input.active {
  color: black;
}
.simulator_input:focus {
    outline: solid 0.533vw #facb32;
}
.simulator_area .input-group p.text-sm {
  font-size: 2.933vw;
  line-height: 1;
}
/* スライダー */
.simulator_slider {
  appearance: none;
  position: relative;
  width: 57.333vw;
  height: 1.333vw;
  border-radius: 2666.4vw;
  background: linear-gradient(90deg, #facb32 44.4444%, #e6e6e6 44.4444%);
  cursor: pointer;
  outline: none;
}
.simulator_slider:focus {
  outline: none;
}
.simulator_slider::before,
.simulator_slider::after {
  content: "";
  color: #3d3d3d;
  position: absolute;
  font-weight: bold;
  bottom: -6.4vw;
  font-size: 2.933vw;
}
.simulator_slider::before {
  content: "1万円";
  left: 0;
}
.simulator_slider::after {
  content: "10万円";
  right: 0;
}

/* ツマミ：Chrome, Safari, Edge用 */
.simulator_slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 5.333vw;
  height: 5.333vw;
  border-radius: 2666.4vw;
  background: #facb32;
  box-shadow: none;
}

/* ツマミ：Firefox用 */
.simulator_slider::-moz-range-thumb {
  border: none;
  width: 5.333vw;
  height: 5.333vw;
  border-radius: 2666.4vw;
  background: #facb32;
  box-shadow: none;
}

.simulator_slider_wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 8.533vw;
}
.simulator_minus,
.simulator_plus {
  position: relative;
  width: 16vw;
  height: 16vw;
}
.simulator_minus::after,
.simulator_plus::after {
  content: "";
  background-position: center;
  background-size: 100%;
  position: absolute;
  top: 0.533vw;
  right: 0;
  background-image: url(../images/simulator_minus.png);
  width: 16vw;
  height: 16vw;
}
.simulator_minus::after {
  right: -1.333vw;
}
.simulator_plus::after {
  background-image: url(../images/simulator_plus.png);
  right: 0.267vw;
}
/* カードエリア */
.simulator_area .card_wrap {
  display: flex;
  justify-content: center;
  align-items: baseline;
  margin-bottom: 6.4vw;
  gap: 8px;
}
.simulator_area .card_wrap .card_content {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  background: #f7f5f5;
  position: relative;
  border: 0.267vw solid #f0eeec;
  width: 31.6%;
  height: 34.667vw;
  border-radius: 2.133vw;
  padding-top: 3.2vw;
  padding-bottom: 2.133vw;
}
.simulator_area .card_wrap .card_content>div {
  margin: auto;
}
.simulator_area .card_content p {
  margin: 0 auto;
  font-size: 2.4vw;
  font-weight: bold;
  line-height: 1.4;
}
.simulator_area .card_content p.lead_text {
  margin: auto;
  margin-top: 0.533vw;
  margin-bottom: 2.133vw;
  background: #ffffff;
  width: 17.067vw;
  font-size: 2.667vw;
  border-radius: 13.333vw;
}
.simulator_area .card_content p.card_name {
  min-height: 9.2vw;
  display: flex;
  align-items: center;
}
.simulator_area .card_content img {
  display: block;
  margin: auto;
  width: auto;
  height: 9.947vw;
  margin-bottom: 1.067vw;
}

/* カードボタンselected */
.simulator_area .card_wrap .card_content.selected {
  background: #fcf5e0;
  border: 0.533vw solid #facb32;
}

.simulator_area .card_wrap .card_content.selected::before {
  content: "";
  background-position: center;
  background-size: 100%;
  position: absolute;
  top: -11%;
  left: 50%;
  transform: translateX(-50%);
  background-image: url(../images/icon_card_selected.png);
  width: 5.867vw;
  height: 5.867vw;
}

/* シミュレーション結果について */
.simulator_area .caution_wrap {
  text-align: left;
}
.simulator_area .caution_wrap h5 {
  margin-top: 6.4vw;
  margin-bottom: 2.13vw;
  font-size: 3.2vw;
}

/* シミュレーションエリア外装 */
#simulatorResultArea {
  /* display: none; */
  position: relative;
}

#simulatorResultArea.active::before {
  content: "";
  background-position: center;
  background-size: 100%;
  background-repeat: no-repeat;
  position: absolute;
  top: -8vw;
  left: 50%;
  transform: translateX(-50%);
  background-image: url(../images/dots.png);
  width: 0.8vw;
  height: 3.733vw;
}

#simulatorResultAreaInner {
  display: none;
  background: #f7f7f7;
  position: relative;
  overflow: hidden;
  border: 0.533vw solid #e06666;
  border-radius: 2.133vw;
  padding: 5.333vw 4.267vw;
  margin-top: 16vw;
  position: relative;
  overflow: hidden;
}

#simulatorResultAreaInner.active {
  border: 0.533vw solid #64c482;
  padding: 15.2vw 4.267vw 5.333vw;
}

.simulator_area .lead_text_wrap {
  background-image: url(../images/bg_simulation_result.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: top;
  width: 108%;
  margin: auto;
  margin-left: -4%;
  margin-bottom: 4.267vw;
}

#simulatorResultAreaInner .lead_text_wrap p {
  font-size: 5.2vw;
  font-weight: bold;
  margin-top: 2.133vw;
}

#simulatorResultAreaInner .lead_text_wrap p sup {
    display: none;
    font-size: 2.667vw;
}

#simulatorResultAreaInner .lead_text_wrap .lead_text_white {
  font-size: 3.733vw;
  width: 41.067vw;
  padding: 1.067vw 0;
  border-radius: 16vw;
  margin: auto;
  background: #ffffff;
}

#simulatorResultAreaInner .lead_text_wrap .totalPoint {
  font-size: 8.533vw;
  font-weight: bolder;
}

/* チャート生成ボタン */
#generateChartButton {
  width: 100%;
  font-size: 4.267vw;
  font-weight: bold;
}

/* チャートエリア */
#simulatorResultAreaInner .border {
  padding-top: 6.4vw;
}

.chart_area_wrap {
  width: 100%;
  margin: auto;
  text-align: center;
}

.chart_area_wrap .bubble {
  padding: 1.067vw 3.733vw;
  background-color: #E06666;
}

#simulatorResultAreaInner.active .chart_area_wrap .bubble {
  background-color: #66bb81;
}

.chart_area_wrap .bubble_text {
  font-size: 4.267vw;
  font-weight: normal;
}

.chart_area_wrap .note {
  text-align: left;
  margin: 3.2vw 0;
}

#simulatorResultAreaInner.active .chart_area_wrap .bubble::after {
    background-image: url(../images/tail_green.png);
}

.chart_area_wrap .lead_text {
  font-size: 5.333vw;
  font-weight: bold;
}

.chart_area_wrap .lead_text_sub {
  margin-bottom: 2.133vw;
  font-size: 4.2vw;
  font-weight: bold;
}

.chart_area_wrap .lead_text_sub .text-red {
  font-weight: bold;
}

.chart_area_wrap .totalAmountRounded {
  font-size: 8.533vw;
}

.chart_area_wrap .slash_wrap {
  margin-bottom: 2.133vw;
}

.chart_area_wrap .slash_wrap .slash p {
  font-size: 3.733vw;
}

.chart_area_wrap .slash_wrap .slash::before,
.chart_area_wrap .slash_wrap .slash::after {
  height: 4.267vw;
  bottom: 0.8vw;
}

#simulatorResultAreaInner.active .chart_area_wrap .slash_wrap {
  display: none;
}

#displayGraphDescription {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: bold;
  margin-bottom: 4.267vw;
}

/* 追加要素 */
.simulator_result_extratext {
  display: none;
  background: #66bb81;
  height: 12vw;
  padding: 3.2vw 0;
  position: absolute;
  width: 100%;
  left: 0;
  top: 0;
}

#simulatorResultAreaInner.active .simulator_result_extratext {
  display: block;
}

.simulator_result_extratext p {
  color: #ffffff;
  font-size: 4.267vw;
  font-weight: bold;
}

/* ツールチップ */
.simulator_area .tooltip_area {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: bold;
  margin-bottom: 5.333vw;
}

.simulator_area .tooltip_area > div {
  width: 49.5%;
  box-sizing: border-box;
}

.simulator_area .tooltip_area > div.active {
  background: #FCF2F2;
  border: 0.266vw solid #EB9999;
  border-radius: 2.133vw;
  padding: 2.133vw 1.6vw;
}

.simulator_area .tooltip_area > div:nth-of-type(2).active {
  background: #EDFAF1;
  border: 0.266vw solid #64C482;
}

.simulator_area .tooltip_area > div h4 {
  font-size: 2.933vw;
  margin-bottom: 1.067vw;
  font-weight: bold;
  text-align: center;
}

.simulator_area .tooltip_area > div p {
  display: flex;
  align-items: center;
  text-align: left;
  font-size: 2.133vw;
  font-weight: 400;
}

.simulator_area .tooltip_area > div p::before {
  content: "";
  display: inline-block;
  background: #e06666;
  margin-right: 0.35em;
  width: 2.72vw;
  height: 2.72vw;
}

.simulator_area .tooltip_area #displayTooltip p.principal_text::before {
  background: #e06666;
}

.simulator_area .tooltip_area #displayTooltip p.profit_text::before {
  background: #f5cccc;
}

.simulator_area .tooltip_area #displayExTooltip p.principal_text::before {
  background: #66bb81;
}

.simulator_area .tooltip_area #displayExTooltip p.profit_text::before {
  background: #bcebca;
}

.chart_subtitle {
  position: absolute;
  font-size: 1.819vw;
  bottom: 41.667vw;
  left: 1.067vw;
}

/* プラチナアップグレードエリア */
#platinaUpgradeArea {
  display: none;
  border: 0.533vw solid #46433d;
  border-radius: 2.133vw;
  padding: 9.067vw 4.267vw 5.333vw;
  margin-top: 6.4vw;
  margin-bottom: 6.4vw;
  background: #f0eeec;
  position: relative;
  overflow: hidden;
}

#platinaUpgradeArea .platinaUpgradeArea_haeder {
  width: 100%;
  height: 5.067vw;
  background: #46433d;
  position: absolute;
  left: 0;
  top: 0;
}

#platinaUpgradeArea .platinaUpgradeArea_haeder::before {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 6px solid transparent;
  border-left: 6px solid transparent;
  border-bottom: 8px solid #ffffff;
  border-top: 0;
}

#platinaUpgradeArea .img_area {
  display: flex;
  align-items: center;
  margin: auto;
  width: 100%;
  border-radius: 2.133vw;
  padding: 1.6vw 2.267vw;
  gap: 2.133vw;
  margin-bottom: 0;
  background: #f7f7f7;
}

#platinaUpgradeArea .img_area img {
  width: 16vw;
}

#platinaUpgradeArea .img_area p {
  font-size: 4.8vw;
  font-weight: bold;
}

#platinaUpgradeArea .lead_text {
  display: flex;
  width: 100%;
  margin: auto;
  margin-bottom: 2.133vw;
  padding-top: 3.2vw;
  justify-content: center;
  align-items: center;
  background-image: url(../images/bg_simulation_point.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: top;
}

#platinaUpgradeArea .lead_text .text-sm {
  font-size: 2.6vw;
}

#platinaUpgradeArea .lead_text .text-bg {
  font-size: 4.5vw;
  font-weight: bold;
}

#platinaUpgradeArea .lead_text #platinaPoint {
  font-size: 7.2vw;
}

#platinaUpgradeArea .lead_text_sub {
  width: auto;
  max-width: 100%;
  padding: 1.067vw 0;
  font-size: 4.267vw;
  border-radius: 16vw;
  font-weight: bold;
  margin: auto;
  background: #ffffff;
}

#platinaUpgradeArea .lead_text_sub .text-sm {
  font-size: 3.733vw;
}

#platinaUpgradeArea .lead_text sup {
    font-size: 3vw;
}

/* シミュレーションエリア下部 */
.simulator_area_inner02 {
  margin: auto;
  width: 100%;
  text-align: left;
  margin-top: 5.33vw;
}

.point_description_area {
    display: none;
    background: #ffffff;
    border-radius: 2.133vw;
    padding: 5.333vw 4.267vw 6.4vw;
    margin-bottom: 8.533vw;
    margin-top: 10.67vw;
}

.point_description_area h3 {
    font-size: 6.4vw;
    margin-bottom: 4.267vw;
}

.point_description_area .content_wrap {
    display: flex;
    align-items: center;
    padding-bottom: 2.133vw;
    padding-top: 2.133vw;
}

.point_description_area .content_wrap:not(:nth-of-type(3)) {
  background-image: linear-gradient(to right, #9E9E9E, #9E9E9E 0.533333vw, transparent 0);
  background-size: 1.6vw 0.333333vw;
  background-repeat: repeat-x;
  background-position: right bottom;
  text-align: left;
}

.point_description_area .content_wrap::before {
    content: '';
    background-position: center;
    background-size: 100%;
    background-repeat: no-repeat;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: auto 0;
    background-image: url(../images/simulation_point01.png);
    width: 15.467vw;
    height: 15.467vw;
    margin-right: 3.2vw;
}

.point_description_area .content_wrap:nth-of-type(2):before {
    background-image: url(../images/simulation_point02.png);
}

.point_description_area .content_wrap:nth-of-type(3):before {
    background-image: url(../images/simulation_point03.png);
}

.point_description_area .content_wrap p {
    font-size: 3.733vw;
    font-weight: bold;
}

.point_description_area .content_wrap p sup {
  font-size: 2.667vw;
}

.point_description_area .content_wrap p .text-red {
  font-size: 4.267vw;
  font-weight: bold;
}

.simulator_area_inner02 .btn_area_wrap {
  display: none;
  justify-content: space-between;
  gap: 2.133vw;
  margin-top: 1.067vw;
  margin-bottom: 6.4vw;
}

.simulator_area_inner02 .btn_area_wrap .note li {
  text-indent: -1.5em;
  padding-left: 1.5em;
}

.simulator_area_inner02 .btn_area_wrap .note li::before {
  margin-right: 0;
}

.simulator_area_inner02 .btn_area_wrap .btn {
  width: 44.533vw;
  height: 14.933vw;
}

.simulator_area_inner02 .btn_area:nth-of-type(2) .btn_text {
  font-size: 3.467vw;
}

.simulator_area_inner02 .accordion {
  margin-top: 6.4vw;
  margin-bottom: 6.4vw;
}
.simulator_area_inner02 .accordion_title {
  padding: 4.267vw 0 4.267vw 4.267vw;
}
.simulator_area_inner02 .accordion_content {
  padding: 0 4.267vw 4.267vw;
}

.simulator_area_inner02 .accordion_content h5 {
  font-size: 3.2vw;
  margin-bottom: 3.2vw;
}

.simulator_area_inner02>.caution_text {
  font-size: 3.2vw;
}

/* .nisa */
.nisa {
  background-color: #F0EEEC;
}

.nisa .border {
  padding-top: 0.533vw;
}

.about-nisa h2 {
  font-size: 4.8vw;
  margin-bottom: 3.2vw;
}

.about-nisa .nisa-box {
  border-radius: 2.133vw;
  padding: 3.2vw 4.267vw;
  background: #F2F2F2;
  margin-bottom: 5.333vw;
}

.about-nisa h2+p {
  font-size: 4.8vw;
  margin-bottom: 3.2vw;
  font-weight: bold;
  text-align: center;
}

.about-nisa .bubble_wrap {
  margin-bottom: 2.133333vw;
}

.about-nisa .bubble_text {
  height: 8.53vw;
  font-size: 4vw;
  font-weight: 500;
}

.about-nisa .nisa-box h3 {
  text-align: center;
  font-weight: bold;
  line-height: 1.32;
  font-size: 3.2vw;
  margin-bottom: 2.133vw;
  margin-top: 4.26666vw;
}

.about-nisa p {
  font-size: 4.26666vw;
  text-align: center;
}

.about-nisa .lead_text {
  background: #FAE6E6;
  margin: auto;
  font-weight: bold;
  width: 70.667vw;
  border-radius: 2.133vw;
  padding: 2.133vw;
  text-align: center;
  font-size: 4.8vw;
  margin-top: 3.2vw;
}


/* .docomo-nisa */
.docomo-nisa .inner:first-of-type {
  padding: 16vw 6.4vw 0;
}

.docomo-nisa .inner:last-of-type {
  padding: 0 6.4vw 17.06666vw;

}

.docomo-nisa .point-list {
  margin-top: 4.8vw;
}

.docomo-nisa .point-list li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: #ffffff;
  border-radius: 4.26666vw;
  margin-top: 3.2vw;
  padding: 3.2vw 4.26666vw;
}

.docomo-nisa .point-list li div img {
  width: 14.93333vw;
}

.docomo-nisa .point-list li div h3 {
  font-size: 4.26666vw;
  font-weight: 600;
  color: #3d3d3d;
}

.docomo-nisa .point-list li div h3 span {
  font-weight: inherit;
  color: #CC0000;
}

.docomo-nisa .point-list li>img {
  width: 15.46666vw;
}

.docomo-nisa>h3 {
  font-size: 5.33333vw;
  text-align: center;
  color: #CC0000;
  font-weight: 600;
  margin-top: 4.8vw;
  background-image: url(../images/bg-nisa2.png);
  background-repeat: no-repeat;
  background-size: 100%;
  background-position: bottom;
}

.docomo-nisa .btn {
  margin: 4.8vw auto 0;
}

.docomo-nisa ul.note {
  margin-top: 4.8vw
}


/* .campaign */
.campaign {
  background-color: #F7F5F3;
}

.campaign .inner {
  padding: 10.66666vw 0;
}

/* bnr_flex */
.campaign .inner .bnr_flex{
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

.campaign .inner .bnr_flex .bnr_flex_contents{
  width: 87.2vw;
  box-shadow: -0.2666666vw 0.2666666vw 3vw 0px rgba(131, 125, 118, 0.33);
  margin: 2.66666vw;
  line-height: 0;
}

/* .detail */
.detail {
  background-color: #F7F5F3;
}

.detail .inner {
  padding: 0;
}

.detail .accordion_title {
  padding: 4.26666vw 0;
  background-color: #E06666;
}

.detail .accordion_title h2 {
  text-align: center;
  color: #ffffff;
  margin: 0;
}

.detail .accordion_title::before,
.detail .accordion_title::after {
  background-color: #ffffff;
}

.detail .accordion_content .inner {
  padding: 8.53333vw 6.4vw 10.66666vw;
  background-color: #ffffff;
}

.detail p {
  font-size: 3.2vw;
}

.detail h3 {
  font-size: 4.8vw;
  font-weight: 600;
  text-align: left;
}

.detail h4 {
  font-size: 3.73333vw;
  font-weight: 600;
}

.detail h5 {
  font-size: 3.2vw;
  font-weight: 600;
}

.detail li {
  font-size: 3.2vw;
  margin-top: 1.06666vw;
  color: #3d3d3d !important;
  font-weight: normal;
}

.detail a {
  font-size: inherit;
  margin-top: 1.06666vw;
}

.detail dt {
  margin-bottom: 4.26666vw;
}

.detail dt:not(:first-of-type) {
  margin: 8.53333vw 0 3.2vw;
}

.detail dd dt {
  margin: 0 0 1.06666vw;
}

.detail dd dt:not(:first-of-type) {
  margin: 3.2vw 0 1.06666vw;
}

.detail dd dd dt {
  margin: 1.06666vw 0 1.06666vw;
}

.detail dd dd dt:not(:first-of-type) {
  margin: 1.06666vw 0 1.06666vw;
}

.detail dd dd dt.mt {
  margin-top: 3.2vw;
}

.detail dd dd dd dt {
  margin: 0;
}

.detail dd dd dd dt:not(:first-of-type) {
  margin: 2.133333vw 0 0;
}


/* cp_notes */
.cp_notes {
  font-family: 'Noto Sans JP', sans-serif;
}

.cp_notes {
  background-color: #F7F5F3;
}

.cp_notes .inner {
  padding: 10.66666vw 6.4vw 8.53333vw !important;
  background: #F7F5F3;
}

.cp_notes>.inner>dl {
  background-color: #FFF;
  padding: 8.53333vw 6.4vw;
  border-radius: 3.2vw;
  height: 106.666666vw;
  box-sizing: border-box;
  overflow-y: scroll;
  overflow-x: hidden;
}

.cp_notes h2,
.cp_notes h3,
.cp_notes h4 {
  font-weight: 600;
}

.cp_notes h3,
.cp_notes h4,
.cp_notes p,
.cp_notes li {
  font-size: 3.2vw !important;
  line-height: 1.48;
}

.cp_notes h2 {
  font-size: 4.8vw;
  text-align: left;
  margin-bottom: 8.53333vw;
}

.cp_notes h3 {
  margin-top: 6.4vw;
}

.cp_notes h4 {
  margin-top: 1.06666vw;
}

.cp_notes li {
  color: #3d3d3d !important;
  font-weight: normal;
}

.cp_notes span.hyphen {
  font-size: inherit;
  margin-top: 1.06666vw;
  display: block;
}

.cp_notes span.hyphen::before {
  content: '－';
  font-size: inherit;
  margin-right: 0.5em;
}

/* .float_bottom */
.float_bottom {
  position: fixed;
  bottom: 0;
  width: 100%;
  padding: 2.133333vw 0;
  z-index: 100;
  background-color: rgba(255, 255, 255, 0.94);
  box-sizing: border-box;
}


.float_bottom .btn {
  width: 75.47vw;
}

.float_bottom .btn_text {
  font-size: 4.26666vw;
}

.float_bottom .btn_text span {
  font-size: 3.2vw;
}

.float_bottom .slash_wrap {
  margin-bottom: 1.06666vw;
}

.float_bottom .slash_wrap .slash p {
  font-size: 3.2vw;
}

.float_bottom .slash_wrap .slash::before,
.float_bottom .slash_wrap .slash::after {
  width: 0.2666666vw;
  height: 4.23333vw;
  background-color: #3D3D3D;
}

.btn::before {
    content: '';
    background-position: center;
    background-size: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 1.6vw;
    margin: auto 0;
  }
  .btn.btn_type2 {
    background: linear-gradient(180deg, #DB0000 50%, #CC0000 50%);
    border: 2px solid #E57878;
    box-shadow: 0px 1vw 0px 0px #800000;
  }
  .about-point a .btn_text,
  .tab_inner .btn_area p {
    font-weight: 600;
  }

  .btn.icon_type3::before {
    background-image: url(https://assets-manager.abtasty.com/5d4c4fb0a08561ffba02da8c0da26ff9/ico-btn2.png);
    width: 11.73vw;
    height: 11.73vw;
  }
  .btn.icon_type3 .btn_text {
    margin-left: 4.2vw;
    margin-right: 0px;
  }
  .float_bottom .btn_text {
    font-size: 4.26666vw;
  }
  .nisa-campaign-inner .btn.btn_type2,
  .simulator_area_inner02 .btn.btn_type2,
  .about-point .btn.btn_type1 {
    margin-bottom: 10px;
  }
  .float_bottom .btn.btn_type2 {
    margin-bottom: 8px;
  }
  .step-list li .btn_type2 {
    margin-bottom: 2.67vw;
  }

/* .footer */
.footer a.link {
  color: #CC0000;
  font-size: inherit;
  line-height: 1.48;
}

.footer a.link.icon {
  position: relative;
  padding-right: 1.39090909091em;
}

.footer a.link.icon::after {
  content: '';
  background-image: url(/assets/inc/footer/images/icon_link.png);
  background-size: 100%;
  background-repeat: no-repeat;
  width: 0.85714285714em;
  height: 0.85714285714em;
  position: absolute;
  font-size: inherit;
  margin-left: 0.25em;
  bottom: 0.21428571428em;
  display: inline;
}

.footer .notes {
  padding: 10.66666vw 6.4vw 8.53333vw;
  background-color: #707070;
}

.footer .notes_content {
  background-color: #FFF;
  padding: 8.52878vw 6.4vw;
  border-radius: 3.2vw;
  height: 106.663113vw;
  overflow-y: scroll;
  overflow-x: hidden;
}

.footer .notes h2,
.footer .notes h3,
.footer .notes h4 {
  font-weight: 600;
}

.footer .notes h2 {
  text-align: left;
  font-size: 4.8vw;
}

.footer .notes h2:not(:first-of-type) {
  margin: 6.4vw 0 4.26666vw;
}

.footer .notes h3 {
  font-size: 4.26666vw;
  line-height: 1.48;
  margin: 6.4vw 0 4.26666vw;
}

.footer .notes h4 {
  margin: 4.26666vw 0 3.2vw;
}

.footer .notes h5 {
  margin: 2.133333vw 0 0;
}

.footer .notes h5.dot {
  position: relative;
  padding-left: 1em;
  font-weight: 600;
}

.footer .notes h5.dot::before {
  content: '';
  background-color: #3D3D3D;
  font-size: inherit;
  width: 0.5em;
  height: 0.5em;
  border-radius: 0.53333vw;
  position: absolute;
  left: 0;
  top: 0.5em;
}

.footer .notes ul.dot>li {
  text-indent: -1.57142857143em;
  padding-left: 1.57142857143em;
  margin-top: 2.133333vw;
}

.footer .notes ul.dot>li::before {
  content: '・';
  font-size: inherit;
  margin-right: 0.571429em;
}

.footer .notes h4,
.footer .notes h5,
.footer .notes p,
.footer .notes ul.dot li {
  font-size: 3.73333vw;
  line-height: 1.48;
}

.footer .notes h4 {
  font-weight: 600;
}

.footer .notes h5,
.footer .notes p,
.footer .notes ul.dot li {
  font-weight: normal;
}

.footer .notes p.company {
  text-align: right;
}

.footer .notes p.company span {
  display: block;
}

.footer .copy {
  padding: 8.52878vw 0 34.133vw;
  text-align: center;
  background-color: #707070;
}

.footer .copy p {
  font-size: 3.2vw;
  color: #ffffff;
}

/* modal */
/* モダールの背景固定 */
body {
  overflow-y: scroll;
}

body.modalLock {
  position: fixed;
  left: 0;
  width: 100%;
}

.modal::before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  height: 100%;
}

.modal {
  background-color: rgba(0, 0, 0, 0.40);
  position: fixed;
  top: 0;
  left: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  z-index: 10000;
  text-align: center;
}

.modal_open:hover {
  opacity: 0.8;
  cursor: pointer;
}

.modal__item {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  width: 91.47%;
  max-width: 91.47vw;
  background-color: #fff;
  border-radius: 4.27vw;
  padding: 10.67vw 4.27vw 6.4vw;
  height: min-content;
  max-height: 80vh;
  box-sizing: border-box;
  overflow-y: auto;
  overflow-x: clip;
}

.modal__item img.dots {
  display: block;
  width: 0.8vw;
  margin: 8px auto;
}

.modal__item img {
  width: 100%;
  margin: 0 auto 4.2666vw;
}

.modal__item h3 {
  font-size: 4.8vw;
  font-weight: 600;
  margin: 0 auto 4.27vw;
  text-align: center;
}

.modal__item p:first-of-type {
  text-align: center;
}

.modal__item p:last-of-type {
  margin-top: 2.13vw;
}

.modal__item p {
  font-size: 3.73vw;
  text-align: left;
}

.modal__item p b {
  font-weight: 600;
}

.modal__item .img_area {
  display: flex;
  justify-content: space-between;
  margin-bottom: 4.27vw;
}
#modal_about .img_area img {
  width: 27.2vw;
  height: 27.2vw;
  margin: auto 0;
  gap: 2.13vw;
}
#app01 .img_area img,
#app02 .img_area img {
  width: 82.93vw;
  height: 32vw;
  margin: 4.27vw 0 0;
}


.modal__item .img_area img:nth-child(2) {
  width: 24vw;
  height: 24vw;
}

.modal__item ul {
  padding-right: 6.4vw;
}

.modal__item ul li {
  text-align: left;
  text-indent: -4.8vw;
  padding-left: 4.8vw;
  font-weight: 300;
  font-size: 3.73vw;
}

.modal__item ul li:nth-child(1),
.modal__item ul li:nth-child(2) {
  margin-bottom: 2.13vw;
}

.modal__item ul li::before {
    content: '・';
    font-size: inherit;
    margin-right: 1.07vw;
}
.modal__button {
  position: absolute;
  top: 4vw;
  right: 4vw;
  width: 5.867vw;
  height: 5.867vw;
  background-image: url(../images/icon-cross.png);
  background-size: contain;
  background-repeat: no-repeat;
  cursor: pointer;
}

.modal__button:hover {
  opacity: 0.6;
}

@media screen and (min-width: 768px) {
  .pc {
    display: block !important;
  }

  .sp {
    display: none !important;
  }

  body {
    /* padding-top: 70px; */
  }

  section .inner {
    max-width: 1080px;
    padding: 0;
  }

  h2 {
    font-size: 36px;
    line-height: 1.48;
    margin-bottom: 40px;
  }

  p {
    font-size: 16px;
  }

  ul.note li,
  ol.note li,
  ul.dot li,
  ol.num li {
    margin-top: 0;
  }

  /* ul.note */
  ul.note li,
  ol.note li,
  ul.dot li,
  ol.num li {
    font-size: 12px;
  }

  /* .btn */
  .btn {
    width: 327px;
    height: 56px;
  }

  .btn_text {
    font-size: 16px;
  }

  .btn::after {
    right: 16px;
  }

  /* .btn.btn_type1 */
  .btn.btn_type1 {
    border: 2px solid #E0DFDD;
  }

  /* .btn.icon_type1 */
  a.link.icon.icon_type1 {
    padding-right: 16px;
  }

  .btn.icon_type1::after {
    width: 12px;
    height: 12px;
  }

  .btn.icon_type1 .btn_text {
    margin-right: 8px;
  }

  /* .btn.icon_type2 */
  .btn.icon_type2::after {
    width: 12px;
    height: 12px;
  }

  .btn.icon_type2 .btn_text {
    margin-right: 12px;
  }

  /* .btn.icon_type3 */
  .btn.icon_type3::after {
    width: 12px;
    height: 12px;
  }

  .btn.icon_type3 .btn_text {
    margin-right: 12px;
  }

  /* .btn.icon_type6 */
  .icon_type6::after {
    width: 16px;
    height: 16px;
  }

  a.link.icon.icon_type4 {
    padding-right: 16px;
  }

  /* .bubble */
  .lead_area .bubble_wrap {
    padding-bottom: 6px;
  }

  .bubble {
    padding: 0 13px 0 15.5px;
  }

  .bubble_text {
    height: 32px;
    font-size: 15px;
  }

  .bubble::after {
    width: 7.64px;
    height: 6.75px;
  }

  /* .accordion */
  .accordion {
    border: 1px solid #E0DEDC;
    border-radius: 8px;
    margin-top: 32px;
  }

  .accordion_title * {
    font-size: 20px;
  }

  .accordion_title::before,
  .accordion_title::after {
    width: 14px;
    height: 2px;
    right: 41px;
  }

  /* .slash */
  .slash_wrap .slash::before,
  .slash_wrap .slash::after {
    width: 2.5px;
    height: 25px;
    top: auto;
    bottom: 4px;
  }

  .slash_wrap .slash::before {
    left: -0.9em;
  }

  .slash_wrap .slash::after {
    right: -0.7em;
  }

  .slash_wrap .slash p {
    font-size: 20px;
  }

  /* border */
  .border {
    background-image: linear-gradient(to right, #9E9E9E, #9E9E9E 3px, transparent 0);
    background-size: 7px 1px;
  }

  .about div.about-top+.border {
    margin-top: 56px;
    padding-top: 56px;

  }

  .about .border+.border {
    margin-top: 32px;
    padding-top: 32px;
  }

  /* .header */
  .header {
    background-color: #ffffff;
  }

  .header .inner {
    max-width: 1280px;
    padding: 8px 0;
    box-sizing: border-box;
  }

  .header a {
    display: inline-block;
  }

  .header img {
    width: 280px;
  }

  /* .float_top */
  .float_top {
    position: fixed;
    top: 0;
    width: 100%;
    padding: 16px 40px;
    z-index: 100;
    background-color: #F0EEEC;
    box-sizing: border-box;
  }

  .float_top .btn_wrap {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 376px;
    margin: 0 0 0 auto;
  }

  .float_top .btn {
    width: 180px;
    height: 38px;
  }

  .float_top .btn_text {
    font-size: 14px;
  }

  .float_top .btn_wrap a:first-of-type .btn_text {
    font-size: 12px
  }

  /* .fv */

  .fv .btn_area {
    width: 327px;
    margin: auto;
  }

  .fv>img {
    max-width: 1280px;
    margin: auto;
  }

  .fv .btn_area img {
    max-width: 892px;
  }
  .fv .btn_area ul {
    margin: 0 auto 8px;
  }

  .fv .btn_area ul li {
    width: auto;
  }

  .fv .btn_area .btn {
    width: 327px;
    height: 56px;
    bottom: 10%;
  }

  .fv .btn_area ul.note {
    justify-content: center;
  }

  .fv ol.note {
    margin: 12px 0 4px;
  }

  .fv .inner .notice{
    padding: 8px 9px 12px;
    margin: 16px 0 0;
  }

  .fv .inner .notice p{
    font-size: 12px;
  }

  .fv .inner .notice p:first-of-type{
    padding-bottom: 12px;
  }

  .text_info .inner {
    padding: 40px 0;
  }

  .text_info .inner>p {
    width: 100%;
    margin: 0 auto;
    font-size: 14px;
  }

  .news {
    margin: 0 auto 24px;
    padding: 0;
  }

  .news p {
    font-size: 14px;
    border: solid 1px #3d3d3d;
    padding: 12px;
  }
  .news p span{
    font-size: 16px;
  }

  /* anchor_simulation */
  .anchor_simulation_area {
    padding: 36px 0 16px;
  }
  .anchor_simulation {
    max-width: 434px;
    padding: 24px 16px 20px;
    border-width: 2px;
    border: 2px solid #E06666;
    border-radius: 8px;
  }
  
  .anchor_simulation .btn_text {
    font-size: 20px;
    margin-left: 0;
  }

  .anchor_simulation .bubble_wrap {
    top: -18px;
    left: 50%;
    transform: translateX(-50%);
  }

  .anchor_simulation::before,
  .anchor_simulation::after {
    top: 0;
    bottom: 0;
    margin: auto 0;
  }

  .anchor_simulation::before {
    width: 58px;
    height: 58px;
    left: 16px;
  }

  .anchor_simulation::after {
    width: 18px;
    height: 18px;
    right: 36px;
  }

  /* about */
  .about {
    padding: 80px 0;
  }

  .about .inner .lead {
    display: block;
    width: 461px;
    margin: auto;
  }

  .about .inner {
    max-width: 1020px;
    margin: auto;
  }

  .about .inner div.summary {
    max-width: 900px;
    margin: auto;
  }

  .about .condition-list-container {
    display: flex;
    gap: 16px;
  }

  .about .condition-list {
    display: flex;
    flex-direction: row;
    background-color: #FCF5E0;
    border: 2px solid #FACB32;
    border-radius: 10px;
    padding: 24px;
    margin: 20px auto 16px;
  }

  .about .condition-list:first-of-type {
    width: 100%;
    max-width: 678px;
    justify-content: center;
  }

  .about .condition-list:first-of-type li {
    width: 50%;
    max-width: 300px;
  }

  .about .condition-list:last-of-type::after {
    top: 50%;
    left: -25px;
    transform: translateY(-50%);
    width: 30px;
    height: 30px;
  }

  .about .condition-list li {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 20px;
    background-image: linear-gradient(to bottom, #9E9E9E, #9E9E9E 4px, transparent 0);
    background-size: 2px 9px;
    background-repeat: repeat-y;
    background-position: right top;
  }

  .about .condition-list li:first-of-type {
    padding-left: 0;
  }

  .about .condition-list li:last-of-type {
    padding-right: 0;
  }

  .about .condition-list-inner img {
    width: 42px;
    margin-right: 6px;
  }

  .about .condition-list-inner p {
    font-size: 18px;
  }

  .about .condition-list-inner span {
    font-size: 14px;
    vertical-align: super;
  }

  .about .condition-list li>img {
    width: 58px;
  }

  .about h2 span {
    font-size: 18px;
  }

  .about ul.note {
    margin-top: 8px;
  }

  .about ul.note+div img {
    margin-top: 40px;
  }

  .about .arrow {
    width: 20px;
    margin: 0 auto 16px;
  }

  .about .image_compare {
    margin-top: 8px;
  }

  .about .inner>.btn {
    margin: 24px auto 16px;
    width: 334px;
  }

  .about .inner>ul.note {
    margin-top: 0;
  }

  .about h3 {
    font-size: 24px;
  }

  .btn.icon_type5::after {
    width: 18px;
    height: 18px;
  }

  .btn.icon_type5 .btn_text {
    margin-right: 8px;
  }

  /* merit */
  .merit h3 {
    margin-top: 40px;
  }

  .merit-list {
    display: flex;
    justify-content: space-between;
    margin: auto;
    margin-bottom: 56px;
    width: 670px;
  }

  .merit-list li {
    max-width: 327px;
    width: 50%;
    border-radius: 16px;
    padding: 16px;
    margin-top: 24px;
  }

  .merit-list li div img {
    width: 60px;
  }

  .merit-list li>img {
    width: 96px;
  }

  .merit-list+img {
    display: block;
    width: 327px;
    margin: 40px auto 0;
  }

  .merit-list ul.note {
    margin-top: 16px;
  }


  /* summary */
  .summary h3 {
    font-size: 36px;
  }

  .tab_label {
    margin-top: 32px;
    margin: auto;
    width: 100%;
    max-width: 900px;
  }

  .tab_label li {
    border-radius: 8px 8px 0 0;
    padding: 8px 0;
    font-size: 16px;
  }

  .tab_label .tab_label-platinum._active,
  .tab_label .tab_label-gold._active {
    padding: 13px 0;
  }

  .tab_inner {
    margin: auto;
    width: 100%;
    max-width: 900px;
    box-sizing: border-box;
  }

  .tab_inner>div {
    padding: 32px;
  }

  .tab_inner>div.tab_platinum {
    border: 2px solid #46433D;
  }

  .tab_inner>div.tab_gold {
    border: 2px solid #BE980F;
  }

  .tab_inner .flex {
    width: 450px;
    margin: auto;
    display: flex;
    align-items: center;
  }

  .tab_inner h4 {
    font-size: 20px;
    margin-bottom: 16px;
  }

  .tab_inner .h4_outer>h4 {
    font-size: 20px;
  }

  .price_area p {
    font-size: 18px;
  }

  .tab_inner .price_area span {
    font-size: 14px;
  }

  .tab_inner .price_area span.price_number {
    font-size: 20px;
    margin-left: 4px;
  }

  .summary .tab_inner .h4_outer+img {
    width: 171px;
    margin: 0 auto;
  }

  .tab_inner>div>p.lead {
    margin: 24px auto 32px;
    font-size: 18px;
  }

  .tab_inner .goldu_area_wrap {
    padding-top: 20px;
  }

  .tab_inner .goldu_area {
    padding: 24px 0;
    border-radius: 8px;
    margin: 0 auto 20px;
    max-width: 688px;
  }

  .tab_inner .goldu_area .flex_wrap {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 40px;
  }

  .tab_inner .goldu_area .lead {
    font-size: 20px;
    margin-bottom: 16px;
  }

  .tab_inner .goldu_area .card_image {
    width: 170px;
    height: fit-content;
    margin: 0;
  }
  
  .tab_inner .goldu_area .card_name {
    font-size: 18px;
  }

  .tab_inner .goldu_area .price_area {
    margin: 8px auto 0;
  }
  
  .tab_inner .goldu_area .price_area span {
    font-size: 14px;
  }

  .tab_inner .goldu_area .price_area .price_number {
    font-size: 28px;
  }

  .tab_inner .goldu_area .goldu_text {
    margin-top: 24px;
    font-size: 18px;
  }

  .tab_inner .goldu_area .card_image_wrap::before {
    top: -42px;
    left: 16px;
    transform: unset;
    width: 117px;
    height: 38px;
    margin: 0;
  }

  .summary p.table_title {
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 12px;
    margin-top: 0;
  }

  .summary .tab_gold p.table_title {
    margin-top: 40px;
  }
  
  .summary .tab_platinum p.table_title {
    margin-top: 32px;
  }

  .summary p.caption {
    width: 100%;
    margin: 0 auto 0;
    font-size: 11px;
  }

  .summary .image-container {
    width: 100%;
    max-width: 688px;
    overflow-x: unset;
    white-space: unset;
    margin: 4px auto 24px;
  }

  .summary .tab_inner .summary-accordion {
    max-width: 688px;
    margin-top: 20px;
  }

  .summary .tab_inner .summary-accordion p.caption {
    text-align: center;
    width: 100%;
  }

  .scroll-image {
    width: 100%;
  }

  .tab_inner div>.link {
    font-size: 14px;
    margin: 16px auto;
  }

  .tab_inner>div>.link {
    font-size: 14px;
    margin: 24px auto;
    width: 688px;
  }

  .tab_inner>div>.note {
    margin: auto;
    width: 100%;
    max-width: 688px;
  }

  .tab_inner .tab_gold .btn_area_wrap{
    display: flex;
    justify-content: center;
    gap: 16px;
  }

  .tab_inner .tab_gold .btn_area {
    margin: 0;
  }

  .tab_inner .tab_gold .btn_area .btn_text {
    font-size: 18px;
  }

  .tab_inner .tab_platinum .btn_area {
    margin: 32px auto 0;
  }

  .tab_inner .tab_platinum .btn_area .btn_text {
    font-size: 16px;
  }

  .bg_yellow {
    width: 296px;
    padding: 28px 77px 24px;
    border-radius: 8px;
    margin: 32px auto 0;
  }

  .bg_yellow::before {
    background-image: url(../images/pc/bg_yellow.png);
  }

  .bg_yellow h5 {
    font-size: 24px;
  }

  .bg_yellow .bubble_wrap {
    margin: 14px auto 6px;
  }

  .bg_yellow img {
    display: block;
    width: 301px;
    margin: auto;
  }

  .bg_yellow .cp_period {
    margin-top: 16px;
    font-size: 20px;
  }

  .bg_yellow .cp_period>span {
    font-size: 14px
  }

  .bg_yellow .cp_period+.note {
    margin-top: 8px;
  }

  .bg_gray {
    border-radius: 8px;
    padding: 24px 32px;
    margin-top: 40px;
  }

  .bg_gray p {
    text-align: center;
  }

  .bg_gray p span {
    font-size: 18px;
  }

  .bg_gray h5 {
    font-size: 24px;
  }

  .bg_gray h5+img {
    display: block;
    width: 258px;
    margin: 16px auto 0;
  }

  .bg_gray .lead {
    width: 537px;
    padding: 4px 0;
    font-size: 18px;
    margin: 20px auto 0;
  }

  .bg_gray>div {
    margin: 16px auto;
  }

  .bg_gray .slash_wrap {
    margin-top: -36px;
  }

  .bg_gray .slash_wrap .slash p {
    font-size: 16px;
  }

  .bg_gray img.dots {
    width: 2px;
    height: 10px;
    margin: 8px auto;
  }

  .bg_gray>div {
    width: 100%;
  }

  .bg_gray>div p {
    font-size: 20px;
    text-align: center;
  }

  .bg_gray>div img {
    display: block;
    width: 314px;
    margin: 16px auto 0;
  }

  .bg_gray .note:first-of-type {
    margin-top: 16px;
  }

  .tab_inner .btn_area ul {
    display: flex;
    justify-content: center;
    margin-top: 32px;
  }

  .tab_inner .btn_area ul li {
    margin: 0;
  }

  .tab_inner .btn_area .slash_wrap {
    margin: 0 auto 8px;
  }

  .tab_inner .btn_area p {
    font-size: 14px;
  }

  /* dcard */
  .dcard {
    padding: 72px 0;
  }

  /* summary */
  .summary h3 {
    margin-bottom: 40px;
  }

  .summary>p {
    text-align: center;
  }

  .summary .border {
    padding-top: 80px;
  }

  .summary .border>h3 {
    font-size: 30px;
  }

  .summary-img-wrapper {
    width: 670px;
    margin: auto;
    margin-bottom: 24px;
  }

  .summary>p {
    margin-bottom: 8px;
  }

  .summary>.note {
    text-align: center;
  }

  /* .summary-accordion */
  .summary-accordion {
    background-color: #FCFCFC;
    margin: auto;
    width: 100%;
    max-width: 900px;
    margin-top: 32px;
  }

  .summary-accordion p.table_title {
    font-size: 18px;
    margin-bottom: 8px;
  }

  .summary-accordion .accordion_title {
    padding: 32px 0 32px 40px;
  }

  .summary-accordion .accordion_content {
    padding: 0 40px 32px;
  }

  .summary-accordion .accordion_content ol.note {
    margin-bottom: 20px;
  }

  .summary-accordion .accordion_title h5 {
    max-width: 800px;
    width: 88%;
  }

  .summary-accordion img {
    width: 400px;
    margin: 16px auto;
  }

  .summary-accordion img.scroll-image {
    width: 100%;
  }

  .summary-accordion img.platinum_table_image {
    width: 100%;
  }

  .summary-accordion img.img_goldtab_card {
    width: 537px;
    margin-bottom: 12px;
  }

  .summary-accordion p {
    font-size: 18px;
  }

  .summary-accordion .btn {
    width: 263px;
    margin: 16px auto 0;
  }

  .about-point ul.note {
    margin-top: 8px;
  }

  .dcard .nisa-campaign {
    width: 100%;
    max-width: 900px;
  }


  /* .return-accordion */
  .return-accordion {
    max-width: 900px;
    margin: auto;
  }

  .return-accordion .accordion_title {
    padding: 32px 0 32px 42px;
  }

  .return-accordion .accordion_content {
    padding: 0 32px 40px;
  }

  .return-accordion ._scroll {
    overflow-y: auto;
  }

  .return-accordion ._scroll img {
    display: block;
    width: 688px;
    margin: auto;
  }

  .return-accordion .list_wrap {
    margin-top: 16px;
  }

  .about-point{
    margin-top: 32px;
  }

  .about-point p.-caution{
    font-size: 12px;
    color: #707070;
    text-align: center;
    margin: 12px auto 0;
    width: 100%;
  }

  .about-point img {
    width: 573px;
    margin: 0 auto;
  }

  .about-point img.bottom{
    margin-bottom: 40px;
  }

  .about-point a {
    margin-top: 16px;
  }

  ul.note.center {
    margin: 4px auto 0;
  }

  /* step */
  .step {
    padding: 80px 0;
  }

  .step .inner .lead {
    width: 461px;
  }

  /* entry */
  .step .entry-wrap {
    width: 327px;
    margin: auto;
    border-radius: 10px;
    padding: 20px 30px;
    margin-top: 40px;
  }

  .step .entry-wrap .btn {
    width: 263px;
}

  .step .entry-wrap p {
    font-size: 16px;
  }

  .step .entry-wrap h3 {
    font-size: 18px;
  }

  .step .entry-wrap::after {
    bottom: -17%;
    width: 30px;
    height: 30px;
  }

  .step .entry-wrap>div {
    margin: 0 auto 12px;
    width: auto;
  }

  .step .entry-wrap>div img {
    width: 32px
  }

  /* .grant-accordion */
  .grant-accordion {
    margin-top: 40px;
  }

  .grant-accordion .accordion_title {
    padding: 32px 0 32px 40px;
  }

  .grant-accordion .accordion_content {
    padding: 0 40px 32px;
  }

  .grant-accordion .accordion_content p {
    font-size: 16px;
  }

  .grant-accordion .accordion_content dl {
    display: flex;
    justify-content: start;
    align-items: center;
    gap: 32px;
  }

  .grant-accordion .accordion_content dl dt h4 {
    font-size: 16px;
    margin-top: 0;
  }

  .grant-accordion .accordion_content .box {
    margin-top: 20px;
    padding: 24px 40px;
  }

  .grant-accordion .accordion_content .box .lead {
    font-size: 16px;
    margin-bottom: 16px;
    padding: 4px 18px;
  }

  .grant-accordion .accordion_content .box .down_type2 {
    width: 14px;
    margin: 8px auto;
    display: block;
  }

  .grant-accordion .accordion_content .box .flow {
    margin-top: 16px;
  }

  .grant-accordion .accordion_content .box img {
    margin-top: 16px;
  }

  .grant-accordion+a {
    margin-top: 40px;
  }

  /* nisa-campaign */
  .nisa-campaign {
    border-radius: 10px;
    margin: 0 auto 0;
  }

  .nisa-campaign-laed.bubble_wrap {
    padding-bottom: 18px;
  }
  
  .nisa-campaign-laed .bubble {
    width: 568px;
    padding: 20px 0;
    border-radius: 8px;
  }
  
  .nisa-campaign-laed .bubble::after {
    width: 20px;
    height: 18px;
  }
  
  .nisa-campaign-laed .bubble_text {
    font-size: 24px;
  }

  .nisa-campaign-inner {
    padding: 56px 0 68px;
  }

  .nisa-campaign-inner .bubble_wrap {
    margin-bottom: 10px;
  }

  .nisa-campaign-text {
    margin: 20px auto 16px;
    padding-top: 0;
    width: 590px;
  }

  .nisa-campaign .btn_wrap {
    width: 674px;
    padding: 28px 16px 16px;
    border-radius: 8px;
    background: #FEFDF7;
    margin: auto;
    margin-top: 56px;
    position: relative;
  }
  
  .nisa-campaign .btn_wrap .bubble_wrap {
    margin-top: -44px;
    margin-bottom: 12px;
  }

  .nisa-campaign .btn_wrap .bubble_wrap .bubble {
    padding-top: 2px;
    padding-bottom: 2px;
  }

  .nisa-campaign .btn_wrap .bubble_wrap .bubble_text {
    font-size: 16px;
  }
  
  .nisa-campaign .btn_wrap .bubble_wrap .bubble_text::before {
    width: 16px;
    height: 16px;
  }

  .nisa-campaign .bnr_area {
    display: block;
    max-width: 726px;
    width: 80%;
    margin: auto;
    padding: 24px;
    border-radius: 10px;
    display: flex;
    flex-direction: row;
    box-sizing: border-box;
    align-items: center;
  }

  .nisa-campaign .bnr_area .btn {
    width: 142px;
    height: 32px;
    position: relative;
    margin-top: 8px;
    border-radius: 20px;
    padding: 4px 20px;
    bottom: unset;
    left: unset;
    transform: unset;
  }

  .nisa-campaign .bnr_area div {
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  .nisa-campaign .bnr_area img {
    margin-bottom: 0;
    width: 323px;
    height: fit-content;
    margin-right: 16px;
  }

  .nisa-campaign .bnr_area p {
    margin-bottom: 0;
    font-size: 20px;
    font-weight: 800;
  }

  .step .inner>.btn.btn_type1 {
    width: 334px;
    margin-top: 20px;
  }

  .step .inner>ol.note {
    margin-top: 16px;
  }
  
  .step .inner>ul.note {
    margin-top: 0;
  }

  /* simulator_area */
  section.dcard .inner.simulator_header_inner,
  section.dcard .inner.simulator_area_inner {
    padding: 0;
    margin: auto;
  }

  .simulator_area.title_wrap {
    background-image: none;
    max-width: 1080px;
    height: auto;
    margin: auto;
    margin-bottom: 40px;
    margin-left: auto;
  }

  .simulator_area.title_wrap .bubble {
    width: auto;
  }
  
  .simulator_area.title_wrap .bubble_text {
    font-size: 18px;
    padding: 0 7px 0 13px;
  }

  .simulator_area.title_wrap h2 {
    font-size: 42px;
  }

  .simulator_area_inner01 {
    max-width: 1080px;
    border-radius: 2px;
    padding: 32px 40px;
  }

  .chart-container {
    width: 100%;
    margin-top: 20px;
    display: none;
  }
  #addBarsButton {
    display: none;
    font-weight: bold;
    width: 327px;
    font-size: 16px;
  }
  #backYourSettingButton {
    width: 327px;
    font-size: 16px;
  }
  /* 数字入力項目 */
  .simulator_area .input-group p {
    font-size: 22px;
    line-height: 2;
  }
  .simulator_area .input-group p sup {
    font-size: 14px;
  }
  .simulator_input {
    width: 64px;
    height: 41px;
    border-radius: 4px;
    font-size: 28px;
    border: 2px solid #F0EEEC;
  }
  .simulator_area .input-group p.text-sm {
    font-size: 12px;
    line-height: 1;
  }
  .simulator_input:focus {
    outline: solid 2px #facb32;
  }
  .simulator_area .input-group p.text-sm {
    font-size: 12px;
  }
  /* スライダー */
  .simulator_slider {
    width: 304px;
    height: 5px;
  }
  .simulator_slider::before,
  .simulator_slider::after {
    bottom: -24px;
    font-size: 11px;
  }

  /* ツマミ：Chrome, Safari, Edge用 */
  .simulator_slider::-webkit-slider-thumb {
    width: 17px;
    height: 17px;
  }

  /* ツマミ：Firefox用 */
  .simulator_slider::-moz-range-thumb {
    width: 17px;
    height: 17px;
  }

  .simulator_slider_wrap {
    margin-bottom: 32px;
  }
  .simulator_minus,
  .simulator_plus {
    width: 60px;
    height: 60px;
  }
  .simulator_minus::after,
  .simulator_plus::after {
    top: 2px;
    right: 0;
    width: 60px;
    height: 60px;
  }
  .simulator_minus::after {
    right: -4px;
  }
  .simulator_plus::after {
    right: 4px;
  }
  /* カードエリア */
  .simulator_area .card_wrap {
    margin-bottom: 24px;
    align-items: center;
  }
  .simulator_area .card_wrap .card_content {
    display: block;
    border: 1px solid #f0eeec;
    width: 309px;
    height: unset;
    border-radius: 8px;
    padding-top: 12px;
    padding-bottom: 12px;
  }
  .simulator_area .card_content p {
    margin: auto;
    font-size: 10px;
    line-height: 2;
  }
  .simulator_area .card_content p.lead_text {
    width: 74px;
    font-size: 12px;
    border-radius: 50px;
    margin-top: auto;
    margin-bottom: 8px;
  }
  .simulator_area .card_content p.card_name {
    min-height: unset;
    display: block;
  }
  .simulator_area .card_content img {
    height: 53px;
    margin-bottom: 8px;
  }

  /* カードボタンselected */
  .simulator_area .card_wrap .card_content.selected {
    border: 2px solid #facb32;
  }

  .simulator_area .card_wrap .card_content.selected::before {
    top: -8%;
    width: 22px;
    height: 22px;
  }

  /* シミュレーション結果について */
  .simulator_area .caution_wrap h5 {
    margin-top: 24px;
    margin-bottom: 12px;
    font-size: 18px;
  }

  /* シミュレーションエリア外装 */

  #simulatorResultArea.active::before {
    top: -30px;
    width: 3px;
    height: 14px;
  }

  #simulatorResultAreaInner {
    border: 2px solid #e06666;
    border-radius: 8px;
    padding: 40px 16px;
    margin-top: 60px;
  }

  #simulatorResultAreaInner.active {
    border: 2px solid #64c482;
    padding: 100px 16px 40px;
  }

  .simulator_area .lead_text_wrap {
    width: 340px;
    height: 90px;
    margin: auto;
    margin-bottom: 24px;
  }

  #simulatorResultAreaInner .lead_text_wrap p {
    font-size: 24px;
    margin-top: 4px;
  }

  #simulatorResultAreaInner .lead_text_wrap p sup {
      font-size: 12px;
  }

  #simulatorResultAreaInner .lead_text_wrap .lead_text_white {
    font-size: 16px;
    width: 172px;
    padding: 4px 0;
    border-radius: 60px;
  }

  #simulatorResultAreaInner .lead_text_wrap .totalPoint {
    font-size: 36px;
  }

  /* チャート生成ボタン */
  #generateChartButton {
    width: 327px;
    font-size: 16px;
  }

  /* チャートエリア */
  #simulatorResultAreaInner .border {
    padding-top: 24px;
  }

  .chart_area_wrap {
    width: 334px;
  }

  .chart_area_wrap .bubble {
    padding: 4px 14px;
  }

  .chart_area_wrap .bubble_text {
    font-size: 18px;
    padding-left: 0;
  }
  .chart_area_wrap .note {
    margin: 12px 0;
  }

  .chart_area_wrap .lead_text {
    font-size: 24px;
  }

  .chart_area_wrap .lead_text_sub {
    margin-bottom: 16px;
    font-size: 16px;
  }

  .chart_area_wrap .totalAmountRounded {
    font-size: 36px;
  }

  .chart_area_wrap .slash_wrap {
    margin-bottom: 8px;
  }

  .chart_area_wrap .slash_wrap .slash p {
    font-size: 14px;
  }

  .chart_area_wrap .slash_wrap .slash::before,
  .chart_area_wrap .slash_wrap .slash::after {
    height: 12px;
    bottom: 0;
  }

  #displayGraphDescription {
    margin-bottom: 24px;
  }

  /* 追加要素 */
  .simulator_result_extratext {
    height: 48px;
    padding: 12px;
  }

  .simulator_result_extratext p {
    font-size: 18px;
  }

  /* ツールチップ */
  .simulator_area .tooltip_area {
    margin-bottom: 20px;
  }

  .simulator_area .tooltip_area > div {
    width: 49.5%;
  }
  
  .simulator_area .tooltip_area > div.active {
    border: 1px solid #EB9999;
    border-radius: 8px;
    padding: 8px 6px;
  }
  
  .simulator_area .tooltip_area > div:nth-of-type(2).active {
    border: 1px solid #64C482;
  }
  
  .simulator_area .tooltip_area > div h4 {
    font-size: 11px;
    margin-bottom: 4px;
  }

  .simulator_area .tooltip_area > div p {
    font-size: 10px;
  }

  .simulator_area .tooltip_area > div p::before {
    width: 12px;
    height: 12px;
  }

  .chart_subtitle {
    font-size: 10px;
    bottom: 190px;
    left: 4px;
  }

  /* プラチナアップグレードエリア */
  #platinaUpgradeArea {
    border: 2px solid #46433d;
    border-radius: 8px;
    padding: 40px 16px 20px;
    margin-top: 24px;
    margin-bottom: 24px;
  }

  #platinaUpgradeArea .platinaUpgradeArea_haeder {
    width: 100%;
    height: 24px;
  }

  #platinaUpgradeArea .platinaUpgradeArea_haeder::before {
    border-right: 7px solid transparent;
    border-left: 7px solid transparent;
    border-bottom: 10px solid #ffffff;
  }

  #platinaUpgradeArea .img_area {
    width: 456px;
    border-radius: 8px;
    padding: 12px 20px;
    gap: 8px;
    margin-bottom: 16px;
  }

  #platinaUpgradeArea .img_area img {
    width: 60px;
  }

  #platinaUpgradeArea .img_area p {
    font-size: 18px;
  }

  #platinaUpgradeArea .lead_text {
    display: flex;
    width: 412px;
    height: 34px;
    margin: auto;
    margin-bottom: 16px;
    padding-top: 0;
    justify-content: center;
    align-items: center;
    background-image: url(../images/bg_simulation_point.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: top;
  }

  #platinaUpgradeArea .lead_text .text-sm {
    font-size: 12px;
  }

  #platinaUpgradeArea .lead_text .text-bg {
    font-size: 22px;
  }

  #platinaUpgradeArea .lead_text #platinaPoint {
    font-size: 32px;
  }

  #platinaUpgradeArea .lead_text_sub {
    width: max-content;
    padding: 4px 16px;
    font-size: 16px;
    border-radius: 60px;
  }

  #platinaUpgradeArea .lead_text_sub .text-sm {
    font-size: 16px;
  }

  #platinaUpgradeArea .lead_text sup {
      font-size: 12px;
  }

  /* シミュレーションエリア下部 */
  .simulator_area_inner02 {
    max-width: 1080px;
    margin-top: 20px;
  }

  .point_description_area {
      border-radius: 8px;
      padding: 40px 40px 48px;
      margin-bottom: 40px;
      margin-top: 40px;
  }

  .point_description_area h3 {
      font-size: 26px;
      margin-bottom: 16px;
  }

  .point_description_area .content_wrap {
      padding-bottom: 8px;
      padding-top: 8px;
  }

  .point_description_area .content_wrap:not(:nth-of-type(3)) {
    background-image: linear-gradient(to right, #9E9E9E, #9E9E9E 3px, transparent 0);
    background-size: 7px 1px;
  }

  .point_description_area .content_wrap::before {
      margin: auto 0;
      width: 58px;
      height: 58px;
      margin-right: 12px;
  }

  .point_description_area .content_wrap p {
      font-size: 16px;
      font-weight: bold;
  }

  .point_description_area .content_wrap p sup {
    font-size: 12px;
  }

  .point_description_area .content_wrap p .text-red {
    font-size: 18px;
    font-weight: bold;
  }

  .simulator_area_inner02 .btn_area_wrap {
    display: none;
    justify-content: center;
    gap: 16px;
    margin-top: 4px;
    margin-bottom: 24px;
  }

  .simulator_area_inner02 .btn_area_wrap .note li {
    text-indent: unset;
    padding-left: unset;
  }

  .simulator_area_inner02 .btn_area_wrap .btn {
    width: 327px;
    height: 56px;
  }

  .simulator_area_inner02 .btn_area_wrap>div:nth-of-type(2) .btn_text {
    font-size: 16px;
  }

  .simulator_area_inner02 .accordion {
    margin-top: 24px;
    margin-bottom: 24px;
  }
  .simulator_area_inner02 .accordion_title {
    padding: 32px 0 32px 40px;
  }
  .simulator_area_inner02 .accordion_content {
    padding: 0 40px 32px;
  }

  .simulator_area_inner02 .accordion_content h5 {
    font-size: 18px;
    margin-bottom: 12px;
  }

  .simulator_area_inner02>.caution_text {
    font-size: 12px;
  }

  /* .nisa */
  .nisa {
    background-color: #F0EEEC;
  }

  .nisa .border {
    padding-top: 0;
  }

  .about-nisa h2 {
    font-size: 24px;
    margin-bottom: 32px;
  }

  .about-nisa .nisa-box {
    border-radius: 8px;
    padding: 12px 0;
    margin-bottom: 24px;
  }

  .about-nisa h2+p {
    font-size: 20px;
    margin-bottom: 24px;
  }

  .about-nisa .bubble_wrap {
    margin-bottom: 8px;
  }

  .about-nisa .bubble_text {
    height: 32px;
    font-size: 15px;
  }

  .about-nisa .nisa-box h3 {
    margin-bottom: 8px;
    font-size: 14px;
    margin-top: 12px;
  }

  .about-nisa .nisa-box img {
    width: 321px;
    margin: 0 auto;
    display: block;
  }

  .about-nisa p {
    font-size: 16px;
  }

  .about-nisa .lead_text {
    width: 320px;
    border-radius: 8px;
    padding: 8px;
    font-size: 20px;
    margin-top: 12px;
  }

  /* .docomo-nisa */
  .docomo-nisa .inner>img {
    width: 363px;
    margin: 0 auto;
    display: block;
  }

  .docomo-nisa .inner:first-of-type {
    padding: 128px 0 0;
  }

  .docomo-nisa .inner:last-of-type {
    padding: 0 0 80px;
    max-width: 1020px;
    margin: 0 auto;
  }

  .docomo-nisa .point-list {
    margin-top: 4.8vw;
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 1005px;
    width: 100%;
    margin: 40px auto 0;
    gap: 16px;
  }

  .docomo-nisa .point-list li {
    margin-top: 0;
    padding: 12px 16px;
    width: 327px;
    min-height: 94px;
    border-radius: 8px;
    height: auto;
    box-sizing: border-box;
  }

  .docomo-nisa .point-list li div img {
    width: 56px;
  }

  .docomo-nisa .point-list li div h3 {
    font-size: 16px;
  }

  .docomo-nisa .point-list li>img {
    width: 58px;
  }

  .docomo-nisa>h3 {
    font-size: 24px;
    margin: 32px auto 0;
    background-image: url(../images/pc/bg-nisa2.png);
    width: 490px;
  }

  .docomo-nisa .btn {
    margin: 32px auto 0;
  }

  .docomo-nisa ul.note {
    margin-top: 32px
  }

  /* .campaign */
  .campaign .inner {
    padding: 80px 0 !important;
  }

  /* .slider */
  .slider_item {
    width: 620px;
    box-shadow: -1px 1px 11.25px 0px rgba(131, 125, 118, 0.33);
    margin: 8px;
  }

  .slider_item:not(:first-of-type) {
    margin-left: 8px;
  }

  /* bnr_flex */
  .campaign .inner .bnr_flex{
    flex-wrap: nowrap;
  }

  .campaign .inner .bnr_flex .bnr_flex_contents{
    width: 620px;
    box-shadow: -1px 1px 11.25px 0px rgba(131, 125, 118, 0.33);
    margin: 8px;
  }

  /* .detail */
  .detail .inner {
    padding: 0 0 50px;
  }

  .detail .accordion_title {
    padding: 20px 0;
  }

  .detail .accordion_content .inner {
    max-width: 1020px;
    width: 100%;
    padding: 50px;
  }

  .detail p {
    font-size: 12px
  }

  .detail h3 {
    font-size: 16px;
  }

  .detail h4 {
    font-size: 14px;
  }

  .detail h5 {
    font-weight: normal;
    font-size: 12px;
  }

  .detail li {
    font-size: 12px;
    margin-top: 4px;
  }

  .detail a {
    margin-top: 1.06666vw;
  }

  .detail dt {
    margin: 0 0 4px;
  }

  .detail dt:not(:first-of-type) {
    margin: 12px 0 4px;
  }

  .detail dd dt {
    margin: 12px 0 4px;
  }

  .detail dd dt:not(:first-of-type) {
    margin: 12px 0 4px;
  }

  .detail dd dd dt {
    margin: 4px 0 4px;
  }

  .detail dd dd dt:not(:first-of-type) {
    margin: 4px 0;
  }

  .detail dd dd dt.mt {
    margin-top: 3.2vw;
  }

  .detail dd dd dd dt {
    margin: 0;
  }

  .detail dd dd dd dt:not(:first-of-type) {
    margin: 2.133333vw 0 0;
  }

  .cp_notes .inner {
    /* width: 100%; */
    padding: 40px 0 !important;
  }

  .cp_notes>.inner>dl {
    padding: 32px 40px;
    border-radius: 12px;
    height: 500px;
  }

  .cp_notes h3,
  .cp_notes h4,
  .cp_notes p,
  .cp_notes li {
    font-size: 12px !important;
  }

  .cp_notes h2 {
    font-size: 18px;
    margin-bottom: 24px;
  }

  .cp_notes h3 {
    margin-top: 24px;
  }

  .cp_notes h4 {
    margin-top: 4px
  }

  .cp_notes span.hyphen {
    margin-top: 4px;
  }

  /* slick */
  .slick-dotted.slick-slider {
    margin-bottom: 0;
  }

  /* .float_bottom */
  .float_bottom {
    padding: 8px 0;
  }

  .float_bottom .btn_wrap {
    width: 496px;
  }

  .float_bottom .btn {
    width: 240px;
  }

  .float_bottom .btn_text {
    font-size: 16px;
  }

  .float_bottom .btn_text span {
    font-size: inherit;
  }

  .float_bottom .slash_wrap {
    margin-bottom: 4px;
  }

  .float_bottom .slash_wrap .slash p {
    font-size: 18px;
  }

  .float_bottom .slash_wrap .slash::before,
  .float_bottom .slash_wrap .slash::after {
    width: 1px;
    height: 18px;
    bottom: 2px;
  }

  .float_bottom .slash_wrap .slash::before {
    left: -0.5em;
  }

  .float_bottom .slash_wrap .slash::after {
    right: -0.5em;
  }

  /* .footer */
  .footer .notes {
    padding: 40px;
  }

  .footer .notes_content {
    padding: 32px 40px;
    border-radius: 12px;
    max-width: 1020px;
    height: 454px;
    margin: 0 auto;
    box-sizing: border-box;
  }

  .footer .notes h2 {
    font-size: 18px;
  }

  .footer .notes h2:not(:first-of-type) {
    margin: 36px 0 14px;
  }

  .footer .notes h3 {
    font-size: 16px;
    margin: 24px 0 16px;
  }

  .footer .notes h4 {
    margin: 16px 0 12px;
  }

  .footer .notes h5 {
    margin: 16px 0 0;
  }

  .footer .notes h5.dot::before {
    width: 0.571428em;
    height: 0.571428em;
    border-radius: 2px;
  }

  .footer .notes ul.dot>li {
    margin-top: 4px;
  }

  .footer .notes h4,
  .footer .notes h5,
  .footer .notes p,
  .footer .notes ul.dot li {
    font-size: 14px;
  }

  .footer .notes p.company {
    margin-top: 40px;
  }

  .footer .notes p.company span {
    display: inline;
  }

  .footer .copy {
    padding: 40px 0 137px;
  }

  .footer .copy p {
    font-size: 12px;
  }

  /* modal */
  .modal {
    width: 100%;
    height: 100%;
  }

  .modal__item {
    width: 90%;
    width: 736px;
    top: 0;
    padding: 56px;
    max-height: 90vh;
    border-radius: 10px;
  }

  .modal__image {
    margin: 0 auto 24px;
  }

  .modal__text {
    font-size: 20px;
    margin: 0 auto 12px;
  }

  .modal__subtext {
    font-size: 16px;
    margin: 0 auto 12px;
  }

  .modal__text-xs {
    font-size: 12px;
  }

  .modal__button {
    top: 24px;
    right: 24px;
    width: 32px;
    height: 32px;
  }

  .modal__item h3 {
    font-size: 24px;
    font-weight: 600;
    margin: 0 auto 16px;
  }

  .modal__item h4 {
    font-size: 20px;
    font-weight: 600;
    margin: 0 auto 16px;
  }

  .modal__item img {
    display: block;
    max-width: 290px;
    margin: 0 auto 16px;
  }

  .modal__item p.lead {
    background-color: #F7F5F5;
    padding: 12px 0;
    border-radius: 50px;
    font-size: 16px;
    font-weight: 600;
    text-align: center;
    margin-top: 20px;
    width: 100%;
    max-width: 300px;
    margin: auto;
  }

  .modal__item img.dots {
    width: 3px;
  }

  .modal__item p {
    font-size: 18px;
  }

  .modal__item .note {
    margin-bottom: 24px;
  }

  .modal__item .caption {
    font-size: 11px;
    margin-bottom: 4px;
  }
    .btn::before {
      left: 6px;
    }
    .btn.icon_type3::before {
      width: 44px;
      height: 44px;
    }
    .btn.icon_type3 .btn_text {
      margin-left: 16px;
      margin-right: 0px
    }
    .float_bottom .btn_text {
      font-size: 16px;
    }
    .fv .btn.btn_type2,
    .float_bottom .btn.btn_type2 {
      margin-bottom: 10px;
    }
    .step-list li .btn {
      margin-bottom: 10px;
    }
  
}


/* 25.01 追加 */
#modal_calc .image-container {
  width: 100%;
  overflow-x: auto;
  white-space: nowrap;
  margin: 1.066vw auto 4.266vw;
}

#modal_calc .scroll-image {
  display: inline-block;
  width: 120vw;
}
@media screen and (min-width: 768px) {
  #modal_calc .scroll-image {
    width: 100%;
    max-width: none;
  }

}

/*fv*/

.fv {
  padding-bottom: 6.4vw;
  background-image: url(../images/fv_background.png);
  background-size: 100%;
  background-repeat: no-repeat;
  background-position-x: 1.6vw;
}

.fv img {
  margin: auto 0;
}

.fv .fv_content_area,
.fv .fv_text_area {
  display: flex;
  padding: 2.67vw 2.67vw 0 4.27vw;
  justify-content: space-between;
}

.fv .logo {
  width: 49.67vw;
  height: 4vw;
}

.fv .Docomo {
  width: 10.135vw;
  position: absolute;
  top: 4vw;
  right: 0;
}

.fv .fv_content_area {
  position: relative;
  flex-direction: column;
  margin: 0 4.27vw 5.33vw;
  padding: 6.4vw 0 0;
}

.fv .fv_content_area::after {
  position: absolute;
  background-image: url(../images/kv_img03.png);
  content: "";
  background-size: 100%;
  width: 25.07vw;
  height: 25.07vw;
  top: 18.07vw;
  right: -1.33vw;
}

.fv .fv_content_area .kv_img01 {
  width: 72vw;
  background-color: unset;
}

.fv .fv_content_area .kv_img02 {
  margin: 3.72vw 0 2.63vw;
  width: 65.87vw;
}

.fv .fv_content_area .kv_img04 {
  width: 58.4vw;
}

.fv .fv_text_area {
  position: relative;
  background-image: url(../images/kv_background.png);
  background-size: 100%;
  background-repeat: no-repeat;
  background-color: #ffffff;
  padding: 2.67vw 2.67vw 3.2vw 2.67vw;
  margin: 0 4.27vw 3.2vw;
  gap: 3.2vw;
  height: 37.6vw;
}

.fv .fv_text_area::after {
  position: absolute;
  background-image: url(../images/kv_poinco.png);
  content: "";
  background-size: 100%;
  width: 34.13vw;
  height: 37.33vw;
  top: -37vw;
  right: 0.53vw;
}

.fv .fv_text_area .kv_img05 {
  width: 17.33vw;
  height: 12.53vw;
}

.fv .fv_text_area img {
  width: 65.6vw;
  height: 26.13vw;
}

.fv .fv_text_area a {
  font-size: 3.2vw;
}

.fv ol.note li,
.fv ul.note li {
  color: #3D3D3D;
}

.fv ol.note li {
  text-indent: -2.5em;
  padding-left: 2.5em;
}

.fv ol.note li::before {
  margin-right: 0.7em;
}

.fv .note {
  padding: 0 4.27vw;
}

.icon_type7 {
  width: 4.53vw;
  height: 4.53vw;
  margin: auto 0;
}

/*lead_area*/
.lead_area {
  background: #FCF5E0;
  padding: 8.53vw 4.27vw;
  display: flex;
  flex-direction: column;
}

.lead_area .bubble_wrap img {
  width: 43.47vw;
  margin: auto;
}

.lead_area .step_area {
  padding: 4.27vw 6.8vw 5.33vw;
  background: #FFFFFF;
  border-radius: 0.53vw;
  display: flex;
  justify-content: center;
  flex-direction: column;
  margin-bottom: 3.2vw;
}

.lead_area .step_area p {
  font-weight: 600;
  font-size: 3.73vw;
}

.under_line {
  border-bottom: 0.8vw solid #FACB32;
  display: inline-block;
  margin-bottom: 1.4vw;
}

.lead_area .step_area .under_line {
  margin: 0 auto;
  text-align: center;
  margin-top: 2.13vw;
}

.lead_area .text_area {
  display: flex;
  justify-content: center;
  gap: 1.07vw;
}

.lead_area .text_area p {
  position: relative;
  font-size: 3.2vw;
}

.anchor_link .bubble_wrap {
  display: flex;
  justify-content: center;
  flex-direction: column;
  padding: 8.53vw 0 0.67vw;
}
.anchor_link .bubble_wrap img {
  width: 61.87vw;
  margin: 0 auto 3.2vw;
}

.anchor_link .bubble_wrap p,
.anchor_link .bubble_wrap h2 {
  font-weight: 700;
  font-size: 7.47vw;
  margin-bottom: 0;
  line-height: 1.26;
}

.anchor_link .bubble_wrap h2 b,
.anchor_link .bubble_wrap p b {
  color: #0054AD;
  font-size: 8.53vw;
  font-weight: 700;
}

.anchor_link .bubble_wrap h2 .b {
  font-size: 8.53vw;
  color: #3D3D3D;
}

.anchor_link .bubble_wrap p .b {
  color: #3D3D3D;
}

.anchor_link_area {
  background-image: url(../images/background-img1.png);
  background-repeat: no-repeat;
  background-size: 100%;
  background-position: top;
}
.anchor_link_area .text_area {
  padding: 21.2vw 4.27vw 3.2vw;
}


.anchor_link_area .text {
  font-weight: 300;
  font-size: 3.73vw;
  padding: 0 4.27vw;
  margin-bottom: -1.2vw;
}

.anchor_link_area .text_area p {
  font-weight: 400;
  padding: 0;
  line-height: 1.2;
}


.anchor_link_area .text_area b {
  font-weight: 600;
  font-size: 4.27vw;
  color: #0054AD;
}

.anchor_link_area .slash_wrap,
.anchor_link_area ul {
  background: #F0F0F0;

}

.anchor_link_area .slash_wrap {
  padding: 8.53vw 0 2.13vw;
}

.anchor_link_area .slash_wrap p {
  font-weight: 600;
  font-size: 3.73vw;
  color: #0054AD;
}

.anchor_link_area ul {
  display: flex;
  justify-content: center;
  gap: 1.87vw;
  padding-bottom: 4.27vw;
  flex-wrap: wrap;
}
.anchor_link_content {
  position: relative;
  background-color: #FCFCFC;
  border: 0.27vw solid #E0DEDC;
  border-radius: 2.13vw;
  display: inline-block;
  width: 44.8vw;
  height: 20.8vw;
  margin-bottom: 0.27vw;
  padding: 4.27vw 0 4.27vw 3.2vw ;
}

.anchor_link_content#case03Anchor {
  padding: 1vw 0 2vw 3.2vw;
}

.anchor_link_content p {
  font-weight: 600;
  font-size: 4.27vw;
  line-height: 1.3;
}

.anchor_link_content#case03Anchor p span {
  font-size: 3.2vw;
}

.anchor_link_content::after {
  content: "";
  background-position: center;
  background-size: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  bottom: 8.27vw;
  margin: auto 0;
  background-repeat: no-repeat;
  background-image: url(../images/btn_arrow.png);
  height: 4.27vw;
  width: 4.27vw;
  right: 3.2vw;
}

/* step */
.step {
  background-color: #E0ECFF;
  background-image: url(../images/background-img2.png);
  background-repeat: no-repeat;
  background-size: 100%;
  background-position: top;
  padding: 20vw 4.27vw 10.67vw;
}

.step div h2 {
  margin: 2.13vw 0 0;
  font-size: 10.67vw;
  line-height: 1.25;
}

.step p {
  font-weight: 600;
  font-size: 4.8vw;
  text-align: center;
}

.step-list .list {
  background: #FFFFFF;
  padding: 4.27vw 4.2vw 8.53vw;
  margin-top: 6.4vw;
  max-width: 1080px;
  border-radius: 0.53vw;
}

.step-list .list .text_area .case {
  width: 26.13vw;
}

.step-list .list .text_area h3 {
  font-weight: 600;
  font-size: 5.83vw;
  margin: 4.27vw 0;
}

.step-list .list .text_area h3 b {
  font-weight: 700;
  font-size: 8.53vw;
}

.step-list .list .text_area p {
  font-weight: 300;
  font-size: 3.73vw;
  text-align: left;
}

.step-list .case01 p.lead_text.sp {
  font-weight: 300;
  font-size: 3.72vw;
  text-align: left;
  margin-top: 6.4vw;
}

.step-list .list .text_area p b {
  font-weight: 400;
}

.main_content_area {
  position: relative;
  margin-top: 10.67vw;
  background: #FCF5E0;
  padding: 10.67vw 4.3vw 7.47vw;
}

.main_content_area::before {
  content: "";
  background-position: center;
  background-size: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: -4.27vw;
  background-repeat: no-repeat;
  background-image: url(../images/bubble1.png);
  width: 43.47vw;
  height: 10.93vw;
  margin: 0 auto;
  right: 0;
  left: 0;
}

.main_content_area ul {
  padding-left: 5.87vw;
}

.main_content_area li {
  position: relative;
  margin-top: 6.4vw;
}

.case01 .main_content_area .text_area li {
  margin-top: 0;
}
.case01 .main_content_area .text_area li p {
  font-weight: 600;
  font-size: 4.8vw;
  margin-top: 0;
  padding: 0;
}

.case01 .main_content_area .text_area p.lead_text {
  margin: 0 0 6.4vw;
  padding: 0;
}

.case01 .main_content_area .text_area {
  margin-bottom: 4.27vw;
  position: relative;
}

.case01 .main_content_area .text_area::after {
  position: absolute;
  content: "";
  background-image: url(../images/flag_img.png);
  background-size: 100%;
  height: 20vw;
  width: 20vw;
  top: -5.33vw;
  right: -7.07vw;

}


.case01 .main_content_area .text_area p {
  margin-top: 3.2vw;
  font-size: 3.72vw;
  font-weight: 300;
  text-align: left;
  padding: 1vw;
}
.case01 .main_content_area .text_area p b {
  font-weight: 600;
}
.main_content_area ol.note li {
  text-indent: -2em;
  padding-left: 2em;
  margin-top: 2.14vw;
}

.main_content_area ol.note li a {
  position: sticky;
  display: inline;
  margin-left: 0;
}

.main_content_area ol.note li::before {
  counter-increment: number 1;
  position: static;
  display: inline;
  content: '※' counter(number);
  font-size: inherit;
  margin-right: 0.5em;
  background-image: none;
  margin: 0 0.5em 0 0;
}

.main_content_area li::before {
  background-image: url(../images/icon_type8.svg);
  content: '';
  background-position: center;
  background-size: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: 1.3vw 0;
  height: 4.8vw;
  width: 4.8vw;
  left: -5.87vw;
}

.main_content_area li p {
  text-align: left;
}

.main_content_area li p b{
  font-size: 3.73vw;
  font-weight: 600;
}

.main_content_area li a {
  position: absolute;
  display: inline-flex;
  bottom: 0.53vw;
  margin-left: 0.93vw;
}


.main_content_area li img {
  width: 5.6vw;
  height: 5.6vw;
}

.main_content_area .note {
  padding: 0;

}
.main_content_area ul.note li::before {
  background-image: none;
  position: static;
  display: inline;
}

.accordion .accordion_content .text_area div {
  display: flex;
  margin-bottom: 2.13vw;
}
.accordion .accordion_content .text_area .icon_type7 {
  width: 4.27vw;
  height: 4.27vw;
}

.accordion .accordion_content .text_area h3 {
  font-size: 3.73vw;
  margin: 0 0 0 1.07vw;
}
.accordion .accordion_content .text_area:nth-child(2){
margin-top: 5.33vw;
}

.case02 .main_content_area {
  padding: 9.6vw 11.47vw 5.33vw 4.27vw;
  z-index: 1;
}

.case02 .main_content_area::after {
  position: absolute;
  background-image: url(../images/case02_bg_img.png);
  background-size: 100%;
  background-repeat: no-repeat;
  content: "";
  height: 36vw;
  width: 85.27vw;
  z-index: -1;
  top: -2.13vw;
  left: -1.07vw;
}

.case02 .main_content_area li  {
  margin: 0 0 2.13vw 0 ;
}

.case02 .main_content_area li p {
  font-size: 4.8vw;
  font-weight: 600;
}

.case02 .main_content_area p {
  font-size: 3.73vw;
  font-weight: 300;
  text-align: left;
}

.case02 .main_content_area p b {
  font-weight: 600;
}

.case03 .main_content_area {
  padding: 10.67vw 0 7.47vw;
}

.case03 .main_content_area  div {
  padding: 0 4.24vw;
}

.case03 .main_content_area li {
  margin-top: 0;
  margin-bottom: 2.13vw;
}

.case03 .main_content_area li p {
  font-weight: 400;

}

.case03 .main_content_area li p b,
.case03 .main_content_area li p {
  font-size: 4.8vw;
}

.case03 .main_content_area p {
  font-weight: 300;
  font-size: 3.73vw;
  text-align: left;
}

.main_content_area .modal_area {
  margin: 3.2vw auto 6.4vw;
  display: flex;
  flex-direction: column;
  gap: 1.07vw;
  padding: 0 4.24vw;
}

.main_content_area .modal_area a {
  position: relative;
  border-radius: 2.13vw;
  border: 0.27vw solid #E0DEDC;
  background: #FFFFFF;
  padding: 3.2vw;
  display: flex;
}

.main_content_area .modal_area a::after {
  position: absolute;
  background-image: url(../images/icon_type10.svg);
  content: '';
  background-position: center;
  background-size: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  bottom: 2.13vw;
  right: 2.13vw;
  width: 4.27vw;
  height: 4.27vw;
}

.main_content_area .modal_area a div {
  display: flex;
  flex-direction: column;
  justify-content: center;
  margin-left: 2.13vw;
  padding: 0;
}

.main_content_area .modal_area a img {
  width: 21.33vw;
  height: 22.93vw;
}

.main_content_area .modal_area h3 {
  font-weight: 600;
  font-size: 3.2vw;
  margin-bottom: 1.07vw;
}

.main_content_area .modal_area p {
  font-weight: 300;
  font-size: 2.93vw;
}

.case03 .main_content_area .slider {
  padding: 0;
}

/* .slider */
.case03 .main_content_area .campaign_box {
  padding: 0;
}
.case03 .main_content_area .slider_item {
  margin: 1.07vw;
}

.case03 .main_content_area .slider_item::before,
.main_content_area .slick-dots li::before {
  content: none;
}

.case03 .main_content_area .slider_item a {
  position: static;
  display: block;
  margin: 0;
}

.case03 .main_content_area .slider_item a img {
  width: 61.33vw;
  height: 22.67vw;
}

.case03 .main_content_area .slider_item:not(:first-of-type) {
  margin-left: 2.133333vw;
}
.main_content_area .slick-dots {
  padding: 0;
}

.case04 .text_area h3 .p {
letter-spacing: -0.8vw;
}

.case04 .main_content_area {
  background: none;
  padding: 8vw 0 4.24vw;
  margin-top: 10.67vw;
}

.main_content_area .img_area ul {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding: 0;
  background-image: url(../images/case04_bg_img.png);
  background-size: 48vw;
  background-repeat: no-repeat;
  background-position-x: 50%;
  background-position-y: 45%;
}
.main_content_area .img_area ul::after {
  position: absolute;
  content: "";
  background-image: url(../images/poinco.png);
  background-size: 100%;
  width: 29.07vw;
  height: 31.73vw;
  top: 33.5%;
  left: 29%;
  background-repeat: no-repeat;
}


.img_area ul li {
  width: 38.67vw;
  background: #FCF5E0;
  margin-top: 4.27vw;
  border-radius: 0.53vw;
}
.img_area ul li .list_content {
  padding: 3.2VW 2.13vw  3.73vw;
}
.img_area ul li::before {
  background-image: none;
  content: none;
}

.list1 .img_header,
.list3 .img_header {
  background: #FACB32;
  text-align: center;
}

.list2 .img_header,
.list4 .img_header {
  background: #CADFFF;
  text-align: center;
}

.list1,
.list2 {
  margin-bottom: 8.53vw;
}

.img_area ul li .img_header p {
  font-size: 3.2vw;
  font-weight: 700;
}

.img_area ul li p {
  text-align: center;
  font-size: 3.2vw;
  font-weight: 300;
}

.img_area ul li p b {
  font-size: 3.73vw;
  font-weight: 700;
}

.img_area ul .list1 .list_content div:first-of-type p,
.img_area ul .list2 .list_content p:first-of-type {
  position: relative;
}

.img_area ul .list1 .list_content div:first-of-type p::after,
.img_area ul .list2 .list_content p:first-of-type::after {
  position: absolute;
  font-size: 2.933vw;
}

.img_area ul .list1 .list_content div:first-of-type p::after {
  content: "※1";
}
.img_area ul .list1 .list_content div:first-of-type .b-color p::after {
  content: none;
}

.img_area ul .list2 .list_content p:first-of-type::after {
  content: "※2";
}


.img_area ul .list1 .img_box {
  display: flex;
  margin-top: 1.07vw;
}

.img_area ul .list1 img {
  width: 22.13vw;
  height: 14.4vw;
  margin: 0 auto 3.2vw;
}

.img_area ul .b-color {
  background: #FFFFFF;
  border-radius: 0.53vw;
  padding: 1.07vw 0;
}

.img_area ul .b-color p {
  color: #0054AD;
  font-weight: 600;
  font-size: 2.67vw;
}

.img_area ul .list2 .img_box {
  display: flex;
  margin-top: 0.53vw;
}

.img_area ul .list2 img {
  width: 34.4vw;
  height: 23.4vw;
  margin: 0 auto 2.67vw;
}

.img_area ul .list3 p .p {
  letter-spacing: -0.8vw;
}

.img_area ul .list3 .img_box {
  display: flex;
  margin-top: 2.63vw;
}

.img_area ul .list3 img {
  width: 34.4vw;
  height: 32.53vw;
  margin: 0 auto ;
}

.img_area ul .list4 .img_box {
  display: flex;
  margin-top: 1.07vw;
}

.img_area ul .list4 img {
  width: 34.4vw;
  height: 26vw;
  margin: 0 auto 1.6vw;
}
.img_area ul .list4 .b-color p {
  font-size: 2.4vw;
}

.img_area ul .list4 a.link.icon.icon_type1 {
  font-size: 2.93vw;
  font-weight: 300;
  position: relative;
  display: block;
  margin: 1.07vw 2.67vw 0;
  bottom: 0;
  padding: 0;
}

@media screen and (min-width: 768px) {

  .fv {
    padding-bottom: 29px;
    background-image: url(../images/pc/fv_background.png);
    background-position-x: 350px;
  }

  .fv .inner {
    max-width: 896px;
    width: 80%;
    margin: auto;
  }

  .fv .heaer_area,
  .fv .fv_content_area,
  .fv .fv_text_area {
    display: flex;
    padding: 0;
    justify-content: space-between;
    margin: auto;
  }

  .fv .heaer_area a {
    margin: 24px 0 0;
  }

  .fv .logo {
    width: 286.22px;
    height: 23px;
  }

  .fv .Docomo {
    width: 50px;
    top: 32px;
  }

  .fv .fv_content_area {
    padding-top: 38px;
  }

  .fv .fv_content_area::after {
    position: absolute;
    background-image: url(../images/pc/kv_img03.png);
    content: "";
    background-size: 100%;
    width: 130px;
    height: 130px;
    top: 87px;
    right: 37px;
  }
  .fv .fv_content_area .kv_img01 {
    width: 727px;
  }


  .fv .fv_text_area {
    background-image: url(../images/pc/kv_background.png);
    gap: 20px;
    justify-content: center;
    height: 119px;
    margin-top: 20px;
  }
  .fv .fv_text_area::after {
    background-image: url(../images/pc/kv_poinco.png);
    width: 202px;
    height: 192px;
    top: -192px;
    right: 11px;
  }

  .fv .fv_text_area div {
    margin: auto 0;
  }

  .fv .fv_text_area .kv_img05 {
    width: 137px;
    height: 78.03px;
  }

  .fv .fv_text_area img {
    width: 615px;
    height: 63px;
  }

  .fv .fv_text_area a {
    font-size: 14px;
  }

  .fv .note {
    padding: 0;
  }
  .lead_area {
    padding: 56px 0;
  }

  .lead_area .bubble_wrap img {
    width: 207px;
    margin-bottom: 4px;
  }

  .lead_area h3 {
    font-size: 24px;

  }

  .lead_area .step_area {
    padding: 24px 32px ;
    width: 648px;
    margin: 10px auto 16px;
  }
  .lead_area .step_area .under_line {
    margin-top: 8px;
    font-size: 18px;
  }

  .icon_type7 {
    height: 22px;
    width: 22px;
  }

  .lead_area .text_area {
    gap: 8px;
  }
  .lead_area .text_area p {
    font-size: 18px;
  }

  .anchor_link .bubble_wrap {
    padding: 50px 0 0;
    height: 155px;
  }

  .anchor_link .bubble_wrap img {
    width: 292px;
    margin: 56px auto 12px;
  }

  .anchor_link .bubble_wrap p,
  .anchor_link .bubble_wrap h2 {
    font-size: 32px;
   }

  .anchor_link .bubble_wrap h2 b,
  .anchor_link .bubble_wrap h2 .b,
  .anchor_link .bubble_wrap p b {
    font-size: 40px;
  }

  .anchor_link_area {
    text-align: center;
    background-image: url(../images/pc/background-img1.png);
  }

  .anchor_link_area .text_area {
    padding: 110px 0 8px;
  }

  .anchor_link_area .text_area p {
    font-weight: 600;
    font-size: 14px;
  }

  .anchor_link_area .text_area p b {
    font-size: 16px;
  }

  .anchor_link_area .text_area p .b {
    color: #3D3D3D;

  }
  .under_line.pc {
    border-bottom: 3px solid #FACB32;
    display: inline-block!important;
    margin-bottom: 0;
  }


  .anchor_link_area .text {
    font-size: 16px;
    padding: 0;
    background-color: #F0F0F0;
  }

  .anchor_link_area .slash_wrap {
    padding: 59px 0 16px;
  }

  .anchor_link_area .slash_wrap p {
    font-size: 22px;
  }

  .anchor_link_area ul {
    justify-content: center;
    gap: 24px;
    padding-bottom: 32px;
  }

  .anchor_link_content {
    border: 1px solid #E0DEDC;
    border-radius: 8px;
    max-width: 252px;
    height: 87px;
    padding: 0;
    display: flex;
    text-align: left;
    margin-bottom: 0;
  }

  .anchor_link_content#case03Anchor {
    padding: 0;
  }

  .anchor_link_content p {
    font-size: 18px;
    margin: auto 0 auto 24px;
  }

    .anchor_link_content#case03Anchor p {
    margin-top: 3px;
  }

  .anchor_link_content#case03Anchor p span {
    font-size: 12px;
    line-height: 1.1;
  }

  .anchor_link_area li:nth-child(3n) .anchor_link_content p:nth-child(1) {
    padding: 0;
  }

  .anchor_link_content::after {
    height: 18px;
    width: 18px;
    right: 16px;
    bottom: 0;
    top: 0;
  }


  .step {
    background-image: url(../images/pc/background-img2.png);
    padding: 126px 100px 56px ;
  }

  .step p {
    font-size: 22px;
  }

  .main_content_area li p b {
    font-size: 16px;
  }

  .step div h2 {
    font-size: 48px;
    margin-top: 8px;
  }

  .step-list-container {
    display: flex;
  }

  .step-list {
    margin: 8px auto 0;
    max-width: 1080px;
  }

  .step-list .list {
    padding: 64px 67.5px ;
    margin-top: 24px;
    border-radius: 2px;
  }
  .step-list .list .text_area .case {
    width: 98px;
    height: 33px;
  }

  .step-list .list .text_area h3 {
    font-size: 24px;
    margin: 24px 0 16px;
  }

  .lead_area .step_area .under_line {
    border-bottom: 3px solid #FACB32;
  }

  .step-list .list .text_area h3 b {
    font-size: 40px;
  }

  .step-list .list .text_area p {
    font-size: 16px;
  }
  .step-list .list .text_area .lead_text.pc {
    margin-top: 8px;
  }

  .step-list .case01 .d-flex img {
    max-width: 368px;
    max-height: 265px;
  }

  .step-list .case01 .text_area {
    max-width: 552px;
  }

  .step-list .case01 .d-flex {
    display: flex;
    justify-content: space-between;
    gap: 24px;
    align-items: end;
  }

  .main_content_area {
    margin-top: 48px;
    padding: 32px 24px 32px;
  }

  .main_content_area::before {
    background-image: url(../images/bubble1.png);
    width: 207px;
    height: 60px;
    top: -28px;
  }
  .step-list .case01 .main_content_area {
    width: 100%;
  }
  .main_content_area ol.note li {
    margin-top: 4px;
  }

  .main_content_area ul {
    padding-left: 30px;
  }

  .main_content_area li {
    margin-top: 24px;
  }

  .main_content_area li::before {
    height: 22px;
    width: 22px;
    margin: auto 0;
    left: -30px;
  }

  .main_content_area li p b, {
    font-size: 16px;
  }

  .main_content_area li a {
    margin-left: 3px;
    bottom: 5px;
  }

  .main_content_area li img {
    height: 21px;
    width: 21px;
  }

  .main_content_area .note {
    margin-top: 4px;
  }

  .step-list .case01 .main_content_area .text_area {
    max-width: 896px;
    margin-bottom: 24px;
  }
  .case01 .main_content_area .text_area p {
    padding: 0;
    margin-top: 12px;
  }
  .case01 .main_content_area .text_area p.lead_text {
    margin: 0 0 24px;
  }

.case01 .main_content_area .text_area li p {
  font-size: 22px;
  margin-top: 0;
  padding: 0;
}
  .case01 .grant-accordion {
    margin-top: 24px;
  }

  .accordion {
  border: 1px solid #E0DEDC;
  border-radius: 8px;
  }
  .grant-accordion .accordion_title {
    padding: 20px 0 20px 16px;
  }
    .grant-accordion .accordion_title h3 {
      font-size: 18px;
  }
  .accordion_title::before,
  .accordion_title::after {
    right: 16px;
  }
  .grant-accordion .accordion_content {
    padding: 0 16px 20px;
  }


  .accordion .accordion_content .text_area div {
    margin-bottom: 8px;
  }

  .accordion .accordion_content .text_area .icon_type7 {
    height: 16px;
    width: 16px;
    margin-right: 4px;
  }

  .accordion .accordion_content .text_area h3 {
    font-size: 16px;
    margin: 0;
  }

  .accordion .accordion_content .text_area:nth-child(2) {
    margin-top: 20px;
  }

  .case01 .case01_img02 {
    margin-top: 7.39px;
  }
  .case01 .img_area {
    display: flex;
    justify-content: center;
    gap: 24px;
  }
  .case01 .img_area .case01_img03 {
    width: 394px;
    height: 153px;
  }
  .case01 .img_area .case01_img04 {
    width: 896px;
  }

.case02 .main_content_area {
  padding: 40px 24px;
  margin-top: 64px;
}

  .case02 .main_content_area li p,
  .case03 .main_content_area li p b,
  .case03 .main_content_area li p {
    font-size: 22px;
  }

  .case02 .main_content_area p,
  .case03 .main_content_area p {
    font-size: 16px;
  }

  .case02 .main_content_area::after {
    background-image: url(../images/pc/case02_bg_img.png);
    height: 100%;
    width: 104.5%;
    top: -25%;
    left: -3%;
  }
  .step-list .case03 .text_area h3 {
    margin: 16px 0;
  }
  .case03 .main_content_area {
    margin-top: 64px;
    padding: 48px 0 40px;
  }
.case03 .main_content_area div {
  padding: 0 24px;
}

  .main_content_area .modal_area {
    margin: 16px 0 32px;
    flex-direction: row;
  }

  .main_content_area .modal_area a {
    border-radius: 8px;
    border: 1px solid #E0DEDC;
    padding: 12px 16px;
  }

  .main_content_area .modal_area a img {
    width: 80px;
    height: 86px;
  }

  .main_content_area .modal_area a div {
    margin-left: 8px;
  }

  .main_content_area .modal_area h3 {
    font-size: 16px;
    margin-bottom: 4px;
  }

  .main_content_area .modal_area p {
    font-size: 14px;
  }

  .main_content_area .modal_area a::after {
    width: 18px;
    height: 18px;
    bottom: 8px;
    right: 8px;
  }

  .case03 .main_content_area li,
  .case02 .main_content_area li {
    margin-bottom: 16px;
  }

  .case03 .main_content_area .campaign_box {
    padding: 0 24px;
  }

  .case03 .main_content_area .slider_item {
    width: 343px;
    margin: 0 12px 12px;
    box-shadow: none;
  }
  .case03 .main_content_area .slider_item a img {
    width: 343px;
    height: 128px;
  }
  .case03 .main_content_area .slider_item:not(:first-of-type) {
    margin-left: 0;
  }

  
  .step-list .case04 .text_area h3 {
    margin-top: 16px;
  }

  .case04 .main_content_area {
    margin-top: 62.61px;
    padding: 32px 0 0 0;
  }

  .img_area ul li {
    max-width: 460px;
    margin-top: 24px;
    border-radius: 2px;
  }

  .img_area ul li .img_header {
    border-top-left-radius: 2px;
    border-top-right-radius: 2px;
  }

  .img_area ul li .img_header p,
  .img_area ul li p b {
    font-size: 16px;
    font-weight: 600;
  }
  .img_area ul li p {
    font-size: 16px;
  }

  .img_area ul .list1 .list_content,
  .img_area ul .list2 .list_content,
  .img_area ul .list3 .list_content,
  .img_area ul .list4 .list_content {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 30px 42px 30px 25px;
    gap: 16px;
  }

.img_area ul .list1 .img_box {
  margin: 0;
}

.img_area ul .list1 .list_content div:first-of-type p::after,
.img_area ul .list2 .list_content p:first-of-type::after {
  font-size: 12px;
}

  .img_area ul .list1 img {
    width: 120px;
    height: 81px;
    margin: 0;
  }

  .img_area ul .b-color {
    padding: 4px 8px;
  }

  .img_area ul .b-color p,
  .img_area ul .list4 .b-color p {
    font-size: 14px;
  }

  .img_area ul .list2 .list_content {
    padding: 24px 32px 24px 24px;
  }
  .img_area ul li .list_content div {
    margin: auto;
  }
  .img_area ul .list2 img {
    width: 187px;
    height: 40px;
    margin: 0 auto;
  }

  .img_area ul .list2 .img_box img {
    width: 146px;
    height: 93px;
  }
  .list1,
  .list2 {
    margin-bottom: 25px;
  }
  .img_area ul .list3 p {
    font-size: 14px;
  }
  .img_area ul .list3 p .p {
    letter-spacing: 0;
  }

  .img_area ul .list3 .list_content {
    padding: 34px 24px 34px 21px;
  }

  .img_area ul .list3 .img_box {
    margin: 0;
  }

  .img_area ul .list3 img {
    width: 146px;
    height: 75px;
    margin: auto;
  }

  .img_area ul .list4 .b-color {
    margin: 4px auto;
  }

  .img_area ul .list4 .img_box {
    margin: 0;
  }

  .img_area ul .list4 a.link.icon.icon_type1 {
    font-size: 12px;
    margin: 0;
  }

  .img_area ul .list4 img {
    width: 146px;
    height: 122px;
    margin: 0;
  }

  .main_content_area .img_area ul::after {
    width: 150px;
    height: 164px;
    top: 28%;
    left: 40%;
  }
  .main_content_area .img_area ul {
    background-size: 320px;
    background-position-y: 60%;
  }
  .img_area ul .list4 .list_content {
    padding: 12px 32px 24px 24px;
  }
  .img_area ul .list4 .list_content div:first-child {
    padding-top: 9px;
  }
  .case04 .note {
    margin-top: 16px;
  }

  .btn.btn_type2 {
    box-shadow: 0px 5px 0px 0px #800000;
    transition: box-shadow 0.1s ease-in-out;
  }

  .btn.btn_type2:hover {
    box-shadow: 0px 3px 0px 0px #800000;
    transform: translateY(2px);
  }
  .btn_type3 {
    box-shadow: 0px 5px 0px 0px #CB9700;
    transition: box-shadow 0.1s ease-in-out;
  }
  .btn_type3:hover {
    box-shadow: 0px 3px 0px 0px #CB9700;
    transform: translateY(2px);
  }

  .btn.btn_type1 {
    box-shadow: 0px 5px 0px 0px #B3B3B3;
    transition: box-shadow 0.1s ease-in-out;
  }

    .btn.btn_type1:hover {
    box-shadow: 0px 3px 0px 0px #B3B3B3;
    transform: translateY(2px);
  }

  .modal__item {
    max-width: 700px;
    padding: 40px 24px 24px 24px;
    border-radius: 12px;
  }

  .modal__item p:first-of-type {
    margin-bottom: 16px;
  }

  .modal__item .img_area {
    margin-bottom: 16px;
    gap: 8px;
    justify-content: center;
  }

  #modal_about .img_area img {
    width: 140px;
    height: 140px;
  }

  .modal__item p:last-of-type {
    margin-top: 12px;
  }

  #app01 .img_area img,
  #app02 .img_area img {
    margin-top: 0;
  }
  .modal__item .d-flex {
    display: flex;
    justify-content: center;
  }
  .modal__item .d-flex .img_area {
    margin-bottom: 0;
  }
  #app01 .img_area img,
  #app02 .img_area img {
    width: 318px;
    height: 167px;
  }
  .modal__item ul {
    padding: 29.5px 0 29.5px 16px;
  }
  .modal__item ul li {
    text-indent: -20px;
    padding-left: 20px;
    font-weight: 300;
    font-size: 16px;
  }
  .modal__item ul li:nth-child(1),
  .modal__item ul li:nth-child(2) {
    margin-bottom: 8px;
  }
  .float_bottom .btn {
    width: 327px;
  }
  .simulator_area.title_wrap .triangle {
    height: 10px;
    width: 24px;
  }
  .simulator_area.title_wrap .bubble {
    border-radius: 3px;
  }
  .step-list .list .text_area p b {
    font-weight: 600;
  }
  .modal__item ul li::before {
    margin-right: 4px;
  }
  .simulator_area {
    padding-bottom: 0;
  }

  .step-list .case01 .accordion_content .text_area {
    max-width: 100%;
  }
    .case01 .main_content_area .text_area::after {
      content: none;
    height: 70px;
    width: 70px;
    top: -12px;
  }

  .case01 .main_content_area .text_area .flag {
    position: absolute;
    width: 120px;
    height: auto;
    right: -2px;
    top: -44px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1279px) {
  .anchor_link_area ul {
    gap: 1.88vw;
    padding-bottom: 2.5vw;
  }
  .anchor_link_content {
    max-width: 19.69vw;
    border-radius: 0.63vw;
    height: 6.8vw;
    padding: 0;
  }
  .anchor_link_content p {
    font-size: 1.41vw;
    margin: auto 0 auto 1.88vw;
  }
  .anchor_link_content#case03Anchor p span {
    font-size: 0.94vw;
  }
  .step-list .list {
    padding: 5vw 5.31vw;
    margin-top: 1.88vw;
    border-radius: 0.16vw;
  }
  .step-list .case01 .d-flex {
    gap: 1.88vw;
  }
  .anchor_link_content::after {
    height: 1.41vw;
    width: 1.41vw;
    right: 1.25vw;
  }
  .step-list .case01 .text_area {
    max-width: 43.13vw;
  }
  .case01 .main_content_area .text_area::after {
    height: 5.47vw;
    width: 5.47vw;
    top: -0.94vw;
    right: 0;
  }
  .step-list .case01 .d-flex img {
    max-width: 28.75vw;
    max-height: 20.75vw;
  }

  .main_content_area {
    margin-top: 3.75vw;
    padding: 2.5vw 1.88vw 2.5vw;
  }

  .case01 .img_area .case01_img03 {
    max-width: 30.78vw;
    height: 11.95vw;
  }
  .case01 .img_area .case01_img04 {
    width: 70vw;
  }
  .main_content_area .note {
    margin-top: 0.63vw;
  }
  .case02 .main_content_area {
    padding: 3.13vw 1.88vw;
    margin-top: 5vw;
  }
  .step {
    padding: 9.84vw 7.81vw  4.38vw;
  }
  .step-list {
    max-width: 84.38vw;
    margin: 0.63vw auto 0;
  }
  /* .slider */
  .case03 .main_content_area .campaign_box {
    padding: 0;
  }
  .case03 .main_content_area .slider_item {
    margin: 1.07vw;
  }

  .case03 .main_content_area .slider_item::before,
  .main_content_area .slick-dots li::before {
    content: none;
  }

  .case03 .main_content_area .slider_item a {
    position: static;
    display: block;
    margin: 0;
  }

  .case03 .main_content_area .slider_item a img {
    width: 26.8vw;
    height: 10vw;
  }
  .case03 .main_content_area .slider_item {
      width: 26.8vw;
  }

  .case03 .main_content_area .slider_item:not(:first-of-type) {
    margin-left: 2.133333vw;
  }
  .main_content_area .slick-dots {
    padding: 0;
  }

  .img_area ul li {
    width: 35.94vw;
  }
  .img_area ul .list1 .list_content,
  .img_area ul .list2 .list_content,
  .img_area ul .list3 .list_content,
  .img_area ul .list4.list_content {
    padding: 2.34vw 3.28vw 2.34vw 1.95vw;
    gap:  1.25vw;
  }

  .img_area ul .list1 .list_content,
  .img_area ul .list2 .list_content,
  .img_area ul .list3 .list_content,
  .img_area ul .list4 .list_content {

  }

  .img_area ul li p {
    font-size: 1.25vw;
  }
  .img_area ul li .img_header p,
  .img_area ul li p b {
    font-size: 1.25vw;
  }
  .img_area ul .list1 .list_content div:first-of-type p::after,
  .img_area ul .list2 .list_content p:first-of-type::after {
    font-size: 0.94vw;
  }
  .img_area ul .b-color {
    padding: 0.31vw 0.63vw;
  }
  .img_area ul .b-color p,
  .img_area ul .list4 .b-color p,
  .img_area ul .list3 p {
    font-size: 1.09vw;
  }
  .img_area ul .list1 img {
    width: 9.38vw;
    height: 6.33vw;
  }
  .img_area ul .list2 img {
    width: 14.61vw;
    height: 3.12vw;
  }
  .img_area ul .list2 .img_box img {
    width: 11.41vw;
    height: 7.27vw;
  }
  .img_area ul .list3 img {
    width: 11.41vw;
    height:5.86vw;
  }
  .img_area ul .list4 .b-color {
    margin: 0.31vw 0;
  }
  .img_area ul .list4 a.link.icon.icon_type1 {
    font-size: 0.94vw;
  }
  .img_area ul .list4 img {
    width: 11.41vw;
    height: 9.2vw;
  }
  .main_content_area .img_area ul::after {
    width: 11.72vw;
    height: 12.81vw;
    top: 28%;
    left: 40%;
  }
  .main_content_area .img_area ul {
    background-size: 25vw;
  }
  .img_area ul .list4 .list_content div:first-child {
    margin-top: 0.7vw;
  }
  .img_area ul .list4 .list_content {
    padding: 0.94vw 2.5vw 1.88vw 1.88vw;
  }
  .step-list .case01 .accordion_content .text_area {
    max-width: 100%;
  }
  .fv .fv_text_area .kv_img05 {
    width: 10.7vw;
    height: 6.09vw;
  }
  .fv .fv_text_area img {
    width: 48.05vw;
    height: 4.92vw;
  }
  .fv .fv_content_area .kv_img01 {
    width: 56.8vw;
  }

  .fv .fv_text_area::after {
    width: 15.78vw;
    height: 15vw;
    top: -14.9vw;
    right: 0.94vw;
  }
  .fv .fv_content_area::after {
    width: 10.16vw;
    height: 10.16vw;
    top: 6.8vw;
    right: 3.05vw;
  }
  .fv .fv_text_area {
    gap: 2.5vw;
    height: 9.3vw;

  }
  .anchor_link .bubble_wrap p,
  .anchor_link .bubble_wrap h2 {
    font-size: 2.5vw;
  }

  .anchor_link .bubble_wrap h2 b,
  .anchor_link .bubble_wrap h2 .b
  .anchor_link .bubble_wrap p b {
    font-size: 3.13vw;
  }
  .step-list .list .text_area h3 {
    font-size: 1.88vw;
    margin: 1.88vw 0 1.25vw;
  }
  .step-list .list .text_area h3 b {
    font-size: 3.13vw;
  }
  .step p,
  .case01 .main_content_area .text_area li p,
  .case02 .main_content_area li p,
  .case03 .main_content_area li p b,
  .case03 .main_content_area li p  {
    font-size: 1.72vw;
  }
  .main_content_area li img {
    height: 1.64vw;
    width: 1.64vw;
  }
  .main_content_area li::before {
    height: 1.72vw;
    width: 1.72vw;
    left: -2.34vw;
  }
  .main_content_area ul {
    padding-left: 2.34vw;
  }
  .anchor_link_area .text_area {
    padding: 8.44vw 0 0.63vw;
  }
  .case03 .main_content_area .campaign_box,
  .case03 .main_content_area div {
    padding: 0 1.88vw;
  }
  section.dcard .inner.simulator_header_inner,
   section.dcard .inner.simulator_area_inner{
    width: auto;
    margin: auto 7.81vw;
  }
  .footer .notes {
    padding: 3.13vw 7.81vw;
  }
    .case01 .main_content_area .text_area .flag {
    position: absolute;
    width: 9.38vw;
    height: auto;
    right: -0.16vw;
    top: -4.44vw;
  }
  .fv {
    padding-bottom: 2.27vw;
    background-position-x: 27.34vw;
  }

  .fv .inner {
    max-width: 70vw;
  }

  .fv .fv_content_area {
    padding-top: 2.97vw;
  }
  .fv .Docomo {
    width: 3.91vw;
    top: 2.5vw;
  }
  ul.note li, ol.note li, ul.dot li, ol.num li {
    font-size: 1.1vw;
  }

  .fv .fv_text_area a {
    font-size: 1.09vw;
  }

  .lead_area {
    padding: 4.38vw 0;
  }

  .lead_area .bubble_wrap {
    padding-bottom: 0.47vw;
  }

  .lead_area .bubble_wrap img {
    width: 16.7vw;
    margin-bottom: 0.31vw;
  }

  .lead_area h3 {
    font-size: 1.88vw;
  }

  .lead_area .step_area {
    padding: 1.88vw 2.5vw;
    width: 50.63vw;
    margin: 0.78vw auto 1.25vw;
  }

  .lead_area .step_area .under_line {
    margin-bottom: 0.63vw;
    font-size: 1.41vw;
    border-bottom: 0.23vw solid #FACB32;
  }

  .lead_area .text_area {
    gap: 0.63vw;
  }

  .icon_type7 {
    height: 1.72vw;
    width: 1.72vw;
  }

  .lead_area .text_area p {
    font-size: 1.41vw;
  }

  .anchor_link .bubble_wrap {
    padding: 3.91vw 0 0;
    height: 12.11vw;
  }

  .anchor_link .bubble_wrap img {
    width: 22.81vw;
    margin: 4.38vw auto 0.94vw;
  }

  .anchor_link .bubble_wrap h2 b,
  .anchor_link .bubble_wrap h2 .b,
  .anchor_link .bubble_wrap p b {
    font-size: 3.13vw;
  }

  .anchor_link_area .text_area p {
    font-size: 1.09vw;
  }

  .anchor_link_area .text_area p b {
    font-size: 1.25vw;
  }

  .under_line.pc {
    border-bottom: 0.23vw solid #FACB32;
  }

  .anchor_link_area .text {
    font-size: 1.25vw;
  }

  .anchor_link_area .slash_wrap {
    padding: 4.61vw 0 1.25vw;
  }

  .anchor_link_area .slash_wrap p {
    font-size: 1.72vw;
  }

  .slash_wrap .slash::before,
  .slash_wrap .slash::after {
    width: 0.2vw;
    height: 1.95vw;
    bottom: 0.31vw;
  }
  .step div h2 {
    font-size: 3.75vw;
    margin-top: 0.63vw;
  }
  .step-list .list .text_area .case {
    width: 7.66vw;
    height: 2.58vw;
  }
  .step-list .list .text_area p {
    font-size: 1.25vw;
  }
  .step-list .list .text_area .lead_text.pc {
    margin-top: 0.63vw;
  }
  .main_content_area::before {
    width: 16.17vw;
    height: 4.69vw;
    top: -2.19vw;
  }
  .step-list .case01 .main_content_area .text_area {
    max-width: 70vw;
    margin-bottom: 1.88vw;
  }

  .case01 .main_content_area .text_area p {
    margin-top: 0.92vw;
  }
  .main_content_area li {
    margin-top:1.88vw;
  }

  .case03 .main_content_area li,
  .case02 .main_content_area li {
    margin-bottom: 1.25vw;
  }

  .case02 .main_content_area p,
  .case03 .main_content_area p {
    font-size: 1.25vw;
  }
  .case03 .main_content_area {
    margin-top: 5vw;
    padding: 3.75vw 0 3.13vw;
  }

  .main_content_area .modal_area P{
    margin: 1.25vw 0 2.5vw;
  }

  .main_content_area .modal_area a {
    border-radius: 0.63vw;
    border: 0.08vw solid #E0DEDC;
    padding: 0.94vw 1.25vw;
  }

  .main_content_area .modal_area a img {
    width: 6.25vw;
    height: 6.72vw;
  }

  .main_content_area .modal_area a div {
    margin-left: 0.63vw;
  }

  .main_content_area .modal_area h3 {
    font-size: 1.25vw;
    margin-bottom: 0.31vw;
  }

  .case04 .main_content_area {
    margin-top: 4.89vw;
    padding: 2.5vw 0 0;
  }
}

@media screen and (min-width: 1000px) and (max-width: 1279px) {
    .fv .fv_content_area::after {
        top: 6.8vw;
    }
  }