@charset "UTF-8";
/*
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
Twitter: @rich_clark
*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

*, *:before, *:after {
  box-sizing: border-box;
}

html {
  font-size: 10px;
  font-family: "Hiragino Kaku Gothic ProN","メイリオ", sans-serif;
}

@media screen and (max-width: 768px) {
  html {
    font-size: 13px;
  }
}

body {
  line-height: 1.8;
}

ul, ol {
  list-style-type: none;
}

img {
  max-width: 100%;
  vertical-align: top;
}

a[href] {
  cursor: pointer;
}

a[href]:hover {
  opacity: .8;
}

.inner-s {
  margin-left: auto;
  margin-right: auto;
  max-width: 980px;
}

@media screen and (max-width: 768px) {
  .inner-s {
    margin-left: 10px;
    margin-right: 10px;
  }
}

.inner-m {
  margin-left: auto;
  margin-right: auto;
  max-width: 1040px;
}

@media screen and (max-width: 768px) {
  .inner-m {
    margin-left: 10px;
    margin-right: 10px;
  }
}

.inner-l {
  margin-left: auto;
  margin-right: auto;
  max-width: 1280px;
}

@media screen and (max-width: 768px) {
  .inner-l {
    margin-left: 10px;
    margin-right: 10px;
  }
}

.head-l {
  color: #083090;
  text-align: center;
}

@media screen and (min-width: 769px) {
  .head-l {
    font-size: 3.4rem;
    line-height: 1.2;
  }
}

@media screen and (max-width: 768px) {
  .head-l {
    font-size: 1.4rem;
    line-height: 1.33333;
  }
}

@media screen and (max-width: 360px) {
  .head-l {
    font-size: 4.26667vw;
  }
}

.head-l > .text {
  display: inline-block;
  position: relative;
}

@media screen and (min-width: 769px) {
  .head-l > .text {
    padding: 0 75px;
  }
}

@media screen and (max-width: 768px) {
  .head-l > .text {
    padding: 0 40px;
  }
}

.head-l > .text:before, .head-l > .text:after {
  background: CurrentColor;
  content: '';
  display: inline-block;
  position: absolute;
}

@media screen and (min-width: 769px) {
  .head-l > .text:before, .head-l > .text:after {
    margin-top: 0.65em;
    vertical-align: super;
    width: 55px;
    height: 2px;
  }
}

@media screen and (max-width: 768px) {
  .head-l > .text:before, .head-l > .text:after {
    top: .5em;
    vertical-align: top;
    width: 33px;
    height: 1px;
  }
}

.head-l > .text:before {
  left: 0;
}

@media screen and (min-width: 769px) {
  .head-l > .text:before {
    margin-right: 25px;
  }
}

.head-l > .text:after {
  right: 0;
}

@media screen and (min-width: 769px) {
  .head-l > .text:after {
    margin-left: 25px;
  }
}

.head-l.no-border > .text:before, .head-l.no-border > .text:after {
  display: none;
}

.head-l.border-bottom > .text:before, .head-l.border-bottom > .text:after {
  top: inherit;
  bottom: .6em;
}

.head-l > .text {
  display: inline-block;
}

.head-l .small {
  display: inline-block;
  line-height: 1.5;
  margin-right: .25em;
}

@media screen and (min-width: 769px) {
  .head-l .small {
    font-size: 2.8rem;
  }
}

@media screen and (max-width: 768px) {
  .head-l .small {
    font-size: 1.6rem;
  }
}

@media screen and (max-width: 372px) {
  .head-l .small {
    font-size: 1.3rem;
  }
}

@media screen and (min-width: 769px) {
  [data-acc]:hover {
    cursor: pointer;
    opacity: .7;
  }
}

[data-acc] > .icon {
  position: relative;
  display: inline-block;
  width: 20px;
  height: 20px;
  margin-left: 10px;
  vertical-align: middle;
}

[data-acc] > .icon:before, [data-acc] > .icon:after {
  background: CurrentColor;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}

[data-acc] > .icon:before {
  height: 2px;
  width: 100%;
}

[data-acc] > .icon:after {
  height: 100%;
  width: 2px;
}

[data-acc].-open > .icon:after {
  display: none;
}

[data-acc].-open .close-text {
  display: none;
}

[data-acc]:not(.-open) .open-text {
  display: none;
}

@media screen and (min-width: 769px) {
  .compare {
    padding-top: 100px;
  }
}

@media screen and (max-width: 768px) {
  .compare {
    padding-top: 35px;
  }
}

.table-compare {
  border-radius: 10px;
  display: block;
  width: 100%;
}

@media screen and (min-width: 769px) {
  .table-compare {
    margin-top: 45px;
  }
}

@media screen and (max-width: 768px) {
  .table-compare {
    margin-top: 20px;
  }
}

.table-compare tr {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap;
  width: 100%;
}

.table-compare th {
  border: 1px solid #fff;
  display: block;
  font-weight: normal;
  line-height: 1.4;
  width: 50%;
}

@media screen and (min-width: 769px) {
  .table-compare th {
    font-size: 2rem;
    padding: .5em 2.5em;
  }
}

@media screen and (max-width: 768px) {
  .table-compare th {
    font-size: .9rem;
    padding: .75em;
  }
}

.table-compare td {
  border: 1px solid #fff;
  display: block;
  font-weight: normal;
  width: 50%;
}

@media screen and (min-width: 769px) {
  .table-compare td {
    font-size: 1.6rem;
    padding: 1em 2.4em;
  }
}

@media screen and (max-width: 768px) {
  .table-compare td {
    font-size: .8rem;
    padding: .5em 1.5em;
  }
}

.table-compare thead {
  display: block;
  color: #fff;
  width: 100%;
}

.table-compare tbody {
  display: block;
  width: 100%;
}

.table-compare tbody tr {
  width: 100%;
}

.table-compare tbody th {
  background: #baebe1;
  width: 100%;
}

.table-compare tbody td {
  width: 50%;
}

.table-compare .cell-cloud-d {
  background-color: #e60012;
  border-radius: 10px 0 0 0;
}

.table-compare .cell-cloud-ap {
  background-color: #1C3E91;
  border-radius: 0 10px 0 0;
}

.table-compare .cell-arrow {
  padding: 3px;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .table-compare .cell-arrow img {
    width: 20px;
  }
}

.table-compare .cell-list-d,
.table-compare .cell-list-ap {
  font-weight: bold;
}

@media screen and (min-width: 769px) {
  .table-compare .cell-list-d,
  .table-compare .cell-list-ap {
    font-size: 1.6rem;
  }
}

@media screen and (max-width: 768px) {
  .table-compare .cell-list-d,
  .table-compare .cell-list-ap {
    font-size: .8rem;
    padding: 1em;
  }
}

.table-compare .cell-list-d > .list,
.table-compare .cell-list-ap > .list {
  text-indent: -1em;
  padding-left: 1em;
}

.table-compare .cell-list-d > .list > .item:nth-child(n+2),
.table-compare .cell-list-ap > .list > .item:nth-child(n+2) {
  margin-top: .2em;
}

.table-compare .cell-list-d {
  background-color: #FFDDDD;
}

.table-compare .cell-list-ap {
  background-color: #DFE2EF;
}

.cooperation {
  background: #EDF3F7;
}

@media screen and (min-width: 769px) {
  .cooperation {
    padding-top: 65px;
    padding-bottom: 65px;
  }
}

@media screen and (max-width: 768px) {
  .cooperation {
    margin-top: 35px;
    padding-top: 35px;
    padding-bottom: 30px;
  }
}

.list-cooperation {
  background: #fff;
  border: 1px solid Currentcolor;
  color: #1C3E91;
  font-weight: bold;
  text-align: center;
  margin-top: 25px;
  margin-left: auto;
  margin-right: auto;
  max-width: 600px;
}

@media screen and (min-width: 769px) {
  .list-cooperation {
    font-size: 1.8rem;
  }
}

@media screen and (max-width: 768px) {
  .list-cooperation {
    font-size: 1rem;
    width: 320px;
  }
}

@media screen and (max-width: 372px) {
  .list-cooperation {
    font-size: 1rem;
    width: 300px;
  }
}

.list-cooperation > li {
  padding: .5em 0;
}

.list-cooperation > li:nth-child(n+2) {
  border-top: 1px solid Currentcolor;
}

.read-cooperation {
  color: #e60012;
  font-weight: bold;
  text-align: center;
  line-height: 1.5;
  margin-top: 1.15em;
}

@media screen and (min-width: 769px) {
  .read-cooperation {
    font-size: 2.2rem;
  }
}

@media screen and (max-width: 768px) {
  .read-cooperation {
    font-size: 1.4rem;
  }
}

.cv {
  background-color: #BF000F;
  background-image: url("../img/cv-bg.png");
}

@media screen and (min-width: 769px) {
  .cv {
    padding-top: 30px;
    padding-bottom: 30px;
  }
}

@media screen and (min-width: 376px) and (max-width: 768px) {
  .cv {
    padding-top: 30px;
    padding-bottom: 30px;
  }
}

@media screen and (max-width: 375px) {
  .cv {
    padding-top: 20px;
    padding-bottom: 20px;
  }
}

@media screen and (min-width: 769px) {
  .cv.cv-3 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}

.btn-list {
  display: -webkit-box;
  display: flex;
  -webkit-box-pack: center;
          justify-content: center;
  flex-wrap: wrap;
}

@media screen and (min-width: 376px) {
  .btn-list {
    margin-bottom: -20px;
  }
}

.btn-list > .item {
  margin-left: 20px;
  margin-right: 20px;
}

@media screen and (min-width: 769px) {
  .btn-list > .item {
    margin-bottom: 20px;
    width: 400px;
  }
}

@media screen and (min-width: 376px) and (max-width: 768px) {
  .btn-list > .item {
    margin-bottom: 20px;
    width: 260px;
  }
}

@media screen and (max-width: 375px) {
  .btn-list > .item {
    width: 260px;
  }
  .btn-list > .item:nth-child(n+2) {
    margin-top: 15px;
  }
}

.btn-list > .item > .link-btn {
  background-color: #fff;
  background-image: url("../img/icon-arrow-red.svg");
  background-position: right 20px center;
  background-repeat: no-repeat;
  border-radius: 5px;
  color: #e60012;
  display: block;
  font-weight: bold;
  padding: 1em;
  text-align: center;
  text-decoration: none;
  width: 100%;
}

@media screen and (min-width: 769px) {
  .btn-list > .item > .link-btn {
    font-size: 2.4rem;
  }
}

@media screen and (max-width: 768px) {
  .btn-list > .item > .link-btn {
    background-size: 8px 14px;
    font-size: 1.6rem;
  }
}

.btn-list > .item.contact > .text {
  color: #fff;
  text-align: center;
  font-weight: bold;
}

@media screen and (min-width: 769px) {
  .btn-list > .item.contact > .text {
    font-size: 2rem;
    margin-top: 40px;
    margin-bottom: 15px;
  }
}

@media screen and (max-width: 768px) {
  .btn-list > .item.contact > .text {
    font-size: 1.1rem;
    margin-bottom: 10px;
  }
}

.btn-list > .item.contact > .link-btn {
  margin-left: auto;
  margin-right: auto;
}

@media screen and (min-width: 769px) {
  .btn-list > .item.contact > .link-btn {
    font-size: 1.8rem;
    width: 340px;
  }
}

@media screen and (max-width: 768px) {
  .btn-list > .item.contact > .link-btn {
    font-size: 1.2rem;
    width: 200px;
  }
}

@media screen and (min-width: 769px) {
  .faq {
    padding-top: 120px;
    padding-bottom: 120px;
  }
}

@media screen and (max-width: 768px) {
  .faq {
    padding-top: 50px;
    padding-bottom: 70px;
  }
}

.faq-list {
  border-top: 1px solid #999;
}

@media screen and (min-width: 769px) {
  .faq-list {
    margin-top: 40px;
  }
}

@media screen and (max-width: 768px) {
  .faq-list {
    margin-top: 20px;
  }
}

.faq-list > .item {
  border-bottom: 1px solid #999;
  font-weight: bold;
}

@media screen and (min-width: 769px) {
  .faq-list > .item {
    padding-top: 30px;
    padding-bottom: 30px;
  }
}

@media screen and (max-width: 768px) {
  .faq-list > .item {
    padding-top: 12px;
    padding-bottom: 12px;
  }
}

.faq-list > .item > .q {
  display: -webkit-box;
  display: flex;
  -webkit-box-align: center;
          align-items: center;
}

@media screen and (min-width: 769px) {
  .faq-list > .item > .q {
    font-size: 1.8rem;
  }
}

@media screen and (max-width: 768px) {
  .faq-list > .item > .q {
    font-size: 1.2rem;
  }
}

.faq-list > .item > .q > .text {
  -webkit-box-flex: 1;
          flex: 1;
}

.faq-list > .item > .q > .text:before {
  content: 'Q.';
  color: #083090;
  display: inline-block;
}

@media screen and (min-width: 769px) {
  .faq-list > .item > .q > .text:before {
    font-size: 2.4rem;
  }
}

@media screen and (max-width: 768px) {
  .faq-list > .item > .q > .text:before {
    font-size: 1.8rem;
  }
}

.faq-list > .item > .q > .icon:before, .faq-list > .item > .q > .icon:after {
  background: #083090;
}

@media screen and (min-width: 769px) {
  .faq-list > .item > .a {
    font-size: 1.6rem;
    margin-top: 20px;
  }
}

@media screen and (max-width: 768px) {
  .faq-list > .item > .a {
    font-size: 1rem;
    margin-top: 12px;
  }
}

.faq-list > .item > .a:before {
  content: 'A.';
  color: #083090;
  display: inline-block;
}

@media screen and (min-width: 769px) {
  .faq-list > .item > .a:before {
    font-size: 2.4rem;
  }
}

@media screen and (max-width: 768px) {
  .faq-list > .item > .a:before {
    font-size: 1.8rem;
  }
}

.faq-list > .item > .a > .a-detail {
  font-weight: normal;
  line-height: 2;
  margin-top: 15px;
}

.faq-list > .item > .a > .a-detail > *:first-child {
  margin-top: 0 !important;
}

.faq-list > .item > .a > .a-detail > .title {
  color: #083090;
  margin-top: 25px;
}

.a-detail .indent {
  margin: 0 0 5px 30px;
}

@media screen and (max-width: 768px) {
  .a-detail .indent {
    margin-left: 20px;
  }
}

.header {
  border-bottom: 1px solid #eee;
}

@media screen and (min-width: 769px) {
  .header {
    padding-top: 15px;
    padding-bottom: 15px;
  }
}

@media screen and (max-width: 768px) {
  .header {
    padding-top: 4px;
    padding-bottom: 10px;
  }
}

.header > .inner-m {
  display: -webkit-box;
  display: flex;
  -webkit-box-align: center;
          align-items: center;
}

.logo {
  -webkit-box-flex: 1;
          flex: 1;
}

@media screen and (min-width: 769px) {
  .logo {
    display: -webkit-box;
    display: flex;
    -webkit-box-align: center;
            align-items: center;
  }
}

@media screen and (max-width: 768px) {
  .logo {
    font-size: .6rem;
  }
}

.logo .link {
  display: block;
  margin-right: 10px;
}

@media screen and (min-width: 769px) {
  .logo .link {
    width: 100px;
  }
}

@media screen and (max-width: 768px) {
  .logo .link {
    width: 55px;
  }
}

.logo > .text {
  font-size: 1.8rem;
  font-weight: normal;
}

@media screen and (max-width: 768px) {
  .logo > .text {
    font-size: 1.1rem;
  }
}

@media screen and (min-width: 769px) {
  .logo-ntt {
    width: 136px;
  }
}

@media screen and (max-width: 768px) {
  .logo-ntt {
    width: 77px;
  }
}

.footer {
  padding-top: 10px;
  padding-bottom: 10px;
}

.footer > .inner-m {
  display: -webkit-box;
  display: flex;
  -webkit-box-align: center;
          align-items: center;
}

.footer > .inner-m .copyright {
  -webkit-box-flex: 1;
          flex: 1;
}

@media screen and (min-width: 769px) {
  .footer > .inner-m .copyright {
    font-size: 1.2rem;
  }
}

@media screen and (max-width: 768px) {
  .footer > .inner-m .copyright {
    font-size: .7rem;
  }
}

@media screen and (min-width: 769px) {
  .footer > .inner-m .privacy-mark {
    width: 70px;
  }
}

@media screen and (max-width: 768px) {
  .footer > .inner-m .privacy-mark {
    width: 50px;
  }
}

.pagetop {
  display: block;
  position: fixed;
}

@media screen and (min-width: 769px) {
  .pagetop {
    width: 60px;
    right: 30px;
    bottom: 30px;
  }
}

@media screen and (max-width: 768px) {
  .pagetop {
    width: 40px;
    right: 10px;
    bottom: 10px;
  }
}

.bg-red-vivid {
  background-color: #e60012;
}

.bg-blue2 {
  background-color: #1C3E91;
}

.bg-gray2 {
  background: #eee;
}

.text-s {
  font-size: 80% !important;
}

.text-xs {
  font-size: 55% !important;
}

.font-w-normal {
  font-weight: normal !important;
}

.font-w-bold {
  font-weight: bold !important;
}

.text-a-right {
  text-align: right !important;
}

.mt-1em {
  margin-top: 1em !important;
}

.d-ib {
  display: inline-block !important;
}

@media screen and (max-width: 768px) {
  .pc {
    display: none !important;
  }
}

@media screen and (min-width: 769px) {
  .sp_tab {
    display: none !important;
  }
}

@media screen and (max-width: 1020px) and (min-width: 769px) {
  .middle_none {
    display: none !important;
  }
}

@media screen and (max-width: 1020px) and (min-width: 769px) {
  .middle_exist {
    display: block !important;
  }
}

@media screen and (max-width: 372px) {
  .small_none {
    display: none !important;
  }
}

@media screen and (max-width: 372px) {
  .small_exist {
    display: block !important;
  }
}

@media screen and (min-width: 373px) {
  .not-small_none {
    display: none !important;
  }
}

@media screen and (min-width: 769px) {
  .model {
    padding-top: 100px;
    padding-bottom: 80px;
  }
}

@media screen and (max-width: 768px) {
  .model {
    padding-top: 40px;
    padding-bottom: 30px;
  }
}

.head-model {
  color: #e60012;
  text-align: center;
}

@media screen and (min-width: 769px) {
  .head-model {
    font-size: 2.2rem;
    margin-top: 2em;
    margin-bottom: 1em;
  }
}

@media screen and (max-width: 768px) {
  .head-model {
    font-size: 1.4rem;
    margin-top: 1.2em;
    margin-bottom: .5em;
  }
}

@media screen and (min-width: 769px) {
  .case-item + .case-item {
    margin-top: 40px;
  }
}

@media screen and (max-width: 768px) {
  .case-item + .case-item {
    margin-top: 20px;
  }
}

.case-item > .title {
  border: 2px solid #ddd;
  display: -webkit-box;
  display: flex;
  font-size: 2rem;
}

@media screen and (min-width: 769px) {
  .case-item > .title {
    -webkit-box-align: center;
            align-items: center;
    border-width: 4px;
    padding: 15px 25px;
  }
}

@media screen and (max-width: 768px) {
  .case-item > .title {
    -webkit-box-align: end;
            align-items: flex-end;
    padding: 10px 12px;
  }
}

.case-item > .title > .text {
  -webkit-box-flex: 1;
          flex: 1;
  text-decoration: underline;
}

@media screen and (max-width: 768px) {
  .case-item > .title > .text {
    font-size: 1rem;
  }
}

.case-item > .title > .text > .num {
  background: #e60012;
  border-radius: 2em;
  color: #fff;
  display: inline-block;
  padding: .1em 1em;
}

@media screen and (min-width: 769px) {
  .case-item > .title > .text > .num {
    margin-right: 1em;
  }
}

@media screen and (max-width: 768px) {
  .case-item > .title > .text > .num {
    font-size: .9rem;
    margin-bottom: .5em;
  }
}

.case-item > .cont > .after-box {
  border: 2px solid #ddd;
  border-top: none;
  position: relative;
}

@media screen and (min-width: 769px) {
  .case-item > .cont > .after-box {
    font-size: 1.6rem;
    border-width: 4px;
    padding: 60px 55px 0;
  }
}

@media screen and (max-width: 768px) {
  .case-item > .cont > .after-box {
    padding: 15px 12px 0;
  }
}

.case-item > .cont > .after-box > .terms {
  background: #1C3E91;
  border-radius: 1em;
  color: #fff;
  display: inline-block;
  font-size: 1.8rem;
  padding: .15em 1.25em;
  margin-bottom: 1em;
}

@media screen and (max-width: 768px) {
  .case-item > .cont > .after-box > .terms {
    font-size: .9rem;
  }
}

.case-item > .cont > .after-box > .list > .item {
  margin-left: 1em;
  margin-bottom: 1.5em;
}

.case-item > .cont > .after-box > .list > .item:before {
  content: '・';
  display: inline-block;
  margin-left: -1em;
}

.case-item > .cont > .after-box > .img {
  background: #EDF3F7;
  margin-top: 1em;
  text-align: center;
}

@media screen and (min-width: 769px) {
  .case-item > .cont > .after-box > .img {
    padding: 35px;
  }
}

@media screen and (max-width: 768px) {
  .case-item > .cont > .after-box > .img {
    padding: 18px 25px;
  }
}

.case-item > .cont > .after-box > .img img {
  max-width: 563pc;
  width: 100%;
}

.case-item > .cont > .after-box > .img.-desktop01 img {
  max-width: 570px;
}

.case-item > .cont > .after-box > .text-calc {
  color: #083090;
  font-weight: bold;
  text-align: center;
  line-height: 1.25;
}

@media screen and (min-width: 769px) {
  .case-item > .cont > .after-box > .text-calc {
    font-size: 40px;
    margin-top: 45px;
    margin-bottom: 45px;
  }
}

@media screen and (max-width: 768px) {
  .case-item > .cont > .after-box > .text-calc {
    font-size: 21px;
    margin-top: 30px;
    margin-bottom: 30px;
  }
}

.case-item > .cont > .after-box > .text-calc > .ico-calculator {
  margin-right: 10px;
  vertical-align: top;
}

@media screen and (max-width: 768px) {
  .case-item > .cont > .after-box > .text-calc > .ico-calculator {
    width: 17px;
  }
}

.case-item > .cont > .after-box > .arrow {
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
}

@media screen and (min-width: 769px) {
  .case-item > .cont > .after-box > .arrow {
    bottom: -65px;
  }
}

@media screen and (max-width: 768px) {
  .case-item > .cont > .after-box > .arrow {
    bottom: -38px;
    width: 56px;
  }
}

.case-item > .cont > .btn-toggle {
  border: 1px solid CurrentColor;
  display: -webkit-box;
  display: flex;
  -webkit-box-align: center;
          align-items: center;
  -webkit-box-pack: center;
          justify-content: center;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
  margin-top: 1.5em;
  padding: .5em;
}

@media screen and (max-width: 768px) {
  .case-item > .cont > .btn-toggle {
    font-size: 1.2rem;
  }
}

.case-item > .cont > .btn-toggle > .icon {
  color: #e60012;
}

.table-monthly-usage {
  border-right: 1px solid #999;
  border-bottom: 1px solid #999;
  width: 100%;
}

@media screen and (min-width: 769px) {
  .table-monthly-usage {
    font-size: 1.6rem;
    margin-top: 40px;
  }
}

@media screen and (max-width: 768px) {
  .table-monthly-usage {
    font-size: 1rem;
    margin-top: 25px;
  }
}

.table-monthly-usage thead {
  background: #EDF3F7;
}

.table-monthly-usage tfoot {
  background: #083090;
  color: #fff;
}

.table-monthly-usage th {
  border-top: 1px solid #999;
  border-left: 1px solid #999;
  font-weight: normal;
  vertical-align: middle;
}

@media screen and (min-width: 769px) {
  .table-monthly-usage th {
    padding: 15px;
  }
}

@media screen and (max-width: 768px) {
  .table-monthly-usage th {
    padding: 10px;
  }
}

.table-monthly-usage td {
  border-top: 1px solid #999;
  border-left: 1px solid #999;
}

@media screen and (min-width: 769px) {
  .table-monthly-usage td {
    padding: 15px;
  }
}

@media screen and (max-width: 768px) {
  .table-monthly-usage td {
    padding: 10px;
  }
}

.table-monthly-usage .cell-constitution {
  text-align: left;
}

@media screen and (min-width: 769px) {
  .table-monthly-usage .cell-constitution-td {
    padding: 0;
  }
}

@media screen and (min-width: 769px) {
  .table-monthly-usage .cell-constitution-td-inner {
    display: -webkit-box;
    display: flex;
  }
}

@media screen and (min-width: 769px) {
  .table-monthly-usage .cell-constitution-td-inner > .cell-title {
    -webkit-box-flex: 1;
            flex: 1;
    padding: 15px;
  }
}

@media screen and (min-width: 769px) {
  .table-monthly-usage .cell-constitution-td-inner > .cell-capacity {
    border-left: 1px solid #999;
    width: 300px;
    padding: 15px;
  }
}

.table-monthly-usage .cell-price {
  text-align: right;
}

@media screen and (min-width: 769px) {
  .table-monthly-usage .cell-price {
    width: 200px;
  }
}

@media screen and (max-width: 768px) {
  .table-monthly-usage .cell-price {
    width: 80px;
  }
}

.product-table {
  border-right: 1px solid #999;
  border-bottom: 1px solid #999;
  width: 100%;
}

@media screen and (min-width: 769px) {
  .product-table {
    font-size: 1.4rem;
    margin-top: 90px;
  }
}

@media screen and (max-width: 768px) {
  .product-table {
    font-size: 1rem;
    margin-top: 45px;
  }
}

.product-table thead {
  background: #FFDDDD;
}

.product-table tfoot {
  background: #e60012;
  color: #fff;
}

.product-table th {
  border-top: 1px solid #999;
  border-left: 1px solid #999;
  text-align: left;
}

@media screen and (min-width: 769px) {
  .product-table th {
    padding: 16px;
  }
}

@media screen and (max-width: 768px) {
  .product-table th {
    padding: 7px;
  }
}

.product-table td {
  border-top: 1px solid #999;
  border-left: 1px solid #999;
  text-align: left;
  vertical-align: top;
}

@media screen and (min-width: 769px) {
  .product-table td {
    padding: 16px;
  }
}

@media screen and (max-width: 768px) {
  .product-table td {
    padding: 8px;
  }
}

@media screen and (min-width: 769px) {
  .product-table td.product {
    padding: 0;
    width: 405px;
  }
}

.product-table .type {
  color: #e60012;
  font-weight: bold;
}

@media screen and (max-width: 768px) {
  .product-table .type {
    line-height: 1.5;
    padding-left: 5px;
    padding-right: 5px;
    text-align: center;
    vertical-align: middle;
    width: 18px;
  }
  .product-table .type > .text {
    display: inline-block;
    width: 1em;
  }
}

@media screen and (max-width: 768px) {
  .product-table .cwd {
    line-height: 1.5;
    padding-left: 5px;
    padding-right: 5px;
    text-align: center;
    vertical-align: middle;
    width: 18px;
  }
  .product-table .cwd > .text {
    display: inline-block;
    width: 1em;
  }
}

@media screen and (min-width: 769px) {
  .product-table .cell-inner {
    display: -webkit-box;
    display: flex;
  }
}

@media screen and (min-width: 769px) {
  .product-table .cell-inner > .name {
    padding: 20px;
    -webkit-box-flex: 1;
            flex: 1;
  }
}

@media screen and (min-width: 769px) {
  .product-table .cell-inner > .edition {
    border-left: 1px solid #999;
    padding-top: 20px;
    padding-bottom: 20px;
    text-align: center;
    width: 66px;
  }
}

@media screen and (max-width: 768px) {
  .product-table .cell-inner > .edition {
    display: inline-block;
    margin-right: .5em;
  }
}

@media screen and (min-width: 769px) {
  .product-table .cell-inner > .dl_pk {
    border-left: 1px solid #999;
    padding-top: 20px;
    padding-bottom: 20px;
    text-align: center;
    width: 140px;
  }
}

@media screen and (max-width: 768px) {
  .product-table .cell-inner > .dl_pk {
    display: inline-block;
  }
}

.product-table .price-title {
  text-align: center;
}

.product-table .price {
  text-align: right;
}

@media screen and (min-width: 769px) {
  .product-table .price {
    width: 210px;
  }
}

@media screen and (max-width: 768px) {
  .product-table .price {
    width: 100px;
  }
}

.product-table .price .value {
  color: #e60012;
  display: block;
}

/* mv */
.mv {
  background: url(../img/mv.png) no-repeat center/cover;
}

