:root {
  --header-h: 70px;
  --adjust-full-h: calc(100svh - var(--header-h));
}

.-fs-n {
  font-size: 1.2rem;
}

.-fs-s {
  font-size: 1.4rem;
}

.-fs-r {
  font-size: 1.6rem;
}

.-fs-m {
  font-size: 1.8rem;
}

.-fs-d {
  font-size: 2rem;
}

.-fs-l {
  font-size: 2.4rem;
}

.-fs-xl {
  font-size: 3.2rem;
  line-height: 1.5;
}

.-fs-xxl {
  font-size: 4rem;
  line-height: 1.5;
}

.-lh-n {
  line-height: 1;
}

.-lh-s {
  line-height: 1.5;
}

.-lh-r {
  line-height: 1.75;
}

.-lh-m {
  line-height: 2;
}

.-lh-trim {
  text-box-trim: trim-both;
}

.-ta-l {
  text-align: left;
}

.-ta-r {
  text-align: right;
}

.-ta-c {
  text-align: center;
}

.-ta-j {
  text-align: justify;
}

.-ls-palt {
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
  letter-spacing: .1em;
}

.-mi-auto {
  margin-inline: auto;
}

.-mt00 {
  margin-top: 0;
}

.-mt10 {
  margin-top: 20px;
}

.-mt20 {
  margin-top: 20px;
}

.-mt30 {
  margin-top: 30px;
}

.-mt40 {
  margin-top: 40px;
}

.-mt60 {
  margin-top: 60px;
}

.-mt80 {
  margin-top: 80px;
}

.-mt120 {
  margin-top: 120px;
}

.-mt160 {
  margin-top: 160px;
}

.-pd00 {
  padding: 0;
}

.-pd20 {
  padding: 20px;
}

.-pd40 {
  padding: 40px;
}

.-pd60 {
  padding: 60px;
}

.-px00 {
  padding-left: 0;
  padding-right: 0;
}

.-px20 {
  padding-left: 20px;
  padding-right: 20px;
}

.-px40 {
  padding-left: 40px;
  padding-right: 40px;
}

.-px60 {
  padding-left: 60px;
  padding-right: 60px;
}

.-py00 {
  padding-top: 0;
  padding-bottom: 0;
}

.-py20 {
  padding-top: 20px;
  padding-bottom: 20px;
}

.-py40 {
  padding-top: 40px;
  padding-bottom: 40px;
}

.-py60 {
  padding-top: 60px;
  padding-bottom: 60px;
}

.-git10>*+* {
  margin-top: 10px;
}

.-git20>*+* {
  margin-top: 20px;
}

.-git30>*+* {
  margin-top: 30px;
}

.-git40>*+* {
  margin-top: 40px;
}

.-git60>*+* {
  margin-top: 60px;
}

.-git80>*+* {
  margin-top: 80px;
}

.-git120>*+* {
  margin-top: 120px;
}

.-git160>*+* {
  margin-top: 160px;
}

.-w100p {
  width: 100%;
}

.-w-fit {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

.-h100p {
  height: 100%;
}

html {
  -ms-scroll-chaining: none;
  overscroll-behavior: none;
}

svg {
  display: block;
}

img,
picture,
video,
canvas,
svg {
  -webkit-transform: translateZ(0);
  image-rendering: auto;
}

#wrapper {
  overflow: clip;
}

.siteTopicpath {
  display: none;
}

.contents {
  padding-bottom: 0;
}

.ip2__contents {
  contain: paint layout style;
  -ms-scroll-chaining: none;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
}

.ip2__btn {
  height: 60px;
  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;
}

.ip2__btn.-white {
  background-color: #fff;
  color: #000;
}

.ip2__btn.-black {
  background-color: #000;
  color: #fff;
}

.ip2__group {
  position: relative;
}

.ip2__header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 15px;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.ip2__header__title {
  text-box-trim: trim-both;
}

.ip2__lead {
  font-size: 3.2rem;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
  text-box-trim: trim-both;
  text-align: center;
}

.ip2__nav {
  color: #000;
  position: sticky;
  top: var(--header-h);
  left: 0;
  height: 0;
  z-index: 1;
}

.ip2__nav.-revert {
  color: #000;
}

.ip2__nav.-invert {
  color: #fff;
}

