@charset "utf-8";

/**********************************************************************/
/* ヒーロー
/**********************************************************************/

section.hero{
  /* background-image: url("../img/home/hero/bg_1.webp"); */
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  position: relative;
  color: var(--c_white);
  padding-inline: 4vw;
}
section.hero::before{
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: rgb(6 6 8 / 50%);
  position: absolute;
  left: 0;
  top: 0;
  z-index: 2;
}
section.hero::after{
  content: "";
  display: block;
  width: 42vw;
  height: 150vh;
  min-height: 1200px;
  background-image: url("../img/home/origami.svg");
  background-repeat: no-repeat;
  background-position: left top;
  background-size: 100% 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 3;
}
section.hero .inner{
  position: relative;
  z-index: 5;
}
section.hero .wrapper{
  padding-top: 138px;
  min-height: 100vh;
  max-height: 1200px;
  position: relative;
  z-index: 2;
}
@media screen and (max-width:768px){
  section.hero{
    padding-inline: 6vw;
  }
  section.hero .wrapper{
    min-height: auto;
    max-height: none;
    max-width: 500px;
    margin: 0 auto;
  }
  section.hero::after{
    width: 400%;
    height: 60%;
    min-height: 0;
    opacity: 1;
    /* mix-blend-mode: hard-light; */
  }
}

/*--------------------------------------------------------------------*/
/*bg*/

section.hero .bg{
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-image: url("../img/home/hero/bg_7.webp");
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-color: var(--c_primary);
}
@media screen and (max-width: 768px){
  section.hero .bg{
    height: 60%;
    top: auto;
    bottom: 0;
  }
}

/*--------------------------------------------------------------------*/
/*centering*/

section.hero .centering{
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto;
  align-items: center;
  grid-template-areas: 
  "mockups leading"
  "mockups action";
  padding-block: 4em;
}
.mockups{
  grid-area: mockups;
}
section.hero .centering .leading{
  grid-area: leading;
}
section.hero .centering .action{
  grid-area: action;
}
@media screen and (max-width: 1680px){
  section.hero .centering{
    gap: 3em 0;
  }
}
@media screen and (max-width: 1200px){
  section.hero .centering{
    grid-template-columns: auto auto;
    grid-template-rows: auto auto;
    grid-template-areas: 
    "mockups leading"
    "action action";
    gap: 3em 0;
  }
}
@media screen and (max-width: 768px){
  section.hero .centering{
    grid-template-columns: auto;
    grid-template-rows: auto auto auto;
    grid-template-areas: 
    "leading"
    "mockups"
    "action";
    gap: 2em 0;
    padding-block: 1em 4em;
  }
}

/*--------------------------------------------------------------------*/
/*mockups*/

.mockups .pc,
.mockups .sp{
  display: inline-block;
}
.mockups .pc img,
.mockups .sp img{
  width: 100%;
}
.mockups .pc{
  border-radius: 2em;
  width: 32.6vw;
  box-shadow: 0 0 4em rgba(21,28,38,.18);
  max-width: 620px;
}
.mockups .sp{
  border-radius: 1.25em;
  width: 8.4vw;
  box-shadow: 0 0 4em rgba(21,28,38,.18);
  max-width: 160px;
}
section.hero .centering .mockups .sp{
  margin-left: -7%;
}
@media screen and (max-width: 768px){
  .mockups .devices{
    position: relative;
    margin-bottom: 1em;
  }
  .mockups .pc{
    width: 100%;
    max-width: 100%;
  }
  .mockups .sp{
    position: absolute;
    right: -2vw;
    bottom: 0;
    width: 25%;
    max-width: 100%;
  }
}

/*--------------------------------------------------------------------*/
/*medals*/

