@charset "utf-8";

/* ==========================================================================
font-family
========================================================================== */
@import url("/business/solution/idea-showroom/detail/css/fonts.css");


/* ==========================================================================
reset
========================================================================== */
/*** The new CSS reset - version 1.8.2 (last updated 23.12.2022) ***/

*:where(:not(html,iframe,canvas,img,svg,video,audio):not(svg *,symbol *)){all:unset;display:revert}*,*::before,*::after{box-sizing:border-box}a,button{cursor:revert}ol,ul,menu{list-style:none}img{max-inline-size:100%;max-block-size:100%}table{border-collapse:collapse}input,textarea{-webkit-user-select:auto}textarea{white-space:revert}meter{-webkit-appearance:revert;appearance:revert}pre{all:revert}::placeholder{color:unset}::marker{content:""}:where([hidden]){display:none}:where([contenteditable]:not([contenteditable="false"])){-moz-user-modify:read-write;-webkit-user-modify:read-write;overflow-wrap:break-word;-webkit-line-break:after-white-space;-webkit-user-select:auto}:where([draggable="true"]){-webkit-user-drag:element}:where(dialog:modal){all:revert}


/* ==========================================================================
base
========================================================================== */
:root {
  --color-blue: #0062C2;
  --color-sky: #F0F5FA;
  --color-gray: #E1E1E1;
  --color-gray2: #6D6D6D;
  --color-black: #000000;
  --color-white: #ffffff;
}
body {
  margin: 0;
  padding: 0;
  font-family: 'Open Sans', 'Arial', 'メイリオ', 'Meiryo', sans-serif;
  line-height: 1.75;
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
}
img {
  vertical-align: middle;
}
summary {
  display: block;
}
summary::-webkit-details-marker {
  display: none;
}

area {
  cursor: pointer;
}

/* ==========================================================================
layout
========================================================================== */
body.is-fixed {
  position: fixed;
  left: 0;
  width: 100vw;
}
.main {
  position: relative;
  z-index: 1;
  padding: 110px 0 90px;
  background: url("/business/solution/idea-showroom/detail/img/contents_bg.png") repeat-y top center/100%;
}
@media screen and (max-width: 768px) {
  .main {
    padding: 95px 0 72px;
  }
}
/*.main::before {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  backdrop-filter: blur(8px);
  content: "";
}*/
.contents {
  position: relative;
  width: 100%;
  max-width: 1050px;
  padding: 0 25px;
  margin: 0 auto;
  letter-spacing: 0.04em;
}
@media screen and (max-width: 768px) {
  .contents {
    max-width: 100%;
  }
}
.contents-inner {
  max-width: 100%;
  padding: 54px 10% 70px;
  border-radius: 20px;
  background-color: var(--color-white);
}
@media screen and (max-width: 768px) {
  .contents-inner {
    padding: 46px 4% 60px;
  }
}


/* ==========================================================================
parts
========================================================================== */
/*****   heading   *****/
.heading-1 {
  margin-bottom: 20px;
  font-size: 30px;
  font-weight: 700;
  line-height: 1.6;
  color: var(--color-blue);
}
@media screen and (max-width: 768px) {
  .heading-1 {
    font-size: 22px;
    font-weight: 400;
  }
}
.heading-1._center {
  text-align: center;
}
@media screen and (max-width: 768px) {
  .heading-1._center {
    font-size: 20px;
    font-weight: 700; 
  }
}
.heading-2 {
  margin: 90px 0 20px;
  padding-left: 24px;
  border-left: 6px solid var(--color-blue);
  font-size: 24px;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .heading-2 {
    margin-top: 45px;
    padding-left: 16px;
    font-size: 20px;
  }
}
.heading-2._center {
  margin-top: 80px;
  padding: 0;
  border-left: none;
  font-size: 22px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .heading-2._center {
    margin-top: 50px;
    font-size: 18px; 
  }
}
.heading-3 {
  margin: 20px 0;
  font-size: 22px;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .heading-3 {
    font-size: 18px; 
  }
}
.heading-3._fz {
  font-size: 20px;
}
@media screen and (max-width: 768px) {
  .heading-3._fz {
    font-size: 16px; 
  }
}
.heading-3._under {
  margin: 90px 0 20px;
  padding-bottom: 17px;
  border-bottom: 1px solid var(--color-gray);
  font-size: 18px;
  line-height: 1.78;
}
@media screen and (max-width: 768px) {
  .heading-3._under {
    margin-top: 45px;
    font-size: 14px;
  }
}
.heading-3._blue {
  margin: 20px 0;
  font-size: 18px;
  line-height: 1.78;
  color: var(--color-blue);
}
@media screen and (max-width: 768px) {
  .heading-3._blue {
    font-size: 15px;
  }
}
.heading-4 {
  margin: 33px 0 20px;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.78;
}
@media screen and (max-width: 768px) {
  .heading-4 {
    font-size: 16px;
  }
}
.heading-4._blue {
  font-size: 16px;
  color: var(--color-blue);
}
@media screen and (max-width: 768px) {
  .heading-4._blue {
    font-size: 14px;
  }
}
.heading-4._emphasis {
  font-size: 28px;
  line-height: 1.79;
  color: var(--color-blue);
}
@media screen and (max-width: 768px) {
  .heading-4._emphasis {
    font-size: 20px;
  }
}


/*****   category   *****/
.categoryA {
  margin: 0 0 20px;
}
.categoryA-inner {
  margin-top: 20px;
  padding: 20px 51px;
  border: 2px solid var(--color-blue);
  border-radius: 20px;
}
@media screen and (max-width: 768px) {
  .categoryA-inner {
    padding: 20px 30px;
  }
}
.categoryA-ttl {
  font-size: 30px;
  font-weight: 700;
  line-height: 1.6;
}
@media screen and (max-width: 768px) {
  .categoryA-ttl {
    font-size: 22px;
  }
}
.categoryA-btn {
  position: relative;
  display: block;
  margin-left: auto;
  padding: 11px 9px 11px 47px;
  border: 1px solid var(--color-blue);
  font-size: 14px;
  font-weight: 700;
  color: var(--color-black);
  cursor: pointer;
  transition: background .3s, color .3s;
}
.categoryA-btn::before {
  position: absolute;
  top: 50%;
  left: 28px;
  transform: translate(-50%,-50%);
  display: block;
  width: 25px;
  height: 25px;
  background-color: var(--color-blue);
  mask-image: url("/business/solution/idea-showroom/detail/img/i_star.svg");
  mask-repeat: no-repeat;
  mask-size: contain;
  -webkit-mask-image: url("/business/solution/idea-showroom/detail/img/i_star.svg");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: contain;
  transition: background .3s;
  content: "";
}
.categoryA-btn:hover {
  background-color: var(--color-blue);
  color: var(--color-white);
}
.categoryA-btn:hover::before {
  background-color: var(--color-white);
}
.categoryATag {
  margin-top: 34px;
}
@media screen and (max-width: 768px) {
  .categoryATag {
    margin-top: 20px;
  }
}
.categoryATag-list {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 14px;
}
@media screen and (max-width: 768px) {
  .categoryATag-list {
    display: block;
  }
}
.categoryATag-item {
  font-size: 14px;
  line-height: 1.79;
}
.categoryB {
  margin: 20px 0;
  padding: 21px 20px 16px;
  background-color: var(--color-sky);
}
.categoryGray {
  margin: 20px 0;
  padding: 25px 30px;
  background-color: #f2f2f2;
}
.categoryGray p{
  margin-top: 5px;
}
.categoryGray a:hover{
  opacity: 0.7;
}
.categoryB-ttl {
  font-size: 24px;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .categoryB-ttl {
    font-size: 18px;
  }
}


/*****   text   *****/
.txt {
  margin: 20px 0;
  font-size: 16px;
}

