@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700;900&display=swap");
h2 {
  color: #0095A1;
}

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

i.eo {
  font-size: 1.4em;
  font-style: normal;
  font-weight: 500;
}

.container {
  width: 100%;
  max-width: 100rem;
  margin: 0 auto;
}

.link_orange {
  color: #fb5000;
  text-decoration: underline;
}

main {
  text-align: justify;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}

span.symbol_caption {
  display: block;
  text-align: right;
  color: #0095A1;
  font-size: 1.4rem;
  font-weight: normal;
}

.full {
  width: 100%;
}

.txt_left {
  text-align: left;
}

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

.green_box {
  border: 2px solid #0095A1;
  padding: 0 0 1rem;
  background: #ffffff;
}

.green_box > *:first-child {
  margin-top: 0 !important;
}

.green_box p {
  width: 90% !important;
}

hr.dot {
  border-top: 2px dotted;
  margin: 3rem auto;
}

h3.white {
  background-color: #ffffff;
  border: 2px solid #0095A1;
  color: #0095A1;
  font-size: 2.8rem;
  padding: 1rem 0;
  margin-top: 6rem;
}

a.ext::after {
  content: "";
  display: inline-block;
  vertical-align: baseline;
  width: 1.4rem;
  height: 1.4rem;
  background: url("../img/ext_link.svg") no-repeat center center;
  background-size: contain;
  margin-left: 0.5rem;
}

.video-js.vjs-fluid,
.video-js.vjs-16-9,
.video-js.vjs-4-3 {
  padding-top: 56.25%;
}

p.backlink {
  text-align: center !important;
  margin-top: 4rem;
}

p.backlink a {
  display: inline-block;
  border: 2px solid;
  color: #0095A1;
  font-weight: bold;
  padding: 0.5rem 1.5rem;
  border-radius: 4px;
}
.breadcrumb {
  background: #ffffff;
  padding: 1px 0;
}

.breadcrumb ul {
  max-width: 100rem;
  margin: 0.5em auto;
}
.breadcrumb ul li {
  display: inline;
}
.breadcrumb ul li a {
  text-decoration: underline;
}
.breadcrumb ul li a, .breadcrumb ul li p {
  display: inline;
}
@media screen and (max-width: 767px) {
  img {
    width: 100%;
  }
  span.caption {
    text-align: left !important;
  }
  header {
    height: auto;
    position: fixed;
    top: 0;
    font-family: "Noto Sans JP", "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
  }
  header .container {
    height: 7rem;
    padding: 1rem;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  header .container p.title {
    margin: 0;
    color: #0095A1;
    font-weight: bold;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
  header .container p.title .logo {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 0 0.5rem 0 0;
    padding: 0;
  }
  header .container p.title .logo img {
    width: auto;
    height: 5rem;
  }
  header .container p.title span {
    font-size: 1.2rem;
    font-weight: 700;
  }
  header .container .menu {
    display: block;
  }
  header .container .menu svg {
    width: 2.5rem;
    height: 2rem;
  }
  main {
    font-family: "Noto Sans JP", "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
    margin-top: 7.5rem;
  }
  main .global_nav {
    width: 100%;
    position: fixed;
    top: 7.5rem;
    background-color: #ffffff;
    border-top: 5px solid #0095A1;
    border-bottom: 5px solid #0095A1;
    display: none;
    z-index: 99;
    -webkit-box-shadow: 0 0 8px rgba(56, 41, 41, 0.2);
            box-shadow: 0 0 8px rgba(56, 41, 41, 0.2);
  }
  main .global_nav ul li {
    border-bottom: 1px solid rgba(0, 0, 0, 0.5);
  }
  main .global_nav ul li a {
    border-top: 1px solid rgba(255, 255, 255, 0.5);
    display: block;
    padding: 1rem 0;
    background-color: #0095A1;
    color: #ffffff;
    text-align: center;
  }
  main .global_nav ul li a.ext::after {
    content: "";
    display: inline-block;
    vertical-align: baseline;
    width: 1.4rem;
    height: 1.4rem;
    background: url("../img/ext_link_sp.svg") no-repeat center center;
    background-size: contain;
    margin-left: 0.5rem;
  }
  main .global_nav ul li.current a {
    background-color: #ffffff;
    color: #0095A1;
  }
  main #mv {
    background: #ffffff;
  }
  main #mv .container {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
  }
  main #mv .container a {
    display: block;
  }
  main #mv .container .button {
    width: 50%;
  }
  main #mv .swiper {
    width: 100%;
    overflow: hidden;
    position: relative;
  }
  main #mv .swiper-button-next,
  main #mv .swiper-button-prev {
    top: 60%;
    width: 27px;
  }
  main #mv .swiper-button-next:after,
  main #mv .swiper-button-prev:after {
    font-size: 3rem;
    color: #000000;
  }
  main #mv .swiper-pagination {
    text-align: right;
    padding-right: 2rem;
  }
  main #mv .swiper-pagination-bullet {
    border-radius: 0;
    border: 1px solid #0095A1;
    background: #ffffff;
    opacity: 1;
  }
  main #mv .swiper-pagination-bullet-active {
    background: #0095A1;
  }
  main #mv .note {
    background-color: #f1f1f1;
    padding: 0.5rem 1rem;
  }
  main #mv .note .container {
    height: auto;
  }
  main #mv .note .container p {
    text-align: justify;
    font-size: 0.85em;
  }
  main #lead,
  main #lead2 {
    background-color: #f1f1f1;
  }
  main #lead .container,
  main #lead2 .container {
    padding: 4rem 0;
  }
  main #lead .container .banner-case,
  main #lead2 .container .banner-case {
    display: block;
    height: auto;
    background: url("../img/banner_case.jpg") no-repeat right top;
    background-size: contain;
    position: relative;
    padding: 19rem 2rem 2rem;
    margin-bottom: 8rem;
  }
  main #lead .container .banner-case::before,
  main #lead2 .container .banner-case::before {
    background: #0095a1;
    content: "";
    width: 100%;
    height: 30rem;
    position: absolute;
    top: 17rem;
    left: 0;
    z-index: 0;
  }
  main #lead .container .banner-case *,
  main #lead2 .container .banner-case * {
    position: relative;
    z-index: 1;
  }
  main #lead .container .banner-case p,
  main #lead2 .container .banner-case p {
    text-align: center;
  }
  main #lead .container .banner-case p.banner-title,
  main #lead2 .container .banner-case p.banner-title {
    width: 90%;
    font-size: 2.4rem;
    font-weight: 700;
    color: #FFE100;
    border: 2px solid;
    margin: 0 auto 2rem;
    padding: 0.5rem 0 0;
  }
  main #lead .container .banner-case p.banner-desc,
  main #lead2 .container .banner-case p.banner-desc {
    width: 90%;
    color: #ffffff;
    font-size: 1.4rem;
    font-weight: 700;
    line-height: 2;
    margin: 0 auto 2rem;
  }
  main #lead .container .banner-case p.button,
  main #lead2 .container .banner-case p.button {
    width: 15rem;
    margin: 0 auto;
  }
  main #lead .container h2,
  main #lead2 .container h2 {
    text-align: center;
    margin-bottom: 2.8rem;
  }
  main #lead .container h2 img,
  main #lead2 .container h2 img {
    width: 32.2rem;
  }
  main #lead .container .img,
  main #lead2 .container .img {
    width: 23.8rem;
    margin: 0 auto 2.4rem;
  }
  main #lead .container .txt,
  main #lead2 .container .txt {
    width: 34rem;
    margin: 0 auto;
  }
  main #lead .container .full,
  main #lead2 .container .full {
    width: 34rem;
    margin: 0.5rem auto 0;
  }
  main #lead2 .container .banner-case {
    margin-bottom: 0;
  }
  main #link_panel .container {
    padding: 4rem 0;
  }
  main #link_panel .container h2 {
    text-align: center;
    margin-bottom: 4rem;
    width: 32.2rem;
    margin-left: auto;
    margin-right: auto;
  }
  main #link_panel .container .link {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    padding: 0 2%;
  }
  main #link_panel .container .link li {
    margin-bottom: 3rem;
    width: 48%;
  }
  main #link_panel .container .link li a {
    display: block;
    width: 100%;
  }
  main #link_panel .container .link li a img {
    width: 100%;
  }
  main #option {
    background-color: #f1f1f1;
  }
  main #option .container {
    padding: 4rem 0;
  }
  main #option .container h2 {
    text-align: center;
    margin-bottom: 1.6rem;
    font-size: 1.8rem;
    font-weight: 700;
    color: #000000;
  }
  main #option .container .body {
    width: 33rem;
    margin: 0 auto 3rem;
  }
  main #option .container .option_panel {
    position: relative;
    text-align: center;
    width: 36rem;
    margin: 0 auto;
  }
  main #option .container .option_panel .option_camera,
  main #option .container .option_panel .option_iot {
    position: absolute;
    width: 33rem;
    margin: auto;
    left: 0;
    right: 0;
  }
  main #option .container .option_panel .option_camera p + p,
  main #option .container .option_panel .option_iot p + p {
    width: 40%;
    margin: 0.5rem 0 0 auto;
  }
  main #option .container .option_panel .option_camera {
    top: 22.72rem;
  }
  main #option .container .option_panel .option_iot {
    top: 39.9rem;
  }
  main #contact {
    background-color: #0095A1;
    position: -webkit-sticky;
    position: sticky;
    bottom: -6rem;
    z-index: 100;
  }
  main #contact.for_fix {
    bottom: -19.1rem;
  }
  main #contact #btn_pagetop {
    display: block;
    width: 5rem;
    height: 5rem;
    background: url("../img/btn_pagetop.svg") no-repeat center center;
    background-size: contain;
    -webkit-box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4);
            box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4);
    border-radius: 50%;
    position: absolute;
    top: -7rem;
    left: 3rem;
    display: none;
  }
  main #contact .container {
    padding: 1rem 3rem 7rem 3rem;
  }
  main #contact .container p.tel {
    margin-bottom: 1.8rem;
  }
  #contact_fixed {
    width: 72%;
    position: fixed;
    bottom: 1rem;
    right: 0;
    z-index: 99;
    -webkit-transition: 0.5s;
    transition: 0.5s;
  }
  #contact_fixed.hide {
    right: -100%;
  }
  #banner-faq .container {
    padding: 0 3rem 8rem;
  }
}

