body {
 counter-reset: number 0;
}
#logo {
 width:200px;
 height:auto;
 }
#header {
 position:fixed;
 top:0px;
 left:0px;
 width:100%;
 }
#header span {
 position:relative;
 top:-17px;
 left:5px;
 color:#0066cc;
}
#menu {
 position:absolute;
 top:10px;
 right:90px;
}
.cta_btn a {
 display:block;
 }
h1.main_catch {
  font-size:55px;
  padding:0px;
  color:orange;
}
#under_h1 {
 font-size:18px;
 margin-top:10px;
 }
h1.main_catch span.cy{
 color:yellow;
}
span.cred {
 color:red;
}
h1.main_catch span.cred {
  color:red;
  text-shadow:
   2px -3px 14px #fff,
   2px 3px 2px #fff,
   -2px -2px 0 #fff,
   1px 0px 0 #fff;
 }
h1#main_catch_item {
  font-size:40px;
  color:#1996d3;
 }
h1#main_catch_item br{
 display:none;
}
span.hira {
 font-size:45px;
 font-weight:normal;
}
span.fv_nayami {
  color:red;
  font-weight:bold;
  display:block;
}
/*
span.fv_nayami::before {
   content: '> ';
}*/
h1.main_catch span.big{
  font-size:60px;
  color:red;
}
span.rank {
  font-size:15px;
  color:white;
  background:#1996d3;
  border-radius:5px;  
  padding:5px;
  display:inline-block;
  margin-top:20px;
  margin-left:10px;
}
p.exp {
 font-size:11px;
 color:#333;
 margin-top:30px !important;
 }
#under_fv {
 color:#1996d3;
 font-size:40px;
 text-align:center;
 margin:0px auto 30px auto;
 font-weight:bold;
}
span#semi {
 display: inline-block;
 background: orangered;
 color: white;
 padding: 5px;
 border-radius: 5px;
 font-size:16px;
 font-weight:normal;
 position:relative;
 top:-10px;
 left:10px;
}
#sokode {
 border: 20px solid #0066cc;
 margin:60px auto;
 padding-right:5px;
}
 #profile_area {
  margin-top:60px;
 }
div.pbox, 
h2.pbox {
 font-size:280%;
 color:#1996d3;
 margin:30px;
 text-align:center;
}
div.pbox {
 font-size:50px;
}
.inner {
 width:96%;
}
img.catch_icon {
 display:block;
 margin:auto;
 }
.body {
 width:80%;
 margin-top:0px !important;
}
section.inquiry {
 margin:50px auto;
 text-align:center;
}
section.inquiry p {
 margin-top:5px;
}
#under_fix { 
 display:none;
}



.inquiry_btn {
    position: fixed;
    top: 10px;
    right: 50px;
    color: white;
    border-radius: 10px;
    font-size: 120%;
    padding: 10px;
}
.inquiry_btn .btn {
  padding: 10px;
  border-radius: 5px;
  margin-right: 10px;
 }

.inquiry_btn #header_doc_btn {
 background:green;
 color:white;
}
.body {
  width:80%;
 }
.body p {
  font-size:110%;
  margin-top:15px;
  line-height:200%;
 }
.body ul, .body ol {
  margin: 20px;
  font-size: 110%;
  line-height: 180%;
  font-weight:normal;
 }
 section {
  margin:100px 0px 50px 0px;
  }
 section h3 {
  font-size:200%;
  margin-bottom:30px; 
 }
 #sokode h3 {
  font-size:100%;
  }
 #top_section {
  width:80%;
  margin:auto;
  margin-top:49px;
  display: flex;
 }
 #form {
  flex:3;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.5);
  border-radius:10px;
  padding:10px;
 }
 #fv {
  padding-top:50px;
  padding-bottom:50px;
  margin:auto;
  flex:7;
  /*
  background-image: url(https://cat-marketing.jp/wp-content/uploads/main_img_name.webp);
  background-repeat: no-repeat;
  border-bottom: 1px solid #ccc;
  background-position: right;
  background-size: contain;
  */
 }
 .fv_text{
  display: block;
  margin: 10px 0px 30px 0px;
  font-size: 28px;
  color:#1996d3;
 }
