@charset "UTF-8";

/*================================================================================
個別CSS 
=================================================================================*/

/*共通*/
.catalog-section {
    width: 100%;
}

.catalog-section__inner {
    max-width: 980px;
    margin: 0 auto;
    padding: 0 10px;
}

.contents p+p, .contents p+[class*=list-cmn]{
    margin-top: inherit;
}

@media screen and (max-width: 767px) {
  .catalog-section__inner{
    padding: 0;
  }
}

.catalog-section__bg-white{
    background-color: #fff;
    border-radius: 10px;
}
@media screen and (max-width: 767px) {
  .catalog-section__bg-white{
    padding: 15px;
  }
}

.catalog-section__bg-blue{
    background-color: #0068B7;
}
@media screen and (max-width: 767px) {
  .catalog-section__bg-blue{
    padding: 0px;
  }
}

.catalog-section__fc-white{
    color: #fff;
}

.catalog-section__bg-pink__only-pc {
  background-color: #FEE8EB;
  border-radius: 10px;
}
@media screen and (max-width: 768px) {
  .catalog-section__bg-pink__only-pc {
    background-color: transparent;
  }
}

.kv-area {
  max-width: min(1200px, 100%)!important;
  padding: 30px 0!important;
}
@media screen and (max-width: 767px) {
  .kv-area{
    padding: 14px!important;
  }
}

/*charge-plan-anchor*/
@media screen and (min-width: 768px) {
  .charge-plan__anchor{
    max-width: 940px;
    margin: 0 auto;
    padding: 0 10px;
  }
}

@media screen and (max-width: 767px) {
  .charge-plan__anchor{
    width: 100%;
    padding: 0 4px;
  }
}

.nav-pageanchor{
	display: flex;
	flex-wrap: wrap;
}

@media screen and (min-width: 768px) {
  .nav-pageanchor{
	  gap: 16px 20px;
  }
}

@media screen and (max-width: 767px) {
  .nav-pageanchor{
	  gap: 8px 12px;
  }
}

@media screen and (min-width: 768px) {
  .nav-pageanchor__list{
    width: calc((100% - 40px) / 3);
  }
}

@media screen and (max-width: 767px) {
  .nav-pageanchor__list{
    width: calc((100% - 12px) / 2);
  }
}

@media screen and (max-width: 767px) {
  .nav-pageanchor__txt{
    width: calc(100% - 20px);
  }
}

.nav-pageanchor__list a{
	position: relative;
	display: flex;
  align-items: center;
  justify-content: space-between;
	text-decoration: none;
	border-radius: 4px;
	border: 2px solid #FFF;
	background: #fff;
	box-shadow: 2px 2px 10px 0 rgba(0, 0, 0, 0.30);
	font-weight: bold;
	color: #000;
}

@media screen and (min-width: 768px) {
.nav-pageanchor__list a{
	padding: 12px 16px;
	font-size: 115%;
}
}

@media screen and (max-width: 767px) {
.nav-pageanchor__list a{
	padding: 3px 12px;
	font-size: 95%;
  min-height: 50px;
  line-height: 1.8rem;
}
}

@media screen and (min-width: 768px) {
.nav-pageanchor__list a:hover{
	opacity: 0.8;
}
}

.nav-pageanchor__list a::after{
	content: "";
	background: 0 0 no-repeat;
	background-size: contain;
}

@media screen and (min-width: 768px) {
.nav-pageanchor__list a::after{
	width: 20px;
	height: 20px;
}
}

@media screen and (max-width: 767px) {
.nav-pageanchor__list a::after{
	width: 18px;
	height: 18px;
}
}

.docomo-mini .nav-pageanchor__list a::after{
	background-image: url(/flcache_data/charge/docomo_mini/images/icon_blue_arrow.svg);
}

/*maxのアイコンは下記で設定*/
.docomo-max .nav-pageanchor__list a::after{
	background-image: url(/flcache_data/charge/docomo_mini/images/icon_blue_arrow.svg);
}


/*select-option*/
.select-option__ttl{
  text-align: center;
}

@media screen and (min-width: 768px) {
.select-option__area{
  margin-top: 20px;
  padding: 40px 79px 50px 79px;
  border-radius: 10px;
  background: #DCEFFE;
}
}

@media screen and (max-width: 767px) {
.select-option__area{
  margin-bottom: 32px;
}
}

.select-option__item{
  border-bottom: 1px solid #F2C5CB;
  margin-top: 30px;
}

.select-option__item:first-child{
  margin-top: 0;
}

.select-option__item:last-child{
  border-bottom: none;
}

.select-option__subttl{
  font-size: 130%;
  font-weight: bold;
  margin-bottom: 16px;
}

@media screen and (max-width: 767px) {
.select-option__subttl{
  text-align: center;
}
}

.select-option__2col{
  display: flex;
  justify-content: space-between;
}

