/* titleSection
================================================== */
#contents.responsive .titleSection {
  background: transparent;
}
#contents.responsive .titleSection__h1 {
  box-sizing: border-box;
  width: 1240px;
  margin: 0 auto 20px;
  padding: 0 15px;
  font-size: 24px;
  line-height: 1;
  text-align: left;
}
#contents.responsive .titleSection__kv {
  background-color: #d11900;
  background-image: url("/katsuyou/nenga/smart/images/2026/ttl_bg_l.png"), url("/katsuyou/nenga/smart/images/2026/ttl_bg_r.png");
  background-repeat: no-repeat, no-repeat;
  background-position: left center, right center;
}
#contents.responsive .titleSection__appdl {
  padding: 30px 0;
  background: #fdf9e8;
  text-align: left;
}
#contents.responsive .titleSection__appdl > div {
  display: flex;
  align-items: center;
  gap: 35px;
  width: 1240px;
  margin: 0 auto;
}
#contents.responsive .titleSection__appdl__btns {
  display: flex;
  align-items: center;
  gap: 17px;
}
#contents.responsive .titleSection__appdl__notes {
  flex: 1 0 0%;
}
#contents.responsive .titleSection__appdl__notes > li {
  display: table-row;
  font-size: 14px;
  line-height: 1.5;
}
#contents.responsive .titleSection__appdl__notes > li > span {
  display: table-cell;
  vertical-align: top;
}
#contents.responsive .titleSection__appdl__notes > li > span:nth-child(1) {
  white-space: nowrap;
}
@media only screen and (max-width: 767px) {
  #contents.responsive .titleSection__h1 {
    width: auto;
    font-size: 5.86667vw;
  }
  #contents.responsive .titleSection__appdl {
    padding: 8vw 0;
  }
  #contents.responsive .titleSection__appdl > div {
    flex-direction: column;
    gap: 4.8vw;
    width: auto;
    padding: 0 4vw;
  }
  #contents.responsive .titleSection__appdl__btns {
    justify-content: center;
    gap: 4vw;
  }
  #contents.responsive .titleSection__appdl__btns img {
    width: auto;
    height: 13.6vw;
  }
  #contents.responsive .titleSection__appdl__notes > li {
    font-size: 3.2vw;
  }
}

/* summary
================================================== */
#contents.responsive .summary {
  margin-top: 40px;
}
#contents.responsive .summary__inner {
  display: table;
  margin: 0 auto;
  padding: 4px;
  border: solid 4px #d11900;
  background: #fdf9e8;
  text-align: center;
}
#contents.responsive .summary__inner p {
  padding: 20px 50px;
  border: solid 1px #d11900;
  font-size: 20px;
  line-height: 1.7;
  font-weight: bold;
}
#contents.responsive .summary__inner p strong {
  font-size: 24px;
  color: #d11900;
}
@media only screen and (max-width: 767px) {
  #contents.responsive .summary {
    margin-top: 10.66667vw;
    padding: 0 4vw;
  }
  #contents.responsive .summary__inner {
    border-width: 0.8vw;
    padding: 0.53333vw;
  }
  #contents.responsive .summary__inner p {
    padding: 4vw;
    border-width: 0.26667vw;
    font-size: 4.26667vw;
    line-height: 1.6875;
  }
  #contents.responsive .summary__inner p strong {
    font-size: 5.6vw;
  }
}

