@charset "UTF-8";
.intro__txt, .intro__ttl {
  font-family: "Zen Kaku Gothic New", "Noto Sans JP", sans-serif;
}

.lp-nttdocomobusiness {
  overflow-y: hidden;
}
.lp-nttdocomobusiness main {
  color: #231815;
  font-family: "Noto Sans JP", "NotoSans", "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", "HiraKakuProN-W3", "Hiragino Kaku Gothic ProN", Helvetica, "Helvetica Neue", sans-serif;
}
.lp-nttdocomobusiness main img {
  max-width: 100%;
  height: auto;
}
.lp-nttdocomobusiness.wrap {
  padding: 0;
}
@media (max-width: 750px) {
  .lp-nttdocomobusiness .only-pc {
    display: none !important;
  }
}
@media (min-width: 751px) {
  .lp-nttdocomobusiness .only-sp {
    display: none !important;
  }
  .lp-nttdocomobusiness .hover {
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }
  .lp-nttdocomobusiness .hover:hover {
    opacity: 0.8;
  }
}
.lp-nttdocomobusiness .sec-inner {
  width: 100%;
  margin: 0 auto;
}
@media (max-width: 750px) {
  .lp-nttdocomobusiness .sec-inner {
    max-width: 100%;
    padding: 0 6.4vw;
  }
}
.lp-nttdocomobusiness .txt-red {
  color: #c81d33;
}
.lp-nttdocomobusiness .sr-only {
  position: absolute !important;
  width: min(1px, 0.0694444444vw) !important;
  height: min(1px, 0.0694444444vw) !important;
  padding: 0 !important;
  margin: max(-1px, -0.0694444444vw) !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}
.lp-nttdocomobusiness.page-iot-sign picture {
  display: block;
}
@media (min-width: 751px) {
  .lp-nttdocomobusiness .cta-group {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: min(17px, 1.1805555556vw);
  }
}
@media (max-width: 750px) {
  .lp-nttdocomobusiness .cta-group {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-flow: column;
            flex-flow: column;
    gap: 2.1333333333vw;
  }
}
.lp-nttdocomobusiness .cta-group.group-01 {
  margin-block: min(50px, 3.4722222222vw) 0;
}
@media (max-width: 750px) {
  .lp-nttdocomobusiness .cta-group.group-01 {
    margin-block: 18.1333333333vw 0;
  }
}
.lp-nttdocomobusiness .cta-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-flow: column;
          flex-flow: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
  width: min(350px, 24.3055555556vw);
  height: min(86px, 5.9722222222vw);
  color: #fff;
  background: #c81d33 url(/content/dam/nttcom/hq/jp/business/lp/nttdocomobusiness/img/btn_arrow.png) right min(15px, 1.0416666667vw) center no-repeat;
  background-size: min(20px, 1.3888888889vw) auto;
  font-weight: 500;
  line-height: 1;
  cursor: pointer;
}
@media (max-width: 750px) {
  .lp-nttdocomobusiness .cta-link {
    width: 170.1333333333vw;
    height: 31.7333333333vw;
    background-position: right 7.4666666667vw center;
    background-size: 9.6vw auto;
  }
}
@media (min-width: 751px) {
  .lp-nttdocomobusiness .cta-link {
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }
  .lp-nttdocomobusiness .cta-link:hover {
    opacity: 0.8;
  }
}
.lp-nttdocomobusiness .cta-link span {
  font-size: min(21px, 1.4583333333vw);
  line-height: 1;
  letter-spacing: 0.04em;
}
@media (max-width: 750px) {
  .lp-nttdocomobusiness .cta-link span {
    font-size: 8.5333333333vw;
  }
}
.lp-nttdocomobusiness .cta-link .txt-sm {
  position: relative;
  display: inline-block;
  padding-inline: min(15px, 1.0416666667vw);
  margin-block: max(-2px, -0.1388888889vw) min(11px, 0.7638888889vw);
  font-size: min(16px, 1.1111111111vw);
  line-height: min(16px, 1.1111111111vw);
  letter-spacing: 0.08em;
}
@media (max-width: 750px) {
  .lp-nttdocomobusiness .cta-link .txt-sm {
    padding-inline: 7.4666666667vw;
    margin-block: -0.5333333333vw 2.9333333333vw;
    font-size: 6.6666666667vw;
    line-height: 6.6666666667vw;
  }
}
.lp-nttdocomobusiness .cta-link .txt-sm:before, .lp-nttdocomobusiness .cta-link .txt-sm:after {
  content: "";
  position: absolute;
  top: max(-2px, -0.1388888889vw);
  width: min(30px, 2.0833333333vw);
  height: 100%;
  background: url(/content/dam/nttcom/hq/jp/business/lp/nttdocomobusiness/img/btn_line.png) no-repeat;
  background-size: auto min(16px, 1.1111111111vw);
}
@media (max-width: 750px) {
  .lp-nttdocomobusiness .cta-link .txt-sm:before, .lp-nttdocomobusiness .cta-link .txt-sm:after {
    top: -0.5333333333vw;
    width: 8vw;
    background-size: auto 6.6666666667vw;
  }
}
.lp-nttdocomobusiness .cta-link .txt-sm:before {
  left: 0;
  background-position: top left;
}
.lp-nttdocomobusiness .cta-link .txt-sm:after {
  right: 0;
  background-position: top right;
}
.lp-nttdocomobusiness .lp-fixedbnr {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: fixed;
  bottom: min(30px, 2.0833333333vw);
  right: 0;
  z-index: 10;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}