/* .fv_text br {
  display:none;
 }
 */
 .fv_text .mark {
  display: block;
  width: 200px;
  background: red;
  border-radius: 10px;
  padding: 5px;
  color: white;
  text-align: center;
  margin-top: 10px;
 }
 #fv-profile-btn{
  color:white;
  }
 #profile_img {
  width:30%;
  height:auto;
  display:block;
  float:left;
  margin-right:5%;
  }
 
 #ec_operation {
  margin-top:0px;
  margin-bottom:0px;
 }
 #ec_operation h2 {
  text-align:center;
  margin-bottom:20px;
  text-align: center;
  margin-bottom: 20px;
  padding: 5px;
  border-radius: 5px;
 }
 img#triangle_icon{
  display:block;
  margin:auto;
 }
 .icon_face {
  width: auto !important;
  height: 100px !important;
 }
 #main_service div {
  width:31.9%;
  float:left;
 }
 #main_service div img{
  display:block;
  margin:auto;
  margin-bottom:5px;
  width:120px;
  height:auto;
 }
 .exp_p {
  font-size:28px;
  text-align:center;
  margin-bottom:80px;
  border:1px solid #ccc;
  padding:1%;
 }
 #effect > div {
   width:28%;
   float:left;
   margin-right:3%;
   padding:1%;
   box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.1);
   border: 1px solid #eee;
   border-radius:5px;
 }
 #function ul {
  list-style:none !important;
  margin:0px !important;
 }
 #function ul li {
  float:left;
  width:31.9%;
  padding:1%;
  font-size:18px;
  border:1px solid #ccc;
  min-height:150px;
  margin-right:1%;
  border-radius:5px;
  }
 #function ul li span {
  display:block;
  font-weight:bold;
  color:#1996d3;
}
  
 #auto_order {
   width: 100%;
   height: auto;
  }
 .video_tag {
  border:1px solid #333;
 }

 .cta_btn {
  background:green !important;
  }

 #three_point div{
  width:30%;
  float:left;
  margin-right:2.9%;
 }
 #three_point section:first-of-type{
  position:relative;
  top:70px;
 }
 #three_point div.solution {
  color: #1996d3;
  text-align: center;
  font-size:24px;
  width:100%;
 }
 #three_point .kakomi{
  border:1px solid #ccc;
  border-radius:10px;
  padding:1%;
  width:98%;
  box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.1);
  min-height:280px;
  }
 section ul {
  list-style:disc;
  margin-left:35px;
 }
 section li {
  margin-bottom:10px;
 }
 #three_point div p{
  font-size:110%;
  margin-top:5px;
 }
 .chatwork_click{
  text-align:center;
  margin-top:10px;
  display:block;
  }
 #api_block .right section{
  margin-top:0px;1
 }
 .front_back {
  width:100%;
  display: -webkit-flex;
  display: flex;
 }
 .front_back #marketing {
   background-image: url("https://cat-marketing.jp/wp-content/uploads/office_operation.webp");
  }
 .front_back #backoffice {
   background-image: url("https://cat-marketing.jp/wp-content/uploads/auto_order2.webp");
  }
 .front_back > div {
   background-size:30%;
   background-repeat:no-repeat;
   background-position: right bottom;
  }

 .front_back h3 span {
  display:block;
  color: white;
  background: #1996d3;
  text-align: center;
  margin-bottom: 10px;
  border-radius: 5px;
  padding: 1%;
 }
 .front_back div {
  width:49%;
  margin-right:1%;
  border:1px solid #ccc;
  padding:1%;
  border-radius:10px;
  }
 .front_back div ul li span  {
  background:orangered;
  color:white;
  padding:1px;
  margin-left: 15px;
  font-size: 13px;
  display:inline-block;
  border-radius:5px;
 }
 h3.red {
  color:orangered;
 }
 h3.blue {
  color:#1996d3;
 }
 /*
 div h4{
  flex-flow: nowrap;
  align-items: center;
  display:flex;
  text-align:left;
  font-size:26px;
  line-height:160%;
 } */
 span.number_icon{
  margin-right:10px;
  font-size:250%;
  color:#1996d3;
 }
 .nayami span.number_icon{
  color:red;
 }

 .note p {
  font-size:90%;
 }
 table {
  width:100%;
 }
 .service .left {
  width:36%;
  float:left;
  margin-right:4%;
 }
 .service .right{
  width:58%;
  float:left;
 }
 .right > div{
  box-shadow:0px 5px 15px 0px rgba(0, 0, 0, 0.1);
  border:1px solid #eee;
  padding:3%;
 }

 section div {
  margin-bottom:30px;
 }
 .left h3 {
  border-bottom:1px solid #1996d3;
  padding-bottom:3px;
 }
 .left h3 span{
  display:inline-block;
  font-size:16px;
  margin-left:15px;
 }
 .right section p {
  margin-bottom:30px;
  }
 .right section h4 {
   border-bottom: 1px solid #ccc;
   color:#1996d3;
   padding-bottom:5px;
 }
 .service hr {
  clear:both;
  }
 .nayami h4 {
  color:red !important;
  font-familly:serif;
  font-weight:normal;
  line-height:160%;
  font-size:27px;
 }
 #achive h3 {
  border-bottom: 1px solid #1996d3;
  padding-bottom:3px;
 }
 #achive hr {
   margin-bottom:30px;
 }
 #jisseki section {
  clear:both;
 }
 #jisseki .right,
 #jisseki .left {
  width:47%;
  margin-right:2.9%;
  float:left;
 }
 #jisseki h4 {
  margin-bottom:20px;
 }
 #jisseki h5 {
  border-bottom: 1px dotted #ccc;
 }
 #jisseki .left h5 {
  color:red;
  font-size:20px;
 }
 #jisseki .right h5 {
  margin-top:30px;
  color:#0066cc;
  font-size:20px;
 }
 .img_center {
   display:block;
   margin:30px auto;
  }
 img.robot_img {
  width:50%;
  height:auto;
 }
 .cta .left {
  width:42%;
  float:left;
  margin-right:4%;
 }
 .cta .right{
  width:52%;
  float:left;
 }
 #doc_btn, #inquiry_btn {
  position:relative;
  top:50px;
  }
 #service_consulting{
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
 }
 #service_consulting table, 
 #compare_table table,
 #function table{
  text-align:center;
  margin:20px 0px;
  width: 100%;
  border-collapse: collapse;
  min-width: 420px; /* 適宜調整 */
  }

 #service_consulting table th {
  background:#eee;
 }
 #service_consulting table td{
  text-align:left;
 }
 #service_consulting table tr th:first-child,
 #service_consulting table tr td:first-child{
  background:#eee;
  color:#333;
 }
 #service_consulting table th,
 #service_consulting table td{
   background:#1996d3;
   color:white;
 }
 #service_consulting table th.semi,
 #service_consulting table td.semi{
   background:orangered;
 }
 span.rec {
  background:orangered;
  color:white;
  padding:3px;
  border-radius:5px;
  }

 #service_consulting table th,
 #service_consulting table td,
 #function table td,
 #function table th {
  border:1px solid #ccc;
  padding:3px;
 }
 #function table caption{
  background:#ccc;
  padding:3px;
  font-weight:bold;
 }
 #function table th img{
  height:40px;
  width:auto;
 }
 #function table th.cat {
  width:150px;
 }
 #function table th.mall {
  width:60px;
 }
 #function tr th,
 #function tr.under td {
  border-bottom:2px solid #333;
  }