@media screen and (max-width: 768px) {
  .mv {
    padding-bottom: 30px;
  }
}

.mv_inner {
  padding-top: 75px;
  text-align: center;
}

@media screen and (min-width: 769px) {
  .mv_inner {
    font-size: 2.2rem;
    line-height: 1.45455;
    margin-bottom: 50px;
    height: 600px;
  }
}

@media screen and (max-width: 768px) {
  .mv_inner {
    font-size: 1.2rem;
    line-height: 1.5;
    margin-bottom: 10px;
  }
}

.mv_read {
  color: #fff;
}

@media screen and (min-width: 769px) {
  .mv_read {
    font-size: 2.2rem;
    line-height: 1.45455;
    margin-bottom: 50px;
  }
}

@media screen and (max-width: 768px) {
  .mv_read {
    font-size: 1.2rem;
    line-height: 1.5;
    margin-bottom: 10px;
  }
}

.text-solusion {
  color: #1C3E91;
  display: inline-block;
}

@media screen and (min-width: 769px) {
  .text-solusion {
    margin-right: .25em;
  }
}

.mv_h1 {
  font-weight: bold;
}

@media screen and (min-width: 1020px) {
  .mv_h1 {
    font-size: 6.4rem;
    line-height: 1.5;
  }
}

@media screen and (max-width: 1019px) and (min-width: 769px) {
  .mv_h1 {
    font-size: 5.0rem;
  }
}