@media (max-width: 750px) {
  .lp-nttdocomobusiness .lp-fixedbnr {
    display: none !important;
  }
}
.lp-nttdocomobusiness .lp-fixedbnr__img {
  width: min(267px, 18.5416666667vw);
}
.lp-nttdocomobusiness .lp-fixedbnr__anchor {
  position: absolute;
  display: block;
  width: min(189px, 13.125vw);
  bottom: min(47px, 3.2638888889vw);
  left: 52%;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
}
@media (max-width: 750px) {
  .lp-nttdocomobusiness .lp-fixedbnr__anchor {
    width: 50.4vw;
    bottom: 12.5333333333vw;
  }
}
.lp-nttdocomobusiness .lp-fixedbnr__close {
  position: absolute;
  border: 0;
  z-index: 9;
  top: 0;
  left: 0;
  width: min(31px, 2.1527777778vw);
  height: min(31px, 2.1527777778vw);
  cursor: pointer;
  background: url(/content/dam/nttcom/hq/jp/business/lp/nttdocomobusiness/img/bnr_btn_close.png) no-repeat;
  background-size: 100% 100%;
}
.lp-nttdocomobusiness .lp-fixedbnr.is-hide {
  -webkit-transform: translateX(120%);
          transform: translateX(120%);
}
.lp-nttdocomobusiness :root {
  --animate-duration: 1s;
  --animate-delay: 1s;
  --animate-repeat: 1;
}
.lp-nttdocomobusiness .animate__fadeIn {
  opacity: 0;
  -webkit-animation-name: fadeIn;
          animation-name: fadeIn;
}
@-webkit-keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.lp-nttdocomobusiness .animate__fadeInLeft {
  -webkit-animation-name: fadeInLeft;
          animation-name: fadeInLeft;
  display: inline-block;
  overflow: hidden;
}
@-webkit-keyframes fadeInLeft {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
            transform: translate3d(-100%, 0, 0);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateZ(0);
            transform: translateZ(0);
  }
}
@keyframes fadeInLeft {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
            transform: translate3d(-100%, 0, 0);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateZ(0);
            transform: translateZ(0);
  }
}
.lp-nttdocomobusiness .animated {
  -webkit-animation-duration: var(--animate-duration, 1s);
          animation-duration: var(--animate-duration, 1s);
  -webkit-animation-fill-mode: both;
          animation-fill-mode: both;
}
.lp-nttdocomobusiness .animate__fadeInUp {
  opacity: 0;
  -webkit-animation-name: fadeInUp;
          animation-name: fadeInUp;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
@-webkit-keyframes fadeInUp {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
            transform: translate3d(0, 100%, 0);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateZ(0);
            transform: translateZ(0);
  }
}
@keyframes fadeInUp {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
            transform: translate3d(0, 100%, 0);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateZ(0);
            transform: translateZ(0);
  }
}
.lp-nttdocomobusiness footer {
  position: relative;
}
@media (max-width: 750px) {
  .lp-nttdocomobusiness main {
    overflow-x: hidden;
  }
  .lp-nttdocomobusiness .main-article {
    padding: 0;
  }
}

:root {
  --vh: 1vh;
}

.is-loading {
  overflow-y: hidden;
}
.is-loading .wrapper {
  opacity: 0;
  pointer-events: none;
}

.is-loaded {
  overflow-y: auto;
}
.is-loaded .wrapper {
  opacity: 1;
  pointer-events: auto;
  -webkit-transition: opacity 0.5s ease;
  transition: opacity 0.5s ease;
}

.page-loader {
  position: fixed;
  z-index: 9999;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background-color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-transition: opacity 0.5s ease, visibility 0.5s ease;
  transition: opacity 0.5s ease, visibility 0.5s ease;
  pointer-events: none;
}
@media (max-width: 750px) {
  .page-loader {
    height: calc(var(--vh, 1vh) * 100);
  }
}
.is-loaded .page-loader {
  opacity: 0;
  visibility: hidden;
}
.page-loader .loader {
  position: relative;
}
.page-loader .loader-img {
  width: auto;
  max-height: 100vh;
  -webkit-transition: opacity 0.2s ease;
  transition: opacity 0.2s ease;
  opacity: 0;
}
@media (max-width: 750px) {
  .page-loader .loader-img {
    width: 100vw;
    max-height: 100lvh;
    min-height: 56.2666666667vw;
  }
}
.page-loader .loader-svg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.page-loader .loader canvas,
.page-loader .loader svg {
  display: block;
  width: auto;
}
@media (max-width: 750px) {
  .page-loader .loader canvas,
  .page-loader .loader svg {
    width: 100vw !important;
    height: 56.2666666667vw !important;
    min-width: 100vw;
    min-height: 56.2666666667vw;
  }
}