@media screen and (min-width: 768px) {
.select-option__2col{
  row-gap: 16px;
}
}

@media screen and (max-width: 767px) {
.select-option__2col{
  row-gap: 12px;
}
}


@media screen and (min-width: 768px) {
.select-option__2col .select-option__iconbtn-area,
.select-option__2col .select-option__btn-area{
  width: calc((100% - 16px) / 2);
}
}

@media screen and (max-width: 767px) {
.select-option__2col .select-option__iconbtn-area,
.select-option__2col .select-option__btn-area{
  width: calc((100% - 12px) / 2);
}
}

.select-option__iconbtn,
.select-option__btn{
  border-radius: 10px;
  background: #FFF;
  box-shadow: 2px 2px 10px 0 rgba(0, 0, 0, 0.20);
  display: flex;
  text-decoration: none;
  position: relative;
}

.select-option__btn{
  color: #000!important;
  justify-content: space-between;
}

.select-option__btn-txt-l{
    font-weight: bold;
}


@media screen and (min-width: 768px) {
  .select-option__btn{
    padding: 20px 16px 20px 30px;
  }
}

@media screen and (max-width: 767px) {
  .select-option__btn{
    padding: 18px 10px 18px 14px;
  }
}

@media screen and (min-width: 768px) {
  .select-option__btn-txt-l{
    font-size: 130%;
  }
}


@media screen and (max-width: 767px) {
.select-option__iconbtn{
  flex-direction: column;
}
}

@media screen and (min-width: 768px) {
  .select-option__iconbtn:hover,
  .select-option__btn:hover{
    opacity: 0.8;
  }
}

.select-option__btn-icon{
  display: flex;
  align-items: center;
}

@media screen and (max-width: 767px) {
.select-option__btn-icon img,
.select-option__iconbtn-icon img{
  width: 5px;
  height: 10px;
}
}

.select-option__img{
  background: #000;
  display: flex;
  align-items: center;
}

@media screen and (min-width: 768px) {
.select-option__img{
  border-radius: 10px 0 0 10px;
}
}

@media screen and (max-width: 767px) {
.select-option__img{
  border-radius: 10px 10px 0 0;
  justify-content: center;
  padding: 5px 0;
}
}

@media screen and (max-width: 767px) {
.select-option__img img{
  width: 40px;
  height: 40px;
}
}


@media screen and (min-width: 768px) {
.select-option__txtarea{
  padding: 14px 16px 8px 25px;
}
}

@media screen and (max-width: 767px) {
.select-option__txtarea{
  padding: 10px 11px 15px 11px;
}
}

.select-option__btnttl{
  color: #000;
  font-weight: bold;
}

@media screen and (min-width: 768px) {
.select-option__txtarea .select-option__btnttl{
  font-size: 140%;
  margin-bottom: 10px;
}
}

@media screen and (max-width: 767px) {
.select-option__txtarea .select-option__btnttl{
  font-size: 110%;
  margin-bottom: 6px;
}
}

.select-option__price strong{
  font-weight: bold;
  display: inline-block;
}

@media screen and (min-width: 768px) {
.select-option__price strong{
  font-size: 140%;
}
}

@media screen and (max-width: 767px) {
.select-option__price strong{
  font-size: 110%;
}
}

.select-option__smalltxt{
  font-weight: normal;
  vertical-align: middle;
}

.select-option__smalltxt{
  font-size: 70%;
}


.select-option__iconbtn-icon{
  position: absolute;
}

@media screen and (min-width: 768px) {
.select-option__iconbtn-icon{
  bottom: 16px;
  right: 16px;
}
}

@media screen and (max-width: 767px) {
.select-option__iconbtn-icon{
  bottom: 0;
  right: 10px;
}
}

@media screen and (max-width: 767px) {
.select-option__btn-txt{
  display: flex;
  align-items: center;
}
}

.select-option__btn-txt strong{
  font-weight: bold;
}

@media screen and (min-width: 768px) {
.select-option__btn-txt strong{
  margin-right: 20px;
  font-size: 130%;
}
}

@media screen and (max-width: 767px) {
.select-option__btn-txt strong{
  margin-right: 10px;
  max-width: 19px;
}
}

@media screen and (max-width: 767px) {
.select-option__connect img{
  width: 30px;
  height: 30px;
}
}

/*apply-method*/

@media screen and (min-width: 768px) {
.apply-method{
  padding: 60px 0;
}
}

@media screen and (max-width: 767px) {
.apply-method {
  padding: 40px 11px!important;
  margin: 0 -11px;
  width: calc(100% + 22px);
}
}

.apply-method__ttl{
  font-weight: bold;
}

@media screen and (min-width: 768px) {
.apply-method__ttl{
  font-size: 343%;
}
}

@media screen and (max-width: 767px) {
.apply-method__ttl{
  font-size: 200%;
}
}

