/* サブスクプラン LP(/promotion_newservice)　タブレット用 */
@media (min-width: 768px) and (max-width: 1280px) {
/* 共通---------------------------------------------------------- */
  /* ヘッダー */
  header:not(.exclusion) .logo, 
  header:not(.exclusion) .logo-lp {
    width: 140px;
    padding: 20px 0;
    margin-left: 20px;
  }
  header:not(.exclusion) .logo img {
    width: 100%;
  }
  .sp_btn {
    right: calc((100% - 740px) / 2 + 80px);
    top: 20px;
  }
  .sp_btn a.business {
    background-color: #026abd;
    padding: 10px 0 6px;
    line-height: 1.4;
  }
  .sp-nav-btn {
    width: 50px;
    height: 50px;
    position: relative;
    margin-top: 17px;
    cursor: pointer;
    margin-right: 10px;
  }
  .sp_btn a.request::before {
    content: "";
    border-top: 5px solid #fff;
    border-right: 5px solid transparent;
    border-bottom: 5px solid transparent;
    border-left: 5px solid transparent;
    position: absolute;
    left: 50%;
    top: 12px;
    transform: translateX(-50%);
  }
  .sp-nav-btn span {
    width: 35px;
    height: 1px;
    background-color: #fff;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
  }
  .sp-nav-btn span:nth-child(1) {
    top: calc(50% - 15px);
  }
  .sp-nav-btn span:nth-child(2) {
    top: 50%;
  }
  .sp-nav-btn span:nth-child(3) {
    top: calc(50% + 15px);
  }
  .hum-nav {
    width: 100%;
    height: 100vh;
    background: #1e1e1e;
    position: fixed;
    top: 0;
    left: 0;
    padding: 80px 1.5rem 1.5rem;
    box-sizing: border-box;
    z-index: 10000;
    opacity: 0;
    transition: opacity .5s;
    visibility: hidden;
    overflow-y: scroll;
    display: block;
  }
  .hum-nav.open {
    width: 100vw;
    height: 100vh;
    opacity: 1;
    visibility: visible;
  }
  .hum-nav .close-btn {
    position: absolute;
    top: 20px;
    right: 1.5rem;
    width: 40px;
    height: 40px;
  }
  .hum-nav .close-btn span {
    position: relative;
    display: inline-block;
    width: 100%;
    height: 100%;
  }
  .hum-nav .close-btn span::before, 
  .hum-nav .close-btn span::after {
    content: "";
    position: absolute;
    width: 30px;
    height: 1px;
    background: #fff;
    top: 50%;
    left: 50%;
    z-index: 1000;
  }
  .hum-nav .close-btn span::before {
    transform: translate(-50%, -50%) rotate(45deg);
  }
  .hum-nav .close-btn span::after {
    transform: translate(-50%, -50%) rotate(-45deg);
  }
  .hum-nav nav {
    width: 500px;
    margin: 0 auto;
  }
  .hum-nav .btn-type1 {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    margin-bottom: 40px;
    position: relative;
    z-index: 101;
  }
  .hum-nav .btn-type1 a {
    width: 142px;
    height: 60px;
    box-sizing: border-box;
    border-radius: 8px;
    color: #fff;
    padding: 8px 0;
    margin: 5px 0;
    font-size: 1.5rem;
    line-height: 1.4;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    letter-spacing: 2px;
    text-align: center;
  }
  .hum-nav .btn-type1 a.business {
    background-color: #026abd;
  }
  .hum-nav .btn-type1 a.request {
    border: solid 1px #DB0066;
    color: #fff;
    background: #DB0066;
    padding: 16px 0 0;
    font-size: 1.7rem;
    position: relative;
  }
  .hum-nav .btn-type1 a.request .sub-mess {
    position: absolute;
    left: 50%;
    top: -8px;
    transform: translateX(-50%);
    background-color: #fff;
    width: 90%;
    padding: 3px 0;
    border-radius: 10px;
    font-size: 1.6rem;
    color: #000;
  }
  .hum-nav .btn-type1 a.request::before {
    content: "";
    border-top: 5px solid #fff;
    border-right: 5px solid transparent;
    border-bottom: 5px solid transparent;
    border-left: 5px solid transparent;
    position: absolute;
    left: 50%;
    top: 20px;
    transform: translateX(-50%);
  }
  .hum-nav .btn-type1 a.request .sub-mess span {
    color: #ff0080;
  }
  .hum-nav ul.hum-nav-list {
    position: static;
    z-index: unset;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 40px 20px;
    margin-bottom: 55px;
  }
  .hum-nav ul.hum-nav-list li {
    text-align: left;
    padding: 10px 0 10px 10px;
    border-bottom: 1px solid #fff;
    width: calc(50% - 10px);
    box-sizing: border-box;
  }
  .hum-nav .btn-type2 {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    margin-bottom: 50px;
    flex-direction: row;
  }
  .hum-nav .btn-type2 a {
    color: #fff;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    width: 230px;
    height: 52px;
    border-radius: 10px;
  }
  .hum-nav .btn-type2 a.mypage-btn {
    background-color: #2c2c2c;
    border: 2px solid #2c2c2c;
  }
  .hum-nav .btn-type2 a.mypage-btn img {
    width: 32px;
    margin-right: 8px;
  }
  .hum-nav .btn-type2 a.charge-btn {
    background-color: #666;
    border: 2px solid #666;
  }
  .hum-nav .btn-type2 a.charge-btn img {
    width: 32px;
  }
  .hum-nav .btn-type2 a.charge-btn .data-charge-sm {
    text-align: center;
    font-size: 1.2rem;
  }
  .hum-nav .menu-logo {
    display: block;
    width: 210px;
    height: auto;
    margin: 8vh auto 0;
  }
  div.main {
    margin-top: 95px;
  }
  /* フッター */
  footer:not(.exclusion) .inner {
    flex-direction: row;
  }
  footer.footer-menu {
    padding: 60px 0 0;
  }
  /* サイドメニュー */
  #entry_fix {
    width: 40px;
    top: 95px;
  }
  #entry_fix div.price-fix-box p {
    font-size: 1.6rem;
  }
  .follow-question {
    width: 11px;
    margin-bottom: 0.5vh;
    padding-left: 3px;
  }
  #entry_fix img.price-fix-hint {
    width: 40px;
    top: 50%;
  }
  /* トップページ */
  #first_view {
    margin: 95px 0 0;
  }
  #price {
    padding: 20px 0 80px;
    margin-top: 0;
  }
  #price .inner .catch_text {
    font-size: 1.6em;
  }
  #reason {
    background-color: #e6e6e6;
  }
  #plus {
    padding: 0px 20px 70px;
  }
  section.promotion-newservice div.top-appeal-area {
    z-index: 0;
    padding: 60px 0 15px;
    font-size: 3vh;
  }
  #top div.top-appeal-area span.emphasis-s {
    font-size: 3vh;
  }
  div.top-appeal-area::before, 
  div.top-appeal-area::after {
    z-index: -1;
  }
  #plus .inner {
    max-width: 680px;
  }
  div.top-appeal-area span.emphasis-s {
    font-size: 3.4vh;
  }
  #top div.top-appeal-area span.emphasis-l {
    font-size: 5vh;
  }
  .standerd-free-sec ul.price-row {
    gap: 6px;
  }
  .standerd-free-sec ul.price-row li {
    width: calc(33.3% - 4px);
  }
  .standerd-free-sec ul.price-row li .price-standerd-case {
    width: 100%;
  }
  .standerd-free-sec .free-giga-btn {
    width: 145px;
    padding: 6px 10px 6px 45px;
  }
  #price {
    padding: 0;
  }
  #price.standerd-free-sec .free-giga-btn p {
    line-height: 1.4;
  }
  .standerd-free-sec .free-giga-btn p span:nth-of-type(2) {
    font-size: 1.3rem;
  }
  .standerd-free-sec .free-giga-content {
    width: 200px;
  }
  .standerd-free-sec .price-box#price-section-v2-1 {
    padding: 0 0 40px;
  }
  #price.standerd-free-sec .free-giga-content .inner .content-ttl {
    font-size: 1.4rem;
    min-height: 90px;
  }
  #price.standerd-free-sec .free-giga-content .inner .content-ttl span {
    font-size: 1.8rem;
  }
  .standerd-free-sec .free-giga-content .inner {
    padding: 15px 5px 100px;
  }
  #price.standerd-free-sec .plan-contact p span {
    font-size: 1.6rem;
    width: 100%;
    box-sizing: border-box;
  }
  #price.standerd-free-sec .plan-contact p span span {
    width: auto;
  }
  #price.standerd-free-sec .plan-contact {
    height: 90px;
  }
  #price.standerd-free-sec .plan-contact p {
    font-size: 1.4rem;
  }
  #price.standerd-free-sec .plan-contact p a {
    font-size: 1.4rem;
  }
  #price.standerd-free-sec .plan-contact p a::before {
    border-top: 5px solid transparent;
    border-bottom: 5px solid transparent;
    border-left: 8px solid #e6006b;
    right: -12px;
    top: 8px;
  }
  .standerd-free-sec .free-box {
    padding: 40px 0 70px;
  }
  .standerd-free-sec .content-box h3 {
    width: 55%;
  }
  .standerd-free-sec .content-box p {
    width: 40%;
  }
  #entry_fix .side-fixed-banner {
    width: 40px;
  }
  .side-fixed-banner .btns .btn-base .body {
    font-size: 1.5rem;
    height: 200px;
  }
  .side-fixed-banner .btns .btn-hint .body::before {
    font-size: 1.6rem;
  }
  .side-fixed-banner .btns .btn-faq .body::before {
    margin: 5px 0 5px 2px;
    font-size: 2.4rem;
  }
  #top .catch_text {
    font-size: 1.6em;
  }
  #top .pink-text,
  #top .blue-text {
    font-size: 3.4rem;
  }
  div.comparison-box p {
    margin: 40px 0 20px;
    font-size: 2.2rem;
  }
  div.comparison-box p span {
    font-size: 3rem;
  }
  .yellow-border, 
  .blue-border {
    padding: 6px 0 12px;
  }
  .standerd-free-sec ul.price-row.free-plan-container li {
    padding: 0 10px;
  }
  #pay {
    padding: 80px 20px 80px;
  }
  #pay h2 {
    font-size: 4rem;
  }
  #pay .pay-box-flex {
    max-width: 680px;
    gap: 15px;
    margin: 65px auto 0;
  }
  #pay .pay-box {
    width: calc(50% - 7.5px);
    padding: 25px;
  }
  #pay .pay-box-title {
    font-size: 2.8rem;
  }
  #pay .pay-box-condopay .pay-box-title {
    font-size: 3rem;
  }
  #pay .pay-box-condopay .pay-box-title .pay-box-subtitle-small {
    font-size: 2rem;
  }
  #pay .pay-box-subtitle-1 {
    font-size: 2.4rem;
  }
  #pay .pay-box-subtitle-2 {
    font-size: 2.4rem;
  }
  #pay .condopay-caution {
    font-size: 1.25rem;
  }
  #pay .pay-box-flex.pay-container {
    margin: 60px auto 0;
  }
  #pay .prepaid-box-link .btn_box02 {
    bottom: 19px;
    right: 19px;
  }
  #pay .prepaid-box-link .btn_box02 > a {
    width: 220px;
    font-size: 1.6rem;
  }
  #pay .prepaid-box-link .btn_box02 > a > span {
    background: url(https://d1q08lkutgkcx2.cloudfront.net/image/icon-window-white.webp) no-repeat 180px center;
    padding: 20px 50px 20px 15px;
  }
  #pay .prepaid-box-link .btn_box02 > a:hover > span {
    background: url(https://d1q08lkutgkcx2.cloudfront.net/image/icon-window-pink.webp) no-repeat 180px center;
  }
  #reason {
    padding: 80px 20px 80px;
  }
  #reason ul {
    margin: 30px 0 0;
  }
  #devise {
    padding: 80px 20px 80px;
  }
  #devise h2 {
    font-size: 4rem;
  }
  #devise p {
    margin: 50px 0 35px;
  }
  #devise .image-slider-wrapper p {
    margin: 30px 0;
  }
  #flow {
    padding: 80px 20px 80px;
  }
  #feature {
    padding: 80px 20px;
  }
  #feature h2 {
    font-size: 4rem;
    margin: 0 0 50px;
  }
  div.top-special-contents-icon {
    width: calc(50% - 30px);
  }
  #news {
    padding: 80px 20px 80px;
  }
  #news h2 {
    font-size: 4rem;
  }
  .news-box-area {
    max-width: 680px;
    margin: 65px auto;
  }
  #news .news-day {
    min-width: 87px;
    white-space: nowrap;
  }
  .news-category-area {
    width: 13%;
    min-width: 110px;
  }
  div.swiper-slide img {
    width: 510px;
  }
  /* キービジュアル */
  #first_view h1 div.top-kv {
    max-height: unset;
    max-width: 100vw;
    height: calc(64vw - 95px);
    text-align: center;
    aspect-ratio: initial;
    /* min-height: 360px; */
  }
  /* #first_view h1 div.top-kv img {
    max-width: 720px;
    margin: auto;
  } */
  #top span.appeal-head {
    font-size: 2rem;
    width: max-content;
    top:8px;
  }
  #top .setuyaku-box.big-banner .btn_box02 {
    bottom: 20px;
    right: 20px;
  }
  #top .setuyaku-box {
    margin: 90px auto 0;
  }
  #top .setuyaku-box.big-banner .btn_box02 a {
    width: 250px;
    font-size: 1.5rem;
  }
  #top .setuyaku-box.big-banner .btn_box02 a::after {
    width: 50px;
  }
  #top .setuyaku-box.big-banner .btn_box02 a span {
    background: url(https://d1q08lkutgkcx2.cloudfront.net/image/arrow02.svg) no-repeat right 20px center;
    padding: 20px 50px 20px 0;
    background-size: 8px;
  }
  #top .overseas-box {
    margin: 60px auto 0;
  }
  #top .setuyaku-box.global-area {
    margin: 60px auto;
  }
  .overseas-box .btn_box02 {
    bottom: 20px;
    left: 90px;
  }
  .overseas-box .btn_box02 a {
    width: 300px;
    font-size: 1.6rem;
  }
  .overseas-box .btn_box02 a span {
    background: url(https://d1q08lkutgkcx2.cloudfront.net/image/arrow02.svg) no-repeat 268px center;
    background-size: 8px;
    padding: 20px 60px 20px 0;
  }
  .overseas-box .btn_box02 a::after {
    width: 60px;
  }
  #plus dt h2 {
    font-size: 3.1rem;
  }
  #plus dt h2 span {
    font-size: 3rem;
  }
  #plus dt p {
    font-size: 1.8rem;
  }
  #plus dd {
    width: 42%;
  }
  #plus dt {
    width: 54%;
  }
  div.image-slider-wrapper.device-slider {
    width: 660px;
  }
  .userflow {
    font-size: 2em;
  }
  .userflow .flow-point {
    font-size: 1.1em;
  }
  .userflow h3 span.flow-number {
    font-size: 1.5em;
  }
  #flow h2 {
    font-size: 4rem;
    margin: 0 0 60px;
  }
  section#flow ul li:first-child div.userflow div.sp-flow-point::before {
    top: 46px;
    left: 185px;
    font-size: 1.8rem;
  }
  section#flow ul li:first-child div.userflow div.sp-flow-point::after {
    top: 85px;
    line-height: 1.4;
    text-align: left;
    width: 100%;
    left: 0px;
  }
  #top div.userflow img {
    margin: auto auto 0;
    max-width: 90%;
  }
  #flow ul li {
    width: 32%;
  }
  #flow ul li:nth-of-type(2) {
    width: 32%;
  }
  #flow ul li:nth-of-type(3) {
    width: 32%;
  }
  #cv dl::after {
    width: 170px;
    height: 220px;
    bottom: -64px;
    left: -30px;
  }
  #cv dl::before {
    right: -30px;
    bottom: -65px;
  }
  #cv dl dt h3 {
    font-size: 1.8rem;
  }
  #cv dl dt h3 img {
    width: 38px;
    margin: -2px 8px 0 0;
  }
  #cv dl dt h3 div p:last-child {
    width: 90%;
  }
  #cv dl dd h3 {
    font-size: 1.8rem;
    margin: 0 0 18px;
  }
  /* 容量選びのヒントポップアップ */
  .hint_pop {
    align-items: flex-start;
  }
  .hint_pop.active {
    margin: 3.5% auto;
    min-width: 680px;
    width: 680px;
    overflow: auto;
  }
  .hint_pop .close {
    right: 30px;
    top: 40px;
    width: 40px;
    height: 40px;
    z-index: 2;
  }
  .hint_box {
    max-width: 680px;
    padding: 90px 20px 0;
  }
  .hint_item01, .hint_item02, .hint_item03 {
    max-width: 31.5%;
    margin-top: 90px;
  }
  .hint_pop .note {
    max-width: 620px;
    margin-left: 35px;
  }
  #top .hint_box h4 img {
    max-width: 55%;
  }
  .hint_box h4 {
    top: 90px;
    transform: translateY(0%);
  }
  #top .hint_box p span.gb_txt {
    font-size: 1.3rem;
  }
  #top .hint_box p span.gb_txt b {
    font-size: 1.2em;
    line-height: 1.5em;
  }
}
@media screen and (min-width: 1281px) {
  /* pc共通 */
  div.main {
    margin-top: 89px;
  }
}
@media screen and (max-width: 767px) {
  .brand-color-line {
    height: calc(100% + 1px);
    width: 10px;
    position: absolute;
    left: 0;
    top: 0;
    background-color: #FFE400;
  }
}
@media (min-width: 768px) and (max-width: 1280px) {
  #entry_fix div.price-fix-box p {
    font-size: 1.3rem;
  }
}