.txt._center{
  text-align: center;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .txt {
    font-size: 14px;
  }
}
.txt-blue {
  font-size: 16px;
  font-weight: 700;
  color: var(--color-blue);
}
@media screen and (max-width: 768px) {
  .txt-blue {
    font-size: 14px;
  }
}
.b-center {
  margin: 20px 0;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.78;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .b-center {
    font-size: 14px;
  }
}
.caption {
  margin: 20px 0;
  font-size: 12px;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  .caption {
    font-size: 11px;
  }
}
.note {
  position: relative;
  margin: 20px 0;
  padding-left: 1.3em;
  font-size: 10px;
  line-height: 1.5;
  color: #888888;
}
.note::before {
  position: absolute;
  top: 7px;
  left: 0;
  transform: translateY(-50%);
  display: block;
  content: "※";
}
.bold {
  font-weight: 700;
}


/*****   list   *****/
.listBox {
  display: flex;
  justify-content: space-between;
  gap: 0 3%;
  margin: 20px 0;
}
@media screen and (max-width: 768px) {
  .listBox {
    flex-direction: column;
    gap: 10px 0;
  }
}
.listBox-listArea {
  width: calc(100% - 3% - min(30%, 235px));
}
@media screen and (max-width: 768px) {
  .listBox-listArea {
    width: 100%;
  }
}
.listBox-imgArea {
  width: min(30%, 235px);
}
@media screen and (max-width: 768px) {
  .listBox-imgArea {
    width: 100%;
    text-align: center;
  }
}
.listBox-listArea .numList {
  margin-top: 0;
}
.numList {
  margin: 40px 0;
}
.numList-list {
  counter-reset: number 0;
}
.numList-item {
  position: relative;
  margin: 20px 0;
  padding-left: 50px;
  font-size: 16px;
}
@media screen and (max-width: 768px) {
  .numList-item {
    padding-left: 45px;
    font-size: 14px;
  }
}
.numList-item:first-child {
  margin-top: 0;
}
.numList-item::before {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 31px;
  height: 31px;
  border: 2px solid var(--color-blue);
  font-size: 14px;
  line-height: 1;
  color: var(--color-blue);
  counter-increment: number 1;
  content: counter(number);
}
@media screen and (max-width: 768px) {
  .numList-item::before {
    transform: translateY(-3px);
    width: 29px;
    height: 29px;
    font-size: 13px; 
  }
}
.numList-ttl {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.78;
}
@media screen and (max-width: 768px) {
  .numList-ttl {
    font-size: 15px;
  }
}
.numList-txt {
  margin-top: 4px;
  font-size: 16px;
}
@media screen and (max-width: 768px) {
  .numList-txt {
    font-size: 14px;
  }
}
.numList-link {
  font-size: 16px;
  font-weight: 700;
  color: var(--color-blue);
  text-decoration: underline;
}
@media screen and (max-width: 768px) {
  .numList-link {
    font-size: 14px;
  }
}
.numList-link:hover {
  text-decoration: none;
}
.discList {
  margin: 20px 0;
}
.discList-list {
  padding-left: 1em;
}
.discList-item {
  padding-left: 0.4em;
  font-size: 16px;
} 
@media screen and (max-width: 768px) {
  .discList-item {
    font-size: 14px;
  }
}
.discList-item::marker {
  content: "・";
}

.decimalList {
  margin: 20px 0;
}
.decimalList-list {
  padding-left: 1.5em;
  list-style: decimal;
}
.decimalList-item {
  padding-left: 0.4em;
  font-size: 16px;
} 
@media screen and (max-width: 768px) {
  .decimalList-item {
    font-size: 14px;
  }
}
.decimalList-item::marker {
  content: inherit;
}

/*****   accordion   *****/
.accordion { 
  padding: 31px 0 28px;
  border-bottom: 1px solid var(--color-gray);
}
.accordion-ttl {
  position: relative;
  display: flex;
  align-items: center;
  flex-direction: row;
  justify-content: space-between;
  padding-right: 40px;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.78;
  cursor: pointer;
}
h2.accordion-h2 > .accordion-ttl {
  font-size: 24px;
}
@media screen and (max-width: 768px) {
  .accordion-ttl {
    font-size: 15px;
  }
  h2.accordion-h2 > .accordion-ttl {
    font-size: 20px;
  }
}
.accordion-icn::before, .accordion-icn::after {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  display: block;
  width: 30px;
  height: 1px;
  background-color: var(--color-black);
  content: "";
}
@media screen and (max-width: 768px) {
  .accordion-icn::before, .accordion-icn::after {
    width: 24px;
  }
}
.accordion-icn::before {
  transform: translateY(-50%) rotate(90deg);
  transition: transform .3s;
}
details[open] > summary .accordion-icn::before {
  transform: translateY(-50%) rotate(180deg);
}
.accordion-cont {
  margin-top: 35px;
  font-size: 16px;
}
@media screen and (max-width: 768px) {
  .accordion-cont {
    font-size: 14px;              
  }
}