@media screen and (max-width: 768px) {
  .mv_h1 {
    font-size: 3.3rem;
    line-height: 1.15;
    margin-bottom: 5px;
  }
}

@media screen and (max-width: 372px) {
  .mv_h1 {
    font-size: 2.7rem;
  }
}

.text-series {
  color: #1C3E91;
  display: inline-block;
  font-weight: normal;
}

@media screen and (min-width: 769px) {
  .text-series {
    margin-right: .25em;
  }
}

.text-read {
  font-weight: bold;
}

.merit {
  display: -webkit-box;
  display: flex;
}

@media screen and (max-width: 768px) {
  .merit {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
            flex-direction: column;
  }
}

.merit_block {
  margin-top: 40px;
  position: relative;
  vertical-align: top;
}

@media screen and (min-width: 769px) {
  .merit_block {
    display: inline-block;
    width: calc((100% - 40px) / 3);
  }
  .merit_block:nth-child(n+2) {
    margin-left: 20px;
  }
}

@media screen and (max-width: 768px) {
  .merit_block:nth-child(n+2) {
    margin-top: 12px;
  }
}

.merit_cont {
  background-color: #fff;
}

@media screen and (min-width: 769px) {
  .merit_cont {
    height: 178px;
    padding-top: 40px;
  }
}