@media screen and (max-width: 374px) {
  :root {
    font-size: 2.66666vw;
  }
}

@media screen and (min-width: 768px) {
  :root {
    font-size: 1vw;
  }
  body {
    min-height: 100vh;
  }
  a {
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  a:hover {
    opacity: 0.75;
  }
  img {
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
  }
  header {
    height: auto;
    position: static;
  }
  header .container {
    height: 8rem;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
  header .container .title {
    color: #0095A1;
    font-weight: bold;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
  header .container .title .logo {
    margin-right: 2.6rem;
    padding: 0;
  }
  header .container .title span {
    font-size: 1.6rem;
    font-weight: 700;
  }
  header .container .aside_link {
    text-align: right;
  }
  header .container .aside_link li {
    font-size: 1.6rem;
  }
  header .container .aside_link li a {
    color: #0095A1;
  }
  header .container .aside_link li:first-of-type {
    font-size: 1.4rem;
  }
  header .container .aside_link li:first-of-type a {
    color: #000000;
  }
  main {
    min-height: 100vh;
  }
  main .global_nav {
    background-color: #0095A1;
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    z-index: 99;
  }
  main .global_nav ul {
    width: 100%;
    max-width: 100rem;
    height: 4rem;
    margin: 0 auto;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    font-size: 1.4rem;
  }
  main .global_nav ul li {
    color: #ffffff;
    padding: 0 0.6rem;
  }
  main .global_nav ul li + li {
    border-left: 1px solid;
  }
  main .global_nav ul li a {
    color: #ffffff;
    display: block;
    padding: 0.3rem 1rem 0;
    font-size: 1.2rem;
  }
  main .global_nav ul li.large {
    font-size: 1.4rem;
    font-weight: bold;
  }
  main .global_nav ul li.current a {
    background-color: #ffffff;
    color: #0095A1;
    border-radius: 4px;
  }
  main #mv .container {
    height: 50rem;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    margin-top: 2rem;
  }
  main #mv .container .button {
    height: 50%;
  }
  main #mv .swiper {
    width: 77rem;
    height: 50rem;
    position: relative;
    overflow: hidden;
  }
  main #mv .swiper-button-next, main #mv .swiper-button-prev {
    width: 24px;
  }
  main #mv .swiper-button-next:after, main #mv .swiper-button-prev:after {
    font-size: 3rem;
    color: #999999;
  }
  main #mv .swiper-pagination {
    text-align: right;
    padding-right: 2rem;
  }
  main #mv .swiper-pagination-bullet {
    border-radius: 0;
    border: 1px solid #0095A1;
    background: #ffffff;
    opacity: 1;
  }
  main #mv .swiper-pagination-bullet-active {
    background: #0095A1;
  }
  main #mv .note {
    background-color: #f1f1f1;
    padding: 0.5rem 0;
  }
  main #mv .note .container {
    height: auto;
    margin-top: 0;
  }
  main #mv .note .container p {
    text-align: left;
    font-size: 0.85em;
  }
  main #lead, main #lead2 {
    background-color: #f1f1f1;
  }
  main #lead .container, main #lead2 .container {
    padding: 6rem 0;
    height: auto;
  }
  main #lead .container .banner-case, main #lead2 .container .banner-case {
    display: block;
    height: 32rem;
    background: url("../img/banner_case.jpg") no-repeat right top;
    background-size: contain;
    position: relative;
    padding: 4rem 7rem;
    margin-bottom: 8rem;
  }
  main #lead .container .banner-case::before, main #lead2 .container .banner-case::before {
    background: #0095a1;
    background: -webkit-gradient(linear, left top, right top, from(#0095a1), color-stop(40%, #0095a1), color-stop(75%, rgba(0, 149, 161, 0)));
    background: -webkit-linear-gradient(left, #0095a1 0%, #0095a1 40%, rgba(0, 149, 161, 0) 75%);
    background: linear-gradient(90deg, #0095a1 0%, #0095a1 40%, rgba(0, 149, 161, 0) 75%);
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
  }
  main #lead .container .banner-case *, main #lead2 .container .banner-case * {
    position: relative;
    z-index: 1;
  }
  main #lead .container .banner-case p, main #lead2 .container .banner-case p {
    text-align: center;
  }
  main #lead .container .banner-case p.banner-title, main #lead2 .container .banner-case p.banner-title {
    width: 34rem;
    font-size: 3rem;
    font-weight: 700;
    color: #FFE100;
    border: 2px solid;
    margin-bottom: 3rem;
    padding: 0.5rem 0 0;
  }
  main #lead .container .banner-case p.banner-desc, main #lead2 .container .banner-case p.banner-desc {
    width: 34rem;
    color: #ffffff;
    font-size: 1.4rem;
    font-weight: 700;
    line-height: 2;
  }
  main #lead .container .banner-case p.button, main #lead2 .container .banner-case p.button {
    width: 15rem;
    position: absolute;
    bottom: 2rem;
    right: 2rem;
  }
  main #lead .container h2, main #lead2 .container h2 {
    margin-bottom: 4rem;
    text-align: center;
  }
  main #lead .container .body, main #lead2 .container .body {
    width: 84rem;
    margin: 0 auto;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
  }
  main #lead .container .body .img, main #lead2 .container .body .img {
    -webkit-flex-shrink: 0;
        -ms-flex-negative: 0;
            flex-shrink: 0;
    width: 18%;
  }
  main #lead .container .body .txt, main #lead2 .container .body .txt {
    line-height: 2;
    width: 80%;
  }
  main #link_panel .container {
    padding: 6rem 0;
  }
  main #link_panel .container h2 {
    text-align: center;
    margin-bottom: 5rem;
    width: 66rem;
    margin-left: auto;
    margin-right: auto;
  }
  main #link_panel .container .link {
    width: 75rem;
    margin: 0 auto;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  main #link_panel .container .link li {
    width: 32.5rem;
    text-align: center;
    margin-bottom: 6rem;
  }
  main #link_panel .container .link li h3 {
    font-size: 3.5rem;
    font-weight: bold;
    color: #0095A1;
    line-height: 1.5;
  }
  main #link_panel .container .link li a {
    display: block;
  }
  main #link_panel .container .link li a p {
    font-size: 2.1rem;
    line-height: 1.4;
    margin-top: 0.5rem;
  }
  main #option {
    background-color: #f1f1f1;
    padding-bottom: 1.5rem;
  }
  main #option .container {
    padding: 6rem 0;
  }
  main #option .container h2 {
    text-align: center;
    margin-bottom: 4rem;
    font-weight: bold;
  }
  main #option .container p.body {
    width: 65rem;
    margin: 0 auto 4rem;
  }
  main #option .container .option_panel {
    width: 96.7rem;
    margin: 0 auto;
    position: relative;
  }
  main #option .container .option_panel .option_camera,
  main #option .container .option_panel .option_iot {
    position: absolute;
    text-align: right;
  }
  main #option .container .option_panel .option_camera p.img,
  main #option .container .option_panel .option_iot p.img {
    margin-bottom: 0;
  }
  main #option .container .option_panel .option_camera p + p,
  main #option .container .option_panel .option_iot p + p {
    margin-top: 0.5rem;
    margin-bottom: 0;
  }
  main #option .container .option_panel .option_camera {
    top: 5.9rem;
    right: 5.1rem;
  }
  main #option .container .option_panel .option_iot {
    top: 47.1rem;
    left: 9.1rem;
    margin: auto;
  }
  main #banner-faq {
    padding-bottom: 4rem;
  }
  main #banner-faq .container {
    padding: 2rem 0 0;
  }
  main #banner-faq .container p {
    text-align: center;
  }
  main #banner-faq .container p a {
    display: inline-block;
    width: 54.8rem;
  }
  main #contact {
    background-color: #0095A1;
    position: -webkit-sticky;
    position: sticky;
    bottom: 0;
    z-index: 99;
  }
  main #contact #btn_pagetop {
    display: block;
    width: 5rem;
    height: 5rem;
    background: url("../img/btn_pagetop.svg") no-repeat center center;
    background-size: contain;
    -webkit-box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4);
            box-shadow: 0 3px 4px rgba(0, 0, 0, 0.4);
    border-radius: 50%;
    position: absolute;
    top: -6rem;
    left: 3rem;
    display: none;
  }
  main #contact .container {
    padding: 1rem 0;
    width: 96rem;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
  main #contact .container p.form {
    height: 5rem;
  }
  .for_sp {
    display: none !important;
  }
}