.ip2__nav__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 0 18px;
  height: auto;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  gap: 20px;
  opacity: 0;
  pointer-events: none;
  -webkit-transition: opacity 1s;
  transition: opacity 1s;
}

.ip2__nav__inner.-show {
  opacity: 1;
  pointer-events: auto;
}

.ip2__nav__label {
  padding-bottom: 1px;
}

.ip2__nav__label svg {
  width: auto;
  height: 18px;
}

.ip2__nav__body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 8px;
  margin-left: auto;
}

.ip2__nav__body__item {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
  border-top-width: 5px;
  border-top-style: solid;
  border-top-color: transparent;
  padding: 20px 2px 2px;
  -webkit-transition: color 1s,border-top-color 1s;
  transition: color 1s,border-top-color 1s;
}

.ip2__nav__body__item.-current {
  color: currentcolor;
  border-top-color: currentcolor;
}

.ip2__nav__body__item svg {
  width: auto;
  height: 14px;
}

.ip2__nav__btn {
  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: 5px;
  width: 60px;
  height: 60px;
  color: #fff;
  margin-left: auto;
}

.ip2__nav__btn span {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: currentcolor;
}

.ip2__content {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  overflow: clip;
}

.ip2__detail__row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 60px;
  padding: 80px 20px;
}

.ip2__img {
  overflow: hidden;
}

.ip2__img.-ar1x1 {
  aspect-ratio: 1/1;
}

.ip2__img.-ar3x2 {
  aspect-ratio: 3/2;
}

.ip2__img.-ar3x4 {
  aspect-ratio: 3/4;
}

.ip2__img.-ar16x9 {
  aspect-ratio: 16/9;
}