.apply-method .txt-link{
  color: #fff;
}

.apply-method__sec:last-child{
  margin-bottom: 0;
}

@media screen and (min-width: 768px) {
.apply-method__sec{
  margin-bottom: 40px;
}
}

@media screen and (max-width: 767px) {
.apply-method__sec{
  margin-bottom: 20px;
}
}


@media screen and (min-width: 768px) {
.apply-method__sec .catalog-section__bg-white{
  padding: 40px;
}
}

@media screen and (max-width: 767px) {
.apply-method__sec .catalog-section__bg-white{
  padding: 20px;
}
}

.apply-method__sec-ttl{
  font-weight: bold;
}

@media screen and (min-width: 768px) {
.apply-method__sec-ttl{
  font-size: 140%;
}
.apply-method__sec-ttl.large{
  font-size: 197%;
}
}

@media screen and (max-width: 767px) {
.apply-method__sec-ttl{
  font-size: 130%;
}
.apply-method__sec-ttl.large{
  font-size: 183%;
}
}

.apply-method__sec-ttl strong{
  font-weight: bold;
}

@media screen and (min-width: 768px) {
.apply-method__sec-ttl strong{
  font-size: 140%;
}
}

@media screen and (max-width: 767px) {
.apply-method__sec-ttl strong{
  font-size: 130%;
}
}

@media screen and (min-width: 768px) {
.apply-method__sec-subttl{
  font-size: 82%;
}
}

@media screen and (max-width: 767px) {
.apply-method__sec-subttl{
  font-size: 70%;
}
}

.apply-method__sec .apply-method__btn{
  display: block;
  border-radius: 10px;
  background: #C03;
  box-shadow: 4px 4px 8px 0 rgba(0, 0, 0, 0.20);
  text-decoration: none;
  color: #fff;
  padding: 20px 40px;
  text-align: center;
  font-weight: bold;
  position: relative;
}

@media screen and (min-width: 768px) {
.apply-method__sec .apply-method__btn{
  font-size: 130%;
}
}

@media screen and (max-width: 767px) {
.apply-method__sec .apply-method__btn{
  font-size: 115%;
}
}

.apply-method__icon{
  position: absolute;
  top: 50%;
  right: 14px;
  transform: translateY(-50%);
  align-items: center;
  display: flex;
}

@media screen and (min-width: 768px) {
.apply-method__sec .apply-method__1col .apply-method__btn{
  margin: 0 auto;
  width: 492px;
  font-size: 160%;
}
}

@media screen and (min-width: 768px) {
.apply-method__sec .apply-method__btn:hover{
  opacity: 0.8;
}
}

.apply-method__4col{
  display: flex;
}

@media screen and (min-width: 768px) {
.apply-method__4col{
  column-gap: 20px;
}
}

@media screen and (max-width: 767px) {
.apply-method__4col{
  flex-direction: column;
  row-gap: 20px;
}
}

@media screen and (min-width: 768px) {
.apply-method__4col .apply-method__plan-btn-area{
  width: calc((100% - 60px) / 4);
}
}

.apply-method__plan-btn{
  display: block;
  text-align: center;
  background: #FFF;
  box-shadow: 4px 4px 8px 0 rgba(0, 0, 0, 0.20);
  border-radius: 10px;
}

.apply-method__plan-btn.max{
  border: 4px solid #C03;
}

.apply-method__plan-btn.poikatsu{
  border: 4px solid #BC9500;
}

.apply-method__plan-btn.mini{
  border: 4px solid #0068B7;
}

@media screen and (min-width: 768px) {
.apply-method__plan-btn{
  padding: 23px 0;
}
}

@media screen and (min-width: 768px) {
.apply-method__plan-btn:hover{
  opacity: 0.8;
}
}

@media screen and (max-width: 767px) {
.apply-method__plan-btn{
  padding: 16px 0;
}
}


@media screen and (min-width: 768px) {
.apply-method__2col{
  display: flex;
  justify-content: space-between;
}
}

@media screen and (min-width: 768px) {
.left-block{
  width: 50%;
  padding-right: 40px;
  align-self: center;
}
}

@media screen and (min-width: 768px) {
.right-block{
  width: 50%;
  padding-left: 40px;
  border-left: 2px solid #D9D9D9;
}
}

.apply-other__sec-ttl{
  text-align: center;
  font-weight: bold;
  margin-bottom: 12px;
}

@media screen and (min-width: 768px) {
.apply-other__sec-ttl{
  font-size: 130%;
}
}

@media screen and (min-width: 768px) {
.apply-other__sec-ttl{
  font-size: 115%;
}
}

.apply-other__tel-txt{
  display: block;
  font-weight: bold;
  text-align: center;
  font-size: 200%;
}

