@charset "UTF-8";

/* レイアウト共通指定
* ======================================== */
body {
  font-size: 16px;
  color: #171718;
}

.phy_contents {
  background-image: url(../images/common/common_background.png);
  background-repeat: no-repeat;
  background-position: 50% 0;
  background-size: contain;
}

.phy_contents * {
  box-sizing: border-box;
  font-family:
    "ヒラギノ角ゴ ProN",
    "Hiragino Kaku Gothic ProN",
    "メイリオ",
    Meiryo,
    "Yu Gothic",
    YuGothic,
    Verdana,
    Helvetica,
    "ＭＳ Ｐゴシック",
    sans-serif;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
}

h1,
h1 *,
.top_newrelease_list dt {
  font-family: "ナウ-GB" !important;
}

.phy_inner,
.breadcrumbs ul {
  width: 100%;
  height: 100%;
  max-width: 960px;
  position: relative;
  margin: 0 auto;
}

.breadcrumbs li:last-child {
  font-weight: bold;
}

.breadcrumbs a {
  color: #171718;
  text-decoration: underline;
}

.breadcrumbs a:hover {
  text-decoration: none;
}

/* header
* ======================================== */
.phy_header {
  height: 80px;
  background-color: #0951ad;
}

.phy_header a {
  color: #fff;
  font-weight: bold;
  transition: all 0.3s ease 0s;
}

.phy_header a:hover {
  color: #3783e4;
}

.phy_logo a {
  display: block;
  width: 200px;
  height: 30px;
  position: absolute;
  top: 34px;
  bottom: 0;
  margin: auto;
  background-repeat: no-repeat;
  background-image: url(../images/common/phy-logo-light.svg);
}