/* section
================================================== */
#contents.responsive .section {
  padding: 60px 0;
  overflow: hidden;
}
#contents.responsive .section--bg {
  background: #fdf9e8;
}
#contents.responsive .section__inner {
  width: 1240px;
  margin: 0 auto;
}
#contents.responsive .section__title {
  margin-bottom: 50px;
  padding-bottom: 3px;
  border-bottom: solid 4px #d11900;
  font-size: 34px;
  line-height: 1.3;
  text-align: center;
}
#contents.responsive .section__title > span {
  display: block;
  padding-bottom: .2em;
  border-bottom: solid 1px #d11900;
}
#contents.responsive .section__subtitle {
  margin: 1.6em 0 .5em;
  font-size: 30px;
  text-align: center;
}
#contents.responsive .section__subtitle strong {
  color: #d11900;
}
#contents.responsive .section__notes > li {
  display: table-row;
  font-size: 14px;
  line-height: 1.5;
}
#contents.responsive .section__notes > li > span {
  display: table-cell;
  vertical-align: top;
}
#contents.responsive .section__notes > li > span:nth-child(1) {
  white-space: nowrap;
}
@media only screen and (max-width: 767px) {
  #contents.responsive .section {
    padding: 10.66667vw 0;
  }
  #contents.responsive .section__inner {
    width: auto;
    padding: 0 4vw;
  }
  #contents.responsive .section__title {
    margin-bottom: 10.66667vw;
    padding-bottom: 0.53333vw;
    border-bottom-width: 0.8vw;
    font-size: 5.86667vw;
    line-height: 1.36;
  }
  #contents.responsive .section__title > span {
    padding-bottom: .3em;
    border-bottom-width: 0.26667vw;
  }
  #contents.responsive .section__subtitle {
    margin-bottom: .6em;
    font-size: 5.33333vw;
  }
  #contents.responsive .section__notes > li {
    font-size: 3.2vw;
  }
}

/* feature
================================================== */
#contents.responsive .feature__steps {
  display: flex;
  gap: 60px;
  max-width: 960px;
  margin: 0 auto;
  list-style: none;
}
#contents.responsive .feature__steps > li + li::before {
  position: absolute;
  left: -39px;
  top: 50%;
  transform: translateY(-50%);
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 21px solid transparent;
  border-bottom: 21px solid transparent;
  border-left: 18px solid #d11900;
  border-right: 0;
}
#contents.responsive .feature__steps + p {
  margin-top: 1em;
  font-size: 18px;
  text-align: center;
}
#contents.responsive .feature__step {
  position: relative;
  margin-top: 50px;
  padding: 53px 10px 30px;
  flex: 1 0 0%;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  text-align: center;
}
#contents.responsive .feature__step__num {
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 73px;
  height: 73px;
  border-radius: 50.1%;
  background: #d11900;
  color: #ffebac;
  font-weight: bold;
  line-height: 1;
}
#contents.responsive .feature__step__num > span:nth-child(1) {
  font-size: 14px;
}
#contents.responsive .feature__step__num > span:nth-child(2) {
  font-size: 28px;
}
#contents.responsive .feature__step__title {
  margin-top: 1em;
  font-size: 20px;
}
#contents.responsive .feature__design {
  display: flex;
  align-items: center;
  gap: 40px;
  max-width: 960px;
  margin: 0 auto;
}
#contents.responsive .feature__design figure {
  margin: 0;
  flex: 0 0 486px;
}
#contents.responsive .feature__design .feature__design__text {
  flex: 1 0 0%;
  font-size: 18px;
  line-height: 1.56;
}
@media only screen and (max-width: 767px) {
  #contents.responsive .feature__steps {
    gap: 4vw;
  }
  #contents.responsive .feature__steps > li + li::before {
    left: -3.33333vw;
    border-top: 2.8vw solid transparent;
    border-bottom: 2.8vw solid transparent;
    border-left: 2.4vw solid #d11900;
  }
  #contents.responsive .feature__steps + p {
    text-align: left;
    font-size: 4.26667vw;
  }
  #contents.responsive .feature__step {
    margin-top: 10.66667vw;
    padding: 10.66667vw 2.66667vw 4vw;
  }
  #contents.responsive .feature__step__num {
    width: 13.86667vw;
    height: 13.86667vw;
  }
  #contents.responsive .feature__step__num > span:nth-child(1) {
    font-size: 3.2vw;
  }
  #contents.responsive .feature__step__num > span:nth-child(2) {
    font-size: 5.33333vw;
  }
  #contents.responsive .feature__step__ill img {
    width: 100%;
    height: auto;
  }
  #contents.responsive .feature__step__title {
    font-size: 3.73333vw;
  }
  #contents.responsive .feature__design {
    flex-direction: column;
    gap: 5.33333vw;
  }
  #contents.responsive .feature__design figure {
    flex: 0 0 auto;
  }
  #contents.responsive .feature__design figure img {
    width: 100%;
    height: auto;
  }
  #contents.responsive .feature__design .feature__design__text {
    font-size: 4.26667vw;
    line-height: 1.625;
  }
}

