@charset "utf-8";

.pc {
  display: none !important;
}

.sp {
  display: block !important;
}

section .inner {
  padding: 0 6.4vw;
  margin: 0 auto;
}

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: 400;
}

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: -1.5em;
  padding-left: 1.5em;
}

ol.note li::before {
  counter-increment: number 1;
  content: '※'counter(number);
  font-size: inherit;
  margin-right: 0.5em;
}

/* 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 !important;
}

.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::after {
  content: '';
  background-position: center;
  background-size: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  background-repeat: no-repeat;
  top: 0;
  bottom: 0;
  right: 4vw;
  margin: auto 0;
}

/* .btn.btn_type1 */
.btn.btn_type1 {
  border: 0.2666666vw solid #E0DFDD;
  box-sizing: border-box;
}

/* .btn.btn_type2 */
.btn.btn_type2 {
  background: linear-gradient(180deg, #DB0000 50%, #CC0000 50%);
  border: 0.533vw solid #E57878;
  box-shadow: 0px 1.333vw 0px 0px #800000;
}

.btn.btn_type4,
.btn.btn_type1 {
  background: #FCFCFC;
  border: 0.533vw solid #E0DFDD;
  box-shadow: 0px 1.333vw 0px 0px #B3B3B3;
  margin-bottom: 3.2vw;
}

.btn.btn_type3 {
  border: 0.533vw solid #FCF16E;
  box-shadow: 0px 1.333vw 0px 0px #FFC20E;
}

#goldCardApplicationButton,
#golduCardApplicationButton,
#PlatinumCardApplicationButton,
#poikatsuButtonPlatinumtab,
#poikatsuButtonGoldtab {
  border: 0.2666666vw solid #E0DFDD;
}

.btn.btn_type2 .btn_text {
  color: #ffffff;
}

/* ホバー時の動き */
.btn.btn_type1:hover,
.btn.btn_type2:hover,
.btn.btn_type3:hover,
.btn.btn_type4:hover {
  box-shadow: none;
  opacity: 1;
  transform: translateY(1.333vw);
}

/* .btn.btn_type3 */
.btn_type3 {
  background-color: #facb32;
}

/* .btn.icon_type1 */
a.link.icon.icon_type1 {
  padding-right: 4.8vw;
}

.btn.icon_type1::after {
  background-image: url(../images/btn_arrow.png);
  width: 4.26666vw;
  height: 4.26666vw;
}

.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-left: 4.2vw;
  margin-right: 0px;
}

.btn.icon_type3::before {
  background-image: url(../images/ico-btn2.png);
  width: 11.73vw;
  height: 11.73vw;
}

/* .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;
}

/* .btn.icon_type7 */
a.link.icon.icon_type7 {
  padding-right: 4.8vw;
}
.btn.icon_type7::after {
  background-image: url(../images/btn_arrow_top.png);
  width: 4.26666vw;
  height: 4.26666vw;
}

/* .bubble */
.bubble_wrap {
  text-align: center;
  position: relative;
  padding-bottom: 2vw;
}

.bubble {
  display: inline-block;
  padding: 0 3.2vw;
  background-color: #E06666;
  border-radius: 9999px;
}

.bubble_text {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 6.93vw;
  color: #ffffff;
  font-size: 3.2vw;
}

.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: #ffffff;
  border-radius: 2.133333vw;
}

.accordion_title {
  cursor: pointer;
  position: relative;
}

.accordion_title * {
  font-size: 3.73333vw;
}

.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: #2B2B2B;
  width: 0.4vw;
  height: 5.33333vw;
  border-radius: 9999px;
  position: absolute;
  bottom: 0;
}

.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: 4px 0 4px 8px;
  box-sizing: border-box;
  text-align: left;
}

.header a {
  display: inline-block;
}

.header img {
  width: 280px;
}


/* .fv */
.fv {
  background-color: #D7D7D8;
}

.fv .inner:first-of-type {
  padding: 3.2vw 0 5.333333vw;
}

.fv .btn_area img {
  display: block;
  margin: 0 auto;
  width: 92vw;
}

.fv .btn_area ul {
  margin: 0 auto 4.266666vw;
  padding: 0 3.2vw;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: start;
}

.fv .btn_area ul li {
  width: 45.867vw;
}

.fv .btn_area ul li>.note {
  margin: 0;
  padding: 0;
  text-align: center;
}

.fv .btn_area ul li>.note {
  margin-top: 1.066666vw;
}

.fv .btn_area .btn {
  width: 100%;
  height: 14.933vw;
  margin: 0 auto;
}

.fv ol.note {
  margin-top: 2.13vw;
}

.fv .note_wrap {
  padding: 0 6.4vw;
}

.fv .inner .notice{
  background: #FFFFFF;
  border-left: solid 3px #E06666;
  padding: 2.3% 2.5% 3.5%;
  line-height: 1.4;
  margin: 4.6% 3.2vw 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;
}


/* about */
.about {
  background-color: #F7F5F5;
  padding: 15.47vw 0 32px;
}

.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: #fcfcfc;
  border: 0.533vw solid #3d3d3d;
  border-radius: 2.13vw;
  padding: 3.2vw 4.267vw;
  margin: 4.266666vw 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-black.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.266666vw auto;
}

.about .slash_wrap+.img_wrap {
  margin-top: 2.133333vw;
}


.about .reduction-list {
  display: flex;
  margin: 2.133vw auto 4.266666vw;
}