/*****   layout   *****/
.line {
  width: 100%;
  margin: 40px 0;
  border-bottom: 1px solid var(--color-gray);
}
.layoutA, .layoutB, .layoutC-content {
  display: flex;
  gap: 0 3%;
  margin: 35px 0;
}
@media screen and (max-width: 768px) {
  .layoutA, .layoutB, .layoutC-content {
    flex-direction: column;
    gap: 10px 0;
  }
}
.layoutA-txtArea {
  width: calc(100% - 3% - min(30%, 235px));
}
@media screen and (max-width: 768px) {
  .layoutA-txtArea {
    width: 100%;
  }
}
.layoutA-txtArea > *:first-of-type, .layoutB-txtArea > *:first-of-type {
  margin-top: 0;
}
.layoutA-imgArea {
  width: min(30%, 235px);
}
@media screen and (max-width: 768px) {
  .layoutA-imgArea {
    width: 100%;
    text-align: center;
  }
}
.layoutB-txtArea, .layoutB-imgArea, .layoutC-txtArea, .layoutC-imgArea {
  width: calc((100% - 3%) / 2);
}
@media screen and (max-width: 768px) {
  .layoutB-txtArea, .layoutB-imgArea, .layoutC-txtArea, .layoutC-imgArea {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .layoutB-imgArea, .layoutC-imgArea {
    text-align: center;
  }
  .layoutC-imgArea .caption{
    text-align: left;
  }
}
.layoutB-imgArea .caption {
  margin: 0 0 12px;
  text-align: center;
}
.layout-img {
  display: block;
}
.layout-img:not(:first-of-type) {
  margin-top: 30px;
}
.layout-btn {
  position: relative;
  display: block;
  margin: 12px 0 12px auto;
  padding: 6px 0 6px 45px;
  font-size: 14px;
  font-weight: 700;
  color: var(--color-blue);
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .layout-btn {
    font-size: 12px;
  }
}
.layout-btn::before {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  display: block;
  width: 33px;
  height: 33px;
  background-color: var(--color-blue);
  border-radius: 50%;
  content: "";
}
@media screen and (max-width: 768px) {
  .layout-btn::before {
    width: 30px;
    height: 30px;
  }
}
.layout-btn span::before, .layout-btn span::after {
  position: absolute;
  top: 50%;
  left: 17px;
  transform: translate(-50%, -50%);
  display: block;
  width: 14px;
  height: 2px;
  background-color: var(--color-white);
  content: "";
}
@media screen and (max-width: 768px) {
  .layout-btn span::before, .layout-btn span::after {
    left: 15px;
    width: 13px;
  }
}
.layout-btn span::after {
  transform: translate(-50%, -50%) rotate(90deg);
}
.layoutC-content {
  display: flex;
  gap: 0 3%;
  margin: 35px 0;
}
@media screen and (max-width: 768px) {
  .layoutC-content {
    flex-direction: column;
    gap: 10px 0;
    margin: 28px 0;
  }
}
.layoutC-sub {
  font-size: 16px;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .layoutC-sub {
    font-size: 14px;
  }
}
.layoutC-imgArea .caption {
  margin-top: 7px;
  text-align: left;
}
.layoutD {
  position: relative;
  display: flex;
  gap: 0 15%;
  margin: 20px 0;
}
@media screen and (max-width: 768px) {
  .layoutD {
    flex-direction: column;
    gap: 88px 0;
  }
}
.layoutD::after {
  position: absolute;
  top: 0;
  left: 50%;
  width: 1px;
  height: 100%;
  background-color: var(--color-gray);
  content: "";
}
@media screen and (max-width: 768px) {
  .layoutD::after {
    top: 50%;
    left: 50%;
    transform: translateX(-50%);
    width: 78%;
    height: 1px;
  }
}
.layoutD-item {
  width: calc((100% - 15%) / 2);
}
@media screen and (max-width: 768px) {
  .layoutD-item {
    width: 100%;
  }
}
.layoutD .heading-4._emphasis {
  margin-top: 0;
}
.layoutD-item > .discList:last-child, .layoutD-item > .layout-img:last-child {
  margin: 35px 0 0;
}


/*****   table   *****/
.table {
  width: 100%;
  margin: 20px 0;
}
.table tbody th {
  width: 35%;
  border: 1px solid #797979;
  background-color: #d9d9d9;
  color: #797979;
  text-align: left;
}
.table tbody td {
  width: 65%;
  border: 1px solid #797979;
  background-color: #fff;
}
.table tbody th, .table tbody td {
  padding: 12px;
  font-size: 16px;
}
@media screen and (max-width: 768px) {
  .table tbody th, .table tbody td {
    padding: 10px;
  }
}


/*****   img   *****/
.mv {
  width: 100%;
  margin: 45px 0 20px;
}
@media screen and (max-width: 768px) {
  .mv {
    margin-top: 35px;
  }
}
.imgBox {
  margin: 45px 0 20px;
}
@media screen and (max-width: 768px) {
  .imgBox {
    margin-top: 35px;
  }
}
.imgBox-list {
  display: flex;
  flex-wrap: wrap;
  gap: 20px 3%;
}
@media screen and (max-width: 768px) {
  .imgBox-list {
    flex-direction: column;
    gap: 20px 0;
  }
}
.imgBox-list._right {
  justify-content: flex-end;
  gap: 20px 5.7%;
}
@media screen and (max-width: 768px) {
  .imgBox-list._right {
    flex-direction: column;
    gap: 20px 0;
  }
}
.imgBox-item {
  display: flex;
  width: calc((100% - 3%) / 2);
}
@media screen and (max-width: 768px) {
  .imgBox-item {
    width: 100%;
  }
}
.imgBox-list._right .imgBox-item {
  width: calc((100% - 11.4%) / 3);
}
@media screen and (max-width: 768px) {
  .imgBox-list._right .imgBox-item {
    width: 100%;
  }
}
.imgBox-img._zoom {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  cursor: pointer;
}
.imgBox-btn {
  position: relative;
  display: block;
  margin: 12px 0 12px auto;
  padding: 6px 0 6px 45px;
  font-size: 14px;
  font-weight: 700;
  color: var(--color-blue);
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .imgBox-btn {
    font-size: 12px;
  }
}
.imgBox-btn::before {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  display: block;
  width: 33px;
  height: 33px;
  background-color: var(--color-blue);
  border-radius: 50%;
  content: "";
}
@media screen and (max-width: 768px) {
  .imgBox-btn::before {
    width: 30px;
    height: 30px;
  }
}
.imgBox-btn span::before, .imgBox-btn span::after {
  position: absolute;
  top: 50%;
  left: 17px;
  transform: translate(-50%, -50%);
  display: block;
  width: 14px;
  height: 2px;
  background-color: var(--color-white);
  content: "";
}
@media screen and (max-width: 768px) {
  .imgBox-btn span::before, .imgBox-btn span::after {
    left: 15px;
    width: 13px;
  }
}
.imgBox-btn span::after {
  transform: translate(-50%, -50%) rotate(90deg);
}
.imgBox._center {
  display: flex;
  justify-content: center;
}
.imgBox .caption {
  margin-top: 7px;
}
.movieBox {
  margin: 45px 0 20px;
}
.movieBox .caption {
  margin-top: 7px;
}
.movieBox-list {
  display: flex;
  justify-content: flex-end;
  gap: 20px 5.7%;
}
.movieBox-item {
  width: calc((100% - 11.4%) / 3);
}
.movieBox-btn {
  cursor: pointer;
}
.movieBox-youtube iframe {
  aspect-ratio: 16 / 9;
  width: 100%;
  height: auto;
}

/*****   modaal plugin   *****/
.modaal-wrapper {
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: auto;
  height: auto;
}
.modaal-image.modaal-wrapper {
  overflow: hidden;
}
.modaal-image .modaal-outer-wrapper {
  display: block;
}
.modaal-image .modaal-inner-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
}
.modaal-image .modaal-container {
  max-width: 1100px;
  padding: 40px;
  background-color: transparent;
  box-shadow: none;
}
@media screen and (max-width: 768px) {
  .modaal-image .modaal-container {
    padding: 40px 20px 20px;
  }
}
.modaal-image .modaal-content {
  background-color: var(--color-white);
  box-shadow: 0 4px 15px rgb(0 0 0 / 20%);
}
.modaal-image img {
  display: inline-block;
  max-height: calc(100vh - 120px);
  object-fit: contain;
}
.modaal-video .modaal-outer-wrapper {
  display: block;
}
.modaal-video .modaal-inner-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
}
.modaal-video .modaal-container-wrapper {
  position: relative;
  width: 100%;
  max-width: 1180px;
  padding: 40px;
}
.modaal-video-wrap {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
}
.modaal-video-container {
  max-width: none;
  height: auto;
  padding: 0;
}
.modaal-video-container embed, .modaal-video-container iframe, .modaal-video-container object {
  position: static;
  height: auto;
  aspect-ratio: 16 / 9;
}
.modaal-close {
  position: absolute;
  top: 0;
  right: 40px;
  width: 40px;
  height: 40px;
  border-radius: 0;
}
@media screen and (max-width: 768px) {
  .modaal-close {
    top: 5px;
    right: 20px;
    width: 30px;
    height: 30px;
  }
}
.modaal-close:after, .modaal-close:before {
  top: 5px;
  left: 18px;
  height: 30px;
}
@media screen and (max-width: 768px) {
  .modaal-close:after, .modaal-close:before {
    top: 0;
    left: 13px;
    height: 30px;
  }
}
.modaal-close:focus, .modaal-close:hover {
  background-color: transparent;
}


/*****   tag   *****/
.tagA {
  margin: 40px 0 20px;
}
@media screen and (max-width: 768px) {
  .tagA {
    margin: 30px 0 20px;
  }
}
.tagA-list {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
}
@media screen and (max-width: 768px) {
  .tagA-list {
    align-items: flex-start;
    flex-direction: column;
    gap: 10px;
  }
}
.tagA-item {
  padding: 6px 22px;
  border-radius: 8px;
  background-color: var(--color-blue);
  color: var(--color-white);
  font-size: 12px;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .tagA-item {
    padding: 4px 14px;
    border-radius: 6px;
    font-size: 10px;
  }
}
.tagB {
  margin: 30px 0 20px;
}
.tagB-list {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
}
@media screen and (max-width: 768px) {
  .tagB-list {
    align-items: flex-start;
    flex-direction: column;
    gap: 10px;
  }
}
.tagB-item {
  padding: 6px 0;
  font-size: 12px;
  font-weight: 700;
}
.tagB-item:first-child {
  border-bottom: 2px solid var(--color-blue);
  color: var(--color-blue);
}
.keyword {
  margin: 20px 0;
}
.keyword-list {
  display: flex;
  flex-wrap: wrap;
  gap: 13px 20px;
}
@media screen and (max-width: 768px) {
  .keyword-list {
    gap: 3px 5px;
  }
}
.keyword-item {
  font-size: 10px;
  color: var(--color-gray2);
}


