/* ------ 0.汎用 ------ */
:root{
  --color-text:#222222;
  --color-text-sub:#666666;
}
.a3test .section__heading {
  font-size: 32px;
}
@media screen and (max-width:960px) {
  .a3test .section__heading {
    font-size: 24px;
    margin-bottom: 16px;
  }
}
.a3test .annotationMark {
  font-size: 12px;
  font-weight: 400;
  vertical-align: baseline;
  color: currentColor;
}
.only--pc {
  display: block;
}
@media screen and (max-width:960px) {
  .only--pc {
    display: none;
  }
}
.br--sp {
  display: none;
}
@media screen and (max-width:960px) {
  .br--sp {
    display: none;
  }
}
@media screen and (max-width:750px) {
  .br--sp {
    display: inline;
  }
}
.br--tab {
  display: none;
}
@media screen and (max-width:960px) {
  .br--tab {
    display: inline;
  }
}
.a3test .kvAreaMain__button__wrapper--sp .dlpo--hidden_login_fv_sp .button--login {
  border: none;
}


/* ------ 1.ABOUT ------ */

.a3test .aboutSection {
  position: relative;
  z-index: 0;
  padding-top: 64px;
}
@media screen and (max-width:960px) {
  .a3test .aboutSection {
    padding-top: 20px;
  }
}
@media screen and (max-width:750px) {
  .a3test .aboutSection {
    padding-top: 32px;
  }
}
@media screen and (max-width:960px) {
  .a3test .aboutSection__heading {
    margin-bottom: 16px;
  }
}
@media screen and (max-width:750px) {
  .a3test .aboutSection__heading {
    margin-bottom: 0;
  }
}
.a3test .aboutSection ul {
  display: flex;
  justify-content: space-between;
  max-width: 928px;
  margin: 0 auto;
  gap: 40px;
}
@media screen and (max-width:960px) {
  .a3test .aboutSection ul {
    gap: 16px;
  }
}
@media screen and (max-width:750px) {
  .a3test .aboutSection ul {
    flex-wrap: wrap;
    justify-content: center;
  }
}
.a3test .aboutSection ul li {
  width: 296px;
  text-align: center;
  font-size: 20px;
  line-height: 1.4;
  font-weight: 600;
}
@media screen and (max-width:750px) {
  .a3test .aboutSection ul li {
    width: 100%;
    max-width: 400px;
    margin-top: 16px;
  }
}
.a3test .aboutSection ul li > p {
  margin-top: 16px;
  font-size: 20px;
}
@media screen and (max-width:960px) {
  .a3test .aboutSection ul li > p {
    margin-top: 8px;
    font-size: 16px;
  }
}
.a3test .aboutSection ul li > img {
  vertical-align: bottom;
}