.about .reduction-list li:first-of-type {
  background-image: linear-gradient(to bottom, #9E9E9E, #9E9E9E 0.533333vw, transparent 0);
  background-size: 0.333333vw 1.6vw;
  background-repeat: repeat-y;
  background-position: right top;
}

.about .inner>.btn {
  margin: 4.266666vw 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;
}

/* step */
.step {
  background-color: #F0EEEC;
  padding: 16vw 0 17.07vw;
}

.step h2 {
  font-size: 8.533vw;
}

/* entry */
.step .entry-wrap {
  background-color: #ffffff;
  border-radius: 4.26666vw;
  padding: 5.333vw;
  margin-top: 4.26666vw;
  position: relative;
}

.step .entry-wrap p {
  font-size: 4.266666vw;
}

.step .entry-wrap h3 {
  font-size: 4.266666vw;
}

.step .entry-wrap::after {
  content: '';
  background-position: center;
  background-size: 100%;
  display: flex;
  position: absolute;
  bottom: -12%;
  left: 50%;
  transform: translateX(-50%);
  margin: auto;
  background-image: url(../images/icon-plus-circle.png);
  width: 8vw;
  height: 8vw;
  z-index: 99;
}

.step .entry-wrap>div {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 85%;
  margin: 0 auto 3.2vw;
}

.step .entry-wrap>div img {
  width: 8.533vw;
}

/* .step-list */
.step-list {
  display: flex;
  flex-direction: column;
  background-color: #fcfcfc;
  border: 0.533vw solid #3d3d3d;
  border-radius: 2.13vw;
  padding: 3.2vw 4.267vw;
  margin: 4.266666vw auto;
  position: relative;
}

.step-list:last-of-type::after {
  content: '';
  background-position: center;
  background-size: 100%;
  display: flex;
  position: absolute;
  top: -10%;
  left: 50%;
  transform: translateX(-50%);
  margin: auto;
  background-image: url(../images/icon-plus-circle-black.png);
  width: 8vw;
  height: 8vw;
}

.step-list>li {
  padding: 4.266666vw 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;
}

.step-list li:last-of-type {
  background: none;
}

.step-list li>div {
  display: flex;
  width: 100%;
  justify-content: space-between;
  align-items: center;
  margin: 0 auto 2.133333vw;
}

.step-list li>div img {
  width: 15.46666vw;
}

.step-list li>div>div h3 {
  line-height: 1.48;
  font-weight: 600;
  font-size: 4.27vw;
  letter-spacing: -0.133vw;
}

.step-list li>div>div img {
  width: 14.93333vw;
  margin-bottom: 1.066vw;
}

.step-list li .btn {
  margin: 0 auto;
  margin-bottom: 3.2vw;
}

.step-list li a.link {
  font-size: 3.2vw;
  color: #cc0000;
}

.step-list+img {
  display: block;
  width: 5.07vw;
  margin: 4.27vw auto;
}

.step-list ul.note li {
  text-align: center;
  margin-bottom: 2.13vw;
  letter-spacing: -0.133vw;
}
.step-list ul.note .left {
  text-align: left;
}

.step-list:last-of-type ul.note li {
  text-align: left;
}

.step .arrow {
  width: 5.333vw;
  display: block;
  margin: 4.266666vw auto;
}

.step-goal>div>div {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}

.step-goal>img {
  width: 100%;
  margin-bottom: 4.266666vw;
}
.step-goal>img::after {
  content: '※';
}

.step-goal>img:nth-of-type(1),
.step-goal>img:nth-of-type(2) {
  width: 100%;
  margin: 0 auto 4.266666vw;
}

.step-goal>div img.img-text {
  width: 58.93vw;
}


.step-goal img.img-card {
  width: 18.67vw;
}

.step-goal div+div {
  background-image: linear-gradient(to right, #9E9E9E, #9E9E9E 0.6vw, transparent 0);
  background-size: 2vw 0.27vw;
  background-repeat: repeat-x;
  background-position: right top;
  padding-top: 3.2vw;
  margin-top: 3.2vw;
}

.step ul.note {
  margin-top: 0.8vw;
}

.step ul.note li span {
  font-weight: 600;
}

/* .grant-accordion */
.grant-accordion {
  margin-top: 4.267vw;
}

.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.53333vw;
}

.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 {
  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;
  margin: 8.533vw auto 0;
  overflow: hidden;
}

.nisa-campaign-header {
  background: #3d3d3d;
  padding: 4.267vw 0;
  text-align: center;
  border-top-left-radius: 2.13vw;
  border-top-right-radius: 2.13vw;
}

.nisa-campaign-header p {
  font-size: 5.867vw;
  font-weight: 600;
  color: #ffffff;
}

.nisa-campaign-inner {
  padding: 6.4vw 4.267vw 7.467vw;
  border: 0.533vw solid #3d3d3d;
  border-bottom-left-radius: 2.13vw;
  border-bottom-right-radius: 2.13vw;
  background-color: #fcfcfc;
}

.nisa-campaign-inner .btn+.note {
  margin-top: 0.8vw;
}

.nisa-campaign-inner .btn+.note li {
  text-align: center;
  margin-top: 0;
}

.nisa-campaign-inner .btn.btn_type2,
.simulator_area_inner02 .btn.btn_type2,
.about-point .btn.btn_type1 {
  margin-bottom: 2.667vw;
}

.float_bottom .btn.btn_type2 {
  margin-bottom: 2.133vw;
}

.nisa-campaign-text {
  margin: 5.33vw auto 2.133vw;
  padding-top: 3.733vw;
}

.nisa-campaign-text p {
  font-size: 4.267vw;
  text-align: center;
  font-weight: 600;
}
.nisa-campaign .bnr_area {
  display: flex;
  flex-direction: column-reverse;
  padding: 5.333vw 0 12vw;
  border-radius: 2.13vw;
  background: #FFFFFF;
  position: relative;
  text-align: center;
}
.nisa-campaign .bnr_area a{
  padding: 0 4.16vw;
}

.nisa-campaign .bnr_area img {
  margin-bottom: 4.267vw;
}

.nisa-campaign .bnr_area p {
  margin-bottom: 3.2vw;
  font-size: 4vw;
  font-weight: 600;
  padding-left: 4.16vw;
  text-align: left;
}
.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: 0;
  left: 50%;
  transform: translateX(-50%);
  font-size: 3.733vw;
}
.nisa-campaign .btn_wrap {
  width: 100%;
  padding: 7.467vw 4.267vw 4.267vw;
  border-radius: 2.133vw;
  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 {
  background-color: #3D3D3D;
}
.nisa-campaign .btn_wrap .bubble_wrap .bubble::after{
  background-image: url(../images/tail_black.svg);
}

.nisa-campaign .btn_wrap .bubble_wrap .bubble .bubble_text {
  height: 8.533vw;
}

.step .inner>.btn.btn_type1 {
  width: 70.133vw;
  margin-top: 4.267vw;
}
.step .inner>.btn.btn_type1:first-of-type {
  width: 100%;
  margin-top: 10.667vw;
  margin-bottom: 17.07vw;
}

/* dcard */
.dcard {
  background: #F7F5F5;
  padding: 15.467vw 0 12.8vw;
}

/* 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.266666vw;
}

.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: 2.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: 3.2vw 0;
}

.tab_label .tab_label-gold._active {
  background-color: #BE980F;
  color: #FFF;
  padding: 3.2vw 0;
}

.reward_wrap>div {
  padding: 8.53vw 6vw;
  background-color: #FFF;
}

.reward_wrap>div.reward_platinum {
  border: 0.53vw solid #46433D;
  position: relative;
}

.reward_wrap>div.tab_gold {
  border: 0.53vw solid #BE980F;
}

.reward_wrap h4 {
  font-size: 4.27vw;
  font-weight: 600;
  text-align: center;
}

.reward_wrap .h4_outer+img {
  display: block;
  width: 41.87vw;
  margin: 14.933vw auto 2.133vw;
}

.reward_wrap p {
  text-align: center;
  font-weight: 400;
}

.reward_wrap>div>p.lead {
  margin: 8.5333vw auto;
}

.summary p.caption {
  font-size: 2.933vw;
  text-align: left;
  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.266666vw;
}

.scroll-image {
  display: inline-block;
  width: 120vw;
}

.reward_wrap div>.link {
  display: block;
  font-size: 3.2vw;
  margin: 4.266666vw auto;
  line-height: 1.3;
  font-weight: 400;
  letter-spacing: -0.04em;
}

.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.266666vw;
  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.266666vw;
  font-weight: 600;
  text-align: center;
  margin-top: 4.27vw;
}

.bg_gray .lead span {
  color: #CC0000;
}

.bg_gray .ex_result {
  background-color: #ffffff;
  border-radius: 2.133333vw;
  margin-top: 4.266666vw;
}

.bg_gray .ex_result p {
  font-size: 4.266666vw;
  font-weight: 600;
  text-align: center;
  line-height: 1.48;
}

.bg_gray .ex_result p span {
  font-size: 5.333333vw;
  color: #cc0000;
  font-weight: inherit;
  display: block;
}

.bg_gray img.dots {
  width: 0.8vw;
  height: 2.667vw;
  margin: 2.133333vw auto;
  display: block;
}

.bg_gray>div {
  width: 100%;
  margin: 4.266666vw auto 0;
}

.bg_gray>div a.link.icon {
  padding-right: 0;
  margin-bottom: 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;
}

.reward_wrap .tab_gold .btn_area {
  margin: 8.533vw auto;
}

.reward_wrap .reward_platinum .price_area .price_number {
  font-size: 5.896vw;
}

.reward_wrap .reward_platinum .price_area p {
  font-size: 3.2vw;
}

.reward_wrap .reward_platinum .price_area p:first-of-type {
  font-size: 4.266666vw;
}

.reward_wrap .reward_platinum .price_area p.card_name {
  position: absolute;
  margin: 0;
  top: 25.6vw;
  left: 50%;
  transform: translateX(-50%);
}

.reward_wrap .reward_platinum .btn_area {
  margin: 8.533vw auto 0;
}

.reward_wrap .reward_platinum .btn_area+.note {
  margin-top: 2.933333vw;
}

.reward_wrap .reward_platinum h3 {
  font-size: 5.33vw;
  margin-bottom: 4.27vw;
}
.reward_wrap .btn_area .slash_wrap {
  margin: 8.53vw auto 2.13vw;
}

/* .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 a {
  margin-top: 5.07vw;
}

.about-point a .btn_text,
.tab_inner .btn_area p {
  font-weight: 600;
}

.about-point a+.note {
  margin-top: 2.933333vw;
}

.about-point a+.note li {
  margin-top: 0;
}

.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;
}

/* .nisa */
.nisa {
  background-color: #F0EEEC;
}

.nisa .border {
  padding-top: 0.533vw;
}

.about-nisa h2+p {
  font-size: 4.8vw;
  font-weight: 600;
  text-align: center;
}

.about-nisa .nisa-box {
  background: rgb(242, 242, 242);
  margin-bottom: 5.333vw;
  border-radius: 2.133vw;
  padding: 3.2vw 4.267vw;
  margin-top: 3.2vw;
}

.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: 600;
  margin-bottom: 6.4vw;
  font-size: 3.2vw;
}

