@charset "utf-8";
html {
 box-sizing: border-box;
 -ms-overflow-style: scrollbar;
 font-size: 62.5%;
}
*, *::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;
  margin: 3.846153846vw auto 6.41025641vw;
 }
}
.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% - 80px) / 4);
 height: 250px;
}
@media (max-width: 768px) {
 .lp-anchor-list {
  width: 100%;
  max-width: 980px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: auto;
 }
 .lp-anchor-item-n {
  width: 100%;
  height: auto;
  padding: 0 0 2vw 0;
 }
}
.lp-anchor-item-n a {
 width: 100%;
 height: 100%;
 background: #fff;
 border: #FF0033 solid 4px;
 border-radius: 10px;
 position: relative;
 overflow: hidden;
 display: block;
 text-align: center;
}
@media (max-width: 768px) {
 .lp-anchor-item-n a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-width: 2px;
  border-radius: 6px;
  padding: 0.5em 0;
  position: relative;
 }
}
.lp-anchor-item-n a::before, .lp-anchor-item-n a::after {
 content: "";
 position: absolute;
}
.lp-anchor-icon {
 width: auto;
 height: 50px;
 display: block;
 margin: 16px auto 26px;
}
@media (max-width: 768px) {
 .lp-anchor-icon {
  flex-basis: 16vw;
  height: 8vw;
  padding: 0 0;
  margin: 0;
 }
}
.lp-anchor-icon img {
 width: auto;
 height: 50px;
}
.spTxt {
 flex-basis: 64vw;
}
.arrow_r {
 position: absolute;
 bottom: 10px;
 left: 0;
 right: 0;
 width: 40px;
 margin: 18px auto 0;
}
.lp-anchor-txt {
 min-height: 52px;
 font-size: 25px;
 font-weight: bold;
 line-height: 1.2;
 text-align: center;
 display: flex;
 justify-content: center;
 align-items: center;
 margin: 0;
}
@media (max-width: 1000px) {
 .lp-anchor-txt {
  font-size: 2.5vw;
 }
}
@media (max-width: 768px) {
 .lp-anchor-icon img {
  width: auto;
  height: 8vw;
 }
 .lp-anchor-txt {
  min-height: 1em;
  font-size: 4.8vw;
  text-align: left;
  line-height: 1.2;
 }
 .arrow_r {
  position: relative;
  top: 0;
  border: 0;
  left: auto;
  right: 0;
  width: 16vw;
  padding: 0 4vw;
  margin: 0 auto 0;
 }
}
/********************************************************/
.lp-anchor-wrapper {
 padding: 20px 15px 50px;
}
.l-lp-section {
 position: relative;
 padding-bottom: 0;
 overflow: hidden;
}
.l-section.pt0 {
 padding: 0px 0 0 0;
 overflow: hidden;
}
.bgP {
 width: 100%;
 background-color: #f0f9ff;
}
.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;
}
.ancSfont {
 font-size: 18px;
 line-height: 1.2;
}
.lp-anchor-wrapper {
 width: 100%;
 background-color: #dff7ff;
}
.xxLargeFont {
 font-size: 48px !important;
 line-height: 1.8;
}
.xsLargeFont {
 font-size: 28px !important;
 line-height: 1.8;
}
.line {
 border-bottom: 6px dotted #000;
}
.btn1 {
 width: 80%;
 margin-left: auto;
 margin-right: auto;
 text-align: center;
}
.lTtl {
 font-size: 30px !important;
 border-left: 10px solid #FF0033;
 font-weight: bold;
 padding-left: 0.5em;
 margin-top: 1em;
}
.lTtl.fz20 {
 font-size: 24px !important;
}
.xLargeFont {
 font-size: 24px !important;
 line-height: 1.8;
}
.largeFont {
 font-size: 20px;
}
.mFont {
 font-size: 16px;
}
.largeFont a {
 font-size: 21px;
 color: #000;
 text-decoration: underline;
}
.largeFont a:hover {
 text-decoration: none;
}
.fc_green {
 color: #008000;
}
.fc_red {
 color: #FF0033;
}
#point, #relief, #lineup, #voice, #app {
 padding-bottom: 80px;
}
#lineup, #voice {
 background-color: #FFEFF1;
}
.lp-ttl-article-wrapper {
 padding: 80px 0 60px;
}
#app .lp-ttl-article-wrapper, #osusume .lp-ttl-article-wrapper {
 /*background-color: #f1fff1;*/
}
#point, #point .lp-ttl-article-wrapper, #relief, #relief .lp-ttl-article-wrapper {
 /*background-color: #f1fff1;*/
}
#point .lp-ttl-article-wrapper, #relief .lp-ttl-article-wrapper, #lineup .lp-ttl-article-wrapper, #lineup .lp-ttl-article-wrapper {
 padding: 60px 0 30px;
 margin-bottom: 0;
 text-align: center;
}
#app .lp-h2 span, #osusume .lp-h2 span {
 color: #FF0033;
}
#point .lp-h2 span, #relief .lp-h2 span {
 color: #008000;
}
.gMarker span {
 position: relative;
 z-index: 1;
 color: #008000;
 background: linear-gradient(transparent 60%, #E1FF91 0%);
 display: inline;
 padding: 0 1px 0px;
 font-weight: bold;
}
.rMarker, .gMarker {
 line-height: 1.6;
}
.rMarker span {
 position: relative;
 z-index: 1;
 color: #FF0032;
 background: linear-gradient(transparent 60%, #FFDCE6 0%);
 display: inline;
 padding: 0 1px 0px;
 font-weight: bold;
}
.lp-accordion {
 width: 100%;
 max-width: 980px;
 background-color: #fff;
 border: #008000 solid 4px;
 border-radius: 0;
 overflow: hidden;
 display: block;
}
#acc1, #acc2 {
 border-bottom: 1px dashed #666;
}
.acc .lp-accordion-title {
 background-color: #f9f9f9;
}
.acc .lp-accordion {
 border: none;
 background-color: #f9f9f9;
}
#point .lp-ttl-article-wrapper, #relief .lp-ttl-article-wrapper {
 background-color: #f1fff1;
}
#point .l-inner, #relief .l-inner {
 padding-top: 60px;
}
.lp-accordion-icon {
 width: 50px;
 height: 50px;
 background-color: #008000;
 border-radius: 25px;
 display: flex;
 justify-content: center;
 align-items: center;
 margin-left: auto;
 position: relative;
}
.lp-accordion-img {
 width: 120px;
 font-size: 52px;
 line-height: 1;
 background-color: #008000;
 display: flex;
 color: #FFF;
 justify-content: center;
 align-items: center;
 align-self: stretch;
 height: auto;
}
#compare.lp-accordion {
 width: 100%;
 max-width: 980px;
 background-color: #fff;
 border: #FF0033 solid 4px;
 border-radius: 10px;
 overflow: hidden;
 display: block;
}
#compare .lp-accordion-icon {
 width: 50px;
 height: 50px;
 background-color: #FF0033;
 border-radius: 25px;
 display: flex;
 justify-content: center;
 align-items: center;
 margin-left: auto;
 position: relative;
}
#compare .lp-accordion-img {
 width: 120px;
 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: 3px;
 height: 27px;
 top: calc(50% - 13.5px);
 left: calc(50% - 1.5px);
 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: 27px;
 height: 3px;
 top: calc(50% - 1.5px);
 left: calc(50% - 13.5px);
}
@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% - 60px);
 line-height: 1 !important;
 padding: 0.25em 0 0.35em 0;
 font-size: 42px;
 background-color: #FFF;
 text-align: center;
}
#point .lp-accordion-title, #relief .lp-accordion-title {
 width: calc(100% - 120px - 60px);
 line-height: 1 !important;
 padding: 0.25em 1em 0.35em;
 font-size: 42px;
 background-color: #FFF;
}
@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-size: 27px;
 font-weight: bold;
}
.wide15 {}