/*****   link   *****/
.btnA {
  margin: 20px 0;
}
.btnA-link {
  position: relative;
  display: block;
  width: 100%;
  padding: 31px 70px;
  border: 2px solid var(--color-blue);
  border-radius: 10px;
  font-size: 18px;
  font-weight: 700;
  background-color: var(--color-blue);
  color: var(--color-white);
  text-align: center;
  transition: background .3s, color .3s;
}
@media screen and (max-width: 768px) {
  .btnA-link {
    padding: 16px 35px;
    font-size: 14px; 
  }
}
.btnA-link::after {
  position: absolute;
  top: 50%;
  right: 50px;
  transform: translateY(-50%);
  border-top: 7px solid transparent;
  border-right: none;
  border-bottom: 7px solid transparent;
  border-left: 14px solid var(--color-white);
  transition: border .3s;
  content: "";
}
@media screen and (max-width: 768px) {
  .btnA-link::after {
    right: 20px;
    border-top-width: 5px;
    border-bottom-width: 5px;
    border-left-width: 10px;
  }
}
.btnA-link:hover {
  background-color: var(--color-white);
  color: var(--color-blue);
}
.btnA-link:hover::after {
  border-left-color: var(--color-blue);
}
.btnB {
  max-width: 490px;
  margin: 20px auto;
}
.btnB-link {
  display: block;
  padding: 20px 36px;
  border: 1px solid var(--color-blue);
  border-radius: 36px;
  font-size: 18px;
  font-weight: 700;
  background-color: var(--color-blue);
  color: var(--color-white);
  text-align: center;
  transition: background .3s, color .3s;
}
@media screen and (max-width: 768px) {
  .btnB-link {
    padding: 17px 30px;
    border-radius: 30px;
    font-size: 14px;
  }
}
.btnB-link span::after {
  display: inline-block;
  width: 11px;
  height: 11px;
  margin-left: 5px;
  background-color: var(--color-white);
  mask-image: url("/business/solution/idea-showroom/detail/img/i_blank.svg");
  mask-repeat: no-repeat;
  mask-size: contain;
  -webkit-mask-image: url("/business/solution/idea-showroom/detail/img/i_blank.svg");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: contain;
  transition: background .3s;
  content: "";
}

.btnF-link span::after {
  display: inline-block;
  width: 11px;
  height: 11px;
  margin-left: 5px;
  background-color: var(--color-white);
  mask-image: url("/business/solution/idea-showroom/detail/img/i_blank.svg");
  mask-repeat: no-repeat;
  mask-size: contain;
  -webkit-mask-image: url("/business/solution/idea-showroom/detail/img/i_blank.svg");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: contain;
  transition: background .3s;
  content: "";
}
.btnB-link:hover {
  background-color: var(--color-white);
  color: var(--color-blue);
}
.btnB-link:hover span::after {
  background-color: var(--color-blue);
}

.btnF-link:hover span::after {
  background-color: var(--color-blue);
}
.btnC {
  max-width: 490px;
  margin: 20px auto;
}
@media screen and (max-width: 768px) {
  .btnC {
    max-width: 100%;
    text-align: center;
  }
}
.btnC-link {
  display: block;
  padding: 20px 36px;
  border: 1px solid var(--color-blue);
  font-size: 16px;
  font-weight: 700;
  background-color: var(--color-white);
  color: var(--color-blue);
  border-radius: 36px;
  text-align: center;
  transition: background .3s, color .3s;
}
@media screen and (max-width: 768px) {
  .btnC-link {
    display: inline-block;
    padding: 17px 36px;
    border-radius: 30px;
    font-size: 14px;
  }
}
.btnC-link:hover {
  background-color: var(--color-blue);
  color: var(--color-white);
}
.btnD {
  max-width: 490px;
  margin: 20px auto;
}
.btnD-link {
  display: block;
  padding: 20px 36px;
  border: 1px solid var(--color-blue);
  border-radius: 36px;
  font-size: 18px;
  font-weight: 700;
  background-color: var(--color-blue);
  color: var(--color-white);
  text-align: center;
  transition: background .3s, color .3s;
}

.btnD-more{
  max-width: 520px!important;
}

.btnD-text {
 
  padding: 20px 10px !important;
}
@media screen and (max-width: 768px) {
  .btnD-link {
    padding: 12px 36px;
    border-radius: 41px;
    font-size: 14px;
  }
}
.btnD-link:hover {
  background-color: var(--color-white);
  color: var(--color-blue);
}
.btnE {
  margin: 20px 0;
}
.btnE-list {
  display: flex;
  gap: 20px 3%;
}
.btnF {
  margin: 20px auto 50px;
}
.btnF-list {
  display: flex;
  gap: 20px 3%;
}
@media screen and (max-width: 768px) {
  .btnE-list {
    align-items: center;
    flex-direction: column;
    gap: 20px 0;
  }

  .btnF-list {
    align-items: center;
    flex-direction: column;
    gap: 20px 0;
  }
}
.btnE-item {
  width: calc((100% - 3%) / 2);
}

.btnF-item {
  width: calc((100% - 3%) / 2);
}

@media screen and (max-width: 768px) {
  .btnE-item {
    width: auto;
  }

  .btnF-item {
    width: 100%;
  }
}
.btnE-link {
  display: block;
  padding: 20px 36px;
  border: 1px solid var(--color-blue);
  border-radius: 36px;
  font-size: 14px;
  font-weight: 700;
  background-color: var(--color-white);
  color: var(--color-blue);
  text-align: center;
  transition: background .3s, color .3s;
}

.btnF-link {
  display: block;
  padding: 20px 20px;
  border: 1px solid var(--color-white);
  border-radius: 36px;
  font-size: 18px;
  font-weight: 700;
  background-color: var(--color-blue);
  color: var(--color-white);
  text-align: center;
  transition: background .3s, color .3s;
}

@media screen and (max-width: 1000px) and (min-width: 768px) {

  .btnF-link {
    padding: 20px 10px;
    font-size: 14px;
  }

}

@media screen and (max-width: 768px) {
  .btnE-link {
    padding: 18px 38px;
    border-radius: 30px;
    font-size: 13px;
  }

  .btnF-link {
    padding: 18px 20px;
    border-radius: 30px;
    font-size: 13px;
  }
}
.btnE-link:hover {
  background-color: var(--color-blue);
  color: var(--color-white);
  
}

.btnF-link:hover {
  background-color: var(--color-white);
  color: var(--color-blue);
  border: 1px solid var(--color-blue);
}
.link-list {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  margin: 20px 0;
}
@media screen and (max-width: 768px) {
  .link-list {
    flex-direction: column;
    gap: 10px 0;
  }
}
.link-item {
  display: flex;
}
.link-link {
  font-size: 14px;
  font-weight: 700;
  line-height: 1.79;
  color: var(--color-blue);
  text-decoration: underline;
}
.link-link:not([href]) {
  color: #75757c;
}
@media screen and (max-width: 768px) {
  .link-link {
    font-size: 11px;
  }
}
.link-link._arrow, .link-link._blank, .link-link._movie {
  position: relative;
  padding: 4px 0 4px 45px;
  text-decoration: none;
}
@media screen and (max-width: 768px) {
  .link-link._arrow, .link-link._blank, .link-link._movie {
    padding-left: 40px;
  }
}
.link-link._arrow::before, .link-link._blank::before, .link-link._movie::before {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  display: block;
  width: 33px;
  height: 33px;
  border-radius: 50%;
  background-color: var(--color-blue);
  content: "";
}

