@charset "UTF-8";
body {
  color: #333;
  font-size: 1.4rem;
  font-weight: normal;
  line-height: 1;
}

/* =================================
base
================================= */
* {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  word-break: normal;
}

html, body {
  width: 100%;
  height: 100%;
}

html {
  font-size: 62.5%;
  scroll-behavior: smooth;
}

body {
  overflow-x: hidden;
  min-width: 1040px;
}

p {
  line-height: 1.8;
}

a {
  opacity: 1;
  color: #FF6C00;
  text-decoration: none;
  cursor: pointer;
}

a:hover {
  color: #F9D801;
  transition: .3s;
  opacity: .7;
  text-decoration: none;
}

a:focus,
a.btn:hover {
  text-decoration: none;
}

img {
  width: 100%;
}

input[type="text"],
input[type="email"] {
  padding: 0;
  border: none;
  border-radius: 0;
  outline: none;
  background: none;
}

input[type="checkbox"] {
  cursor: pointer;
}

textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  resize: none;
  padding: 0;
  border: 0;
  outline: none;
  background: transparent;
}

button,
input[type="submit"] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 0;
  border: none;
  outline: none;
  background: transparent;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  padding: 0;
  line-height: 1;
}

ul,
li {
  padding: 0;
  margin: 0;
  list-style: none;
}

button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

/*セレクトボックスの矢印を消す*/
select{
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
}

select::-ms-expand{
display: none;
}

*:focus::-webkit-input-placeholder {
  opacity: 0;
}

*:focus::-moz-placeholder {
  opacity: 0;
}

*:focus:-ms-input-placeholder {
  opacity: 0;
}

*:focus::placeholder {
  opacity: 0;
}

.clearfix::after{
  content: "";
  display: block;
  clear: both;
}

.clearfix::after{
  content: "";
  display: block;
  clear: both;
}

/* =================================
汎用クラスの定義
================================= */
.float-l {
  float: left;
}

.float-r {
  float: right;
}

.bold {
  font-weight: bold;
}

.center {
  text-align: center;
}

.left {
  text-align: left;
}

.inner-wrap {
  width: 1024px;
  margin: 0 auto;
}

.is-sp-only {
  display: none !important;
}

.shadow {
  box-shadow: 4px 4px 7px rgba(0,0,0,0.2);
}

.text-center {
  line-height: 1.8;
}

.rounded {
  border-radius: 8px;
}

/* badge
---------------------------------------------------------- */
.new {
  position: relative;
}

.new:before {
  content: "NEW";
  color: #FF6C00;
  padding-top: 23px;
  width: 60px;
  height: 60px;
  border: 1px solid #FF6C00;
  border-radius: 50%;
  position: absolute;
  top: 120px;
  left: 8%;
}








/* title
---------------------------------------------------------- */
.ttl-xl {
  font-size: 44px;
  font-size: 4.4rem;
  font-weight: bold;
  line-height: 1;
}

.ttl-lg {
  font-size: 28px;
  font-size: 2.8rem;
  line-height: 1;
}

.ttl-md {
  font-size: 24px;
  font-size: 2.4rem;
  line-height: 1;
}

.ttl-sm {
  font-size: 20px;
  font-size: 2.0rem;
  line-height: 1;
}

.txt-lg {
  font-size: 18px;
  font-size: 1.8rem;
  line-height: 1;}

.txt-md {
  font-size: 14px;
  font-size: 1.4rem;
}

.txt-sm {
  font-size: 12px;
  font-size: 1.2rem;
}

.txt-lead {
  line-height: 1.8;
}

.txt-bl {
  color: #1275A0;
}

.txt-wh {
  color: #fff;
}

.txt-rd {
  color: red;
}

.txt-bg-yl {
  margin-right: 15px;
  padding: 7px 25px;
  display: inline-block;
  line-height: 1;
  background: #F9D801;
}

.ttl-border-bl {
  padding: 18px 40px;
  background-image: url(../images/bg_border_br.jpg);
  background-size: contain;
  color: #fff;
  display: inline-block;
}

.ttl-border-bl span {
  padding-top: 8px;
  display: block;
}


.ttl-border-yl {
  padding-bottom: 15px;
  position: relative;
}

.ttl-border-yl:after {
  content: "";
  background: #bababa;
  width: 100%;
  height: 1px;
  position: absolute;
  bottom: 0;
  left: 0;
}

.ttl-border-yl:before {
  content: "";
  background: #F9D801;
  width: 40%;
  height: 1px;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
}

.ttl-pillar,
.ttl-pillar-sm {
  margin-bottom: 35px;
  padding-left: 50px;
  position: relative;
  font-size: 26px;
  font-size: 2.6rem;
  line-height: 1.5;
}

.ttl-pillar:before,
.ttl-pillar-sm:before {
  content: "";
  background: #F9D801;
  width: 24px;
  height: 120%;
  position: absolute;
  top: 0;
  left: 0;
}

.ttl-pillar-sm {
  margin-bottom: 15px;
  padding-left: 20px;
  color: #333;
  font-size: 22px;
  font-size: 2.2rem;
}

.ttl-pillar-sm span {
  font-size: 14px;
  font-size: 1.4rem;
  display: block;
}

.ttl-pillar-sm:before {
  width: 9px;
  height: 100%;
}

.ttl-dots {
  padding-bottom: 6px;
  letter-spacing: 5px;
  display: inline-block;
  position: relative;
}