/* catalog-discount */
.catalog-discount {
  width: 100%;
}
.catalog-discount__ttl {
  margin: 0 auto;
  width: 51%;
}
@media screen and (max-width: 768px) {
  .catalog-discount__ttl {
    width: 87%;
  }
}
.catalog-discount__ttl img {
  width: 100%;
}



/* --- smt 余白調整 --- */
@media screen and (max-width: 767px) {
  .catalog-section__inner{
    padding: 0 10px;
  }
}


/* --- catalog-special --- */
.catalog-special {
  width: 100%;
  padding: 40px 80px;
  background-color: #fff;
  border-radius: 10px;
}
@media screen and (max-width: 768px) {
  .catalog-special {
    background-color: transparent;
    padding: 0;
  }
}
.catalog-special__ttl {
  position: relative;
  top: -0px;
  display: flex;
  justify-content: center;
  margin-bottom: 30px;
}

/* float-cv */
.float-cv {
  position: fixed;
  bottom: 0;
  width: 100%;
  padding: 15px 203px;
  background: rgba(51, 51, 51, 0.64);
  opacity: 0;
  z-index: 500;
  transition: 0.2s all;
}
@media screen and (max-width: 768px) {
  .float-cv {
    padding: 15px 8px;
    background: unset;
  }
}
.float-cv.is-show {
  opacity: 1;
}
.float-cv__inner  {
  position: relative;
  justify-content: center;
  align-items: center;
  gap: 14px;
  display: flex;
  width: 100%;
}
@media screen and (max-width: 768px) {
  .float-cv__inner  {
    flex-wrap: nowrap;
    gap: 2px;
  }
}
.float-cv__inner__link {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16px;
  width: 194px;
  height: 57px;
  padding-right: 24px;
  border-radius: 10px;
  background-color: #fff;
  transition: 0.2s all;
}
.float-cv__inner__link:hover {
  opacity: 0.8;
}
@media screen and (max-width: 768px) {
  .float-cv__inner__link {
    width: 49%;
    height: 40px;
    padding-right: 21px;
    background: #666;
  }
}
.float-cv__inner__link img {
  width: 129px;
}
.float-cv__inner__link.blue img {
  width: 107px;
}
.float-cv__inner__link.green img {
  width: 113px;
}
@media screen and (max-width: 768px) {
  .float-cv__inner__link img {
    width: min(100px, 72%);
  }
  .float-cv__inner__link.red {
    border-radius: 10px 0 0 10px;
  }
  .float-cv__inner__link.red img {
    transform: translateY(6%) translateX(15%);
  }
  .float-cv__inner__link.blue {
    border-radius: 0;
  }
  .float-cv__inner__link.blue img {
    width: min(78px, 51%);
    transform: translateX(12%);
  }
  .float-cv__inner__link.green {
    border-radius: 0 10px 10px 0;
  }
  .float-cv__inner__link.green img {
    width: min(62px, 58%);
    transform: translateX(20%);
  }
}
.float-cv__inner__link::after {
  content: "";
  position: absolute;
  right: 11px;
  width: 8px;
  height: 10px;
  background: url(/flcache_data/charge/docomo_mini/images/icon_black_arrow.svg) no-repeat center center;
  background-size: contain;
}

.float-cv__inner__link.blue::after {
  width: 9px;
  height: 10px;
  background: url(/images_osp/common/ico/ico_window03_v2.png) no-repeat center center;
  background-size: contain;
}

.float-cv__inner__link.green::after {
  width: 9px;
  height: 10px;
  background: url(/images_osp/common/ico/ico_window03_v2.png) no-repeat center center;
  background-size: contain;
}
@media screen and (max-width: 768px) {
  .float-cv__inner__link::after {
    right: 4%;
    width: 9px;
    height: 11px;
    background-size: contain;
    background: url(/flcache_data/charge/docomo_mini/images/icon_white_arrow.svg) no-repeat center center;
  }
  .float-cv__inner__link.blue::after {
    background: url(/flcache_data/charge/docomo_mini/images/icon_target_white.svg) no-repeat center center;
  }
  .float-cv__inner__link.green::after {
    background: url(/flcache_data/charge/docomo_mini/images/icon_target_white.svg) no-repeat center center;
  }
}
.float-cv__close {
  --s: 22px;
  position: absolute;
  top: 0;
  left: calc((50% - var(--s) + 340px));
  width: var(--s);
  height: var(--s);
}
.float-cv__close img {
  width: 100%;
}
@media screen and (max-width: 768px) {
  .float-cv__close {
    display: none;
  }
}