@media screen and (min-width: 1001px) {
  :root {
    font-size: 10px;
  }
}

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

@media screen and (max-width: 767px) {
  main.subPage section {
    text-align: center;
  }
  main.subPage section:nth-of-type(2n) {
    background-color: #f1f1f1;
  }
  main.subPage section .container {
    padding: 3rem 1.5rem;
  }
  main.subPage section .container p.head {
    margin: 3rem auto;
    width: 10rem;
  }
  main.subPage.inv section:nth-of-type(2n) {
    background-color: #ffffff;
  }
  main.subPage.inv section:nth-of-type(2n + 1) {
    background-color: #f1f1f1;
  }
  main.subPage h2,
  main.subPage h3 {
    margin-bottom: 3rem;
    font-weight: 900;
    font-size: 2rem;
  }
  main.subPage h2 {
    font-size: 2rem;
  }
  main.subPage h2.inv_green {
    background: #0095A1;
    color: #ffffff;
    padding: 1rem 0;
  }
  main.subPage h3.white {
    background-color: #ffffff;
    border: 2px solid #0095A1;
    color: #0095A1;
    font-size: 1.8rem;
    padding: 1rem 0;
  }
  main.subPage h3.cb_green {
    color: #0095A1;
    border: 1px solid #0095A1;
    line-height: 3;
    margin-bottom: 3rem;
    font-size: 1.8rem;
  }
  main.subPage span.icon_green {
    display: inline-block;
    font-size: 0.8em;
    color: #ffffff;
    text-align: center;
    background-color: #0095A1;
    padding: 0.1em 0.5em;
    font-weight: 500;
  }
  main.subPage .bg_green {
    color: #ffffff;
    background-color: #0095A1;
    margin: 3rem auto;
    padding: 1rem 0;
    font-size: 1.6rem;
  }
  main.subPage .txt_green {
    color: #0095A1;
  }
  main.subPage .txt_yellow {
    color: #FFE100;
  }
  main.subPage p {
    margin-bottom: 2rem;
    text-align: justify;
    font-size: 1.4rem;
  }
  main.subPage p .caption {
    font-size: 0.85em;
    display: block;
    text-align: right;
  }
  main.subPage p.lead {
    font-size: 1.8rem;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
  }
  main.subPage p.lead_l {
    font-size: 1.8rem;
  }
  main.subPage p.img {
    margin: auto auto 2rem;
    width: auto;
  }
  main.subPage p.img .caption {
    display: block;
    text-align: justify;
    font-size: 1rem;
  }
  main.subPage img.small {
    width: 75%;
  }
  main.subPage img.half {
    width: 50%;
  }
  main.subPage .txt-left {
    text-align: left !important;
  }
  main.subPage .txt-right {
    text-align: right !important;
  }
  main.subPage .img-right {
    margin: 0 0 0 auto;
  }
  main.subPage strong {
    color: #0095A1;
  }
  main.subPage .txt_green {
    color: #0095A1;
  }
  main.subPage h4.iot_scene_head {
    font-size: 2rem;
    color: #0095A1;
    margin-bottom: 1.5rem;
  }
  main.subPage h4.iot_scene_head span {
    display: block;
    margin: auto auto 2rem;
    height: 3rem;
  }
  main.subPage .flex {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
  main.subPage .flex > img {
    width: 48%;
  }
  main.subPage .flex.three > * {
    width: 31%;
  }
  main.subPage .flex.mb-column {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  main.subPage .flex.mb-column-r {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: column-reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
  main.subPage .w700 {
    width: 100%;
  }
  main.subPage .w900 {
    width: 100%;
  }
  main.subPage .w920 {
    width: 100%;
  }
  main.subPage .movie_index {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-bottom: 3rem;
  }
  main.subPage .movie_index li {
    width: 36.3rem;
    margin-bottom: 2rem;
  }
  main.subPage .movie_index li h4 {
    background: #0095A1;
    color: #ffffff;
  }
  main.subPage .movie_index li a {
    display: block;
    margin-bottom: 1rem;
    border: 1px solid #999999;
  }
  main.subPage .video_homelink {
    display: block;
    margin: 0 auto 1rem;
  }
  main.subPage .point_box {
    border: 1px solid #FFE100;
    margin-bottom: 2rem;
  }
  main.subPage .point_box .head {
    background-color: #FFE100;
    padding: 1rem;
  }
  main.subPage .point_box .head h3 {
    font-size: 1.6rem;
    color: #0095A1;
    margin-bottom: 0;
  }
  main.subPage .point_box .body {
    padding: 1.5rem;
  }
  main.subPage .point_box .body p {
    text-align: left;
  }
  main.subPage .point_box .body p.img {
    text-align: center;
  }
  main.subPage .point_box .body p:last-child {
    margin-bottom: 0;
  }
  main.subPage .point_box .body .sub_box {
    background-color: rgba(0, 147, 159, 0.1);
    padding: 2.5rem 2.5rem 1rem;
  }
  main.subPage .homelink_wrap {
    background-color: #ffffff;
    padding: 0;
  }
  main.subPage .homelink_wrap ul#tab-index {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    position: -webkit-sticky;
    position: sticky;
    top: 7rem;
    z-index: 99;
  }
  main.subPage .homelink_wrap ul#tab-index li {
    width: 50%;
    background: #ffffff;
  }
  main.subPage .homelink_wrap ul#tab-index li a {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    width: 100%;
    height: 4.5em;
    text-align: center;
    font-size: 1.5rem;
    padding: 1rem 0;
    position: relative;
    cursor: pointer;
    opacity: .4;
  }
  main.subPage .homelink_wrap ul#tab-index li a.on {
    opacity: 1;
  }
  main.subPage .homelink_wrap ul#tab-index li a::after {
    display: block;
    height: 0;
    width: 0;
    border-top: 2rem solid;
    border-left: 1.2rem solid transparent;
    border-right: 1.2rem solid transparent;
    position: absolute;
    bottom: -1.8rem;
    left: 0;
    right: 0;
    margin: auto;
  }
  main.subPage .homelink_wrap ul#tab-index li a[data-href$="general"] {
    background: #FFE100;
  }
  main.subPage .homelink_wrap ul#tab-index li a[data-href$="general"].on::after {
    content: "";
    border-top-color: #FFE100;
  }
  main.subPage .homelink_wrap ul#tab-index li a[data-href$="whole"] {
    background: #0095A1;
    color: #ffffff;
  }
  main.subPage .homelink_wrap ul#tab-index li a[data-href$="whole"].on::after {
    content: "";
    border-top-color: #0095A1;
  }
  main.subPage .homelink_wrap #tab-general,
  main.subPage .homelink_wrap #tab-whole {
    display: none;
  }
  main.subPage .homelink_wrap #tab-general.on,
  main.subPage .homelink_wrap #tab-whole.on {
    display: block;
  }
  main.subPage .homelink_wrap #tab-general .yellow-box,
  main.subPage .homelink_wrap #tab-whole .yellow-box {
    background: rgba(255, 255, 0, 0.2);
    border: 2px solid #FFE100;
    padding: 4rem 2rem;
  }
  main.subPage .homelink_wrap #tab-general .green-box,
  main.subPage .homelink_wrap #tab-whole .green-box {
    background: rgba(0, 147, 159, 0.1);
    border: 2px solid #0095A1;
    padding: 4rem 2rem;
  }
  main.subPage .homelink_wrap #tab-general ul.lineup,
  main.subPage .homelink_wrap #tab-whole ul.lineup {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  main.subPage .homelink_wrap #tab-general ul.lineup li,
  main.subPage .homelink_wrap #tab-whole ul.lineup li {
    width: 48%;
    margin-bottom: 2rem;
  }
  main.subPage .homelink_wrap #tab-general ul.lineup li h4,
  main.subPage .homelink_wrap #tab-whole ul.lineup li h4 {
    font-size: 1.3rem;
    line-height: 1.6;
    border-bottom: 2px solid #FFE100;
    height: 3.6em;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
  main.subPage .homelink_wrap #tab-general ul.lineup li p,
  main.subPage .homelink_wrap #tab-whole ul.lineup li p {
    font-size: 1rem;
    text-align: justify;
    word-break: break-all;
  }
  main.subPage .homelink_wrap #tab-general ul.lineup li.feature,
  main.subPage .homelink_wrap #tab-whole ul.lineup li.feature {
    width: 100%;
    margin: auto 0;
  }
  main.subPage .homelink_wrap #tab-general ul.lineup li.feature h3,
  main.subPage .homelink_wrap #tab-whole ul.lineup li.feature h3 {
    font-size: 1.7rem;
    font-weight: 700;
    text-align: left;
  }
  main.subPage .homelink_wrap #tab-general ul.lineup li.full,
  main.subPage .homelink_wrap #tab-whole ul.lineup li.full {
    width: 100%;
    margin: auto 0;
  }
  main.subPage .homelink_wrap #tab-general ul.lineup li.full h3,
  main.subPage .homelink_wrap #tab-whole ul.lineup li.full h3 {
    font-size: 1.6rem;
    font-weight: 700;
    text-align: left;
  }
  main.subPage .homelink_wrap #tab-general .others,
  main.subPage .homelink_wrap #tab-whole .others {
    padding: 4rem 2rem;
  }
  main.subPage .homelink_wrap #tab-general .others h3,
  main.subPage .homelink_wrap #tab-whole .others h3 {
    padding: 1rem 0 0.7rem;
    margin-bottom: 6rem;
    font-size: 1.6rem;
    font-weight: normal;
    position: relative;
  }
  main.subPage .homelink_wrap #tab-general .others h3.yellow,
  main.subPage .homelink_wrap #tab-whole .others h3.yellow {
    background: #FFE100;
  }
  main.subPage .homelink_wrap #tab-general .others h3.green,
  main.subPage .homelink_wrap #tab-whole .others h3.green {
    background: #0095A1;
    color: #ffffff;
  }
  main.subPage .homelink_wrap #tab-general .others h3::after,
  main.subPage .homelink_wrap #tab-whole .others h3::after {
    content: "＞";
    position: absolute;
    right: 2rem;
    top: 0;
    bottom: 0;
    margin: auto;
    line-height: 1em;
    height: 1em;
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
  }
  main.subPage .homelink_wrap #tab-general .others h3.on::after,
  main.subPage .homelink_wrap #tab-whole .others h3.on::after {
    -webkit-transform: rotate(-90deg);
            transform: rotate(-90deg);
  }
  main.subPage .homelink_wrap #tab-general .others ul.lineup,
  main.subPage .homelink_wrap #tab-whole .others ul.lineup {
    display: none;
  }
  main.subPage .homelink_wrap #tab-general .others ul.lineup li h4,
  main.subPage .homelink_wrap #tab-whole .others ul.lineup li h4 {
    border-bottom-color: #999999;
  }
  main.subPage .homelink_wrap #tab-general .button_link_homelink,
  main.subPage .homelink_wrap #tab-whole .button_link_homelink {
    display: block;
    border: 3px solid #FFE100;
    padding: 1rem 0;
    font-size: 1.6rem;
    font-weight: 700;
  }
  main.subPage .homelink_wrap #tab-general .button_link_homelink.green,
  main.subPage .homelink_wrap #tab-whole .button_link_homelink.green {
    border-color: #0095A1;
  }
  main.subPage .homelink_wrap #tab-whole ul.lineup li h4 {
    border-bottom-color: #0095A1;
  }
  main.subPage .offer_box {
    width: 100%;
    margin: auto;
  }
  main.subPage .offer_box li {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: start;
    -webkit-justify-content: flex-start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    height: auto;
    margin-bottom: 3rem;
    background-color: #FFE100;
  }
  main.subPage .offer_box li p {
    height: 100%;
    margin: 0;
  }
  main.subPage #mv > .container {
    height: auto;
    padding: 0 !important;
  }
  main.subPage #mv > .container h2 {
    margin: 0;
  }
  main.subPage #mv .container {
    padding: 0 1.5rem;
  }
  main.subPage #mv .note {
    background-color: transparent;
  }
  main.subPage #mv p.lead {
    text-align: justify;
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 2;
    padding: 1rem 1.5rem;
  }
  main.subPage #mv p.lead span.caption {
    font-size: 1.2rem;
    font-weight: normal;
    text-align: justify;
    line-height: 1.6;
  }
  main.subPage #page-header {
    background: url("../camera/img/camera_header_bg.png") no-repeat right top;
    background-size: cover;
  }
  main.subPage #page-header h1 {
    color: #ffffff;
    font-size: 2rem;
    font-weight: normal;
  }
  main.subPage #intro .container {
    text-align: center;
  }
  main.subPage #intro .container .intro_box {
    width: 100%;
    margin: auto auto 6rem;
  }
  main.subPage #intro .container .intro_box .head {
    background-color: #0095A1;
    padding: 2rem 1.5rem;
  }
  main.subPage #intro .container .intro_box .head h3 {
    margin-bottom: 2rem;
  }
  main.subPage #intro .container .intro_box .head h3 span.icon {
    background-color: #FFE100;
    color: #0095A1;
    font-size: 0.6em;
    line-height: 1.6em;
    display: inline-block;
    text-align: center;
    padding: 0.3rem 1rem;
    vertical-align: middle;
  }
  main.subPage #intro .container .intro_box .head p {
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 1.8;
    color: #ffffff;
    margin: 0;
  }
  main.subPage #intro .container .intro_box .body {
    background-color: #ffffff;
    border: 2px solid #0095A1;
    padding: 1.5rem;
  }
  main.subPage #intro .container .intro_box .body p {
    font-size: 1.4rem;
  }
  main.subPage #intro .container .intro_box .body p.lead {
    font-size: 1.8rem;
    font-weight: bold;
    text-align: center;
  }
  main.subPage #intro .container .intro_box .body p.lead .caption {
    font-size: 1.2rem;
    font-weight: normal;
    text-align: center;
  }
  main.subPage #intro .container .compare_box {
    border: 1px solid #999999;
    padding: 2rem 1rem 1rem;
    margin-bottom: 3rem;
  }
  main.subPage #intro .container .compare_box h2 {
    font-size: 1.8rem;
  }
  main.subPage #intro .container .compare_box h3 {
    color: #ffffff;
    background-color: #999999;
    padding: 1rem 0;
    border-radius: 2rem;
    font-size: 1.6rem;
    font-weight: 700;
    margin: 0 auto 3rem;
    width: 28rem;
  }
  main.subPage #intro .container .compare_box h3.green {
    background-color: #0095A1;
  }
  main.subPage #intro .container .compare_box hr {
    border-top: 2px dotted #999999;
  }
  main.subPage #intro .container .compare_box.green {
    border-color: #0095A1;
  }
  main.subPage #intro .container .row {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  main.subPage #intro .container .row h2.intro-title {
    width: 100%;
    background: #0095A1;
    color: #ffffff;
    font-weight: 500;
    padding: 1rem 0;
  }
  main.subPage #intro .container .row .item {
    width: 100%;
  }
  main.subPage #intro .container .row .item h3 {
    font-size: 2rem;
    font-weight: 600;
    border: 2px solid;
    color: #0095A1;
    padding: 0.5rem 0;
  }
  main.subPage p.link_more {
    width: 100%;
    text-align: center;
  }
  main.subPage p.link_more a {
    display: inline-block;
    width: 50%;
  }
  main.subPage #link_panel .container {
    padding-top: 0;
    padding-bottom: 3rem;
  }
  main.subPage #link_panel .container .link {
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
  }
  main.subPage #link_panel .container .link li {
    width: 32%;
    margin-bottom: 0.5rem;
  }
  main.subPage #link_panel .container .link li a {
    border: 2px solid #0095A1;
  }
  main.subPage #link_panel .container .link > p {
    margin-bottom: 0;
  }
  main.subPage .gray_box {
    border: 2px solid #999999;
    margin-bottom: 3rem;
    padding-bottom: 2rem;
  }
  main.subPage .gray_box > * {
    margin: auto 3rem;
  }
  main.subPage .gray_box h3 {
    background-color: #0095A1;
    color: #FFE100;
    font-size: 1.8rem;
    padding: 1rem 0 0;
    margin: 0 0 1rem;
  }
  main.subPage .gray_box h3 span {
    display: block;
    background-color: #cce9ec;
    color: #0095A1;
    margin-top: 2rem;
    font-size: 1.4rem;
    padding: 1rem 0;
  }
  main.subPage .gray_box h3 span img {
    display: block;
    margin: auto auto 1rem;
    width: 20%;
  }
  main.subPage .gray_box h4 {
    color: #ffffff;
    background-color: #999999;
    padding: 1rem 0;
    border-radius: 2rem;
    font-size: 1.6rem;
    margin-bottom: 3rem;
  }
  main.subPage .gray_box h4.green {
    background-color: #0095A1;
  }
  main.subPage .gray_box hr {
    border-top: 2px dotted #999999;
    margin: 3rem 6rem;
  }
  main.subPage .gray_box p {
    font-size: 1.4rem;
    font-weight: bold;
  }
  main.subPage .gray_box p.img {
    width: 90%;
  }
  main.subPage #point3 .container {
    padding-bottom: 1px;
  }
  main.subPage #option {
    background-color: #ffffff;
  }
  main.subPage #option.gray {
    background-color: #f1f1f1;
  }
  main.subPage #option .container .option_camera p.img,
  main.subPage #option .container .option_iot p.img {
    margin: 0;
  }
  main.subPage #option .container .lineup_box {
    width: 36rem;
    margin: 4rem auto 4rem;
    padding: 2rem;
    background-color: #ffffff;
    border: 1px solid #0095A1;
  }
  main.subPage #option .container .lineup_box p {
    font-size: 1.2rem;
  }
  main.subPage #option .container .lineup_box .lineup_list {
    margin: 3rem 0;
  }
  main.subPage #option .container .lineup_box .lineup_list li {
    width: 30%;
  }
  main.subPage #option .container .lineup_box .button {
    margin-top: 2rem;
    margin-bottom: 0;
  }
  main.subPage #contact p {
    margin: 0;
  }
  .camera .lity-iframe-container {
    width: 100%;
    height: 80vh;
    overflow: auto;
    pointer-events: auto;
    -webkit-transform: translateZ(0);
            transform: translateZ(0);
  }
}