.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: 1em;
}
.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 30px 28px;
}
.deviceImg {
 width: 80%;
 margin: 20px auto 0;
}
.deviceName {
 font-size: 31px;
 font-weight: bold;
 line-height: 1;
 margin-bottom: 1em;
}
.deviceName2 {
 font-size: 26px;
 font-weight: bold;
 line-height: 1;
 margin-bottom: 1em;
}
.deviceTxt {
 font-size: 18px;
 line-height: 1.4;
 margin-bottom: 1.25em;
}
.deviceLink {
 width: 70%;
 margin-left: auto;
 margin-right: auto;
}
.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-cta-list {
 width: 800px;
 max-width: 100%;
 height: auto;
 display: flex;
 justify-content: space-between;
 align-items: center;
 flex-wrap: nowrap;
 margin: auto;
 padding: 10px 0;
}
#lp .gotop {
 bottom: 150px;
}
.line-red {
 border-bottom: 4px solid #ff0032;
}
.movieBox {
 margin: 40px auto 60px;
}
.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 #008000;
}
.add-table td.btpn {
 border-top: none;
}
.add-table .brl {
 border-left: 2px solid #008000;
 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 #008000;
 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: #008000;
 font-size: 26px;
 padding-bottom: 0.5em;
}
.fc-green.lp-ttl-slash:before, .fc-green.lp-ttl-slash:after {
 background: #008000;
}
.add_btn_img {
 width: 100%;
 max-width: 400px;
 margin-left: auto;
 margin-right: auto;
 display: block;
}
#lp .l-footer-bottom {
 padding-bottom: 140px;
}
.indent1 {
 text-indent: -1em;
 padding-left: 1em;
}
.indent3 {
 text-indent: -2.5em;
 padding-left: 2.5em;
}
#moonlight .fz90 {
 font-size: 100px;
}
#moonlight .fz80 {
 font-size: 80px;
}
#moonlight .fz60 {
 font-size: 60px;
}
#moonlight .fz44 {
 font-size: 52px;
}
#moonlight .fz36 {
 font-size: 42px;
}
#moonlight .fz30 {
 font-size: 36px;
}
#moonlight .fz26 {
 font-size: 30px;
}
#moonlight .fz22 {
 font-size: 26px;
}
#moonlight .fz20 {
 font-size: 24px;
}
#moonlight .fz18 {
 font-size: 22px;
}
#moonlight .ancBox .fz18 {
 font-size: 19px;
}
#moonlight .priceTop .fz18 {
 font-size: 24px;
}
#moonlight .fz16 {
 font-size: 22px;
}
#moonlight .fz14 {
 font-size: 18px;
}
#moonlight .ancBox .fz14 {
 font-size: 16px;
}
#moonlight .acc .lp-accordion-title-wrapper .fz18 {
 font-size: 32px;
 margin-top: 0.25em;
 ;
}
#moonlight .acc .lp-accordion-title-wrapper .fz14 {
 font-size: 18px;
}
#moonlight .fz12 {
 font-size: 18px;
}
#moonlight #compare .fz16 {
 font-size: 18px;
}
#moonlight .compare .fz14 {
 font-size: 16px;
}
#moonlight #compare .fz12 {
 font-size: 16px;
}
.pcW80 {
 width: 70%;
 margin-left: auto;
 margin-right: auto;
}
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("../../family/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("../../family/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("../../family/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("../../family/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: #000;
}
.lp-ttl-slash:before, .lp-ttl-slash:after {
 background: #000;
}
.blk.lp-ttl-slash:before, .blk.lp-ttl-slash:after {
 background: #000;
}
.lp-ttl-slash.blk {
 margin: 0 auto 15px;
}
.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;
}
.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;
}
.deviceName4 {
 width: 40%;
 margin: 30px auto 40px;
}
.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: 300px;
 margin: 20px auto;
 text-align: center;
}
.dColor {
    width:100%;
}
.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: #c23a65;
}
.c2 {
 background-color: #c4bc9f;
}
.c3 {
 background-color: #262c4c;
}
.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 50px;
 margin: 50px auto 0;
 box-shadow: 8px 8px #e0e0e0;
 position: relative;
 z-index: 10;
}
.ancBox {
 padding: 1em 25px 0;
}
.ancBox ul.flex {
 display: block;
}
.ancBox ul.flex li.w33 a.inflex {
 display: flex;
 align-items: center;
 justify-content: flex-start;
 width: 100%;
}
.ancBox ul.flex li.w33 h3 a {
 color: #323232;
 text-decoration: none;
}
.featureBox ul li {
 position: relative;
}
.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: 11;
}
.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 20px 0;
}
.flail {
 padding: 30px 30px;
 background-color: #ffffff;
 border: 2px solid #dfdfdf;
 border-radius: 12px;
 margin: 30px auto;
}
.flex {
 display: flex;
 justify-content: space-between;
 flex-wrap: wrap;
}
.flex2 {
 display: flex;
 justify-content: center;
 align-items: center;
 flex-wrap: wrap;
}
.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: 100%;
}
.w46:nth-child(1) {
 margin-top: 1em !important;
}
.w46:nth-child(2) {
 margin-top: 3em !important;
}
.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 {
 text-align: center;
 max-width: 500px;
 margin-left: auto;
 margin-right: auto;
}
.fImg2 {
 width: 100%;
 max-width: 200px;
 margin: 0 auto;
}
.fImg3 {
 width: 100%;
 max-width: 500px;
 margin: 0 auto;
}
.fImg_m {
 width: 60%;
 margin: 0 auto;
}
.fImg_s {
 width: 60%;
 margin: 0 auto;
}
.fTxt {
 min-height: 5.5em;
}
.fTxt2 {
 min-height: 6.5em;
}
.fTxt3 {
 min-height: 2.5em;
}
.rbBox {
 border: 4px solid #FF0033;
 padding: 20px;
 border-radius: 8px;
 width: 70%;
 margin: 30px 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;
}
.lp-ttl-article-wrapper {
 padding: 40px 0 45px;
 margin-bottom: 40px;
 text-align: center;
}
.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;
}
.acc .lp-accordion-box {
 padding: 0 0;
}
.acc .featureBox {
 background-color: #f9f9f9;
 border: none;
 border-radius: 0;
 padding: 0;
 margin: 0 auto 0;
 box-shadow: none;
 position: relative;
 z-index: 10;
}
.acc .lp-accordion-icon {
 background-color: #FF0033;
}
.sp_compare {
 display: none;
}
table.compare td, table.compare th {
 border-bottom: 1px solid #CCC;
 padding: 0.4em 0.1em 0.5em;
}
.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: 0 auto 0;
 padding-bottom: 60px;
}
.model-item {
 height: 100%;
 padding: 0 15px;
 float: none;
}
.model-list {
 margin-right: -15px;
 margin-left: -15px;
}
.pdl30 {
 padding-left: 30px;
}
#lp .flex .btn-arrow.btn-l {
 min-width: 100%;
}
.lp-cta-list .btn-fl {
 border-radius: 8px;
 min-width: 57.10267229%;
 padding: 0.75em 0 0.2em;
}
.lp-cta-list .btn-fl .fz20 {
 font-size: 24px;
}
.lp-cta-list .btn-fr {
 border-radius: 8px;
 min-width: 40.64697609%;
 padding: 0.75em 0 0.2em;
}
.lp-cta-list .btn-fr .fz20 {
 font-size: 24px;
}
.btn-fl:not(.btn-disabled):hover, .btn-fr:not(.btn-disabled):hover {
 padding: 0.75em 0 0.2em;
 -webkit-box-shadow: 0px 3px 0px rgb(215, 11, 50);
 box-shadow: 0px 3px 0px rgb(215, 11, 50);
 top: 0;
}
.borderW {
 border: 1px solid #fff;
 padding: 0.1em 0.5em;
 width: 216px;
 margin: 0 auto;
 font-size: 15px;
}
.borderW2 {
 border: 1px solid #fff;
 padding: 0.1em 0.5em;
 width: 158px;
 margin: 0 auto;
 font-size: 15px;
}
.btn-red {
 border: none;
 background: #FF0032;
 background: -webkit-gradient(linear, left top, left bottom, from(#FF9AAE), to(#FF0032));
 background: -webkit-linear-gradient(top, #FF9AAE 0%, #FF0032 100%);
 background: linear-gradient(to bottom, #FF9AAE 0%, #FF9AAE 10%, #FF0032 80%, #FF0032 100%);
}
.btn {
 display: inline-block;
 font-size: 20px;
 border-radius: 7px;
 min-width: 260px;
 padding: 0.5em 0.25em;
}
#lp .btn-l {
 padding: 16px 5px;
}
#lp .btn-ll {
 font-size: 32px;
 min-width: 80% !important;
 margin-right: auto;
 margin-left: auto;
}
#lp .btn-lll {
 font-size: 22px;
 min-width: 90% !important;
 margin-right: auto;
 margin-left: auto;
 padding: 16px 5px
}
#lp .btn-arrow.btn-red::after, #lp .btn-arrow.btn-black::after {}
#lp .btn-ll.btn-arrow::after {
 content: "";
 width: 15px;
 height: 32px;
 background-image: url(https://www.ymobile.jp/sp/common/images/icon_arrow_white.svg);
 background-repeat: no-repeat;
 background-position: center;
 background-size: 100% auto;
 position: absolute;
 top: 50%;
 right: 19px;
 transform: translateY(-50%);
}
.num1, .num2, .num3 {
 position: relative;
 padding-left: 2.5em;
 text-indent: -2.5em;
 line-height: 1.3 !important;
}
.num1::before {
 display: inline-block;
 margin: 0 0.5em 0 0;
 content: '';
 border-radius: 100%;
 background-image: url("../assets/images/num1.png");
 background-size: cover;
 width: 2em;
 height: 2em;
 vertical-align: middle;
}
.num2::before {
 display: inline-block;
 margin: 0 0.5em 0 0;
 content: '';
 border-radius: 100%;
 background-image: url("../assets/images/num2.png");
 background-size: cover;
 width: 2em;
 height: 2em;
 vertical-align: middle;
}
.num3::before {
 display: inline-block;
 margin: 0 0.5em 0 0;
 content: '';
 border-radius: 100%;
 background-image: url("../assets/images/num3.png");
 background-size: cover;
 width: 2em;
 height: 2em;
 vertical-align: middle;
}
.lyp_1 {
 width: 93%;
 max-width: 570px;
 margin: 0 auto;
}
.lyp_2 {
 width: 86%;
 margin: 0 auto;
}
.lyp_4 {
 width: 50%;
 max-width: 382px;
 margin: 0 auto;
}
.lyp_5 {
 width: 30%;
 max-width: 165px;
 margin: 0 auto;
}
/*-- 20241107 --*/
.iconItem {
 display: flex;
 justify-content: space-between;
 align-items: center;
 margin: 30px auto 0 auto;
}
.iconImg {
 flex-basis: 12%;
}
.iconImg img {
 width: 140px;
}
.iconTxt {
 flex-basis: 88%;
 padding: 0 0 0 1em;
}

h5 .free{
    background-color: #156082;
    padding: 15px;
    margin-right: 10px;
    border-radius: 100%;
    color: #fff;
}

.wall_info{
    padding:15px;
    border:solid 1px #ccc;
    border-radius: 5px;
    background-color:#eee;
    box-shadow: 5px 5px 0px 0px rgba(134, 134, 134, 0.4);
}

.border_solid{
    padding:4px 25px;
    border:solid 3px #000;
}
@media (min-width: 1180px) {
    .bnr-slider-wrapper.andmovie{
        height:auto;
    }

}

/* 20250725 */
.bnr-cp-invitation-inner    {
    background-color: #fff;
    padding: 35px;
    border-radius: 10px;
}
.bnr-cp-invitation-inner p  {
    text-align: left;
}
.fs-caution     {
    font-size: 14px;
}
#lp .accordion-box {
    padding: 10px 10px 0;
}
.accordion-box-inner    {
    margin: 10px 0;
}
.accordion-box-inner a  {
    font-size: 14px !important;
}
.accordion-title    {
    display: flex;
    margin-top: 0;
    border: none;
    font-size: 14px;
    height: 30px;
}
.accordion-title p  {
    font-size: 14px;
}
.accordion-icon {
    position: relative;
    margin-top: 0px;
    margin-left: 10px;
    width: 25px;
    height: 25px;
    background-color: #dddddd;
    border-radius: 50%;
    right: auto;
}
.accordion-icon span:nth-child(1) {
    left: 11px;
    top: 5px;
}
.accordion-icon span:nth-child(2) {
    left: 5px;
    top: 11px;
}
.accordion-title.is-active .accordion-icon span:nth-child(1) {
    left: 11px;
    top: 5px;
}
.bnr-cp-invitation-wrap {
    background-color: #65a5a2;
}
.lp-anchor-item-n {
    width: calc((100% - 80px) / 5);
    height: 250px;
}
.tab-list   {
    padding: 0;
}
.tab-list-item, .tab-list-item-2 {
    border: 1px solid #dddddd;
}
.tab-list-item.is-active, .tab-list-item-2.is-active {
    border: 3px solid #FF0033;
}
.wBox {
    background-color: #FFF;
    border-radius: 12px;
    padding: 0px 40px 40px 40px;
}
.tab    {
    margin-top: 0;
    margin-bottom: 0;
}
.tab-target-item ul {
    text-align: left;
    margin: 0 auto;
}
.invitation-area-wrap    {
    position: relative;
    border: solid 10px #FF0033;
    margin-top: 155px !important;
    margin-bottom: 97px !important;
}
.invitation-area-ttl    {
    position: absolute;
    top: -67px;
    right: 0;
    left: 0;
    margin: auto;
}
.invitation-cp  {
    margin-top: 100px;
}
.invitation-area-bottom {
    display: flex;
    margin-top: 96px;
}
.invitation-area-bottom p {
    text-align: left;
    margin: 10px 20px 0 5%;
}
.invitation-area-bottom img {
    text-align: right;
    object-fit: contain;
}
.fs6rem {
    font-weight: 800;
    color: #000 !important;
    font-size: 6rem;
}
.fs22   {
    font-size: 22px;
}
.fs48   {
    font-size: 48px;
}
.fs64   {
    font-size: 64px;
}
.pt-60  {
    padding-top: 60px;
}
@media (max-width: 768px) {
    .bnr-cp-invitation-inner    {
        padding: 20px;
    }
    .bnr-cp-invitation-inner p  {
        font-size: 12px !important;
    }
    .lp-anchor-item-n {
        width: 100%;
        height: auto;
        padding: 0 0 2vw 0;
    }
    .invitation-area-wrap   {
        margin-top: 90px !important;
    }
    .invitation-cp {
        margin-top: 65px;
    }
    .invitation-area-bottom {
        display: block;
        margin-top: 25px;
    }
    .invitation-area-bottom p {
        text-align: left;
        margin: 0 20px 20px 20px;
    }
    #lp .accordion-title {
        font-size: 12px;
        font-weight: 500;
    }
    .accordion-icon {
        width: 20px;
        height: 20px;
    }
    .accordion-icon span:nth-child(1) {
        left: 9px;
        top: 4px;
        width: 2px;
        height: 12px;
    }
    .accordion-icon span:nth-child(2) {
        left: 4px;
        top: 9px;
        width: 12px;
        height: 2px;
    }
    .accordion-title.is-active .accordion-icon span:nth-child(1) {
        left: 9px;
        top: 4px;
    }
    #lp .accordion-box {
        padding: 10px 10px 20px 10px;
    }
    .accordion-box-inner  {
        font-size: 13px;
    }
    .accordion-box-inner a  {
        font-size: 13px !important;
    }
}
/* 20250725 */


/* チャット追加 */
@media (max-width: 768px) {
  .header-submenu.header-submenu--temporarily211020 {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
    z-index: 10000;
  }
  .header-submenu.header-submenu--temporarily211020 .header-submenu-chat span {
    display: inline-block;
    width: 60px;
    height: 56px;
    background: url(/common_c/images/common/icon/icon_chat.png) center 1px no-repeat;
    background-size: 35px 37px;
    background-position: center center;
  }
  img:has(+ div[data-sba-target="sbchat"]),
    div[data-sba-target="sbchat"],
    div[data-sba-target="sbchat-close"]{display:none;
  }
}
/* /チャット追加 */