/* --- background --- */
/* bg-special */
.bg-special {
  position: relative;
  padding: 80px 0;
  background: url(/flcache_data/charge/docomo_mini/images/bg_special_main_pc.svg);
  background-size: 100% auto;
  background-position: center top;
  background-repeat: no-repeat;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .bg-special {
    background: url(/flcache_data/charge/docomo_mini/images/bg_special_main_smt.svg);
    padding: 80px 0 0;
    background-size: 100% auto;
    background-repeat: no-repeat;
    overflow: visible;
  }
}
.bg-special::before {
  --w: 1443px;
  --h: 875px;
  content: "";
  position: absolute;
  top: 45px;
  left: calc(50% - var(--w) / 2 + 10px);
  display: block;
  width: var(--w);
  height: var(--h);
  background: url(/flcache_data/charge/docomo_mini/images/bg_special_accents_pc.png);
  background-size: contain;
  background-position: center top;
  background-repeat: no-repeat;
  overflow-x: hidden;
}
@media screen and (max-width: 768px) {
  .bg-special::before {
    --w: 100vw;
    --h: 48.606012vw;
    position: absolute;
    top: -11vw;
    left: unset;
    background: url(/flcache_data/charge/docomo_mini/images/bg_special_accents_smt.png);
    background-size: cover;
    background-position: center top;
    background-repeat: no-repeat;
    z-index: 0;
  }
}
@media screen and (max-width: 768px) {
  .bg-special .catalog-section__bg-white {
    background-color: transparent;
    border-radius: none;
    padding: 0;
  }
}

/* bg-blue */
.bg-blue {
  position: relative;
  padding: 60px 0;
  background: url(/flcache_data/charge/docomo_mini/images/bg_blue_main_pc.svg);
  background-size: 100% auto;
  background-position: center top;
  background-repeat: repeat-y;
  overflow: hidden;
}
 @media screen and (max-width: 768px) {
  .bg-blue {
    padding: 0;
    padding: 30px 0;
    background-size: 100% auto;
    background-repeat: repeat-y;
  }
}

/* bg-ryoukin */
.bg-ryoukin {
  --separate-bold: 10px;
  --gradient-height: 300px;
  --b-c: #EBF6FF;
  --y-c: #FFF8EA;
  --mask-y: 682px;
  position: relative;
}
.bg-ryoukin .catalog-section__inner {
  position: relative;
  z-index: 1;
}
.bg-ryoukin::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: block;
  background: linear-gradient(
    90deg,
    var(--y-c) 0%,
    var(--y-c) calc(50% - (var(--separate-bold) / 2)),
    #fff calc(50% - (var(--separate-bold) / 2)),
    #fff calc(50% + (var(--separate-bold) / 2)),
    var(--b-c) calc(50% + (var(--separate-bold) / 2)),
    var(--b-c) 100%
  );
  mask-image: linear-gradient(transparent 0%, black var(--mask-y), black 100%);
  z-index: 0;
  pointer-events: none;
}
.bg-ryoukin::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(/flcache_data/charge/docomo_mini/images/bg_ryoukin_main_v2_pc.png);
  background-size: 1920px;
  background-position: center top;
  background-repeat: no-repeat;
  z-index: 0;
  pointer-events: none;
}
@media screen and (max-width: 768px) {
  .bg-ryoukin {
    --mask-y: 80vw;
  }
  .bg-ryoukin::after {
    background: url(/flcache_data/charge/docomo_mini/images/bg_ryoukin_main_v2_smt.png);
    background-size: 100%;
  }
}

/* bg-otoku */
.bg-otoku {
  position: relative;
  padding: 60px 0 50px;
  background: #F2F9FF;
}


/* bg-red */
.bg-red {
  position: relative;
  padding: 80px 0;
  background: url(/flcache_data/charge/docomo_mini/images/bg_red_main_pc.svg);
  background-size: 100% auto;
  background-position: center top;
  background-repeat: repeat-y;
}
 @media screen and (max-width: 768px) {
  .bg-red {
    padding: 60px 0;
    background-size: 100% auto;
    background-repeat: repeat-y;
  }
}

/* margin */
@media screen and (min-width: 769px) {
  .s-mt-m07-pc {
    margin-top: -7px;
  }
  .s-mt-m10-pc {
    margin-top: -10px;
  }
  .s-mt-m14-pc {
    margin-top: -14px;
  }
  .s-mb-30-pc {
    margin-bottom: 30px;
  }
}

/* オーバーラップ用 */
/* .sec-common-lv2__inner, .sec-common-lv2__inner--slim {
  width: 100% !important;
} */
.btn-pagetop, .btn-pagetop.bottom {
  bottom: 10px;
}
html:has(.float-cv) .btn-pagetop,
html:has(.float-cv) .btn-pagetop.bottom {
  bottom: 105px;
}
html:has(.float-cv:not(.is-show)) .btn-pagetop,
html:has(.float-cv:not(.is-show)) .btn-pagetop.bottom {
  bottom: 10px;
}
@media screen and (max-width: 768px) {
  html:has(.float-cv) .btn-pagetop,
  html:has(.float-cv) .btn-pagetop.bottom,
  html:has(.float-cv) .btn-pagetop.btn-stagger {
    bottom: 70px;
  }
  .btn-pagetop.btn-stagger {
    animation: none;
  }
}
@media screen and (min-width: 767px) {
  .btn-common__button--h3-blank.wide {
    width: 340px;
  }
}