.about-nisa h3 {
  font-size: 6.4vw;
  font-weight: 600;
  text-align: center;
  line-height: 1.32;
  margin-top: 4.26666vw;
}

.about-nisa p {
  font-size: 4.26666vw;
  text-align: center;
}


/* .docomo-nisa */
.docomo-nisa .inner:first-of-type {
  padding: 10.667vw 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;
}

/* .slider */
.slider_item {
  width: 87.2vw;
  box-shadow: -0.2666666vw 0.2666666vw 3vw 0px rgba(131, 125, 118, 0.33);
  margin: 2.66666vw;
}

.slider_item:not(:first-of-type) {
  margin-left: 2.133333vw;
}

/* 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: #3d3d3d;
}

.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;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease-in-out, visibility 0.5s ease-in-out;
}
.float_bottom.is-visible {
  /* 表示状態 */
  opacity: 1;
  visibility: visible;
}

.float_bottom .btn_wrap {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  width: 93.6vw;
  margin: 0 auto;
}

.float_bottom .btn {
  width: 45.86666vw;
  margin: auto;
}

.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.73333vw;
}

.float_bottom .slash_wrap .slash::before,
.float_bottom .slash_wrap .slash::after {
  width: 0.2666666vw;
  height: 4.53333vw;
}

.float_bottom .note {
  margin-top: 0.8vw;
}

.float_bottom .note li {
  text-align: center;
}

/* .footer */
.footer a.link {
  color: #CC0000;
  font-size: inherit;
  line-height: 1.48;
}

.footer a.link.icon {
  position: relative;
  padding-right: 1.39090909091em;
  font-weight: normal;
}

.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: #EBEAE6;
}

.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: #EBEAE6;
}

.footer .copy p {
  font-size: 3.2vw;
  color: #706B61;
}

/* 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: 92%;
  max-width: 92vw;
  background-color: #fff;
  border-radius: 2.13vw;
  padding: 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.2666vw;
  text-align: left;
}

.modal__item.modal_calc-platinum01 h3 {
  padding-right: 10.666vw;
}

.modal__item h4 {
  font-size: 4.267vw;
  font-weight: 600;
  margin: 0 auto 4.2666vw;
  text-align: left;
}

.modal__item p {
  font-size: 4.267vw;
  text-align: center;
}

.modal__item p span {
  color: #CC0000;
  font-weight: 600;
}

.modal__item p.lead {
  background-color: #F7F5F5;
  padding: 1.06666vw 0;
  border-radius: 2666.4vw;
  font-size: 3.73vw;
  font-weight: 600;
  text-align: center;
  margin-top: 4.27vw;
}

.modal__item .note {
  margin-bottom: 5.333vw;
  text-align: left;
}

.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;
}

.modal__item .note:not(:first-of-type) {
  counter-reset: note-counter;
}

.modal__item .caption {
  font-size: 2.933vw;
  margin-bottom: 1.066vw;
  text-align: center;
}

.summary-accordion {
  margin-top: 4.27vw;
}

.summary-accordion .accordion_title {
  padding: 4.26vw 0 4.26vw 4.26vw;
  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 h4 {
  text-align: left;
  margin-top: 5.333vw;
  margin-bottom: 4.267vw;
}

/* 25.04 追加 */
.anchor_simulation_area {
  padding: 9.23vw 0 4.27vw;
}

.anchor_simulation {
  display: flex;
  width: 100%;
  max-width: 91.47vw;
  margin: auto;
  padding: 6.4vw 4.27vw 5.333vw;
  border: 0.53vw solid #E06666;
  background-color: #FCF2F2;
  border-radius: 2.13vw;
  align-items: center;
  position: relative;
  justify-content: center;
}

.anchor_simulation::before {
  background-image: url(../images/icon_simulation.png);
  width: 15.467vw;
  left: 4.27vw;
}
.anchor_simulation::after {
  background-image: url(../images/icon_arrow_under.png);
  width: 4.8vw;
  right: 4.27vw;
}

.anchor_simulation::before,
.anchor_simulation::after {
  content: "";
  background-position: center;
  background-size: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: 0 auto;
  background-repeat: no-repeat;
}

.anchor_simulation .bubble_wrap{
  position: absolute;
  top: -4.97vw;
  width: max-content;
}

.bubble_text {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 6.96vw;
  color: #ffffff;
  font-size: 3.73vw;
}
.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;
}

.anchor_simulation .btn_text {
  color:  #393636;
  font-weight: 700;
  font-size: 4.8vw;
  margin-left: 10.6vw;
}