.logo_alternative_text:not(:focus):not(:active) {
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

.phy_global_navi {
  display: flex;
  position: absolute;
  right: 232px;
  bottom: 12px;
}

.phy_global_navi li {
  margin-left: 16px;
}

.phy_utilities_navi {
  display: flex;
  position: absolute;
  top: 4px;
  right: 0;
}

.phy_utilities_navi li {
  margin-left: 16px;
  font-size: 14px;
  line-height: 32px;
}

.phy_request_navi {
  display: flex;
  position: absolute;
  right: 0;
  bottom: 10px;
}

.phy_request_navi a {
  display: block;
  padding: 2px 16px;
  border: 1px solid #f3742d;
  border-radius: 4px;
  background-color: #fff;
  color: #f3742d;
}

.phy_request_navi a:hover {
  background-color: #f3742d;
  color: #fff;
}

.phy_request_navi .request_consult {
  display: none;
}

.navigation_toggle,
.navigation_close {
  display: none;
}

@media (min-width: 961px) {
  .phy_header {
    top: -32px;
    z-index: 9999;
    width: 100%;
  }

  .sticky {
    position: fixed;
  }

  .type_top .phy_header {
    background-color: #fff;
  }

  .type_top a {
    color: #74747a;
    font-weight: bold;
    transition: all 0.3s ease 0s;
  }

  .type_top a:hover {
    color: #1d51ae;
  }

  .type_top .phy_logo a {
    background-image: url(../images/common/phy-logo-default.svg);
  }

  .type_top .phy_request_navi a {
    color: #f3742d;
    transition: all 0.3s ease 0s;
  }

  .type_top .phy_request_navi a:hover {
    color: #fff;
  }
}

@media (max-width: 960px) {
  .phy_header {
    height: auto;
    position: relative;
  }

  .phy_logo {
    position: relative;
    z-index: 150;
    height: 48px;
    background: #0951ad;
  }

  .navigation_toggle {
    display: block;
    width: 12px;
    height: 12px;
    position: absolute;
    top: -8px;
    right: 24px;
    bottom: 0;
    z-index: 160;
    margin: auto;
    border: 2px solid #fff;
    border-top-color: transparent;
    border-left-color: transparent;
    background: none;
    transform: rotate(45deg);
    outline: 0;
  }

  .is_open .navigation_toggle {
    top: 0;
    bottom: -8px;
    border: 2px solid #fff;
    border-right-color: transparent;
    border-bottom-color: transparent;
  }

  .phy_logo a {
    display: block;
    width: 196px;
    height: 24px;
    top: 0;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: contain;
  }

  .navi_closure {
    position: absolute;
    top: -440px;
    z-index: 100;
    width: 100%;
    background-color: #3783e4;
    box-shadow: 0 2px 6px 3px rgba(0, 0, 0, 0.3);
    transition: all 0.5s ease-in-out;
  }

  .is_open .navi_closure {
    top: 48px;
  }

  .phy_global_navi {
    position: static;
    flex-direction: column;
  }

  .phy_global_navi {
    border-top: 1px solid #9fc5f5;
  }

  .phy_global_navi li {
    margin-left: 0;
  }

  .phy_global_navi a {
    display: block;
    position: relative;
    height: 48px;
    padding: 0 10px;
    border-bottom: 1px solid #9fc5f5;
    font-size: 14px;
    line-height: 48px;
  }

  .phy_global_navi a::after {
    content: "";
    width: 8px;
    height: 8px;
    position: absolute;
    right: 32px;
    top: 0;
    bottom: 0;
    margin: auto;
    border: 2px solid #9fc5f5;
    border-left-color: transparent;
    border-bottom-color: transparent;
    transform: rotate(45deg);
  }

  .phy_request_navi {
    position: static;
    align-items: center;
    justify-content: space-around;
    height: 80px;
    padding: 0 10px;
    border-bottom: 1px solid #9fc5f5;
  }

  .phy_request_navi .request_consult {
    display: block;
  }

  .phy_request_navi li {
    max-width: 400px;
    width: 47%;
    font-size: min(3.8vw, 16px);
  }

  .phy_request_navi a {
    height: 48px;
    width: 100%;
    padding: 0;
    border: 1px solid transparent;
    font-weight: bold;
    text-align: center;
    line-height: 48px;
  }

  .phy_request_navi .request_consult a {
    color: #1e51ae;
  }

  .phy_request_navi .request_entry a {
    background-color: #f3742d;
    color: #fff;
  }

  .phy_utilities_navi {
    position: static;
    border-bottom: 1px solid #9fc5f5;
  }

  .phy_utilities_navi li {
    width: 50%;
    margin-left: 0;
    border-right: 1px solid #9fc5f5;
  }

  .phy_utilities_navi li:last-child {
    border: 0;
  }

  .phy_utilities_navi li a {
    display: block;
    width: 100%;
    color: #fff;
    text-align: center;
    line-height: 48px;
  }

  .navigation_close {
    display: block;
    width: 100%;
    height: 48px;
    border: 0;
    background-color: #3783e4;
    color: #fff;
    font-size: 14px;
    text-align: center;
  }
}

/* パンくず
* ======================================== */
.breadcrumbs.is_bottom {
  background: #808088;
  color: #fff;
  position: relative;
  z-index: 1;
}

.breadcrumbs ul {
  display: flex;
}

.breadcrumbs li {
  height: 40px;
  font-size: 14px;
  line-height: 40px;
}

.breadcrumbs li::after {
  content: ">";
  display: inline-block;
  padding: 0 8px;
}

.breadcrumbs li:last-child::after {
  display: none;
}

.breadcrumbs a {
  font-size: 14px;
}

.breadcrumbs.is_bottom a {
  color: #fff;
}

@media (max-width: 960px) {
  .breadcrumbs {
    display: none;
  }
}

/* main
 * ======================================== */

/* 見出し、段落、区切り線（要素に直接指定）
 * ---------------------------------------- */
main h1 {
  margin: 64px 0 80px;
  color: #1d51ae;
  font-size: 48px;
  font-weight: normal;
  line-height: 52px;
  text-align: center;
}

main h2 {
  margin: 80px 0 28px;
  padding: 0;
  background: none;
  color: #0751ae;
  font-size: 30px;
  font-weight: bold;
  line-height: 35px;
}

main h3 {
  margin: 28px 0 16px;
  font-size: 25px;
  font-weight: bold;
  line-height: 32px;
}

main h4 {
  position: relative;
  margin: 28px 0 16px;
  padding-left: 32px;
  font-size: 20px;
  font-weight: bold;
  line-height: 24px;
}

main h4::before {
  content: "";
  background: #aaa;
  display: inline-block;
  width: 20px;
  height: 20px;
  border-radius: 5px;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
}

main h5 {
  margin: 32px 0 16px;
  font-size: 18px;
  line-height: 24px;
}

main p {
  margin: 8px 0 16px;
  line-height: 28px;
}

main hr {
  height: 1px;
  margin: 40px 0;
  border-top: 0;
  border-bottom: 1px solid #ccc;
}

main a {
  text-decoration: underline;
}

main a:hover {
  text-decoration: none;
}

main table {
  border-collapse: collapse;
}

main figure {
  text-align: center;
}

@media (max-width: 960px) {
  main .phy_inner {
    max-width: 600px;
    padding: 0 10px;
  }

  main h1 {
    margin: 40px 0;
    font-size: 36px;
  }

  main h2 {
    margin: 48px 0 32px;
  }

  main h3 {
    margin: 32px 0 24px;
  }
}

/* セクション切り替えサブナビゲーション
 * ---------------------------------------- */
.section_sub_navi {
  display: flex;
  width: 100%;
  max-width: 960px;
  margin: 80px auto;
  justify-content: center;
}

.section_sub_navi.is_bottom {
  margin-bottom: 160px;
}

.section_sub_navi li {
  width: 25%;
  position: relative;
  border: 1px solid #ccc;
  border-left: 0;
  background-color: #fff;
}

.section_sub_navi li:first-child {
  border-left: 1px solid #ccc;
}

.section_sub_navi a {
  display: block;
  width: 100%;
  height: 64px;
  color: #74747a;
  text-align: center;
  text-decoration: none;
  line-height: 64px;
}

.section_sub_navi a:hover,
.section_sub_navi .selected a {
  background: #1d51ae;
  color: #fff;
}

.section_sub_navi .selected::after {
  content: "";
  display: block;
  width: 16px;
  height: 16px;
  position: absolute;
  right: 0;
  left: 0;
  margin: auto;
  background: #1d51ae;
  transform: rotate(45deg);
}

.section_sub_navi.is_top .selected::after {
  bottom: -8px;
}

.section_sub_navi.is_bottom .selected::after {
  top: -8px;
}

@media (max-width: 960px) {
  .section_sub_navi {
    margin: 40px 0;
    padding: 0 8px;
  }

  .section_sub_navi li {
    width: 50%;
  }

  .section_sub_navi a {
    display: flex;
    min-height: 56px;
    padding: 8px 4px;
    font-size: 14px;
    line-height: 20px;
    align-items: center;
    justify-content: center;
  }

  .section_sub_navi.is_bottom {
    margin: 80px 0;
  }
}

/* 頻出する派生バリエーション（class指定）
 * ---------------------------------------- */
main .notice {
  margin: 40px 0;
  color: #080808;
  font-size: 14px;
}

main .behave_as_button {
  display: block;
  width: 100%;
  min-height: 64px;
  max-width: 300px;
  margin: auto;
  border: 1px solid #1d51ad;
  border-radius: 4px;
  background-color: #fff;
  color: #1d51ad;
  text-align: center;
  text-decoration: none;
  line-height: 62px;
  box-shadow: 0 2px 3px 1px rgba(0, 0, 0, 0.2);
  transition: all 0.3s ease 0s;
}

.behave_as_button:hover {
  border: 1px solid #1d51ad;
  background-color: #1d51ad;
  color: #fff;
}

@media (max-width: 960px) {
  main .notice {
    margin: 16px 0;
  }
}

/* リファレンスのリンク（疑似リスト）
 * ---------------------------------------- */
.reference_link {
  display: block;
  margin: 8px 0;
  padding-left: 12px;
  border-left: 1px solid #3482e7;
}

.reference_link a {
  text-decoration: underline;
}

.reference_link i {
  padding-right: 8px;
}

/* 通常のリスト（青丸つき）
 * ---------------------------------------- */
.usual_list {
  margin: 24px 0;
}

.usual_list li {
  padding-left: 24px;
  position: relative;
  line-height: 32px;
}

.usual_list > li ul {
  margin: 0;
}

.usual_list li::before {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  position: absolute;
  top: 12px;
  left: 8px;
  background-color: #3482e7;
  border-radius: 16px;
}

.usual_list > li ul li::before {
  background-color: #9ad8fc;
}

/* 通常のオーダーリスト（青数字つき）
 * ---------------------------------------- */
.usual_olist {
  margin: 24px 0;
  counter-reset: number 0;
}

.usual_olist li {
  margin-bottom: 24px;
  padding-left: 24px;
  position: relative;
  line-height: 32px;
}

.usual_olist li::before {
  counter-increment: number 1;
  content: counter(number) ".";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  color: #3482e7;
  font-weight: bold;
}

/* ※印リスト（枝分かれなし）
 * ---------------------------------------- */
.notice_list {
  margin: 32px 0;
}

.notice_list li {
  margin: 4px 0;
  font-size: 14px;
}

.notice_list .fa {
  margin-right: 4px;
}

/* ※印リスト（枝分かれあり）
 * ---------------------------------------- */
.branch_list {
  margin: 32px 0;
}

.branch_list li > ul {
  margin-left: 24px;
}

.branch_list > li,
.branch_list > .notice {
  margin: 4px 0;
}

@media (max-width: 960px) {
  .branch_list {
    margin: 24px 0;
  }
}

/* 警告メッセージ（赤背景）
 * ---------------------------------------- */
.notice_attention {
  padding: 16px 16px 16px 72px;
  border-radius: 4px;
  background-color: #ffcdd3;
  background-image: url(../images/specification/exclamation-triangle.svg);
  background-repeat: no-repeat;
  background-size: 24px;
  background-position: 24px 50%;
}

.notice_attention p {
  margin: 0;
}

/* 通常のテーブル（濃い青のth/てれこのtd）
 * ---------------------------------------- */
.usual_table {
  width: 100%;
  border-spacing: 0;
  border-collapse: separate;
  border-radius: 4px;
  border: 1px solid #ccc;
  table-layout: fixed;
}

.usual_table thead th,
.usual_table tbody th,
.usual_table tbody td {
  padding: 8px;
  border-bottom: 1px solid #ccc;
  text-align: center;
  line-height: 32px;
}

.usual_table thead th,
.usual_table tbody th {
  background-color: #1d51ad;
  color: #fff;
}

.usual_table thead th + th,
.usual_table tbody td {
  border-left: 1px solid #ccc;
}

.usual_table thead th[rowspan="2"] {
  border-right: 1px solid #ccc;
}

.usual_table thead th[rowspan="2"] + th {
  border-left: 0;
}

.usual_table tbody tr:last-child th,
.usual_table tbody tr:last-child td {
  border-bottom: none;
}

.usual_table thead tr:first-child th:first-child {
  border-radius: 4px 0 0;
}

.usual_table thead tr:first-child th:last-child {
  border-radius: 0 4px 0 0;
}

.usual_table tbody tr:last-child th:first-child {
  border-radius: 0 0 0 4px;
}

.usual_table tbody tr:last-child th:last-child {
  border-radius: 0 0 4px;
}

.usual_table tr:nth-child(even) {
  background-color: #e8f2ff;
}

.usual_table.spanned .odd {
  background-color: transparent;
}

.usual_table.spanned .even {
  background-color: #e8f2ff;
}

@media (min-width: 961px) {
  .spec_table th,
  .spec_table td {
    position: relative;
    z-index: -1;
  }

  .wrap_spec_table {
    position: relative;
    z-index: 10;
  }
}

/* TOPの指定
 * ======================================== ======================================== */

/* TOPの「ファーストビュー」
 * ---------------------------------------- */
.top_firstview {
  padding: 64px 0;
  background-image: url(../images/top/top_01_firstview.png);
  background-position: calc(50% - 720px) -320px;
  background-repeat: no-repeat;
}

.top_firstview h1 {
  margin: 0;
  text-align: right;
}

.top_firstview .lead_text {
  margin: 24px 0 40px;
  text-align: right;
}

.top_request_list {
  display: flex;
  justify-content: flex-end;
  width: 100%;
  max-width: 532px;
  margin: 0 0 0 auto;
}

.top_request_list li {
  margin-right: 16px;
}

.top_request_list li:last-child {
  margin-right: 0;
}

.top_request_list .behave_as_button {
  width: 240px;
  height: 110px;
  padding: 24px 0;
  line-height: 28px;
  font-weight: bold;
}

.request_entry .behave_as_button {
  border: 1px solid #f3742d;
  background-color: #f3742d;
  color: #fff;
}

.request_entry .behave_as_button:hover {
  background-color: #fff;
  color: #f3742d;
}

.top_request_list .subtext {
  display: block;
}

.top_request_list .maintext {
  display: block;
  font-size: 25px;
}

.release_note {
  display: flex;
  margin: 32px 0 0;
  border-radius: 5px;
  background-color: #e8f2ff;
  align-items: center;
}

.release_note h2 {
  margin: 8px 8px 8px 12px;
  font-size: 16px;
}

.release_note h2 i {
  margin-right: 8px;
}

.release_note h2 .text-link {
  padding-left: 0;
  background: none;
  color: #0751ae;
  text-decoration: none;
}

.release_note h2 .text-link:hover {
  text-decoration: underline;
}

@media (max-width: 960px) {
  .top_firstview {
    padding: 40px 20px;
    background-position: -120px -366px;
    background-image: url(../images/top/top_01_firstview_sp.png);
  }

  .top_firstview h1 {
    margin-top: 140px;
    font-size: 26px;
    line-height: 30px;
  }

  .top_firstview .lead_text {
    max-width: 240px;
    width: 100%;
    margin: 24px 0 48px auto;
    font-size: 14px;
    text-align: left;
  }

  .top_firstview .lead_text br {
    display: none;
  }

  .top_request_list li {
    max-width: 168px;
    width: 50%;
  }

  .top_request_list .behave_as_button {
    width: 100%;
    height: 88px;
    padding: 22px 0;
    line-height: 20px;
  }

  .top_request_list .subtext {
    font-size: 14px;
  }

  .top_request_list .maintext {
    display: block;
    font-size: 18px;
  }

  .release_note {
    align-items: start;
    flex-direction: column;
  }

  .release_note h2 {
    margin: 8px 0 0 16px;
    font-size: 14px;
  }
}

@media (max-width: 600px) {
  .top_firstview {
    padding: 40px 0;
    background-position: -120px -160px;
    background-size: cover;
  }
}

/* TOPの「特長」
 * ---------------------------------------- */
.top_feature {
  position: relative;
  padding: 40px 0;
  background-color: #0951ad;
  background-image: url(../images/top/top_03_newrelease.png);
  background-repeat: no-repeat;
  background-size: contain;
}

.top_feature::after {
  content: "";
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  bottom: 0;
  right: 0;
  left: auto;
  background-image: url(../images/top/top_02_feature.png);
  background-repeat: no-repeat;
  background-position: calc(50% + 320px) 0;
  background-size: contain;
  z-index: 1;
}

.top_feature h1 {
  position: relative;
  margin: 40px 0;
  color: #fff;
  text-align: left;
  z-index: 10;
}

.top_feature ruby rt {
  font-size: 16px;
}

.top_feature .subtext {
  display: block;
  font-size: 27px;
  line-height: 40px;
}

.top_feature .maintext {
  display: block;
  margin-top: -16px;
}

.top_feature .lead_text {
  position: relative;
  color: #fff;
  max-width: 424px;
  z-index: 10;
}

.top_feature .lead_text p {
  margin: 0;
}

.top_feature .lead_text .behave_as_button {
  max-width: 100%;
  margin: 32px 0;
  font-size: 30px;
}

.top_feature .lead_text .behave_as_button:hover {
  border: 1px solid #fff;
  color: #fff;
}

@media (max-width: 960px) {
  .top_feature {
    padding: 40px 20px;
  }

  .top_feature::after {
    background-position: 0% 100%;
    background-size: cover;
  }

  .top_feature .subtext {
    display: block;
    font-size: 18px;
    line-height: 24px;
  }

  .top_feature .maintext {
    font-size: 26px;
  }

  .top_feature ruby rt {
    font-size: 14px;
  }

  .top_feature .lead_text p {
    max-width: 290px;
  }

  .top_feature .lead_text .behave_as_button {
    font-size: 24px;
  }
}

@media (max-width: 600px) {
  .top_feature {
    padding: 40px 0;
  }
}

/* TOPの「新しい機能」
 * ---------------------------------------- */
.top_newrelease {
  padding: 40px 0 0;
}

.banner_moving_campaign {
  max-width: 960px;
  margin: 40px auto 80px;
}

.banner_moving_campaign img {
  width: 100%;
}

.top_newrelease h1 {
  margin: 64px 0 40px;
}

.top_newrelease_list li {
  display: flex;
  width: 100%;
  min-height: 504px;
  margin: 0 auto;
}

.top_newrelease_list .newrelease_controlpannel {
  flex-direction: row-reverse;
}

.top_newrelease_list dl {
  max-width: 456px;
  margin-left: 24px;
}

.newrelease_controlpannel dl {
  margin-left: 0;
  margin-right: 24px;
}

.top_newrelease_list dt {
  color: #1d51ad;
  font-size: 40px;
  line-height: 48px;
}

.top_newrelease_list dt .pc {
  display: block;
}

@media screen and (max-width: 960px) {
  .top_newrelease_list dt .pc {
    display: none;
  }
}

.top_newrelease_list dd {
  margin: 32px 0;
}

@media (max-width: 960px) {
  .top_newrelease .phy_inner {
    padding: 0;
  }

  .top_newrelease_list .newrelease_network,
  .top_newrelease_list .newrelease_controlpannel,
  .top_newrelease_list .newrelease_powersupply {
    min-height: 560px;
    flex-direction: column;
    justify-content: center;
    text-align: center;
  }

  .newrelease_image img {
    width: 100%;
    max-width: 320px;
  }

  .top_newrelease_list dl {
    max-width: 100%;
    margin: 0 10px;
  }

  .top_newrelease_list dt {
    font-size: 24px;
    line-height: 40px;
  }
}

@media (max-width: 600px) {
  .top_newrelease h1 {
    margin: 64px 0 40px;
  }

  .top_newrelease_list .newrelease_network,
  .top_newrelease_list .newrelease_controlpannel,
  .top_newrelease_list .newrelease_powersupply {
    min-height: 440px;
  }

  .top_newrelease_list dd {
    font-size: 14px;
  }
}

/* TOPの「専用サーバを選ぶ理由」
 * ---------------------------------------- */
.top_reason h1 {
  margin: 0 0 80px;
}

.top_reason_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
}