.link-link:not([href])::before{
  background-color: #75757c;
  content: "";
}
@media screen and (max-width: 768px) {
  .link-link._arrow::before, .link-link._blank::before, .link-link._movie::before {
    width: 30px;
    height: 30px;
  }
}
.link-link._arrow::after, .link-link._blank::after, .link-link._movie::after {
  position: absolute;
  top: 50%;
  left: 16px;
  content: "";
}
@media screen and (max-width: 768px) {
  .link-link._arrow::after, .link-link._blank::after, .link-link._movie::after {
    left: 15px;
  }
}
.link-link._arrow::after {
  transform: translate(-50%, -50%) rotate(45deg);
  display: block;
  width: 7px;
  height: 7px;
  border-top: 2px solid var(--color-white);
  border-right: 2px solid var(--color-white);
}
.link-link._blank::after {
  transform: translate(-50%, -50%);
  width: 11px;
  height: 10px;
  background: url("/business/solution/idea-showroom/detail/img/i_blank.svg") no-repeat center/contain;
}
@media screen and (max-width: 768px) {
  .link-link._blank::after {
    width: 9px;
    height: 9px;
  }
}
.link-link._movie::after {
  left: 18px;
  transform: translate(-50%, -50%);
  border-top: 6px solid transparent;
  border-right: none;
  border-bottom: 6px solid transparent;
  border-left: 12px solid var(--color-white);
}
@media screen and (max-width: 768px) {
  .link-link._movie::after {
    left: 17px;
    border-top-width: 4px;
    border-bottom-width: 4px;
    border-left-width: 8px;
  }
}
.link-link:hover {
  text-decoration: none;
}
.link-txt {
  font-weight: 700;
  line-height: 1.79;
  color: var(--color-blue);
  text-decoration: underline;
}
.link-txt:hover {
  text-decoration: none;
}
.link-img {
  display: block;
  text-align: center;
  transition: transform .3s;
}
.link-img:hover {
  transform: scale(1.03);
}


/*****   card   *****/
.cardA {
  display: flex;
  align-items: center;
  margin: 16px 0;
  padding: 24px 0;
  background-color: var(--color-sky);
}
@media screen and (max-width: 768px) {
  .cardA {
    flex-direction: column;
    padding: 27px 0 48px;
  }
}
.cardA-term {
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: center;
  width: 100%;
  max-width: 185px;
  padding: 0 20px;
}
.cardA-ttl {
  font-size: 18px;
}
@media screen and (max-width: 768px) {
  .cardA-ttl {
    font-size: 16px;
  }
}
.cardA-en {
  margin-top: 3px;
  font-size: 10px;
  font-weight: 500; 
  color: var(--color-blue);
}
.cardA-desc {
  padding: 0 20px;
}
@media screen and (max-width: 768px) {
  .cardA-desc {
    margin-top: 14px;
  }
}
.cardA-item {
  font-size: 14px;
}
@media screen and (max-width: 768px) {
  .cardA-item {
    font-size: 13px;
  }
}
.cardA-txt {
  font-size: 14px;
}
.cardB {
  display: flex;
  gap: 20px 3%;
  margin: 20px 0;
}
@media screen and (max-width: 768px) {
  .cardB {
    flex-direction: column;
    flex-wrap: wrap;
  }
}
.cardB-item {
  width: calc((100% - 9%) / 4);
}
@media screen and (max-width: 768px) {
  .cardB-item {
    width: 100%;
  }
}
.cardB-link {
  display: block;
  padding: 19px 20px 25px;
  border-radius: 10px;
  background-color: var(--color-sky);
  transition: transform .3s;
}
.cardB-link:hover {
  transform: scale(1.03);
}
.cardB-ttl {
  font-size: 14px;
  line-height: 1.79;
}
@media screen and (max-width: 768px) {
  .cardB-ttl {
    font-size: 12px;
  }
}
.cardB-img {
  margin-top: 15px;
  text-align: center;
}
.cardB-txt {
  margin-top: 9px;
  font-size: 14px;
  font-weight: 700;
  color: var(--color-blue);
  text-align: center;
}
@media screen and (max-width: 768px) {
  .cardB-txt {
    font-size: 12px;
  }
}
.cardB-txt span {
  position: relative;
  padding-right: 18px;
}
.cardB-txt span::after {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  content: ">";
}
.cardC {
  display: flex;
  flex-wrap: wrap;
  gap: 20px 3%;
  margin: 20px 0;
}
@media screen and (max-width: 768px) {
  .cardC {
    flex-direction: column;
    gap: 18px 0;
  }
}
.cardC-item {
  width: calc((100% - 3%) / 2);
}
@media screen and (max-width: 768px) {
  .cardC-item {
    width: 100%;
  }
}
.cardC-link {
  display: block;
  padding: 30px 30px 40px;
  border-radius: 10px;
  background-color: var(--color-sky);
  transition: transform .3s;
}
@media screen and (max-width: 768px) {
  .cardC-link {
    padding: 20px 20px 25px;
  }
}
.cardC-link:hover {
  transform: scale(1.03);
}
.cardC-top {
  display: flex;
  gap: 0 7%;
}
.cardC-bottom {
  margin-top: 20px;
  border-top: 1px solid var(--color-gray);
}
.cardC-imgArea {
  width: min(40%, 130px);
}
@media screen and (max-width: 768px) {
  .cardC-imgArea {
    width: clamp(92px, 35%, 130px);
  }
}
.cardC-txtArea {
  width: calc(100% - 7% - min(40%,130px));
}
@media screen and (max-width: 768px) {
  .cardC-txtArea {
    width: calc(100% - 7% - clamp(92px, 35%, 130px));
  }
}
.cardC-ttl {
  font-size: 16px;
  font-weight: 700;
  color: var(--color-blue);
}
@media screen and (max-width: 768px) {
  .cardC-ttl {
    font-size: 13px;
  }
}
.cardC-txt {
  margin-top: 15px;
  font-size: 12px;
  color: var(--color-gray2);
}
@media screen and (max-width: 768px) {
  .cardC-txt {
    margin-top: 7px;
    font-size: 11px;
  }
}
.cardC-top .keyword {
  margin: 20px 0 0;
}
@media screen and (max-width: 768px) {
  .cardC-top .keyword {
    margin-top: 15px;
  }
}
.cardC-top .keyword-list {
  gap: 8px 0;
}
@media screen and (max-width: 768px) {
  .cardC-top .keyword-list {
    flex-direction: column;
  }
}
.cardC-top .keyword-item {
  width: 100%;
}
.cardC-bottom .keyword {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 15px;
  margin: 15px 0 0;
}
.cardD {
  margin: 20px 0;
}
.cardD-link {
  display: flex;
  gap: 0 4%;
  padding: 20px;
  border-radius: 10px;
  background-color: var(--color-sky);
  transition: transform .3s;
}
@media screen and (max-width: 768px) {
  .cardD-link {
    padding: 10px;
  }
}
.cardD-link:hover {
  transform: scale(1.03);
}
.cardD-imgArea {
  width: min(18%, 144px);
}
@media screen and (max-width: 768px) {
  .cardD-imgArea {
    width: 96px;
  }
}
.cardD-txtArea {
  width: calc(100% - 4% - min(18%, 144px));
}
@media screen and (max-width: 768px) {
  .cardD-txtArea {
    width: calc(100% - 4% - 96px);
  }
}
.cardD-ttl {
  font-size: 14px;
}
.cardD-txt {
  font-size: 16px;
  font-weight: 700;
}
.cardD-more {
  margin-top: 10px;
  padding-right: 20px;
  font-size: 14px;
  font-weight: 700;
  color: var(--color-blue);
}
.cardD-more::after {
  display: inline-block;
  content: ">"
}
.contact {
  display: flex;
  gap: 0 2%;
  margin: 90px 0 20px;
}
@media screen and (max-width: 768px) {
  .contact {
    flex-direction: column;
    gap: 20px 0;
    margin: 40px 0 20px;
  }
}
.contact-item {
  width: calc((100% - 4%) / 3);
}
@media screen and (max-width: 768px) {
  .contact-item {
    width: 100%;
  }
}
.contact-link {
  position: relative;
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: center;
  padding: 44px 0 45px;
  background-color: var(--color-sky);
  transition: transform .3s;
}
@media screen and (max-width: 768px) {
  .contact-link {
    padding: 26px 0 27px;
  }
}
.contact-link:hover {
  transform: scale(1.03);
}
.contact-link::after {
  position: absolute;
  right: 4px;
  bottom: 4px;
  display: block;
  border-top: 5px solid transparent;
  border-right: 5px solid var(--color-blue);
  border-bottom: 5px solid var(--color-blue);
  border-left: 5px solid transparent;
  content: "";
}
.contact-ttl {
  font-size: 18px;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .contact-ttl {
    font-size: 16px;
  }
}
.contact-en {
  margin-top: 5px;
  font-size: 12px;
  font-weight: 500;
  color: var(--color-blue);
}
@media screen and (max-width: 768px) {
  .contact-en {
    margin-top: 7px;
  }
}
.caseDetail {
  display: flex;
  gap: 0 9%;
  margin: 100px 0 20px;
  padding: 40px 50px;
  background-color: var(--color-sky);
}
@media screen and (max-width: 768px) {
  .caseDetail {
    margin-top: 80px;
    padding: 30px 20px;
  }
}
.caseDetail-txtArea {
  width: calc(100% - 9% - min(23%, 185px));
}
@media screen and (max-width: 768px) {
  .caseDetail-txtArea {
    width: 100%;
  }
}
.caseDetail-imgArea {
  width: min(23%, 185px);
  /*width: 185px;*/
}
@media screen and (max-width: 768px) {
  .caseDetail-imgArea {
    display: none;
  }
}
.caseDetail-ttl {
  font-size: 20px;
  font-weight: 700;
  color: var(--color-blue);
}
@media screen and (max-width: 768px) {
  .caseDetail-ttl {
    font-size: 16px;
  }
}
.caseDetail-profile {
  display: flex;
  flex-wrap: wrap;
  gap: 20px 6%;
  width: 100%;
  margin-top: 40px;
}
@media screen and (max-width: 768px) {
  .caseDetail-profile {
    flex-direction: column;
    gap: 20px 0;
    margin-top: 25px;
  }
}
.caseDetail-profileTerm {
  flex-shrink: 0;
  width: 110px;
  font-size: 16px;
  color: var(--color-blue);
}
@media screen and (max-width: 768px) {
  .caseDetail-profileTerm {
    width: 100%;
    font-size: 14px;
  }
}
.caseDetail-profileDesc {
  align-self: center;
  width: calc(100% - 6% - 110px);
  padding-left: 12px;
  font-size: 13px;
}
@media screen and (max-width: 768px) {
  .caseDetail-profileDesc {
    width: 100%;
    padding-left: 0;
    font-size: 12px;
  }
}
@media screen and (max-width: 768px) {
  .caseDetail-link {
    text-decoration: underline;
  }
}
.caseDetail + .note {
  margin-top: 7px;
}