.about-nisa h2 {
  font-size: 4.8vw;
  margin-bottom: 3.2vw;
}
.about-nisa .lead_text {
  font-weight: bold;
  width: 70.667vw;
  text-align: center;
  font-size: 4.8vw;
  background: rgb(250, 230, 230);
  margin: 3.2vw auto auto;
  border-radius: 2.133vw;
  padding: 2.133vw;
}
/* 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: 12.8vw;
}
.simulator_area a.link {
  font-weight: 400;
}
.simulator_area.title_wrap {
  background-image: url(../images/simulation_title_bg.png);
  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 {
  width: 63.467vw;
}
.simulator_area.title_wrap .bubble_text {
  font-size: 4vw;
  font-weight: bold;
}
.simulator_area.title_wrap h2 {
  font-size: 6.4vw;
}
.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: 2.133vw;
  padding: 8.533vw 4.267vw 9.6vw;
  margin-bottom: 10.667vw;
}

.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: space-between;
  align-items: baseline;
  margin-bottom: 6.4vw;
}
.simulator_area .card_wrap .card_content {
  cursor: unset;
  display: flex;
  flex-direction: row-reverse;
  justify-content: center;
  align-items: center;
  background: #f7f5f5;
  position: relative;
  border: 0.267vw solid #f0eeec;
  width: 100%;
  border-radius: 2.133vw;
  padding-top: 5.333vw;
  padding-bottom: 4.267vw;
  gap: 2.133vw;
}
.simulator_area .card_content p {
  margin: 0 auto;
  font-size: 3.733vw;
  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: 26.667vw;
  font-size: 4.267vw;
  border-radius: 13.333vw;
}
.simulator_area .card_content p.card_name {
  font-size: 3.2vw;
}
.simulator_area .card_content img {
  display: block;
  margin: auto;
  width: 34.667vw;
  height: auto;
  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: -8%;
  left: 50%;
  transform: translateX(-50%);
  background-image: url(../images/icon_card_selected.png);
  width: 5.867vw;
  height: 5.867vw;
}

/* シミュレーション結果について */
.simulator_area .caution_wrap {
  margin-top: 4.267vw;
  text-align: left;
}
.simulator_area .caution_wrap h5 {
  margin-top: 4.267vw;
  font-size: 4.267vw;
}
.simulator_area .caution_wrap ul {
  margin-top: 2.133vw;
}

/* シミュレーションエリア外装 */
#simulatorResultArea {
  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: 14vw;
  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;
}

#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;
}

.chart_area_wrap .note {
  text-align: left;
  margin: 3.2vw 0;
}

.simulator_area_inner01 .note.center {
  text-align: center;
  width: fit-content;
  margin: 0 auto;
}

#simulatorResultAreaInner .btn_area_wrap {
  margin: 4.267vw 0 3.2vw;
  display: flex;
  justify-content: space-between;
  gap: 2.133vw;
}

#simulatorResultAreaInner .btn_area_wrap .btn {
  width: 36.133vw;
  height: 14.933vw;
  margin-bottom: 0;
}

#simulatorResultAreaInner .btn_area_wrap .btn p {
  font-size: 2.933vw;
}

#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;
}

#displayGraphDescription .displayGraphDescription_inner {
  background: #fcf2f2;
  border: 0.266vw solid #eb9999;
  border-radius: 2.133vw;
  width: 34.667vw;
  padding: 1.6vw 2.133vw;
}

#displayGraphDescription .displayGraphDescription_inner:nth-of-type(2) {
  background: #edfaf1;
  border: 0.266vw solid #66bb81;
}

#displayGraphDescription .displayGraphDescription_inner p {
  display: flex;
  align-items: center;
  text-align: left;
  font-size: 2.933vw;
}

#displayGraphDescription .displayGraphDescription_inner p::before {
  content: "";
  display: inline-block;
  background: #e06666;
  margin-right: 2.133vw;
  border-radius: 2.667vw;
  width: 4.267vw;
  height: 2.667vw;
}

#displayGraphDescription
  .displayGraphDescription_inner:nth-of-type(2)
  p::before {
  background: #66bb81;
}

/* 追加要素 */
.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;
}

.simulator_area .tooltip_area > div p::before {
  content: "";
  display: inline-block;
  background: #e06666;
  margin-right: 0.5em;
  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;
}

/* シミュレーションエリア下部 */
.simulator_area_inner02 {
  margin: auto;
  width: 100%;
  text-align: left;
}

.point_description_area {
    display: none;
    background: #ffffff;
    border-radius: 2.133vw;
    padding: 5.333vw 4.267vw 6.4vw;
    margin-bottom: 8.533vw;
}

.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: flex;
  justify-content: space-between;
  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 .btn {
  width: 44.533vw;
  height: 14.933vw;
}

.simulator_area_inner02 .btn_area .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;
}