/* support
================================================== */
#contents.responsive .support__items {
  display: flex;
  gap: 35px;
}
#contents.responsive .support__item {
  flex: 1 0 0%;
}
#contents.responsive .support__item__title {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: .5em;
  margin-bottom: 50px;
  font-size: 20px;
  font-weight: bold;
  color: #d11900;
  text-align: center;
}
#contents.responsive .support__item__title::before, #contents.responsive .support__item__title::after {
  font-size: 1.2em;
}
#contents.responsive .support__item__title::before {
  content: "|";
  transform: rotate(-30deg);
}
#contents.responsive .support__item__title::after {
  content: "|";
  transform: rotate(30deg);
}
#contents.responsive .support__panel {
  position: relative;
  padding: 70px 15px 15px 15px;
  border-radius: 20px;
  background: #fff;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}
#contents.responsive .support__panel__desc {
  position: absolute;
  left: 50%;
  top: 0;
  transform: translate(-50%, -50%);
  display: flex;
  align-items: center;
  gap: 12px;
  height: 76px;
  padding: 0 25px 0 10px;
  border-radius: 38px;
  background: #e6e6e6;
}
#contents.responsive .support__panel__desc > i {
  flex: 0 0 56px;
}
#contents.responsive .support__panel__desc > span {
  flex: 1 0 0;
  white-space: nowrap;
  font-size: 16px;
  line-height: 1.625;
  font-weight: bold;
}
#contents.responsive .support__panel__desc::after {
  position: absolute;
  left: 50%;
  top: 100%;
  transform: translateX(-50%);
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 11px solid transparent;
  border-left: 11px solid transparent;
  border-top: 14px solid #e6e6e6;
  border-bottom: 0;
}
#contents.responsive .support__panel__title {
  margin-bottom: .75em;
  font-size: 21px;
  text-align: center;
	color: #d11900;
}
#contents.responsive .support__panel__lead {
  margin-bottom: 1.5em;
  padding: 0 1em;
  font-size: 16px;
  line-height: 1.625;
}
#contents.responsive .support__panel__img {
  margin: 0;
}
#contents.responsive .support__panel__img img {
  width: 100%;
  height: auto;
}
@media only screen and (max-width: 767px) {
  #contents.responsive .support__items {
    flex-direction: column;
    gap: 10.66667vw;
  }
  #contents.responsive .support__item__title {
    margin-bottom: 13.06667vw;
    font-size: 4.8vw;
  }
  #contents.responsive .support__panel {
    padding: 17.33333vw 0 4vw;
    border-radius: 2.66667vw;
    box-shadow: 0 0 1.33333vw rgba(0, 0, 0, 0.1);
  }
  #contents.responsive .support__panel__desc {
    gap: 3.73333vw;
    height: 20vw;
    padding: 0 5.33333vw 0 3.2vw;
    border-radius: 10vw;
  }
  #contents.responsive .support__panel__desc > i {
    flex: 0 0 14.93333vw;
  }
  #contents.responsive .support__panel__desc > i img {
    width: 14.93333vw;
    height: auto;
  }
  #contents.responsive .support__panel__desc > span {
    font-size: 4.26667vw;
  }
  #contents.responsive .support__panel__desc::after {
    border-right: 3.06667vw solid transparent;
    border-left: 3.06667vw solid transparent;
    border-top: 3.73333vw solid #e6e6e6;
  }
  #contents.responsive .support__panel__title {
    font-size: 5.33333vw;
  }
  #contents.responsive .support__panel__lead {
    padding: 0 4vw;
    font-size: 4.26667vw;
  }
  #contents.responsive .support__panel__img {
    padding: 0 4vw;
  }
}

/* movie
================================================== */
#contents.responsive .movie__video {
  max-width: 640px;
  margin: 0 auto;
  aspect-ratio: 16 / 9;
}
#contents.responsive .movie__video iframe {
  width: 100%;
  height: 100%;
}