#compare_table table td, 
#compare_table table th{
 background-color:#1996d3;
 color:white;
 width:24%;
 border:1px solid #fff;
 padding:0.5%;
}
#compare_table table .se{
 background-color:orangered;
}

.profile_btn {
 text-decoration:underline;
}
.profile_btn:hover {
 text-decoration:none;
}
#profile a {
 background: green;
 color: white;
 padding: 5px;
 border-radius: 5px;
}
#profile h3 {
 border:0px;
 }
#api-ecimg {
 display:block;
 margin:auto;
}



#api-service h3, .mark h3{
 font-size: 40px;
 color: #1996d3;
 text-align: center;
 border-top: 1px solid #ccc;
 border-bottom: 1px solid #ccc;
 padding: 10px;
}
#api-service > div {
 width:49%;
 float:left;
 }
#api-service h4{
 font-size:24px;
 margin-bottom:10px;
}
#api-service > div img {
 width:auto;
 height:445px;
}
#circle_img {
 display:block;
 margin:10px auto;
 width:600px;
 height:auto;
}

p.pbox {
 margin:auto;
 padding:5px;
 font-weight:bold;
 text-align:center;
 color:#1996d3;
 font-size:40px;
 }
.under_pbox {
 text-align:center;
 font-size:26px !important;
 margin-bottom:30px;
 color:orangered;
 font-weight:bold;
 }