.a3test .aboutSection .morePanel__wrapper {
  position: relative;
  margin-top: 104px;
  padding: 64px;
  text-align: center;
  border-radius: 64px;
  background: linear-gradient(to bottom,  
  #5ec5ed 0%,  
  #20AEE5 70%,  
  #0CA0DA 98%);
}
@media screen and (max-width:960px) {
  .a3test .aboutSection .morePanel__wrapper {
    padding: 40px 32px 32px;
    border-radius: 32px;
  }
}
@media screen and (max-width:750px) {
  .a3test .aboutSection .morePanel__wrapper {
    margin-top: 68px;
    padding: 40px 20px 20px;
  }
}
.a3test .aboutSection .morePanel__wrapper .circle-container {
  position: absolute;
  top: 0;
  left: 50%;
  text-align: center;
  padding-top: 50px;
}
.a3test .aboutSection .morePanel__wrapper .circle-container .circle {
  width: 80px;
  height: 80px;
  background-color: white;
  border-radius: 50%;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  align-items: center;
  justify-content: center;
}
.a3test .aboutSection .morePanel__wrapper .circle-container .circle .circle-text {
  font-size: 16px;
  font-weight: 600;
  color: #20aee5;
}
.a3test .aboutSection .morePanel__title {
  color: #fff;
  font-size: 28px;
  line-height: 1.4;
  text-align: center;
  display: inline-block;
  text-decoration: underline;
  text-decoration-color: rgba(255, 255, 255, 0.3);
  text-decoration-thickness: 4px;
  text-underline-offset: 10px;
}
@media screen and (max-width:960px) {
  .a3test .aboutSection .morePanel__title {
    margin-top: 4px;
  }
}
@media screen and (max-width:750px) {
  .a3test .aboutSection .morePanel__title {
    line-height: 1.73;
    text-underline-offset: 10px;
  }
}
.a3test .aboutSection .morePanel__description {
  color: #fff;
  font-size: 16px;
  line-height: 2.0;
  margin-top: 20px;
  margin-bottom: 40px;
}
@media screen and (max-width:960px) {
  .a3test .aboutSection .morePanel__description {
    margin-top: 16px;
    margin-bottom: 16px;
    line-height: 1.6;
  }
}
@media screen and (max-width:750px) {
  .a3test .aboutSection .morePanel__description {
    text-align: left;
  }
}
@media screen and (max-width:960px) {
  .a3test .aboutSection .morePanel__img {
    max-width: 520px;
  }  
}


/* ------ 2.FEATURE ------ */
.a3test .featuresSection {
  margin-top: -380px;
  padding-top: 380px;
  background-color: var(--color-bg-primary);
  position: relative;
  z-index: -1;
}
@media screen and (max-width:1295px) {
  .a3test .featuresSection {
    margin-top: calc(-0.185vw - 339.5px);
    padding-top: calc(0.185vw + 339.5px);
  }
}
@media screen and (max-width:960px) {
  .a3test .featuresSection {
    margin-top: -550px;
    padding-top: 550px;
  }
}
@media screen and (max-width:750px) {
  .a3test .featuresSection {
    margin-top: calc((-2 / 3) * 100vw - 150px);
    padding-top: calc((2 / 3) * 100vw + 150px);
  }
}
.a3test .featuresSection .featuresSection__heading {
  color: var(--color-text);
}
.a3test .featuresSection .featuresSection__text {
  text-align: center;
  margin-bottom: var(--space-xxl);
}
@media screen and (max-width:960px) {
  .a3test .featuresSection .featuresSection__text {
    margin-bottom: 16px;
  }  
}
@media screen and (max-width:750px) {
  .a3test .featuresSection .featuresSection__text {
    text-align: left;
  }  
}
.a3test .featurePanel__container>:not(:first-child) {
  margin-top: 40px;
}
@media screen and (max-width:960px) {
  .a3test .featurePanel__container>:not(:first-child) {
    margin-top: 16px;
  }
}
.a3test .featurePanel {
  border-radius: 20px;
  box-shadow: none;
}
@media screen and (max-width:960px) {
  .a3test .featurePanel {
    border-radius: 16px;
  }
}
.a3test .featurePanel__inner {
  display: flex;
  align-items: center;
  padding: 40px;
}
.a3test .featurePanel__inner>* {
  width: calc(100% - 10px);
}
.a3test .featurePanel--01 .featurePanel__inner {
  padding: 26px 40px;
}
@media screen and (max-width:960px) {
  .a3test .featurePanel--01 .featurePanel__inner {
    padding: 20px;
  }  
}
.a3test .featurePanel__inner--reverse {
  flex-direction: row-reverse;
}
@media screen and (max-width:960px) {
  .a3test .featurePanel__inner {
    padding: var(--space-md);
  }
  .a3test .featurePanel__inner,
  .a3test .featurePanel__inner.reverse {
    flex-direction: column;
  }
  .a3test .featurePanel__inner>* {
    width: 100%;
  }
}
.a3test .featurePanel__content {
  margin-right: 64px;
  margin-left: 24px;
}
@media screen and (max-width:960px) {
  .a3test .featurePanel__content {
    margin-right: 0;
    margin-left: 0;
  }
}
.a3test .featurePanel__title {
  font-size: 28px;
  font-weight: 600;
}
@media screen and (max-width:960px) {
  .a3test .featurePanel__title {
    font-size: 22px;
  }
}
.a3test .featurePanel__description {
  font-size: 16px;
  line-height: 2.0;
  margin-top: 24px;
}
@media screen and (max-width:960px) {
  .a3test .featurePanel__description {
    font-size: 16px;
    line-height: 1.6;
    margin-top: 16px;
  }
}
.a3test .featurePanel__image__wrapper {
  max-width: 456px;
}
@media screen and (max-width:960px) {
  .a3test .featurePanel__image__wrapper {
    max-width: 520px;
    margin-top: 20px;
  }  
}
.a3test .featurePanel__image {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
  margin: 0 auto
}


/* ------ 3.FUNCTION ------ */
.a3test .functionsPanel {
  padding: var(--space-xl);
}
.a3test .functionsPanel__row:not(:first-child) {
  margin-top: var(--space-xxl);
}
.a3test .featurePanel__container .functionsPanel {
  margin-top: 64px;
}
@media screen and (max-width:960px) {
  .a3test .featurePanel__container .functionsPanel {
    margin-top: 32px;
    padding: var(--space-md);
  }
}
.a3test .functionsPanel__heading {
  font-size: 24px;
  font-weight: 600;
  background-color: var(--color-primary);
  text-align: center;
  line-height: 1.4;
  color: #fff;
  border-radius: 10px;
  padding: 8px;
}
@media screen and (max-width:960px) {
  .a3test .functionsPanel__heading {
    font-size: 16px;
  }
}
.a3test .functionDetailBox__container {
  margin-top: 16px;
  gap: 16px;
  display: flex;
  flex-wrap: wrap;
}
.a3test .functionDetailBox {
  aspect-ratio: 1;
  width: calc((100% - (10px * 2 * 4))/ 4);
  min-width: 248px;
  margin: 0;
}
@media screen and (max-width:960px) {
  .a3test .functionDetailBox {
    margin-top: 0;
    width: calc((100% - (10px * 2 * 1))/ 2);
    min-width: auto;
    padding: 10px 0;
    aspect-ratio: auto;
  }
}
.a3test .functionDetailBox__inner {
  border: 1px solid var(--color-border);
  border-radius: 10px;
  height: 110%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
}
@media screen and (max-width:960px) {
  .a3test .functionDetailBox__inner {
    border: none;
    height: auto;
  }
}
.a3test .functionDetailBox__head {
  height: 80%;
  display: flex;
  align-items: center;
}
@media screen and (max-width:960px) {
  .a3test .functionDetailBox__head {
    width: 40vw;
    height: 40vw;
    border: 1px solid var(--color-border);
    border-radius: 10px;
  }
}
.a3test .functionDetailBox__image__wrapper {
  width: 100%;
  height: 100%;
  max-width: 140px;
  max-height: 140px;
  display: flex;
  align-items: center;
  padding: 10px 10px 0;
}
.a3test .functionDetailBox__image__wrapper_logo {
  width: 100%;
  height: 100%;
  max-width: 220px;
  max-height: 200px;
  display: flex;
  align-items: center;
  padding: 28px 10px 26px;
}
@media screen and (max-width:960px) {
  .a3test .functionDetailBox__image__wrapper {
    padding: 20px;
    max-width: none;
    max-height: 80%;
    padding: 10px;
  }
  .a3test .functionDetailBox__image__wrapper_logo {
    max-height: 100%;
    padding: 24px 10px 20px;
    margin-right: auto;
    margin-left: auto;
  }
}
.a3test .functionDetailBox__image {
  -o-object-fit: contain;
  object-fit: contain;
  width: 100%;
  height: 100%;
}
@media screen and (max-width:960px) {
  .a3test .functionDetailBox__image {
    max-width: 200px;
    margin-right: auto;
    margin-left: auto;
  }
}
.a3test .functionDetailBox__body {
  flex: 1 0 auto;
  display: grid;
  height: 30%;
  width: 90%;
  padding: 16px;
  align-items: center;
  font-weight: 600;
  border-top: 1px solid #ccc;
}
@media screen and (max-width:960px) {
  .a3test .functionDetailBox__body {
    height: auto;
    flex: auto;
    padding: 10px 0;
    border-top: none;
  }
}
.a3test .functionDetailBox__title {
  font-size: 16px;
  text-align: center;
  line-height: 1.4;
}
@media screen and (max-width:960px) {
  .a3test .functionDetailBox__title {
    font-size: 14px;
  }
}


/* ------ 4.CV_AREA(共通) ------ */
.a3test .cv_annotation {
  margin-top: 8px;
  text-indent: 100px;
}
@media screen and (max-width:960px) {
  .a3test .cv_annotation {
    margin-top: 8px;
    text-indent: 0;
    font-size: 12px;
  }
}
.a3test .cvArea {
  padding: 64px 80px;
}
@media screen and (max-width:960px) {
  .a3test .cvArea {
    padding: 32px 0;
  }
}
@media screen and (max-width:750px) {
  .a3test .cvArea {
    padding: 32px 16px;
  }
}
.a3test .cvArea__inner {
  padding: 64px 40px;
}
@media screen and (max-width:960px) {
  .a3test .cvArea__inner {
    padding: 32px 20px;
    max-width: 600px;
  }
}
.a3test .cvArea__heading {
  padding: 0;
  line-height: 1.4;
}
.a3test .cvArea__body {
  margin-top: 0;
}
.a3test .cvPanel__inner {
  padding: 40px 0 0 0;
  display: flex;
  align-items: center;
  gap: 80px;
  justify-content: center;
}
@media screen and (max-width:960px) {
  .a3test .cvPanel__inner {
    gap: 0;
    padding: 0;
  }
}
.a3test .cvPanel__image__wrapper {
  width: 50%;
  max-width: 425px;
  margin-top: var(--space-md);
  margin-right: 0;
}
@media screen and (max-width:960px) {
  .a3test .cvPanel__image__wrapper {
    width: 100%;
    max-width: 560px;
    margin-right: auto;
    margin-left: auto;
  }  
}
@media screen and (max-width:960px) {
  .a3test .cvPanel__logo__wrapper{
    margin-right: auto;
    margin-left: auto;
    width: auto;
    height: auto;
    margin-top: 10px;
  }
}
.a3test .cvPanel__logo {
  max-width: 410px;
}
@media screen and (max-width:960px) {
  .a3test .cvPanel__logo {
    max-width: 410px;
  }
}
.a3test .cvPanel__button__wrapper {
  font-size: 20px;
  margin: 0 auto;
  width: 410px;
}
@media screen and (max-width:750px) {
  .a3test .cvPanel__button__wrapper {
    width: 100%;
  }
}
.a3test .cvPanel__catch {
  font-size: 28px;
  text-align: center;
  color: var(--color-primary);
  line-height: 1.4;
}
@media screen and (max-width:960px) {
  .a3test .cvPanel__catch {
    font-size: 14px;
  }
}


/* ------ 5.PRICE ------ */
.a3test .priceTeaserSection {
  padding-top: 64px;
  padding-bottom: 64px;
}
@media screen and (max-width:960px) {
  .a3test .priceTeaserSection {
    padding-top: 32px;
    padding-bottom: 32px;
  }
}
.a3test .priceTeaserSection__text {
  font-size: 16px;
  margin-bottom: var(--space-xxl);
}
@media screen and (max-width:960px) {
  .a3test .priceTeaserSection__text {
    margin-bottom: 16px;
  }
}
.a3test .priceTeaserSection ul {
  display: flex;
  justify-content: space-between;
  gap: 32px;
}
@media screen and (max-width:960px) {
  .a3test .priceTeaserSection ul {
    flex-wrap: wrap;
    gap: 16px;
  }  
}
.a3test .priceTeaserSection ul li {
  width: 352px;
  padding: 24px;
  text-align: center;
  background-color: #fff;
  border-radius: 16px;
}
@media screen and (max-width:960px) {
  .a3test .priceTeaserSection ul li {
    width: 100%;
    padding: 16px;
  }  
}
.a3test .priceTeaserSection ul li h3 {
  font-size: 24px;
  font-weight: 600;
  height: 68px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width:960px) {
  .a3test .priceTeaserSection ul li h3 {
    font-size: 20px;
    line-height: 1.4;
    height: auto;
  }
}
.a3test .priceTeaserSection ul li img {
  margin: 16px 0;
}
@media screen and (max-width:960px) {
  .a3test .priceTeaserSection ul li img {
    max-width: 400px;
  }
}
.a3test .priceTeaserSection ul li p {
  font-size: 16px;
}


/* ------ 6.FLOW ------ */
@media screen and (max-width:960px) {
  .a3test .flow__wrapper {
    margin-top: 16px;
  }
}
.a3test .flowSection__text {
  font-size: 16px;
}


/* ------ 7.CASE ------ */
.a3test .caseSection__text {
  font-size: 16px;
}


/* ------ 8.CV_AREA(下部のみ) ------ */
.a3test .cvArea_bottom .cvArea__inner {
  background-color: #fff;
  box-shadow: 0 3px 10px rgba(85, 85, 85, .2);
  border-radius: 20px;
}


/* ------ 9.注釈 ------ */
.a3test .noteSection {
  padding-top: 0;
}
.a3test .noteSection .annotation {
  color: var(--color-text-sub);
}