.top_reason_list li {
  width: 30%;
}

.reason_image {
  display: flex;
  min-height: 240px;
  justify-content: center;
  align-items: center;
}

.top_reason_list dt {
  display: flex;
  height: 48px;
  color: #1e51ae;
  font-size: 24px;
  text-align: center;
  justify-content: center;
  align-items: center;
}

.reason_signup dt,
.reason_maintenance dt {
  height: 24px;
}

.top_reason_list dd {
  margin: 24px 0;
}

.more_than_reason {
  display: flex;
  justify-content: space-between;
  max-width: 784px;
  margin: 64px auto;
}

.more_than_reason li {
  max-width: 352px;
  width: 50%;
}

.more_than_reason li:first-of-type {
  margin-right: 8px;
}

.more_than_reason li:last-of-type {
  margin-left: 8px;
}

.more_than_reason .behave_as_button {
  width: 100%;
  height: 124px;
  padding: 16px 0;
}

.more_than_reason .subtext {
  display: block;
  line-height: 24px;
}

.more_than_reason .maintext {
  display: block;
  font-size: 30px;
  font-weight: bold;
  line-height: 48px;
}

@media (max-width: 960px) {
  .top_reason_list dt {
    height: 80px;
  }

  .top_reason_list dt br {
    display: none;
  }

  .reason_signup dt,
  .reason_maintenance dt {
    height: 40px;
  }
}