@media screen and (min-width: 768px) {
  main.subPage section {
    text-align: center;
  }
  main.subPage section:nth-of-type(2n) {
    background-color: #f1f1f1;
  }
  main.subPage section .container {
    padding: 6rem 0;
  }
  main.subPage section .container p.head {
    margin-bottom: 6rem;
  }
  main.subPage.inv section:nth-of-type(2n) {
    background-color: #ffffff;
  }
  main.subPage.inv section:nth-of-type(2n + 1) {
    background-color: #f1f1f1;
  }
  main.subPage h2,
  main.subPage h3 {
    margin-bottom: 3rem;
  }
  main.subPage h2 {
    font-size: 4.2rem;
  }
  main.subPage h2.inv_green {
    background: #0095A1;
    color: #ffffff;
    padding: 1rem 0;
  }
  main.subPage h3.cb_green {
    color: #0095A1;
    border: 1px solid #0095A1;
    line-height: 3;
    margin-bottom: 3rem;
  }
  main.subPage .bg_green {
    color: #ffffff;
    background-color: #0095A1;
    margin: 3rem auto;
    padding: 1rem 0;
    font-size: 2.8rem;
  }
  main.subPage .txt_yellow {
    color: #FFE100;
  }
  main.subPage .txt_green {
    color: #0095A1;
  }
  main.subPage h4.iot_scene_head {
    font-size: 3.2rem;
    color: #0095A1;
    margin: 8rem auto 4rem;
  }
  main.subPage h4.iot_scene_head span {
    display: block;
    margin: auto auto 2rem;
  }
  main.subPage p {
    margin-bottom: 2rem;
  }
  main.subPage p .caption {
    font-size: 0.85em;
    display: block;
    text-align: left;
  }
  main.subPage p.lead {
    font-size: 1.8rem;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
  }
  main.subPage p.lead_l {
    font-size: 1.8rem;
  }
  main.subPage p.img {
    margin: auto auto 4rem;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
  main.subPage p.img .caption {
    display: block;
    text-align: left;
    font-size: 1.4rem;
  }
  main.subPage .txt-left {
    text-align: left !important;
  }
  main.subPage .txt-right {
    text-align: right !important;
  }
  main.subPage strong {
    color: #0095A1;
  }
  main.subPage .flex {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
  main.subPage .w700 {
    width: 70rem;
  }
  main.subPage .w860 {
    width: 86rem;
  }
  main.subPage .w900 {
    width: 90rem;
  }
  main.subPage .w920 {
    width: 92rem;
  }
  main.subPage .movie_index {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-bottom: 3rem;
  }
  main.subPage .movie_index li {
    width: 36.3rem;
    margin-bottom: 2rem;
  }
  main.subPage .movie_index li h4 {
    background: #0095A1;
    color: #ffffff;
  }
  main.subPage .movie_index li a {
    display: block;
    margin-bottom: 1rem;
    border: 1px solid #999999;
  }
  main.subPage .video_homelink {
    display: block;
    width: 36.3rem;
    margin: 0 auto 6rem;
  }
  main.subPage .point_box {
    border: 2px solid #FFE100;
    margin-bottom: 4rem;
  }
  main.subPage .point_box .head {
    background-color: #FFE100;
    padding: 3rem 0;
  }
  main.subPage .point_box .head h3 {
    font-size: 2.8rem;
    color: #0095A1;
    margin-bottom: 0;
  }
  main.subPage .point_box .body {
    padding: 3rem 4rem;
  }
  main.subPage .point_box .body p {
    text-align: left;
  }
  main.subPage .point_box .body p.img {
    text-align: center;
  }
  main.subPage .point_box .body .sub_box {
    background-color: rgba(0, 147, 159, 0.1);
    padding: 2.5rem 2.5rem 1rem;
  }
  main.subPage .homelink_wrap {
    background-color: #ffffff;
    padding: 0;
  }
  main.subPage .homelink_wrap ul#tab-index {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    position: -webkit-sticky;
    position: sticky;
    top: 4rem;
  }
  main.subPage .homelink_wrap ul#tab-index li {
    width: 50%;
    background: #ffffff;
  }
  main.subPage .homelink_wrap ul#tab-index li a {
    display: block;
    width: 100%;
    text-align: center;
    font-size: 2.5rem;
    padding: 1rem 0;
    position: relative;
    cursor: pointer;
    opacity: .4;
  }
  main.subPage .homelink_wrap ul#tab-index li a.on, main.subPage .homelink_wrap ul#tab-index li a:hover {
    opacity: 1;
  }
  main.subPage .homelink_wrap ul#tab-index li a::after {
    display: block;
    height: 0;
    width: 0;
    border-top: 2rem solid;
    border-left: 1.2rem solid transparent;
    border-right: 1.2rem solid transparent;
    position: absolute;
    bottom: -2rem;
    left: 0;
    right: 0;
    margin: auto;
  }
  main.subPage .homelink_wrap ul#tab-index li a[data-href$="general"] {
    background: #FFE100;
  }
  main.subPage .homelink_wrap ul#tab-index li a[data-href$="general"].on::after {
    content: "";
    border-top-color: #FFE100;
  }
  main.subPage .homelink_wrap ul#tab-index li a[data-href$="whole"] {
    background: #0095A1;
    color: #ffffff;
  }
  main.subPage .homelink_wrap ul#tab-index li a[data-href$="whole"].on::after {
    content: "";
    border-top-color: #0095A1;
  }
  main.subPage .homelink_wrap #tab-general,
  main.subPage .homelink_wrap #tab-whole {
    display: none;
  }
  main.subPage .homelink_wrap #tab-general.on,
  main.subPage .homelink_wrap #tab-whole.on {
    display: block;
  }
  main.subPage .homelink_wrap #tab-general .yellow-box,
  main.subPage .homelink_wrap #tab-whole .yellow-box {
    background: rgba(255, 255, 0, 0.2);
    border: 2px solid #FFE100;
    padding: 5.2rem 8.4rem;
  }
  main.subPage .homelink_wrap #tab-general .green-box,
  main.subPage .homelink_wrap #tab-whole .green-box {
    background: rgba(0, 147, 159, 0.1);
    border: 2px solid #0095A1;
    padding: 5.2rem 8.4rem;
  }
  main.subPage .homelink_wrap #tab-general ul.lineup,
  main.subPage .homelink_wrap #tab-whole ul.lineup {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  main.subPage .homelink_wrap #tab-general ul.lineup li,
  main.subPage .homelink_wrap #tab-whole ul.lineup li {
    width: 28%;
    margin-bottom: 4rem;
  }
  main.subPage .homelink_wrap #tab-general ul.lineup li h4,
  main.subPage .homelink_wrap #tab-whole ul.lineup li h4 {
    font-size: 1.8rem;
    line-height: 1.6;
    border-bottom: 2px solid #FFE100;
    height: 3.6em;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
  main.subPage .homelink_wrap #tab-general ul.lineup li p,
  main.subPage .homelink_wrap #tab-whole ul.lineup li p {
    font-size: 1.5rem;
    text-align: justify;
    word-break: break-all;
  }
  main.subPage .homelink_wrap #tab-general ul.lineup li.feature,
  main.subPage .homelink_wrap #tab-whole ul.lineup li.feature {
    width: 65%;
    margin: auto 0;
  }
  main.subPage .homelink_wrap #tab-general ul.lineup li.feature h3,
  main.subPage .homelink_wrap #tab-whole ul.lineup li.feature h3 {
    font-size: 2.8rem;
    font-weight: 700;
    text-align: left;
  }
  main.subPage .homelink_wrap #tab-general ul.lineup li.full,
  main.subPage .homelink_wrap #tab-whole ul.lineup li.full {
    width: 100%;
    margin: auto 0;
  }
  main.subPage .homelink_wrap #tab-general ul.lineup li.full h3,
  main.subPage .homelink_wrap #tab-whole ul.lineup li.full h3 {
    font-size: 2.8rem;
    font-weight: 700;
    text-align: left;
  }
  main.subPage .homelink_wrap #tab-general .others,
  main.subPage .homelink_wrap #tab-whole .others {
    padding: 5.2rem 8.4rem;
  }
  main.subPage .homelink_wrap #tab-general .others h3,
  main.subPage .homelink_wrap #tab-whole .others h3 {
    padding: 1rem 0 0.7rem;
    margin-bottom: 6rem;
  }
  main.subPage .homelink_wrap #tab-general .others h3.yellow,
  main.subPage .homelink_wrap #tab-whole .others h3.yellow {
    background: #FFE100;
  }
  main.subPage .homelink_wrap #tab-general .others h3.green,
  main.subPage .homelink_wrap #tab-whole .others h3.green {
    background: #0095A1;
    color: #ffffff;
  }
  main.subPage .homelink_wrap #tab-general .others ul.lineup li h4,
  main.subPage .homelink_wrap #tab-whole .others ul.lineup li h4 {
    border-bottom-color: #999999;
  }
  main.subPage .homelink_wrap #tab-general .button_link_homelink,
  main.subPage .homelink_wrap #tab-whole .button_link_homelink {
    display: block;
    border: 3px solid #FFE100;
    padding: 1rem 0;
    font-size: 2rem;
    font-weight: 700;
  }
  main.subPage .homelink_wrap #tab-general .button_link_homelink.green,
  main.subPage .homelink_wrap #tab-whole .button_link_homelink.green {
    border-color: #0095A1;
  }
  main.subPage .homelink_wrap #tab-whole ul.lineup li h4 {
    border-bottom-color: #0095A1;
  }
  main.subPage .offer_box {
    width: 86.5rem;
    margin: auto;
  }
  main.subPage .offer_box li {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    height: 23.5rem;
    margin-bottom: 3rem;
    background-color: #FFE100;
  }
  main.subPage .offer_box li p {
    height: 100%;
  }
  main.subPage #mv {
    background-color: #ffffff;
  }
  main.subPage #mv > .container {
    height: 44.8rem;
  }
  main.subPage #mv .container {
    padding: 0;
    margin-top: 0;
  }
  main.subPage #mv .note {
    background-color: transparent;
  }
  main.subPage #mv p.lead {
    text-align: center;
    font-size: 2.3rem;
    font-weight: bold;
    line-height: 2;
    padding: 4rem 0;
  }
  main.subPage #mv p.lead span.caption {
    font-size: 1.4rem;
    font-weight: normal;
  }
  main.subPage #page-header {
    background: url("../camera/img/camera_header_bg.png") no-repeat right top;
    background-size: cover;
  }
  main.subPage #page-header h1 {
    color: #ffffff;
    font-size: 4.8rem;
    font-weight: normal;
  }
  main.subPage #lead .container .banner-case, main.subPage #lead2 .container .banner-case {
    margin-bottom: 0;
  }
  main.subPage #intro .container {
    padding: 6rem 0;
    text-align: center;
  }
  main.subPage #intro .container .intro_box {
    width: 93.6rem;
    margin: auto auto 6rem;
  }
  main.subPage #intro .container .intro_box .head {
    background-color: #0095A1;
    padding: 3rem 0;
  }
  main.subPage #intro .container .intro_box .head h3 {
    margin-bottom: 2rem;
  }
  main.subPage #intro .container .intro_box .head p {
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1.8;
    color: #ffffff;
    margin: 0;
  }
  main.subPage #intro .container .intro_box .body {
    background-color: #ffffff;
    border: 2px solid #0095A1;
    padding: 4rem;
  }
  main.subPage #intro .container .intro_box .body p.lead {
    font-size: 3rem;
    font-weight: bold;
    text-align: center;
  }
  main.subPage #intro .container .intro_box .body p.lead .caption {
    font-size: 1.4rem;
    font-weight: normal;
    text-align: center;
  }
  main.subPage #intro .container .compare_box {
    border: 2px solid #999999;
    padding: 4rem 6rem 1rem;
    margin: 0 auto 6rem;
    max-width: 91rem;
  }
  main.subPage #intro .container .compare_box h2 {
    font-size: 2.6rem;
  }
  main.subPage #intro .container .compare_box h3 {
    color: #ffffff;
    background-color: #999999;
    padding: 1.5rem 0;
    border-radius: 2rem;
  }
  main.subPage #intro .container .compare_box h3.green {
    background-color: #0095A1;
  }
  main.subPage #intro .container .compare_box hr {
    border-top: 2px dotted #999999;
  }
  main.subPage #intro .container .compare_box.green {
    border-color: #0095A1;
  }
  main.subPage #intro .container .row {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    width: 86rem;
    margin: 0 auto;
  }
  main.subPage #intro .container .row h2.intro-title {
    width: 100%;
    background: #0095A1;
    color: #ffffff;
    font-size: 4.2rem;
    font-weight: 600;
    padding: 2rem 0;
  }
  main.subPage #intro .container .row .item {
    width: 48%;
  }
  main.subPage #intro .container .row .item h3 {
    font-size: 3rem;
    font-weight: 600;
    border: 2px solid;
    color: #0095A1;
    padding: 2rem 0;
  }
  main.subPage #intro .container .row .item p {
    text-align: justify;
  }
  main.subPage p.link_more {
    width: 100%;
    text-align: right;
  }
  main.subPage p.link_more.center {
    text-align: center;
  }
  main.subPage p.link_more a {
    display: inline-block;
    width: 19.8rem;
  }
  main.subPage #link_panel .container {
    padding-top: 3rem;
  }
  main.subPage #link_panel .container .link {
    width: 64rem;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
  }
  main.subPage #link_panel .container .link li {
    width: 20rem;
  }
  main.subPage #link_panel .container .link li a {
    border: 2px solid #0095A1;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    position: relative;
    overflow: hidden;
  }
  main.subPage #link_panel .container .link li a::after {
    content: "";
    display: block;
    width: 100%;
    height: 2.4rem;
    background: #0095A1 url("../img/anker_down.svg") no-repeat center center;
    background-size: 10%;
    position: absolute;
    bottom: 0;
    -webkit-transform: translate(0, 100%);
            transform: translate(0, 100%);
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  main.subPage #link_panel .container .link li a:hover {
    opacity: 1;
    -webkit-box-shadow: 0 0 0 2px #0095A1;
            box-shadow: 0 0 0 2px #0095A1;
  }
  main.subPage #link_panel .container .link li a:hover::after {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
  main.subPage .gray_box {
    border: 2px solid #999999;
    margin-bottom: 6rem;
    padding-bottom: 4rem;
  }
  main.subPage .gray_box > * {
    margin: auto 6rem;
  }
  main.subPage .gray_box h3 {
    background-color: #0095A1;
    color: #FFE100;
    font-size: 3.8rem;
    padding: 3rem 0 0;
    margin: 0 0 4rem;
  }
  main.subPage .gray_box h3 span {
    display: block;
    background-color: #cce9ec;
    color: #0095A1;
    margin-top: 2rem;
    font-size: 2.6rem;
    padding: 1rem 0;
  }
  main.subPage .gray_box h3 span img {
    display: block;
    margin: auto auto 1rem;
  }
  main.subPage .gray_box h4 {
    color: #ffffff;
    background-color: #999999;
    padding: 1.5rem 0;
    border-radius: 2rem;
    font-size: 2.8rem;
    margin-bottom: 3rem;
  }
  main.subPage .gray_box h4.green {
    background-color: #0095A1;
  }
  main.subPage .gray_box hr {
    border-top: 2px dotted #999999;
    margin: 3rem 6rem;
  }
  main.subPage .gray_box p {
    font-size: 2rem;
    font-weight: bold;
  }
  main.subPage #point3 .container {
    padding-bottom: 1px;
    max-width: 94rem;
  }
  main.subPage #point3 .container .row {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: end;
    -webkit-align-items: flex-end;
        -ms-flex-align: end;
            align-items: flex-end;
  }
  main.subPage #point3 .container .row h3 {
    width: 100%;
  }
  main.subPage #point3 .container .row p.text {
    width: 70rem;
    text-align: justify;
  }
  main.subPage #point3 .container .row p.link_more {
    width: 19.8rem;
  }
  main.subPage #option {
    background-color: #ffffff;
  }
  main.subPage #option.gray {
    background-color: #f1f1f1;
  }
  main.subPage #option .container .lineup_box {
    width: 96.7rem;
    margin: 4rem auto 4rem;
    padding: 6rem 11.6rem;
    background-color: #ffffff;
    border: 2px solid #0095A1;
  }
  main.subPage #option .container .lineup_box .lineup_list {
    margin: 3rem 0;
  }
  main.subPage #option .container .lineup_box .button {
    margin-top: 6rem;
    margin-bottom: 0;
  }
  main.subPage #contact p {
    margin: 0;
  }
  .camera .lity-iframe-container {
    width: 100%;
    height: 90vh;
    /* padding-top: 56.25%; */
    overflow: auto;
    pointer-events: auto;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    -webkit-overflow-scrolling: touch;
  }
}