@media screen and (min-width: 769px) {
  .pc {
    display: block !important;
  }

  .sp {
    display: none !important;
  }

  section .inner {
    max-width: 1020px;
    width: 90%;
    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: 263px;
    height: 56px;
  }

  .btn_text {
    font-size: 16px;
  }

  .nisa-campaign-inner .btn.btn_type2,
  .simulator_area_inner02 .btn.btn_type2,
  .about-point .btn.btn_type1 {
    margin-bottom: 10px;
  }

  .fv .btn.btn_type2,
  .float_bottom .btn.btn_type2 {
    margin-bottom: 10px;
  }

  .btn::after {
    right: 16px;
  }

  /* .btn.btn_type1 */
  .btn.btn_type1 {
    border: 2px solid #E0DFDD;
  }

  /* .btn.btn_type2 */
  .btn.btn_type2 {
    border: 2px solid #E57878;
    box-shadow: 0px 5px 0px 0px #800000;
  }

  .btn.btn_type4,
  .btn.btn_type1 {
    border: 2px solid #E0DFDD;
    box-shadow: 0px 5px 0px 0px #B3B3B3;
    margin-bottom: 12px;
  }

  .btn.btn_type3 {
    border: 2px solid #FCF16E;
    box-shadow: 0px 5px 0px 0px #FFC20E;
  }
  
  .btn.btn_type2 .btn_text {
    color: #ffffff;
  }
  
  /* ホバー時の動き */
  .btn.btn_type1:hover,
  .btn.btn_type2:hover,
  .btn.btn_type3:hover,
  .btn.btn_type4:hover {
    box-shadow: none;
    transform: translateY(5px);
  }

  /* .btn.icon_type1 */
  a.link.icon.icon_type1 {
    padding-right: 16px;
  }

  .btn.icon_type1::after {
    width: 16px;
    height: 16px;
  }

  .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-left: 16px;
    margin-right: 0px;
  }

  .btn::before {
    left: 6px;
  }

  .btn.icon_type3::before {
    width: 44px;
    height: 44px;
    left: 4.5px;
  }

  a.link.icon.icon_type4 {
    padding-right: 16px;
  }

  #goldCardApplicationButton,
  #golduCardApplicationButton,
  #PlatinumCardApplicationButton,
  #poikatsuButtonPlatinumtab,
  #poikatsuButtonGoldtab {
    border: 2px solid #E0DFDD;
  }

  /* .btn.icon_type6 */
  .icon_type6::after {
    width: 16px;
    height: 16px;
  }

  /* .btn.icon_type7 */
  a.link.icon.icon_type7 {
    padding-right: 16px;
  }

  .btn.icon_type7::after {
    width: 16px;
    height: 16px;
  }

  /* .bubble */
  .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: 2px 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: 1.5px;
    height: 20px;
    top: auto;
    bottom: 4px;
  }

  .slash_wrap .slash::before {
    left: -0.5em;
  }

  .slash_wrap .slash::after {
    right: -0.5em;
  }

  .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;
    text-align: center;
  }

  .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 .inner:first-of-type {
    padding: 24px 0 40px;
  }

  .fv .btn_area {
    width: 542px;
    margin: auto;
  }

  .fv>img {
    max-width: 1280px;
    margin: auto;
  }

  .fv .btn_area img {
    max-width: 892px;
  }

  .fv .btn_area ul li {
    width: 263px;
  }

  .fv .btn_area ul li>.note {
    margin-top: 11px;
  }

  .fv .btn_area .btn {
    width: 100%;
    height: 56px;
    bottom: 10%;
    margin: 0;
  }

  .fv .btn_area ul {
    margin: 0 auto 24px;
    padding: 0;
  }

  .fv ol.note {
    margin-top: 24px;
  }
  
  .fv .inner .notice{
    padding: 8px 9px 12px;
    margin: 16px 6.4vw 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;
  }

  /* 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: #fcfcfc;
    border: 2px solid #3d3d3d;
    border-radius: 10px;
    padding: 24px;
    margin: 20px auto 16px;
  }

  .about .condition-list:first-of-type {
    width: 100%;
    max-width: 668px;
    justify-content: center;
    padding: 24px 9px;
  }

  .about .condition-list:first-of-type li {
    max-width: 338px;
  }

  .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 .slash_wrap+.img_wrap {
    margin-top: 16px;
  }

  .about .reduction-list {
    width: 624px;
    margin: 20px auto 24px;
    justify-content: space-between;
  }

  .about .reduction-list li {
    width: 322px;
    padding-left: 32px;
  }

  .about .reduction-list li:first-of-type {
    padding-right: 32px;
    padding-left: 0;
    background-image: linear-gradient(to bottom, #9E9E9E, #9E9E9E 4px, transparent 0);
    background-size: 2px 9px;
    background-repeat: repeat-y;
    background-position: right top;
  }

  .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;
  }

  .reward_wrap {
    margin: auto;
    width: 100%;
    max-width: 900px;
    box-sizing: border-box;
  }

  .reward_wrap>div {
    padding: 32px;
  }

  .reward_wrap>div.reward_platinum {
    border: 2px solid #46433D;
  }

  .reward_wrap>div.tab_gold {
    border: 2px solid #BE980F;
  }

  .reward_wrap .flex {
    width: 450px;
    margin: auto;
    display: flex;
    align-items: center;
  }

  .reward_wrap h4 {
    font-size: 20px;
    margin-bottom: 16px;
  }

  .reward_wrap .h4_outer+img {
    width: 171px;
    margin: 0 auto;
  }

  .reward_wrap>div>p.lead {
    margin: 32px auto;
  }

  .summary p.caption {
    width: 688px;
    margin: auto;
    font-size: 11px;
  }

  .summary .image-container {
    width: 100%;
    max-width: 688px;
    overflow-x: unset;
    white-space: unset;
    margin: 4px auto 24px;
  }

  .scroll-image {
    width: 100%;
  }

  .reward_wrap div>.link {
    font-size: 14px;
    margin: 16px auto;
  }

  .reward_wrap>div>.link {
    font-size: 14px;
    margin: 24px auto;
    width: 688px;
  }

  .reward_wrap>div>.note {
    margin: auto;
    width: 100%;
    max-width: 688px;
  }

  .reward_wrap .tab_gold .btn_area {
    margin: 32px auto;
  }

  .reward_wrap .reward_platinum .price_area .price_number {
    font-size: 25.52px;
  }

  .reward_wrap .reward_platinum .price_area p {
    font-size: 14px;
  }

  .reward_wrap .reward_platinum .price_area p:first-of-type {
    font-size: 18px;
  }

  .reward_wrap .reward_platinum .btn_area {
    margin: 32px auto 0;
  }

  .reward_wrap .reward_platinum .btn_area+.note {
    margin-top: 8px;
  }

  .reward_wrap .reward_platinum h3 {
    font-size: 26px;
    margin-bottom: 24px;
  }

  .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 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: 16px;
    margin: 20px auto 0;
  }

  .bg_gray .ex_result {
    border-radius: 8px;
    width: 540px;
    margin: 16px auto 0;
  }

  .bg_gray .ex_result p {
    font-size: 18px;
  }

  .bg_gray .ex_result p span {
    font-size: 22px;
  }

  .bg_gray>div {
    margin: 16px auto 0;
  }

  .bg_gray .slash_wrap {
    margin-top: -40px;
  }

  .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: 269px;
    margin: 16px auto 0;
  }

  .bg_gray .note:first-of-type {
    margin-top: 16px;
  }

  .reward_wrap .btn_area ul {
    display: flex;
    justify-content: center;
    margin-top: 32px;
  }

  .reward_wrap .btn_area ul li {
    margin: 0 16px;
  }

  .reward_wrap .btn_area .slash_wrap {
    margin: 0 auto 8px;
  }

  .reward_wrap .btn_area p {
    font-size: 14px;
  }

  /* dcard */
  .dcard {
    padding: 80px 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: 386px;
    margin: auto;
    margin-bottom: 24px;
  }

  .summary>p {
    margin-bottom: 8px;
  }

  .summary>.note {
    text-align: center;
  }

  /* .summary-accordion */
  .summary-accordion {
    background-color: #FCFCFC;
    margin: 32px auto 0;
    max-width: 688px;
  }

  .summary-accordion .accordion_title {
    padding: 32px 0 32px 40px;
  }

  .summary-accordion .accordion_content {
    padding: 0 40px 32px;
  }

  .summary-accordion .accordion_content h4 {
  margin-top: 20px;
  margin-bottom: 16px;
  }

  .summary-accordion .accordion_title h5 {
    width: 410px;
  }

  .summary-accordion img {
    width: 100%;
    margin: 16px auto;
  }

  .summary-accordion p {
    font-size: 16px
  }

  .summary-accordion .btn {
    width: 263px;
    margin: 16px auto 0;
  }

  .about-point ul.note {
    margin-top: 8px;
  }

  .dcard .nisa-campaign {
    width: 100%;
    max-width: 900px;
  }

  .nisa-campaign .btn_area {
    width: 100%;
    max-width: 706px;
  }

  /* .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 img {
    max-width: 900px;
    margin: 0 auto;
  }


  .about-point a {
    margin-top: 16px;
    width: 327px;
  }

  .about-point a+.note {
    margin-top: 8px;
  }

  /* step */
  .step {
    padding: 80px 0;
  }

  .step h2 {
    font-size: 36px;
  }

  /* entry */
  .step .entry-wrap {
    width: 327px;
    margin: auto;
    border-radius: 10px;
    padding: 20px 8px;
    margin-top: 40px;
  }

  .step .entry-wrap p {
    font-size: 16px;
  }

  .step .entry-wrap h3 {
    font-size: 18px;
  }

  .step .entry-wrap::after {
    bottom: -18%;
    width: 30px;
    height: 30px;
  }

  .step .entry-wrap>div {
    margin: 0 auto 12px;
  }

  .step .entry-wrap>div img {
    width: 32px
  }

  /* .step-list */
  .step-list-container {
    display: flex;
    justify-content: space-between;
  }

  .step-list {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0;
    flex-direction: row;
    margin: 42px 0 16px;
    border: 2px solid #3d3d3d;
    border-radius: 10px;
    padding: 24px 0 24px;
    box-sizing: border-box;
  }

  .step-list:last-of-type::after {
    top: 50%;
    left: -25px;
    transform: translateY(-50%);
    width: 30px;
    height: 30px;
  }

  .step-list:first-of-type {
    width: 64.5%;
    max-width: 658px;
    height: inherit;
    align-items: center;
  }

  .step-list:nth-of-type(2) {
    width: 34%;
    max-width: 346px;
  }

  .step-list>li {
    padding: 0 24px;
    width: 100%;
    min-height: 170px;
    height: auto;
    border-radius: 8px;
    margin-top: 0;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    background-image: linear-gradient(to bottom, #9E9E9E, #9E9E9E 4px, transparent 0);
    background-size: 2px 9px;
    background-repeat: repeat-y;
    background-position: right top;
    box-sizing: border-box;
  }

  .step-list li>div {
    margin-bottom: 30px;
    min-height: 120px;
    padding-top: 30px;
  }

  .step-list:last-of-type li>div {
    margin-top: 24px;
    padding-top: 12px;
    margin-bottom: 12px;
  }

  .step-list li>div img {
    width: 56px;
  }

  .step-list li>div>div img {
    position: absolute;
    top: 24px;
  }

  .step-list li>div>div h3 {
    font-size: 18px;
    letter-spacing: -0.5px;
  }

  .step-list li>div>div img {
    width: 58px;
    margin-bottom: 16px;
  }

  .step-list li a.link {
    font-size: 13px;
  }

  .step-list+img {
    width: 19px;
    margin: 16px auto;
  }

  .step-list ul.note li {
    letter-spacing: -0.5px;
    margin-bottom: 0;
  }

  .step-list li .btn {
    width: 100%;
    max-width: 263px;
    margin: 0 auto;
    margin-bottom: 4px;
  }

  .step .arrow {
    width: 20px;
    margin: 16px auto;
  }

  .step-goal>img:nth-of-type(1),
  .step-goal>img:nth-of-type(2) {
    width: 654px;
    margin: 0 auto 16px;
  }

  .step-goal>img {
    width: 428px;
    margin: auto;
    margin-bottom: 8px;
  }

  .step-goal>div {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  .step-goal>div img.img-text {
    width: 74.25%;
  }

  .step-goal img.img-card {
    width: 24.03%;
  }

  .step-goal div+div {
    background-image: linear-gradient(to top, #9E9E9E 4px, #9E9E9E, transparent 0);
    background-size: 1px 7px;
    background-repeat: repeat-y;
    background-position: left top;
    padding-top: 0;
    margin-top: 0;
    padding-left: 20px;
    margin-left: 20px;
  }

  .step ul.note {
    margin-top: 4px;
  }

  .step .btn+ul.note {
    max-width: 263px;
    margin: 8px auto 0;
  }

  /* .grant-accordion */
  .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;
    border-radius: 16px;
  }

  .grant-accordion .accordion_content .box .lead {
    font-size: 16px;
    margin-bottom: 16px;
    padding: 4px 18px;
    width: fit-content;
  }

  .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 {
    margin: 40px auto 0;
  }

  .nisa-campaign-header {
    padding: 16px 0;
    border-top-right-radius: 0.63vw;
    border-top-left-radius: 0.63vw;
  }

  .nisa-campaign-header p {
    font-size: 24px;
  }

  .nisa-campaign-inner {
    padding: 24px 0 28px;
    border: 1px solid #707070;
    border-bottom-left-radius: 0.63vw;
    border-bottom-right-radius: 0.63vw;
  }

  .nisa-campaign-inner .btn+.note {
    margin-top: 4px;
  }

  .nisa-campaign-text {
    margin: 0 auto 8px;
    padding-top: 0;
    width: 590px;
  }

  .nisa-campaign-text p {
    font-size: 20px;
  }

  .nisa-campaign-text p.bubble_text {
    font-size: 16px;
  }

  .nisa-campaign .btn_area {
    max-width: 706px;
    width: 80%;
    margin: auto;
    padding: 24px;
    border-radius: 10px;
    display: flex;
    box-sizing: border-box;
    align-items: center;
  }

  .nisa-campaign .btn_area div {
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  .nisa-campaign .btn_area div p {
    font-size: 20px;
    font-weight: 800;
  }

  .nisa-campaign .btn_area img {
    margin-bottom: 0;
    width: 323px;
    height: fit-content;
    margin-right: 16px;
  }

  .nisa-campaign .btn_area p {
    font-size: 20px;
  }

  .step .inner>.btn.btn_type1 {
    width: 334px;
    margin-top: 20px;
    margin-bottom: 24px;
  }
  .step .inner>.btn.btn_type1:first-of-type {
    width: 334px;
    margin-top: 40px;
    margin-bottom: 80px;
  }

  /* .nisa */
  .nisa {
    background-color: #F0EEEC;
  }

  .nisa .border {
    padding-top: 0;
  }

  /* .about-nisa */
  .about-nisa h2 {
    font-size: 24px;
    margin-bottom: 32px;
  }
  .about-nisa .lead_text {
    width: 320px;
    border-radius: 8px;
    padding: 8px;
    font-size: 20px;
    margin-top: 12px;
  }
  .about-nisa .inner {
    padding: 0;
    width: 100%;
    max-width: none;
    margin-bottom: 16px;
  }

  .about-nisa h2+p {
    font-size: 24px;
  }

  .about-nisa .nisa-box {
    border-radius: 15px;
    margin: 32px auto 56px;
    padding: 31px;
    width: 478px;
  }

  .about-nisa .bubble_wrap {
    margin-bottom: 8px;
  }

  .about-nisa .bubble_text {
    height: 32px;
    font-size: 15px;
  }

  .about-nisa .nisa-box h3 {
    text-align: center;
    margin-bottom: 31.13px;
    font-size: 20px;
  }

  .about-nisa .nisa-box img {
    width: 361.87px;
    margin: 0 auto;
    display: block;
  }

  .about-nisa h3 {
    font-size: 32px;
    margin-top: 12px;
  }

  .about-nisa p {
    font-size: 16px;
  }

  /* .docomo-nisa */
  .docomo-nisa .inner>img {
    width: 371px;
    margin: 0 auto;
    display: block;
  }

  .docomo-nisa .inner:first-of-type {
    padding: 40px 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: 432px;
  }

  .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 {
    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;
    margin: auto;
  }

  .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: 14px;
  }

  .float_bottom .slash_wrap .slash::before,
  .float_bottom .slash_wrap .slash::after {
    width: 1px;
    height: 15px;
    bottom: 2px;
  }

  .float_bottom .btn.btn_type2 {
    margin-bottom: 8px;
  }

  .float_bottom .slash_wrap .slash::before {
    left: -0.5em;
  }

  .float_bottom .slash_wrap .slash::after {
    right: -0.5em;
  }

  .float_bottom .note {
    margin-top: 12px;
  }

  /* .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;
  }

}

@media (768px <=width < 830px) {
  .step_summary li.box .btn_text {
    max-width: 7em;
  }
}

@media (768px <=width < 1052px) {

  .step_summary,
  .docomo-nisa .point-list {
    align-items: stretch;
  }
}

@media (768px <=width < 1116px) {
  .slider {
    width: 700px;
    margin: 0 auto;
  }
}

/* 25.01 追加 */
#modal_calc .image-container {
  width: 100%;
  overflow-x: auto;
  white-space: nowrap;
  margin: 1.066vw auto 4.266666vw;
}

#modal_calc .scroll-image {
  display: inline-block;
  width: 120vw;
}