@media (max-width: 600px) {
  .top_reason h1 {
    font-size: 26px;
    line-height: 36px;
  }

  .top_reason_list li {
    width: 48%;
    padding: 0 1%;
  }

  .reason_image img {
    width: 100%;
  }

  .top_reason_list dt {
    margin-bottom: 24px;
    font-size: 16px;
    font-weight: bold;
  }

  .top_reason_list dd {
    font-size: 14px;
  }

  .reason_cloud dt,
  .reason_storage dt {
    height: 72px;
  }

  .reason_signup dt {
    height: 48px;
  }

  .top_reason_list .reason_signup {
    background-position: 50% 32px;
  }

  .more_than_reason li:first-of-type {
    margin-right: 6px;
  }

  .more_than_reason li:last-of-type {
    margin-left: 6px;
  }

  .more_than_reason .behave_as_button {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 0
  }

  .more_than_reason .behave_as_button br {
    display: none;
  }

  .more_than_reason .maintext {
    font-size: 22px;
  }

  .more_than_reason .subtext {
    display: flex;
    flex-direction: column;
    justify-content: center;
    line-height: 1.5;
    font-size: 14px;
    min-height: 36px;
  }
}

@media (max-width: 375px) {
  .top_reason_list li {
    background-size: contain;
  }
  .more_than_reason .subtext {
    font-size: 12px;
  }
}

/* 仕様一覧のPDFダウンロード
 * ---------------------------------------- */

.spec_dl_button {
  max-width: 784px;
  margin: 64px auto;
	text-align:center;
}

.spec_dl_button li {
  max-width: 352px;
  width: 50%;
  margin: 0px auto;
}

.spec_dl_button li:last-of-type {
  margin-top: 32px;
}

.spec_dl_button .behave_as_button {
  max-width: 400px;
  width: 100%;
}

@media (max-width: 600px) {
  .spec_dl_button {
    display: block;
    width: 100%;
  }
  .spec_dl_button li {
    display: inline-block;
    width: 100%;
  }
}
@media (max-width: 375px) {
  .spec_dl_button li {
    display: block;
    width: 100%;
  }
}

/* TOPの「モデル一覧」
 * ---------------------------------------- */
.top_modelplan {
  padding: 40px 0;
  background: #f1f1f1;
}

.top_modelplan h1 {
  margin-top: 40px;
}

.top_modelplan_list {
  display: flex;
  justify-content: space-between;
  gap: 0 20px;
}

.top_modelplan_list li {
  position: relative;
  flex: calc(100% / 3) 0 0;
}

.top_modelplan_list figure img {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  margin: auto;
  z-index: 100;
}

.top_modelplan_list figcaption {
  position: relative;
  margin-top: 176px;
  padding: 32px 16px 24px 16px;
  min-height: 80px;
  border-radius: 5px 5px 0 0;
  background-color: #0951ad;
  color: #fff;
  text-align: left;
}

.top_modelplan_list figcaption .balloon {
  position: absolute;
  bottom: 96px;
  padding: 8px 16px;
  background-color: #f3742d;
  z-index: 100;
  width: auto;
  text-align: center;
  border-radius: 8px;
}

.top_modelplan_list figcaption .balloon .text {
  font-size: 16px;
  color: #fff;
  text-align: center;
  display: block;
  width: 100%;
  position: relative;
  z-index: 100;
}

.top_modelplan_list figcaption .balloon .text::after {
  width: 10px;
  height: 10px;
  content: "";
  display: block;
  transform: rotate(45deg);
  position: absolute;
  z-index: 0;
  bottom: -12px;
  left: calc(50% - 5px);
  border-right: 5px #f3742d solid;
  border-bottom: 5px #f3742d solid;
}


.top_modelplan_list .brand {
  display: block;
}

.top_modelplan_list .model_name {
  display: block;
  font-size: 24px;
  font-weight: bold;
}

.top_modelplan_list .model {
  display: block;
  font-size: 24px;
  padding-bottom: 2px;
}

.top_modelplan_list .cpu {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 4px;
  background: #f3742d;
  font-size: 14px;
  font-weight: bold;
}

.top_modelplan_list dl {
  margin-top: 0;
  background-color: #fff;
}

.top_modelplan_list dt {
  padding: 24px 16px 4px;
  color: #74747a;
  font-size: 14px;
  line-height: 24px;
}

.top_modelplan_list dd {
  padding: 4px 16px 32px;
  border-bottom: 1px solid #ccc;
  color: #000;
  font-size: 18px;
  font-weight: bold;
  line-height: 24px;
}

.top_modelplan_list .main {
  display: block;
}

.top_modelplan_list .sub {
  display: block;
  font-weight: normal;
}

.top_modelplan_list dd.model_spec_initial {
  border-bottom: 0;
  padding-bottom: 8px;
}

.top_modelplan_list dt.model_spec_monthly {
  padding-top: 8px;
}

.top_modelplan_list dd.model_spec_monthly {
  font-size: 24px;
  border-bottom: 0;
}

.top_modelplan_list .detail_link {
  display: block;
  height: 40px;
  background-color: #fff;
  color: #74747a;
  text-align: center;
  text-decoration: underline;
}

.top_modelplan_list .detail_link i {
  padding-right: 4px;
}

.top_modelplan_list .entry_link {
  display: block;
  height: 64px;
  border: 1px solid #f3742d;
  border-radius: 0 0 5px 5px;
  background-color: #f3742d;
  color: #fff;
  font-size: 24px;
  font-weight: bold;
  text-align: center;
  text-decoration: none;
  line-height: 64px;
  transition: all 0.3s ease 0s;
}

.top_modelplan_list .detail_link:hover {
  opacity: 07;
  text-decoration: none;
}

.top_modelplan_list .entry_link:hover {
  border: 1px solid #f3742d;
  background-color: #fff;
  color: #f3742d;
}

.top_modelplan_list .entry_link.gray_link {
   background-color: #ddd;
   border-color: #ddd;
 }

.top_modelplan_list .entry_link.gray_link:hover {
   background-color: #ddd;
   color: #fff;
}