@media screen and (max-width: 768px) {
  .merit_cont {
    padding: 20px 15px 15px;
  }
}

.merit_title {
  color: #1C3E91;
  font-weight: bold;
  letter-spacing: -1px;
  margin-bottom: 5px;
}

@media screen and (min-width: 769px) {
  .merit_title {
    font-size: 2.2rem;
    height: 60px;
    line-height: 30px;
  }
}

@media screen and (max-width: 768px) {
  .merit_title {
    font-size: 1.3rem;
  }
}

@media screen and (min-width: 769px) {
  .merit_text {
    font-size: 1.4rem;
  }
}

@media screen and (max-width: 768px) {
  .merit_text {
    font-size: 1rem;
  }
}

.merit_img {
  position: absolute;
}

@media screen and (min-width: 769px) {
  .merit_img {
    top: -40px;
    right: 0;
    left: 0;
    margin: auto;
  }
}

@media screen and (max-width: 768px) {
  .merit_img {
    top: -20px;
    left: 0;
    width: 66px;
  }
}

@media screen and (min-width: 769px) {
  .soft {
    padding-top: 100px;
    padding-bottom: 70px;
  }
}

@media screen and (max-width: 768px) {
  .soft {
    padding-top: 50px;
    padding-bottom: 38px;
  }
}