@media screen and (min-width: 769px) {
  #modal_calc .scroll-image {
    width: 100%;
    max-width: none;
  }

}

@media screen and (min-width: 769px) {
  .bubble {
    padding: 0 13px 0 15.5px;
  }

  .bubble_text {
    height: 32px;
    font-size: 15px;
  }
  /* 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: 30px;
  }

  .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;
  }
  .step .inner .lead {
    width: 461px;
    margin: 0 auto;
    display: flex;
  }
  .step-list li>div>div .note li {
    margin-bottom: 0;
  }
  .nisa-campaign .bnr_area {
    max-width: 726px;
    margin: auto;
    padding: 24px 20px;
    border-radius: 10px;
    display: flex;
    flex-direction: row;
    box-sizing: border-box;
    align-items: center;
    justify-content: center;
    gap: 16px;
  }
  .nisa-campaign .bnr_area a {
    padding: 0 ;
  }
  .nisa-campaign .bnr_area div {
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .nisa-campaign .bnr_area p {
    margin-bottom: 0;
    font-size: 18px;
    font-weight: 800;
    padding: 0;
    width: 339px;
  }
  .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;
    font-size: 16px;
  }
  .nisa-campaign .bnr_area img {
    margin-bottom: 0;
    width: 323px;
    height: fit-content;
  }
  .nisa-campaign .btn_wrap {
    width: 674px;
    padding: 28px 16px 16px;
    border-radius: 8px;
    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 .bubble_text {
    height: 32px;
  }
  .bubble::after {
    width: 7.64px;
    height: 6.75px;
  }
  .nisa-campaign .btn_wrap .bubble_wrap .bubble_text::before {
    width: 16px;
    height: 16px;
  }
  .btn_wrap a {
    width: 327px;
  }

    /* simulator_area */
    section.dcard .inner.simulator_header_inner,
    section.dcard .inner.simulator_area_inner {
      padding: 0;
    }
    .simulator_area {
      padding-bottom: 56px;
    }
    .simulator_area.title_wrap {
      background-image: url(../images/pc/simulation_title_bg.png);
      background-size: contain;
      width: 708px;
      height: 115px;
      margin: auto;
      margin-bottom: 24px;
      margin-left: auto;
    }
  
    .simulator_area.title_wrap .bubble {
      width: auto;
    }
    
    .simulator_area.title_wrap .bubble_text {
      font-size: 18px;
    }
  
    .simulator_area.title_wrap h2 {
      font-size: 30px;
    }
  
    .simulator_area_inner01 {
      max-width: 670px;
      border-radius: 8px;
      padding: 32px 40px;
      margin-bottom: 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;
      justify-content: center;
    }
    .simulator_area .card_wrap .card_content {
      display: block;
      border: 1px solid #f0eeec;
      width: 240px;
      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;
      font-size: 10px;
    }
    .simulator_area .card_content img {
      width: 82px;
      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 {
      margin-top: 24px;
      text-align: left;
    }
    .simulator_area .caution_wrap h5 {
      margin-top: 24px;
      font-size: 18px;
    }
    .simulator_area .caution_wrap ul {
      margin-top: 12px;
    }
  
    /* シミュレーションエリア外装 */
  
    #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;
    }
  
    .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;
    }

    .chart_area_wrap .note {
    margin: 12px 0;
    }

    #simulatorResultAreaInner .btn_area_wrap {
      margin: 24px 0 12px;
      gap: 16px;
    }
  
    #simulatorResultAreaInner .btn_area_wrap .btn {
      width: 271px;
      height: 56px;
    }
    
    #simulatorResultAreaInner .btn_area_wrap .btn p {
      font-size: 14px;
    }
  
    #displayGraphDescription {
      margin-bottom: 24px;
    }
  
    #displayGraphDescription .displayGraphDescription_inner {
      border: 1px solid #eb9999;
      border-radius: 8px;
      width: 163px;
      padding: 6px 21px 6px 16px;
    }
  
    #displayGraphDescription .displayGraphDescription_inner:nth-of-type(2) {
      border: 1px solid #66bb81;
    }
  
    #displayGraphDescription .displayGraphDescription_inner p {
      font-size: 12px;
    }
  
    #displayGraphDescription .displayGraphDescription_inner p::before {
      margin-right: 8px;
      border-radius: 10px;
      width: 16px;
      height: 10px;
    }
  
    /* 追加要素 */
    .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: 13px;
      height: 13px;
    }
  
    .chart_subtitle {
      font-size: 10px;
      bottom: 190px;
      left: 4px;
    }
  
    /* シミュレーションエリア下部 */
    .simulator_area_inner02 {
      max-width: 670px;
    }
  
    .point_description_area {
        border-radius: 8px;
        padding: 40px 40px 48px;
        margin-bottom: 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: flex;
      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;
      text-align: center;
      margin: 4px auto 0;
    }
  
    .simulator_area_inner02 .btn_area_wrap .btn {
      width: 327px;
      height: 56px;
    }
  
    .simulator_area_inner02 .btn_area_wrap .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;
    }
}

