@charset "utf-8";

/* --------------------
common
-------------------- */

.content.bg .item-list li .lead {
 text-align: left;
 font-size: 16px;
}

.content.bg .item-list li .title span {
 font-size: 20px;
 color: #333;
}

.content .minheadline,
.content .minheadline span {
 padding-bottom: 0;
}

.content .section {
 padding: 20px 0;
 margin-bottom: 40px;
}

.content .subheadline.center {
 text-align: center;
}

.content .subheadline.center span {
 font-size: 24px;
 padding: 20px 0;
 display: block;
}

.content .inner img {
 width: 100%;
 transition: all 0.2s;
 box-shadow: rgba(0, 0, 0, 0.1) 3px 3px 0;
}

.content .campain {
 margin-bottom: 0;
}

.overview.content .campain .image {
 margin: 0;
}

.content .campain .image .click-area:hover img {
 opacity: 0.6;
}

.content .campain {
 display: flex;
 justify-content: space-between;
 flex-direction: row-reverse;
 align-items: stretch;
}

.content .inner {
 padding-top: 40px;
}

.content .inner .note.campain-note {
 padding-top: 0;
 display: block;
}

.content .inner .note.campain-note li {
 margin-bottom: 8px;
}

.content .campain .lead {
 width: 50%;
}

.content .campain .image {
 width: 400px;
}

.content .campain .image .click_area .bnr_platform {
 width: 100%;
}

@media only screen and (max-width: 960px) {
 .content .subheadline.center span {
  font-size: 20px;
 }
}

@media only screen and (max-width: 767px) {
 .subheadline.orange {
  margin: 0;
 }

 .content .campain {
  flex-direction: column;
  padding: 20px 0;
 }

 .overview.content .campain .image,
 .content .campain .image {
  width: auto;
  margin-bottom: 20px;
 }

 .content .campain .lead {
  width: auto;
 }
}

/* --------------------
.overview
-------------------- */
.overview {
 padding: 80px 0 0 0;
}

.overview .image {
 margin: 20px 0;
}

.overview .bnr-area {
 margin: 40px 0;
}

.overview .bnr-area .click-area img {
 transition: all 0.2s ease-in-out;
}

.overview .bnr-area .click-area:hover img {
 opacity: 0.6;
}

.overview .bnr-area figure {
 background-color: #fff;
 box-shadow: rgb(0 0 0 / 10%) 2px 2px 0;
}

.content .btn .click-area .fa-dev-kit {
 right: -20%;
}

@media only screen and (max-width: 960px) {
 .overview .btn-dev-kit {
  width: 60%;
 }
}

@media only screen and (max-width: 767px) {
 .overview .btn-dev-kit {
  width: 100%;
 }
}
/* --------------------
.monthly-cost
-------------------- */

.monthly-cost .table-area .table .name-list {
 min-width: 200px;
}

.monthly-cost .table.orange.bg-white .item {
 width: auto;
}

.monthly-cost .table-area .table .type-list {
 min-width: 200px;
}

.monthly-cost .table-area .table .price-list {
 min-width: 120px;
}

.monthly-cost .table-area .table .summary-list {
 width: auto;
}

.monthly-cost .table-area .table .ul-list {
 padding-left: 1rem;
}

.monthly-cost .table-area .table .ul-list li {
 text-indent: -0.5rem;
 margin-bottom: 0.5em;
 line-height: 1.75em;
 font-size: 14px;
}

.monthly-cost .table-area .table .ul-list li::before {
 content: "・";
}

.monthly-cost .table-area .table .ul-list {
 padding-left: 1rem;
}

.monthly-cost .table-area .table .ol-list {
 padding-left: 2em;
}

.monthly-cost .table-area .table .ol-list li {
 padding-left: 1rem;
 text-indent: -1rem;
 margin-bottom: 0;
 line-height: 1.75em;
 list-style-type: decimal;
 font-size: 14px;
}

.monthly-cost .table .item {
 width: auto;
}

@media only screen and (max-width: 960px) {
  .monthly-cost .table-area .table .name-list {
    min-width: auto;
    width: 20vw;
  }

  .monthly-cost .lead {
   text-align: left;
   padding-bottom: 20px;
  }

  .monthly-cost .lead .pc {
   display: none;
  }
}

@media only screen and (max-width: 767px) {
 .monthly-cost .lead {
  padding-bottom: 20px;
 }

 .monthly-cost .table .item {
  width: 160px;
 }
}

/* --------------------
.communication-path
-------------------- */

.communication-path {
 background-color: #e5d6cc;
}

.communication-path .bnr-area {
 margin: 40px 0;
}

.communication-path .bnr-area .click-area img {
 transition: all 0.2s ease-in-out;
}

.communication-path .bnr-area .click-area:hover img {
 opacity: 0.6;
}

.communication-path .bnr-area figure {
 background-color: #fff;
 box-shadow: rgb(0 0 0 / 10%) 2px 2px 0;
}

/*
.table
-------------------- */

.communication-path .table th,
.communication-path .table td {
 border-color: #e5d6cc;
}

.communication-path .table .item {
 background-color: #ece5de;
 background-color: #f3ccbd;
}

/*
.btn
-------------------- */

.communication-path .btn {
 width: 50%;
}

.communication-path .btn .click-area .fa {
 right: -35%;
 font-size: 16px;
}

.communication-path .btn .click-area .fa.fa-sim {
 right: -8%;
 font-size: 16px;
}

@media only screen and (max-width: 960px) {
 .communication-path .lead {
  text-align: left;
 }
 .communication-path .lead .pc {
  display: none;
 }
 .communication-path .btn {
  width: 70%;
 }
}

@media only screen and (max-width: 767px) {
 .communication-path .btn {
  width: 100%;
 }
 .communication-path .btn-sim .text {
  font-size: 12px;
 }
 .communication-path .btn .click-area .fa {
  right: -12%;
 }
}

/* --------------------
.configuration-example
-------------------- */

.configuration-example .subheadline {
 display: block;
 text-align: center;
 padding-bottom: 10px;
}

.configuration-example .subheadline span {
 font-size: 24px;
}

.configuration-example .white-bg {
 background-color: #fff;
 padding: 20px;
 border-radius: 5px;
 margin: 20px 0;
 width: auto;
 text-align: center;
 box-shadow: rgb(0 0 0 / 10%) 2px 2px 0;
}

.configuration-example .table-2column {
 display: flex;
 justify-content: space-between;
 gap: 20px;
}

.configuration-example .table-2column .table-list {
 width: 100%;
}

.configuration-example .table-2column .table-list .table thead th {
 height: 25px;
 background-color: #f3ccbd;
 color: #333;
}

.configuration-example .initial-cost.table.orange.bg-white .item {
 width: auto;
 background-color: #f5f5f5;
 height: 231px;
}

.configuration-example tfoot th {
 background-color: #d65727;
 color: #fff;
}

.configuration-example .btn {
 padding-top: 80px;
}

@media only screen and (max-width: 960px) {
 .configuration-example .table.orange.bg-white {
  font-size: 12px;
 }
 .configuration-example .initial-cost.table.orange.bg-white .item {
  height: 189px;
 }
 .configuration-example .btn {
  width: 60%;
 }
}

@media only screen and (max-width: 767px) {
 .configuration-example .white-bg {
  padding:  10px;
 }

 .configuration-example .table-2column {
  flex-direction: column;
 }

 .configuration-example .table-2column .note {
  width: 200%;
 }
 .configuration-example .btn {
  width: 100%;
 }
 .configuration-example .btn .click-area .fa {
  right: -120%;
 }
}