@media (max-width: 960px) {
  .top_modelplan .phy_inner {
    max-width: 100%;
  }

  .top_modelplan h1 {
    font-size: 26px;
  }

  .top_modelplan_list {
    overflow: auto;
    margin-top: 80px;
    gap: 0;
  }

  .top_modelplan_list::before {
    content: "横にスクロールできます→";
    position: absolute;
    top: 96px;
    right: 16px;
    color: #1d51ad;
    font-size: 14px;
    font-weight: bold;
  }

  .top_modelplan_list li {
    margin-right: 16px;
  }

  .top_modelplan_list figcaption {
    min-height: 120px;
  }

  .top_modelplan_list .model {
    width: 100%;
    display: block;
  }

  .top_modelplan_list .cpu {
    margin-bottom: 0.5em;
    position: relative;
    left: -0.5em;
  }
}

@media (max-width: 767px) {
  .top_modelplan_list {
    gap: 0 20px;
  }

  .top_modelplan_list li {
    flex: 50% 0 0;
    gap: 0;
    margin-right: 0;
  }
}


/* TOP：構成例
 * ---------------------------------------- */
.top_case {
  padding: 40px 0;
  background-image: url(../images/common/common_wp_01.png);
}

.top_case h1 {
  margin-top: 40px;
}

.top_case_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.top_case_list li {
  position: relative;
  min-height: 160px;
  margin-bottom: 24px;
  border-radius: 5px;
  background-color: #fff;
  box-shadow: 0 4px 2px 2px rgba(0, 0, 0, 0.1);
}

.top_case_list li img {
  max-width: 100%;
}

.top_case_list li::before {
  display: block;
  position: absolute;
  color: #1d51ad;
  font-size: 30px;
  font-weight: bold;
}

.top_case_list .case1st {
  width: 100%;
  padding: 32px 40px 96px;
}

.top_case_list .case2nd,
.top_case_list .case3rd {
  width: 48%;
  padding: 24px 24px 88px;
}

.case1st::before {
  content: "01";
  top: 28px;
  left: 96px;
}

.case1st::after {
  content: "";
  display: block;
  width: 54px;
  height: 163px;
  position: absolute;
  top: -28px;
  left: 20px;
  background-image: url(../images/top/top_16_sakuraman.png);
}

.case1st figcaption {
  margin: 0 0 32px 120px;
  font-size: 25px;
  line-height: 35px;
  text-align: left;
}

.case2nd::before {
  content: "02";
}

.case3rd::before {
  content: "03";
}

.case2nd figcaption,
.case3rd figcaption {
  margin: 56px 0 24px;
  font-size: 25px;
  line-height: 32px;
  text-align: left;
}

.top_case_list .detail_link {
  display: block;
  width: 100%;
  height: 64px;
  position: absolute;
  left: 0;
  bottom: 0;
  border: 2px solid #1d51ad;
  border-radius: 0 0 5px 5px;
  background-color: #1d51ad;
  color: #fff;
  font-weight: bold;
  text-align: center;
  text-decoration: none;
  line-height: 60px;
  transition: all 0.3s ease 0s;
}

.top_case_list .detail_link:hover {
  border: 2px solid #1d51ad;
  background-color: #fff;
  color: #1d51ad;
}

@media (max-width: 600px) {
  .top_case h1 {
    font-size: 26px;
  }

  .top_case img {
    width: 100%;
  }

  .top_case_list li::before {
    position: static;
    font-size: 18px;
  }

  .top_case_list .case1st {
    width: 100%;
    padding: 16px 16px 80px;
  }

  .top_case_list li::after {
    display: none;
  }

  .top_case_list li figcaption {
    margin: 8px 0 32px;
    font-size: 18px;
    font-weight: bold;
    text-align: left;
    line-height: 28px;
  }

  .top_case_list .detail_link {
    height: 48px;
    line-height: 48px;
  }

  .top_case_list .case2nd,
  .top_case_list .case3rd {
    width: 100%;
    padding: 16px 16px 80px;
  }
}

/* TOP最下部のバナー
 * ---------------------------------------- */
.top_banner {
  padding: 40px 0;
}

.top_banner ul {
  display: flex;
  justify-content: space-between;
}

.top_banner li {
  max-width: 265px;
  width: 100%;
  margin: auto;
  padding: 0 4px;
}

.top_banner li img {
  width: 100%;
}

@media (max-width: 600px) {
  .top_banner ul {
    flex-direction: column;
  }

  .top_banner li {
    margin-bottom: 16px;
  }

  .top_banner li:last-child {
    margin-bottom: 0;
  }
}

/* TOP最下部のリンク
 * ---------------------------------------- */
.top_etc {
  padding: 40px 0;
  background: #f1f1f1;
}

.top_etc ul {
  display: flex;
  justify-content: space-between;
}

.top_etc .behave_as_button {
  width: 464px;
  max-width: 464px;
  padding: 16px 0;
  font-size: 20px;
  font-weight: bold;
  line-height: 25px;
}
.top_etc .behave_as_button .annotation {
  font-size: 14px;
  text-align: left;
  display: block;
  padding-left: 100px;
}
.top_etc .behave_as_button.one_line_button {
  min-height: 84px;
  padding: 28px 0;
}

.top_etc .maintext,
.top_etc .subtext {
  display: block;
  line-height: 30px;
}

.top_etc .subtext {
  font-size: 16px;
}

@media (max-width: 960px) {
  .top_etc ul {
    display: flex;
    justify-content: space-between;
    flex-direction: column;
  }

  .top_etc li {
    margin-bottom: 16px;
  }

  .top_etc li:last-child {
    margin-bottom: 0;
  }

  .top_etc .behave_as_button {
    width: 100%;
    min-height: 48px;
    font-size: 14px;
    line-height: 16px;
  }
  .top_etc .behave_as_button .annotation {
    font-size: 12px;
    text-align: center;
    padding-left: 0;
  }
  .top_etc .behave_as_button.one_line_button {
    min-height: auto;
    padding: 16px 0;
  }
  .top_etc .maintext,
  .top_etc .subtext {
    font-size: 14px;
    line-height: 24px;
  }
}

/* ご利用の流れ（/flow）
 * ======================================== ======================================== */
.flow_image img {
  max-width: 100%;
}

/* 支払い方法（/flow/payment）の項目リスト
 * ---------------------------------------- */
.payment_feature,
.payment_pattern {
  display: flex;
  position: relative;
}

.payment_feature li,
.payment_pattern li {
  display: block;
  min-width: 182px;
  margin-right: 16px;
  padding: 8px 20px;
  border-radius: 5px;
  background-color: #e8f2ff;
  background-repeat: no-repeat;
}

.payment_feature li {
  display: flex;
  align-items: center;
}

.payment_pattern li {
  min-height: 272px;
  padding: 20px;
  position: relative;
}

.payment_announce {
  background-image: url(../images/flow/envelope.svg);
  background-size: 32px 32px;
  background-position: 24px 50%;
}

.payment_fee {
  background-image: url(../images/flow/money-bill.svg);
  background-size: 40px 40px;
  background-position: 20px 50%;
}

.payment_confirm {
  background-image: url(../images/flow/check.svg);
  background-size: 24px 24px;
  background-position: 26px 50%;
}

.payment_feature dl {
  margin-left: 56px;
  padding-left: 16px;
  border-left: 1px solid #8fafe8;
}

.payment_feature dt,
.payment_pattern dt {
  color: #1e51ae;
  font-size: 13px;
  font-weight: bold;
  margin-top: 12px;
}

.payment_feature dd,
.payment_pattern dd {
  margin: 4px 0 12px;
  font-weight: bold;
}