.soft-read > .text {
  font-weight: bold;
  text-align: center;
  margin-top: 1em;
  line-height: 1.66667;
}

@media screen and (max-width: 768px) {
  .soft-read > .text {
    font-size: 1.1rem;
  }
}

@media screen and (min-width: 769px) {
  .soft-read > .text-1 {
    font-size: 2.0rem;
  }
  .soft-read > .text-2 {
    font-size: 1.8rem;
  }
}

.title-list {
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap;
  -webkit-box-align: start;
          align-items: flex-start;
}

@media screen and (min-width: 769px) {
  .title-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
            flex-direction: column;
    margin-top: 50px;
    height: 390px;
  }
}

@media screen and (max-width: 768px) {
  .title-list {
    margin-top: 20px;
  }
}

.title-list > .item {
  background: #f7f7f7;
  display: -webkit-box;
  display: flex;
  -webkit-box-align: center;
          align-items: center;
  border-radius: 5px;
  font-weight: bold;
  line-height: 1.3;
  margin-top: 10px;
}

@media screen and (min-width: 769px) {
  .title-list > .item {
    font-size: 1.8rem;
    margin-left: 25px;
    width: calc((100% - 25px * 2) / 3);
    height: 70px;
  }
  .title-list > .item:nth-child(5n+1) {
    margin-top: 0;
  }
  .title-list > .item:nth-child(-n+5) {
    margin-left: 0;
  }
}