@media screen and (max-width: 767px) {
  main.case.case-desc {
    background: #ffffff;
  }
  main.case.case-desc #page-header {
    background: #ffffff;
  }
  main.case.case-desc section {
    background: #ffffff;
  }
  main.case #page-header {
    background: #f1f1f1;
  }
  main.case #page-header .container {
    padding: 4rem 0 1px;
  }
  main.case #page-header h1 {
    margin-bottom: 3rem;
    font-size: 2rem;
    width: 80%;
    margin-left: auto;
    margin-right: auto;
  }
  main.case #page-header p {
    text-align: center;
  }
  main.case #case-list .container {
    width: 100%;
  }
  main.case #case-list .container ul li {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
        -ms-flex-align: start;
            align-items: flex-start;
    margin-bottom: 4rem;
  }
  main.case #case-list .container ul li p.ava {
    width: 15%;
    margin-right: 1rem;
  }
  main.case #case-list .container ul li .message-box__wrap {
    width: 80%;
  }
  main.case #case-list .container ul li .message-box {
    background: #ffffff;
    border-radius: 2rem;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: column-reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    padding: 1rem;
  }
  main.case #case-list .container ul li .message-box .message-meta {
    width: 100%;
    padding-top: 1rem;
    border-top: 1px solid #000;
  }
  main.case #case-list .container ul li .message-box .message-meta h2 {
    color: #000000;
    font-size: 1.4rem;
    font-weight: 700;
    text-align: left;
    margin-bottom: 1rem;
  }
  main.case #case-list .container ul li .message-box .message-meta a.button {
    display: block;
    width: 30%;
    margin: 0 0 0 auto;
  }
  main.case #case-list .container ul li .message-box .message-body {
    width: 100%;
    color: #0095A1;
    text-align: justify;
    margin: 0 0 1rem;
  }
  main.case #case-list .container ul li p.note {
    font-size: 1rem;
    margin-top: 0.5rem;
  }
  main.case #case-desc .container {
    padding-top: 0;
  }
  main.case #case-desc .container h2 {
    margin-bottom: 5rem;
  }
  main.case #case-desc .container .row {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
        -ms-flex-align: start;
            align-items: flex-start;
    margin-bottom: 5rem;
  }
  main.case #case-desc .container .row .item {
    width: 100%;
  }
  main.case #case-desc .container .row .item.img p.img .caption {
    display: block;
    font-size: 1rem;
  }
  main.case #case-desc .container .row .item h3 {
    color: #0095A1;
    font-size: 2rem;
    font-weight: 700;
    text-align: left;
    margin-bottom: 3rem;
  }
  main.case #case-desc .container .row .item p {
    font-size: 1.4rem;
    line-height: 2;
    text-align: justify;
  }
  main.case #case-desc .container .row.reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: row-reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
  main.case #case-desc .container .case_report {
    border: 1px solid #0095A1;
    padding: 0 2.4rem 0 2.4rem;
  }
  main.case #case-desc .container .case_report h2 {
    text-align: left;
    font-size: 0;
  }
  main.case #case-desc .container .case_report .inner {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  main.case #case-desc .container .case_report .inner .item_txt {
    width: 100%;
  }
  main.case #case-desc .container .case_report .inner .item_txt h3 {
    font-size: 3rem;
    color: #0095A1;
    text-align: left;
  }
  main.case #case-desc .container .case_report .inner .item_txt h3 span {
    font-size: 1.6rem;
    color: #000000;
    display: block;
  }
  main.case #case-desc .container .case_report .inner .item_txt p {
    text-align: justify;
    font-size: 1.4rem;
    line-height: 2;
  }
  main.case #case-desc .container .case_report .inner .item_txt p.lead {
    font-size: 2.2rem;
    font-weight: 700;
    color: #0095A1;
    width: auto;
  }
  main.case #case-desc .container .case_report .inner .item_img {
    width: 100%;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  main.case #case-desc .container .case_report .inner .item_img p.img {
    width: 100%;
  }
  main.case #case-desc .container .case_report .inner .item_img p.img.half {
    width: 45%;
    margin-left: 0;
    margin-right: 0;
  }
  main.case #case-desc .container .case_report .inner .item_img p.img .caption {
    font-size: 1rem;
  }
  main.case #case-desc .container .case_report .inner .item_img p.img .caption.right {
    width: 45%;
    margin: 0 0 0 auto;
  }
}

