@charset "UTF-8";
/* CSS Document */

.contents-wrapper-right.manufacturer{
        background: url(../img/common/bg/bg5-d.png), linear-gradient(to bottom, #0f0497, #4F10D0, #0f0497, #4F10D0, #0f0497, #4F10D0);
}
.contents-wrapper-right.manufacturer .contents-wrapper-right-inner{
    background: url(../img/common/bg-star-blue-purple2.png);
    background-size: 100% auto;
    background-repeat: repeat-y;
        background-position: 50% 0;
}
.footer-copyright.manufacturer {
    background-color: rgb(79 26 196 / 80%);
}
.sign-section{
    margin-bottom:60px;
}

/***********************************************
*** メーカーブース
***********************************************/

.manufacturer-section {
  position: relative;
  z-index: 0;
  padding-top: 40px;
}
.manufacturer-lead {
  display: block;
  margin: 40px auto;
  position: relative;
  text-align: center;
}

.manufacturer-chara1 {
  position: relative;
        max-width: 1000px;
    display: block;
    margin: 0 auto;
    z-index: 20;
}
.manufacturer-chara1:before {
      position: absolute;
    content: "";
    width: 24%;
    height: 360px;
    background-image: url(../img/manufacturer/manufacturer-chara1.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: bottom;
    bottom: -40px;
    left: -2%;
    z-index: 2;
}
.manufacturer-chara1:after {
      position: absolute;
    content: "";
    width: 26%;
    height: 400px;
    background-image: url(../img/manufacturer/manufacturer-chara2.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: bottom;
    bottom: -40px;
    right: -1%;
    z-index: -1;
}
.manufacturer-deco1{
    position: relative;
}
.manufacturer-deco1:before {
        position: absolute;
    content: "";
    width: 200px;
    height: 260px;
    background-image: url(../img/manufacturer/manufacturer-chara3.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: bottom;
    top: 200px;
    right: -80%;
    z-index: 2;
}
.manufacturer-deco1:after {
        position: absolute;
    content: "";
    width: 240px;
    height: 320px;
    background-image: url(../img/manufacturer/manufacturer-chara4.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: bottom;
    top: 800px;
    right: -83%;
    z-index: 2;
}

/***********************************************
*** メニュー
***********************************************/
.manufacturer-menu-lists{
    display:grid;
     grid-template-columns: 1fr 1fr 1fr 1fr;
    column-gap: 20px;
  row-gap: 20px;
        max-width: 600px;
    margin: 0 auto 40px;
}
.manufacturer-menu-list {
    border: 2px solid rgba(154, 232, 253, 1);
    border-image: linear-gradient(-35deg, rgba(163, 253, 234, 1) 0%, rgba(154, 232, 253, 1) 33%, rgba(190, 178, 228, 1) 65%, rgba(255, 183, 227, 1) 90%);
    border-image-slice: 1;
    transition: .3s;
        box-shadow: 2px 2px 2px rgba(0,0,0,0.4);
}
.manufacturer-menu-list:hover{
    opacity:0.7;
}
.manufacturer-list-container {
    margin-top: 40px;
}
.manufacturer-lists {
  display: flex;
  column-gap: 2%;
  grid-row-gap: 60px;
  justify-content: flex-start;
  flex-wrap: wrap;
  padding-bottom: 100px;
  position: relative;
  z-index: 5;
    max-width: 500px;
    margin: 0 auto;
}
.manufacturer-list {
  background-color: #fff;
  width: 100%;
  padding: 10px;
  box-shadow: 2px 2px 2px rgb(0 0 0 / 30%);
}

.ribbon22 {
  display: inline-block;
  position: relative;
  height: 60px;
  width: 100%;
  line-height: 60px;
  text-align: center;
  padding: 7px 0;
  font-size: 18px;
  font-weight: 800;
  background: linear-gradient(-35deg, rgba(190, 178, 228, 1) 0%, rgba(190, 178, 228, 1) 13%, rgba(255, 183, 227, 1) 90%); 
  color: #FFF; 
  box-sizing: border-box;
  margin-bottom: 20px;
}
.ribbon22 h3 {
  margin: 0;
  padding: 0 30px;
  border-top: dashed 1px #FFF; 
  border-bottom: dashed 1px #FFF;
  line-height: 1;
  height: 46px;
  vertical-align: unset;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
}
.ribbon22 h3.break{
        display: block;
  padding: 5px 30px;
}
.ribbon22:before {
  position: absolute;
  content: '';
  width: 0px;
  height: 0px;
  z-index: 1;
}
.ribbon22:before {
  top: 0;
  left: 0;
  border-width: 30px 0px 30px 15px;
  border-color: transparent transparent transparent #fff;
  border-style: solid;
}
.ribbon22:after {
  position: absolute;
  content: '';
  width: 0px;
  height: 0px;
  z-index: 1;
  top: 0;
  right: 0;
  border-width: 30px 15px 30px 0px;
  border-color: transparent #fff transparent transparent;
  border-style: solid;
}
@media only screen and (max-width: 1200px) {
    .manufacturer-chara1:before {
    left: 2%;
}
.manufacturer-chara1:after {
    right:2%;
}
    .manufacturer-deco1:before,
    .manufacturer-deco1:after{
        display:none;
    }

  .manufacturer-list.wide {
    width: 100%;
  }
  .manufacturer-lists {
    padding-bottom: 60px;
  }
}


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

.manufacturer-menu-lists {
    column-gap: 10px;
    row-gap: 10px;
    max-width: 90%;
}
  .manufacturer-lists {
    max-width: 90%;
  }
}

.manufacturer-list-inner {
  background-color: #fff;
  border: 4px solid rgba(154, 232, 253, 1);
  border-image: linear-gradient(-35deg, rgba(163, 253, 234, 1) 0%, rgba(154, 232, 253, 1) 33%, rgba(190, 178, 228, 1) 65%, rgba(255, 183, 227, 1) 90%);
  border-image-slice: 1;
  height: 100%;
  padding: 20px;
}
.manufacturer-list-heading span.small {
  font-size: 12px;
  margin: 0 3px;
    padding-top: 3px;
}
.manufacturer-list-heading span.mid {
  font-size: 16px;
}
.manufacturer-list-image {
  margin-bottom: 20px;
    padding: 10px;
}
.manufacturer-list-text {
  font-size: 14px;
  line-height: 1.5;
  margin-bottom: 20px;
  text-align: justify;
overflow-wrap: break-word;
    word-break: break-word;
    word-break: break-all;
}
.manufacturer-list-btn {
  background-color: #44dde1;
  color: #fff;
  border-radius: 80px;
  font-size: 16px;
  text-align: center;
  margin-bottom: 20px;
  box-shadow: 2px 2px 2px rgb(0 0 0 / 30%);
  line-height: 1.3;
}
.manufacturer-list-btn .small {
  font-size: 0.8em;
}
.manufacturer-list-btn-link {
  padding: 10px 0;
  display: block;
  width: 100%;
  font-weight: 800;
}
.manufacturer-list-btn-link:link, .manufacturer-list-btn-link:hover, .manufacturer-list-btn-link:visited {
  text-decoration: none;
  color: #fff;
}
.manufacturer-list-btn-link .ib{
    display:inline-block;
}
.manufacturer-list-credit {
  font-size: 10px;
  line-height: 1.3;
}
/*
.manufacturer-list-credit {
    font-size: 0.75vw;
}
*/
.manufacturer-sub-lists {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
    flex-direction: column;
}
.manufacturer-sub-list {
       background: #ffe7f2;
    padding: 13px;
    margin-bottom: 30px;
}
@media only screen and (max-width: 800px) {
  .manufacturer-list {
    width: 100%;
  }
  .manufacturer-sub-lists {
    flex-wrap: wrap;
  }
  .manufacturer-sub-list {
    width: 100%;
    margin-bottom: 40px;
  }
}