/* catalog-discount-table */
.catalog-discount-table {
  position: relative;
  width: 100%;
  aspect-ratio: 960 / 285;
  background: url(/flcache_data/charge/docomo_mini/images/img_discount_table_base_v2_pc.png) no-repeat center center;
  background-size: contain;
}
.catalog-discount-table::after {
  --s: 48px;
  content: "";
  position: absolute;
  top: calc(var(--s) * 2 / 3 * -1);
  left: calc(50% - var(--s) / 2);
  display: block;
  width: var(--s);
  height: var(--s);
  background: url(/flcache_data/charge/docomo_max/images/ico_plus_green.svg);
  background-size: contain;
  background-repeat: no-repeat;
}
@media screen and (max-width: 768px) {
  .catalog-discount-table {
    aspect-ratio: 672 / 606;
    background: url(/flcache_data/charge/docomo_mini/images/img_discount_table_base_v2_smt.png) no-repeat center center;
    background-size: contain;
    transform: translatey(10vw);
    margin-bottom: calc(10vw + 30px);
  }
  .catalog-discount-table::after {
    --s: 9.5vw;
    top: -11vw;
  }
}
.catalog-discount-table__list {
  position: absolute;
  top: 82px;
  left: 20px;
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 768px) {
   .catalog-discount-table__list {
    top: calc((100vw - 20px) * 0.31);
    left: calc((100vw - 20px) * 0.035);
  }
}
.catalog-discount-table__list__item {
  display: flex;
  align-items: center;
  width: 422px;
  height: 100px;
  transition: 0.2s all;
}
.catalog-discount-table__list__item button{
  display: flex;
  align-items: center;
  width: 100%;
  height: 100%;
  padding-left: 48px;
}
@media screen and (max-width: 768px) {
  .catalog-discount-table__list__item {
    width: calc((100vw - 20px) * 0.929);
    height: calc((100vw - 20px) * 0.33);
    transform-origin: center left;
  }
  .catalog-discount-table__list__item button{
    align-items: unset;
    padding-top: calc((100vw - 20px) * 0.02);
    padding-left: calc((100vw - 20px) * 0.02);
  }
}
.catalog-discount-table__list__item:hover {
  opacity: 0.7;
}
.catalog-discount-table__list__item.no-link:hover {
  opacity: 1;
}
.catalog-discount-table__list__item:nth-child(2) {
  height: 42px;
}
.catalog-discount-table__list__item:nth-child(3) {
  height: 41px;
}
@media screen and (max-width: 768px) {
  .catalog-discount-table__list__item:nth-child(1) img {
    width: auto;
    height: calc((100vw - 20px) * 0.041);
  }
  .catalog-discount-table__list__item:nth-child(2) {
    height: calc((100vw - 20px) * 0.119);
  }
  .catalog-discount-table__list__item:nth-child(2) button {
    padding-top: calc((100vw - 20px) * 0.025);
  }
  .catalog-discount-table__list__item:nth-child(2) img {
    width: auto;
    height: calc((100vw - 20px) * 0.0763);
  }
  .catalog-discount-table__list__item:nth-child(3) {
    height: calc((100vw - 20px) * 0.107);
  }
  .catalog-discount-table__list__item:nth-child(3) button {
    padding-top: calc((100vw - 20px) * 0.024);
  }
  .catalog-discount-table__list__item:nth-child(3) img {
    width: auto;
    height: calc((100vw - 20px) * 0.0385);
  }
}

/* --- bnr-mydocomo --- */
.bnr-mydocomo a{
  box-shadow: 2px 2px 10px 0 rgba(0, 0, 0, 0.20);
  border-radius: 10px;
}

@media screen and (min-width: 768px) {
  .bnr-mydocomo a:hover{
    opacity: 0.8;
  }
}