section.hero .centering .medals{
  gap: 1em;
  margin-top: 1em;
  padding-left: 4vw;
}
section.hero .centering .medals .item{
  position: relative;
  width: 10em;
  height: 10em;
  max-width: 9vw;
  max-height: 9vw;
  background-color: var(--c_white);
  aspect-ratio: 1/1;
  border-radius: 50%;
  overflow: hidden;

  background-repeat: no-repeat;
  background-position: center top 30%;
  background-size: 36%;
}
section.hero .centering .medals .item .label{
  width: 100%;
  position: absolute;
  bottom: 0;
}
section.hero .centering .medals .item .title{
  color: var(--c_black);
  font-size: clamp(10px, 1vw, 16px);
  padding: .75em;
}
section.hero .centering .medals .item .num{
  width: 100%;
  background-color: var(--c_primary);
  font-style: italic;
}
@media screen and (max-width: 768px){
  section.hero .centering .medals .item{
    max-width: 26vw;
    max-height: 26vw;

    background-position: center top 20%;
  }
}

/*--------------------------------------------------------------------*/
/* medal icon */

section.hero .centering .medals .item.i1{
  background-image: url("../img/icon/feature_icon_1.svg");
}
section.hero .centering .medals .item.i2{
  background-image: url("../img/icon/feature_icon_2.svg");
}
section.hero .centering .medals .item.i3{
  background-image: url("../img/icon/feature_icon_3.svg");
}

/*--------------------------------------------------------------------*/
/*leading*/

section.hero .centering .leading{

}
section.hero .centering .leading h1{

}
section.hero .centering .leading .line{
  display: block;
  line-height: 1.2;
}
section.hero .centering .leading .line.pre{
  font-size: clamp(15px, 1.62vw, 31px);
}
section.hero .centering .leading .line.suf{
  font-size: clamp(15px, 1.88vw, 36px);
}
section.hero .centering .leading .line.pre .label{
  border: 1px solid var(--c_white);
  display: inline-block;
  padding-inline: .4em;
  padding-block: .1em .25em;
}
section.hero .centering .leading .line.main{
  margin-top: .1em;
  font-size: clamp(30px, 4.45vw, 85px);
}
section.hero .centering .leading .description{
  max-width: 33vw;
  margin-top: 1em;
  font-size: clamp(14px, .83vw, 16px);
}
@media screen and (max-width: 768px){
  section.hero .centering .leading .line.pre{
    display: inline-flex;
    align-items: center;
    gap: .5em;
    flex-wrap: wrap;
    font-size: clamp(15px, 4.1vw, 31px);
  }
  section.hero .centering .leading .line.suf{
    font-size: clamp(15px, 4.2vw, 36px);
  }
  section.hero .centering .leading .line.main{
    font-size: clamp(30px, 11.5vw, 66px);
    white-space: nowrap;
    margin-top: .4em;
    font-weight: 900;
    font-style: italic;
  }
  section.hero .centering .leading .description{
    max-width: none;
    margin-top: 1em;
    font-size: clamp(14px, 3.5vw, 15px);
  }
}

/*--------------------------------------------------------------------*/
/* action */

@media screen and (max-width: 768px){
  section.hero .action{
    margin-top: 2em;
  }
  section.hero .action .box .contact{

  }
  section.hero .action .box .contact a{
    padding-block: 1.25em;
  }
  section.hero .action .box .contact a .icon{
    font-size: 120%;
  }
}

/**********************************************************************/
/* ミッション
/**********************************************************************/

main{
  overflow: hidden;
}
section.mission{
  position: relative;
  z-index: 10;
}
section.mission .mockups{
  transform: translate(50%, -10%);
  position: absolute;
  right: 0;
  top: 0;
}
section.mission .mockups .sp{
  position: absolute;
  left: 5%;
  bottom: -25%;
}
section.mission .wrapper{
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 1299px){
  section.mission .mockups{
    display: none;
  }
}
@media screen and (max-width: 768px){
  
}

/*--------------------------------------------------------------------*/
/*heading*/