.payment_pattern dl {
  position: absolute;
  top: 72px;
  left: 40px;
}

.pattern_name {
  font-size: 20px;
  display: block;
  line-height: 24px;
  position: relative;
  padding-left: 24px;
}

.pattern_name::before {
  content: "";
  background: #aaa;
  display: inline-block;
  width: 16px;
  height: 16px;
  border-radius: 5px;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
}

.payment_pattern small {
  margin-left: 12px;
  font-size: 16px;
}

@media (max-width: 960px) {
  .payment_feature,
  .payment_pattern {
    flex-direction: column;
  }

  .payment_feature li {
    display: flex;
    align-items: center;
    margin-right: 0;
    margin-bottom: 16px;
  }

  .payment_pattern li {
    margin-right: 0;
    margin-bottom: 16px;
  }

  .payment_feature li:last-child,
  .payment_pattern li:last-child {
    margin-bottom: 0;
  }

  .pattern_name {
    display: inline;
  }

  .payment_pattern small {
    margin-left: 0;
  }

  .payment_pattern dt {
    margin-top: 0;
  }
}

/* 納期について(/flow/delivery)の項目表
 * ---------------------------------------- */
.delivery_table {
  width: 100%;
  margin-bottom: 40px;
  table-layout: auto;
}

.delivery_table tr {
  background-color: #fff;
}

.delivery_table tr:nth-child(even) {
  background-color: #e8f2ff;
}

.delivery_table th,
.delivery_table td {
  height: 48px;
  border: 1px solid #ccc;
}

.delivery_table th {
  background: #1e51ae;
  color: #fff;
}

.delivery_table td {
  padding: 8px 24px;
}

@media (max-width: 960px) {
  .delivery_table {
    margin-bottom: 16px;
  }

  .delivery_table td {
    padding: 8px;
    font-size: 14px;
  }

  .delivery_table:first-of-type th:nth-child(2) {
    width: 20%;
  }

  .delivery_table:nth-of-type(2) th:nth-child(2) {
    width: 40%;
  }
}

/* 仕様一覧（/specification）
 * ======================================== ======================================== */

/* 仕様一覧（/specification）のスペック表
 * ---------------------------------------- */
.wrap_spec_table {
  width: 100%;
}

.spec_table {
  width: 960px;
  margin: 40px 0;
  border-collapse: collapse;
}

.spec_table th,
.spec_table td {
  padding: 16px 4px;
  border: 1px solid #c7c7c9;
  background: #fff;
  text-align: center;
}

.spec_table th {
  position: relative;
  background: #e8f2ff;
  color: #1e51ae;
  font-weight: bold;
}

.spec_table thead th,
.spec_table thead td {
  width: 20%;
}

.spec_table thead td {
  padding-left: 24px;
  background: #1e51ae;
  color: #fff;
  text-align: center;
  border-left: 1px solid #c7c7c9;
  border-right: 1px solid #c7c7c9;
}

.spec_table thead tr:nth-child(2) td:last-child {
  border-right: 1px solid #1d51ad;
}

.spec_table thead .balloon-cell {
  position: relative;
  z-index: 0;
}

.spec_table thead .balloon {
  position: absolute;
  left: calc(50% - 3em);
  bottom: 80px;
  padding: 8px 16px;
  background-color: #f3742d;
  z-index: 100;
  width: auto;
  text-align: center;
  border-radius: 8px;
  z-index: 100;
}

.spec_table thead .balloon .text {
  font-size: 14px;
  color: #fff;
  text-align: center;
  display: block;
  width: 100%;
  position: relative;
  z-index: 100;
}

.spec_table thead .balloon .text::after {
  width: 10px;
  height: 10px;
  content: "";
  display: block;
  transform: rotate(45deg);
  position: absolute;
  z-index: 0;
  bottom: -12px;
  left: calc(50% - 5px);
  border-right: 5px #f3742d solid;
  border-bottom: 5px #f3742d solid;
}


.spec_table thead .typename {
  display: block;
}

.spec_table thead .brand {
  display: block;
  font-size: 20px;
  padding-bottom: 2px;
  text-align: center;
}

.spec_table .models-provided .brand {
  display: block;
}

.spec_table thead .cpu {
  display: inline-block;
  font-size: 14px;
  margin: 0 auto;
  text-align: center;
}

.spec_table thead .cpu {
  margin-left: 4px;
  padding: 2px 8px;
  border-radius: 4px;
  background: #f37835;
  color: #fff;
}

.spec_table thead .empty {
  background: transparent;
  border: none;
  padding: 0;
}

.spec_table thead .empty figure {
  position: relative;
  top: 0;
  width: 100%;
  height: 128px;
  background-repeat: no-repeat;
  background-position: 50% 0;
}

.spec_table .maintext {
  display: block;
}

.spec_table .subtext {
  display: block;
  font-size: 14px;
  font-weight: normal;
}

.spec1st figure {
  background-image: url(../images/specification/spec_01_model_rx1330-m3.png);
}

.spec2nd figure {
  background-image: url(../images/specification/spec_02_model_rx2530-m4.png);
}

.spec3rd figure {
  background-image: url(../images/specification/spec_03_model_rx2530-m4_2cpu.png);
}

.spec4th figure {
  background-image: url(../images/specification/spec_04_model_rx2530-m5.png);
}

/* 仕様一覧（/specification）の共通仕様リスト
 * ---------------------------------------- */
.spec_common {
  margin: 80px 0 0;
  padding: 40px 0 80px;
  background-color: #e8f2ff;
  background-image: url(../images/common/common_wp_01.png);
}

.spec_common h1 {
  margin-top: 40px;
}

.spec_pannel_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  width: 100%;
  gap: 24px;
}

.spec_pannel_list > li {
  width: calc((100% / 3) - 24px);
}

.spec_pannel_list a {
  display: block;
  position: relative;
  padding: 16px 24px;
  min-height: 160px;
  border-radius: 5px;
  box-shadow: 0 4px 2px 2px rgba(0, 0, 0, 0.1);
  background-color: #fff;
  text-decoration: none;
  transition: all 0.3s ease 0s;
}

.spec_pannel_list a:hover {
  background-color: #1d51ad;
  color: #fff;
}

.spec_pannel_list a:hover dt,
.spec_pannel_list a:hover li,
.spec_pannel_list a:hover .detail_link::after {
  color: #fff;
}

.spec_pannel_list dt {
  color: #1d51ad;
  font-size: 24px;
  font-weight: bold;
}

.spec_pannel_list .detail_link {
  position: absolute;
  right: 16px;
  bottom: 16px;
  font-size: 18px;
}

.detail_option li {
  color: #333;
}

.spec_pannel_list .detail_link::after {
  content: ">";
  display: inline-block;
  margin-left: 16px;
  color: #1d51ad;
  font-weight: bold;
}

.spec_difference .notice {
  margin: 0 0 40px;
}

@media (max-width: 960px) {
  .wrap_spec_table {
    overflow: auto;
  }

  .spec_difference .phy_inner {
    max-width: 100%;
  }

  .spec_table::before {
    content: "横にスクロールできます→";
    position: absolute;
    top: 96px;
    right: 16px;
    color: #1d51ad;
    font-size: 14px;
    font-weight: bold;
  }

  .spec_pannel_list > li {
    width: calc(48% - 24px);
  }

  .spec_pannel_list a {
    padding: 12px;
  }

  .spec_pannel_list dt {
    font-size: 18px;
  }

  .detail_option li {
    font-size: 12px;
  }
}

@media (max-width: 767px) {
  .spec_pannel_list > li {
    width: 100%;
  }

  .spec_pannel_list a {
    min-height: 120px;
  }
}