/* modal-note */
.modal-note {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: end;
  z-index: 100;
}
.modal-note__dsc-area {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  position: absolute;
  width: 400px;
  padding: 10px;
  background-color: rgba(0, 0, 0, 0.6);
  opacity: 0;
  z-index: -1;
  transition: 0.2s all;
  pointer-events: none;
}
.catalog-pran-explain__notes__item:nth-child(3) .modal-note__dsc-area {
  left: -130px;
}
.catalog-pran-explain__notes__item:nth-child(3) .modal-note__dsc-area::after {
  left: 320px;
}
@media screen and (max-width: 768px) {
  .catalog-pran-explain__notes__item:nth-child(1) .modal-note__dsc-area {
    left: 32.5vw;
  }
  .catalog-pran-explain__notes__item:nth-child(1) .modal-note__dsc-area::after {
    left: 18vw;
  }
  .catalog-pran-explain__notes__item:nth-child(2) .modal-note__dsc-area::after {
    left: 51vw;
  }
  .catalog-pran-explain__notes__item:nth-child(3) .modal-note__dsc-area {
    left: -28vw;
  }
  .catalog-pran-explain__notes__item:nth-child(3) .modal-note__dsc-area::after {
    left: 74vw;
  }
}
@media screen and (max-width: 768px) {
  .modal-note__dsc-area {
    width: 80vw;
  }
}
.modal-note__dsc-area.is-show {
  opacity: 1;
  z-index: 100;
  pointer-events: auto;
}
.modal-note__dsc-area::after {
  --w: 12px;
  --h: 8px;
  content: "";
  position: absolute;
  bottom: -12px;
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-right: var(--h) solid transparent;
  border-left: var(--h) solid transparent;
  border-top: var(--w) solid rgba(0, 0, 0, 0.6);
  border-bottom: 0;
}
.modal-note__dsc-area__close {
  display: flex;
  justify-content: end;
  position: absolute;
  top: 0;
  right: 0;
  padding-top: 4px;
  padding-right: 4px;
  width: 30px;
  height: 30px;
}
.modal-note__dsc-area__close img {
  height: 100%;
  cursor: pointer;
}
.modal-note__dsc-area__dsc {
  width: 100%;
  margin-top: 25px;
  font-size: 1.2rem;
  color: #fff;
}
.modal-note__icon {
  position: absolute;
  bottom: -40px;
  left: 187px;
  width: 22px;
  height: 22px;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .modal-note__icon {
    left: 48vw;
    width: 19px;
    height: 19px;
  }
}
.modal-note__icon img {
  width: 100%;
}

/* モーダル用 */
#catalog-modal-area {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  visibility: hidden;
  opacity: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
}
#catalog-modal-area.active {
  visibility: visible;
  opacity: 1;
}

.catalog-modal-area__content {
  width: 100%;
}