@media screen and (max-width: 768px) {
  .title-list > .item {
    font-size: 1rem;
    margin-left: 10px;
    width: calc((100% - 10px) / 2);
    height: 36px;
  }
  .title-list > .item:nth-child(2n+1) {
    margin-left: 0;
  }
}

@media screen and (max-width: 372px) {
  .title-list .small-text {
      font-size: .8rem;
  }
}

.title-list > .item > .soft-ico {
  box-sizing: content-box;
  height: 38px;
  padding: 0 15px;
  width: 38px;
}

@media screen and (max-width: 768px) {
  .title-list > .item > .soft-ico {
    height: 16px;
    width: 16px;
  }
}

.title-list > .item > .num {
  display: -webkit-box;
  display: flex;
  -webkit-box-align: center;
          align-items: center;
  -webkit-box-pack: center;
          justify-content: center;
  background: #083090;
  border-radius: 34px;
  color: #fff;
}

@media screen and (min-width: 769px) {
  .title-list > .item > .num {
    font-size: 1.2rem;
    margin-left: 10px;
    margin-right: 30px;
    width: 34px;
    height: 34px;
  }
}

@media screen and (max-width: 768px) {
  .title-list > .item > .num {
    font-size: .7rem;
    margin-left: 5px;
    margin-right: 7px;
    width: 18px;
    height: 18px;
  }
}