/*****   utility   *****/
.br-sp {
  display: none;
}
@media screen and (max-width: 768px) {
  .br-sp {
    display: block;
  }
}
.br-pc {
  display: block;
}
@media screen and (max-width: 768px) {
  .br-pc {
    display: none;
  }
}

.mt-0{
  margin-top:0px!important;
}
.mb-0{
  margin-bottom:0px!important;
}
.mr-0{
  margin-right:0px!important;
}
.ml-0{
  margin-left:0px!important;
}
.mt-5{
  margin-top:5px!important;
}
.mb-5{
  margin-bottom:5px!important;
}
.mt-10{
  margin-top:10px!important;
}
.mb-10{
  margin-bottom:10px!important;
}
.mr-10{
  margin-right:10px!important;
}
.ml-10{
  margin-left:10px!important;
}
.mt-20{
  margin-top:20px!important;
}
.mb-20{
  margin-bottom:20px!important;
}
.mr-20{
  margin-right:20px!important;
}
.ml-20{
  margin-left:20px!important;
}
.mt-30{
  margin-top:30px!important;
}
.mb-30{
  margin-bottom:30px!important;
}
.mr-30{
  margin-right:30px!important;
}
.ml-30{
  margin-left:30px!important;
}
.mt-40{
  margin-top:40px!important;
}
.mb-40{
  margin-bottom:40px!important;
}
.mr-40{
  margin-right:40px!important;
}
.ml-40{
  margin-left:40px!important;
}
.mt-50{
  margin-top:50px!important;
}
.mb-50{
  margin-bottom:50px!important;
}
.mr-50{
  margin-right:50px!important;
}
.ml-50{
  margin-left:50px!important;
}
.mt-60{
  margin-top:60px!important;
}
.mb-60{
  margin-bottom:60px!important;
}
.mr-60{
  margin-right:60px!important;
}
.ml-60{
  margin-left:60px!important;
}
.mt-70{
  margin-top:70px!important;
}
.mb-70{
  margin-bottom:70px!important;
}
.mr-70{
  margin-right:70px!important;
}
.ml-70{
  margin-left:70px!important;
}
.mt-80{
  margin-top:80px!important;
}
.mb-80{
  margin-bottom:80px!important;
}
.mr-80{
  margin-right:80px!important;
}
.ml-80{
  margin-left:80px!important;
}
.mt-90{
  margin-top:90px!important;
}
.mb-90{
  margin-bottom:90px!important;
}
.mr-90{
  margin-right:90px!important;
}
.ml-90{
  margin-left:90px!important;
}
.mt-100{
  margin-top:100px!important;
}
.mb-100{
  margin-bottom:100px!important;
}
.mr-100{
  margin-right:100px!important;
}
.ml-100{
  margin-left:100px!important;
}

.pt-30 {
  padding-top:30px!important;
}

@media screen and (max-width: 768px) {
  .mt-sp-0{
    margin-top:0px!important;
  }
  .mb-sp-0{
    margin-bottom:0px!important;
  }
  .mr-sp-0{
    margin-right:0px!important;
  }
  .ml-sp-0{
    margin-left:0px!important;
  }
  .mt-sp-10{
    margin-top:10px!important;
  }
  .mb-sp-10{
    margin-bottom:10px!important;
  }
  .mr-sp-10{
    margin-right:10px!important;
  }
  .ml-sp-10{
    margin-left:10px!important;
  }
  .mt-sp-20{
    margin-top:20px!important;
  }
  .mb-sp-20{
    margin-bottom:20px!important;
  }
  .mr-sp-20{
    margin-right:20px!important;
  }
  .ml-sp-20{
    margin-left:20px!important;
  }
  .mt-sp-30{
    margin-top:30px!important;
  }
  .mb-sp-30{
    margin-bottom:30px!important;
  }
  .mr-sp-30{
    margin-right:30px!important;
  }
  .ml-sp-30{
    margin-left:30px!important;
  }
  .mt-sp-40{
    margin-top:40px!important;
  }
  .mb-sp-40{
    margin-bottom:40px!important;
  }
  .mr-sp-40{
    margin-right:40px!important;
  }
  .ml-sp-40{
    margin-left:40px!important;
  }
  .mt-sp-50{
    margin-top:50px!important;
  }
  .mb-sp-50{
    margin-bottom:50px!important;
  }
  .mr-sp-50{
    margin-right:50px!important;
  }
  .ml-sp-50{
    margin-left:50px!important;
  }
  .mt-sp-60{
    margin-top:60px!important;
  }
  .mb-sp-60{
    margin-bottom:60px!important;
  }
  .mr-sp-60{
    margin-right:60px!important;
  }
  .ml-sp-60{
    margin-left:60px!important;
  }
  .mt-sp-70{
    margin-top:70px!important;
  }
  .mb-sp-70{
    margin-bottom:70px!important;
  }
  .mr-sp-70{
    margin-right:70px!important;
  }
  .ml-sp-70{
    margin-left:70px!important;
  }
  .mt-sp-80{
    margin-top:80px!important;
  }
  .mb-sp-80{
    margin-bottom:80px!important;
  }
  .mr-sp-80{
    margin-right:80px!important;
  }
  .ml-sp-80{
    margin-left:80px!important;
  }
  .mt-sp-90{
    margin-top:90px!important;
  }
  .mb-sp-90{
    margin-bottom:90px!important;
  }
  .mr-sp-90{
    margin-right:90px!important;
  }
  .ml-sp-90{
    margin-left:90px!important;
  }
  .mt-sp-100{
    margin-top:100px!important;
  }
  .mb-sp-100{
    margin-bottom:100px!important;
  }
  .mr-sp-100{
    margin-right:100px!important;
  }
  .ml-sp-100{
    margin-left:100px!important;
  }

  .pt-sp-30 {
    padding-top:30px!important;
  }
}

