@charset "utf-8";
html {
 box-sizing: border-box;
 -ms-overflow-style: scrollbar;
 font-size: 62.5%;
}
/*html { scroll-behavior: smooth;}*/
*, *::before, *::after {
 box-sizing: border-box;
}
body {
 -webkit-text-size-adjust: 100%;
 color: #000000;
 font-size: 1.6rem;
 font-family: "Noto Sans JP", "Yu Gothic Medium", YuGothic, "Yu Gothic Medium", "Yu Gothic", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
 margin: 0;
 overflow-x: hidden;
 position: relative;
}
.lp-h2 {
 font-weight: 700;
 text-align: center;
 font-size: 4rem;
 margin-bottom: 35px;
 line-height: 1.3;
}
@media (max-width: 768px) {
 .lp-h2 {
  font-size: 6.4vw;
  line-height: 1.2;
 }
}
.lp-h2 span {
 font-weight: 800;
 color: #FF0033;
 font-size: 6rem;
}
.lp-ttl-article > span span.strong {
 color: #FF0033;
 font-size: 6rem;
}
@media (max-width: 768px) {
 .lp-h2 span {
  font-size: 7.666666667vw;
 }
}
.lp-h3 {
 font-weight: 700;
 text-align: center;
 font-size: 3.6rem;
 margin-bottom: 20px;
 position: relative;
}
@media (max-width: 768px) {
 .lp-h3 {
  font-size: 6.1333333333vw;
  margin-bottom: 30px;
 }
}
.lp-h3 span {
 position: relative;
 z-index: 1;
}
.lp-h3 span::after {
 content: "";
 width: 100%;
 height: 18px;
 background-color: rgba(255, 0, 51, 0.4);
 position: absolute;
 bottom: 2px;
 left: 50%;
 transform: translateX(-50%);
 z-index: -1;
}
@media (max-width: 768px) {
 .lp-h3 span::after {
  height: 12px;
 }
}
.lp-h3-wrapper {
 position: relative;
 text-align: center;
}
.lp-h3:before, .lp-h3:after {
 position: relative;
 display: inline-block;
 content: "";
 background: #000;
 width: 3px;
 height: 0.8em;
 margin: 0 0.5em;
 vertical-align: middle;
}
@media (max-width: 768px) {
 .lp-h3:before, .lp-h3:after {
  position: absolute;
  bottom: 3px;
  height: 1.2em;
  margin: 0;
 }
}
.lp-h3:before {
 transform: rotate(-35deg);
}
@media (max-width: 768px) {
 .lp-h3:before {
  left: 15px;
 }
}
.lp-h3:after {
 transform: rotate(35deg);
}
@media (max-width: 768px) {
 .lp-h3:after {
  right: 15px;
 }
}
.lp-h3-plane {
 font-family: "M PLUS Rounded 1c", sans-serif;
 font-weight: 700;
 font-size: 4.4rem;
 margin-bottom: 45px;
}
@media (max-width: 768px) {
 .lp-h3-plane {
  font-size: 8.2666666667vw;
  text-align: center;
  margin-bottom: 30px;
 }
}
.lp-h3-plane span {
 position: relative;
 z-index: 1;
}
.lp-h3-plane span::after {
 content: "";
 width: 100%;
 height: 18px;
 background-color: rgba(255, 0, 51, 0.4);
 position: absolute;
 bottom: 2px;
 left: 50%;
 transform: translateX(-50%);
 z-index: -1;
}
@media (max-width: 768px) {
 .lp-h3-plane span::after {
  height: 12px;
 }
}
.lp-h4 {
 font-size: 2.2rem;
 font-weight: bold;
}
@media (max-width: 768px) {
 .lp-h4 {
  font-size: 6.4vw;
 }
}
.justify-content-center {
 justify-content: center !important;
}
.lp-anchor-item-n {
 width: calc(100% / 4);
}
.lp-anchor-list {
 width: 100%;
 max-width: 980px;
 display: flex;
 justify-content: space-between;
 flex-wrap: wrap;
 margin: auto;
 background-color: #FFF;
 border: #FF0033 solid 2px;
 border-radius: 12px;
 padding: 1em 0;
 box-shadow: 0.25em 0.35em #FF0033;
}
.lp-anchor-item-n a {
 width: 100%;
 height: 100%;
 border-right: #FF0033 solid 3px;
 position: relative;
 display: block;
 text-align: center;
 padding: 1em 0 0.5em;
}
.lp-anchor-item-n:last-child a {
 border-right: none;
}
.lp-anchor-item-n a::before, .lp-anchor-item-n a::after {
 content: '';
 width: 12px;
 height: 12px;
 border: 0;
 border-bottom: solid 3px #ff0033;
 border-right: solid 3px #ff0033;
 position: absolute;
 bottom: -0.4em;
 margin-left: -6px;
 transform: rotate(45deg);
 transition: all 0.3s;
}
.lp-anchor-item-n a:hover::before, .lp-anchor-item-n a:hover::after {
 bottom: -0.6em;
}
.lp-anchor-icon {
 font-size: 50px;
 position: absolute;
 top: -1.25em;
 left: 0;
 right: 0;
 height: 1.2em;
 display: block;
 margin: 16px auto 18px;
 border-radius: 2em;
 width: 1.2em;
}
@media (max-width: 768px) {
 .lp-anchor-icon {
  width: 16vw;
  height: 8vw;
  padding: 0 0;
  margin: 0 auto;
 }
}
.lp-anchor-icon img {
 vertical-align: top;
}
.lp-anchor-txt {
 min-height: 52px;
 font-size: 20px;
 font-weight: bold;
 line-height: 1.2;
 text-align: center;
 display: flex;
 justify-content: center;
 align-items: center;
 margin: 0;
}
@media (max-width: 768px) {
 .lp-anchor-txt {
  min-height: 1em;
  font-size: 3.333333333vw;
  text-align: left;
  line-height: 1.2;
 }
 .arrow_r {
  width: 16vw;
  padding: 0 4vw;
  margin: 0 auto 0;
 }
}
/********************************************************/
.lp-anchor-wrapper {
 padding: 20px 15px 0;
}
.l-lp-section {
 position: relative;
 padding-bottom: 0;
 overflow: hidden;
}
.l-section.pt0 {
 padding: 0px 0 0 0;
 overflow: hidden;
}
.bgB {
 width: 100%;
 background-color: #dff7ff;
}
.bgW {
 width: 100%;
 background-color: #FFF;
 padding: 40px 25px;
}
.bgW2 {
 width: 100%;
 background-color: #FFF;
 padding: 40px 25px 0;
}
.ttlBox {
 border-radius: 20px;
 padding: 2.5em 0;
 margin: 0 auto;
 max-width: 980px;
}
.ttlBox .lp-h2 {
 margin-bottom: 0;
}
.tab_boxA .btn_area {
 max-width: 980px;
 margin: 0 auto;
 display: flex;
 justify-content: center;
}
.tab_boxA .tab_btn {
 width: 45%;
 padding: 0 0;
 text-align: center;
 cursor: pointer;
 transition: all 0.2s ease 0s;
 opacity: 0.6;
 margin-bottom: 0;
 margin-top: 20px;
}
.tab_boxA .tab_btn + .tab_btn {
 margin-left: 30px;
}
.tab_boxA .tab_btn:hover {
 opacity: 1;
}
.tab_boxA .tab_btn.active {
 opacity: 1;
}
.tab_box .panel_area {
 padding: 80px 0;
}
.tab_box .tab_panel {
 height: 0;
 opacity: 0;
}
.tab_box .tab_panel.active {
 height: 100%;
 opacity: 1;
 transition: all .5s ease;
}
.fc_g {
 color: #555555;
}
.sTxt {
 font-size: 16px;
 line-height: 1.4;
}
.sTxt a {
 font-size: 16px;
 color: #000;
 text-decoration: underline;
}
.sTxt a:hover {
 text-decoration: none;
}
.lp-anchor-wrapper {
 width: 100%;
 background-color: #dff7ff;
}
#moonlight .fz90 {
 font-size: 90px;
}
#moonlight .fz80 {
 font-size: 80px;
}
#moonlight .fz60 {
 font-size: 60px;
}
#moonlight .fz44 {
 font-size: 44px;
}
#moonlight .fz36 {
 font-size: 36px;
}
#moonlight .fz32 {
 font-size: 32px;
}
#moonlight .fz30 {
 font-size: 30px;
}
#moonlight .fz26 {
 font-size: 26px;
}
#moonlight .fz22 {
 font-size: 22px;
}
#moonlight .fz20 {
 font-size: 20px;
}
#moonlight .fz18 {
 font-size: 18px;
}
#moonlight .fz16 {
 font-size: 16px;
}
#moonlight .fz14 {
 font-size: 14px;
}
#moonlight .fz12 {
 font-size: 12px;
}
.scale {
 transform: scale(1.2);
 margin: 2.5% auto;
 width: 100%;
 max-width: 900px;
}
.lTtl {
 border-left: 5px solid #FF0033;
 font-weight: bold;
 padding-left: 0.5em;
 margin-top: 1em;
}
.lTtl2 {
 border-left: 5px solid #FF0033;
 font-weight: bold;
 padding-left: 0.5em;
 margin-top: 1em;
 line-height: 2.9;
}
.xLargeFont {
 font-size: 30px;
}
.largeFont {
 font-size: 22px;
}
.mFont {
 font-size: 16px;
}
.largeFont a {
 font-size: 21px;
 color: #000;
 text-decoration: underline;
}
.largeFont a:hover {
 text-decoration: none;
}
.fc_green {
 color: #FF0033;
}
.fc_red {
 color: #FF0033;
}
#point, #relief, #lineup, #voice, #app {
 padding-bottom: 80px;
}
#voice {
 background-color: #dff7ff;
}
.lp-ttl-article-wrapper {
 padding: 80px 0 60px;
}
#point, #point .lp-ttl-article-wrapper, #osusume .lp-ttl-article-wrapper {
 background-color: #dff7ff;
}
#relief, #relief .lp-ttl-article-wrapper {
 background-color: #dff7ff;
}