.catalog-modal-slider {
  width: 100%;
}
.catalog-modal-slider__item {
  position: relative;
  height: 100vh;
  display: flex!important;
  justify-content: center;
  align-items: center;
}
.slick-initialized .slick-slide {
  display: flex !important;
}
.catalog-modal-slider__item__body {
  --w: 980px;
  --h: 516px;
  position: relative;
  display: flex;
  flex-direction: column;
  width: var(--w);
  margin: 0 auto;
  padding: 40px 87px;
  background-color: #fff;
  border-radius: 10px;
  background: url(/flcache_data/charge/docomo_mini/images/bg_modal_pc.png);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
@media screen and (max-width: 768px) {
  .catalog-modal-slider__item__body {
    --w: 94vw;
    --h: 74.5vh;
    max-height: var(--h);
    padding: 32px 14px;
    background: url(/flcache_data/charge/docomo_mini/images/bg_modal_smt.png);
    background-size: 120%;
    background-position: center;
    background-repeat: no-repeat;
    overflow: visible;
  }
}
.catalog-modal-slider__item__body__inner {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 62px 60px;
  background-color: #fff;
  border-radius: 10px;
  overflow: auto;
}
@media screen and (max-width: 768px) {
  .catalog-modal-slider__item__body__inner {
    padding: 31px 24px;
  }
}
.catalog-modal-slider__item__body__inner__ttl {
  color: #000;
  font-size: 2.4rem;
  font-weight: bold;
  text-align: center;
  line-height: 150%;
}
@media screen and (max-width: 768px) {
  .catalog-modal-slider__item__body__inner__ttl {
    font-size: 2rem;
  }
}
.catalog-modal-slider__item__body__inner__ttl + .catalog-modal-slider__item__inner__txt {
  margin-top: 20px;
}
.catalog-modal-slider__item__body__inner__txt {
  color: #000;
  font-size: 1.6rem;
  line-height: 180%;
}
@media screen and (max-width: 768px) {
  .catalog-modal-slider__item__body__inner__txt {
    font-size: 1.5rem;
  }
}
.catalog-modal-slider__item__body__inner__txt strong {
  color: #C03;
  font-weight: bold;
}
.catalog-modal-slider__item__body__inner__btn-area {
  display: flex;
  justify-content: center;
  gap: 22px;
  flex-wrap: wrap;
  margin-top: auto;
}
.catalog-modal-slider__item__body__inner__btn-area__btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 310px;
  padding: 14px 40px;
  font-size: 1.4rem;
  font-weight: bold;
  line-height: 16.8px;
  color: #fff;
  background: linear-gradient(90deg, #C03 0%, #F06789 100%);
  border-radius: 100vw;
  text-decoration: none;
  transition: 0.2s all;
}
.catalog-modal-slider__item__body__inner__btn-area__btn:visited, .catalog-modal-slider__item__body__inner__btn-area__btn:active, .catalog-modal-slider__item__body__inner__btn-area__btn:hover {
  color: #fff;
}
.catalog-modal-slider__item__body__inner__btn-area__btn .ico-arrow {
  --s: 8px;
  content: "";
  position: relative;
  top: calc(var(--s) * -0.14);
  margin-left: 4px;
  width: var(--s);
  height: var(--s);
  border-bottom: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(-45deg);
}
.catalog-modal-slider__item__body__inner__btn-area__btn:hover {
  opacity: 0.8;
}
.catalog-modal-slider__item__close-btn {
  --s: 40px;
  position: absolute;
  top: 21px;
  right: 33px;
  font-size: 0;
  width: var(--s);
  height: var(--s);
  background: url(/flcache_data/charge/docomo_max/images/ico_close_w.svg);
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
  border: none;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .catalog-modal-slider__item__close-btn {
    top: -48px;
    right: 4px;
  }
}

.catalog-modal-slider .slick-list {
  overflow: unset !important;
}
.catalog-modal-slider .slick-prev, .catalog-modal-slider .slick-next {
  --s: 40px;
  position: absolute;
  top: calc(50% - var(--s) / 2);
  display: flex;
  justify-content: center;
  align-items: center;
  width: var(--s);
  height: var(--s);
  background-color: #fff;
  border-radius: 100vw;
  font-size: 0;
  border: none;
  cursor: pointer;
}
.catalog-modal-slider .slick-prev::before, .catalog-modal-slider .slick-next::before {
  --s: 11px;
  content: "";
  position: absolute;
  width: var(--s);
  height: var(--s);
  border-bottom: 4px solid #cc0033;
  border-right: 4px solid #cc0033;
  transform: rotate(-45deg);
}
.catalog-modal-slider .slick-prev {
  left: calc(50% - 504px);
}
@media screen and (max-width: 768px) {
  .catalog-modal-slider .slick-prev {
    left: 0;
  }
}
.catalog-modal-slider .slick-prev::before {
  right: 9px;
  transform: rotate(135deg);
}
.catalog-modal-slider .slick-next {
  right: calc(50% - 498px);
}
@media screen and (max-width: 768px) {
  .catalog-modal-slider .slick-next {
    right: 0;
  }
}
.catalog-modal-slider .slick-next::before {
  left: 9px;
}

.catalog-modal-slider .slick-prev,
.catalog-modal-slider .slick-prev {
  background: #fff !important;
  z-index: 100 !important;
}

.catalog-modal-slider .slick-prev:hover,
.catalog-modal-slider .slick-prev:focus,
.catalog-modal-slider .slick-next:hover,
.catalog-modal-slider .slick-next:focus {
  color: unset !important;
  background: #fff !important;
  z-index: 100 !important;
}

html:has(.catalog-modal-slider .slick-active[data-slick-index="0"]) .slick-prev {
  opacity: 0.5;
  cursor: default;
  pointer-events: none;
}

html:has(.catalog-modal-slider .slick-active[data-slick-index="4"]) .slick-next {
  opacity: 0.5;
  cursor: default;
  pointer-events: none;
}

@media screen and (min-width: 768px) {
.apply-method__tel-btn{
  display: none;
}
}

@media screen and (max-width: 767px) {
.apply-method .apply-method__tel-btn{
  display: flex;
  align-items: center;
  padding: 2px;
  border-radius: 10px;
  background: #C03;
  box-shadow: 4px 4px 8px 0 rgba(0, 0, 0, 0.20);
  align-items: center;
  color: #fff!important;
}
}

@media screen and (max-width: 767px) {
.apply-method__tel-btn-icon{
  background: #fff;
  align-self: stretch;
  width: 32px;
  border-radius: 8px 0 0 8px;
  display: flex;
  align-items: center;
}
}

@media screen and (max-width: 767px) {
.apply-method__tel-btn-icon img{
  margin: 0 auto;
}
}
@media screen and (max-width: 767px) {
.apply-method .apply-method__tel-btn-txt{
  text-align: center;
  font-size: 115%;
  font-weight: bold;
  width: calc(100% - 32px);
}
}

@media screen and (max-width: 767px) {
.apply-method__tel-btn-s-txt{
  font-size: 75%;
}
}


/* txt-side-line */
.txt-side-line{
margin-top: 40px;
padding: 0 25px;
}
.txt-side-line span{
display: inline-block;
position: relative;
padding: 0 10px;
}
.txt-side-line span:before,
.txt-side-line span:after{
content: "";
display: block;
width: 1px;
height: 27px;
position: absolute;
background: #000;
}
.txt-side-line span:before{
left: -10px;
bottom: -2px;
transform: rotate(-45deg);
}
.txt-side-line span:after{
right: -10px;
bottom: -2px;
transform: rotate(45deg);
}