@media screen and (min-width: 768px) {
  p.backlink a {
    display: inline-block;
    border: 2px solid;
    color: #0095A1;
    font-weight: bold;
    padding: 0.5rem 3rem 0.2rem;
    border-radius: 4px;
    font-size: 2rem;
  }
  main.case.case-desc {
    background: #ffffff;
  }
  main.case.case-desc #page-header {
    background: #ffffff;
  }
  main.case.case-desc section {
    background: #ffffff;
  }
  main.case #page-header {
    background: #f1f1f1;
  }
  main.case #page-header .container {
    padding: 4rem 0 1px;
  }
  main.case #page-header h1 {
    margin-bottom: 3rem;
    font-size: 2rem;
  }
  main.case #case-list .container {
    width: 90rem;
  }
  main.case #case-list .container ul li {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
        -ms-flex-align: start;
            align-items: flex-start;
    margin-bottom: 4rem;
  }
  main.case #case-list .container ul li .message-box__wrap {
    width: 69.6rem;
  }
  main.case #case-list .container ul li .message-box {
    background: #ffffff;
    border-radius: 2rem;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: row-reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    padding: 3rem 3rem 3rem 5rem;
  }
  main.case #case-list .container ul li .message-box .message-meta {
    width: 17rem;
    padding-left: 3rem;
    border-left: 1px solid #000;
  }
  main.case #case-list .container ul li .message-box .message-meta h2 {
    color: #000000;
    font-size: 1.4rem;
    font-weight: 700;
    text-align: left;
    margin-bottom: 4rem;
  }
  main.case #case-list .container ul li .message-box .message-meta a.button {
    display: block;
    width: 14.2rem;
  }
  main.case #case-list .container ul li .message-box .message-body {
    width: 40.7rem;
    color: #0095A1;
    text-align: justify;
    margin: 0;
  }
  main.case #case-list .container ul li p.note {
    text-align: left;
    font-size: 1.4rem;
    margin-top: 1rem;
  }
  main.case #case-desc .container {
    padding-top: 0;
  }
  main.case #case-desc .container h2 {
    margin-bottom: 5rem;
  }
  main.case #case-desc .container .row {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
        -ms-flex-align: start;
            align-items: flex-start;
    margin-bottom: 5rem;
  }
  main.case #case-desc .container .row .item {
    width: 48%;
  }
  main.case #case-desc .container .row .item.img p.img .caption {
    display: block;
    font-size: 1rem;
  }
  main.case #case-desc .container .row .item h3 {
    color: #0095A1;
    font-size: 2rem;
    font-weight: 700;
    text-align: left;
    margin-bottom: 3rem;
  }
  main.case #case-desc .container .row .item p {
    font-size: 1.4rem;
    line-height: 2;
    text-align: justify;
  }
  main.case #case-desc .container .row .item p.note {
    font-size: 0.6em;
  }
  main.case #case-desc .container .row.reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: row-reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
  main.case #case-desc .container .case_report {
    border: 1px solid #0095A1;
    padding: 0 2.4rem 0 4rem;
  }
  main.case #case-desc .container .case_report h2 {
    text-align: left;
    font-size: 0;
  }
  main.case #case-desc .container .case_report .inner {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  main.case #case-desc .container .case_report .inner .item_txt {
    width: 48.5%;
  }
  main.case #case-desc .container .case_report .inner .item_txt h3 {
    font-size: 3rem;
    color: #0095A1;
    text-align: left;
  }
  main.case #case-desc .container .case_report .inner .item_txt h3 span {
    font-size: 1.6rem;
    color: #000000;
    display: block;
  }
  main.case #case-desc .container .case_report .inner .item_txt p {
    text-align: justify;
    font-size: 1.4rem;
    line-height: 2;
  }
  main.case #case-desc .container .case_report .inner .item_txt p.lead {
    font-size: 2.2rem;
    font-weight: 700;
    color: #0095A1;
    width: auto;
  }
  main.case #case-desc .container .case_report .inner .item_img {
    width: 45.6%;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  main.case #case-desc .container .case_report .inner .item_img p.img {
    width: 100%;
    margin-top: 0;
  }
  main.case #case-desc .container .case_report .inner .item_img p.img.half {
    width: 45%;
    margin-left: 0;
    margin-right: 0;
  }
  main.case #case-desc .container .case_report .inner .item_img p.img .caption {
    font-size: 1rem;
  }
  main.case #case-desc .container .case_report .inner .item_img p.img .caption.right {
    width: 45%;
    margin: 0 0 0 auto;
  }
}