@media screen and (min-width: 769px) and (max-width: 1024px) {
  /* .step-list */
  .step-list-container {
    display: flex;
    gap: 0;
    flex-direction: column;
  }
  .step .entry-wrap {
    width: 500px;
    padding: 20px 90px;
  }
  .step .entry-wrap::after {
    bottom: -11%;
    width: 30px;
    height: 30px;
  }
  .step-list:first-of-type {
    width: 100%;
    max-width: 500px;
    height: inherit;
    align-items: center;
  }
  .step-list {
    display: flex;
    flex-direction: column;
    border-radius: 10px;
    padding: 0 24px;
    margin: 16px auto 0;
    position: relative;
    width: 100%;
    max-width: 500px;
  }
  
  .step-list:nth-of-type(2) {
    width: 100%;
    max-width: 500px;
  }
  
  .step-list:nth-of-type(2) ul.note {
    width: 330px;
    margin: auto;
  }
  
  .step-list:last-of-type::after {
    content: '';
    background-position: center;
    background-size: 100%;
    display: flex;
    position: absolute;
    top: -10%;
    left: 50%;
    transform: translateX(-50%);
    width: 30px;
    height: 30px;
  }
  
  .step-list li {
    padding: 24px 0;
    background-image: linear-gradient(to left, #9E9E9E, #9E9E9E 4px, transparent 0);
    background-size: 9px 2px;
    background-repeat: repeat-x;
    background-position: right bottom;
    text-align: left;
  }
  
  .step-list li:last-of-type {
    background: none;
  }
  
  .step-list li>div {
    display: flex;
    width: 330px;
    justify-content: space-between;
    align-items: center;
    margin: 0 auto 16px;
    min-height: auto;
  }
  
  .step-list li>div img {
    width: 56px;
  }
  
  .step-list li>div>div h3 {
    line-height: 1.48;
    font-weight: 600;
    font-size: 18px;
  }
  
  .step-list li>div>div img {
    position: unset;
    width: 58px;
    margin-bottom: 16px;
  }
  
  .step-list li .btn {
    margin: 0 auto;
  }
  
  .step-list>li>a.link {
    font-size: 13px;
    color: #cc0000;
    padding-left: 60px;
  }
  
  .step-list li ul.note li {
    min-height: unset;
    display: unset;
    padding: 0;
  }
  
  .step-list:last-of-type li>div {
    margin-top: 0;
  }

  /* .about condition-list */
  .about .condition-list-container {
    display: block;
  }
  .about .condition-list {
    display: flex;
    flex-direction: column;
    border-radius: 10px;
    padding: 24px 30px;
    margin: 16px auto 16px;
    width: 100%;
    max-width: 500px;
  }
  .about .condition-list li:first-of-type {
    padding-left: 0;
  }
  .about .condition-list li {
    width: 100%;
    max-width: unset;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 0 10px;
    background-image: linear-gradient(to left, #9E9E9E, #9E9E9E 2px, transparent 0);
    background-size: 6px 2px;
    background-repeat: repeat-x;
    background-position: right bottom;
  }
  .about .condition-list:first-of-type li {
    width: 100%;
    max-width: unset;
  }
  .about .condition-list:first-of-type li:last-of-type {
    padding-top: 10px;
  }
  .about .condition-list li:last-of-type {
    padding-bottom: 0;
  }
  .about .condition-list:first-of-type {
    width: 100%;
    max-width: 500px;
    justify-content: center;
  }
  .about .condition-list {
    max-width: 500px;
  }
  .about .condition-list-inner img {
    margin-right: 16px;
  }
  .about .condition-list:last-of-type::after {
    top: -26px;
    left: 50%;
    transform: translatex(-50%);
    width: 30px;
    height: 30px;
  }
}

/*KV検証*/
    .fv2 {
      background-color: #080809;
      margin-bottom: -5%;
    }
    .fv2 .btn_area ul {
      display: block;
    }
    .fv2 {
      position: relative;
    }
    .btn_content01 {
      position: absolute;
      top: 45%;
    }
    .btn_content02 {
      position: absolute;
      top: 63%;
    }
    .fv2 .note_wrap {
      position: absolute;
      top: 80%;
      width: 95%;
    }
    .fv2 .btn_area .btn {
      width: 67.47vw;
      margin-bottom: 2.133vw;
    }
    .fv2 .btn_area ul li {
      width: 100%;
      color: #d5d5d5;
      margin-bottom: 6px;
    }
    .btn_content01,
    .btn_content02,
    .fv2 .note_wrap {
      left: 50%;
      transform: translateX(-50%);
    }
    .fv2 .note_wrap ol.note li,
    .fv2 .note_wrap ul.note li {
      color: #d5d5d5;
    }
    .fv2 ul.note li::before {
      margin-right: 0.1em;
    }
    .fv2 .inner .btn_area ul .btn_content01 .note {
      margin-top: 2px;
    }
    .fv2 .btn_content01 ul.note li::before {
      margin-right: 1px;
    }
    .fv2 .inner:first-of-type {
      padding: 0;
    }

    @media screen and (min-width: 769px) and (max-width: 1280px) {
      .fv2 {
        margin-bottom: -40px;
      }
      .btn_content01 {
        position: absolute;
        top: 21.8vw;
        left: 62.5%;
      }
      .fv .btn_area .btn_content01 .btn {
        margin-bottom: 1.04vw;
      }
      .btn_content01 .btn.icon_type3::before {
        width: 3.43vw;
        height: 3.43vw;
        left: 0.35vw;
      }
      .btn_content02 {
        position: absolute;
        top: 62.5%;
      }
      .fv2 .note_wrap {
      position: absolute;
      top: 46.5vw;
      width: 58.7%;
      }
      .btn_content02,
      .fv2 .note_wrap {
      left: 50%;
      transform: translateX(-50%);
      }
      .fv2 .btn_area .btn {
        width: 19.77vw;
        height: 4.38vw;
      }
      .fv2 .btn_area ul li {
      width: 19.61vw;
      }
      .fv2 .btn_area ul li {
        margin-bottom: 2.5%;
        font-size: 0.9vw;
      }
      .fv2 .btn_text {
        font-size: 1.21vw;
      }
      .fv2 .btn.icon_type3 .btn_text {
        margin-right: 0.91vw;
      }
      .fv2 .btn.icon_type1 .btn_text {
        margin-right: 0.61vw;
      }
      .fv2 .btn.icon_type3::after {
        width: 0.94vw;
        height: 0.94vw;
      }
      .fv2 .btn.icon_type1::after {
        width: 1.25vw;
        height: 1.25vw;
      }
      .fv2 .inner .note_wrap .note li {
      font-size: 0.937vw;
      }
    }

    @media screen and (min-width: 1281px) {
      .fv2 {
        position: sticky;
        margin-bottom: -2%;
      }
      .fv2 .inner:first-of-type {
        position: relative;
      }
      .btn_content01 {
        position: absolute;
        top: -482px;
        left: 668px;
      }
      .fv .btn_area .btn_content01 .btn {
        margin-bottom: 8px;
      }
      .btn_content02 {
        position: absolute;
        top: -294px;
      }
      .fv2 .note_wrap {
      position: absolute;
      top: -152px;
      width: 586px;
      padding: 0;
      }
      .btn_content02,
      .fv2 .note_wrap {
      left: 50%;
      transform: translateX(-50%);
      }
      .fv2 .btn_area .btn {
        width: 253px;
        height: 56px;
      }
      .fv2 .btn_area ul li {
      width: 19.61vw;
      }
      .fv2 .btn_area ul li {
        margin-bottom: 2.5%;
        font-size: 11.511px;
        align-items: center;
        display: flex;
        flex-direction: column;
      }
      .fv2 ul.note li::before {
        display: contents;
      }
    }