/* 仕様一覧（/specification）の特殊ボタン
 * ---------------------------------------- */
.spec_oldplan {
  padding: 80px 0;
  background: #eee;
}

.spec_oldplan .behave_as_button {
  max-width: 480px;
  margin: auto;
  padding: 0;
  font-size: 20px;
  font-weight: bold;
}

.spec_oldplan .behave_as_button small {
  display: block;
  padding-right: 64px;
  font-size: 16px;
  font-weight: normal;
  line-height: 20px;
}

@media (max-width: 960px) {
  .spec_oldplan .behave_as_button {
    font-size: 16px;
  }

  .spec_oldplan .behave_as_button small {
    padding-right: 16px;
    font-size: 14px;
    line-height: 12px;
  }
}

/* OS （/specification/os）の固有要素
 * ---------------------------------------- */
.spec_os {
  padding-bottom: 160px;
}

.provided_label {
  display: inline-block;
  padding: 4px;
  border-radius: 4px;
  background: #ffdfdf;
  color: #f00;
  font-size: 12px;
  font-weight: normal;
}

.line_button_list {
  display: flex;
  justify-content: space-evenly;
}

.line_button_list li {
  width: 48%;
  max-width: 320px;
}

.wrap_os_table .notice {
  margin: 0 0 40px;
}

.wrap_windows_table {
  overflow-x: scroll;
  width: 100%;
}

@media (max-width: 960px) {
  .spec_os {
    padding-bottom: 40px;
  }

  .wrap_os_table {
    position: relative;
  }

  .wrap_windows_table .usual_table {
    width: 960px;
  }
}

/* リージョン/ゾーン （/specification/region）の固有要素
 * ---------------------------------------- */
.spec_region {
  padding-bottom: 160px;
}

.spec_region .notice_list {
  position: relative;
  left: 15%;
}

@media (max-width: 960px) {
  .spec_region_image01 img,
  .spec_region_image02 img {
    width: 100%;
  }
  .spec_region .notice_list {
    left: 0;
  }
}

/* 保守：コンソール （/specification/console）の固有要素
 * ---------------------------------------- */
.mail_template {
  display: flex;
  flex-wrap: wrap;
}

.mail_template dt {
  width: 48px;
  margin: 8px 0;
  border-radius: 4px;
  background-color: #e8f2ff;
  font-weight: bold;
  text-align: center;
  line-height: 32px;
}

.mail_template dd {
  width: calc(100% - 48px);
  margin: 8px 0;
  padding: 0 8px;
  line-height: 32px;
}

.mail_template .body_text {
  width: 100%;
  padding: 0;
}

.mail_template .template_copy {
  display: block;
  width: 176px;
  height: 32px;
  margin: 8px 0;
  border: 1px solid #000;
  border-radius: 4px;
  background-color: #fff;
  cursor: pointer;
}

.mail_template .template_text {
  display: block;
  width: 100%;
  max-width: 744px;
  min-height: 208px;
  padding: 8px 16px;
}

@media (max-width: 960px) {
  .spec_console_flow01 img {
    width: 100%;
  }

  .spec_console_flow02 img {
    width: 100%;
    max-width: 420px;
  }
}

/* 保守：機器リブート （/specification/reboot）の固有要素
 * ---------------------------------------- */
.info_request_reboot h5 {
  margin: 24px 0 8px;
  font-size: 16px;
}

@media (max-width: 960px) {
  .spec_reboot_flow01 img {
    width: 100%;
  }
}

/* アプライアンス （/specification/fw）の固有要素
 * ---------------------------------------- */
@media (max-width: 960px) {
  .spec_appliance_fw img,
  .spec_appliance_lb img {
    width: 100%;
  }
}

/* ネットワーク （/specification/network）の固有要素
 * ---------------------------------------- */
.spec_network {
  padding-bottom: 160px;
}

.spec_network_featurelist li {
  display: flex;
  min-height: 156px;
  margin-top: 40px;
}

.spec_network_featurelist .notice {
  margin-bottom: 0;
}

.network_feature_image {
  flex: 0 0 216px;
}

.spec_network_featurelist dt {
  display: flex;
  font-size: 28px;
  font-weight: bold;
  align-items: center;
  line-height: 32px;
}

.label_paid {
  display: inline-block;
  margin-left: 8px;
  padding: 0 8px;
  border: 1px solid #f60;
  border-radius: 4px;
  color: #f60;
  font-size: 14px;
  font-weight: bold;
  line-height: 32px;
}

@media (max-width: 960px) {
  .spec_network_featurelist li {
    flex-direction: column;
  }

  .spec_network_featurelist dt {
    display: block;
  }
}

/* WAF （/specification/waf）の固有要素
 * ---------------------------------------- */
@media (max-width: 960px) {
  .spec_waf_image img {
    width: 100%;
  }
}

/* WAF （/specification/gn）の固有要素
 * ---------------------------------------- */
.spec_gn {
  padding-bottom: 160px;
}

@media (max-width: 960px) {
  .spec_gn_image01 img,
  .spec_gn_image02 img {
    width: 100%;
  }

  .spec_gn {
    padding-bottom: 40px;
  }
}

/* サービス保守とSLAについて：サーバー機器の故障についての固有要素
 * ---------------------------------------- */

.spec_maintenance_lifecycle img {
  max-width: 100%;
}


/* 主な特長（/feature）
 * ======================================== ======================================== */

/* 主な特長（/feature）の最初の４つの定義リスト
 * ---------------------------------------- */
.feature_topics_list li {
  display: flex;
  min-height: 320px;
  margin: 32px 0;
  padding: 24px 0;
}

.feature_topics_list .topics_image {
  padding-right: 16px;
}

.feature_topics_list dt {
  margin: 0 0 16px;
  color: #1e51ae;
  font-size: 30px;
  font-weight: bold;
}

.feature_topics_list dd {
  margin: 16px 0 24px;
}

.feature_topics_list .detail_link .behave_as_button {
  margin-right: 0;
}

@media (max-width: 960px) {
  .feature_topics_list {
    margin-bottom: 72px;
  }

  .feature_topics_list li {
    padding: 24px 0 0;
    flex-direction: column;
  }

  .feature_topics_list .topics_image img {
    width: 50%;
    padding-bottom: 24px;
  }

  .feature_topics_list dt {
    font-size: 26px;
  }

  .feature_topics_list .detail_link .behave_as_button {
    margin-right: auto;
  }
}

/* 主な特長（/feature）の2つ目のセクションの定義リスト
 * ---------------------------------------- */
.feature_basic {
  padding: 80px 0;
  background-color: #e8f2ff;
  background-image: url(../images/common/common_wp_01.png);
}

.feature_basic_list > li {
  display: flex;
  min-height: 160px;
  margin-bottom: 24px;
  padding: 16px 24px;
  border-radius: 5px;
  background-color: #fff;
  background-repeat: no-repeat;
  background-position: 40px 50%;
  box-shadow: 0 4px 2px 2px rgba(0, 0, 0, 0.1);
}

.feature_basic_list > li:last-child {
  margin-bottom: 0;
}

.basic_image {
  display: flex;
  align-items: center;
  flex: 0 0 96px;
}

.basic_image img {
  display: block;
}

.feature_basic_list dt {
  margin-bottom: 8px;
  color: #1d51ad;
  font-size: 24px;
  font-weight: bold;
}

.feature_basic_list .detail_link {
  margin-top: 16px;
}

.feature_basic_list .detail_link::after {
  content: ">";
  display: inline-block;
  margin-left: 16px;
  color: #1d51ad;
  font-weight: bold;
}

