@import"https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Outfit:wght@100..900&family=Saira:ital,wght@0,100..900;1,100..900&display=swap";
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  vertical-align: baseline;
  background: rgba(0, 0, 0, 0)
}
body {
  line-height: 1;
  margin: 0;
  font-feature-settings: "palt"
}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block
}
nav ul {
  list-style: none
}
blockquote, q {
  quotes: none
}
blockquote:before, blockquote:after, q:before, q:after {
  content: "";
  content: none
}
a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: rgba(0, 0, 0, 0)
}
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none
}
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold
}
del {
  text-decoration: line-through
}
abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help
}
table {
  border-collapse: collapse;
  border-spacing: 0
}
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
  padding: 0
}
input, select {
  vertical-align: middle
}
li {
  list-style: none
}
*, *:before, *:after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box
}
body {
  color: #141428;
  font-family: "Noto Sans JP", sans-serif;
  letter-spacing: .05em;
  text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%
}
a {
  color: #1e1e6e;
  cursor: pointer;
  outline: none;
  text-decoration: none;
  transition: .1s;
  word-wrap: break-word
}
@media screen and (min-width: 768px) {
  a[href^="tel:"] {
    color: inherit;
    pointer-events: none
  }
  a[href^="tel:"]:hover {
    opacity: 1
  }
}
a img {
  transition: .1s
}
@media(any-hover: hover) {
  a:hover {
    opacity: .7;
    text-decoration: none
  }
}
img {
  max-width: 100%;
  vertical-align: bottom;
  height: auto
}
figcaption {
  font-size: 14px;
  margin-top: 10px;
  text-align: center
}
address {
  font-style: normal;
  text-decoration: none
}
input, button, textarea, select {
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  vertical-align: middle
}
button {
  background-color: rgba(0, 0, 0, 0);
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0
}
input, textarea {
  background-color: rgba(0, 0, 0, 0);
  border: none;
  outline: none;
  padding: 0
}
select {
  cursor: pointer
}
select::-ms-expand {
  display: none
}
input[type=reset], input[type=submit], input[type=button] {
  appearance: button;
  border: none;
  border-radius: 0;
  cursor: pointer;
  transition: .2s
}
input[type=reset]:hover, input[type=submit]:hover, input[type=button]:hover {
  opacity: .7
}
input[type=reset]:focus, input[type=submit]:focus, input[type=button]:focus {
  outline-offset: -2px
}
input[type=reset]::-webkit-search-decoration, input[type=submit]::-webkit-search-decoration, input[type=button]::-webkit-search-decoration {
  display: none
}
sub {
  font-size: .75em;
  vertical-align: baseline
}
sup {
  font-size: .75em;
  vertical-align: text-top
}
#pageTitle {
  padding: 9.5rem 2rem
}
@media screen and (max-width: 960px) {
  #pageTitle {
    padding: 5rem 0
  }
}
.intoro__text {
  margin-bottom: 7rem;
  position: relative
}
.intoro__text:before {
  position: absolute;
  content: "";
  width: 10rem;
  height: 1px;
  background: #3632ce;
  left: 50%;
  bottom: -3.5rem;
  transform: translateX(-50%)
}
.intoro__number {
  color: #3632ce;
  font-family: "Outfit", sans-serif;
  font-size: 1.6rem;
  width: 10rem;
  margin: 0 auto;
  text-align: center;
  line-height: 26px;
  background: #fff;
  display: block;
  border-radius: 100rem
}
.intoro__name {
  text-align: center
}
.intoro__name dt {
  font-size: 1.7rem;
  font-weight: 400;
  margin: 2rem auto
}
.intoro__name dd {
  font-size: 2.7rem;
  font-weight: 400;
  font-weight: 500;
  line-height: 4rem
}
.intoro .commonTitle {
  line-height: 6rem
}
.intoro__img {
  display: block;
  margin: 2rem auto 0
}
.summary__request {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 6rem
}
.summary__request--assignment {
  max-width: 70rem;
  margin-right: 2rem
}
.summary__request--assignment--item {
  margin-bottom: 2rem;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 28px;
  padding-left: 2.3rem;
  background: url(../img/common/check.png) no-repeat top 7px left/16px
}
.summary__request--assignment--item:last-child {
  margin-bottom: 0
}
.summary__request--assignment .anotherList .subtitle {
  color: #1e1e6e;
  font-size: 1.6rem;
  font-weight: 400
}
.summary__request--assignment .anotherList .summary__request--assignment--item {
  margin-bottom: 0
}
.summary__request--company {
  max-width: 36rem;
  width: 100%;
  box-shadow: 0px 10px 10px 0px rgba(20, 20, 120, .1);
  background: #fff;
  border-radius: 2rem;
  padding: 3rem;
  font-size: 1.6rem;
  font-weight: 400
}
.summary__request--company p {
  background: #1e1e6e;
  text-align: center;
  position: relative;
  border-radius: 100rem;
  color: #fff;
  margin-bottom: 2rem
}
.summary__request--company p:before {
  position: absolute;
  content: "";
  width: 7rem;
  height: 7rem;
  background: url(../img/common/company.png) no-repeat center/contain;
  top: 50%;
  right: -2rem;
  transform: translateY(-50%)
}
.summary__request--company table {
  width: 100%
}
.summary__request--company table tr {
  position: relative
}
.summary__request--company table tr:before {
  position: absolute;
  content: "";
  width: 100%;
  height: 1px;
  background: url(../img/common/dotline.png) repeat-x left center/6px 1px;
  bottom: 0;
  left: 0
}
.summary__request--company table tr th, .summary__request--company table tr td {
  padding: 1rem 0;
  line-height: 28px
}
.summary__request--company table tr th {
  font-weight: 400;
  padding-right: 1rem;
  width: 26%
}
.summary__request--company table tr td {
  width: 74%;
  color: #4f4f5e
}
.summary__solution img {
  display: block;
  margin: 0 auto
}
.summary__solution--text {
  text-align: center;
  background: #fff;
  border-radius: 2rem;
  border: 2px solid #1e1e6e;
  position: relative;
  box-shadow: 5px 5px 0px 0px #1e1e6e;
  padding: 2rem;
  font-size: 2.4rem;
  font-weight: 400;
  font-weight: 500;
  line-height: 36px;
  color: #1e1e6e;
  margin: 2rem auto 5rem;
  margin-top: 10rem
}
.summary__solution--text:before, .summary__solution--text:after {
  position: absolute;
  content: ""
}
.summary__solution--text:before {
  width: 37px;
  height: 33px;
  background: url(../img/common/balloonarrow.png) no-repeat center top/contain;
  bottom: -32px;
  left: 15%
}
.summary__solution--text:after {
  width: 300px;
  height: 60px;
  background: url(../img/common/summary-arrow.png) no-repeat center/contain;
  top: -8rem;
  left: 50%;
  transform: translateX(-50%)
}
.summary__solution--detail {
  position: relative
}
.summary__solution--subtext .popup, .summary__solution--subtext .close {
  position: absolute
}
.summary__solution--subtext .popup {
  width: 3.6rem;
  height: 3.6rem;
  cursor: pointer
}
.summary__solution--subtext .popup:before, .summary__solution--subtext .popup:after {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  border: inherit;
  top: 0;
  left: 0;
  z-index: 1;
  background: #ff7d00;
  border-radius: inherit;
  animation: wave 2s linear infinite;
  border-radius: 100rem
}
.summary__solution--subtext .popup:after {
  animation: wave 2s linear infinite 1s
}
@keyframes wave {
  0% {
    opacity: 1;
    transform: scale(1)
  }
  20% {
    opacity: .8
  }
  70% {
    opacity: .2;
    transform: scale(1.3)
  }
  80% {
    opacity: 0;
    transform: scale(1.3)
  }
  90% {
    opacity: 0;
    transform: scale(1)
  }
}
.summary__solution--subtext .popup p {
  font-family: "Outfit", sans-serif;
  font-size: 1.6rem;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 3.6rem;
  height: 3.6rem;
  border-radius: 100rem;
  border: 2px solid #ff7d00;
  background: #fff;
  z-index: 2;
  position: relative;
  color: #ff7d00
}
.summary__solution--subtext .popup img {
  position: absolute;
  bottom: -3px;
  right: -6px;
  z-index: 2
}
.summary__solution--subtext .close {
  border-radius: 2rem;
  padding: 2rem;
  border: 2px solid #1e1e6e;
  max-width: 26rem;
  background: #fff;
  font-weight: 500;
  line-height: 21px;
  color: #1e1e6e;
  display: none;
  z-index: 3
}
.summary__solution--subtext .close:before {
  position: absolute;
  content: "";
  width: 22px;
  height: 21px;
  background: url(../img/common/popuparrow.png) no-repeat center/contain;
  left: -21px;
  top: 50%
}
.summary__solution--subtext .close.inversionarrow:before {
  left: auto;
  right: -21px;
  transform: rotate(180deg)
}
.summary__solution--subtext .close dt {
  background: #e7ebfd;
  border-radius: 1rem;
  padding: 1rem 1.5rem;
  margin-bottom: 1rem
}
.summary__solution--subtext .close.another dt {
  background: #fff;
  border-radius: 0;
  padding: 0
}
.summary__solution--subtext .close.another dd {
  background: #e7ebfd;
  border-radius: 1rem;
  padding: 1rem;
  color: #1e1e6e
}
.summary__solution--subtext .close.another dd span {
  background: #1e1e6e;
  color: #fff;
  margin-bottom: .5rem;
  display: block;
  padding: .1rem 1rem;
  border-radius: 6px
}
.summary__effect {
  border-radius: 2rem;
  background: #ffecd9;
  padding: 3rem;
  margin: 5rem auto 12rem
}
.summary__effect--subtitle {
  font-size: 1.8rem;
  font-weight: 400;
  font-weight: 500;
  line-height: 40px;
  text-align: center;
  color: #fff;
  background: #ff7d00;
  border-radius: 6px;
  margin-bottom: 3rem;
  display: block;
  padding: 0 2rem
}
.summary__effect--item {
  position: relative;
  font-size: 2.4rem;
  font-weight: 400;
  font-weight: 500;
  line-height: 36px;
  padding: 0 0 2rem 3rem;
  margin-bottom: 2rem;
  background: url(../img/common/check.png) no-repeat top 7px left/20px
}
.summary__effect--item span {
  color: #eb6400
}
.summary__effect--item:before {
  position: absolute;
  content: "";
  width: 100%;
  height: 1px;
  background: url(../img/common/dotline.png) repeat-x left center/6px 1px;
  bottom: 0;
  left: 0
}
.summary__effect--item:last-child {
  margin-bottom: 0;
  padding-bottom: 0
}
.summary__effect--item:last-child:before {
  display: none
}
.summary__dropdown {
  display: none
}
#detail01 .summary__solution--subtext.item01 .popup {
  top: 19%;
  right: 21%
}
#detail01 .summary__solution--subtext.item01 .close {
  top: 1%;
  right: 26.5%
}
#detail01 .summary__solution--subtext.item02 .popup {
  bottom: 35%;
  right: 21%
}
#detail01 .summary__solution--subtext.item02 .close {
  bottom: 18.5%;
  right: 26.5%
}
#detail02 .summary__solution--subtext.item01 .popup {
  top: 12%;
  right: 39%
}
#detail02 .summary__solution--subtext.item01 .close {
  top: -4%;
  right: 13%
}
#detail02 .summary__solution--subtext.item02 .popup {
  bottom: 29%;
  left: 41%
}
#detail02 .summary__solution--subtext.item02 .close {
  bottom: 15%;
  right: 30%
}
#detail02 .summary__solution--subtext.item03 .popup {
  bottom: 3%;
  left: 42%
}
#detail02 .summary__solution--subtext.item03 .close {
  bottom: -9%;
  right: 29%
}
#detail04 .intoro__img {
  display: block;
  margin: 2rem auto 0
}
#detail04 .summary__solution--subtext.item01 .popup {
  bottom: 11%;
  right: 26%
}
#detail04 .summary__solution--subtext.item01 .close {
  bottom: -4%;
  right: 32%
}
#detail04 .summary__solution--subtext.item02 .popup {
  top: 1%;
  right: 1%
}
#detail04 .summary__solution--subtext.item02 .close {
  top: -17%;
  right: 7%
}
#detail05 .summary__solution--subtext.item01 .popup {
  bottom: 23%;
  left: 26%
}
#detail05 .summary__solution--subtext.item01 .close {
  bottom: 12%;
  left: 32%
}
#detail05 .summary__solution--subtext.item02 .popup {
  top: 44%;
  left: 61%
}
#detail05 .summary__solution--subtext.item02 .close {
  top: 29%;
  left: 67%
}
#detail05 .summary__solution--subtext.item03 .popup {
  bottom: 12%;
  right: 26%
}
#detail05 .summary__solution--subtext.item03 .close {
  bottom: 4%;
  right: 32%
}
#detail05 .summary__solution--subtext.item04 .popup {
  top: 5%;
  right: 1%
}
#detail05 .summary__solution--subtext.item04 .close {
  top: -10%;
  right: 6.5%
}
#detail06 .intoro .commonTitle {
  letter-spacing: -0.1rem
}
#detail06 .summary__solution--subtext.item01 .popup {
  top: 27%;
  right: 43%
}
#detail06 .summary__solution--subtext.item01 .close {
  top: 12%;
  right: 17%
}
#detail06 .summary__solution--subtext.item02 .popup {
  bottom: 24%;
  left: 43%
}
#detail06 .summary__solution--subtext.item02 .close {
  bottom: 13%;
  left: 17%
}
#detail06 .summary__solution--subtext.item03 .popup {
  bottom: 34%;
  right: 34.5%
}
#detail06 .summary__solution--subtext.item03 .close {
  bottom: 23%;
  right: 8%
}
.notpage {
  text-align: center;
  font-size: 3rem;
  font-weight: 400;
  font-weight: 500;
  color: #1e1e6e
}
.notpage p {
  line-height: 45px
}
@media screen and (max-width: 1140px) {
  .summary .spScroll__item {
    max-width: none;
    width: 100%
  }
  .summary__request--company {
    padding: 2rem
  }
  .summary__request--company table tr:before {
    display: none
  }
  .summary__request--company table tr th, .summary__request--company table tr td {
    display: block;
    width: 100% !important
  }
  .summary__request--company table tr th {
    font-weight: 500;
    padding: 1rem 0 0;
    text-align: left
  }
  .summary__request--company table tr td {
    position: relative;
    padding-top: 0 !important
  }
  .summary__request--company table tr td:before {
    position: absolute;
    content: "";
    width: 100%;
    height: 1px;
    background: url(../img/common/dotline.png) repeat-x left center/6px 1px;
    bottom: 0;
    left: 0
  }
  .summary__request--company table tr:first-child th {
    padding-top: 0
  }
  .summary__dropdown {
    display: block;
    margin-top: 3rem
  }
  .summary__dropdown--item {
    border-radius: 1rem;
    overflow: hidden
  }
  .summary__dropdown--item:not(:last-child) {
    margin-bottom: 1rem
  }
  .summary__dropdown--title {
    cursor: pointer;
    background: #1e1e6e;
    color: #fff;
    font-weight: 500;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    padding: 1.1rem 4rem 1.1rem 2rem;
    position: relative
  }
  .summary__dropdown--title span {
    width: 36px;
    height: 36px;
    border-radius: 100rem;
    color: #eb6400;
    border: 2px solid #eb6400;
    box-sizing: border-box;
    background: #fff;
    display: flex;
    justify-content: center;
    align-items: center
  }
  .summary__dropdown--title p {
    margin-left: 1rem;
    line-height: 1.6;
    width: calc(100% - 46px)
  }
  .summary__dropdown--title:before {
    position: absolute;
    content: "";
    width: 10px;
    height: 10px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(135deg) translateY(100%);
    top: 50%;
    right: 1rem
  }
  .summary__dropdown--text {
    display: none;
    background: #fff;
    padding: 1.1rem 2rem;
    line-height: 24px
  }
  .summary__dropdown--text span {
    color: #fff;
    background: #1e1e6e;
    font-weight: 500;
    padding: .1rem 1rem;
    border-radius: 4px
  }
}
@media screen and (max-width: 1024px) {
  .summary .spScroll__item {
    width: 1000px
  }
}
@media screen and (max-width: 768px) {
  .intoro__text {
    margin-bottom: 5rem
  }
  .intoro__text:before {
    bottom: -3rem
  }
  .intoro__name dd {
    font-size: 2.4rem
  }
  .intoro .commonTitle {
    line-height: 4rem
  }
  .summary__request {
    display: block
  }
  .summary__request--assignment {
    max-width: 100%;
    margin: 0 auto 3rem
  }
  .summary__request--company {
    max-width: 100%
  }
  .summary__solution--text {
    font-size: 1.8rem;
    line-height: 26px;
    margin-top: 8rem
  }
  .summary__solution--text br {
    display: none
  }
  .summary__solution--text:before {
    left: 3rem
  }
  .summary__solution--text:after {
    width: 200px;
    height: 40px;
    top: -6rem
  }
  .summary__effect {
    margin: 5rem auto 6rem;
    padding: 2rem
  }
  .summary__effect--subtitle {
    line-height: 26px;
    margin-bottom: 2rem;
    padding: .5rem 2rem
  }
  .summary__effect--item {
    font-size: 2rem;
    line-height: 30px;
    background: url(../img/common/check.png) no-repeat top 5px left/20px
  }
  .notpage {
    font-size: 2.4rem
  }
  .notpage p {
    line-height: 38px
  }
}
@media screen and (max-width: 400px) {
  .summary__request--company table tr th, .summary__request--company table tr td {
    display: block;
    width: 100% !important
  }
  .summary__request--company table tr th {
    font-weight: 500;
    padding: 1rem 0 0;
    text-align: left
  }
  .summary__request--company table tr:first-child th {
    padding-top: 0
  }
}