#point .lp-ttl-article-wrapper, #relief .lp-ttl-article-wrapper, #lineup .lp-ttl-article-wrapper, #lineup .lp-ttl-article-wrapper {
 padding: 80px 0 20px;
 margin-bottom: 0;
 text-align: center;
}
.lp-ttl-article-wrapper {
 background-color: #dff7ff;
 padding: 40px 0 45px;
 margin-bottom: 40px;
 text-align: center;
}
#addBox{
 margin: 40px auto;
}
#addBox .c2{
 background-color: transparent;
}
#addBox .lp-ttl-article-wrapper {
 background-color: #FFF;
 padding: 40px 0 45px;
 margin-bottom: 0;
 text-align: center;
}
#point .lp-h2 span, #relief .lp-h2 span, #app .lp-h2 span, #osusume .lp-h2 span {
 color: #FF0033;
}
.gMarker span {
 position: relative;
 z-index: 1;
 color: #FF0033;
 background: linear-gradient(transparent 60%, #E1FF91 0%);
 display: inline;
 padding: 0 1px 0px;
 font-weight: bold;
}
.rMarker {
 line-height: 1.6;
}
.rMarker span {
 position: relative;
 z-index: 1;
 color: #FF0032;
 background: linear-gradient(#FFF 60%, #ffe9ef 0%);
 display: inline;
 padding: 0 1px 0px;
 font-weight: bold;
}
.lp-accordion {
 width: 100%;
 max-width: 980px;
 background-color: #fff;
 border: #FF0033 solid 4px;
 border-radius: 10px;
 overflow: hidden;
 display: block;
}
.lp-accordion-icon {
 width: 30px;
 height: 30px;
 background-color: #FF0033;
 border-radius: 4px;
 display: flex;
 justify-content: center;
 align-items: center;
 margin-left: 0;
 position: relative;
}
.lp-accordion-img {
 width: 80px;
 font-size: 52px;
 line-height: 1;
 background-color: #FF0033;
 display: flex;
 color: #FFF;
 justify-content: center;
 align-items: center;
 align-self: stretch;
 height: auto;
}
.lp-accordion-icon span {
 background-color: #fff;
 position: absolute;
}
.lp-accordion-icon span:nth-child(1) {
 width: 4px;
 height: 20px;
 top: calc(50% - 10px);
 left: calc(50% - 2px);
 transition: all 0.25s ease;
}
@media (max-width: 768px) {
 .lp-accordion-icon span:nth-child(1) {
  width: 0.5333333333vw;
  height: 3.7333333333vw;
  top: calc(50% - 1.85vw);
  left: calc(50% - 0.265vw);
 }
}
@media (max-width: 500px) {
 .lp-accordion-icon span:nth-child(1) {
  width: 0.5333333333vw;
  height: 3.7333333333vw;
  top: calc(50% - 1.85vw);
  left: calc(50% - 0.265vw);
 }
}
.lp-accordion-icon span:nth-child(2) {
 width: 20px;
 height: 4px;
 top: calc(50% - 2px);
 left: calc(50% - 10px);
}
@media (max-width: 768px) {
 .lp-accordion-icon span:nth-child(2) {
  width: 3.7333333333vw;
  height: 0.5333333333vw;
  top: calc(50% - 0.265vw);
  left: calc(50% - 1.85vw);
 }
}
@media (max-width: 500px) {
 .lp-accordion-icon span:nth-child(2) {
  width: 3.7333333333vw;
  height: 0.5333333333vw;
  top: calc(50% - 0.265vw);
  left: calc(50% - 1.85vw);
 }
}
.lp-accordion-title {
 width: calc(100% - 30px);
 line-height: 1 !important;
 padding: 0.25em 0 0.35em 50px;
 background-color: #FFF;
 text-align: center;
}
@media (max-width: 768px) {
 .lp-accordion-title {
  width: calc(100% - 50px - 7vw);
 }
}
@media (max-width: 500px) {
 .lp-accordion-title {
  width: calc(100% - 12.5333333333vw - 6vw);
  padding: 5px 0.8vw 5px 1.6vw;
 }
}
.text-link-arrow-bottom {
 font-weight: bold;
}
.wide15 {}
.wBox {
 background-color: #FFF;
 border-radius: 0;
 padding: 25px 25px;
}
.wBox2 {
 background-color: #FFF;
 border-radius: 0;
 padding: 25px 25px 50px;
}
.dotted {
 margin: 20px auto;
}
.dotted img {
 display: block;
}
.wImg {
 width: 420px;
 margin: 40px auto;
}
.onlineStore {
 border: 4px solid #fb5060;
 background-color: #fff8f8;
 padding: 25px;
 margin: 0 auto 0;
 border-radius: 8px;
}
.priceTop {
 margin-top: 2em;
}
.mt2em {
 margin-top: 2em;
}
.mb1em {
 margin-bottom: 1em;
}
.deviceBox {
 display: flex;
 justify-content: space-between;
 padding: 0px 0 20px;
}
.deviceItem {
 text-align: center;
 width: 46%;
 background-color: #FFF;
 border-radius: 10px;
 padding: 0 28px 20px 28px;
}
.deviceImg {
 width: 80%;
 margin: 20px auto 0;
}
.deviceName {
 font-size: 31px;
 font-weight: bold;
 line-height: 1;
 margin-bottom: 1em;
}
.deviceName2 {
 font-size: 31px;
 font-weight: bold;
 line-height: 1;
 margin-bottom: 1em;
}
.deviceTxt {
 font-size: 21px;
 line-height: 1.4;
 margin-bottom: 1.25em;
}
.ttlHead {
 margin-top: 80px;
 margin-bottom: 40px;
}
.simBox {
 background-color: #FFF;
 border-radius: 12px;
 padding: 60px 80px;
}
.simItem {
 display: flex;
 justify-content: space-between;
 align-items: center;
}
.simImg {
 flex-basis: 17%;
}
.simImg img {
 width: 140px;
}
.simTxt {
 flex-basis: 83%;
 font-weight: bold;
 padding: 0 0 0 1em;
}
.mImg {
 width: 80%;
 margin-left: auto;
 margin-right: auto;
}
.voiceArea {
 border: 4px solid #FF0033;
 padding: 40px 80px;
 border-radius: 10px;
 flex-wrap: wrap;
 background-color: #FFF;
}
.voiceBox {
 display: flex;
 justify-content: space-between;
 align-items: center;
}
.voiceThumb {
 flex-basis: 19%;
 text-align: center;
 font-weight: bold;
}
.voiceItem {
 flex-basis: 81%;
 padding-left: 2em;
}
.btn-m {
 border-radius: 8px;
 min-width: 280px;
 padding: 13px 5px;
 font-size: 21px;
}
#lp .btn-arrow.btn-m {
 min-width: 360px;
}
#lp .gotop {
 bottom: 150px;
}
.line-red {
 border-bottom: 4px solid #ff0032;
}
.movieWrap {
 position: relative;
 padding-bottom: 56.25%;
 height: 0;
 overflow: hidden;
}
.movieWrap iframe {
 position: absolute;
 top: 0;
 left: 0;
 width: 100%;
 height: 100%;
 border: 1px solid #333;
}
.lp-video {
 border-radius: 12px;
 overflow: hidden;
 display: inline-block;
}
.add-table th, .add-table td {
 line-height: 1.5;
 border-top: 2px solid #FF0033;
}
.add-table td.btpn {
 border-top: none;
}
.add-table .brl {
 border-left: 2px solid #FF0033;
 white-space: nowrap;
}
.add-table th {
 background: #FFFFD4;
 padding: 0.5em 0.25em;
}
.add-table td {
 background: #FFFFD4;
 padding: 0.5em 0.25em;
}
.add-table td.lpd {
 background: #FFFFD4;
 padding: 0.5em 3.25em;
}
.add-table {
 border-collapse: separate;
 border: solid 2px #FF0033;
 border-radius: 6px;
 text-align: center;
 position: relative;
 margin: 0 auto 60px;
}
.add-table .tatb {
 border-radius: 6px 6px 6px 6px;
}
.add-table .trt {
 border-radius: 6px 0 0 0;
}
.add-table .tlt {
 border-radius: 0 6px 0 0;
}
.add-table .trb {
 border-radius: 0 0 6px 0;
}
.add-table .tlb {
 border-radius: 0 0 0 6px;
}
.tatb.text-left.btpn.lpd {
 text-align: center;
}
.add-table .freeSetting {
 width: 70%;
 margin: 0.75em auto 0.75em;
 text-align: center;
}
.add-table.bdg1::before {
 position: absolute;
 top: -42.5px;
 left: -30px;
 width: 85px;
 height: 85px;
 content: '';
 background-image: url(../assets/images/free.png);
 background-size: contain;
}
.add-table.bdg2::before {
 position: absolute;
 top: -42.5px;
 left: -30px;
 width: 85px;
 height: 85px;
 content: '';
 background-image: url("../assets/images/paid.png");
 background-size: contain;
}
.fc-green.lp-ttl-slash {
 color: #FF0033;
 font-size: 26px;
 padding-bottom: 0.5em;
}
.fc-green.lp-ttl-slash:before, .fc-green.lp-ttl-slash:after {
 background: #FF0033;
}
.add_btn_img {
 width: 100%;
 max-width: 400px;
 margin-left: auto;
 margin-right: auto;
 display: block;
}
.indent1 {
 text-indent: -1em;
 padding-left: 1em;
}
.indent3 {
 text-indent: -2.5em;
 padding-left: 2.5em;
}
.sm3-txt {
 font-size: 11px;
 text-align: center;
 background-color: #F00;
 border-radius: 2em;
 color: #FFF;
 padding: 0.25em 1em;
}
.lp-anchor-txt {
 display: block;
 text-align: center;
}
.family-h2 {
 width: 9.5em;
 font-size: 55px;
 margin-bottom: 35px;
 line-height: 1.3;
 transform: rotate(-5deg);
 margin: 0.75em auto 2.5em;
 position: relative;
}
.btmM {
 position: absolute;
 bottom: -0.85em;
 right: 0em;
}
.slash {
 font-size: 30px;
 font-weight: 700;
 width: 100%;
 margin: 0 0 0 -1em;
 line-height: 1.5;
}
.slash:before, .slash:after {
 position: relative;
 display: inline-block;
 content: "";
 background: #000;
 width: 2px;
 height: 1em;
 margin: 0 0.5em 0;
 vertical-align: middle;
}
.slash:before {
 transform: rotate(-35deg);
}
.slash:after {
 transform: rotate(35deg);
}
.mid, .btm {
 position: relative;
 color: #FFF;
 z-index: 4;
 line-height: 1;
 padding: 0 0.2em;
 display: inline-block;
}
.mid:before {
 background-color: #FF0033;
 content: '';
 position: absolute;
 top: 0;
 left: 0;
 display: inline-block;
 width: 8.9em;
 height: 1.1em;
 transform: skewX(-5deg);
 z-index: -1;
}
.btm:before {
 background-color: #FF0033;
 content: '';
 position: absolute;
 top: 0;
 left: 3.7em;
 display: inline-block;
 width: 2.8em;
 height: 1.1em;
 transform: skewX(-5deg);
 z-index: -1;
}
.fzS {
 font-size: 26px;
}
.fzSS {
 margin-top: 0.15em;
 font-size: 0.85em;
 display: block;
}
.fc-red {
 color: #FF0033;
}
.l-lp-section[class*=bg] {
 padding: 40px 0;
}
section {
 margin-top: 40px;
}
section#price {}
section#scope {}
section#recommend {}
section#introduce {}
section.general {
 margin-top: 40px;
}
h2.board {
 background-color: #FF0033;
 position: relative;
 color: #FFF;
 text-align: center;
 font-weight: bold;
 padding: 0.5em 0;
 margin: 0 auto 30px;
 display: flex;
 justify-content: center;
 align-items: center;
}
h2.board::before {
 position: absolute;
 content: '';
 background-image: url("../assets/images/ttl_deco_s.png");
 width: 0.65em;
 height: 1.75em;
 top: -0.15em;
 left: 0.5em;
 background-size: contain;
 background-repeat: no-repeat;
}
h2.board::after {
 position: absolute;
 content: '';
 background-image: url("../assets/images/ttl_deco_s.png");
 width: 0.65em;
 height: 1.75em;
 top: -0.15em;
 right: 0.5em;
 background-size: contain;
 background-repeat: no-repeat;
}
h2.board2 {
 background-color: #FF0033;
 position: relative;
 color: #FFF;
 text-align: center;
 font-weight: bold;
 padding: 0.5em 0;
 margin: 0 auto 30px;
}
h2.board2::before {
 position: absolute;
 content: '';
 background-image: url("../assets/images/ttl_deco_l.png");
 width: 0.55em;
 height: 2.25em;
 top: -0.15em;
 left: 0.5em;
 background-size: contain;
 background-repeat: no-repeat;
}
h2.board2::after {
 position: absolute;
 content: '';
 background-image: url("../assets/images/ttl_deco_l.png");
 width: 0.55em;
 height: 2.25em;
 top: -0.15em;
 right: 0.5em;
 background-size: contain;
 background-repeat: no-repeat;
}
h2 img.ttlIcon {
 width: 1.2em;
 height: 1.2em;
 margin-right: 0.5em;
}
h2 img.ttlIcon2 {
 width: 1.642857143em;
 height: 1.0em;
 margin-right: 0.5em;
}
h2 img.ttlIcon3 {
 width: 0.8em;
 height: auto;
 margin-right: 0.5em;
}
h2 img.ttlIcon4 {
 width: 1.26em;
 height: 1.2em;
 margin-right: 0.5em;
}
h2 .lp-ttl-slash {
 margin: 0 auto;
 color: #FFF;
}
.lp-ttl-slash:before, .lp-ttl-slash:after {
 background: #FFF;
}
.blk.lp-ttl-slash:before, .blk.lp-ttl-slash:after {
 background: #000;
}
.tac {
 text-align: center;
}
.tal {
 text-align: left;
}
.tar {
 text-align: right;
}
.fcr {
 color: #FF0033;
}
.fwb {
 font-weight: bold;
}
.lh1 {
 line-height: 1;
}
.priceFont {
 font-family: "Oswald", "Noto Sans JP";
 font-weight: bold;
 line-height: 1;
 letter-spacing: -0.03em;
 padding: 0 0.1em;
}
.p_c_1 {
 display: block;
 padding: 0.2em;
 border: 1px solid #000000;
 line-height: 1;
 margin-bottom: 0.1em;
}
.priceWrap {
 display: flex;
 align-items: flex-end;
 justify-content: center;
 font-feature-settings: "palt";
 margin-left: auto;
 margin-right: auto;
}
.priceBlock1Sp {
 display: none;
}
.priceBlock1 {
 text-align: center;
 font-weight: bold;
 line-height: 1.2;
}
.priceBlock2 {
 display: flex;
 align-items: flex-end;
}
.priceBlock2 .xxLargeFont {
 padding: 0 0.1em;
}
.priceBlock2 .rightBox {
 padding: 0 0 0.3em 0;
}
.priceBlock3 {
 margin: 0.5em auto;
}
.priceBlock4 {
 max-width: 540px;
 margin: 40px auto;
 display: flex;
 justify-content: space-between;
}
.panelBox {
 width: 49%;
 border: 4px solid #8c8c8c;
 border-radius: 8px;
 position: relative;
}
.palt {
 font-feature-settings: "palt";
}
.panelTtl {
 background-color: #8c8c8c;
 color: #FFF;
 text-align: center;
 padding: 0.35em 0 0.6em;
 line-height: 1;
 font-weight: bold;
}
.panelCon {
 text-align: center;
 font-weight: bold;
 padding: 0.5em;
}
.panelBox:last-child::after {
 line-height: 1;
 content: "＋";
 width: 1.5em;
 height: 1.5em;
 background-color: black;
 color: #fff;
 font-size: 24px;
 font-weight: bold;
 border-radius: 50%;
 display: flex;
 justify-content: center;
 align-items: center;
 position: absolute;
 top: calc(70% - 0.5em);
 left: -3%;
 transform: translateX(-50%);
 padding: 0 0 0.1em 0;
}
.panelBox2 {
 max-width: 900px;
 margin: 0 auto;
 border: 4px solid #FF0033;
 border-radius: 8px;
 position: relative;
}
.panelTtl2 {
 background-color: #FF0033;
 color: #FFF;
 text-align: center;
 padding: calc(0.5em - 3px) 0 0.5em;
 font-weight: bold;
}
.panelCon2 {
 padding: 30px;
 display: flex;
 align-items: center;
 justify-content: space-between;
 flex-wrap: wrap;
}
.panelCon2 > div.contBox {
 width: 50%;
}
.w40p {
 max-width: 100%;
 margin: 0;
}
.ttlFlex {
 display: flex;
 align-items: center;
 justify-content: center;
}
.pointBox {
 display: flex;
 width: 75%;
 margin: 0 auto;
 justify-content: space-between;
}
.pointBox > div {
 display: flex;
 align-items: center;
 justify-content: center;
}
.circle {
 font-weight: bold;
 text-align: center;
 border: 4px solid #FF0033;
 border-radius: 100%;
 width: 140px;
 height: 140px;
 box-shadow: 2px 5px #FF0033;
}
.band {
 color: #FFF;
 text-align: center;
 background-color: #FF0033;
 padding: 0.25em 2em;
 border-radius: 2em;
 display: inline-block;
 margin: 0 auto 1em;
}
.deviceName {
 width: 40%;
 margin: 40px auto 30px;
}
.border {
 line-height: 1;
 padding: 0.5em 1em;
 border: 1px solid #000;
 display: inline-block;
 text-align: center;
 background-color: #FFF;
}
.mtb05 {
 margin: 0.5em auto;
}
.ksBox {
 width: 76%;
 margin: 0px auto 30px;
 min-height: 355px;
}
.selectBox {
 display: flex;
 justify-content: space-between;
 max-width: 250px;
 margin: 20px auto;
 text-align: center;
}
.dColor {}
.colorCircle {
 width: 50px;
 height: 50px;
 display: inline-block;
 border-radius: 50%;
 cursor: pointer;
}
.colorCircle:hover {
 display: inline-block;
 border-radius: 50%;
 cursor: pointer;
 border: 2px solid #6666ff;
}
.selected .colorCircle {
 border: 2px solid #000;
 cursor: auto;
}
.selected .colorName {
 font-weight: bold;
}
.c1 {
 background-color: #c2c4c3;
}
.c2 {
 background-color: #016c7c;
}
.c3 {
 background-color: #E1287B;
}
.movieBox {
 margin: 50px auto;
 max-width: 640px;
}
.dot {
 background-image: radial-gradient(circle at center, #000 20%, transparent 20%);
 background-position: top right;
 background-repeat: repeat-x;
 background-size: 1em 1em;
 padding-top: .5em;
}
.fukiBox {
 border: 4px solid #FF0033;
 padding: 2em 1em;
 border-radius: 8px;
 margin: 0 auto 30px;
 position: relative;
}
.fukiBox:before {
 content: "";
 position: absolute;
 bottom: -24px;
 left: 50%;
 margin-left: -15px;
 border: 12px solid transparent;
 border-top: 12px solid #FFF;
 z-index: 2;
}
.fukiBox:after {
 content: "";
 position: absolute;
 bottom: -30px;
 left: 50%;
 margin-left: -17px;
 border: 14px solid transparent;
 border-top: 14px solid #FF0033;
 z-index: 1;
}
.fukiBoxA {
 border: 4px solid #FF0033;
 padding: 1.1em 1em;
 border-radius: 8px;
 margin: 20px auto 0;
 position: relative;
}
.fukiBoxA:before {
 content: "";
 position: absolute;
 top: -24px;
 left: 50%;
 margin-left: -15px;
 border: 12px solid transparent;
 border-bottom: 12px solid #FFF;
 z-index: 2;
}
.fukiBoxA:after {
 content: "";
 position: absolute;
 top: -30px;
 left: 50%;
 margin-left: -17px;
 border: 14px solid transparent;
 border-bottom: 14px solid #FF0033;
 z-index: 1;
}
.fukiBox2 {
 padding: 0.5em;
 max-width: 100%;
 margin: 0 auto 30px;
 position: relative;
 background-color: #ffe5e8;
 color: #FF0033;
 text-align: center;
}
.fukiBox2:before {
 content: "";
 position: absolute;
 bottom: -24px;
 left: 50%;
 margin-left: -15px;
 border: 12px solid transparent;
 border-top: 12px solid #ffe5e8;
 z-index: 2;
}
.fukiBox3 {
 border: 2px solid #000;
 padding: 0.45em;
 max-width: 640px;
 line-height: 1;
 text-align: center;
 margin: 0 auto;
}
.fukiCont {
 display: flex;
 align-items: center;
 justify-content: space-around;
 margin: 20px auto;
}
.fukiCont a {
 text-decoration: underline;
}
.featureBox {
 background-color: #f9f9f9;
 border: 2px solid #cccccc;
 border-radius: 12px;
 padding: 50px 25px 35px;
 margin: 50px auto 0;
 box-shadow: 8px 8px #e0e0e0;
 position: relative;
 z-index: 3;
}
.ancBox {
 padding: 1em 25px 35px;
}
.featureBox ul li {
 position: relative;
}
.featureBox ul li a::before, .featureBox ul li a::after {
 content: '';
 width: 0;
 height: 0;
 border-left: 10px solid transparent;
 border-right: 10px solid transparent;
 border-top: 10px solid #FF0033;
 position: absolute;
 bottom: -1.0em;
 left: 0;
 right: 0;
 margin: 0 auto;
 transition: all 0.3s;
}
.featureBox ul li a:hover::before, .featureBox ul li a:hover::after {
 bottom: -1.2em;
}
.ancNum {
 display: none;
}
.p0 {
 padding: 0;
}
.featureBoxUp {
 position: relative;
 margin-top: 120px;
}
.circleFa {
 position: absolute;
 top: -73px;
 left: 0;
 right: 0;
 margin: 0 auto;
 background: linear-gradient(180deg, #f9f9f9 0%, #f9f9f9 60%, transparent 60%, transparent 100%);
 font-weight: bold;
 text-align: center;
 border-radius: 100%;
 width: 148px;
 height: 148px;
 display: flex;
 justify-content: center;
 padding: 1em 0 0 0;
 z-index: 4;
}
.circleFb {
 position: absolute;
 top: -75px;
 left: 0;
 right: 0;
 margin: 0 auto;
 border: 4px solid #cccccc;
 font-weight: bold;
 text-align: center;
 border-radius: 100%;
 width: 152px;
 height: 152px;
 display: flex;
 justify-content: center;
 padding: 1em 0 0 0;
 z-index: 1;
}
.iconBox {
 width: 80px;
 margin-right: 10px;
}
.iconBoxR {
 padding-right: 80px;
}
.iconBoxAnc {
 width: 80px;
 margin: 0 auto 10px;
}
.flail {
 padding: 30px 30px;
 background-color: #ffffff;
 border: 2px solid #dfdfdf;
 border-radius: 12px;
 margin: 30px auto 50px;
}
.flex {
 display: flex;
 justify-content: space-between;
 flex-wrap: wrap;
}
.flex2 {
 display: flex;
 justify-content: center;
 align-items: center;
 flex-wrap: wrap;
}
.flexItemB {
 align-items: end;
}
.flexItemC {
 align-items: center;
}
.jcLeft {
 justify-content: left;
}
.jcCenter {
 justify-content: center;
}
.jcRight {
 justify-content: right;
}
.jcSa {
 justify-content: space-around;
}
.flex div.txtBox {
 flex-basis: 60%;
}
.flex div.imgBox {
 flex-basis: 40%;
 padding: 35px;
}
.w100 {
 flex-basis: 100%;
}
.w70 {
 flex-basis: 70%;
}
.w60 {
 flex-basis: 60%;
}
.w55 {
 flex-basis: 55%;
}
.w50 {
 flex-basis: 50%;
}
.w48 {
 flex-basis: 48%;
}
.w46 {
 flex-basis: 46%;
}
.w46:nth-child(3) {
 margin-top: 3em !important;
}
.w46:nth-child(4) {
 margin-top: 3em !important;
}
.w45 {
 flex-basis: 45%;
}
.w40 {
 flex-basis: 40%;
}
.w33 {
 flex-basis: calc(100% / 3);
}
.w30 {
 flex-basis: 30%;
}
.photo {
 width: 160px;
}
.w600 {
 max-width: 600px;
 margin-left: auto;
 margin-right: auto;
}
.fImg1 {
 padding: 15px;
 text-align: center;
}
.fImg2 {
 width: 100%;
 max-width: 150px;
 margin: 0 auto;
}
.fImg3 {
 width: 100%;
 margin: 0 auto;
}
.fImg_m {
 width: 60%;
 margin: 0 auto;
}
.fImg_s {
 width: 50%;
 margin: 0 auto;
}
.fTxt {
 min-height: 7.5em;
}
.fTxt2 {
 min-height: 6.5em;
}
.fTxt3 {
 min-height: 4.5em;
}
.rbBox {
 border: 4px solid #FF0033;
 padding: 20px;
 border-radius: 8px;
 max-width: 640px;
 margin: 0 auto;
 position: relative;
 background-color: #FFF;
 text-align: center;
}
.rbBox .rbBoxNum {
 font-size: 60px;
 background: none;
 display: inline;
 padding: 0 0 0px;
 line-height: 1;
}
#lp .btn-arrow::after {
 content: "";
 width: 10px;
 height: 16px;
 background-image: url(https://www.ymobile.jp/sp/common/images/icon_arrow.svg);
 background-repeat: no-repeat;
 background-position: center;
 background-size: 100% auto;
 position: absolute;
 top: 50%;
 right: 19px;
 transform: translateY(-50%);
}
.introduceBox {
 max-width: 640px;
 margin: 40px auto;
 display: flex;
 justify-content: space-between;
}
.introduceBoxC {
 width: 49%;
}
.panelBox3 {
 border: 4px solid #32b5ff;
 border-radius: 8px;
 position: relative;
 margin-bottom: 10px;
}
.panelTtl3 {
 background-color: #32b5ff;
 line-height: 1;
 color: #FFF;
 text-align: center;
 padding: calc(0.5em - 4px) 0 0.5em;
 font-weight: bold;
}
.panelCon3 {
 text-align: center;
}
.confirmBox {
 max-width: 640px;
 background-color: #f8f8f8;
 border: 3px solid #b8bbba;
 border-radius: 8px;
 margin: 50px auto;
 padding: 30px 25px;
}
.confirmBox a.link {
 font-size: inherit;
 text-decoration: underline;
}
#moonlight .fc_g a.link {
 color: #555555;
}
.w640 {
 max-width: 640px;
 margin: 0 auto;
}

.mb0 {
 margin-bottom: 0 !important;
}
.btmLine {
 border-bottom: 2px solid #000;
 margin-bottom: 20px;
 padding-top: 1em;
}
.btnBefore {
 opacity: 0.3;
}
.btn-gray2 {
 color: #fff;
 background: #666666;
 border-color: #666666;
}
#lp .btn-arrow.btn-gray2::after {
 content: "";
 width: 8px;
 height: 16px;
 background-image: url(https://www.ymobile.jp/sp/common/images/icon_arrow.svg);
 background-repeat: no-repeat;
 background-position: center;
 background-size: 100% auto;
 position: absolute;
 top: 50%;
 right: 12px;
 transform: translateY(-50%);
}
#lp .btn-arrow.btn-gray2::after {
 background-image: url(https://www.ymobile.jp/sp/common/images/icon_arrow_white.svg);
}
table.compare {}
.lp-accordion-box {
 display: none;
 padding: 25px 30px;
}
.sp_compare {
 display: none;
}
table.compare td, table.compare th {
 border-bottom: 1px solid #CCC;
 padding: 0.3em 0.1em 0.35em;
}
.devicePhoto {
 width: 70px;
 vertical-align: bottom;
 margin: 0 auto 0;
}
table.compare td.bdnone, table.compare th.bdnone {
 border-bottom: none;
 vertical-align: bottom;
}
table.compare td.pb10, table.compare th.pb10 {
 padding-bottom: 0.75em;
}
table.compare td.bgG, table.compare th.bgG {
 background-color: #fafafa;
}
table.compare td.bgG2, table.compare th.bgG2 {
 background-color: #fbfbfb;
}
.model-wrapper {
 max-width: 100%;
 margin: auto;
}
#movie .model-item {
    height: 100%;
    padding: 0 15px;
    float: none;
}
.model-list {
    margin-right: -15px;
    margin-left: -15px;
}
#addBox .model-list {
    margin-right: auto;
    margin-left: auto;
}
.app-content .model-list .slick-dots{
 margin-bottom: 15px;
}
.pdl30 {
 padding-left: 30px;
}
#lp .flex .btn-arrow.btn-l {
 min-width: 100%;
}
.lp-cta-list {
 max-width: 100%;
 height: 110px;
 display: flex;
 justify-content: space-between;
 align-items: center;
 flex-wrap: nowrap;
 margin: auto;
 padding: 10px 0;
}
.lp-cta-list .btn {
 border-radius: 8px;
 width: calc( 100% / 3);
 padding: 0.75em 5px;
}
.lp-cta-list .btn:not(.btn-disabled):hover {
 padding: 0.75em 5px;
 -webkit-box-shadow: 0px 3px 0px rgb(215, 11, 50);
 box-shadow: 0px 3px 0px rgb(215, 11, 50);
 top: 0;
}