section.mission .heading{
  margin-bottom: 3em;
}
section.mission .heading .overview{
  margin-top: 2em;
}
@media screen and (max-width: 768px){
  section.mission .heading{
    margin-bottom: 0;
  }
}
@media screen and (max-width: 520px){
  section.mission{
    padding-inline: 6vw;
  }
  section.mission .heading .overview{
    margin-top: 1em;
    text-align: left;
  }
}

/*--------------------------------------------------------------------*/
/*bodying*/

section.mission .bodying{
  padding-top: 3em;
}

/*--------------------------------------------------------------------*/
/*bodying item*/

section.mission .bodying .block{
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 2em;
  --padding-inline: 2em;
  --border-radius: 1em;
}
section.mission .bodying .block .item{
  border-radius: var(--border-radius);
  background-color: var(--c_white);
}
section.mission .bodying .block .item .upper{
  padding: 0 var(--padding-inline) 1em var(--padding-inline);
}
section.mission .bodying .block .item .upper .icon{
  width: 3.5em;
  height: 3.5em;
  background-image: url("../img/icon/feature_icon_2.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  margin: 0 auto;
  transform: translate(0, -40%);
}
section.mission .bodying .block .item .upper .index{
  border-bottom: 1px solid var(--c_border);
  padding-bottom: 1.5em;
}
section.mission .bodying .block .item .upper .index .pre{
  margin-bottom: .25em;
}
section.mission .bodying .block .item .lower{
  padding: 1em var(--padding-inline) 4em var(--padding-inline);
}
section.mission .bodying .block .item .lower dl + dl{
  margin-top: 1.5em;
}
section.mission .bodying .block .item .lower dt{
  color: var(--c_primary);
}
section.mission .bodying .block .item .link{
  color: var(--c_white);
  padding: 1em;
  background-color: var(--c_primary);
  border-radius: 0 0 var(--border-radius) var(--border-radius);
  margin-top: auto;
}
section.mission .bodying .block .item .link a{
  display: block;
}
section.mission .bodying .block .item .link a .icon_arrow::before{
  width: .5em;
  height: .5em;
  transform: translate(0, 15%) rotate(45deg);
}
@media screen and (max-width: 768px){
  section.mission .bodying .block{
    grid-template-columns: 1fr;
    gap: 3em;
  }
  section.mission .bodying .block .item .upper .index .main{
    font-size: clamp(20px, 6vw, 28px);
  }
  section.mission .bodying .block .item .lower dt{
    font-size: 120%;
  }
}

/*--------------------------------------------------------------------*/
/* icon */

section.mission .bodying .block .item.i1 .upper .icon{
  background-image: url("../img/icon/feature_icon_2.svg");
}
section.mission .bodying .block .item.i2 .upper .icon{
  background-image: url("../img/icon/feature_icon_3.svg");
}
section.mission .bodying .block .item.i3 .upper .icon{
  background-image: url("../img/icon/feature_icon_4.svg");
}

/*--------------------------------------------------------------------*/
/*bodying link*/

section.mission .bodying .navigation{
  margin-top: 4em;
}

/**********************************************************************/
/* 強み
/**********************************************************************/

section.strength .heading{
  margin-bottom: 4em;
}
section.strength .bodying .block{
  gap: 6em;
}
@media screen and (max-width: 768px){
  section.strength .heading{
    margin-bottom: 3em;
  }
  section.strength .bodying{
    padding-inline: 2vw;
  }
  section.strength .bodying .block{
    gap: 3em;
  } 
}

/*--------------------------------------------------------------------*/
/*bodying - item*/

section.strength .bodying .item{
  gap: 5em;
}
section.strength .bodying .item:nth-of-type(even){
  flex-direction: row-reverse;
}
section.strength .bodying .item .info{
  max-width: 30em;
}
section.strength .bodying .item .info .numbering{
  font-style: italic;
  margin-bottom: 1em;
}
section.strength .bodying .item .info .title{
  margin-bottom: .5em;
}
section.strength .bodying .item .info .text p + p{
  margin-top: 1.5em;
}
@media screen and (max-width: 768px){
  section.strength .bodying .item,
  section.strength .bodying .item:nth-of-type(even){
    gap: 2em;
    flex-direction: column-reverse;
    max-width: 500px;
    margin: auto;
  }
  section.strength .bodying .item .info{
    max-width: 100%;
  }
}

/*--------------------------------------------------------------------*/
/*item benefits*/

section.strength .bodying .item .info .benefits{
  margin-top: 2em;
}
section.strength .bodying .item .info .benefits dt{
  background-color: var(--c_primary);
  color: var(--c_white);
  display: inline-block;
  padding: 0 .5em .2em .5em;
}
section.strength .bodying .item .info .benefits dd .table{
  border: 1px solid var(--c_border);
  padding: 1em 1.5em;
  display: flex;
  gap: .5em 2em;
  flex-wrap: wrap;
}
section.strength .bodying .item .info .benefits dd .table .cell{
  display: inline-block;
}

/**********************************************************************/
/* サマリー
/**********************************************************************/

section.summary{

}
section.summary .heading{
  margin-bottom: 5em;
}
section.summary .annotation{
  color: #9b9b9b;
}
@media screen and (max-width: 768px){
  section.summary .heading{
    margin-bottom: 2em;
  }
  section.summary .heading .overview{
    text-align: left;
  }
  section.summary .heading .overview br{
    display: none;
  }
  section.summary .bodying .table{
    overflow: auto;
    margin-bottom: 0;
  }
  section.summary .bodying .table img{
    min-width: 1000px;
  }
  section.summary .annotation{
    margin-top: 1em;
  }
}

/**********************************************************************/
/* 料金
/**********************************************************************/

section.price{

}
section.price .bodying .wrapper .panel{
  background-color: var(--c_white);
  border-radius: 1em;
  padding: 2em 2em;
  display: inline-block;
  max-width: 48%;
  flex: 1;
}
section.price .bodying .wrapper .panel .upper{
  gap: 2em;
  padding: 2em 1em;
  display: flex;
  justify-content: center;
}
section.price .bodying .wrapper .panel .upper .medal{
  min-width: 5em;
  min-height: 5em;
  background-color: var(--c_yellow);
  border-radius: 50%;
}
section.price .bodying .wrapper .panel.running .upper .medal{
  background-color: var(--c_primary);
  color: var(--c_white);
}
section.price .bodying .wrapper .panel.running .lower .link a{
  display: inline-block;
  background-color: #EFEFEF;
  padding: .75em 2em;
  border-radius: 5em;
}
@media screen and (max-width: 520px){
  section.price .bodying .wrapper{
    flex-direction: column;
  }
  section.price .bodying .wrapper .panel{
    max-width: 100%;
  }
  section.price .bodying .wrapper .panel .upper{
    gap: 1em;
    padding-inline: 0;
    padding-top: 1em;
  }
  section.price .bodying .wrapper .panel .upper .label .title{
    font-size: 4.8vw;
  }
  section.price .bodying .wrapper .panel .upper .label .value{
    font-size: 5.3vw;
  }
  section.price .bodying .wrapper .panel .lower{
    font-size: clamp(12px, 3.3vw, 15px);
  }
}

/*--------------------------------------------------------------------*/
/*plus*/

section.price .bodying .wrapper{
  padding: 1em 0;
}
section.price .bodying .wrapper .plus{
  width: 3em;
  height: 3em;
  display: flex;
  align-self: center;
}
section.price .bodying .wrapper .plus::before,
section.price .bodying .wrapper .plus::after{
  width: 1.25em;
  height: 3px;
  background-color: var(--c_primary);
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
section.price .bodying .wrapper .plus::after{
  transform: translate(-50%, -50%) rotate(90deg);
}
@media screen and (max-width: 520px){
  section.price .bodying .wrapper .plus{
    height: 1em;
  }
}

/*--------------------------------------------------------------------*/
/* initial */

section.price .bodying .wrapper .panel.initial{
  display: inline-flex;
}
section.price .bodying .wrapper .panel.initial .title{
  margin-right: 1em;
}
section.price .bodying .wrapper .panel.initial sup{
  vertical-align: super;
}
@media screen and (max-width: 520px){
  section.price .bodying .wrapper .panel.initial .label{
    flex-direction: column;
  }
}

/*--------------------------------------------------------------------*/
/*annotation*/

section.price .bodying .annotation{
  padding: 2em;
}
section.price .bodying .annotation p{
  max-width: 50em;
  margin: auto;
}
@media screen and (max-width: 520px){
  section.price .bodying .annotation{
    padding: .5em 0 1.5em 0;
    margin-bottom: 1em;
    text-align: left;
  }
}

/**********************************************************************/
/* よくあるご質問
/**********************************************************************/

section.faq .heading{
  margin-bottom: 3em;
}
section.faq .bodying .list .q{
  line-height: 1.5;
}
section.faq .bodying .link{
  margin-top: 3em;
}
@media screen and (max-width: 768px){
  section.faq .heading{
    margin-bottom: 1em;
  }
  section.faq .bodying .link{
    margin-top: 2em;
  }
}

/**********************************************************************/
/* 導入事例
/**********************************************************************/

section.cases .heading{
  
}

/*--------------------------------------------------------------------*/
/*bodying*/

section.cases .bodying{
 --gap: 1em; 
}
section.cases .bodying .list{
  /* display: grid;
  grid-template-columns: 1fr 1fr 1fr; */
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: stretch;
  gap: 1em;
}
section.cases .bodying .list .item{
  position: relative;
  width: calc((100% - (var(--gap) * 2)) / 3);
}
section.cases .bodying .list .item::after{
  content: "";
  display: block;
  width: 100%;
  height: 3em;
  position: absolute;
  bottom: 0;
  left: 0;
  transform: scale(.86);
  box-shadow: 0 1em 2em rgba(0,0,0,.1);
}
section.cases .bodying .list .item > *{
  display: block;
  background-color: var(--c_white);
  border-radius: 1em;
  overflow: hidden;
  position: relative;
  z-index: 2;
  height: 100%;
}
@media screen and (max-width: 520px){
  section.cases .bodying .list{
    display: grid;
    grid-template-columns: 1fr;
    gap: 1em;
  }
  section.cases .bodying .list .item{
    width: auto;
  }
}

/*--------------------------------------------------------------------*/
/*thumbnail*/

section.cases .bodying .list .item .thumbnail{
  width: 100%;
  height: 200px;
  background-color: var(--c_bg_download);
}
@media screen and (max-width: 768px){
  section.cases .bodying .list .item .thumbnail{
    height: 160px;
  }
}

/*--------------------------------------------------------------------*/
/*info*/

section.cases .bodying .list .item .info{
  padding: 2em 2em 1em 2em;
}
section.cases .bodying .list .item .info .title{
  margin-bottom: .75em;
}
section.cases .bodying .list .item .info .cats{
  padding: 2em 0 1em 0;
}
section.cases .bodying .list .item .info .cats .terms{
  display: inline-block;
  padding: 0 .5em;
  background-color: #F2F5F9;
  color: var(--c_primary);
  margin-right: .25em;
  margin-bottom: .5em;
}
@media screen and (max-width: 768px){
  section.cases .bodying .list .item .info{
    padding: 2em 2em 1em 2em;
  }
}

/*--------------------------------------------------------------------*/
/*navigation*/

section.cases .bodying .navigation{
  margin-top: 3em;
}

/**********************************************************************/
/* お知らせ
/**********************************************************************/

section.news .bodying{
  max-width: 48em;
  margin-left: auto;
}