/*--戻るボタン--*/
.backto {
  position: fixed;
  top: 135px;
  left: 50%;
  z-index: -1;
  transform: translate(-50%, -50%);
  width: 1000px;
}

.backto-btn {
  width: 50px;
  height: 50px;
  background: #0d63c0;
  position: relative;
  left: -60px;
}

.backto-btn:hover {
  cursor: pointer;
}

.backto-btn:before {
  content: "";
  position: absolute;
  top: 0;
  left: 20px;
  bottom: 0;
  margin: auto;
  width: 12px;
  height: 12px;
  border-top: 3px solid #fff;
  border-left: 3px solid #fff;
  -webkit-transform: rotate(315deg);
  transform: rotate(315deg);
}

@media screen and (max-width: 1151px) {
.backto {
  position: fixed;
  top: 100px;
  left: 50px;
  z-index: 0;
  width: 50px;
}

.backto-btn {
  left: 0;
}

.contents {
  padding-top: 36px;
}
}

@media screen and (max-width: 767px) {
.backto {
  top: 90px;
  left: 20px;
  width: 30px;
  height: 30px;
  line-height: 1;
}

.backto-btn {
  /*left: 3px;*/
  width: 30px;
  height: 30px;
}

.backto-btn:before {
  left: 12px;
}
}

/*--3col imag-- contact-->chg */
.contact.col3 {
  margin: 0;
}

.contact.col3 .imgBox._center {
  margin: 0;
  display: flex;
}

.contact.col3 .contact-item {
  display: flex;
  justify-content: center;
  align-items: center;
}

.hidden-sm {
  display: flex!important
}

.hidden-lg {
  display: none!important
}

@media screen and (max-width: 767px) {
.hidden-sm {
  display: none!important
}

.hidden-lg {
  display: flex!important
}
}

#sk-wrap .m-box-video {
  display: block;
  position: relative;
  width: 100%;
  margin-top: 20px;
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-video {
    max-width: 760px;
    margin-left: auto;
    margin-right: auto;
  }
}

#sk-wrap .m-box-video:before {
  content: '';
  display: block;
  padding-top: 56.5%;
}

#sk-wrap .m-box-video > video,
#sk-wrap .m-box-video > iframe {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width: 100%;
  height: auto;
  min-height: 100%;
}

#sk-wrap .m-box-movielist {
  margin-top: 20px;
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-movielist {
    margin-top: 40px;
  }
}

#sk-wrap .m-box-movielist .movielist-main {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: 45px;
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-movielist .movielist-main {
    margin-bottom: 60px;
  }
}

#sk-wrap .m-box-movielist .movielist-main .main-btn {
  border: none;
  position: relative;
  padding: 0;
  margin: 0;
  overflow: hidden;
  cursor: pointer;
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-movielist .movielist-main .main-btn {
    width: 600px;
  }
}

#sk-wrap .m-box-movielist .movielist-main .main-btn::after {
  content: '';
  display: block;
  width: 74px;
  height: 74px;
  background: url(/business/solution/idea-showroom/common/img/i_play.svg) center no-repeat;
  background-size: 100% auto;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  -webkit-filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.16));
          filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.16));
}

#sk-wrap .m-box-movielist .movielist-main .main-btn img {
  -webkit-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
}

#sk-wrap .m-box-movielist .movielist-main .main-btn:hover img {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}

#sk-wrap .m-box-movielist .movielist-main .main-txt {
  font-size: 14px;
  text-align: left;
  margin-top: 7px;
  color: #333;
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-movielist .movielist-main .main-txt {
    width: 600px;
  }
}

#sk-wrap .m-box-movielist .movielist-img img {
  height: auto;
}

#sk-wrap .m-box-movielist .movielist-inner {
  margin-top: 45px;
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-movielist .movielist-inner {
    margin-top: 35px;
  }
}

#sk-wrap .m-box-movielist .movielist-inner .movielist-list {
  margin: 0 -10px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
}

@media print {
  #sk-wrap .m-box-movielist .movielist-inner .movielist-list {
    display: block;
  }
}

#sk-wrap .m-box-movielist .movielist-inner .movielist-list .list-item {
  width: calc(100% / 2);
  width: calc((100% / 2) - 0.1px) \0;
  padding: 0 10px;
}

@media print {
  #sk-wrap .m-box-movielist .movielist-inner .movielist-list .list-item {
    width: 50%;
    display: inline-block;
    padding: 0 10px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    vertical-align: top;
  }
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-movielist .movielist-inner .movielist-list .list-item {
    width: calc(100% / 3);
    width: calc((100% / 3) - 0.1px) \0;
    padding: 0 10px;
  }
}

@media print {
  #sk-wrap .m-box-movielist .movielist-inner .movielist-list .list-item {
    width: 33.33333%;
    display: inline-block;
    padding: 0 10px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    vertical-align: top;
  }
}

#sk-wrap .m-box-movielist .movielist-inner .movielist-list .list-item:nth-child(n + 3) {
  margin-top: 20px;
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-movielist .movielist-inner .movielist-list .list-item:nth-child(n + 3) {
    margin-top: 0;
  }
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-movielist .movielist-inner .movielist-list .list-item:nth-child(n + 4) {
    margin-top: 25px;
  }
}

#sk-wrap .m-box-movielist .movielist-inner .movielist-list .list-item .item-inner {
  border: none;
  background: transparent;
  position: relative;
  display: block;
  padding: 0;
  cursor: pointer;
  width: 100%;
}

#sk-wrap .m-box-movielist .movielist-inner .movielist-list .list-item .item-inner::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  margin: auto;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 60px 60px 0 0;
  border-color: #007bff transparent transparent transparent;
  z-index: 1;
}

#sk-wrap .m-box-movielist .movielist-inner .movielist-list .list-item .item-inner .item-num {
  color: #fff;
  position: absolute;
  top: 9px;
  left: 10px;
  z-index: 1;
  font-size: 16px;
  line-height: 1;
  font-family: "Lucida Sans Unicode", "メイリオ", "Meiryo", sans-serif;
}

#sk-wrap .m-box-movielist .movielist-inner .movielist-list .list-item .item-inner .item-img {
  display: block;
  position: relative;
  overflow: hidden;
}

#sk-wrap .m-box-movielist .movielist-inner .movielist-list .list-item .item-inner .item-img img {
  -webkit-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
}

#sk-wrap .m-box-movielist .movielist-inner .movielist-list .list-item .item-inner .item-img::after {
  content: '';
  display: block;
  width: 40px;
  height: 40px;
  background: url(/business/solution/idea-showroom/common/img/i_play.svg) center no-repeat;
  background-size: 100% auto;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  -webkit-filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.16));
          filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.16));
}

#sk-wrap .m-box-movielist .movielist-inner .movielist-list .list-item .item-inner .item-txt {
  font-size: 14px;
  text-align: left;
  margin-top: 7px;
  color: #333;
  display: block;
}

#sk-wrap .m-box-movielist .movielist-inner .movielist-list .list-item .item-inner:hover .item-img img {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-movielist .movielist-inner .movielist-list.list-col1 {
    width: 600px;
    margin: 0 auto;
  }
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-movielist .movielist-inner .movielist-list.list-col1 .list-item {
    width: 100%;
    padding: 0;
  }
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-movielist .movielist-inner .movielist-list.list-col1 .list-item .item-inner .item-img img {
    width: 600px;
  }
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-movielist .movielist-inner .movielist-list.list-col1 .list-item .item-inner .item-img::after {
    width: 74px;
    height: 74px;
  }
}

#sk-wrap .m-box-movielist .movielist-modal {
  display: none;
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-movielist.movielist-main-size-full .movielist-main .main-btn {
    width: 100%;
  }
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-movielist.movielist-main-size-full .movielist-main .main-txt {
    width: 100%;
  }
}

#sk-wrap .m-box-modal_movie {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 110vw;
  right: 0;
  z-index: 2000;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  visibility: hidden;
  opacity: 0;
  -webkit-transition: opacity 0.2s ease-out;
  transition: opacity 0.2s ease-out;
  pointer-events: none;
  outline: none;
  -webkit-overflow-scrolling: auto;
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-modal_movie {
    padding: 0px 0 0;
  }
}