#lineup .lp-cta-btn.wide {
    width: 100%;
    max-width: 482px;
    height: 62px;
    margin: auto;
}
.borderW {
 border: 1px solid #fff;
 padding: 0.1em 0.5em;
 width: 216px;
 margin: 0 auto;
}
.borderW2 {
 border: 1px solid #fff;
 padding: 0.1em 0.5em;
 width: 158px;
 margin: 0 auto;
}
.flTxt {
 line-height: 1;
 padding: 0.4em 0 0;
}
.plQem {
 padding-left: 0.25em;
}
#cv_online {
 position: relative;
}
#cv_online .fukiFl {
 position: absolute;
 top: -60%;
 left: 0;
 right: 0;
 margin: 0 auto;
 animation-name: updown;
 animation-delay: 0s;
 animation-duration: 3s;
 animation-timing-function: ease-in-out;
 animation-iteration-count: infinite;
 z-index: 1;
}
@keyframes updown {
 0% {
  transform: translateY(0);
 }
 50% {
  transform: translateY(-5px);
 }
 100% {
  transform: translateY(0);
 }
}
#cv_online .fukiFl div {
 position: relative;
 display: inline-block;
 margin: 0 auto;
 padding: 0.25em 1em;
 min-width: 20em;
 max-width: 100%;
 color: #000;
 background: #FFF;
 border-radius: 2em;
 border: 2px solid #000;
 font-size: 16px;
}
#cv_online .fukiFl div:before {
 content: "";
 position: absolute;
 top: 100%;
 left: 50%;
 margin-left: -8px;
 border: 8px solid transparent;
 border-top: 8px solid #000;
}
#cv_online .fukiFl div:after {
 content: "";
 position: absolute;
 top: 99%;
 left: 50%;
 margin-left: -6px;
 border: 6px solid transparent;
 border-top: 6px solid #FFF;
}
.liBorder {
 border-left: 2px dashed #DDD;
 border-right: 2px dashed #DDD;
}
.over60Box {
 margin: 80px auto 0;
}
#addBox{
 background-color: #FFF;
}