@media screen and (max-width: 767px) {
  main.faq {
    background: #ffffff !important;
  }
  main.faq section#faq-list {
    background: #ffffff !important;
  }
  main.faq #page-header {
    background: #0095A1 !important;
    padding: 0;
  }
  main.faq #page-header .container {
    padding: 0;
  }
  main.faq #page-header .container h1 {
    width: 80%;
    margin: 0 auto;
  }
  main.faq #faq-list .container ul.anker-index {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  main.faq #faq-list .container ul.anker-index li {
    width: 30%;
  }
  main.faq #faq-list .container ul.anker-index li a {
    display: block;
    text-align: center;
    background: #FFE100;
    color: #0095A1;
    font-size: 1.2rem;
    font-weight: 500;
    line-height: 2.4;
    border-radius: 6rem;
    padding-top: .2rem;
    margin-bottom: 4rem;
  }
  main.faq #faq-list .container .faq-wrap {
    background: #f1f1f1;
    padding-bottom: 4rem;
  }
  main.faq #faq-list .container .faq-wrap h2 {
    background: #0095A1;
    color: #ffffff;
    font-size: 1.6rem;
    padding: 0.8rem 1.5rem 0.6rem;
    text-align: left;
  }
  main.faq #faq-list .container .faq-wrap dl {
    width: 96%;
    margin: 0 auto 4rem;
  }
  main.faq #faq-list .container .faq-wrap dl dt {
    text-align: left;
    color: #0095A1;
    font-size: 1.6rem;
    font-weight: 700;
    padding: 1rem 2rem 1rem 3rem;
    background: #ffffff url(../faq/img/icon-q.svg) no-repeat 1rem center;
    background-size: 1.5rem;
    border: 1px solid #999999;
    position: relative;
    cursor: pointer;
    margin-top: 1.5rem;
  }
  main.faq #faq-list .container .faq-wrap dl dt::after {
    content: "";
    display: block;
    width: 1.2rem;
    height: 1rem;
    background: url("../faq/img/arrow.svg") no-repeat center;
    background-size: contain;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 1rem;
    margin: auto;
    -webkit-transform: rotate(180deg);
            transform: rotate(180deg);
  }
  main.faq #faq-list .container .faq-wrap dl dt.on::after {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }
  main.faq #faq-list .container .faq-wrap dl dd {
    background: #ffffff;
    padding: 2rem 3rem;
    font-size: 1.6rem;
    color: #000000;
    text-align: left;
    margin: -1px 0 0;
    border: 1px solid #999999;
    display: none;
  }
  main.faq #faq-list .container .faq-wrap dl dd a {
    color: #0095A1;
    text-decoration: underline;
  }
}