.ip2__img.-ar-fit {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

.ip2__img img.-cover {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.ip2__img img.-contain {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
}

.ip2__row {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  padding: 40px 0;
}

.ip2__row.-gap20 {
  gap: 20px;
}

.ip2__row.-gap40 {
  gap: 40px;
}

.ip2__row.-gap60 {
  gap: 60px;
}

.ip2__row.-gap80 {
  gap: 80px;
}

.ip2__row.-top {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}

.ip2__row.-middle {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.ip2__row.-bottom {
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}

.ip2__row.-baseline {
  -webkit-box-align: baseline;
  -ms-flex-align: baseline;
  align-items: baseline;
}

.ip2__row.-left {
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}

.ip2__row.-center {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.ip2__row.-right {
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}

:where(.ip2__row__item) {
  position: relative;
  min-width: 0;
  padding: 40px 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}

.ip2__column {
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: stretch;
  -ms-flex-align: stretch;
  align-items: stretch;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.ip2__column__item {
  position: relative;
  min-width: 0;
  -webkit-box-flex: 1;
  -ms-flex: 1 1 100%;
  flex: 1 1 100%;
}

.ip2__front {
  background-color: #2d2d2d;
  color: #fff;
}

.ip2__hero {
  background-color: #2d2d2d;
  z-index: 2;
  position: relative;
  isolation: isolate;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  will-change: opacity,transform;
}

.ip2__hero__body {
  -webkit-transition: opacity 1s;
  transition: opacity 1s;
}

.ip2__hero__body:not(.-show) {
  opacity: 0;
}

.ip2__hero__body.-show {
  opacity: 1;
}

.ip2__hero__id {
  width: 240px;
}

.ip2__hero__logo {
  margin-top: 20px;
  width: 240px;
}

.ip2__hero__img {
  padding: 0;
  -webkit-box-flex: 1;
  -ms-flex: 1 1 100%;
  flex: 1 1 100%;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.ip2__hero__img__anm {
  position: absolute;
  inset: 0;
  aspect-ratio: 1/1;
  border: 1px solid red;
  z-index: 2;
  -webkit-transform: scale(1.61);
  transform: scale(1.61);
  -webkit-transition: opacity 2s;
  transition: opacity 2s;
  opacity: 1;
}

.ip2__hero__img__anm+img {
  -webkit-transition: opacity 2s;
  transition: opacity 2s;
}

.ip2__hero__img__anm.-done {
  opacity: 0;
  -webkit-transition: opacity 2s;
  transition: opacity 2s;
}

.ip2__hero__img__anm:not(.-done)+img {
  opacity: 0;
}

.ip2__hero__img__anm.-done+img {
  opacity: 1;
}

.ip2__hero__img__item {
  position: relative;
  aspect-ratio: 1/1;
  margin-inline: auto;
  max-width: 100%;
  overflow: hidden;
}

.ip2__hero__img__item img {
  -webkit-transform: scale(1.3);
  transform: scale(1.3);
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
}

.ip2__hero__body {
  padding: 0;
  -webkit-box-flex: 0;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
}

.ip2__hero__body[data-ip2-inview] .ip2__hero__logo {
  top: 10px;
  position: relative;
  opacity: 0;
  -webkit-transition: opacity 2s .25s,top 2s .25s;
  transition: opacity 2s .25s,top 2s .25s;
  will-change: opacity,top;
}

.ip2__hero__body[data-ip2-inview] .ip2__hero__id {
  top: 15px;
  position: relative;
  opacity: 0;
  -webkit-transition: opacity 2s,top 2s;
  transition: opacity 2s,top 2s;
  will-change: opacity,top;
}

.ip2__hero__body[data-ip2-inview].-show .ip2__hero__logo,
.ip2__hero__body[data-ip2-inview].-show .ip2__hero__id {
  top: 0;
  opacity: 1;
}

.ip2__hero__row01 {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding: 0 0 60px;
  height: var(--adjust-full-h);
}

.ip2__introduction {
  position: relative;
  isolation: isolate;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  will-change: opacity,transform;
  background-color: #2d2d2d;
  z-index: 2;
}

.ip2__introduction__img {
  padding: 0;
  -webkit-box-flex: 1;
  -ms-flex: 1 1 100%;
  flex: 1 1 100%;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.ip2__introduction__img__anm {
  position: absolute;
  inset: 0;
  aspect-ratio: 1/1;
  border: 1px solid red;
  z-index: 2;
  -webkit-transform: scale(1.61);
  transform: scale(1.61);
  -webkit-transition: opacity 2s;
  transition: opacity 2s;
  opacity: 1;
}

.ip2__introduction__img__anm+img {
  -webkit-transition: opacity 2s;
  transition: opacity 2s;
}

.ip2__introduction__img__anm.-done {
  opacity: 0;
  -webkit-transition: opacity 2s;
  transition: opacity 2s;
}

.ip2__introduction__img__anm:not(.-done)+img {
  opacity: 0;
}

.ip2__introduction__img__anm.-done+img {
  opacity: 1;
}

.ip2__introduction__img__item {
  position: relative;
  aspect-ratio: 1/1;
  margin-inline: auto;
  max-width: 100%;
  overflow: hidden;
}

.ip2__introduction__img__item img {
  -webkit-transform: scale(1.3);
  transform: scale(1.3);
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
}

.ip2__visual {
  position: sticky;
  bottom: 0;
  left: 0;
  aspect-ratio: 3/4;
  padding: 80px 20px;
  color: #fff;
  background-color: #fff;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  will-change: transform;
  contain: paint;
}

.ip2__visual[data-ip2-inview] {
  opacity: 0;
  -webkit-transition: opacity 2s;
  transition: opacity 2s;
}

.ip2__visual[data-ip2-inview].-show {
  opacity: 1;
}

.ip2__visual__slide {
  position: absolute;
  inset: 0;
}

.ip2__visual__slide .slick-list {
  height: 100%;
}

.ip2__visual__slide .slick-list .slick-track {
  height: 100%;
}

.ip2__visual__slide__item {
  position: absolute;
  inset: 0;
  aspect-ratio: 375/500;
  overflow: hidden;
}

.ip2__visual__slide__item img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  pointer-events: none;
}

.ip2__visual__slide__item img.-pc {
  display: none;
}

.ip2__visual__slide__item img.-sp {
  display: block;
}

.ip2__visual__mov {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  overflow: hidden;
}

.ip2__visual__mov__item {
  display: none;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  pointer-events: none;
}

.ip2__visual__mov__item.-pc {
  display: none;
}

.ip2__visual__mov__item.-sp {
  display: block;
}

.ip2__visual__lead {
  position: relative;
}

.ip2__visual-nav {
  position: absolute;
  bottom: 20px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  margin-inline: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 20px;
  width: 100%;
  padding: 0 20px;
}

.ip2__visual-nav__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-flex: 0;
  -ms-flex: 0 0 calc( (100% - ( 20px * 2 )) / 3 );
  flex: 0 0 calc( (100% - ( 20px * 2 )) / 3 );
  text-align: center;
  gap: 10px;
}

.ip2__visual-nav__item svg {
  width: auto;
  height: 24px;
}

.ip2__visual-nav__item>* {
  text-box-trim: trim-both;
}

.ip2__design__body {
  padding-top: 40px;
}

.ip2__design__img {
  padding: 0;
}

.ip2__design__img__item {
  aspect-ratio: 1/1;
  margin-inline: auto;
  max-width: 100%;
  overflow: hidden;
}

.ip2__design__img__item[data-ip2-inview] {
  position: relative;
  top: 40px;
  opacity: 0;
  -webkit-transition: top 2s cubic-bezier(0.25, 1, 0.5, 1),opacity 2s;
  transition: top 2s cubic-bezier(0.25, 1, 0.5, 1),opacity 2s;
  will-change: opacity,filter;
}

.ip2__design__img__item[data-ip2-inview].-show {
  top: 0;
  opacity: 1;
}

.ip2__design__img__item img {
  -webkit-transform: scale(1.3);
  transform: scale(1.3);
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
}

.ip2__design-variation {
  min-height: initial;
  padding-top: 40px;
}

.ip2__design-variation__row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-top: 40px;
  gap: 20px;
}

.ip2__row__item:has(.ip2__design-variation__row) {
  width: 100%;
}

.ip2__design-variation__row__item {
  aspect-ratio: 3/2;
  max-width: 100%;
}

.ip2__design-variation__row__item img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.ip2__design-variation__row__item[data-ip2-inview] {
  position: relative;
  top: 20px;
  opacity: 0;
  -webkit-transition: opacity 1s,top 1s cubic-bezier(0.25, 1, 0.5, 1);
  transition: opacity 1s,top 1s cubic-bezier(0.25, 1, 0.5, 1);
}

.ip2__design-variation__row__item[data-ip2-inview].-show {
  top: 0;
  opacity: 1;
}

.ip2__sounddesign {
  background-color: #2d2d2d;
  --bg-color: #2d2d2d;
  color: #fff;
}

.ip2__sounddesign__body+.ip2__sounddesign__body {
  margin-top: 160px;
}

.ip2__sounddesign__row {
  padding: 80px 0;
}

.ip2__sounddesign__row [data-ip2-inview=-show] {
  opacity: 0;
  -webkit-transition: opacity .5s;
  transition: opacity .5s;
  will-change: opacity;
}

.ip2__sounddesign__row [data-ip2-inview=-show].-show {
  opacity: 1;
}

.ip2__sounddesign__row__header {
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}

.ip2__sounddesign__row__body {
  padding-top: 120px;
}

.ip2__sounddesign__row__visual {
  position: absolute;
  top: 0;
  left: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  padding: 0;
}

.ip2__sounddesign__scope {
  position: sticky;
  top: var(--header-h);
  left: 0;
  height: var(--adjust-full-h);
  opacity: 0;
  -webkit-transition: opacity 1s;
  transition: opacity 1s;
}

.ip2__sounddesign__scope.-show {
  opacity: 1;
}

.ip2__sounddesign__axis {
  stroke: transparent;
  stroke-width: .5;
  vector-effect: non-scaling-stroke;
}

.ip2__sounddesign__wave {
  fill: none;
  stroke: currentcolor;
  stroke-width: .5;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-opacity: .5;
  vector-effect: non-scaling-stroke;
}

.ip2__sounddesign__btns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 20px;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  max-width: 240px;
  margin-inline: auto;
}

.ip2__sounddesign__btns__item {
  width: 60px;
  height: 60px;
  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;
  border-radius: 50%;
  border: 1px solid currentcolor;
  text-align: center;
  color: #fff;
  background-color: var(--bg-color);
  -webkit-transition: color .25s,background-color .25s;
  transition: color .25s,background-color .25s;
}

.ip2__sounddesign__btns__item.-on {
  color: var(--bg-color);
  background-color: #fff;
  pointer-events: none;
}

.ip2__sounddesign__btns__item:hover {
  opacity: 1;
  -webkit-transform: scale(0.99);
  transform: scale(0.99);
}

.ip2__sounddesign__btns__item:active {
  opacity: 1;
  -webkit-transform: scale(0.95);
  transform: scale(0.95);
}

.ip2__delivery .ip2__img[data-ip2-inview] {
  opacity: 0;
  -webkit-transition: opacity .5s;
  transition: opacity .5s;
  will-change: opacity;
}

.ip2__delivery .ip2__img[data-ip2-inview].-show {
  opacity: 1;
}

.ip2__delivery__row {
  padding: 0;
  background-color: #e6e6e6;
}

.ip2__delivery__img {
  padding: 0;
}

.ip2__delivery__img[data-ip2-inview] {
  opacity: 0;
  -webkit-transition: opacity .5s;
  transition: opacity .5s;
  will-change: opacity;
}

.ip2__delivery__img[data-ip2-inview].-show {
  opacity: 1;
}

.ip2__delivery__img__item {
  aspect-ratio: 3/2;
  overflow: hidden;
}

.ip2__delivery__img__item img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.ip2__delivery__body {
  padding: 80px 20px;
}

.ip2__security .ip2__img[data-ip2-inview] {
  opacity: 0;
  -webkit-transition: opacity .5s;
  transition: opacity .5s;
  will-change: opacity;
}

.ip2__security .ip2__img[data-ip2-inview].-show {
  opacity: 1;
}

.ip2__security__row {
  padding: 0;
  background-color: #e6e6e6;
}

.ip2__security__img {
  padding: 0;
}

.ip2__security__img[data-ip2-inview] {
  opacity: 0;
  -webkit-transition: opacity .5s;
  transition: opacity .5s;
  will-change: opacity;
}

.ip2__security__img[data-ip2-inview].-show {
  opacity: 1;
}

.ip2__security__img__item {
  aspect-ratio: 3/2;
  overflow: hidden;
}

.ip2__security__img__item img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.ip2__security__body {
  padding: 80px 20px;
}

.product__support {
  background-color: #f2f2f2;
}

.product__lineup__spec__img {
  border: 1px solid #f2f2f2;
}

.product__lineup__spec__table {
  border-collapse: separate;
  border-spacing: 1px;
}

.product__lineup__spec__table th,
.product__lineup__spec__table td {
  background-color: #f2f2f2;
  padding: 8px 20px;
  font-size: 14px;
}

.product__lineup__spec__table th {
  width: 96px;
  font-weight: normal;
}

.product__lineup__apps {
  border: 1px solid #000;
  padding: 35px 20px;
  max-width: 340px;
  margin-inline: auto;
}

.product__lineup__apps>*+* {
  margin-top: 35px;
}

.product__lineup__apps__type {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 20px;
}

.product__lineup__apps__type__item {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 10px;
}

.product__lineup__apps__type__item .icon {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 45px;
  flex: 0 0 45px;
}

.product__lineup__apps__type__item .icon img {
  width: 45px;
  height: 45px;
}

.product__lineup__apps__summary {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 10px 0;
}

.product__lineup__apps__summary dt {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 6em;
  flex: 0 0 6em;
}

.product__lineup__apps__summary dd {
  -webkit-box-flex: 0;
  -ms-flex: 0 1 calc( 100% - 6em );
  flex: 0 1 calc( 100% - 6em );
}

.product__lineup__slide__item .product__img {
  width: 100%;
  aspect-ratio: 1/1;
}

.product__lineup__slide__title {
  position: absolute;
  top: 20px;
  right: 0;
  left: 0;
}

.product__lineup__slide__nav {
  position: absolute;
  bottom: 0;
  right: 0;
  left: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 20px;
}

.product__lineup__slide__nav button {
  -webkit-box-flex: 0;
  -ms-flex: 0;
  flex: 0;
  text-align: center;
  white-space: nowrap;
  color: currentcolor;
}

.product__lineup__slide__nav button:hover {
  opacity: 1;
}

.product__lineup__slide__nav__bullet {
  display: block;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  margin-inline: auto;
  margin-bottom: 5px;
  font-size: 14px;
}

.product__content {
  padding: 60px 20px;
}

.product__content.-sub {
  padding-top: 0;
}

.product__img {
  overflow: hidden;
}

.product__img.-ar1x1 {
  aspect-ratio: 1/1;
}

.product__img.-ar3x2 {
  aspect-ratio: 3/2;
}

.product__img.-ar3x4 {
  aspect-ratio: 3/4;
}

.product__img.-ar16x9 {
  aspect-ratio: 16/9;
}

.product__img.-ar-fit {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

.product__img img.-cover {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.product__img img.-contain {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
}

.product__img img.-s {
  width: 33%;
  height: auto;
}

.product__row {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

.product__row.-gap20 {
  gap: 20px;
  --gap: 20px;
}

.product__row.-gap40 {
  gap: 40px;
  --gap: 40px;
}

.product__row.-gap60 {
  gap: 60px;
  --gap: 60px;
}

.product__row.-gap80 {
  gap: 80px;
  --gap: 80px;
}

.product__row.-top {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}

.product__row.-middle {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.product__row.-bottom {
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}

.product__row.-baseline {
  -webkit-box-align: baseline;
  -ms-flex-align: baseline;
  align-items: baseline;
}

.product__row.-left {
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}

.product__row.-center {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.product__row.-right {
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}

:where(.product__row__item) {
  position: relative;
  min-width: 0;
}

:where(.product__row__item).-col2 {
  width: 100%;
  margin-inline: auto;
}

.pagetop {
  display: none;
}

[data-ip2-inview=-b-t-20] {
  position: relative;
  top: 20px;
  opacity: 0;
  -webkit-transition: top 1.5s,opacity 1.5s;
  transition: top 1.5s,opacity 1.5s;
}

[data-ip2-inview=-b-t-20].-b-t-20 {
  top: 0;
  opacity: 1;
}

[data-ip2-inview=-b-t-10] {
  position: relative;
  top: 10px;
  opacity: 0;
  -webkit-transition: top 1.5s,opacity 1.5s;
  transition: top 1.5s,opacity 1.5s;
}

[data-ip2-inview=-b-t-10].-b-t-10 {
  top: 0;
  opacity: 1;
}

@media screen and (min-width: 481px) {
  .-w-s {
    width: 340px;
  }

  .-w-smax {
    max-width: 340px;
  }

  .-w-smin {
    min-width: 340px;
  }

  .-w-m {
    width: 720px;
  }

  .-w-mmax {
    max-width: 720px;
  }

  .-w-mmin {
    min-width: 720px;
  }

  .-w-l {
    width: 1100px;
  }

  .-w-lmax {
    max-width: 1100px;
  }

  .-w-lmin {
    min-width: 1100px;
  }

  .ip2__nav__inner {
    padding: 0 40px;
  }

  .ip2__nav__label svg {
    height: 24px;
  }

  .ip2__nav__body {
    gap: 40px;
  }

  .ip2__nav__body__item {
    padding: 35px 10px 0;
  }

  .ip2__nav__body__item svg {
    height: 21px;
  }

  .ip2__nav__btn {
    color: #000;
  }

  .ip2__content {
    padding: 0;
  }

  .ip2__detail__row {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    gap: 40px;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 80px 0;
    margin: 0 40px;
  }

  .ip2__detail__row__item {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 calc( (100% - 80px) / 3 );
    flex: 0 0 calc( (100% - 80px) / 3 );
  }

  .ip2__row {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 0;
  }

  .ip2__row.-reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
  }

  :where(.ip2__row__item) {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 50%;
    flex: 1 0 50%;
    padding: 80px 40px;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    min-height: 800px;
  }

  .ip2__hero__id {
    width: 386px;
  }

  .ip2__hero__logo {
    margin-top: 40px;
    width: 386px;
  }

  .ip2__hero__img {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 50%;
    flex: 1 0 50%;
    min-height: var(--adjust-full-h);
  }

  .ip2__hero__img__anm {
    -webkit-transform: scale(1.24);
    transform: scale(1.24);
  }

  .ip2__hero__img__item {
    max-width: 720px;
  }

  .ip2__hero__img__item img {
    -webkit-transform: scale(1);
    transform: scale(1);
  }

  .ip2__hero__body {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 50%;
    flex: 1 0 50%;
    padding: 80px 40px;
    min-height: var(--adjust-full-h);
  }

  .ip2__introduction__img {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 50%;
    flex: 1 0 50%;
    min-height: var(--adjust-full-h);
  }

  .ip2__introduction__img__anm {
    -webkit-transform: scale(1.24);
    transform: scale(1.24);
  }

  .ip2__introduction__img__item {
    max-width: 720px;
  }

  .ip2__introduction__img__item img {
    -webkit-transform: scale(1);
    transform: scale(1);
  }

  .ip2__visual {
    aspect-ratio: auto;
    height: 800px;
  }

  .ip2__visual__slide__item {
    aspect-ratio: 1200/675;
  }

  .ip2__visual__slide__item img.-pc {
    display: block;
  }

  .ip2__visual__slide__item img.-sp {
    display: none;
  }

  .ip2__visual__mov__item.-pc {
    display: block;
  }

  .ip2__visual__mov__item.-sp {
    display: none;
  }

  .ip2__visual-nav {
    bottom: 40px;
    max-width: 680px;
    gap: 60px;
    padding: 0;
  }

  .ip2__visual-nav__item {
    gap: 15px;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 calc( (100% - ( 60px * 2 )) / 3 );
    flex: 0 0 calc( (100% - ( 60px * 2 )) / 3 );
  }

  .ip2__visual-nav__item svg {
    height: 28px;
  }

  .ip2__design__body {
    padding-top: 80px;
    min-height: var(--adjust-full-h);
  }

  .ip2__design__img {
    min-height: var(--adjust-full-h);
  }

  .ip2__design__img__item {
    max-width: 720px;
  }

  .ip2__design__img__item img {
    -webkit-transform: scale(1);
    transform: scale(1);
  }

  .ip2__design-variation {
    padding-top: 0;
  }

  .ip2__design-variation__row {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    margin-top: 40px;
    max-width: 1280px;
    margin-inline: auto;
    gap: 0;
  }

  .ip2__design-variation__row__item {
    aspect-ratio: 3/4;
    -webkit-box-flex: 0;
    -ms-flex: 0 1 auto;
    flex: 0 1 auto;
  }

  .ip2__design-variation__row__item[data-ip2-inview] {
    top: 32px;
  }

  .ip2__design-variation__row__item[data-ip2-inview]:nth-of-type(2) {
    -webkit-transition-delay: .16s;
    transition-delay: .16s;
  }

  .ip2__design-variation__row__item[data-ip2-inview]:nth-of-type(3) {
    -webkit-transition-delay: .32s;
    transition-delay: .32s;
  }

  .ip2__design-variation__row__item[data-ip2-inview]:nth-of-type(4) {
    -webkit-transition-delay: .48s;
    transition-delay: .48s;
  }

  .ip2__sounddesign {
    min-height: var(--adjust-full-h);
  }

  .ip2__sounddesign__header {
    min-height: var(--adjust-full-h);
    position: sticky;
    top: var(--header-h);
    left: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }

  .ip2__sounddesign__body {
    min-height: var(--adjust-full-h);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }

  .ip2__sounddesign__body+.ip2__sounddesign__body {
    margin-top: 0;
  }

  .ip2__sounddesign__row {
    padding: 0;
  }

  .ip2__sounddesign__row__body {
    padding-top: 80px;
  }

  .ip2__sounddesign__row__visual {
    min-height: 0;
    height: 100%;
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }

  .ip2__delivery__img {
    -ms-flex-item-align: stretch;
    -ms-grid-row-align: stretch;
    align-self: stretch;
  }

  .ip2__delivery__img__item {
    aspect-ratio: auto;
    position: relative;
    -webkit-box-flex: 1;
    -ms-flex: 1 1 100%;
    flex: 1 1 100%;
  }

  .ip2__delivery__img__item img {
    position: absolute;
    top: 0;
    left: 0;
  }

  .ip2__security__img {
    -ms-flex-item-align: stretch;
    -ms-grid-row-align: stretch;
    align-self: stretch;
  }

  .ip2__security__img__item {
    aspect-ratio: auto;
    position: relative;
    -webkit-box-flex: 1;
    -ms-flex: 1 1 100%;
    flex: 1 1 100%;
  }

  .ip2__security__img__item img {
    position: absolute;
    top: 0;
    left: 0;
  }

  .product__lineup__spec__table th {
    width: 140px;
  }

  .product__lineup__slide__nav__bullet {
    width: 20px;
    height: 20px;
    margin-bottom: 10px;
    font-size: 16px;
  }

  .product__img img.-s {
    width: env();
  }

  .product__row {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 0;
  }

  .product__row.-reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
  }

  :where(.product__row__item) {
    -webkit-box-flex: 1;
    -ms-flex: 1 1 100%;
    flex: 1 1 100%;
  }

  :where(.product__row__item).-col2 {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 calc(50% - var(--gap) / 2 );
    flex: 0 0 calc(50% - var(--gap) / 2 );
  }
}