#ec_page {
 margin:80px 0px;
 }
#ec_page h3 {
 font-size:250%;
 margin-bottom:20px;
 }
.img_block {
 margin:15px 0px;
 }
 #main_img {
  width:1000px;
  display:block;
  margin:auto;
 }
 h3 span.icon {
  background-color:#1996d3;
  color:white;
  display:block;
  font-size:14px;
  font-weight:normal;
  padding:3px;
  border-radius:5px;
  margin-bottom:5px;
  font-weight:normal;
  width:300px;
  text-align:center;
 }
 #image-icon {
  position:fixed;
  bottom:50px;
  left:2%;
  border-radius:5px;
  background: rgb(0 0 0 / 10%);
  padding:5px;
 }
 #disp_none_btn {
  position: absolute;
  top: 0px;
  right: 0px;
  height: 20px;
  width: 20px;
  text-align: center;
  background: white;
  border: 1px solid #ccc;
  border-top: 0px;
  border-right: 0px;
 }
 .hide {
    display: none;
 }
 .recommend_pop1 {
  position:fixed;
  bottom:30px;
  border:1px solid #ccc;
  border-radius:5px;
  left:1%;
  box-shadow:5px 5px 5px #ccc;
 }
 span.signature {
  font-size: 11px;
  margin-top: 10px;
  display: block;
  font-weight: bold;
 }
 .price_table td, .price_table th {
  border: 1px solid #ccc;
  padding: 10px;
 }
 #price_system {
  text-align: center;
  margin: 30px;
  font-size: 24px;
  font-weight: bold;
 }
 #point_three div{
  margin-top:30px;
 }
 #point_three div h4{
  font-size:140%;
 }
 .recent {
  margin-top: 60px;
  text-align: left;
  margin-bottom: 30px;
 }
 .recent ul {
  margin:10px 0px !important;
  list-style:none !important;
 }

 /*ベース*/
 .toggle {
   display: none;
  }
 .Label {		/*タイトル*/
  display: block;
  font-weight:bold;
  font-size:125%;
  text-decoration:underline;
 }
 .Label:hover {
   text-decoration:none;
  }
 .Label::before{		/*タイトル横の矢印*/
  content:"";
  width: 6px;
  height: 6px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  -webkit-transform: rotate(45deg);
  position: absolute;
  top:calc( 50% - 3px );
  right: 20px;
  transform: rotate(135deg);
 }
 .Label,
 .content {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  transform: translateZ(0);
  transition: all 0.3s
 }
 .content {		/*本文*/
  height: 0;
  margin-bottom:30px;
  padding:0 20px;
  overflow: hidden;
 }
 .toggle:checked + .Label + .content {	/*開閉時*/
  height: auto;
  padding:20px ;
  transition: all .3s;
 }
 .toggle:checked + .Label::before {
  transform: rotate(-45deg) !important;
 }
 .rpa_block {
  width:47%;
  float:left;
  margin-right:2.8%;
  }
 .rpa_block h4{
  font-size:24px;
 }
 img#api_img {
  display:block;
  margin:auto;
  width:100%;
  height:auto;
  }
 p.marking{
  text-align:center;
 }
 div.marking {
  text-align:center;
  border: 1px solid #ccc;
  width: 90%;
  margin: auto;
 }
 #profile-btn {
  display:none;
 }
 span.btn_primary {
  background:#1996d3;
  display:block;
  margin:auto;
  width:240px;
  padding:10px;
  font-size:20px;
  text-align:center;
  border-radius:5px;
  margin-bottom:90px;
 }
 span.btn_primary a {
  color:white !important;
  }

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

 .container {
  height: 100vh;
  overflow: auto;
  scroll-snap-type: y  mandatory;
 }
 #header span {
  top:-12px;
 }
 #top_section {
  width:90%;
  margin-top:10px;
 }
 section {
  scroll-snap-align: start;
  height: 100vh;
  clear:both;
  scroll-margin: 60px 0 0 0
 }
 section div {
  width:96%;
  margin:2%;
  }
 #sokode {
  width:auto !important;
  }
 section.block_head{
  display:none;
 }
 #profile_area {
  margin-top:130px;
 }
 h1#main_catch_item {
  font-size:35px;
  margin-top:30px;
  line-height:130%;
 }
 h1#main_catch_item br{
  display:inline-block;
 }
 span#semi{
  position:static;
 }
 #fv {
  min-height:120px;
  width:100%;
  padding:0px;
  margin-top:30px;
  }
 #fv br {
  display:inline;
  }
 .p_catch {
  color:#1996d3;
  font-size:30px !important;
  font-weight:bold;
  text-align:center;
 }
 .fv_text {
  font-size:24px;
  margin:20px auto auto auto;
  height:60px;
  text-align:center;
 }
 .fv_text br {
  display:inline-block;
 }
 h1.main_catch > .hira,
 .fv_text > .hira {
  font-size:24px;
 }
 #fv_btn {
  width:96%;
  margin:auto;
 }
 #fv_btn li {
  width:47%;
  float:left;
  margin-right:2%;
  border:1px solid #ccc;
  border-radius:5px;
 }
 #fv_btn li a{
  font-size:30px;
 }
 #main_service div {
  width:100%;
  float:none;
  padding:0px;
  margin-bottom:50px;
 }
 .front_back {
  display:block;
  }
 .front_back div {
  width:100%;
  margin:0px;
  }
 #api-ecimg {
  width: 100%;
  height: auto;
 }
 #concern_article1 {
  width:94%;
  }
 #concern_article1 br{
  display:block;
 }
 #three_point {
  margin-top:30px;
 }
 #three_point div h4::before{
  color:#1996d3;
  position:relative;
  top:50px;
 }
 #three_point h4 {
  margin-bottom:10px;
  font-size:150%;
 }
  
 #three_point div{
  width:96%;
  margin:1%;
 }
 #three_point div p span{
  color:#ed8305;
  font-weight:bold;
 }
 span.rank {
  display:inline-block;
  padding:5px;
  display: block;
  padding: 5px;
  width: 200px;
  margin: auto;
  margin-top: 50px;
  text-align: center;
  }
 #effect > div {
  width:94%;
  float:none;
  padding:3%;
  }
 h3 {
  text-align:center;
 }
 h3 span.icon {
  width:100%;
  font-size:18px;
  margin-bottom:20px;
 }
 #image-icon {
  width:94%;
 }
 #two_point .common{
  background-size: 80%;
  background-position:center 30px;
 }