@media (max-width: 960px) {
  .feature_basic_list li {
    background-image: none;
  }

  .basic_image {
    display: none;
  }

  .feature_basic_list dl {
    margin-left: 0;
    width: 100%;
  }

  .feature_basic_list dt {
    margin: 8px 0 16px;
    padding-left: 40px;
    background-repeat: no-repeat;
    background-size: contain;
  }

  .basic_server dt {
    background-image: url(../images/feature/feature_05_basic_server.png);
  }

  .basic_appliance dt {
    background-image: url(../images/feature/feature_06_basic_appliance.png);
  }

  .basic_oslineup dt {
    background-image: url(../images/feature/feature_07_basic_oslineup.png);
  }

  .basic_network dt {
    background-image: url(../images/feature/feature_08_basic_network.png);
  }

  .feature_basic_list dd {
    font-size: 14px;
    line-height: 24px;
  }

  .feature_basic_list .detail_link {
    text-align: right;
  }
}

/* 主な特長（/feature）の３つ目のセクション
 * ---------------------------------------- */
.feature_hosting {
  padding: 120px 0;
  background-image: url(../images/feature/feature_09_feature_hosting.png);
  background-repeat: no-repeat;
  background-position: 0 50%;
}

.view_as_full {
  max-width: 536px;
  width: 100%;
  margin: 0 0 0 auto;
}

.view_as_full h1 {
  margin: 24px 0;
  height: 100%;
  font-size: 45px;
  text-align: left;
}

.view_as_full .behave_as_button {
  margin-top: 32px;
}

@media (max-width: 960px) {
  .feature_hosting {
    padding: 60px 0;
    background-position: -40px 40px;
    background-size: auto 45%;
  }

  .view_as_full {
    font-size: 14px;
  }

  .view_as_full h1 {
    margin-top: 380px;
    font-size: 32px;
    line-height: 40px;
  }
}

/* 主な特長（/feature）の4つ目のセクション
 * ---------------------------------------- */
.feature_controlpannel {
  position: relative;
  padding: 120px 0;
  background-color: #d8e9ff;
  background-image: url(../images/feature/feature_11_feature_controlpannel.png);
  background-repeat: no-repeat;
  background-size: contain;
}

.feature_controlpannel::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 590px;
  height: 579px;
  margin: auto;
  background-image: url(../images/feature/feature_10_feature_controlpannel.png);
}

.feature_controlpannel .view_as_full {
  margin: 0 auto 96px 0;
}

@media (max-width: 960px) {
  .feature_controlpannel {
    padding: 60px 0;
  }

  .feature_controlpannel::before {
    width: calc(100% - 24px);
    height: 352px;
    top: 60px;
    left: 24px;
    right: auto;
    bottom: auto;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: right;
  }
}

/* 構成例（/case）
 * ======================================== ======================================== */

.case_example {
  padding: 40px 0 80px;
}

.case_1st {
  padding: 0 0 80px;
}

.case_2nd {
  background-image: url(../images/common/common_wp_01.png);
}

.case_3rd {
  padding: 40px 0 160px;
}

.case_example h2 {
  margin: 40px 0;
}

.case_example h4 {
  margin: 40px 0 16px;
}

.case_example .lead_text {
  font-size: 28px;
  font-weight: bold;
  line-height: 40px;
}

.case_image {
  padding: 24px;
  border: 4px solid #e8f2ff;
  border-radius: 4px;
  background-color: #fff;
}

.case_flow_list {
  display: flex;
  justify-content: space-between;
  margin: 32px 0;
}

.case_flow_list > li {
  max-width: 450px;
  width: 50%;
}

.case_flow_list dl {
  width: 100%;
  padding: 24px;
}

.case_flow_list dt {
  font-size: 22px;
  font-weight: bold;
}

.case_flow_list .usual_list {
  margin: 16px 0 0;
}

.case_problem {
  position: relative;
  background-color: #f1f1f1;
}

.case_problem::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  position: absolute;
  top: 0;
  bottom: 0;
  right: -64px;
  margin: auto;
  border-width: 22.5px 20px;
  border-color: transparent;
  border-style: solid;
  border-left-color: #0a52ad;
}

.case_solution {
  background-color: #e8f2ff;
}

.case_2nd .case_solution {
  background-color: #fff;
}

.case_usefunction_list li {
  display: inline-block;
  padding: 8px 16px;
  border: 2px solid #3783e4;
  border-radius: 4px;
  background: #fff;
}

@media (max-width: 960px) {
  .case_flow_list {
    flex-direction: column;
    align-items: center;
  }

  .case_flow_list > li {
    width: 100%;
  }

  .case_problem {
    margin-bottom: 64px;
  }

  .case_problem::after {
    right: 0;
    left: 0;
    top: auto;
    bottom: -64px;
    border-width: 20px 22.5px;
    border-color: transparent;
    border-top-color: #0a52ad;
  }

  .case_image img {
    width: 100%;
  }

  .case_usefunction_list li {
    margin-bottom: 8px;
    font-size: 12px;
  }
}

/* footer
 * ======================================== */
.phy_footer {
  height: 272px;
  color: #fff;
  background-color: #3365a6;
  background-image: url(../images/common/common_wp_02.png);
}

.phy_footer .phy_inner {
  max-width: 1366px;
  padding: 40px 0;
  background-position: 156px 16px;
  background-repeat: no-repeat;

}

.phy_boxcel_customer {
  max-width: 960px;
  width: 100%;
  margin: auto;
  text-align: center;
  position: relative;
  z-index: 1;
}

.phy_boxcel_customer::before {
  background-image: url(../images/common/footer_01.png);
  display: block;
  width: 218px;
  height: 252px;
  position: absolute;
  left: -70px;
  bottom: -70px;
  content: "";
  z-index: -1;
}

.phy_boxcel_customer::after {
  background-image: url(../images/common/footer_dog_cat.png);
  display: block;
  width: 171px;
  height: 135px;
  position: absolute;
  right: 0;
  bottom: -60px;
  content: "";
  z-index: -1;
}

.phy_footer h2 {
  margin: 0 0 10px 0;
  padding: 0;
  background: none;
  color: #fff;
  font-size: 24px;
  line-height: 100%;
}

.phy_footer .lead_text {
  margin: 0;
  font-size: 18px;
}

.customer_infomation {
  display: flex;
  justify-content: space-between;
  margin: 24px 0 0 0;
}

.customer_infomation li {
  max-width: 352px;
  width: 100%;
  max-height: 88px;
  border-radius: 4px;
  margin:0 auto;
}

.customer_mail_form {
  background: #fff;
}

.customer_mail_form a {
  display: block;
  border-radius: 4px;
  color: #003071;
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  line-height: 88px;
  transition: all 0.3s ease 0s;
}

.customer_mail_form a:hover {
  background-color: #003071;
  color: #fff;
}

@media (max-width: 960px) {
  .phy_footer {
    height: auto;
  }

  .phy_footer .phy_inner {
    padding: 40px 10px;
    background-image: none;
  }

  .phy_boxcel_customer::before,
  .phy_boxcel_customer::after {
    display: none;
  }

  .phy_footer h2 {
    padding: 0;
    font-size: 18px;
  }

  .phy_footer .lead_text {
    margin: 16px 0;
    font-size: 14px;
  }

  .phy_footer img {
    width: 100%;
  }

  .customer_infomation {
    margin: 0;
    flex-direction: column;
    align-items: center;
  }

  .customer_call_number {
    margin-bottom: 16px;
  }
}
@media (max-width: 767px) {
  .phy_footer .lead_text {
    text-align: left;
  }
}