.title-list > .item > .text > .option {
  display: block;
  font-size: 75%;
  font-weight: normal;
}

@media screen and (min-width: 769px) {
  .type {
    padding-top: 100px;
  }
}

@media screen and (max-width: 768px) {
  .type {
    padding-top: 36px;
  }
}

.type-item-list > .item {
  overflow: hidden;
}

@media screen and (min-width: 769px) {
  .type-item-list > .item {
    margin-top: 75px;
  }
}

@media screen and (max-width: 768px) {
  .type-item-list > .item {
    margin-top: 24px;
  }
}

.type-item-list > .item > .text {
  font-size: 2.2rem;
  font-weight: bold;
  line-height: 1.3;
}

@media screen and (max-width: 768px) {
  .type-item-list > .item > .text {
    font-size: 1.2rem;
    text-align: center;
    margin-bottom: 20px;
  }
}

.type-item-list > .item > .text > .title {
  color: #083090;
  display: -webkit-box;
  display: flex;
  -webkit-box-align: center;
          align-items: center;
  margin-bottom: .5em;
}

@media screen and (min-width: 769px) {
  .type-item-list > .item > .text > .title {
    font-size: 2.8rem;
  }
}

@media screen and (max-width: 768px) {
  .type-item-list > .item > .text > .title {
    font-size: 1.7rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
            flex-direction: column;
    -webkit-box-pack: center;
            justify-content: center;
  }
}