@media screen and (min-width: 768px) {
  main.faq {
    background: #ffffff !important;
  }
  main.faq section#faq-list {
    background: #ffffff !important;
  }
  main.faq #page-header {
    background: #0095A1 !important;
    padding: 0;
  }
  main.faq #page-header .container {
    padding: 0;
  }
  main.faq #page-header .container h1 {
    width: 81rem;
    margin: 0 auto;
  }
  main.faq #faq-list .container ul.anker-index {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  main.faq #faq-list .container ul.anker-index li {
    width: 30%;
  }
  main.faq #faq-list .container ul.anker-index li a {
    display: block;
    text-align: center;
    background: #FFE100;
    color: #0095A1;
    font-size: 2rem;
    font-weight: 700;
    line-height: 2.4;
    border-radius: 6rem;
    padding-top: .2rem;
    margin-bottom: 4rem;
  }
  main.faq #faq-list .container .faq-wrap {
    background: #f1f1f1;
    padding-bottom: 4rem;
  }
  main.faq #faq-list .container .faq-wrap h2 {
    background: #0095A1;
    color: #ffffff;
    font-size: 2.2rem;
    padding: 0.8rem 1.5rem 0.6rem;
    text-align: left;
  }
  main.faq #faq-list .container .faq-wrap dl {
    width: 86rem;
    margin: 0 auto 4rem;
  }
  main.faq #faq-list .container .faq-wrap dl dt {
    text-align: left;
    color: #0095A1;
    font-size: 2rem;
    font-weight: 700;
    padding: 1.6rem 8rem;
    background: #ffffff url(../faq/img/icon-q.svg) no-repeat 2rem center;
    background-size: 3rem;
    border: 1px solid #999999;
    position: relative;
    cursor: pointer;
    margin-top: 3rem;
  }
  main.faq #faq-list .container .faq-wrap dl dt::after {
    content: "";
    display: block;
    width: 1.2rem;
    height: 1rem;
    background: url("../faq/img/arrow.svg") no-repeat center;
    background-size: contain;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 3rem;
    margin: auto;
    -webkit-transform: rotate(180deg);
            transform: rotate(180deg);
  }
  main.faq #faq-list .container .faq-wrap dl dt.on::after {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }
  main.faq #faq-list .container .faq-wrap dl dd {
    background: #ffffff;
    padding: 2rem 3rem;
    font-size: 1.6rem;
    color: #000000;
    text-align: left;
    margin: -1px 0 0;
    border: 1px solid #999999;
    display: none;
  }
  main.faq #faq-list .container .faq-wrap dl dd a {
    color: #0095A1;
    text-decoration: underline;
  }
}

@media all and (-ms-high-contrast: none) {
  body main #contact {
    position: fixed;
    width: 100%;
    z-index: 99;
  }
  body main.case #case-desc .container .case_report .inner .item_txt p,
  body main.case #case-desc .container .row .item p {
    text-align: left;
    font-size: 1.5rem;
    word-break: break-all;
  }
  body footer {
    padding-bottom: 10rem !important;
  }
}