/* spec
================================================== */
#contents.responsive .spec__subtitle {
  margin: 3.125em 0 1.5625em;
  padding: .8em 1.2em .7em;
  background: #e2e2e2;
  font-size: 16px;
  line-height: 1;
}
#contents.responsive .spec__table table {
  width: 100%;
  table-layout: fixed;
}
#contents.responsive .spec__table table th, #contents.responsive .spec__table table td {
  padding: .5em 1.25em;
  border: solid 1px #d0d0d0;
  font-size: 16px;
}
#contents.responsive .spec__table table th {
  background: #f3f3f3;
}
#contents.responsive .spec__table table td {
  background: #fff;
}
#contents.responsive .spec__link {
  margin-bottom: 1em;
  font-size: 16px;
}
#contents.responsive .spec__link a {
  background-position: left center;
}
@media only screen and (max-width: 767px) {
  #contents.responsive .spec__subtitle {
    margin: 13.33333vw 0 6.66667vw;
    font-size: 4.8vw;
  }
  #contents.responsive .spec__subtitle--device {
    margin-top: 0;
  }
  #contents.responsive .spec__table table {
    table-layout: auto;
  }
  #contents.responsive .spec__table table th, #contents.responsive .spec__table table td {
    padding: .5em;
    font-size: 4vw;
  }
  #contents.responsive .spec__link {
    font-size: 4.53333vw;
  }
  #contents.responsive .spec__link a {
    background-position: left .65em;
  }
}

/* banner
================================================== */
#contents.responsive .banner {
  padding-bottom: 0;
}
#contents.responsive .banner__title {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: .5em;
  margin-bottom: 1em;
  font-size: 24px;
  font-weight: bold;
  color: #d11900;
  text-align: center;
}
#contents.responsive .banner__title::before, #contents.responsive .banner__title::after {
  font-size: 1em;
}
#contents.responsive .banner__title::before {
  content: "|";
  transform: rotate(-35deg);
}
#contents.responsive .banner__title::after {
  content: "|";
  transform: rotate(35deg);
}
#contents.responsive .banner__list {
  display: flex;
  justify-content: center;
}
#contents.responsive .banner__list li {
  flex: 0 0 460px;
}
#contents.responsive .banner__list li + li {
  margin-left: 40px;
}
#contents.responsive .banner__list a {
  display: block;
}
#contents.responsive .banner__subtitle {
  margin: 50px 0 15px;
  font-size: 20px;
  font-weight: bold;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  #contents.responsive .banner__title {
    gap: 1.2em;
    font-size: 4.8vw;
    line-height: 1.38;
  }
  #contents.responsive .banner__title::before, #contents.responsive .banner__title::after {
    font-size: 2.5em;
    font-weight: normal;
  }
  #contents.responsive .banner__title::before {
    transform: rotate(-30deg);
  }
  #contents.responsive .banner__title::after {
    transform: rotate(30deg);
  }
  #contents.responsive .banner__list {
    display: block;
  }
  #contents.responsive .banner__list li + li {
    margin: 6.66667vw 0 0 0;
  }
  #contents.responsive .banner__subtitle {
    margin: 10.66667vw 0 4vw;
    font-size: 4.8vw;
  }
}