.type-item-list > .item > .text > .title > .num {
  color: #e60012;
  font-size: 150%;
}

@media screen and (min-width: 769px) {
  .type-item-list > .item > .text > .title > .num {
    margin-right: .25em;
  }
}

@media screen and (min-width: 769px) {
  .type-item-list > .item:nth-child(2n+1) > .text,
  .type-item-list > .item:nth-child(2n+1) > .plan-box {
    float: left;
    width: 440px;
  }
}

@media screen and (min-width: 769px) {
  .type-item-list > .item:nth-child(2n+1) > .img {
    float: right;
    max-width: 801px;
    width: calc(100% - 440px - 39px);
  }
}

@media screen and (min-width: 769px) {
  .type-item-list > .item:nth-child(2n) > .text,
  .type-item-list > .item:nth-child(2n) > .plan-box {
    float: right;
    width: 440px;
  }
}

@media screen and (min-width: 769px) {
  .type-item-list > .item:nth-child(2n) > .img {
    float: left;
    width: 801px;
    max-width: 801px;
    width: calc(100% - 440px - 39px);
  }
}

.plan-box {
  display: -webkit-box;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
          flex-direction: column;
  -webkit-box-align: center;
          align-items: center;
  -webkit-box-pack: center;
          justify-content: center;
  text-align: center;
  border: 4px solid #e60012;
  border-radius: 10px;
}

@media screen and (min-width: 769px) {
  .plan-box {
    margin-top: 25px;
    padding-top: 50px;
    padding-bottom: 50px;
  }
}

@media screen and (max-width: 768px) {
  .plan-box {
    border-width: 2px;
    margin-top: 18px;
    padding-top: 20px;
    padding-bottom: 20px;
    text-align: center;
  }
}

@media screen and (min-width: 769px) {
  .plan-box > .title {
    font-size: 2.2rem;
    line-height: 1.45455;
    margin-bottom: 1em;
  }
}

@media screen and (max-width: 768px) {
  .plan-box > .title {
    font-size: 1.5rem;
    margin-bottom: .5em;
  }
}

.plan-box > .text > .price {
  color: #e60012;
  font-weight: bold;
  line-height: 1;
  padding-top: 0;
}

@media screen and (min-width: 769px) {
  .plan-box > .text > .price {
    font-size: 2.4rem;
  }
}

@media screen and (max-width: 768px) {
  .plan-box > .text > .price {
    font-size: 1.4rem;
  }
}

.plan-box > .text > .price > .num {
  font-size: 200%;
}

@media screen and (min-width: 769px) {
  .plan-box > .text > .note {
    font-size: 1.4rem;
    margin-top: 45px;
  }
}

@media screen and (max-width: 768px) {
  .plan-box > .text > .note {
    font-size: 1rem;
  }
}

.type-note {
  font-weight: bold;
  text-align: center;
  margin-top: 2.5em;
}

@media screen and (min-width: 769px) {
  .type-note {
    font-size: 1.6rem;
  }
}

@media screen and (max-width: 768px) {
  .type-note {
    font-size: 1rem;
  }
}

.add {
  padding-top: 50px;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .add{
    padding-top: 25px;
  }
}

.read-add {
  font-size: 28px;
}

@media screen and (max-width: 768px) {
  .read-add {
    font-size: 18px;
    line-height: 2.25;
  }
}

@media screen and (max-width: 768px) {
  .read-add {
    font-size: 15px;
  }
}

.underline01-add {
  border-bottom: 8px solid #fdd;
}

@media screen and (min-width: 1020px) {
  .underline01-add {
    padding-left: 65px;
  }
}

@media screen and (max-width: 1019px) {
  .underline01-add {
    display: inline-block;
    width: 95%;
  }
}

.underline02-add {
  border-bottom: 8px solid #fdd;
}

@media screen and (min-width: 1020px) {
  .underline02-add {
    padding-right: 65px;
  }
}

@media screen and (max-width: 1019px) {
  .underline02-add {
    display: inline-block;
    width: 60%;
  }
}

.read-red-add {
  color: #f00;
}

/*動画用 ifrmae*/
@media screen and (min-width: 1020px) {

	.video_frame
	{
		position:relative;
		padding-bottom:56.25%;
		height:0;
		margin-top: 30px;
	}
	
	.video_iframe{
	width: 80%;
	height: 80%;
	position:absolute ;
    top: 0;
    left: 10%;

}
}
@media screen and (max-width: 1019px) {

	.video_frame
	{
		position:relative;
		padding-bottom:56.25%;
		height:0;
		overflow:hidden;
margin-top: 30px;
	}
	
	.video_iframe
{
	width:100%;
	height:100%;
	position:absolute;
	top:0;
	left:0;
}
}