@media (min-width: 751px) {
  .hover {
    cursor: pointer;
    -webkit-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease;
  }
  .hover:hover {
    opacity: 0.7;
  }
}
.lp-container {
  margin-inline: auto;
}
@media (min-width: 751px) {
  .lp-container {
    max-width: min(990px, 68.75vw);
  }
}

@-webkit-keyframes arrowMoveDown {
  0% {
    clip-path: inset(0 0 100% 0);
  }
  25% {
    clip-path: inset(0 0 60% 0);
  }
  50% {
    clip-path: inset(0 0 40% 0);
  }
  75% {
    clip-path: inset(0 0 20% 0);
  }
  100% {
    clip-path: inset(0 0 0 0);
  }
}

@keyframes arrowMoveDown {
  0% {
    clip-path: inset(0 0 100% 0);
  }
  25% {
    clip-path: inset(0 0 60% 0);
  }
  50% {
    clip-path: inset(0 0 40% 0);
  }
  75% {
    clip-path: inset(0 0 20% 0);
  }
  100% {
    clip-path: inset(0 0 0 0);
  }
}
@-webkit-keyframes arrowMoveRight {
  0% {
    clip-path: inset(0 100% 0 0);
  }
  25% {
    clip-path: inset(0 60% 0 0);
  }
  50% {
    clip-path: inset(0 40% 0 0);
  }
  75% {
    clip-path: inset(0 20% 0 0);
  }
  100% {
    clip-path: inset(0 0 0 0);
  }
}
@keyframes arrowMoveRight {
  0% {
    clip-path: inset(0 100% 0 0);
  }
  25% {
    clip-path: inset(0 60% 0 0);
  }
  50% {
    clip-path: inset(0 40% 0 0);
  }
  75% {
    clip-path: inset(0 20% 0 0);
  }
  100% {
    clip-path: inset(0 0 0 0);
  }
}
.lp-sec .lp_aside {
  opacity: 0 !important;
  visibility: hidden !important;
}
@media (min-width: 751px) {
  .lp-sec .lp_aside {
    position: sticky;
    top: min(65px, 4.5138888889vw);
    left: 0;
    width: min(30px, 2.0833333333vw);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media (max-width: 750px) {
  .lp-sec .lp_aside {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 4.2666666667vw;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-flow: row wrap;
            flex-flow: row wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
.lp-sec .lp_aside__txt {
  margin-block: min(30px, 2.0833333333vw) min(40px, 2.7777777778vw);
  text-align: center;
}
@media (max-width: 750px) {
  .lp-sec .lp_aside__txt {
    margin: 0;
  }
  .lp-sec .lp_aside__txt picture {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .lp-sec .lp_aside__txt img {
    width: auto;
    height: 1.3333333333vw;
  }
}
.lp-sec .lp_aside__arrow {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  background: url(/content/dam/nttcom/hq/jp/business/lp/nttdocomobusiness/img/ico_arrow_red.png) repeat-y top center;
  background-size: min(30px, 2.0833333333vw) auto;
}
@media (max-width: 750px) {
  .lp-sec .lp_aside__arrow {
    -webkit-box-ordinal-group: 0;
        -ms-flex-order: -1;
            order: -1;
    max-width: 60vw;
    height: 100%;
    background: url(/content/dam/nttcom/hq/jp/business/lp/nttdocomobusiness/img/ico_arrow_red_sp.png) repeat-x left center;
    background-size: auto 100%;
  }
}

.lp_head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-flow: row wrap;
          flex-flow: row wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #000;
  margin-bottom: min(80px, 5.5555555556vw);
}
@media (max-width: 750px) {
  .lp_head {
    margin-bottom: 12.8vw;
  }
}
.lp_head__ttl {
  min-height: min(62px, 4.3055555556vw);
  line-height: min(62px, 4.3055555556vw);
  margin-right: min(48px, 3.3333333333vw);
  font-size: min(50px, 3.4722222222vw);
  font-weight: 500;
  letter-spacing: 0.08em;
  font-family: Outfit;
}
@media (max-width: 750px) {
  .lp_head__ttl {
    margin: 0 auto 1.3333333333vw;
    font-size: 7.4666666667vw;
    min-height: 10.6666666667vw;
    line-height: 10.6666666667vw;
  }
}
.lp_head__ttl .animate__slideIn {
  position: relative;
  display: inline-block;
  overflow: hidden;
  background: url(/content/dam/nttcom/hq/jp/business/lp/nttdocomobusiness/img/ttl_line.png) repeat-y top left;
  background-size: min(4px, 0.2777777778vw) auto;
}
@media (max-width: 750px) {
  .lp_head__ttl .animate__slideIn {
    background: url(/content/dam/nttcom/hq/jp/business/lp/nttdocomobusiness/img/ttl_line_sp.png) repeat-y top left;
    background-size: 1.0666666667vw auto;
  }
}
.lp_head__ttl .animate__slideIn:after {
  content: "";
  position: absolute;
  z-index: 1;
  top: 0;
  right: 0;
  width: min(4px, 0.2777777778vw);
  height: 100%;
  background: url(/content/dam/nttcom/hq/jp/business/lp/nttdocomobusiness/img/ttl_line.png) repeat-y top right;
  background-size: min(4px, 0.2777777778vw) auto;
}
@media (max-width: 750px) {
  .lp_head__ttl .animate__slideIn:after {
    width: 1.0666666667vw;
    background: url(/content/dam/nttcom/hq/jp/business/lp/nttdocomobusiness/img/ttl_line_sp.png) repeat-y top right;
    background-size: 1.0666666667vw auto;
  }
}
.lp_head__ttl .animate__slideIn span {
  padding-inline: min(50px, 3.4722222222vw);
  white-space: nowrap;
  color: #c03;
}
@media (max-width: 750px) {
  .lp_head__ttl .animate__slideIn span {
    padding-inline: 12.8vw;
  }
}
.lp_head__subttl {
  display: inline-block;
  overflow: hidden;
  font-size: min(24px, 1.6666666667vw);
  font-weight: 600;
  letter-spacing: 0.02em;
}
@media (max-width: 750px) {
  .lp_head__subttl {
    text-align: center;
    font-size: 3.7333333333vw;
    line-height: 1.7142857143;
    width: 76.2666666667vw;
    margin: 0 auto;
  }
}
.lp_head__txt {
  font-size: min(16px, 1.1111111111vw);
  font-weight: 500;
  line-height: 1.88;
}
@media (min-width: 751px) {
  .lp_head__txt {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
@media (max-width: 750px) {
  .lp_head__txt {
    margin: 0 auto;
    text-align: center;
    width: 76.2666666667vw;
    font-size: 3.7333333333vw;
    line-height: 1.7142857143;
  }
}

.kv {
  position: relative;
  text-align: center;
}
.kv__img img {
  width: 100%;
  height: auto;
}
.kv__img.hidden {
  opacity: 0 !important;
  visibility: hidden;
}
@media (max-width: 750px) {
  .kv__img {
    height: 138.1333333333vw;
    -webkit-filter: blur(10px);
            filter: blur(10px);
  }
  .is-loaded .kv__img {
    opacity: 1;
    -webkit-filter: blur(0);
            filter: blur(0);
    -webkit-transition: opacity 1s ease, -webkit-filter 1.4s ease;
    transition: opacity 1s ease, -webkit-filter 1.4s ease;
    transition: opacity 1s ease, filter 1.4s ease;
    transition: opacity 1s ease, filter 1.4s ease, -webkit-filter 1.4s ease;
    -webkit-transition-delay: 0.7s;
            transition-delay: 0.7s;
  }
}
.kv__logo {
  position: absolute;
  z-index: 0;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
}
.kv__logo .svg-wrapper {
  position: absolute;
}
@media (min-width: 751px) {
  .kv__logo .svg-wrapper {
    height: 100%;
    top: min(125px, 8.6805555556vw);
    right: min(130px, 9.0277777778vw);
    width: min(354px, 24.5833333333vw);
    margin-left: auto;
  }
}
@media (max-width: 750px) {
  .kv__logo .svg-wrapper {
    bottom: 0;
    left: 50%;
    width: 54.9333333333vw;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
.kv__logo .svg-wrapper svg {
  width: 100%;
  height: auto !important;
}

.intro {
  position: relative;
  background-color: #fff;
}
.intro .lp-container {
  padding-block: min(123px, 8.5416666667vw) min(160px, 11.1111111111vw);
}
@media (max-width: 750px) {
  .intro .lp-container {
    padding-block: 20.8vw 21.3333333333vw;
  }
}
.intro .lp-container.--style02 {
  padding-block: min(113px, 7.8472222222vw) min(160px, 11.1111111111vw);
}
.intro .line {
  opacity: 0;
  display: inline-block;
  overflow: hidden;
  will-change: opacity, transform;
}
.intro__ttl {
  width: min(796px, 55.2777777778vw);
  margin: 0 auto min(68px, 4.7222222222vw);
  color: #000;
  font-weight: 700;
  font-size: min(30px, 2.0833333333vw);
  line-height: 2.0833333333;
  letter-spacing: 0.072em;
}
.intro__ttl .line {
  line-height: 1.5;
  letter-spacing: 0.24em;
}
.intro__ttl svg {
  width: 100%;
}
@media (max-width: 750px) {
  .intro__ttl {
    margin: 0 auto 9.0666666667vw;
    width: 84vw;
    font-size: 4.2666666667vw;
    line-height: 1.375;
  }
  .intro__ttl .line {
    line-height: 1.7;
  }
}
@media (min-width: 751px) {
  .intro__ttl.--style01 {
    width: min(762px, 52.9166666667vw);
  }
  .intro__ttl.--style01 .--ttl01 {
    width: min(540px, 37.5vw);
  }
}
.intro__ttl.--style02 {
  width: 78.6666666667vw;
}
@media (min-width: 751px) {
  .intro__ttl.--style02 {
    width: min(598px, 41.5277777778vw);
    margin: 0 auto min(46px, 3.1944444444vw);
  }
}
.intro__txt {
  width: min(796px, 55.2777777778vw);
  margin: 0 auto min(64px, 4.4444444444vw);
  font-weight: 500;
  text-align: justify;
}
.intro__txt .line {
  line-height: min(34px, 2.3611111111vw);
}
.intro__txt span {
  text-align: justify;
}
.intro__txt p {
  font-size: min(23px, 1.5972222222vw);
  line-height: 2.4782608696;
  letter-spacing: 0.23em;
}
.intro__txt svg {
  width: 100%;
}
@media (max-width: 750px) {
  .intro__txt {
    width: 84vw;
    margin: 0 auto 11.2vw;
  }
  .intro__txt p {
    font-size: 3.7333333333vw;
    line-height: 2.1428571429;
    letter-spacing: 0.08em;
  }
  .intro__txt p .line {
    line-height: 1.6;
  }
}
@media (max-width: 750px) {
  .intro__txt.--style01 .line {
    letter-spacing: 0.08em;
    white-space: nowrap;
  }
  .intro__txt.--style01 .line:nth-of-type(2) {
    letter-spacing: 0.1em;
  }
  .intro__txt.--style01 .line:nth-of-type(3) {
    letter-spacing: 0.07em;
  }
  .intro__txt.--style01 .line:nth-of-type(4) {
    letter-spacing: 0.07em;
  }
  .intro__txt.--style01 .line:nth-of-type(5) {
    letter-spacing: 0.03em;
  }
  .intro__txt.--style01 .line:nth-of-type(6) {
    letter-spacing: 0.18em;
  }
  .intro__txt.--style01 .line:nth-of-type(7) {
    letter-spacing: 0.07em;
  }
  .intro__txt.--style01 .line:nth-of-type(8) {
    letter-spacing: 0.03em;
  }
}
@media (min-width: 751px) {
  .intro__txt.--style01 {
    width: min(762px, 52.9166666667vw);
    white-space: nowrap;
  }
  .intro__txt.--style01 .--txt01 {
    width: min(762px, 52.9166666667vw);
  }
  .intro__txt.--style01 .line:nth-of-type(1) {
    letter-spacing: 0.145em;
  }
  .intro__txt.--style01 .line:nth-of-type(2) {
    letter-spacing: 0.34em;
  }
  .intro__txt.--style01 .line:nth-of-type(3) {
    letter-spacing: 0.215em;
  }
  .intro__txt.--style01 .line:nth-of-type(4) {
    letter-spacing: 0.26em;
  }
  .intro__txt.--style01 .line:nth-of-type(5) {
    letter-spacing: 0.24em;
  }
  .intro__txt.--style01 .line:nth-of-type(6) {
    letter-spacing: 0.195em;
  }
}
@media (max-width: 750px) {
  .intro__txt.--style02 {
    width: 78.6666666667vw;
    margin: 0 auto 7.4666666667vw;
    white-space: nowrap;
  }
}
@media (min-width: 751px) {
  .intro__txt.--style02 {
    width: min(598px, 41.5277777778vw);
    white-space: nowrap;
  }
}
.intro__logo {
  width: min(578px, 40.1388888889vw);
  height: 100%;
  margin-inline: auto;
  padding-block: min(102px, 7.0833333333vw) min(101px, 7.0138888889vw);
}
@media (max-width: 750px) {
  .intro__logo {
    width: 48.5333333333vw;
    padding-block: 21.3333333333vw 10.6666666667vw;
  }
}
.intro__subttl {
  font-size: min(32px, 2.2222222222vw);
  line-height: 1.92;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.08em;
}
@media (min-width: 751px) {
  .intro__subttl {
    width: min(688px, 47.7777777778vw);
    margin-inline: auto;
    text-align: left;
  }
  .intro__subttl img {
    width: min(462px, 32.0833333333vw);
  }
}
@media (max-width: 750px) {
  .intro__subttl {
    font-size: 4.2666666667vw;
    line-height: 1.9285714286;
    width: 84vw;
    text-align: left;
    margin-inline: auto;
  }
  .intro__subttl img {
    width: 53.3333333333vw;
  }
}
.intro__subttl.--style02 {
  width: 78.6666666667vw;
}
@media (min-width: 751px) {
  .intro__subttl.--style02 {
    width: min(598px, 41.5277777778vw);
  }
}
.intro__btn {
  margin-top: min(61px, 4.2361111111vw);
}
@media (max-width: 750px) {
  .intro__btn {
    margin-top: 9.6vw;
  }
}

.bg-blue {
  position: relative;
  background: #fff url(/content/dam/nttcom/hq/jp/business/lp/nttdocomobusiness/img/tvcm_bg.png) repeat top left;
  background-size: min(1440px, 100vw) auto;
  background-attachment: fixed;
}
@media (max-width: 750px) {
  .bg-blue {
    background-size: 384vw auto;
  }
}

.tvcm {
  position: relative;
}
@media (min-width: 751px) {
  .tvcm {
    padding-top: min(12px, 0.8333333333vw);
  }
}
.tvcm .lp-container {
  padding-block: min(107px, 7.4305555556vw) min(135px, 9.375vw);
}
@media (max-width: 750px) {
  .tvcm .lp-container {
    padding-block: 19.4666666667vw 0;
  }
  .tvcm .lp-container .lp_head__ttl {
    width: 48.5333333333vw;
  }
  .tvcm .lp-container .lp_head__ttl .animate__slideIn {
    width: 100%;
  }
}
.tvcm__block {
  width: min(990px, 68.75vw);
  padding: min(48px, 3.3333333333vw);
  border-radius: min(5px, 0.3472222222vw);
  background-color: #fff;
}
@media (max-width: 750px) {
  .tvcm__block {
    margin: 0 auto;
    width: 92.2666666667vw;
    padding: 5.3333333333vw 9.0666666667vw;
    border-radius: 1.3333333333vw;
  }
}
.tvcm__video {
  width: min(788px, 54.7222222222vw);
  margin: 0 auto;
  display: block;
}
@media (max-width: 750px) {
  .tvcm__video {
    width: 73.6vw;
  }
}

.video_wrapper.is-playing .video_thumbnail {
  z-index: -1;
  pointer-events: none;
}
.video_wrapper.is-playing .video_iframe {
  z-index: 1;
  opacity: 1;
}
.video_thumbnail {
  position: relative;
}
.video_thumbnail:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: min(80px, 5.5555555556vw);
  height: min(80px, 5.5555555556vw);
  background: url(/content/dam/nttcom/hq/jp/business/lp/nttdocomobusiness/img/ico_play.png) no-repeat center center;
  background-size: contain;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media (max-width: 750px) {
  .video_thumbnail:after {
    width: 10.6666666667vw;
    height: 10.6666666667vw;
  }
}
.video_iframe {
  position: absolute;
  z-index: -1;
  opacity: 0;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  aspect-ratio: 16/9;
  -webkit-transition: 1s opacity ease;
  transition: 1s opacity ease;
}
.video_iframe:after {
  content: "";
  position: absolute;
  top: -0.5333333333vw;
  left: -0.5333333333vw;
  right: -0.5333333333vw;
  bottom: -0.5333333333vw;
  border: 1.0666666667vw solid #fff;
  pointer-events: none;
}
@media (min-width: 751px) {
  .video_iframe:after {
    position: absolute;
    top: max(-2px, -0.1388888889vw);
    left: max(-2px, -0.1388888889vw);
    right: max(-2px, -0.1388888889vw);
    bottom: max(-2px, -0.1388888889vw);
    border-width: min(4px, 0.2777777778vw);
  }
}
.video_iframe iframe {
  display: block;
  border: 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: none;
  display: block;
  background-color: #fff;
}

.lp_btn__link {
  width: min(990px, 68.75vw);
  height: min(70px, 4.8611111111vw);
  padding: min(20px, 1.3888888889vw) min(30px, 2.0833333333vw) min(20px, 1.3888888889vw) min(38px, 2.6388888889vw);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-radius: min(5px, 0.3472222222vw);
  font-size: min(15px, 1.0416666667vw);
  letter-spacing: 0.03em;
  font-weight: bold;
  color: #fff;
  background-color: #000;
  text-decoration: none;
}
@media (max-width: 750px) {
  .lp_btn__link:hover {
    color: #fff;
  }
}
.lp_btn__link span {
  color: inherit;
}
@media (max-width: 750px) {
  .lp_btn__link {
    margin-inline: auto;
    width: 89.3333333333vw;
    height: 13.3333333333vw;
    padding: 3.7333333333vw 4vw;
    font-size: 3.2vw;
    border-radius: 1.3333333333vw;
  }
}
.lp_btn__link.external-link .txt-left {
  padding-right: min(26px, 1.8055555556vw);
  background: url(/content/dam/nttcom/hq/jp/business/lp/nttdocomobusiness/img/ico_link.png) no-repeat center right;
  background-size: min(10px, 0.6944444444vw) auto;
}
@media (max-width: 750px) {
  .lp_btn__link.external-link .txt-left {
    padding-right: 6.9333333333vw;
    background-size: 2.6666666667vw auto;
  }
}
.lp_btn__link .txt-right {
  position: relative;
  margin-left: auto;
}
@media (min-width: 751px) {
  .lp_btn__link .txt-right {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    width: min(210px, 14.5833333333vw);
  }
}
@media (max-width: 750px) {
  .lp_btn__link .txt-right {
    font-size: 0;
    width: 6.6666666667vw;
  }
}
.lp_btn__link .ico-arrow {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  display: inline-block;
  background: url(/content/dam/nttcom/hq/jp/business/lp/nttdocomobusiness/img/btn_arrow.png) no-repeat top right;
  background-size: auto 100%;
  -webkit-transition: width 0.3s ease;
  transition: width 0.3s ease;
}
@media (min-width: 751px) {
  .lp_btn__link .ico-arrow {
    left: min(108px, 7.5vw);
    margin-left: min(20px, 1.3888888889vw);
    width: min(50px, 3.4722222222vw);
    height: min(30px, 2.0833333333vw);
  }
}
@media (max-width: 750px) {
  .lp_btn__link .ico-arrow {
    right: 0;
    width: 6.6666666667vw;
    height: 3.7333333333vw;
    background: url(/content/dam/nttcom/hq/jp/business/lp/nttdocomobusiness/img/btn_arrow_sp.png) no-repeat top right;
    background-size: auto 100%;
  }
}
@media (min-width: 751px) {
  .lp_btn__link {
    -webkit-transition: background-color 0.3s ease;
    transition: background-color 0.3s ease;
  }
  .lp_btn__link:hover {
    color: #fff;
    background-color: #c03;
  }
  .lp_btn__link:hover .ico-arrow {
    width: min(90px, 6.25vw);
  }
}

.diagram {
  position: relative;
}
.diagram .lp-container {
  padding-block: min(62px, 4.3055555556vw) min(130px, 9.0277777778vw);
}
@media (max-width: 750px) {
  .diagram .lp-container {
    padding-block: 19.4666666667vw 0;
  }
  .diagram .lp-container .lp_head__ttl {
    min-width: 49.8666666667vw;
  }
}
@media (max-width: 750px) {
  .diagram .scroll-wrapper {
    margin-inline: 4vw 0;
    overflow-x: auto;
  }
}
.diagram .lp_head__ttl span {
  font-family: "NotoSans", "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", "HiraKakuProN-W3", "Hiragino Kaku Gothic ProN", Helvetica, "Helvetica Neue", sans-serif;
}
.diagram__block {
  background-color: #fff;
}
@media (min-width: 751px) {
  .diagram__block {
    width: min(990px, 68.75vw);
    padding: 0;
    border-radius: min(5px, 0.3472222222vw);
  }
}
@media (max-width: 750px) {
  .diagram__block {
    width: 153.0666666667vw;
    padding: 5.3333333333vw 4.5333333333vw;
    border-radius: 1.3333333333vw;
  }
}
.diagram__img {
  position: relative;
  background-color: #fff;
  text-align: center;
  margin: 0 auto;
}
@media (max-width: 750px) {
  .diagram__img img {
    max-width: none !important;
    width: 100%;
  }
}
.diagram__link {
  position: absolute;
  z-index: 1;
  display: block;
  bottom: min(20px, 1.3888888889vw);
  height: min(40px, 2.7777777778vw);
  background-color: rgba(255, 255, 255, 0);
}
@media (max-width: 750px) {
  .diagram__link {
    height: 10.6666666667vw;
  }
}
@media (min-width: 751px) {
  .diagram__link:hover {
    background-color: rgba(255, 255, 255, 0.3);
  }
}
.diagram__link.link-01 {
  left: min(55px, 3.8194444444vw);
  width: min(280px, 19.4444444444vw);
}
@media (max-width: 750px) {
  .diagram__link.link-01 {
    width: 90.6666666667vw;
    left: 9.3333333333vw;
  }
}
.diagram__link.link-02 {
  width: min(184px, 12.7777777778vw);
  right: min(180px, 12.5vw);
}
@media (max-width: 750px) {
  .diagram__link.link-02 {
    width: 57.3333333333vw;
    right: 37.3333333333vw;
  }
}
.diagram__btn {
  margin-top: min(79px, 5.4861111111vw);
}
@media (max-width: 750px) {
  .diagram__btn {
    margin-top: 12.5333333333vw;
  }
}

.making .lp-container {
  padding-block: min(70px, 4.8611111111vw) min(160px, 11.1111111111vw);
}
@media (max-width: 750px) {
  .making .lp-container {
    padding-block: 19.4666666667vw 21.3333333333vw;
  }
  .making .lp-container .lp_head__ttl {
    width: 58.4vw;
  }
  .making .lp-container .lp_head__ttl .animate__slideIn {
    width: 100%;
  }
}
.making__block {
  width: min(990px, 68.75vw);
  padding: min(48px, 3.3333333333vw);
  border-radius: min(5px, 0.3472222222vw);
  background-color: #fff;
}
@media (max-width: 750px) {
  .making__block {
    margin: 0 auto;
    width: 92.2666666667vw;
    padding: 5.3333333333vw 9.0666666667vw;
    border-radius: 1.3333333333vw;
  }
}
.making__video {
  width: min(788px, 54.7222222222vw);
  margin: 0 auto;
  display: block;
}
@media (max-width: 750px) {
  .making__video {
    width: 73.6vw;
  }
}
.making__video.video-iframe {
  position: relative;
  aspect-ratio: 16/9;
}
.making__video.video-iframe iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: none;
  display: block;
}

.business {
  position: relative;
  background-color: #fff;
}
@media (min-width: 751px) {
  .business {
    padding-top: min(9px, 0.625vw);
  }
}
.business .lp-container {
  padding-block: min(118px, 8.1944444444vw) min(160px, 11.1111111111vw);
}
@media (max-width: 750px) {
  .business .lp-container {
    padding-block: 20.8vw 21.3333333333vw;
  }
}
.business__ttl {
  margin-bottom: min(54px, 3.75vw);
  font-size: min(30px, 2.0833333333vw);
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.04em;
  color: #c03;
}
@media (max-width: 750px) {
  .business__ttl {
    margin-bottom: 6.4vw;
    font-size: 4.8vw;
  }
}
.business__list {
  width: min(990px, 68.75vw);
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-flow: row wrap;
          flex-flow: row wrap;
  -ms-flex-line-pack: justify;
      align-content: space-between;
  gap: min(21px, 1.4583333333vw) min(19px, 1.3194444444vw);
}
@media (max-width: 750px) {
  .business__list {
    width: 89.3333333333vw;
    gap: 2.6666666667vw 2.6666666667vw;
  }
}
.business__item {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-flow: column;
          flex-flow: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: min(317px, 22.0138888889vw);
  min-height: min(220px, 15.2777777778vw);
  border-radius: min(5px, 0.3472222222vw);
  border: solid min(3px, 0.2083333333vw) #c03;
  background-color: #fff;
}
@media (max-width: 750px) {
  .business__item {
    width: 28vw;
    min-height: 26.6666666667vw;
    border-radius: 1.3333333333vw;
    border-width: 0.5333333333vw;
  }
}
.business__item:after {
  content: "";
  position: absolute;
  z-index: 2;
  bottom: min(13px, 0.9027777778vw);
  right: min(13px, 0.9027777778vw);
  width: min(32px, 2.2222222222vw);
  height: min(32px, 2.2222222222vw);
  background: url(/content/dam/nttcom/hq/jp/business/lp/nttdocomobusiness/img/business_arrow_red.png) no-repeat;
  background-size: contain;
}
@media (max-width: 750px) {
  .business__item:after {
    bottom: 1.0666666667vw;
    right: 1.0666666667vw;
    width: 4.2666666667vw;
    height: 4.2666666667vw;
  }
}
@media (min-width: 751px) {
  .business__item:hover:after {
    background: url(/content/dam/nttcom/hq/jp/business/lp/nttdocomobusiness/img/business_arrow_white.png) no-repeat;
    background-size: contain;
  }
  .business__item:hover .business__overlay {
    opacity: 1;
  }
  .business__item:hover .business__overlay::before {
    width: 100%;
  }
}
.business__item__img {
  width: min(111px, 7.7083333333vw);
  margin: max(-10px, -0.6944444444vw) auto 0;
}
@media (max-width: 750px) {
  .business__item__img {
    width: 10.1333333333vw;
    margin: -3.2vw auto 0;
  }
}
.business__item__ttl {
  margin: min(15px, 1.0416666667vw) 0 0;
  font-size: min(20px, 1.3888888889vw);
  font-weight: bold;
  text-align: center;
  color: #000;
}
@media (max-width: 750px) {
  .business__item__ttl {
    margin: 3.2vw 0 0;
    font-size: 3.4666666667vw;
  }
  .business__item__ttl sup {
    font-size: 3.4666666667vw;
    vertical-align: text-top;
  }
}
.business__overlay {
  position: absolute;
  padding: min(35px, 2.4305555556vw) 0 0;
  opacity: 0;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  color: #fff;
  text-align: center;
  will-change: opacity;
  -webkit-transition: opacity 0.4s ease;
  transition: opacity 0.4s ease;
}
@media (max-width: 750px) {
  .business__overlay {
    display: none;
  }
}
.business__overlay:before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: 0%;
  height: 100%;
  cursor: pointer;
  background-color: #CC0033;
  -webkit-transition: width 0.6s ease;
  transition: width 0.6s ease;
}
.business__overlay p {
  font-size: min(16px, 1.1111111111vw);
  line-height: 1.5;
  font-weight: 500;
  color: #fff;
  letter-spacing: 0.02em;
}
.business__overlay__img {
  width: min(72px, 5vw);
  margin: 0 auto min(10px, 0.6944444444vw);
}
.business__overlay__ttl {
  font-size: min(26px, 1.8055555556vw);
  letter-spacing: 0.035em;
  font-weight: bold;
  margin: 0 0 min(10px, 0.6944444444vw);
  color: #fff;
}
.business__overlay__ttl span,
.business__overlay__ttl sup {
  color: inherit;
}