.ttl-dots:after {
  content: "";
  width: 100%;
  height: 7px;
  background: -webkit-repeating-linear-gradient(-45deg, #F9D801, #F9D801 4px, transparent 4px, transparent 8px);
  background: repeating-linear-gradient(-45deg, #F9D801, #F9D801 4px, transparent 4px, transparent 8px);
  position: absolute;
  left: 0;
  bottom: -8px;
}

.ttl-dots span {
  font-size: 18px;
  font-size: 1.8rem;
}

br + .ttl-dots {
  margin-top: 15px;
}

.ttl-dots + .ttl-dots {
  margin-top: 25px;
}

section > .center > .ttl-dots + div,
.content-inner + .content-inner {
  margin-top: 60px;
}

.ttl-dots + p {
  margin-top: 30px;
}

.ttl-band {
  margin-left: -40%;
  padding: 25px 0 15px 0;
  width: 120%;
  font-size: 44px;
  font-size: 4.4rem;
  text-align: center;
  letter-spacing: 5px;
  font-weight: bold;
  color: #fff;
  -webkit-transform: rotate(-20deg);
  -moz-transform: rotate(-20deg);
  -ms-transform: rotate(-20deg);
  -o-transform: rotate(-20deg);
  transform: rotate(-20deg);
  display: inline-block;
  position: relative;
  left: -100px;
  top: 0;
}

.ttl-band span {
  padding-top: 5px;
  font-size: 14px;
  font-size: 1.4rem;
  display: block;
}

.p-5per {
  padding: 0 5%;
}

.border-bt {
  margin-bottom: 15px;
  padding-bottom: 15px;
  border-bottom: 1px solid #eee;
}

/* btn
---------------------------------------------------------- */
.btn {
  padding: 12px 25px;
  border-radius: 0;
  font-size: 14px;
  font-size: 1.4rem;
  cursor: pointer;
}

.btn-or {
  background: #FF6C00;
  color: #fff;
}

.btn-or:hover {
  color: #fff;
}

.btn-bk {
  padding: 8px 30px;
  background: #333;
  color: #fff;
  font-size: 12px;
  font-size: 1.2rem;
}

.btn-bk + .btn-bk {
  margin-left: 5px;
}

.btn-bk:hover {
  color: #fff;
}

.btn-border-yl {
  background: #fff;
  background-image: linear-gradient(to right, rgba(0,0,0,0) 50%, #F9D801 50%);
  background-position: 0 0;
  background-size: 200% auto;
  transition: all .7s ease 0s;
  border: 4px solid #F9D801;
}

.btn-border-yl:hover {
  background-position: -100% 0;
  opacity: 1;
  transition: .7s;
}


.w-30 {
  width: 30%;
}

.w-50 {
  width: 50%;
}

.w-50.btn {
  min-width: 300px;
}

/* box
---------------------------------------------------------- */
.flow-gr {
  margin: 40px 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;/*?*/
}

.flow-gr li {
  width: 20%;
  align-items: stretch;
}

.flow-gr li div {
  width: 100%;
  height: 100%;
  padding: 23px 4%;
  text-align: center;
  border: 1px dotted #c1c1c1;
}

.flow-gr li + li {
  padding-left: 2%;
  position: relative;
}

.flow-gr li + li:before {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 13px 0 13px 12px;
  border-color: transparent transparent transparent #F9D801;
  position: absolute;
  top: calc(50% - 13px);
  left: 5px;
}

.flow-gr li h3  {
  padding-bottom: 15px;
  font-weight: bold;
  line-height: 1.3;
}

.flow-gr li h3 span {
  padding-bottom: 15px;
  display: block;
  font-size: 50px;
  font-size: 5.0rem;
  font-weight: bold;
  color: #F9D801;
}

.balloon-yl {
  margin-bottom: 40px;
  padding: 6px 25px;
  background: #F9D801;
  border-radius: 25px;
  display: inline-block;
  letter-spacing: 3px;
  position: relative;
}

.balloon-yl:after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 15px 8.5px 0 8.5px;
  border-color: #F9D801 transparent transparent transparent;
  position: absolute;
  bottom: -15px;
  left: calc((100% - 8.5px) / 2);
}


/* list
---------------------------------------------------------- */
.list-btn-lg .col-sm-4 {
  margin-bottom: 20px;
}

.list-btn-lg li a {
  padding: 0 20px;
  width: 100%;
  height: 100px;
  color: #333;
  background: #F9D801;
  letter-spacing: 2px;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}

.list-btn-lg li a:after {
  content: "";
  width: 13px;
  height: 13px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: calc((100% - 13px) / 2);
  right: 20px;
}

.list-btn-lg li a h3 {
  line-height: 1.4;
}

.list-btn-sm {
  margin-top: 35px;
  margin-bottom: 35px;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.list-btn-sm li + li {
  margin-left: 10px;
}

.list-btn-sm li a {
  background: #F9D801;
  font-size: 12px;
  font-size: 1.2rem;
  padding: 10px 15px;
  color: #333;
  font-weight: bold;
  letter-spacing: 2px;
}

.list-check {
  padding-left: 10%;
  margin: 50px auto;
}

.list-check li {
  padding-bottom: 20px;
  padding-left: 30px;
  font-size: 18px;
  font-size: 1.8rem;
  position: relative;
}

.list-check li:before {
  content: "";
  width: 25px;
  height: 25px;
  background-image: url(../images/ico_check.png);
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  top: -5px;
  left: 0;
}

.list-link-col2 {
  text-align: center;
  margin: 0;
}

.list-link-col2 li {
  padding: 0;
}

.list-link-col2 li:first-child {
  background: #0A3553;
}

.list-link-col2 li:last-child {
  background: #F44F11;
}

.list-link-col2 li a {
  padding: 50px 10% 30px 10%;
  width: 100%;
  height: 100%;
  display: block;
  color: #fff;
}

.page-index .list-link-col2 li a {
  padding: 90px 10% 50px 10%;
}


.list-link-col2 li a .txt-lg {
  margin-bottom: 10px;
  padding-top: 35px;
  display: inline-block;
  position: relative;
}

.page-index .list-link-col2 li a .txt-lg:before {
  padding-top: 55px;
  content: "";
  width: 80px;
  height: 80px;
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  top: -53px;
  left: calc(50% - 40px);
}

.list-link-col2 li:first-child a .txt-lg:before {
  background-image: url(../images/ico_question.png);
}

.list-link-col2 li:last-child a .txt-lg:before {
  height: 78px;
  background-image: url(../images/ico_speech.png);
}

.list-link-col2 li a p {
  display: block;
}

.list-link-col2 li a .float-l:first-child img {
  width: 200px;
}

.list-link-col2 li a .float-l:last-child p.btn {
  margin-top: 20px;
  display: block;
  border: 1px solid #fff;
  color: #fff;
  background-image: linear-gradient(to right, rgba(0,0,0,0) 50%, #fff 50%);
  background-color: transparent;
  background-position: 0 0;
  background-size: 200% auto;
  transition: all .7s ease 0s;
}

.list-link-col2 li a:hover .float-l:last-child p.btn {
  background-position: -100% 0;
  transition: .7s;
}

.list-link-col2 li.bl a:hover .float-l:last-child p.btn {
  color: #0A3553;
}

.list-link-col2 li.or a:hover .float-l:last-child p.btn {
  color: #FF6C00;
}

.list-link-col2 li a:hover {
  opacity: 1;
}

.page-index .list-link-col2 li a:hover {
  opacity: 0.5;
}

.list-link-col2 li a .float-l:last-child {
  padding-left: 20px;
  width: calc(100% - 200px);
}

/*faq*/
.list-faq {
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
}

.list-faq li + li {
  border-top: 1px solid #ccc;
}

.list-faq li {
  position: relative;
}

.list-faq li:after {
  content: "";
  width: 13px;
  height: 13px;
  border-top: 1px solid #F9D801;
  border-right: 1px solid #F9D801;
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: calc((100% - 13px) / 2);
  right: 20px;
}

.list-faq li a {
  padding: 30px;
  display: block;
}

.list-faq li p {
  margin-bottom: 0;
}

.list-faq li a span,
.list-faq li p span {
  padding-right: 15px;
  font-size: 28px;
  font-size: 2.8rem;
  color: #F9D801;
  letter-spacing: 2px;
}

.list-faq .panel-body {
  margin-top: -30px;
  padding: 10px 50px 30px 30px;
}

a.link-sub {
  padding-left: 20px;
  position: relative;
}

a.link-sub:before {
  content: "";
  width: 10px;
  height: 1px;
  background: #707070;
  position: absolute;
  top: 2rem;
  left: 0;
}

/* form
---------------------------------------------------------- */
.input-group .form-control {
  padding: 22.5px;
  font-size: 14px;
  font-size: 1.4rem;
}

.form-control:focus {
  border: 1px solid #ced4da;
  box-shadow: none;
}

.input-group .btn {
  background: #F9D801;
}


/* table
---------------------------------------------------------- */
.table th,
.table td {
  margin-top: 8px;
  padding: 20px;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.4;
}

.table {
  border-bottom: 1px solid #dee2e6;
}

/* carousel
---------------------------------------------------------- */
.carousel-control-next,
.carousel-control-prev {
  width: 3%;
  background: #000;
}


.multiple { padding: 0;}
.multiple img { width: 100%;}
.multiple div { margin: 0 5px;}
.multiple .slick-next { right: 17px;　z-index: 100;}
.multiple .slick-prev { left: 23px; z-index: 100;}




/* =================================
layout
================================= */
.page-sub {
  background: #F8F8F8;
  position: relative;
}

.page-sub section + section {
  margin-top: 100px;
}

.inner {
  padding: 80px 0;
}

.bnr-wrap {
  width: 100%;
}

.img-lg {
  margin: 30px auto 0 auto;
  width: 100%;
  max-width: 600px;
}

.img-md {
  margin: 50px 0;
  width: 90%;
  max-width: 600px;
}

.col-lg-12 {
  margin-top: 30px;
}

.col-sm-12 + .col-sm-12 {
  margin-top: 80px;
}

.mt-20 {
  margin-top: 20px;
}

.mb-100 {
  margin-bottom: 100px;
}

.pt-80 {
  padding-top: 80px;
}

.pb-50 {
  padding-bottom: 50px;
}

.pb-100 {
  padding-bottom: 100px;
}

.container.mt-minor-80 {
  padding-top: 0;
}

.mt-minor-80 {
  position: relative;
  top: -80px;
}

.frame {
  margin-top: 40px;
  border: 30px solid #fff;
}

/*
card
------------------------------ */
.list-card > div {
  margin-bottom: 20px;
  display: flex;
}

.list-card > div.col-lg-12,
.list-card > div.col-lg-6 {
  margin-bottom: 30px;
}

.card-body {
  width: 100%;
  height: auto;
  padding: 35px 5%;
}

.card-body > p {
  line-height: 1.5;
}

.card-body.bg-bl.center > p.txt-wh {
  margin-bottom: 2px;
}

.card-body .card-title.ttl-sm {
  font-weight: bold;
}

.card-title .txt-sm {
  font-size: 10px;
  font-size: 1.0rem;
  font-weight: bold;
}

a.card {
  color: #333;
  width: 100%;
}

.card-title > span {
  padding-bottom: 10px;
  display: block;
}

.col-lg-4 {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
}

.col-sm-4 {
  margin-bottom: 30px;
}

.card {
  width: 100%;
}

.card img {
  width: 100%;
  height: auto;
}

.card-img-top {
  max-width: 100%;
  flex-shrink:0;
}

.card.bl {
  width: 100%;
}

.card.bl .card-body {
  padding: 30px 5%;
}

.card.bl .card-body.bg-bl.center,
.card.gr .card-body.bg-gr.center {
  padding: 15px 5%;
}

.card.bl .card-body.bg-bl.center .card-title,
.card.gr .card-body.bg-gr.center .card-title {
  margin-bottom: 0;
}

.card.bl .card-title {
  line-height: 1.4;
}

.ico-wrap th {
  padding-top: 8px;
}

.ico-wrap td {
  padding-left: 30px;
}

.ico-wrap img {
  width: 30px;
}




/*
modal
------------------------------ */
.modal-body {
  padding-top: 50px;
}

.modal .ttl-dots {
  margin-bottom: 30px;
  font-size: 22px;
  font-size: 2.2rem;
  line-height: 1.5;
}

.modal .ttl-dots span {
  padding-bottom: 15px;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.5;
  display: block;
}

.modal .ttl-pillar-sm {
  margin-bottom: 5px;
  width: 100%;
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: bold;
}

.modal p + .ttl-pillar-sm {
  margin-top: 25px;
}

.modal img {
  margin-bottom: 30px;
}

.modal-footer {
  padding: 0 24px 24px;
  justify-content: center;
}


.modal-footer .btn {
  border-radius: 6px;
  background: #ccc;
}



/*
bg
------------------------------ */
.bg-wh {
  background: #fff;
}

.bg-gr {
  background: #F8F8F8;
}

.bg-gr-02 {
  background: #929292;
}

.bg-bk {
  background: #000;
  color: #fff;
}

.bg-bl {
  background: #1275A0;
}

.bg-gr-02 {
  background: #ececec;
}

.bg-yl {
  background: #F9D801;
}

.bg-stripe-yl {
  background: -webkit-repeating-linear-gradient(-45deg, #FDF6C8, #FDF6C8 8px, transparent 8px, transparent 16px);
  background: repeating-linear-gradient(-45deg, #FDF6C8, #FDF6C8 8px, transparent 8px, transparent 16px);
}

.bg-img-factory {
  background-image: url(../images/bg_casestudy_factory.jpg);
  background-size: cover;
  background-repeat: no-repeat;
}



/*
others
------------------------------ */
.arrow-wrap:first-of-type {
  margin-top: 20px;
}

.arrow-wrap + .arrow-wrap {
  margin-top: 50px;
  margin-bottom: 30px;
  position: relative;
}

.arrow-wrap + .arrow-wrap:before {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 20px 28px 0 28px;
  border-color: #ff6a00 transparent transparent transparent;
  position: absolute;
  top: -33px;
  left: calc((100% - 56px)/2);
}


/* =================================
animation
================================= */
/*inview用_表示前*/
.js-fade,
.js-fade-delay,
.js-fade-pseudo:before,
.js-fade-pseudo:after,
.js-fade-pseudo-delay:before,
.js-fade-pseudo-delay:after {
  opacity: 0;
  transform: translate(0,0);
  -webkit-transform: translate(0,0);
  transition: 1s;
}
.js-fade-up {
  opacity: 0;
  transform: translate(0,60px);
  -webkit-transform: translate(0,60px);
  transition: 1s;
}
.js-fade-delay,
.js-fade-down {
  opacity: 0;
  transform: translate(0,-40px);
  -webkit-transform: translate(0,-40px);
  transition: 1.2s;
}
.js-rotate {
  opacity: 0;
  transform: translateX(100px) rotate(180deg) ;
  -webkit-transform: translateX(100px) rotate(180deg);
  transition: 1.5s;
}
/*inview用_表示後*/
.js-fade-set,
.js-fade-pseudo-set:before,
.js-fade-pseudo-set:after,
.js-fade-up-set {
  opacity: 1.0 !important;
  transform: translate(0,0);
  -webkit-transform: translate(0,0);
}
.js-rotate-set {
  opacity: 1.0;
  transform: translateX(0) rotate(0deg);
  -webkit-transform: translateX(0) rotate(0deg);
}

/* =================================
index
================================= */
.mv-index {
  width: 100%;
  height: 500px;
  background-image: url(../images/bg_sub.jpg);
  background-size: cover;
  position: relative;
}

.mv-index:after {
  content: "";
  width: 123px;
  height: 250px;
  background-image: url(../images/img_mv_printer.png);
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  top: calc((100% - 250px) / 2);
  right: -90px;
  z-index: 10;
}

.mv-index h1 {
  font-size: 40px;
  font-size: 4.0rem;
  font-weight: bold;
  letter-spacing: 4px;
  color: #fff;
  position: absolute;
  top: 90px;
  left: 5%;
}

.mv-index h1 span {
  padding-bottom: 4px;
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: normal;
  letter-spacing: 1px;
  display: block;
}

.mv-index h1 span > span {
  display: inline;
  font-size: 12px;
  font-size: 1.2rem;
}

/*プリンタ画像*/
.mv-index > img {
  width: 400px;
  position: absolute;
  bottom: -80px;
  right: 50px;
}

.box-bk {
  padding: 35px 58px;
  width: 70%;
  background: #000;
  color: #fff;
  letter-spacing: 2px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  position: relative;
  top: calc((100% - 153px) / 2);
  right: -100%;
}

.mv-index.inview .box-bk {
  right: -30%;
  transition: 2.5s;
}

/*ロゴ*/
.box-bk img {
  width: 190px;
}

.box-bk > div {
  padding-left: 30px;
}

.box-bk > div > p:last-child {
  margin-bottom: 0;
}

.page-index {
  overflow: hidden;
}

.page-index .topics {
  padding-bottom: 80px;
}

.page-index .card img {
  height: 100%;
}

/*スライダー*/
.slider {
  margin-top: 10px;
}

.slider li > div {
  border: 1px solid #ccc;
  margin: 10px;
}

.slider li a div {
  padding: 0;
  position: relative;
}

.slider p {
  margin: 0;
  padding: 7px 14px;
  width: 100%;
  font-size: 28px;
  font-size: 2.8rem;
  font-family: Impact;
  letter-spacing: 1.5px;
  color: #fff;
  background: rgba(0,0,0,0.2);
  line-height: 1;
  position: absolute;
  top: -55px;
}

.slider h3 {
  margin: 0;
  padding: 15px;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.5;
  background: #F4F4F4;
  color: #333;
}

.slick-dots li button:hover:before,
.slick-dots li button:focus:before
{
    opacity: 1;
    color: #1275A0; /* hover時の色を変更 */
}
.slick-dots li button:before
{
    font-family: 'slick';
    font-size: 6px;
    line-height: 20px;

    position: absolute;
    top: 0;
    left: 0;

    width: 20px;
    height: 20px;

    /* 元のcontentプロパティの値だとfont-sizeを変更した際に位置がずれてしまうので値を変更 */
    /* content: '•'; */
    content: '●';
    text-align: center;

    opacity: .25;
    color: black;

    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.slick-dots li.slick-active button:before
{
    opacity: .75;
    color: #1275A0; /* active時の色を変更 */
}


.page-index .bg-bk {
  margin-left: -10%;
  width: 120%;
  padding: 50px 0 30px 0;
  transform: rotate(3deg);
  -webkit-transform: rotate(3deg);
  -moz-transform: rotate(3deg);
  -ms-transform: rotate(3deg);
  -o-transform: rotate(3deg);
  transform: rotate(3deg);
}

.page-index .bg-bk .container .row .col-sm-6:first-child {
  display: flex;
  align-items: center;
}

.page-index .bg-bk .container .row .col-sm-6:first-child img {
  margin-left: -30px;
  width: 100%;
  height: 55%;
}

@media screen and (max-width: 990px) {
  .page-index .bg-bk .container .row .col-sm-6:first-child img {
    margin-left: 0;
    height: auto;
  }
}

.page-index .bg-bk .ttl-xl {
  letter-spacing: 4px;
}

.page-index .bg-bk .ttl-xl > .txt-md {
  padding-top: 10px;
  padding-bottom: 25px;
  display: block;
}

.page-index .ttl-md {
  padding-bottom: 20px;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 2px;
}

.ttl-band {
  z-index: 0;
}

.ttl-band.bl {
  background: #1275A0;
}

.ttl-band.rd {
  background: #A01212;
}

.ttl-band.bk {
  background: #000;
}

.page-index .mv-index {
  z-index: 1;
}

.page-index .topics {
  z-index: 0;
  position: relative;
}

.page-index .about {
  z-index: 2;
  position: relative;
}

.page-index .bg-img-factory {
  padding-top: 70px;
  padding-bottom: 80px;
  margin-top: -50px;
  z-index: 1;
  position: relative;
}

.page-index .bg-img-factory .ttl-band {
  top: -30px;
}

.page-index .bg-stripe-yl {
  padding: 50px 0;
  z-index: 0;
  position: relative;
}

.page-index .bg-stripe-yl .ttl-band {
  top: -25px;
}


/* =================================
sub
================================= */
.mv-sub {
  padding: 140px 0 110px 0;
  background-image: url(../images/bg_sub.jpg);
  background-size: contain;
  color: #fff;
  text-align: center;
}

.mv-sub > h1 {
  font-size: 44px;
  font-size: 4.4rem;
  font-weight: bold;
  letter-spacing: 3px;
  line-height: 1.3;
}

.mv-sub > p {
  padding-top: 0;
  font-size: 14px;
  font-size: 1.4rem;
  letter-spacing: 3px;
}

/*
パンくず
------------------------------ */
.breadcrumb {
  margin: 0;
  padding: 10px 0 80px 1%;
  background: transparent;
}

/* Bepopとは？
---------------------------------------------------------- */
.bg-triangle {
  position: relative;
  z-index: 0;
}

.bg-triangle:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  border-width: 30vh 50vw;
  border-style: solid;
  border-color: #F8F8F8 #F9D801 #F9D801 #F8F8F8;
  z-index: -1;
}

.page-about .bg-stripe-yl {
  padding-top: 180px;
  padding-bottom: 80px;
}

.page-about .bg-stripe-yl h2 {
  z-index: 1;
  position: relative;
}

.page-about .bg-stripe-yl h2 img {
  width: 200px;
  padding-right: 10px;
}

.page-about .row > div:first-child > img {
  margin-bottom: 30px;
  width: 280px;
}

.page-about .bg-yl {
  position: relative;
}

.page-about .bg-yl:after {
  content: "";
  position: absolute;
  bottom: -30vh;
  left: 0;
  border-width: 15vh 50vw;
  border-style: solid;
  border-color: #F9D801 transparent transparent transparent;
}

.img-wrap > div:last-child {
  padding-top: 50px;
}

.page-about .list-ico,
.page-casestudy .list-ico {
  padding-top: 50px;
}

.page-about .list-ico > li {
  margin-bottom: 0;
}

.page-about .bg-img-factory {
  padding: 80px 0;
}

.page-about .bg-img-factory .list-ico {
  padding-top: 0;
}

.page-about .movie-wrap h3 {
  padding-top: 20px;
  padding-bottom: 25px;
}

/*
ラインナップ
------------------------------ */
.list-product li a {
  width: 100%;
  height: 100%;
  display: block;
  padding: 45px 8%;
  background: #fff;
  text-align: center;
  position: relative;
  transition: all .1s;
  top: 0;
  left: 0;
}

.list-product li a:hover {
  box-shadow: none;
  opacity: 1;
  top: 3px;
  left: 3px;
}

.list-product li a i {
  font-size: 20px;
  font-size: 2.0rem;
  position: absolute;
  top: 23px;
  right: 23px;
  transition: all .5s;
  opacity: 0;
}

.list-product li a:hover i {
  color: #FF6C00;
  opacity: 1;
}

.list-product li a h3 span {
  padding-bottom: 7px;
  font-size: 12px;
  font-size: 1.2rem;
  color: #FF6C00;
  display: block;
}

.list-product li a h3 {
  margin-bottom: 10px;
  color: #4F4F4F;
  font-size: 24px;
  font-size: 2.4rem;
  font-weight: bold;
}

.list-product li a p {
  color: #4F4F4F;
}

.list-product li a p + p {
  margin-top: 10px;
  margin-bottom: 10px;
}

.list-ico li img {
  width: 100px;
}

.list-product .txt-sm {
  margin-top: 10px;
  line-height: 1.5;
}

/*機能アイコン*/
.list-feature {
  margin: 0;
}

.list-feature li {
  width: 25%;
  padding: 0;
}

.list-rank {
  margin: 0 0 30px 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
}

.list-rank li {
  padding: 15px;
  background: #fff;
  border-radius: 10px;
  position: relative;
}

.list-rank li:before {
  padding-top: 20px;
  width: 50px;
  height: 50px;
  text-align: center;
  background: #F9E000;
  font-weight: bold;
  border-radius: 50%;
  position: absolute;
  top: -10px;
  left: -15px;
  letter-spacing: 2px;
}

.list-rank li:first-child:before {
  content: "1位";
}

.list-rank li:nth-child(2):before {
  content: "2位";
}

.list-rank li:nth-child(3):before {
  content: "3位";
}

.list-rank li:nth-child(4):before {
  content: "4位";
}

.list-rank li:nth-child(5):before {
  content: "5位";
}

/*
ラインナップ
------------------------------ */
.page-lineup .ttl-wrap {
  margin: 0 0 50px 0;
}

.page-lineup .ttl-wrap .btn-or {
  margin-top: 10px;
}

.print-wrap {
  margin: 0 auto;
  width: 820px;
  height: auto;
}

.print-wrap > div {
  margin-top: 50px;
  width: 30%;
  float: left;
}

.print-wrap > div + div {
  margin-left: 5%;
}

.print-wrap > div:first-child,
.print-wrap > div:last-child {
  position: relative;
}

.print-wrap div:first-child:after {
  content: "";
  width: 22px;
  height: 16px;
  background-image: url(../images/img_arrow_yl_01.png);
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  bottom: calc(50% - 8px);
  right: -32px;
}

.print-wrap div:last-child:after {
  content: "";
  width: 44px;
  height: 28px;
  background-image: url(../images/img_arrow_yl_02.png);
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  bottom: calc(50% - 14px);
  left: -35px;
}

/*
機能紹介
------------------------------ */
.txt-wrap .txt-md {
  margin-bottom: 5px;
}

#pcex .txt-sm.center {
  padding-top: 25px;
}

#pcex .img-wrap img {
  margin: 30px auto 50px auto;
  width: 250px;
  display: block;
}

#pcex .card-body {
  padding: 35px 5% 10px 5%;
}

.page-features .seat .btn-wrap {
  padding-top: 15px;
}

/*
活用事例
------------------------------ */
.center.ttl-md {
  line-height: 1.6;
  margin-bottom: 40px;
  letter-spacing: 2px;
}

.list-casestudy li {
  display: flex;
  flex-wrap: wrap;
}

.list-casestudy li.factory a {
  background-image: url(../images/bg_casestudy_factory.jpg);
}

.list-casestudy li.construction a {
  background-image: url(../images/bg_casestudy_construction.jpg);
}

.list-casestudy li.public a {
  background-image: url(../images/bg_casestudy_public.jpg);
}

.list-casestudy li a {
  padding: 50px 5% 40px 5%;
  width: 100%;
  background-size: cover;
  display: block;
  text-align: center;
}

.list-casestudy li a h2 {
  font-size: 16px;
  font-size: 1.6rem;
  padding-bottom: 30px;
  color: #F9D801;
  line-height: 1.3;
}

.list-casestudy li a h2 span {
  font-size: 28px;
  font-size: 2.8rem;
  display: block;
  letter-spacing: 3px;
}

.list-casestudy li a > span {
  padding-bottom: 8px;
  color: #fff;
  display: block;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.5;
}

.list-casestudy li a p {
  padding: 10px 25px;
  color: #fff;
  background: #333;
  border: 1px solid #fff;
  font-size: 12px;
  font-size: 1.2rem;
  display: inline-block;
}

/*工場*/
.page-factory .bg-img-factory {
  margin-top: -100px;
  padding-bottom: 100px;
}

.page-factory .bg-wh {
/*  margin-top: -100px;*/
  padding: 50px 5% 15px 5%;
}

.page-factory .bg-wh .col-sm-8 {
  padding-left: 5%;
}

.page-factory .list-card .col-lg-4 {
  width: auto;
  height: 100%;
}

.page-factory .list-card .txt-lg {
  margin-bottom: 8px;
}
.page-factory .list-card .col-lg-5 > img {
}

/*
安全表示・人づくりコンテスト
------------------------------ */
/*過去*/
.caption-wrap + .caption-wrap {
  margin-top: 60px;
}

.caption-wrap > .row + .row {
  margin-top: 80px;
}

.caption-wrap p + .btn {
  margin-top: 30px;
}

.caption-wrap p {
  line-height: 2.3;
}

.caption-wrap p + p {
  margin-top: 20px;
}

/*受賞*/
.award-wrap > div > .row {
  margin-top: 40px;
}

.award-wrap > div + div {
  margin-top: 80px;
}

.award-wrap .txt-md {
  padding-bottom: 10px;
}

.award-wrap .bg-gr-02 {
  padding: 30px 5% 40px 5%;
  position: relative;
}

.award-wrap .bg-gr-02 img {
  width: 50%;
  position: absolute;
  right: 0;
  bottom: -140px;
}

/*コメント・写真がない時用*/
.award-wrap .none {
  text-align: center;
}

.award-wrap .none .col-sm-6 {
  margin: 0 auto;
}

/*応募作品*/
.list-apply li {
  margin-bottom: 60px;
}




.list-apply .ttl-pillar-sm {
  line-height: 1.2;
}

.list-apply .ttl-pillar-sm span {
  padding-bottom: 8px;
  line-height: 1.5;
}

/* ダウンロード
---------------------------------------------------------- */
.page-download .list-card .card-body {
  padding: 20px 5% 35px 5%;
}

.page-download .list-card .card-body.bg-gr {
  background: #777;
}

.page-download .list-card .btn-wrap {
  padding-top: 20px;
  display: flex;
  justify-content: space-around;
}

.btn-zoom {
  position: relative;
}

.btn-zoom:after {
  content: "";
  width: 35px;
  height: 35px;
  background-image: url(../images/ico_zoom.png);
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  top: -30px;
  right: 15px;
}

/* リクエストBOX
---------------------------------------------------------- */
.page-request .card {
  background: none;
  border: none;
}

.page-request .card .txt-lg {
  line-height: 1.4;
}

.page-request .card img {
  width: 80px;
  margin: 10px auto -15px auto;
}

.page-request .card-body {
  padding: 20px 5% 5px 5%;
}

/*フォーム*/
.page-request .formWrap {
  margin: 0 auto;
  max-width: 700px;
}

.page-request .formWrap label,
.page-request .formWrap input,
.page-request .formWrap textarea {
  width: 100%;
  padding: 13px;
  text-align: left;
}

.page-request .formWrap input,
.page-request .formWrap textarea {
  background: #fff;
  border: 1px solid #efefef;
}

.page-request .formWrap p {
  line-height: 1;
  display: inline-block;
  width: auto;
}

.mustwrap {
  position: relative;
}

.page-request .formWrap p.must:after {
  content: "必須";
  padding: 4px 8px;
  font-size: 10px;
  font-size: 1.0rem;
  color: #fff;
  background: #D11515;
  border-radius: 10px;
  position: absolute;
  right: -42px;
  top: -1px;
}

/*確認画面*/
.page-request.confirm form input {
  padding-left: 0;
  background: none;
  border: none;
  cursor: default;
}

.page-request.confirm form input:focus {
  outline: none;
}

/* =================================
header
================================= */
.mv-index,
.mv-sub {
  position: relative;
}

header.is-pc-only {
  position: absolute;
  width: 100%;
  top: 30px;
  left: 0;
  z-index: 10;
}

header.is-pc-only .container {
  max-width: 900px;
}

header.is-pc-only .navbar {
  background: #000;
  padding: 0;
}

header.is-pc-only .nav-link {
  padding: 10px 0;
}

header.is-pc-only .navbar-brand {
  position: absolute;
  top: -20px;
  left: 10px;
  z-index: 1;
}

header.is-pc-only .navbar-brand img {
  width: 80px;
}

header.is-pc-only nav a {
  color: #fff;
}

header.is-pc-only .dropdown-toggle::after {
  display: none;
}

/*ドロップダウンをホバーで開く*/
header.is-pc-only nav li.dropdown:hover > .dropdown-menu {
  display: block;
}

header.is-pc-only .dropdown-menu {
  width: 100%;
  margin: 0;
  padding: 0;
  font-size: 14px;
  font-size: 1.4rem;
  background: #000;
  border-radius: 0;
  top: 100%;
  left: 0;
  border: none;
}

header.is-pc-only .dropdown-item {
  padding: 20px 10px;
  color: #fff;
  text-align: center;
}

header.is-pc-only .dropdown-item span {
  font-size: 10px;
  font-size: 1.0rem;
}

.navbar-expand-md .navbar-nav .nav-link {
  padding-right: 0;
  padding-left: 0;
}

header.is-pc-only .dropdown-item,
header.is-pc-only .nav-item .nav-link {
  position: relative;
}

header.is-pc-only .dropdown-item:hover,
header.is-pc-only .nav-item .nav-link:hover {
  color: #fff;
  background: #000;
  opacity: 1;
}

header.is-pc-only .dropdown-item:after,
header.is-pc-only .nav-item .nav-link:after {
  content: '';
  width: 0;
  height: 4px;
  background-color: #F9D801;
  position: absolute;
  bottom: 0;
  left: 0;
  transition: .7s;
}

header.is-pc-only .dropdown-item:hover:after,
header.is-pc-only .nav-item .nav-link:hover:after {
  width: 100%;
}

.band-yl {
  padding: 5px 50px 5px 0;
  width: 300px;
  font-weight: bold;
  color: #333;
  background: #F9D801;
  display: inline;
  position: absolute;
  top: 0;
  right: -110px;
  -webkit-transform: rotate(30deg);
  -moz-transform: rotate(30deg);
  -ms-transform: rotate(30deg);
  -o-transform: rotate(30deg);
  transform: rotate(30deg);
  overflow: hidden;
}

.page-index .band-yl {
  padding: 5px 0 5px 81px;
}

/* =================================
footer
================================= */
footer {
  background: #000;
}

footer .container {
  padding-top: 50px;
  padding-bottom: 30px;
}

footer .logo {
  margin-bottom: 50px;
  width: 100px;
  display: block;
}

footer ul + ul {
  margin-top: 20px;
}

footer ul li a {
  font-size: 12px;
  font-size: 1.2rem;
  color: #fff;
  display: block;
}

footer ul li a span {
  font-size: 10px;
  font-size: 1.0rem;
}

footer ul li a + a {
  padding-top: 15px;
}

footer ul li a:hover {
  opacity: 1;
}

footer small {
  padding-top: 50px;
  color: #777;
  display: block;
}

@media screen and (min-width: 768px) and (max-width: 1000px) {

  .container {
    max-width: 90%;
  }
}



@media screen and (max-width: 767px) {
  /* =================================
  base
  ================================= */
  html, body{
    min-width: 320px;
    width: 100%;
    max-width: 100%;
  }

  /* =================================
  汎用クラスの定義
  ================================= */
  .is-sp-only{
    display: block !important;
  }

  .is-pc-only{
    display: none !important;
  }

  .float-l, .float-r{
    float: none;
  }




.bold {
  font-weight: bold;
}

.center {
  text-align: center;
}

.left {
  text-align: left;
}

.inner-wrap {
  width: 1024px;
  margin: 0 auto;
}

.shadow {
  box-shadow: 4px 4px 7px rgba(0,0,0,0.2);
}

.text-center {
  line-height: 1.8;
}

.rounded {
  border-radius: 8px;
}

/* badge
---------------------------------------------------------- */
.new {
  position: relative;
}

.new:before {
  content: "NEW";
  color: #FF6C00;
  padding-top: 23px;
  width: 60px;
  height: 60px;
  border: 1px solid #FF6C00;
  border-radius: 50%;
  position: absolute;
  top: 120px;
  left: 8%;
}








  /* title
  ---------------------------------------------------------- */
  .ttl-xl {
    font-size: 28px;
    font-size: 2.8rem;
  }

  .ttl-lg {
    font-size: 24px;
    font-size: 2.4rem;
  }

  .ttl-md {
    font-size: 18px;
    font-size: 1.8rem;
  }

.ttl-sm {
  font-size: 20px;
  font-size: 2.0rem;
  line-height: 1;
}

.txt-lg {
  font-size: 18px;
  font-size: 1.8rem;
  line-height: 1;}

.txt-md {
  font-size: 14px;
  font-size: 1.4rem;
}

.txt-sm {
  font-size: 12px;
  font-size: 1.2rem;
}

.txt-lead {
  line-height: 1.8;
}

.txt-bl {
  color: #1275A0;
}

.txt-wh {
  color: #fff;
}

.txt-rd {
  color: red;
}

  .txt-bg-yl {
    margin-right: 0;
    margin-bottom: 15px;
    padding: 7px;
    display: block;
}

.ttl-border-bl {
  padding: 18px 40px;
  background-image: url(../images/bg_border_br.jpg);
  background-size: contain;
  color: #fff;
  display: inline-block;
}

.ttl-border-bl span {
  padding-top: 8px;
  display: block;
}


.ttl-border-yl {
  padding-bottom: 15px;
  position: relative;
}

.ttl-border-yl:after {
  content: "";
  background: #bababa;
  width: 100%;
  height: 1px;
  position: absolute;
  bottom: 0;
  left: 0;
}

.ttl-border-yl:before {
  content: "";
  background: #F9D801;
  width: 40%;
  height: 1px;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
}

  .ttl-pillar,
  .ttl-pillar-sm {
    margin-bottom: 20px;
    padding-left: 20px;
    font-size: 22px;
    font-size: 2.2rem;
  line-height: 1.5;
}

  .ttl-pillar:before,
  .ttl-pillar-sm:before {
      width: 12px;
      height: 100%;
    top: 0;
    left: 0;
  }

.ttl-pillar-sm {
  margin-bottom: 15px;
  padding-left: 20px;
  color: #333;
  font-size: 22px;
  font-size: 2.2rem;
}

.ttl-pillar-sm span {
  font-size: 14px;
  font-size: 1.4rem;
  display: block;
}

.ttl-pillar-sm:before {
  width: 9px;
  height: 100%;
}

  .ttl-dots {
    line-height: 1.3;
    letter-spacing: 1px;
  }

.ttl-dots:after {
  content: "";
  width: 100%;
  height: 7px;
  background: -webkit-repeating-linear-gradient(-45deg, #F9D801, #F9D801 4px, transparent 4px, transparent 8px);
  background: repeating-linear-gradient(-45deg, #F9D801, #F9D801 4px, transparent 4px, transparent 8px);
  position: absolute;
  left: 0;
  bottom: -8px;
}

.ttl-dots span {
  font-size: 18px;
  font-size: 1.8rem;
}

br + .ttl-dots {
  margin-top: 15px;
}

.ttl-dots + .ttl-dots {
  margin-top: 25px;
}

  section > .center > .ttl-dots + div,
  .content-inner + .content-inner {
    margin-top: 40px;
  }

.ttl-dots + p {
  margin-top: 30px;
}

  .ttl-band {
    margin-top: 50px;
    margin-bottom: 25px;
    margin-left: -65%;
    padding: 10px 0;
    width: 200%;
    font-size: 30px;
    font-size: 3.0rem;
    -webkit-transform: rotate(-7deg);
    -moz-transform: rotate(-7deg);
    -ms-transform: rotate(-7deg);
    -o-transform: rotate(-7deg);
    transform: rotate(-7deg);
    left: 0;
    top: 25px;
}

.ttl-band span {
  padding-top: 5px;
  font-size: 14px;
  font-size: 1.4rem;
  display: block;
}

.p-5per {
  padding: 0 5%;
}

.border-bt {
  margin-bottom: 15px;
  padding-bottom: 15px;
  border-bottom: 1px solid #eee;
}

/* btn
---------------------------------------------------------- */
.btn {
  margin-right: auto;
  margin-left: auto;
  padding: 12px 25px;
  border-radius: 0;
  font-size: 14px;
  font-size: 1.4rem;
  cursor: pointer;
  display: block;
}

.btn-or {
  background: #FF6C00;
  color: #fff;
}

.btn-or:hover {
  color: #fff;
}

.btn-bk {
  padding: 8px 30px;
  background: #333;
  color: #fff;
  font-size: 12px;
  font-size: 1.2rem;
}

.btn-bk + .btn-bk {
  margin-left: 5px;
}

.btn-bk:hover {
  color: #fff;
}

.btn-border-yl {
  background: #fff;
  background-image: linear-gradient(to right, rgba(0,0,0,0) 50%, #F9D801 50%);
  background-position: 0 0;
  background-size: 200% auto;
  transition: all .7s ease 0s;
  border: 4px solid #F9D801;
}

.btn-border-yl:hover {
  background-position: -100% 0;
  opacity: 1;
  transition: .7s;
}

  .w-25.btn {
    width: 100% !important;
  }

  .w-30.btn {
    width: 100%;
  }

  .w-50.btn {
    padding: 0;
    width: 100%;
    min-width: 100%;
  }

  /* box
  ---------------------------------------------------------- */
  .flow-gr {
  margin: 40px 0;
    display: block;
  }

  .flow-gr li {
    width: 100%;
    align-items: block;
  }

  .flow-gr li div {
    padding: 10px 5%;
  }

  .flow-gr li + li {
    margin-top: 40px;
    padding-left: 0;
  }

  .flow-gr li + li:before {
    border-width: 13px 0 13px 12px;
    position: absolute;
    top: -32px;
    left: calc((100% - 13px) / 2);
    -webkit-transform: rotate(90deg);
    -moz-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    -o-transform: rotate(90deg);
    transform: rotate(90deg);
  }

  .flow-gr li h3  {
    padding-bottom: 10px;
    line-height: 1;
  }

  .flow-gr li h3 span {
    padding-bottom: 10px;
    font-size: 30px;
    font-size: 3.0rem;
  }

.balloon-yl {
  margin-bottom: 40px;
  padding: 6px 25px;
  background: #F9D801;
  border-radius: 25px;
  display: inline-block;
  letter-spacing: 3px;
  position: relative;
}

.balloon-yl:after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 15px 8.5px 0 8.5px;
  border-color: #F9D801 transparent transparent transparent;
  position: absolute;
  bottom: -15px;
  left: calc((100% - 8.5px) / 2);
}


/* list
---------------------------------------------------------- */
.list-btn-lg .col-sm-4 {
  margin-bottom: 20px;
}

.list-btn-lg li a {
  padding: 0 20px;
  width: 100%;
  height: 100px;
  color: #333;
  background: #F9D801;
  letter-spacing: 2px;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}

.list-btn-lg li a:after {
  content: "";
  width: 13px;
  height: 13px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: calc((100% - 13px) / 2);
  right: 20px;
}

.list-btn-lg li a h3 {
  line-height: 1.4;
}

  .list-btn-sm {
    margin-top: 15px;
    display: block;
    text-align: center;
  }

.list-btn-sm li + li {
  margin-left: 0;
  margin-top: 10px;
}

.list-btn-sm li a {
  background: #F9D801;
  font-size: 12px;
  font-size: 1.2rem;
  padding: 10px 15px;
  color: #333;
  font-weight: bold;
  letter-spacing: 2px;
  display: block;
}

  .list-check {
    padding-left: 0;
    margin: 30px auto 10px auto;
  }

  .list-check li {
    font-size: 16px;
    font-size: 1.6rem;
  }

  .list-check li:before {
    width: 20px;
    height: 20px;
    top: -3px;
  }

.list-link-col2 {
  text-align: center;
  margin: 0;
}

.list-link-col2 li {
  padding: 0;
}

.list-link-col2 li:first-child {
  background: #0A3553;
}

.list-link-col2 li:last-child {
  background: #F44F11;
}

  .list-link-col2 li a {
    padding: 20px 10% 20px 10%;
  }

  .page-index .list-link-col2 li a {
    padding: 60px 5% 30px 5%;
  }

  .list-link-col2 li a .txt-lg {
    margin-bottom: 5px;
  }

  .list-link-col2.printer li a .txt-lg {
    padding-top: 10px;
  }

  .page-index .list-link-col2 li a .txt-lg:before {
    padding-top: 20px;
    width: 40px;
    height: 40px;
    top: -20px;
    left: calc(50% - 20px);
  }

.list-link-col2 li a p {
  display: block;
}

  .list-link-col2 li a .float-l:first-child img {
    width: 180px;
  }

.list-link-col2 li a .float-l:last-child p.btn {
  margin-top: 20px;
  display: block;
  border: 1px solid #fff;
  color: #fff;
  background-image: linear-gradient(to right, rgba(0,0,0,0) 50%, #fff 50%);
  background-color: transparent;
  background-position: 0 0;
  background-size: 200% auto;
  transition: all .7s ease 0s;
}

.list-link-col2 li a:hover .float-l:last-child p.btn {
  background-position: -100% 0;
  transition: .7s;
}

.list-link-col2 li.bl a:hover .float-l:last-child p.btn {
  color: #0A3553;
}

.list-link-col2 li.or a:hover .float-l:last-child p.btn {
  color: #FF6C00;
}

.list-link-col2 li a:hover {
  opacity: 1;
}

.page-index .list-link-col2 li a:hover {
  opacity: 0.5;
}

  .list-link-col2 li a .float-l:last-child {
    padding-left: 0;
    width: 100%;
  }

  /*ナビで使用*/
  a.link-sub {
    padding-left: 35px;
    position: relative;
  }

  a.link-sub:before {
    content: "";
    width: 10px;
    height: 1px;
    background: #707070;
    position: absolute;
    top: 23px;
    left: 15px;
  }

/*faq*/
.list-faq {
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
}

.list-faq li + li {
  border-top: 1px solid #ccc;
}

.list-faq li {
  position: relative;
}

  .list-faq li:after {
  width: 8px;
  height: 8px;
  top: calc((100% - 8px) / 2);
  right: 5px;
}

  .list-faq li a {
    padding: 20px 20px 20px 0;
    line-height: 1.6;
  }

.list-faq li p {
  margin-bottom: 0;
}

  .list-faq li a span,
  .list-faq li p span {
    padding-right: 10px;
    font-size: 22px;
    font-size: 2.2rem;
  }

  .list-faq .panel-body {
    margin-top: -35px;
    padding: 20px 20px 20px 0;
  }

a.link-sub {
  padding-left: 20px;
  position: relative;
}

a.link-sub:before {
  content: "";
  width: 10px;
  height: 1px;
  background: #707070;
  position: absolute;
  top: 2rem;
  left: 0;
}

/* form
---------------------------------------------------------- */
.input-group .form-control {
  padding: 22.5px;
  font-size: 14px;
  font-size: 1.4rem;
}

.form-control:focus {
  border: 1px solid #ced4da;
  box-shadow: none;
}

.input-group .btn {
  background: #F9D801;
}


/* table
---------------------------------------------------------- */
.table th,
.table td {
  margin-top: 8px;
  padding: 20px;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.4;
}

.table {
  border-bottom: 1px solid #dee2e6;
}





  /* =================================
  layout
  ================================= */
  .container {
    padding: 0 5%;
  }

  .page-sub section + section {
    margin-top: 50px;
  }

  .inner {
    padding: 40px 0;
  }

.bnr-wrap {
  width: 100%;
}

.img-lg {
  margin: 30px auto 0 auto;
  width: 100%;
  max-width: 600px;
}

.img-md {
  margin: 50px 0;
  width: 90%;
  max-width: 600px;
}

.col-lg-12 {
  margin-top: 30px;
}

.col-sm-12 + .col-sm-12 {
  margin-top: 80px;
}

.mt-20 {
  margin-top: 20px;
}

  .mb-100 {
    margin-bottom: 50px;
  }

  .pt-80 {
    padding-top: 40px;
  }

  .pb-50 {
    padding-bottom: 25px;
  }

  .pb-100 {
    padding-bottom: 50px;
  }

.container.mt-minor-80 {
  padding-top: 0;
}

.mt-minor-80 {
  position: relative;
  top: -80px;
}

.frame {
  margin-top: 40px;
  border: 30px solid #fff;
}

/*
card
------------------------------ */
.list-card > div {
  margin-bottom: 20px;
  display: flex;
}

.list-card > div.col-lg-12,
.list-card > div.col-lg-6 {
  margin-bottom: 30px;
}

  .card-body {
    padding: 20px 5%;
  }

.card-body > p {
  line-height: 1.5;
}

.card-body.bg-bl.center > p.txt-wh {
  margin-bottom: 2px;
}

.card-body .card-title.ttl-sm {
  font-weight: bold;
}

.card-title .txt-sm {
  font-size: 10px;
  font-size: 1.0rem;
  font-weight: bold;
}

a.card {
  color: #333;
  width: 100%;
}

.card-title > span {
  padding-bottom: 10px;
  display: block;
}

.col-lg-4 {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
}

.card {
  width: 100%;
}

.card img {
  width: 100%;
  height: auto;
}

.card-img-top {
  max-width: 100%;
  flex-shrink:0;
}

  .card.bl .card-body {
    margin: 0 auto;
    padding: 20px 5%;
  }

  .card.bl .card-body.bg-bl.center,
.card.gr .card-body.bg-gr.center {
  padding: 15px 5%;
}

.card.bl .card-body.bg-bl.center .card-title,
.card.gr .card-body.bg-gr.center .card-title {
  margin-bottom: 0;
}

.card.bl .card-title {
  line-height: 1.4;
}

.ico-wrap th {
  padding-top: 8px;
}

.ico-wrap td {
  padding-left: 30px;
}

.ico-wrap img {
  width: 30px;
}




/*
modal
------------------------------ */
.modal-body {
  padding-top: 50px;
}

.modal .ttl-dots {
  margin-bottom: 30px;
  font-size: 22px;
  font-size: 2.2rem;
  line-height: 1.5;
}

.modal .ttl-dots span {
  padding-bottom: 15px;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.5;
  display: block;
}

.modal .ttl-pillar-sm {
  margin-bottom: 5px;
  width: 100%;
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: bold;
}

.modal p + .ttl-pillar-sm {
  margin-top: 25px;
}

.modal img {
  margin-bottom: 30px;
}

.modal-footer {
  padding: 0 24px 24px;
  justify-content: center;
}


.modal-footer .btn {
  border-radius: 6px;
  background: #ccc;
}



/*
bg
------------------------------ */
.bg-wh {
  background: #fff;
}

.bg-gr {
  background: #F8F8F8;
}

.bg-gr-02 {
  background: #929292;
}

.bg-bk {
  background: #000;
  color: #fff;
}

.bg-bl {
  background: #1275A0;
}

.bg-gr-02 {
  background: #ececec;
}

.bg-yl {
  background: #F9D801;
}

.bg-stripe-yl {
  background: -webkit-repeating-linear-gradient(-45deg, #FDF6C8, #FDF6C8 8px, transparent 8px, transparent 16px);
  background: repeating-linear-gradient(-45deg, #FDF6C8, #FDF6C8 8px, transparent 8px, transparent 16px);
}

.bg-img-factory {
  background-image: url(../images/bg_casestudy_factory.jpg);
  background-size: cover;
  background-repeat: no-repeat;
}



/*
others
------------------------------ */
.arrow-wrap:first-of-type {
  margin-top: 20px;
}

.arrow-wrap + .arrow-wrap {
  margin-top: 50px;
  margin-bottom: 30px;
  position: relative;
}

.arrow-wrap + .arrow-wrap:before {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 20px 28px 0 28px;
  border-color: #ff6a00 transparent transparent transparent;
  position: absolute;
  top: -33px;
  left: calc((100% - 56px)/2);
}
















  /* =================================
  index
  ================================= */
  .mv-index {
    background-size: contain;
  }

  .mv-index:after {
    width: 140px;
    height: 280px;
  top: calc((100% - 200px) / 2);
  right: -100px;
  }


  /*プリンタ画像*/
  .mv-index > img {
    width: 80%;
    bottom: -100px;
    right: 10%;
  }

.mv-index h1 {
  font-size: 40px;
  font-size: 4.0rem;
  font-weight: bold;
  letter-spacing: 4px;
  color: #fff;
  position: absolute;
  top: 90px;
  left: 5%;
}

.mv-index h1 span {
  padding-bottom: 4px;
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: normal;
  letter-spacing: 1px;
  display: block;
}

  .box-bk {
    padding: 20px 30px;
    width: 100%;
  letter-spacing: 2px;
  top: calc((100% - 153px) / 2);
  right: -100%;
}

  .mv-index.inview .box-bk {
    right: -5%;
  }

  /*ロゴ*/
  .box-bk img {
    width: 150px;
  }

  .box-bk > div {
    margin-top: 20px;
    width: 100%;
    padding-left: 0;
  }

  .box-bk .txt-lg {
    line-height: 1.5;
  }
.box-bk > div > p:last-child {
  margin-bottom: 0;
}

.page-index {
  overflow: hidden;
}

.page-index .topics {
  padding-bottom: 40px;
}

.page-index .card img {
  height: 100%;
}

/*スライダー*/
.slider {
  margin-top: 20px;
}

.slider li a div {
  padding: 0;
  position: relative;
}

.slider p {
  margin: 0;
  padding: 7px 14px;
  width: 100%;
  font-size: 28px;
  font-size: 2.8rem;
  font-family: Impact;
  letter-spacing: 1.5px;
  color: #fff;
  background: rgba(0,0,0,0.2);
  line-height: 1;
  position: absolute;
  top: -55px;
}

.slider h3 {
  margin: 0;
  padding: 15px;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.5;
  background: #F4F4F4;
}

  .slick-dots {
    bottom: -20px;
  }

  .page-index .bg-bk {
    margin-left: 0;
    width: 100%;
    padding: 40px 0;
    transform: rotate(0);
    -ms-transform: rotate(0);
    -webkit-transform: rotate(0);
  }

.page-index .bg-bk .container .row .col-sm-6:first-child {
  display: flex;
  align-items: center;
}

  .page-index .bg-bk .container .row .col-sm-6:first-child img {
    margin-left: 10%;
    margin-bottom: 20px;
    width: 80%;
    height: auto;
  }

.page-index .bg-bk .ttl-xl {
  letter-spacing: 4px;
}

.page-index .bg-bk .ttl-xl > .txt-md {
  padding-top: 10px;
  padding-bottom: 25px;
  display: block;
}

  .page-index .ttl-md {
    padding-bottom: 10px;
  }

.ttl-band {
  z-index: 0;
}

.ttl-band.bl {
  background: #1275A0;
}

.ttl-band.rd {
  background: #A01212;
}

.ttl-band.bk {
  background: #000;
}

.page-index .mv-index {
  z-index: 1;
}

.page-index .topics {
  z-index: 0;
  position: relative;
}

  .page-index .about {
    padding: 30px 5% 20px 5%;
  }

  .page-index .bg-img-factory {
    padding: 30px 5%;
    margin-top: 0;
  }

  .page-index .bg-img-factory .ttl-band {
    top: 0;
  }

  .page-index .bg-stripe-yl {
    padding: 40px 5%;
  }

.page-index .bg-stripe-yl .ttl-band {
  top: -25px;
}

/* =================================
sub
================================= */
.mv-sub {
  padding: 100px 0 40px 0;
  background-image: url(../images/bg_sub.jpg);
  background-size: contain;
  color: #fff;
  text-align: center;
}

  .mv-sub > h2 {
    font-size: 24px;
    font-size: 2.4rem;
  }

.mv-sub > p {
  padding-top: 0;
  font-size: 14px;
  font-size: 1.4rem;
  letter-spacing: 3px;
}

  /*
  パンくず
  ------------------------------ */
  .breadcrumb {
    margin-bottom: 40px;
    padding: 10px 0 20px 0;
    display:block;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    overflow-scrolling: touch;
    overflow: auto;
    white-space: nowrap;
  }

 .breadcrumb li {
  display:inline;
 }

/* Bepopとは？
---------------------------------------------------------- */
.bg-triangle {
  position: relative;
  z-index: 0;
}

.bg-triangle:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  border-width: 30vh 50vw;
  border-style: solid;
  border-color: #F8F8F8 #F9D801 #F9D801 #F8F8F8;
  z-index: -1;
}

  .page-about .bg-stripe-yl {
    padding-top: 100px;
    padding-bottom: 40px;
  }

.page-about .bg-stripe-yl h2 {
  z-index: 1;
  position: relative;
}

  .page-about .bg-stripe-yl h2 img {
    width: 130px;
    padding-right: 10px;
  }

  .page-about .row > div:first-child > img {
    margin: 25px auto 30px auto;
    display: block;
    width: 50%;
    max-width: 200px;
  }

.page-about .bg-yl {
  position: relative;
}

  .page-about .bg-yl:after {
    bottom: -20vh;
    border-width: 10vh 50vw;
  }

  .img-wrap > div:last-child {
    padding-top: 20px;
  }

  .page-about .list-ico {
    padding-top: 30px;
    padding-bottom: 20px;
  }
  
  .page-casestudy .list-ico {
    padding-top: 40px;
    padding-bottom: -40px;
  }
  
  .page-casestudy .list-ico li {
    width: 50%;
  }

.page-about .list-ico > li {
  margin-bottom: 0;
}

.page-about .bg-img-factory {
  padding: 80px 0;
}

.page-about .bg-img-factory .list-ico {
  padding-top: 0;
}

.page-about .movie-wrap h3 {
  padding-top: 20px;
  padding-bottom: 25px;
}

  /*
  ラインナップ
  ------------------------------ */
  .list-product li a {
    padding: 20px 5%;
  }

.list-product li a:hover {
  box-shadow: none;
  opacity: 1;
  top: 3px;
  left: 3px;
}

  .list-product li a > img {
    margin:  -20px 0 -10px 0;
    width: 70%;
    max-width: 300px;
  }

.list-product li a i {
  font-size: 20px;
  font-size: 2.0rem;
  position: absolute;
  top: 23px;
  right: 23px;
  transition: all .5s;
  opacity: 0;
}

.list-product li a:hover i {
  color: #FF6C00;
  opacity: 1;
}

.list-product li a h3 span {
  padding-bottom: 7px;
  font-size: 12px;
  font-size: 1.2rem;
  color: #FF6C00;
  display: block;
}

.list-product li a h3 {
  margin-bottom: 10px;
  color: #4F4F4F;
  font-size: 24px;
  font-size: 2.4rem;
  font-weight: bold;
}

.list-product li a p {
  color: #4F4F4F;
}

.list-product li a p + p {
  margin-top: 10px;
  margin-bottom: 10px;
}

  .list-ico li {
    width: 33%;
  }

  .list-ico li img {
    margin-bottom: 5px;
    width: 70px;
  }

.list-product .txt-sm {
  margin-top: 10px;
  line-height: 1.5;
}

  /*機能アイコン*/
  .list-feature {
    margin: 0 auto;
    width: 80%;
  }

.list-feature li {
  width: 25%;
  padding: 0;
}

  .list-rank {
    margin: 0 0 20px 0;
    justify-content: space-between;
  }

  .list-rank li {
    margin-bottom: 10px;
    padding: 10px;
    width: 45%;
  }

  .list-rank li:before {
    padding-top: 15px;
    width: 40px;
    height: 40px;
    top: 5px;
    left: 5px;
  }

.list-rank li:first-child:before {
  content: "1位";
}

.list-rank li:nth-child(2):before {
  content: "2位";
}

.list-rank li:nth-child(3):before {
  content: "3位";
}

.list-rank li:nth-child(4):before {
  content: "4位";
}

.list-rank li:nth-child(5):before {
  content: "5位";
}

/*
ラインナップ
------------------------------ */
.page-lineup .ttl-wrap {
  margin: 0 0 50px 0;
}

.page-lineup .ttl-wrap .btn-or {
  margin-top: 10px;
}

  .print-wrap {
    width: 100%;
    text-align: center;
  }

  .print-wrap > div {
    margin-top: 20px;
    width: 70%;
    display: inline-block;
    float: none;
  }

  .print-wrap > div + div {
    margin-left: 0;
    margin-top: 35px;
  }

.print-wrap > div:first-child,
.print-wrap > div:last-child {
  position: relative;
}

.print-wrap div:first-child:after {
  width: 30px;
  height: 22px;
  bottom: -28px;
  left: calc(50% - 15px);
  -webkit-transform: rotate(90deg);
  -moz-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  -o-transform: rotate(90deg);
  transform: rotate(90deg);
}

  .print-wrap div:last-child:after {
    width: 70px;
    height: 33px;
    top: -15px;
    left: calc(50% - 35px);
    -webkit-transform: rotate(90deg);
    -moz-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    -o-transform: rotate(90deg);
    transform: rotate(90deg);
  }

/*
機能紹介
------------------------------ */
.txt-wrap .txt-md {
  margin-bottom: 5px;
}

#pcex .txt-sm.center {
  padding-top: 25px;
}

#pcex .img-wrap img {
  margin: 30px auto 50px auto;
  width: 250px;
  display: block;
}

#pcex .card-body {
  padding: 35px 5% 10px 5%;
}

.page-features .seat .btn-wrap {
  padding-top: 15px;
}

  /*
  活用事例
  ------------------------------ */
  .center.ttl-md {
    margin-bottom: 10px;
  }

.list-casestudy li {
  display: flex;
  flex-wrap: wrap;
}

  .list-casestudy li.col-sm-6 {
    margin-bottom: 30px;
  }

.list-casestudy li.factory a {
  background-image: url(../images/bg_casestudy_factory.jpg);
}

.list-casestudy li.construction a {
  background-image: url(../images/bg_casestudy_construction.jpg);
}

.list-casestudy li.public a {
  background-image: url(../images/bg_casestudy_public.jpg);
}

.list-casestudy li a {
  padding: 50px 5% 40px 5%;
  width: 100%;
  background-size: cover;
  display: block;
  text-align: center;
}

.list-casestudy li a h2 {
  font-size: 16px;
  font-size: 1.6rem;
  padding-bottom: 30px;
  color: #F9D801;
  line-height: 1.3;
}

.list-casestudy li a h2 span {
  font-size: 28px;
  font-size: 2.8rem;
  display: block;
  letter-spacing: 3px;
}

.list-casestudy li a > span {
  padding-bottom: 8px;
  color: #fff;
  display: block;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.5;
}

.list-casestudy li a p {
  padding: 10px 25px;
  color: #fff;
  background: #333;
  border: 1px solid #fff;
  font-size: 12px;
  font-size: 1.2rem;
  display: inline-block;
}

/*工場*/
.page-factory .bg-img-factory {
  margin-top: -60px;
  padding-bottom: 50px;
}

  .page-factory .bg-img-factory .col-lg-6 + .col-lg-6 {
    margin-top: 30px;
  }

.page-factory .bg-wh {
/*  margin-top: -100px;*/
  padding: 50px 5% 15px 5%;
}

.page-factory .bg-wh .col-sm-8 {
  padding-left: 5%;
}

.page-factory .list-card .col-lg-4 {
  width: auto;
  height: 100%;
}

.page-factory .list-card .txt-lg {
  margin-bottom: 8px;
}
.page-factory .list-card .col-lg-5 > img {
}

/*
安全表示・人づくりコンテスト
------------------------------ */
/*過去*/
.caption-wrap + .caption-wrap {
  margin-top: 60px;
}

.caption-wrap > .row + .row {
  margin-top: 80px;
}

  .caption-wrap p + .btn {
  margin-top: 20px;
    display: block;
}

.caption-wrap p {
  line-height: 2.3;
}

.caption-wrap p + p {
  margin-top: 20px;
}

  .caption-wrap .col-sm-6 + .col-sm-6,
  .list-img .col-sm-6 + .col-sm-6 {
    margin-top: 30px;
  }

/*受賞*/
.award-wrap > div > .row {
  margin-top: 40px;
}

.award-wrap > div + div {
  margin-top: 80px;
}

.award-wrap .txt-md {
  padding-bottom: 10px;
}

  .award-wrap .bg-gr-02 {
    margin-top: 20px;
    padding: 20px 5%;
  }

.award-wrap .bg-gr-02 img {
  width: 100%;
  position: static;
}

/*コメント・写真がない時用*/
.award-wrap .none {
  text-align: center;
}

.award-wrap .none .col-sm-6 {
  margin: 0 auto;
}

/*応募作品*/
.list-apply li {
  margin-bottom: 60px;
}




.list-apply .ttl-pillar-sm {
  line-height: 1.2;
}

.list-apply .ttl-pillar-sm span {
  padding-bottom: 8px;
  line-height: 1.5;
}

  /* ダウンロード
  ---------------------------------------------------------- */
  .page-download .list-card .card-body {
    padding: 20px 5% 25px 5%;
  }

.page-download .list-card .card-body.bg-gr {
  background: #777;
}

  .page-download .list-card .btn-wrap {
    padding-top: 10px;
  }

.btn-zoom {
  position: relative;
}

.btn-zoom:after {
  content: "";
  width: 35px;
  height: 35px;
  background-image: url(../images/ico_zoom.png);
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  top: -30px;
  right: 15px;
}

/* リクエストBOX
---------------------------------------------------------- */
.page-request .card {
  background: none;
  border: none;
}

.page-request .card .txt-lg {
  line-height: 1.4;
}

  .page-request .card img {
    width: 70px;
    margin: 5px auto -20px auto;
}

.page-request .card-body {
  padding: 20px 5% 5px 5%;
}

  .page-request .list-btn-lg > div + div {
    margin-top: 40px;
    padding-top: 50px;
    border-top: 1px solid #ccc;
  }

/*フォーム*/
.page-request .formWrap {
  margin: 0 auto;
  max-width: 700px;
}

.page-request .formWrap label,
.page-request .formWrap input,
.page-request .formWrap textarea {
  width: 100%;
  padding: 13px;
  text-align: left;
}

.page-request .formWrap input,
.page-request .formWrap textarea {
  background: #fff;
  border: 1px solid #efefef;
}

.page-request .formWrap p {
  line-height: 1;
  display: inline-block;
  width: auto;
}

.mustwrap {
  position: relative;
}

.page-request .formWrap p.must:after {
  content: "必須";
  padding: 4px 8px;
  font-size: 10px;
  font-size: 1.0rem;
  color: #fff;
  background: #D11515;
  border-radius: 10px;
  position: absolute;
  right: -42px;
  top: -1px;
}



  /* =================================
  header
  ================================= */
  header.is-sp-only {
    width: 100%;
    height: 50px;
    padding: 10px 5%;
    z-index: 10;
    position: fixed;
    background: #000;
  }

  /*ロゴ*/
  header.is-sp-only > a,
  header.is-sp-only > a > img {
    width: auto;
    height: 100%;
  }

  .drawer-hamburger-icon,
  .drawer-hamburger-icon:after,
  .drawer-hamburger-icon:before {
    background: #fff;
  }

  .drawer-hamburger {
    width: 28px;
    padding: 15px;
  }

  .drawer-nav {
    width: 70%;
    background: #333;
    z-index: 100;
  }

  /*閉じてる時*/
  .drawer--right .drawer-nav {
    right: -70%;
  }

  .drawer--right.drawer-open .drawer-hamburger {
    right: 70%;
    padding: 15px 5px 15px;
  }
  
  .drawer-menu {
    padding: 30px 15px;
  }

  .drawer-brand,
  .drawer-menu-item {
    color: #fff;
    font-size: 15px;
    font-size: 1.5rem;
  }
  
  .drawer-menu-item {
    padding: 15px;
  }

  .drawer-menu-item span {
    font-size: 10px;
    font-size: 1.0rem;
  }

  /* =================================
  footer
  ================================= */
  footer .container {
    padding-top: 30px;
  }

  footer small {
    padding-top: 0;
  }

}  /* =================================
  import from MA website prduct pages
  ================================= */