/* download
================================================== */
.download_float {
  position: relative;
  background: #d11900;
  color: #FFF;
  width: 100%;
  margin-top: 80px;
  z-index: 2;
}
.download_float.jsfixed {
  bottom: 0;
  position: fixed;
}
.download_float.jsfixed .download__close {
  display: block;
}
.download_float__btns {
  align-self: flex-end;
  width: 50%;
  display: flex;
  justify-content: center;
  gap: 0 20px;
}
.download_float__btns:not(.app__btns) li {
  width: calc(50% - 10px);
}
.download_float__btns.app__btns {
  width: 320px;
}
.download_float__btn {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 10px 20px 10px 40px;
  border-radius: 5px;
  font-size: 18px;
  font-weight: bold;
  background-color: #FFF;
  text-align: center;
  text-decoration: none !important;
  color: #e83015 !important;
}
.download_float__btn i {
  position: absolute;
  top: 50%;
  left: 10px;
  transform: translateY(-50%);
}
.download_float__btn::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 15px;
  width: 8px;
  height: 8px;
  border-top: solid 2px #e83015;
  border-right: solid 2px #e83015;
  transform: rotate(45deg) translateY(-50%);
}
.download_inner {
  width: 1240px;
  margin: 0 auto;
  box-sizing: border-box;
}
.download_inner * {
  box-sizing: border-box;
}
.download__close {
  display: none;
  position: absolute;
  right: 20px;
  top: .25em;
  font-size: 34px;
  font-family: Arial, Helvetica, "sans-serif";
  line-height: 1;
  color: #fff;
  cursor: pointer;
}
.download_box {
  display: flex;
  padding: 15px 0;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 0 10px;
}
.download_box.with_icn {
  padding-bottom: 5px;
}
.download_box.with_icn .download_text {
  flex: 1;
}
.download_icn {
  width: 80px;
}
.download_text h3 {
  font-size: 22px;
}
@media only screen and (max-width: 767px) {
  .download_inner {
    width: 100%;
  }
  .download__close {
    right: 15px;
    top: .1em;
  }
  .download_box {
    padding: 3vw 3vw 4vw 3vw;
  }
  .download_icn {
    width: 14vw;
  }
  .download_icn img {
    width: 100%;
    height: auto;
  }
  .download_text {
    font-size: 3vw;
  }
  .download_text h3 {
    margin-bottom: .25em;
    font-size: 4vw;
  }
  .download_float__btns {
    align-self: center;
    width: calc(100% - 70px);
    justify-content: flex-start;
    gap: 0 3vw;
    margin-top: 2vw;
  }
  .download_float__btns.app__btns {
    width: calc(100% - 70px);
  }
  .download_float__btns.app__btns li img {
    height: 12vw;
    width: auto;
  }
  .download_float__btn {
    min-width: 100%;
    min-height: inherit;
    padding: 2vw 5vw 2vw 8vw;
    font-size: 3.6vw;
  }
  .download_float__btn i {
    left: 2vw;
  }
  .download_float__btn i img {
    width: 5vw;
    height: auto;
  }
  .download_float__btn::before {
    right: 3vw;
    width: 1.5vw;
    height: 1.5vw;
  }
}

#footer {
  margin-top: 0;
}

#contents.responsive .titleSection__end {
    width: 1240px;
    margin: 40px auto;
		border: solid 2px #d0d0d0;
		padding:20px;
		box-sizing: border-box;
}

#contents.responsive .titleSection__end .titleSection__end_title {
    font-size: 20px;
    margin-bottom: 20px;
}

#contents.responsive .titleSection__end .titleSection__end_text {
    font-size: 14px;
}

#contents.responsive .titleSection__end .titleSection__end_text + .titleSection__end_text {
    margin-top: 15px;
}

@media only screen and (max-width: 767px) {
    #contents.responsive .titleSection__end {
    width: auto;
    padding: 4vw;
  }

  #contents.responsive .titleSection__end .titleSection__end_title {
      font-size: 4.6vw;
      margin-bottom: 5.3vw;
  }

  #contents.responsive .titleSection__end .titleSection__end_text {
      font-size: 4.0vw;
  }

  #contents.responsive .titleSection__end .titleSection__end_text + .titleSection__end_text {
      margin-top: 4.0vw;
  }
}


span.marker {
  background:linear-gradient(transparent 60%, #ffea00 60%);
}
.section__btn {
    display: flex;
		box-sizing: border-box;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
    width: 90%;
		padding:10px 40px;
    background-color: #d11900;
		background-repeat:no-repeat;
		background-position: right 14px center;
		background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg  xmlns='http://www.w3.org/2000/svg' viewBox='0 0 36 36' %3E%3Cg%3E%3Cpath fill='%23FFFFFF' d='M18,0C8.1,0,0,8.1,0,18s8.1,18,18,18,18-8.1,18-18S27.9,0,18,0M23.4,19.4l-6,6.2c-.4.4-.9.6-1.4.6s-1-.2-1.4-.6c-.8-.8-.8-2-.1-2.8l4.6-4.8-4.6-4.6c-.8-.8-.8-2,0-2.8s2-.8,2.8,0l6,6c.9.8.9,2,.1,2.8' /%3E%3C/g%3E%3C/svg%3E");
    background-size: 20px 20px;
    border-radius: 9999px;
    color: #fff !important;
    font-size: 16px;
    font-weight: bold;
    text-decoration: none !important;
    text-align: center;
}
@media only screen and (max-width: 767px) {
	.sptaL {
		text-align:left;
	}
	.section__btn {
    width: 100%;
		padding:2vw 7vw 2vw 5vw;
		background-size:4vw;
		background-position: right 3vw center;
		font-size: 4.0vw;
	}
}