#sk-wrap .m-box-modal_movie .modal_movie-title {
  position: absolute !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  width: 1px !important;
  height: 1px !important;
  margin: -1px !important;
  padding: 0 !important;
  border: 0 !important;
}

#sk-wrap .m-box-modal_movie.is-active {
  opacity: 1;
  visibility: visible;
  left: 0;
  pointer-events: auto;
}

#sk-wrap .m-box-modal_movie .modal_movie-overlay {
  background-color: #000;
  opacity: 0.5;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
}

#sk-wrap .m-box-modal_movie .modal_movie-inner {
  position: relative;
  z-index: 1;
  min-width: 200px;
  min-height: 200px;
  padding-top: 40px;
  padding-bottom: 40px;
  pointer-events: none;
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-modal_movie .modal_movie-inner {
    padding-top: 40px;
    padding-left: 40px;
    padding-right: 40px;
    padding-bottom: 40px;
  }
}

#sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content {
  display: none;
  width: calc(100vw - 30px);
  background-color: #fff;
  padding: 0;
  overflow-y: auto;
  overflow-x: hidden;
  max-height: calc(100vh - 80px);
  max-height: calc(var(--vh, 1vh) * 100 - 80px);
  pointer-events: auto;
}

#sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content > *:first-child {
  margin-top: 0 !important;
}

#sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content > *:first-child.m-box-section {
  padding-top: 0;
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content > .m-list-image.position-left:first-child + *,
  #sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content > .m-list-image.position-right:first-child + * {
    margin-top: 0 !important;
  }
}

@media screen and (max-width: 599px) {
  #sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content > [data-gs]:first-child [data-gs-col]:first-child > *:first-child {
    margin-top: 0 !important;
  }
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content > [data-gs]:first-child > [data-gs-col='12']:nth-child(-n + 1) > *:first-child {
    margin-top: 0 !important;
  }
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content > [data-gs]:first-child > [data-gs-col='12']:nth-child(-n + 1) > [data-gs]:first-child > [data-gs-col='12']:nth-child(-n + 1) > *:first-child {
    margin-top: 0 !important;
  }
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content > [data-gs]:first-child > [data-gs-col='12']:nth-child(-n + 1) > [data-gs]:first-child > [data-gs-col='6']:nth-child(-n + 2) > *:first-child {
    margin-top: 0 !important;
  }
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content > [data-gs]:first-child > [data-gs-col='6']:nth-child(-n + 2) > *:first-child {
    margin-top: 0 !important;
  }
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content > [data-gs]:first-child > [data-gs-col='6']:nth-child(-n + 2) > [data-gs]:first-child > [data-gs-col='12']:nth-child(-n + 1) > *:first-child {
    margin-top: 0 !important;
  }
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content > [data-gs]:first-child > [data-gs-col='6']:nth-child(-n + 2) > [data-gs]:first-child > [data-gs-col='6']:nth-child(-n + 2) > *:first-child {
    margin-top: 0 !important;
  }
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content > [data-gs]:first-child > [data-gs-col='4']:nth-child(-n + 3) > *:first-child {
    margin-top: 0 !important;
  }
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content > [data-gs]:first-child > [data-gs-col='4']:nth-child(-n + 3) > [data-gs]:first-child > [data-gs-col='12']:nth-child(-n + 1) > *:first-child {
    margin-top: 0 !important;
  }
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content > [data-gs]:first-child > [data-gs-col='4']:nth-child(-n + 3) > [data-gs]:first-child > [data-gs-col='6']:nth-child(-n + 2) > *:first-child {
    margin-top: 0 !important;
  }
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content > [data-gs]:first-child > [data-gs-col='3']:nth-child(-n + 4) > *:first-child {
    margin-top: 0 !important;
  }
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content > [data-gs]:first-child > [data-gs-col='3']:nth-child(-n + 4) > [data-gs]:first-child > [data-gs-col='12']:nth-child(-n + 1) > *:first-child {
    margin-top: 0 !important;
  }
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content > [data-gs]:first-child > [data-gs-col='3']:nth-child(-n + 4) > [data-gs]:first-child > [data-gs-col='6']:nth-child(-n + 2) > *:first-child {
    margin-top: 0 !important;
  }
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content > [data-gs-group]:first-child > [data-gs-col] > *:first-child {
    margin-top: 0 !important;
  }
}

@media screen and (max-width: 599px) {
  #sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content > [data-gs-group='ratio-1_1_1_1']:first-child > [data-gs-col]:nth-child(-n + 2) > *:first-child {
    margin-top: 0 !important;
  }
}

@media screen and (max-width: 599px) {
  #sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content > [data-gs-group='ratio-1_1_2']:first-child > [data-gs-col]:nth-child(-n + 2) > *:first-child {
    margin-top: 0 !important;
  }
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content {
    max-width: 1200px;
    padding: 0;
    width: calc(100vw - 80px);
  }
}

#sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content .content-video {
  max-width: 100%;
  display: block;
}

#sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content .content-youtube {
  padding-top: 56.25%;
  width: 100%;
  max-width: 100%;
  height: 0;
  position: relative;
}

#sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-content .content-youtube iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

#sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-close {
  position: absolute;
  top: 0;
  right: 0;
  background-color: transparent;
  border: none;
  -webkit-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
  width: 40px;
  height: 40px;
  pointer-events: auto;
  cursor: pointer;
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-close {
    width: 40px;
    height: 40px;
  }
}

#sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-close::before {
  content: '';
  position: absolute;
  right: 10px;
  bottom: 10px;
  margin: auto;
  background: url(../img/i_close.svg) center no-repeat;
  background-size: 100% auto;
  width: 20px;
  height: 20px;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}

@media print, screen and (min-width: 600px) {
  #sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-close::before {
    right: auto;
    left: 10px;
  }
}

#sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-close .btn-wrap {
  position: absolute !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  width: 1px !important;
  height: 1px !important;
  margin: -1px !important;
  padding: 0 !important;
  border: 0 !important;
}

#sk-wrap .m-box-modal_movie .modal_movie-inner .modal_movie-close:hover {
  text-decoration: none;
}

#sk-wrap .m-box-modal_movie.is-vertical .modal_movie-inner .modal_movie-content {
  max-width: calc((var(--vh, 1vh) * 100 - 80px) / 0.5625);
}

.m-box-movielist .movielist-main .btn-accordion::after {
  width: 45px !important;
  height: 45px !important;
}

.m-box-movielist .movielist-main .main-btn::after {
  content: '';
  display: block;
  width: 74px;
  height: 74px;
  background: url(/business/solution/idea-showroom/common/img/i_play.svg) center no-repeat;
  background-size: 100% auto;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  -webkit-filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.16));
          filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.16));
}

.m-box-movielist .movielist-main .main-btn img {
  -webkit-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
}

.m-box-movielist .movielist-main .main-btn:hover img {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}

.m-box-movielist .movielist-main .main-btn {
  border: none;
  position: relative;
  padding: 0;
  margin: 0;
  overflow: hidden;
  cursor: pointer;
}

@media screen and (max-height: 900px) {
  .modaal-video-container {
    max-height: fit-content !important;
  }
}

@media screen and (max-width: 376px) {
  .btnB_sp{
    font-size: 14px;
    padding: 17px 0px;
  }
}

._center {
  text-align: center;
}

small{
  font-size: 16px;
}

@media screen and (max-width: 599px) {
  small{
    font-size: 12px;
  }
}

@media screen and (max-width: 768px) {
  .mb-sm-0{
    margin-bottom: 0px !important;
  }

  .mt-sm-5{
    margin-top: 5px !important;
  }

  .mt-sm-20{
    margin-top: 20px !important;
  }
}

@media screen and (min-width: 769px) {
  .mb-lg-0{
    margin-bottom: 0px !important;
  }

  .mt-lg-5{
    margin-top: 5px !important;
  }

  .mt-lg-20{
    margin-top: 20px !important;
  }
}