﻿/* PC */
@media screen and (min-width: 769px) {
  .pc {
    display: block;
  }
  .sp {
    display: none;
  }
  .underlayer_topline {
    overflow: hidden;
    width: 100%;
    background: #2f68b1;
    background: -moz-linear-gradient(#85c7ce 0%, #73b5c8 25%, #5395be 50%, #3a7ab6 74%, #2f68b1 100%);
    background: -webkit-gradient(linear, left top, left bottom, from(#85c7ce), color-stop(25%, #73b5c8), color-stop(50%, #5395be), color-stop(74%, #3a7ab6), to(#2f68b1));
    background: -webkit-linear-gradient(#85c7ce 0%, #73b5c8 25%, #5395be 50%, #3a7ab6 74%, #2f68b1 100%);
    background: -o-linear-gradient(#85c7ce 0%, #73b5c8 25%, #5395be 50%, #3a7ab6 74%, #2f68b1 100%);
    background: -ms-linear-gradient(#85c7ce 0%, #73b5c8 25%, #5395be 50%, #3a7ab6 74%, #2f68b1 100%);
    background: linear-gradient(#85c7ce 0%, #73b5c8 25%, #5395be 50%, #3a7ab6 74%, #2f68b1 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr=#85c7ce, endColorstr=#2f68b1, GradientType=0);
  }
  .underlayer_topline_inner {
    overflow: hidden;
    width: 1000px;
    margin: 5px auto 0 auto;
  }
  h1.underlayer_headertext.clearfix {
    margin: 0 0 0 5px;
    font-size: 11px;
    font-weight: 500;
    opacity: 0.95;
    color: #fff;
  }
  h1.underlayer_headerlogo.clearfix {
    float: left;
    font-size: 17px;
    color: #fff;
    line-height: 50px;
    margin: 25px 0 0 0;
  }
  h1.underlayer_headerlogo.clearfix img {
    margin: -24px 10px 0 0;
  }
  p.underlayer_tel.clearfix {
    float: right;
    font-size: 30px;
    font-weight: 600;
    color: #fff;
    letter-spacing: -2px;
    margin: -30px 0 0 0;
  }
  /*-------------
memu
-------------*/
  #underlayer_menu {
    width: 600px;
    float: right;
  }
  /*nav*/
  div#underlayer_menu-nav {
    float: left;
    height: 30px;
    margin: 3px 0 0 0;
  }
  #underlayer_menu-nav li {
    float: left;
    margin: 0;
    line-height: 18px;
    font-weight: 600;
  }
  #underlayer_menu-nav li a {
    font-size: 12px;
    color: #fff;
    display: block;
    padding: 0 8px 3px 8px;
  }
  #underlayer_menu-nav li a:hover {
    border-bottom: solid 8px #193f87;
  }
  #underlayer_menu-nav li ul.drop {
    width: 64px;
    position: absolute;
    z-index: 100;
    /*left: 0;*/
    top: 97px;
    opacity: 0.8;
    filter: alpha(opacity=80);
    -ms-filter: "alpha(opacity=80)";
    -khtml-opacity: .80;
    -moz-opacity: .80;
    padding: 10px 0;
    margin: 0;
    background-color: #000;
    display: none;
    line-height: 15px;
  }
  #underlayer_menu-nav li ul.drop li {
    font-size: 11px;
    /*font-weight: bold;*/
    background-color: #000;
    opacity: 0.9;
    text-align: center;
    padding: 0 0;
    margin: 0;
    position: static;
    width: 100%;
    float: none;
    border: none;
  }
  #underlayer_menu-nav li ul.drop li a {
    font-size: 12px;
    text-decoration: none;
    color: #fff;
    padding: 3px 0 3px 2px;
  }
  #underlayer_menu-nav li ul.drop li a:link {
    text-decoration: none;
    color: #fff;
  }
  #underlayer_menu-nav li ul.drop li a:hover {
    border: none;
    color: #fff;
    text-decoration-color: #fff;
  }
  /*-------------
undermain
-------------*/
  .underlayer_main {
    width: 1000px;
    margin: 0 auto;
    overflow: hidden;
    min-height: 800px;
    background-color: #fff;
    padding: 30px 20px 60px;
  }
  .underlayer_main_right.clearfix {
    float: right;
    margin: 0 0 30px 0;
    width: 760px;
  }
  h2.banner {
    width: 100%;
    font-size: 27px;
    line-height: 40px;
    border-bottom: solid 3px #c1c1c1;
    margin: 30px 0 0 0;
    padding: 0 0 0 10px;
    margin: 0 0 10px 0;
    letter-spacing: 2px;
  }
  h2.banner img {
    margin: 3px 10px 0 0;
  }
  h3.underlayertitle_top {
    width: 100%;
    line-height: 30px;
    font-size: 20px;
    margin: 0 0 15px 0;
    clear: both;
    font-weight: 600;
    letter-spacing: 1px;
    border-bottom: solid 1px #c1c1c1;
    padding: 5px 0 0 0;
  }
  h3.underlayertitle {
    width: 100%;
    line-height: 30px;
    font-size: 20px;
    margin: 20px 0 15px 0;
    clear: both;
    font-weight: 600;
    letter-spacing: 1px;
    border-bottom: solid 1px #c1c1c1;
    padding: 20px 0 0 0;
  }
  h3.underlayertitle:before, h3.underlayertitle_top:before, h3.underlayertitle2:before {
    content: "●";
    padding-right: 7px;
    padding-left: 7px;
  }
  .right_banner {
    position: fixed;
    top: 105px;
    right: 0;
    z-index: 300;
  }
  .right_banner:hover {
    opacity: 0.8;
  }
  /*-------------
side
-------------*/
  .side.clearfix {
    float: left;
    width: 200px;
    margin: 0 0 50px 0;
  }
  .side a:hover {
    opacity: 0.8;
  }
  p.sidemenu {
    background: #2f68b1;
    background: -moz-linear-gradient(#82c5cd 0%, #4889bb 50%, #2f68b1 100%);
    background: -webkit-gradient(linear, left top, left bottom, from(#82c5cd), color-stop(50%, #4889bb), to(#2f68b1));
    background: -webkit-linear-gradient(#82c5cd 0%, #4889bb 50%, #2f68b1 100%);
    background: -o-linear-gradient(#82c5cd 0%, #4889bb 50%, #2f68b1 100%);
    background: -ms-linear-gradient(#82c5cd 0%, #4889bb 50%, #2f68b1 100%);
    background: linear-gradient(#82c5cd 0%, #4889bb 50%, #2f68b1 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr=#82c5cd, endColorstr=#2f68b1, GradientType=0);
    padding: 10px 0;
    margin: 0 0 10px 0;
    text-align: center;
  }
  p.sidemenu img {
    margin: 0 7px 0 0;
  }
  p.sidemenu a {
    font-size: 20px;
    line-height: 30px;
    display: block;
    color: #fff;
  }
  p.side_title {
    font-size: 20px;
    line-height: 40px;
    border-bottom: solid 3px #c1c1c1;
    margin: 0 0 0 0;
    padding: 0 0 0 10px;
  }
  p.side_title img {
    margin: 3px 7px 0 0;
  }
  p.side_text {
    line-height: 21px;
    margin: 15px 0 0 5px;
  }
  ul.sidemenu_list {
    width: 100%;
    margin: 40px 0 0 0;
  }
  ul.sidemenu_list li {
    font-size: 24px;
    line-height: 20px;
    font-weight: 600;
    margin: 0 0 22px 0;
    letter-spacing: -1px;
  }
  ul.sidemenu_list li a {
    font-size: 18px;
    letter-spacing: 1px;
  }
  ul.sidemenu_list li:nth-child(2) img {
    margin: 0 10px 0 0;
  }
  ul.sidemenu_list li a:hover {
    color: #193f87;
  }
  /*-------------
company
-------------*/
  table.company {
    border-collapse: collapse;
    width: 470px;
    margin: 0 17px 20px 0;
    line-height: 20px;
    float: left;
  }
  table.company th {
    text-align: justify;
    padding: 11px 30px 8px 10px;
    border-bottom: dotted 1px #c1c1c1;
    width: 65px;
    font-weight: 500;
    -moz-text-align-last: justify;
    text-align-last: justify;
    text-justify: inter-ideograph;
  }
  table.company td {
    padding: 8px 0 8px 0;
    border-bottom: dotted 1px #c1c1c1;
  }
  /*-------------
technology
-------------*/
  .technologybox1 {
    background: url(../images/technology/technology_img.png)no-repeat;
    width: 750px;
    height: 250px;
    margin: 0;
  }
  .technologybox1 p {
    font-size: 19px;
    letter-spacing: 1px;
    font-weight: 600;
    line-height: 35px;
    padding: 55px 0 0 470px;
  }
  ul.technology_list1.clearfix {
    width: 100%;
    margin: 5px 0 0 0;
  }
  ul.technology_list1.clearfix li {
    float: left;
    margin: 0 0 0 2px;
  }
  ul.technology_list1.clearfix li:first-child {
    margin: 0;
  }
  .technologybox2 {
    width: 100%;
    margin: 25px 0 45px 0;
  }
  p.technology_title {
    font-size: 15px;
    font-weight: 600;
    background-color: #c1c1c1;
    line-height: 35px;
    height: 35px;
    padding: 0 0 0 10px;
    margin: 20px 0 0 0;
    clear: both;
  }
  p.technology_text.clearfix {
    font-size: 15px;
    line-height: 23px;
    width: 500px;
    float: left;
    margin: 15px 9px 30px 10px;
  }
  .technologybox2 img {
    margin: 15px 0 0 0;
  }
  .technologybox3 p {
    font-size: 15px;
    line-height: 1.5;
    margin: 0 0 20px 10px;
  }
  .technologybox3 p.technology_text2 {
    font-size: 16px;
    font-weight: 600;
    line-height: 1.5;
    margin: 0 0 20px 10px;
  }
  .technologybox3 p span {
    color: red;
    font-size: 19px;
  }
  /*ul.technology_list2.clearfix {
    width: 100%;
    margin: 15px 0 0 0;
  }
  ul.technology_list2.clearfix li {
    width: 120px;
    text-align: center;
    font-size: 20px;
    line-height: 35px;
    float: left;
    margin: 0 0 0 8px;
  }
  ul.technology_list2.clearfix li:first-child {
    margin: 0 0 0 0;
  }*/
  .technologybox3 p.technology_title2 {
    font-size: 19px;
    font-weight: 600;
    color: #193f87;
    line-height: 35px;
    margin: 20px 0 0 10px;
  }
  .technologybox3 p.technology_title3 {
    display: inline-block;
    border-bottom: solid 10px #E2FF11;
    font-size: 19px;
    font-weight: 600;
    line-height: 0.3;
    margin: 0 0 10px 10px;
  }
  .technologybox3 .tecimg {
    margin-bottom: 20px;
  }
  .technologybox3 .tecimg img {
    width: 250px;
  }
  .tecimg span {
    position: relative;
    display: inline-block;
    width: 80px;
    height: 80px;
    background-color: #2f6ab1;
    /*clip-path: polygon(0 33%, 50% 33%, 50% 15%, 100% 50%, 50% 85%, 50% 67%, 0 67%);*/
    clip-path: polygon(25% 100%, 25% 0%, 75% 50%);
    margin: 15% 30px;
  }
  /*-------------
equipment
-------------*/
  .equipmentbox ul {
    width: 100%;
    margin: 15px 0 0 0;
  }
  .equipmentbox ul li {
    width: 241px;
    text-align: center;
    font-size: 15px;
    line-height: 30px;
    float: left;
    margin: 0 18px 15px 0;
  }
  .equipmentbox ul li:nth-child(3n) {
    margin: 0 0 15px 0;
  }
  table.equipment {
    border-collapse: collapse;
    width: 760px;
    font-size: 14px;
    line-height: 20px;
  }
  table.equipment th {
    text-align: justify;
    padding: 5px 5px 5px 5px;
    background-color: #282828;
    color: #fff;
    border: solid 1px #c1c1c1;
    font-weight: 500;
  }
  table.equipment td {
    padding: 5px 5px 5px 5px;
    border: solid 1px #c1c1c1;
  }
  table.equipment th:nth-child(4) {
    width: 100px;
  }
  table.equipment th:nth-child(5) {
    text-align: center;
    width: 50px;
    padding: 5px 0 5px 0;
  }
  table.equipment td:nth-child(5) {
    text-align: center;
    width: 50px;
    padding: 5px 0 5px 0;
  }
  /*-------------
product
-------------*/
  ul.product_list.clearfix {
    width: 100%;
    margin: 15px 0 0 0;
  }
  ul.product_list.clearfix li {
    width: 241px;
    text-align: center;
    font-size: 15px;
    line-height: 30px;
    float: left;
    margin: 0 18px 15px 0;
  }
  ul.product_list.clearfix li:nth-child(3n) {
    margin: 0 0 15px 0;
  }
  /*-------------
movie
-------------*/
  p.movietext {
    font-size: 15px;
    margin: 0 0 20px 0;
  }
  .moviebox {
    text-align: center;
    margin: 0 0 10px 0;
  }
  /*-------------
faq
-------------*/
  p.faq_text {
    margin: 25px 0 0 13px;
  }
  ul.faq_list.clearfix {
    width: 100%;
    margin: 20px 0 0 0;
  }
  ul.faq_list.clearfix li {
    line-height: 30px;
    border-bottom: dotted 1px #c1c1c1;
    margin: 0 0 12px 0;
    padding: 0 0 0 13px;
  }
  ul.faq_list.clearfix li p {
    color: #e80000;
    font-weight: 600;
  }
  ul.faq_list.clearfix li p.annotation_text {
    color: #282828;
    line-height: 1.5;
    font-weight: 400;
  }
  ul.faq_list.clearfix li table {
    width: 480px;
    border-collapse: collapse;
    margin: 0 0 5px 0;
  }
  ul.faq_list.clearfix li table th, ul.faq_list.clearfix li table td {
    width: 160px;
    border: solid 1px;
    padding: 0 0 0 10px;
  }
  /*-------------
flow
-------------*/
  ul.flowlist.clearfix {
    width: 100%;
  }
  ul.flowlist.clearfix li {
    float: left;
    height: 280px;
    line-height: 20px;
  }
  ul.flowlist.clearfix li img {
    margin: 0 0 10px 0;
  }
  ul.flowlist.clearfix li:nth-child(odd) {
    width: 150px;
  }
  ul.flowlist.clearfix li p {
    font-size: 15px;
    color: #1c72e9;
    font-weight: 600;
    line-height: 36px;
    margin: 0 0 15px 0;
  }
  ul.flowlist.clearfix li p img {
    margin: 0 5px 0 0;
  }
  ul.flowlist.clearfix li:nth-child(even) {
    width: 50px;
    height: 50px;
    text-align: center;
    margin: 100px 0 0 0;
  }
  ul.flowlist.clearfix li:nth-child(8), ul.flowlist.clearfix li:nth-child(16) {
    display: none;
  }
  /*-------------
contact
-------------*/
  p.contacttext {
    font-size: 14px;
    line-height: 22px;
    padding: 0 0 0 10px;
  }
  p.contacttext a {
    color: #ff0000;
    text-decoration: underline;
  }
  p.contacttext a:hover {
    text-decoration: none;
  }
  #contact .form {
    clear: both;
  }
  #contact .form table {
    border-collapse: collapse;
    width: 100%;
    margin: 20px 0 0 0;
  }
  #contact .form table th, #contact .form td {
    line-height: 25px;
    border-bottom: dotted 1px #c1c1c1;
  }
  #contact .form table th {
    width: 150px;
    padding: 10px 0 5px 100px;
    text-align: left;
    font-size: 12px;
    font-weight: 500;
    vertical-align: top;
    letter-spacing: 1px;
  }
  #contact .form td {
    padding: 5px 0 5px 14px;
  }
  #contact .form td input#companyname, #contact .form td input#name, #contact .form td input#department {
    width: 400px;
    height: 25px;
    font-size: 12px;
    padding: 0 0 0 5px;
    background-color: #e6e6e6;
    border: none;
    margin: 5px 0;
  }
  #contact .form td input#mail, #contact .form td input#adress {
    width: 450px;
    height: 25px;
    font-size: 12px;
    padding: 0 0 0 5px;
    background-color: #d6d6d6;
    border: none;
    margin: 5px 0;
  }
  #contact .form td input#tel, #contact .form td input#adress_code, #contact .form td input#prefectures {
    width: 300px;
    height: 25px;
    font-size: 12px;
    padding: 0 0 0 5px;
    background-color: #d6d6d6;
    border: none;
    margin: 5px 0;
  }
  #contact .form td textarea#comment {
    width: 500px;
    height: 200px;
    font-size: 12px;
    background-color: #d6d6d6;
    border: none;
    margin: 5px 0;
  }
  #contact .form #formEnd {
    text-align: center;
    margin: 5px 0 60px 0;
  }
  #contact .form #formEnd button {
    margin: 10px -5px 0;
    border: 0;
    background-color: #fff;
  }
  #contact .form #formEnd button:hover {
    opacity: 0.8;
  }
  ul.personal_list {
    width: 100%;
    line-height: 21px;
  }
  ul.personal_list li {
    margin: 0 0 15px 35px;
    text-indent: -2em;
  }
}
/* Tablet */
@media screen and (max-width: 768px) {
  .pc {
    display: none;
  }
  .sp {
    display: block;
  }
  *::after, * {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
  }
  /*-------------
undermain
-------------*/
  .underlayer_main {
    width: 100%;
    margin: 55px 0 0 0;
    overflow: hidden;
  }
  .underlayer_main_right.clearfix {
    width: 100%;
    margin: 10px 0 30px 0;
    padding: 0 10px;
  }
  h2.banner {
    width: 100%;
    font-size: 20px;
    line-height: 30px;
    border-bottom: solid 3px #c1c1c1;
    margin: 0 0 10px 0;
    padding: 0 0 0 10px;
    letter-spacing: 1px;
  }
  h2.banner img {
    margin: 0 7px -3px 0;
    width: 20px;
  }
  h3.underlayertitle_top {
    width: 100%;
    line-height: 27px;
    font-size: 16px;
    margin: 0 0 15px 0;
    clear: both;
    font-weight: 600;
    letter-spacing: 1px;
    border-bottom: solid 1px #c1c1c1;
    padding: 5px 0 0 0;
  }
  h3.underlayertitle {
    width: 100%;
    line-height: 27px;
    font-size: 16px;
    margin: 20px 0 15px 0;
    clear: both;
    font-weight: 600;
    letter-spacing: 1px;
    border-bottom: solid 1px #c1c1c1;
    padding: 20px 0 0 0;
  }
  h3.underlayertitle:before, h3.underlayertitle_top:before, h3.underlayertitle2:before {
    content: "●";
    padding-right: 7px;
    padding-left: 7px;
  }
  /*-------------
company
-------------*/
  .company {
    width: 50%;
    margin: 10px 0 20px 0;
    float: left;
  }
  .company dt {
    background-color: #eeefef;
    padding: 2px 0 2px 5px;
    text-align: left;
    font-weight: 600;
  }
  .company dd {
    padding: 5px;
  }
  img.companyimg {
    width: 47%;
    max-width: 273px;
    float: right;
  }
  /*-------------
technology
-------------*/
  .technologybox1 {
    background: url(../images/technology/technology_img.png)no-repeat;
    width: 100%;
    margin: 0;
    background-size: contain;
  }
  .technologybox1 p {
    font-size: 15px;
    letter-spacing: 1px;
    font-weight: 600;
    line-height: 26px;
    padding: 28px 0 100px 10px;
    width: 215px;
    margin: 0 0 0 auto;
  }
  ul.technology_list1.clearfix {
    width: 100%;
    margin: 5px 0 0 0;
    overflow: hidden;
  }
  ul.technology_list1.clearfix li {
    float: left;
    width: 47%;
    max-width: 188px;
    margin: 0 2px 0 5px;
  }
  .technologybox2 {
    width: 100%;
    margin: 25px 0 25px 0;
    clear: both;
  }
  p.technology_title {
    font-size: 15px;
    font-weight: 600;
    background-color: #c1c1c1;
    line-height: 35px;
    height: 35px;
    padding: 0 0 0 10px;
    margin: 20px 0 0 0;
    clear: both;
  }
  p.technology_text.clearfix {
    font-size: 13px;
    line-height: 21px;
    width: 100%;
    margin: 10px 0 20px 0;
  }
  .technologybox2 img {
    margin: 15px 0 0 0;
    width: 241px;
  }
  p.technology_text2 {
    font-size: 14px;
    font-weight: 600;
    line-height: 22px;
  }
  /*ul.technology_list2.clearfix {
    width: 100%;
    margin: 15px 0 0 0;
    overflow: hidden;
  }
  ul.technology_list2.clearfix li {
    width: 120px;
    text-align: center;
    font-size: 16px;
    line-height: 21px;
    float: left;
    margin: 0 0 10px 8px;
  }*/
  p.technology_title2 {
    font-size: 16px;
    font-weight: 600;
    color: #193f87;
    line-height: 24px;
    margin: 30px 0 0 0;
    clear: both;
  }
  .technologybox3 p {
    font-size: 15px;
    line-height: 1.5;
    margin: 0 0 20px 10px;
  }
  .technologybox3 p.technology_text2 {
    font-size: 15px;
    font-weight: 600;
    line-height: 1.5;
    margin: 0 0 20px 10px;
  }
  .technologybox3 p span {
    color: red;
  }
  .technologybox3 p.technology_title2 {
    font-size: 19px;
    font-weight: 600;
    color: #193f87;
    line-height: 35px;
    margin: 20px 0 0 10px;
  }
  .technologybox3 p.technology_title3 {
    display: inline-block;
    border-bottom: solid 10px #E2FF11;
    font-size: 19px;
    font-weight: 600;
    line-height: 0.3;
    margin: 0 0 10px 10px;
  }
  .technologybox3 .tecimg {
    margin-bottom: 20px;
  }
  .technologybox3 .tecimg img {
    width: 250px;
  }
  .tecimg span {
    position: relative;
    display: inline-block;
    width: 80px;
    height: 80px;
    background-color: #2f6ab1;
    clip-path: polygon(25% 100%, 25% 0%, 75% 50%);
    margin: 15% 30px;
  }

  /*-------------
equipment
-------------*/
  .equipmentbox ul {
    width: 100%;
    margin: 15px 0 0 0;
    overflow: hidden;
  }
  .equipmentbox ul li {
    max-width: 241px;
    width: 47%;
    text-align: center;
    font-size: 14px;
    line-height: 20px;
    float: left;
    margin: 0 2px 15px 5px;
  }
  .equipmentscroll {
    overflow: auto;
    white-space: nowrap;
    margin: 0 0 30px 0;
  }
  table.equipment {
    border-collapse: collapse;
    width: 100%;
    font-size: 12px;
    line-height: 20px;
  }
  table.equipment th {
    text-align: justify;
    padding: 5px 5px 5px 5px;
    background-color: #282828;
    color: #fff;
    border: solid 1px #c1c1c1;
    font-weight: 500;
  }
  table.equipment td {
    padding: 5px 5px 5px 5px;
    border: solid 1px #c1c1c1;
  }
  table.equipment td:nth-child(5) {
    text-align: center;
  }
  /*-------------
product
-------------*/
  ul.product_list.clearfix {
    width: 100%;
    margin: 15px 0 0 0;
    overflow: hidden;
  }
  ul.product_list.clearfix li {
    max-width: 241px;
    width: 47%;
    text-align: center;
    font-size: 14px;
    line-height: 20px;
    float: left;
    margin: 0 2px 15px 5px;
  }
  /*-------------
movie
-------------*/
  p.movietext {
    font-size: 14px;
    margin: 0 0 20px 0;
  }
  .moviebox {
    text-align: center;
    width: 100%;
    max-width: 400px;
    margin: 0 auto;
  }
  /*-------------
faq
-------------*/
  p.faq_text {
    margin: 10px 0 0 0;
  }
  ul.faq_list.clearfix {
    width: 100%;
    margin: 20px 0 0 0;
  }
  ul.faq_list.clearfix li {
    line-height: 20px;
    border-bottom: dotted 1px #c1c1c1;
    margin: 0 0 12px 0;
    padding: 0 0 5px 5px;
  }
  ul.faq_list.clearfix li p {
    color: #e80000;
    font-weight: 600;
    margin: 0 0 10px 0;
  }
  ul.faq_list.clearfix li p.annotation_text {
    color: #282828;
    line-height: 1.5;
    font-weight: 400;
  }
  ul.faq_list.clearfix li table {
    width: 480px;
    border-collapse: collapse;
    margin: 0 0 5px 0;
  }
  ul.faq_list.clearfix li table th, ul.faq_list.clearfix li table td {
    width: 160px;
    border: solid 1px;
    padding: 0 0 0 10px;
  }
  /*-------------
flow
-------------*/
  ul.flowlist.clearfix.sp {
    display: none;
  }
  ul.flowlist.clearfix.pc {
    display: block;
  }
  ul.flowlist.clearfix {
    width: 100%;
  }
  ul.flowlist.clearfix li {
    float: left;
    height: 280px;
    line-height: 20px;
  }
  ul.flowlist.clearfix li img {
    margin: 0 0 10px 0;
  }
  ul.flowlist.clearfix li:nth-child(odd) {
    width: 150px;
  }
  ul.flowlist.clearfix li p {
    font-size: 15px;
    color: #1c72e9;
    font-weight: 600;
    line-height: 36px;
    margin: 0 0 15px 0;
  }
  ul.flowlist.clearfix li p img {
    margin: 0 5px -13px 0;
    width: 36px;
  }
  ul.flowlist.clearfix li:nth-child(even) {
    width: 10px;
    height: 50px;
    text-align: center;
    margin: 100px 7px 130px 7px;
  }
  /*-------------
contact
-------------*/
  p.contacttext {
    font-size: 14px;
    line-height: 22px;
  }
  p.contacttext a {
    color: #ff0000;
    text-decoration: underline;
  }
  p.contacttext a:hover {
    text-decoration: none;
  }
  #contact .form {
    clear: both;
  }
  #contact .form table {
    border-collapse: collapse;
    width: 100%;
    margin: 20px 0 0 0;
  }
  #contact .form table th, #contact .form td {
    line-height: 23px;
    border-bottom: dotted 1px #c1c1c1;
  }
  #contact .form table th {
    width: 35%;
    padding: 10px;
    text-align: left;
    font-size: 14px;
    font-weight: 500;
    vertical-align: top;
    letter-spacing: 1px;
  }
  #contact .form td {
    padding: 10px;
  }
  #contact .form td input#companyname, #contact .form td input#name, #contact .form td input#department {
    width: 100%;
    height: 25px;
    font-size: 12px;
    padding: 0 0 0 5px;
    background-color: #e6e6e6;
    border: none;
    margin: 5px 0;
  }
  #contact .form td input#mail, #contact .form td input#adress {
    width: 100%;
    height: 25px;
    font-size: 12px;
    padding: 0 0 0 5px;
    background-color: #d6d6d6;
    border: none;
    margin: 5px 0;
  }
  #contact .form td input#tel, #contact .form td input#adress_code, #contact .form td input#prefectures {
    width: 100%;
    height: 25px;
    font-size: 12px;
    padding: 0 0 0 5px;
    background-color: #d6d6d6;
    border: none;
    margin: 5px 0;
  }
  #contact .form td textarea#comment {
    width: 100%;
    height: 200px;
    font-size: 12px;
    background-color: #d6d6d6;
    border: none;
    margin: 5px 0;
  }
  #contact .form #formEnd {
    text-align: center;
    margin: 5px 0 30px 0;
  }
  #contact .form #formEnd button {
    margin: 10px -5px 0;
    border: 0;
    background-color: #fff;
  }
  ul.personal_list {
    width: 100%;
    line-height: 21px;
  }
  ul.personal_list li {
    margin: 0 0 15px 35px;
    text-indent: -2em;
  }
}
/* SP */
@media screen and (max-width: 480px) {
  .pc {
    display: none;
  }
  .sp {
    display: block;
  }
  * {
    margin: 0;
    padding: 0;
  }
  *::after, * {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
  }
  /*-------------
undermain
-------------*/
  .underlayer_main {
    width: 100%;
    margin: 55px 0 0 0;
    overflow: hidden;
  }
  .underlayer_main_right.clearfix {
    width: 100%;
    margin: 10px 0 30px 0;
    padding: 0 10px;
  }
  h2.banner {
    width: 100%;
    font-size: 20px;
    line-height: 30px;
    border-bottom: solid 3px #c1c1c1;
    margin: 0 0 10px 0;
    padding: 0 0 0 10px;
    letter-spacing: 1px;
  }
  h2.banner img {
    margin: 0 7px -3px 0;
    width: 20px;
  }
  h3.underlayertitle_top {
    width: 100%;
    line-height: 27px;
    font-size: 16px;
    margin: 0 0 15px 0;
    clear: both;
    font-weight: 600;
    letter-spacing: 1px;
    border-bottom: solid 1px #c1c1c1;
    padding: 5px 0 0 0;
  }
  h3.underlayertitle {
    width: 100%;
    line-height: 22px;
    font-size: 16px;
    margin: 20px 0 15px 0;
    clear: both;
    font-weight: 600;
    letter-spacing: 1px;
    border-bottom: solid 1px #c1c1c1;
    padding: 20px 0 0 23px;
    text-indent: -1.9em;
  }
  h3.underlayertitle:before, h3.underlayertitle_top:before, h3.underlayertitle2:before {
    content: "●";
    padding-right: 7px;
    padding-left: 7px;
  }
  /*-------------
company
-------------*/
  .company {
    width: 100%;
    margin: 10px 0 20px 0;
    float: none;
  }
  .company dt {
    background-color: #eeefef;
    padding: 2px 0 2px 5px;
    text-align: left;
    font-weight: 600;
  }
  .company dd {
    padding: 5px;
  }
  img.companyimg {
    width: 273px;
    float: none;
  }
  /*-------------
technology
-------------*/
  .technologybox1 {
    background: url(../images/technology/technology_img_sp.png)no-repeat;
    width: 100%;
    margin: 0;
    background-size: cover;
  }
  .technologybox1 p {
    font-size: 13px;
    letter-spacing: 1px;
    font-weight: 600;
    line-height: 22px;
    color: #fff;
    padding: 35px 0 80px 0;
    width: 255px;
    margin: 0 0 0 auto;
  }
  ul.technology_list1.clearfix {
    width: 100%;
    margin: 5px 0 0 0;
    overflow: hidden;
  }
  ul.technology_list1.clearfix li {
    float: left;
    width: 47%;
    max-width: 188px;
    margin: 0 2px 0 5px;
  }
  .technologybox2 {
    width: 100%;
    margin: 25px 0 25px 0;
    clear: both;
  }
  p.technology_title {
    font-size: 15px;
    font-weight: 600;
    background-color: #c1c1c1;
    line-height: 35px;
    height: 35px;
    padding: 0 0 0 10px;
    margin: 20px 0 0 0;
    clear: both;
  }
  p.technology_text.clearfix {
    font-size: 13px;
    line-height: 21px;
    width: 100%;
    margin: 10px 0;
  }
  .technologybox2 img {
    margin: 15px 0 0 0;
    width: 241px;
  }
  p.technology_text2 {
    font-size: 14px;
    font-weight: 600;
    line-height: 22px;
  }
  /*ul.technology_list2.clearfix {
    width: 100%;
    margin: 15px 0 0 0;
    overflow: hidden;
  }
  ul.technology_list2.clearfix li {
    width: 120px;
    text-align: center;
    font-size: 16px;
    line-height: 21px;
    float: left;
    margin: 0 0 10px 8px;
  }*/
  p.technology_title2 {
    font-size: 16px;
    font-weight: 600;
    color: #193f87;
    line-height: 24px;
    margin: 30px 0 0 0;
    clear: both;
  }
  .technologybox3 p {
    font-size: 13px;
    line-height: 1.5;
    margin: 0 0 20px 10px;
  }
  .technologybox3 p.technology_text2 {
    font-size: 16px;
    font-weight: 600;
    line-height: 1.5;
    margin: 0 0 20px 10px;
  }
  .technologybox3 p span {
    color: red;
    font-size: 18px;
  }
  .technologybox3 p.technology_title2 {
    font-size: 19px;
    font-weight: 600;
    color: #193f87;
    line-height: 1.5;
    margin: 20px 0 0 10px;
  }
  .technologybox3 p.technology_title3 {
    display: inline-block;
    border-bottom: solid 10px #E2FF11;
    font-size: 19px;
    font-weight: 600;
    line-height: 0.3;
    margin: 0 0 10px 10px;
  }
  .technologybox3 .tecimg {
    width: 250px;
    display: block;
    margin: 0 auto 20px auto;
  }
  .technologybox3 .tecimg img {
    width: 250px;
  }
  .tecimg span {
    position: relative;
    display: block;
    width: 60px;
    height: 60px;
    background-color: #2f6ab1;
    clip-path: polygon(50% 75%, 0% 25%, 100% 25%);
    margin: 15px auto 15px auto;
  }
  /*-------------
equipment
-------------*/
  .equipmentbox ul {
    width: 100%;
    margin: 15px 0 0 0;
    overflow: hidden;
  }
  .equipmentbox ul li {
    max-width: 241px;
    width: 47%;
    text-align: center;
    font-size: 13px;
    line-height: 20px;
    float: left;
    margin: 0 2px 15px 5px;
  }
  .equipmentscroll {
    overflow: auto;
    white-space: nowrap;
    margin: 0 0 30px 0;
  }
  table.equipment {
    border-collapse: collapse;
    width: 100%;
    font-size: 12px;
    line-height: 20px;
  }
  table.equipment th {
    text-align: justify;
    padding: 5px 5px 5px 5px;
    background-color: #282828;
    color: #fff;
    border: solid 1px #c1c1c1;
    font-weight: 500;
  }
  table.equipment td {
    padding: 5px 5px 5px 5px;
    border: solid 1px #c1c1c1;
  }
  table.equipment td:nth-child(5) {
    text-align: center;
  }
  /*-------------
product
-------------*/
  ul.product_list.clearfix {
    width: 100%;
    margin: 15px 0 0 0;
    overflow: hidden;
  }
  ul.product_list.clearfix li {
    max-width: 241px;
    width: 47%;
    text-align: center;
    font-size: 13px;
    line-height: 20px;
    float: left;
    margin: 0 2px 15px 5px;
  }
  /*-------------
movie
-------------*/
  p.movietext {
    font-size: 14px;
    margin: 0 0 20px 0;
  }
  .moviebox {
    text-align: center;
    width: 100%;
    max-width: 400px;
    margin: 0 auto;
  }
  /*-------------
faq
-------------*/
  p.faq_text {
    margin: 10px 0 0 0;
  }
  ul.faq_list.clearfix {
    width: 100%;
    margin: 20px 0 0 0;
  }
  ul.faq_list.clearfix li {
    line-height: 20px;
    border-bottom: dotted 1px #c1c1c1;
    margin: 0 0 12px 0;
    padding: 0 0 5px 5px;
  }
  ul.faq_list.clearfix li p {
    color: #e80000;
    font-weight: 600;
    margin: 0 0 10px 0;
  }
  ul.faq_list.clearfix li p.annotation_text {
    color: #282828;
    line-height: 1.5;
    font-weight: 400;
  }
  ul.faq_list.clearfix li table {
    width: 100%;
    border-collapse: collapse;
    margin: 0 0 5px 0;
  }
  ul.faq_list.clearfix li table th, ul.faq_list.clearfix li table td {
    width: 32%;
    border: solid 1px;
    padding: 0 0 0 10px;
  }
  /*-------------
flow
-------------*/
  ul.flowlist.clearfix.sp {
    display: block;
  }
  ul.flowlist.clearfix.pc {
    display: none;
  }
  ul.flowlist.clearfix {
    width: 100%;
  }
  ul.flowlist.clearfix li {
    float: none;
    height: auto;
    line-height: 20px;
  }
  ul.flowlist.clearfix li img {
    margin: 0 0 10px 0;
  }
  ul.flowlist.clearfix li:nth-child(odd) {
    width: 150px;
  }
  ul.flowlist.clearfix li p {
    font-size: 15px;
    color: #1c72e9;
    font-weight: 600;
    line-height: 36px;
    margin: 0 0 15px 0;
  }
  ul.flowlist.clearfix li p img {
    margin: 0 5px -13px 0;
    width: 36px;
  }
  ul.flowlist.clearfix li:nth-child(even) {
    width: 15px;
    margin: 20px 0 0 65px;
  }
  /*-------------
contact
-------------*/
  p.contacttext {
    font-size: 13px;
    line-height: 21px;
  }
  p.contacttext a {
    color: #ff0000;
    text-decoration: underline;
  }
  p.contacttext a:hover {
    text-decoration: none;
  }
  #contact .form {
    clear: both;
  }
  #contact .form table {
    border-collapse: collapse;
    width: 100%;
    margin: 20px 0 0 0;
  }
  #contact .form table th, #contact .form td {
    line-height: 23px;
    border-bottom: dotted 1px #c1c1c1;
  }
  #contact .form table th {
    width: 35%;
    padding: 5px;
    text-align: left;
    font-size: 12px;
    font-weight: 500;
    vertical-align: top;
    letter-spacing: 1px;
  }
  #contact .form td {
    padding: 5px;
  }
  #contact .form td input#companyname, #contact .form td input#name, #contact .form td input#department {
    width: 100%;
    height: 25px;
    font-size: 12px;
    padding: 0 0 0 5px;
    background-color: #e6e6e6;
    border: none;
    margin: 5px 0;
  }
  #contact .form td input#mail, #contact .form td input#adress {
    width: 100%;
    height: 25px;
    font-size: 12px;
    padding: 0 0 0 5px;
    background-color: #d6d6d6;
    border: none;
    margin: 5px 0;
  }
  #contact .form td input#tel, #contact .form td input#adress_code, #contact .form td input#prefectures {
    width: 100%;
    height: 25px;
    font-size: 12px;
    padding: 0 0 0 5px;
    background-color: #d6d6d6;
    border: none;
    margin: 5px 0;
  }
  #contact .form td textarea#comment {
    width: 100%;
    height: 200px;
    font-size: 12px;
    background-color: #d6d6d6;
    border: none;
    margin: 5px 0;
  }
  #contact .form #formEnd {
    text-align: center;
    margin: 5px 0 30px 0;
  }
  #contact .form #formEnd button {
    margin: 10px -5px 0;
    border: 0;
    background-color: #fff;
  }
  ul.personal_list {
    width: 100%;
    line-height: 21px;
  }
  ul.personal_list li {
    margin: 0 0 15px 35px;
    text-indent: -2em;
  }
}