.balloon1-left {
 width:64%;
}
 #main_img {
  width:100%; 
  display:block;
  margin:auto
 }
 #profile_img {
  width:40%;
  }
 #three_point .kakomi{
  min-height:10px;
  padding-top:10px;
 }
 h1.main_catch br {
  display:block;
 }
 .subp {
  margin:30px 0px;
  padding:10px;
  border-top:1px solid #ccc;
  border-bottom:1px solid #ccc;
  font-weight:bold;
  font-size:130%;
  text-align:center;
 }
 .subp br {
  display:block !important;
  }
 #logo { 
  width:150px !important;
  }
 #header .inquiry_btn {
    position: absolute;
    top: 10px;
    right: 5px;
    color: white;
    border-radius: 10px;
    font-size: 12px;
    padding: 5px 10px;
 }
 .inquiry_btn .btn {
   padding:5px;
   margin-right:5px;
 }
 h1.main_catch {
  margin:0px auto;
  font-size:32px;
  border-bottom:0px;
  background:white;
  color:orange;
  display: block;
  padding:20px 10px 0px 10px;
 }
 h1.main_catch span.big {
  font-size:40px;
  display:block;
  }
 #under_h1 {
  font-size:18px;
  display:block;
  color:#cf8805;
  width:250px;
  margin:auto;
  }
 #under_fv {
  font-size:28px;
  }
 #under_h1 br {
  display:block;
  }
 h2.pbox{
  font-size:200%;
  margin:0px 0px 30px 0px;
 }
 .exp_p {
  font-size:20px;
 }
 p.three_p{
  text-align:center;
 }
 .body {
   width:96%;
   margin-top:30px;
  }
 body p {
  font-size: 115%;
  margin-top: 15px;
  line-height: 160%;
 }
 p.exp {
  font-size:12px;
  }
 p.pbox {
  font-size:180%;
 }
 .fv_text .mark {
   margin:auto;
   margin-top:30px;
 }
 #main .cta_btn {
  margin:30px auto;
  padding:5px;
  font-size:120%;
 }
 #ec_page {
  width:100%;
  min-height:50px;
  margin-top:30px;
 }
 #under_fix ul li {
  width:99%;
 }
 #function ul li {
  float:none;
  width:96%;
  min-height:5px;
 }
 .price_table table {
  width: 94%;
 }
 .body ul {
   margin-top:10px;
   margin-right:0px;
 }
 .body ol {
   margin:10px 0px;
   font-size:20px;
 }
 .kakomi ul {
  margin-left:30px;
 }
 section h3 {
  font-size:130%;
 }
 .profile_link {
  text-align:center;
  font-weight:bold;
  font-size:130%;
 }
 img.meta_img {
  margin-right:5px !important;
 }
 .reason h3,
 div h4{
  justify-content: center;
 }

 section .left h3 {
  font-size:220% !important;
  text-align:left;
  }

 .service .left, 
 .service .right{
  width:90% !important;
  float:none;
 }
 
 #jisseki .right, #jisseki .left {
  width:90% !important;
  float:none;
  margin-bottom:0px;
 }

 .service .right > p,
 .service .left > p {
   margin:3%;
  }
 img.catch_icon {
  width:100%;
  }
 div.pbox {
  font-size:25px;
  margin:15px;
  } 
 div.marking {
  width:87%;
  padding:3%;
  text-align:left;
 }
 #function table th.func {
  width:100px;
 }
 #function table th.cat {
  width:60px;
 }
 #function table th.mall {
  width:40px;
 }
 #function table td.func {
  text-align:left;
  width:40px;
 }
 #circle_img {
  width:100%;
 }
 #inquiry_btn {
  position:static;
  top:0px;
  }
 .img_center {
  width: 340px;
  height: 164px;
 }
 #zaiko_renkei, #item_regist, #auto_order {
  width: 100%;
  height: auto;
 }

 .rpa_block {
  float:none;
  width:100%;
  }

 #ngp ul li{
  float:none;
  width:96%;
  margin:0px 0px 5px 0px;
  padding:2%;
  border-radius:5px;
  min-height:110px;
 }
 #fv p.exp {
  width:96%;
  margin:auto;
  margin-top:10px;
 }
 #under_fix {
  display:block;
  }
 .sp-btn {
  position:fixed;
  width:100%;
  bottom:5px;
  left:5px;
 }
 .sp-btn a{
  height: 56px;
  width: 98%;
  display:block;
  color:black;
  text-align:center;
  border: none;
  border-radius: 4px;
  background: #ffd600;
  background-repeat: no-repeat;
  background-position: right 8px center;
  background-size: 28px 28px;
  font-weight:600;
  line-height:56px;
 }
 #profile-btn {
  left:5px;
  display:inline-block;
 }
 a.high {
  background-color:orangered;
 }
}
