@charset "UTF-8";
/* CSS Document */
:root{
  --fnt-base:kozuka-gothic-pr6n, sans-serif;
  --fnt-ud:fot-udkakugo-large-pr6n, var(--fnt-base);
  --fnt-noto:"noto-sans-cjk-jp", var(--fnt-base);
  --clr-org:#ed812f;
  --clr-lgrn:#669900;
  --clr-grn:#096c30;
  --clr-blue:#016fbb;
  --clr-gry:#666666;
  --wall-lgrn:#98cc41;
  --wall-g-gry:#669999;
  --wall-pale-grn:#d5ecde;
  --wall-pale-lgrn:#e2eccd;
  --gra-grn:linear-gradient(#135d4a,#147d3a);
  --hvr-gra-grn:linear-gradient(#147d3a,#135d4a);
}
html{
  scroll-behavior: auto;
}
body {
  width: 100%;
  font-family: var(--fnt-base);
  text-rendering: optimizeLegibility;
  -webkit-text-size-adjust: 100%;
  word-break: break-word;
  overflow-wrap: break-word;
  font-weight: 300;
  font-size: min(16px, 3.6vw);
  color: #000;
}
a.cvr {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.grecaptcha-badge { visibility: hidden; }
/*#container 
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
#container {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  width: 100%;
  min-height: 100dvh;
  overflow: hidden;
}
.fl {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
}
.fl_c {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
}
.ai_c {
  -ms-align-items: center;
  align-items: center;
}

.fnt-ud{
  font-family: var(--fnt-ud);
}

.inner{
  width: min(1190px,100%);
  padding-left: min(50px,4vw);
  padding-right: min(50px,4vw);
  margin-left: auto;
  margin-right: auto;
}
.inner.w-wid{
  width: min(1286px,100%);
}
.box-wrap{
  width: min(815px,100%);
}
/*button settings*/
.round-button{
  border-radius: 100vmax;
  height: min(70px,12vw);
}
.round-button > *{
  width: 100%;
  height: 100%;
  display: grid;
  place-content:center;
  background: var(--gra-grn);
  border-radius: 100vmax;
  cursor: pointer;
  color: #fff;
  font-weight: 600;
  font-size: min(18px,4vw);
  overflow: hidden;
  line-height: 1;
}
.head-button > *{
  padding-left: min(20px,4vw);
  padding-right: min(20px,4vw);
  font-size: clamp(0.875rem, 0.431rem + 0.93vw, 1.125rem);
  letter-spacing: .1em;
}
.round-button > *::before{
  content: "";
  width: 100%;
  height: 100%;
  background: var(--hvr-gra-grn);
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  transition:opacity .3s ease;
}
@media(hover){
  .round-button > *:hover::before{
    opacity: 1;
  }
}

/*header ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/

header{
  background: #fff;
  width: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: calc(infinity);
  transition-delay: .2s;
}
header.nav-open{
  border-bottom: 2px solid var(--clr-grn);
}
.head_inner{
  padding: min(15px,3vw) min(20px,4vw);
  display: grid;
  grid-template-columns: min(185px,25vw) auto;
  -ms-align-items: center;
  align-items: center;
}
.header-nav{
  margin-left: auto;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -ms-align-items: center;
  align-items: center;
  gap:min(25px,3vw);
}
.g-nav{
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  gap:min(20px,3vw);
  font-weight: 700;
  color: var(--clr-gry);
  font-size: clamp(0.875rem, 0.431rem + 0.93vw, 1.125rem);
}
.g-nav li a{
  letter-spacing: .1em;
}

/*humhum*/
#hum-button{
  position: absolute;
  right: 0;
  top: 0;
  aspect-ratio:1;
  height: 100%;
  background: var(--gra-grn);
  display: none;
}
#hum-button button{
  width: 50%;
  position: absolute;
  left: 50%;
  top: 50%;
  translate:-50% -50%;
  height: 3px;
  background-color: #fff;
  transition:rotate .3s ease;
}
#hum-button button::before
,#hum-button button::after{
  content: "";
  position: absolute;
  width: 100%;
  height: 3px;
  background-color: #fff;
  left: 0;
  transition:rotate .3s ease;
}
#hum-button button::before{
  top: max(-13px,-2.5vw);
}
#hum-button button::after{
  top: min(13px,2.5vw);
}
#hum-button.open button{
  rotate:45deg;
}
#hum-button.open button::before
,#hum-button.open button::after{
  rotate:90deg;
  top: 0;
}
/*l nav*/
#l-nav{
  width: 100%;
  height: 100dvh;
  overflow-y: scroll;
  position: fixed;
  z-index: 100;
  background-color: rgba(255,255,255,.85);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  visibility: hidden;
  opacity: 0;
  transition:opacity .3s ease;
}
#l-nav.is-view{
  opacity: 1;
  visibility: visible;
}
.l-nav_inner{
  min-height: 100%;
  padding-left: min(80px,5vw);
  padding-right: min(80px,5vw);
  padding-bottom: min(50px,10vw);
  display: grid;
  grid-template-columns: 1fr;
  place-content:start;
  gap:min(80px,12vw);
}
.l-nav__menu{
  padding-top: min(50px,10vw);
  font-size: min(24px,calc(100vw/15));
}
.l-nav__menu > li{
  background-image: radial-gradient(circle, #096c30 2px, transparent 2px);
  background-position: left bottom;
  background-repeat: repeat-x;
  background-size: 10px 4px;
}
.l-nav__menu > li a{
  font-family: var(--fnt-ud);
  font-weight: 600;
  padding: .5em 1.5em calc(.5em + 5px) .5em;
  display: block;
}
.l-nav__menu > li a::after{
  content: "";
  width: .75em;
  aspect-ratio:1;
  position: absolute;
  right: .5em;
  top: calc(50% + 2.5px);
  translate:0 -50%;
  background-image: url("../images/icon/arrow.svg");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
.l-nav__button {
  height: min(80px, 15vw);
}
.l-nav__button > a{
  font-size: min(24px,calc(100vw/15));
}
/*main ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
main{
  flex: 1;
}

/*hero ++++++++++++++++++++++++++++++++++++++*/
.hero-text{
  position: absolute;
  width: 100%;
  display: grid;
  place-content:center;
  top: 0;
  left: 0;
  background-color: rgba(255,255,255,.44);
  padding: min(15px,2vw) min(20px,4vw);
}
.hero-text span{
  word-break: keep-all;
  font-size: min(42px,calc(100vw/31));
  font-weight: 700;
  font-family: var(--fnt-noto);
  text-align: center;
  letter-spacing: .075em;
  text-indent: .075em;
  line-height: calc(66/42);
  -webkit-text-stroke: 6px #fff;
  text-stroke: 6px #fff;
  paint-order: stroke fill;
  -webkit-paint-order: stroke fill;
}
.hero-image{
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap:4px;
}
.hero-image li{
  min-height: 650px;
  max-height: 800px;
}
.hero-image li img{
  object-fit: cover;
  height: 100%;
  object-position: center;
}
.hero-image li .txt{
  position: absolute;
  bottom: 1em;
  left: 50%;
  translate:-50% 0;
  font-weight: 700;
   -webkit-text-stroke: 6px #fff;
  text-stroke: 6px #fff;
  paint-order: stroke fill;
  -webkit-paint-order: stroke fill;
  font-size: clamp(1.125rem, -0.653rem + 3.7vw, 2.125rem);/*18-34*/
  white-space: nowrap;
  letter-spacing: .075em;
  text-indent: .075em;
  padding-bottom: min(13px,2vw);
}
.hero-image li .txt::after{
  content: "";
  width: 100%;
  height: min(10px,1.5vw);
  background-color: var(--clr-org);
  position: absolute;
  bottom: 0;
  left: 0;  
}

/*content ++++++++++++++++++++++++++++++++++++++*/
#content{
  margin-top: min(80px,15vw);
}
.sec-title{
  font-size:clamp(1.313rem, 0.426rem + 4.43vw, 3.75rem);/*20-60*/
  font-family: var(--fnt-ud);
  font-weight: 700;
  letter-spacing: .05em;
  line-height: calc(80/60);
}
/*feature ++++++++++++++++++++*/
.feature-title{
  font-size: clamp(1.75rem, -2.25rem + 8.33vw, 4rem);/*28-64*/
  font-family: var(--fnt-ud);
  font-weight: 700;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -ms-align-items: center;
  align-items: center;
  letter-spacing: .1em;
  font-style: italic;
  gap:min(30px,2.5vw);
  padding-left: min(30px,4vw);
  padding-right: min(30px,4vw);
}
.feature-title > span{
  display: flex;
  -ms-align-items: center;
  align-items: center;
}
.feature-title span.min{
  font-size: .77em;
}
.feature-title .udl{
  padding-top: min(15px,3vw);
  padding-bottom: min(15px,3vw);
}
.feature-title .udl::before{
  content: "";
  width: 100%;
  height: min(12px,2vw);
  background-color: var(--line-clr);
  position: absolute;
  bottom: 0;
  left: 0;
}
.feature-title .l-grn{
  --line-clr:var(--clr-grn);
}
.feature-title .l-lgrn{
  --line-clr:var(--clr-lgrn);
}
.feature-title .l-org{
  --line-clr:var(--clr-org);
}
.box-feature_intro{
  display: grid;
  grid-template-columns: auto 65%;
  margin-top: min(50px,12vw);
  -ms-align-items: center;
  align-items: center;
  gap:min(50px,4vw) min(50px,6vw);
  padding-bottom: calc((100vw * 0.09) + min(80px,8vw));
}
.box-feature_intro .detail-area{
  font-weight: 700;
  font-size: min(24px,4vw);
  display: grid;
  gap:min(35px,5vw);
}
.feature-list{
  display: grid;
  grid-template-columns: auto 1fr;
  gap:min(25px,4vw);
}
.feature-list.pros{
  --bdr-clr:var(--clr-grn);
}
.feature-list.trust{
  --bdr-clr:var(--clr-lgrn);
}
.feature-list dt{
  display: grid;
  place-content:center;
  padding-right: min(25px,6vw);
  padding-top: 1em;
  padding-bottom: 1em;
}
.feature-list dt::before{
  content: "";
  width: min(10px,1.5vw);
  height: 100%;
  position: absolute;
  top: 0;
  right: 0;
  background-color: var(--bdr-clr);
}
.feature-list dt h3{
  writing-mode: vertical-rl;
  font-size: 1.6em;
  font-style: italic;
  letter-spacing: .2em;
}
.feature-list dd{
  line-height: calc(34/24);
  display: grid;
  -ms-align-items: center;
  align-items: center;
  padding-top: 1em;
  padding-bottom: 1em;
}
ul.num-list{
  counter-reset: count;
}
ul.num-list > li{
  padding-left: 1.25em;
}
ul.num-list > li:nth-child(n+2){
  margin-top: min(10px,2vw);
}
ul.num-list > li::before{
  counter-increment: count 1;
  content: counter(count)'.';
  position: absolute;
  left: 0;
  top: 0;
}

.box-feature_pros{
  --title-clr:var(--clr-grn);
  background-color: var(--wall-pale-grn);
  padding-top: min(50px,10vw);
}
.box-feature_pros::before{
  content: "";
  width: 100%;
  aspect-ratio:1/0.09;
  position: absolute;
  top: 1px;
  left: 0;
  translate:0 -100%;
  background-image: url("../images/wall.svg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.box-feature_trust{
  --title-clr:var(--clr-lgrn);
}

.feature-item_intro{
  padding-bottom: min(50px,12vw);
}
.intro-title{
  display: grid;
  grid-template-columns: min(160px,20vw) auto;
  font-family: var(--fnt-ud); 
  gap:min(35px,5vw);
}
.intro-title .num{
  font-size: min(48px,calc(100vw/20));
  text-align: center;
  font-style: italic;
  font-weight: 700;
  display: grid;
  place-content:center;
  line-height: calc(50/40);
  padding-right: min(10px, 2vw);
}
.intro-title .num::before{
  content: "";
  width: min(10px, 1.5vw);
  height: 100%;
  position: absolute;
  top: 0;
  right: 0;
  background-color: var(--title-clr);
}
.intro-title h3{
  font-size: min(40px,calc(100vw/19));
  letter-spacing: .05em;
  color: var(--title-clr);
  line-height: calc(60/40);
  font-weight: 600;
  display: grid;
  -ms-align-items: center;
  align-items: center;
}
.intro-title h3.fs-min{
  font-size: min(40px,calc(100vw/21));
}
.feature-item_intro .detail{
  margin-top: min(35px,6vw);
  gap:min(35px,6vw);
}
.feature-item_intro .detail .fkds{
  width: 100%;
}
.feature-item_intro .detail .fkds p{
  background-color: #fff;
  border-radius: 100vmax;
  font-size: min(24px,3.7vw);
  text-align: center;
  letter-spacing: .1em;
  text-indent: .1em;
  line-height: calc(48/24);
  padding: 1em 2em;
}
.feature-item_intro .detail .fkds p::after{
  content: "";
  aspect-ratio:1/0.5397;
  width: min(63px,10vw);
  background-color: #fff;
  clip-path: polygon(30% 0, 0% 100%, 100% 0);
  position: absolute;
  bottom: 2px;
  right: min(100px,18vw);
  translate:0 100%;
}
.feature-item_intro .detail .thumb{
  width: min(400px,60%);
}
.feature-item_intro .detail .thumb.w-wid{
  width: 100%;
}
ul.dot-list > li{
  padding-left: 1em;
}
ul.dot-list > li:nth-child(n+2){
  margin-top: .25em;
}
ul.dot-list > li::before{
  content: "・";
  position: absolute;
  left: 0;
  top: 0;
}
.feature-item_intro .detail .dot-list{
  font-size: min(24px,3.6vw);
  font-family: var(--fnt-ud);
  font-weight: 600;
  width: 100%;
}
.feature-item_intro .detail .dot-list >li{
  line-height: calc(40/24);
}
.feature-item_detail{
  padding-top: min(75px,8vw);
  padding-bottom: min(75px,8vw);
}
.feature-item_detail::before{
  content: "";
  width: 100vw;
  height: 100%;
  background-color: #fff;
  position: absolute;
  left: 50%;
  top: 0;
  translate:-50% 0;
}
.prop-thumb-list > li{
  line-height: calc(34/24);
  font-size: min(24px,3.6vw);
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  gap:min(20px,3vw);
}
.prop-thumb-list > li .list-title{
  text-align: center;
}
.prop-thumb-list > li:nth-child(n+2){
  margin-top: min(50px,10vw);
}
.prop-thumb-list .thumb-item{
  display: grid;
  gap:min(20px,3vw) min(30px,4vw);
}
.prop-thumb-list .thumb-item .att{
  margin-left: auto;
  font-size: min(14px,2.8vw);
  margin-top: max(-5px, -1vw);
}
.prop-thumb-list .thumb-item.clm2{
  grid-template-columns: repeat(2,1fr);
}
.prop-thumb-list .thumb-item.clm3{
  grid-template-columns: repeat(3,1fr);
  font-size: min(20px,3.6vw);
}
.prop-thumb-list .thumb-item figure{
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  -webkit-flex-direction: column;
  -moz-flex-direction: column;
  -ms-flex-direction: column;
  -o-flex-direction: column;
  flex-direction: column;
  -ms-align-items: center;
  align-items: center;
  gap:min(10px,2vw);
}
.prop-thumb-list .thumb-item figcaption{
  letter-spacing: .1em;
  text-indent: .1em;
}
.prop-thumb-list .thumb-item figcaption span{
  font-size: min(15px,3vw);
  display: block;
  text-align: left;
  letter-spacing: normal;
}
.prop-thumb-list .thumb-item.clm2 figcaption{
  width: min(21em,100%);
}
.prop-thumb-list .thumb-item.clm3 figcaption{
  text-align: center;
}
/*media*/
.prop-media-list{
  font-family: var(--fnt-ud);
  font-size: min(20px,3.6vw);
  font-weight: 600;
  gap:min(50px,10vw);
  margin-top: min(70px,12vw);
  display: grid;
  place-content:center;
}
.prop-media-list h4{
/*  font-size: min(36px,5vw);*/
  font-size: min(36px,calc(100vw/22));
  line-height: calc(40/36);
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: flex-start;
  letter-spacing: .1em;
}
.prop-media-list h4 span{
  border-bottom: 2px solid;
  padding-bottom: 5px;
}
.media-list{
  -ms-align-items: flex-start;
  align-items: flex-start;
  gap:min(10px,2vw);
}
.media-list > li {
  
  font-weight: 700;
}
.media-list > li.link{
  padding-right: 1.5em;
}
.media-list > li a
,.media-list > li p{
  display: grid;
  grid-template-columns: auto auto;
  gap:min(10px,2vw) 2em;
  line-height: calc(24/20);
  background-image: radial-gradient(circle, #096c30 2px, transparent 2px);
  background-position: left bottom;
  background-repeat: repeat-x;
  background-size: 10px 4px;
  padding-bottom: 10px;
  padding-top: 10px;
}
.media-list > li a::after{
  content: "";
  width: 1em;
  aspect-ratio:1;
  background-image: url("../images/icon/arrow.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  position: absolute;
  right: -.5em;
  top: 50%;
  translate:100% -50%;
  transition:translate var(--transit);
}
.media-list > li a span:nth-child(2)
,.media-list > li p span:nth-child(2){
  padding-left: .75em;
}
.media-list > li a span:nth-child(2)::before
,.media-list > li p span:nth-child(2)::before{
  content: "-";
  position: absolute;
  left: 0;
  top: 0;
}
@media(hover){
  .media-list > li a:hover::after{
    translate:120% -70%;
  }
}
.props02{
  padding-top: min(80px,12vw);
}
.prop03{
  padding-top: min(50px, 6vw);
}

/*trust*/
.box-feature_trust{
  padding-top: min(100px,15vw);
  background-image: url("../images/wall_lgrn.svg"),linear-gradient(rgba(226,236,205,0) calc((100vw*0.09) - 1px),rgba(226,236,205,1) calc((100vw*0.09) - 1px));
  background-repeat: no-repeat;
  background-position: top center;
  background-size: 100%;
  display: grid;
  grid-template-columns:min(850px,100%);
  justify-content: center;
  padding-left: min(50px,4vw);
  padding-right: min(50px,4vw);
}
.box-feature_trust .dot-list{
  display: grid;
  grid-template-columns: min(812px,100%);
  justify-content: center;
}

/*比較*/
.sec-hikaku-blc{
  padding-top: min(120px,15vw);
  padding-bottom: min(110px,15vw);
  gap:min(100px, 12vw);
}
.lead-fkds{
  display: grid;
  place-content:center;
}
.lead-fkds p{
  display: grid;
  justify-content: center;
  -ms-align-items: center;
  align-items: center;
  font-size: min(24px,4.5vw);
  gap:.5em;
  
  border-radius: 100vmax;
  background-color: #fff;
  letter-spacing: .1em;
  text-indent: .1em;
  line-height: calc(30 / 24);
  padding: 1em 2em;
}
.lead-fkds p.line{
  border: 1px solid #cccccc;
}
.lead-fkds.logo p{
  grid-template-columns: min(200px,30vw) auto;
}
.lead-fkds p.line::before
,.lead-fkds p::after{
  content: "";
  aspect-ratio: 1 / 0.5397;
  clip-path: polygon(30% 0, 0% 100%, 100% 0);
  position: absolute;
}
.lead-fkds p.line::before{
  background-color: #cccc;
  translate: -1px 100%;
  bottom: 0;
  right: min(100px, 18vw);
  width: min(65px, calc(10vw + 2px));
}
.lead-fkds p::after{
  width: min(63px, 10vw);
  background-color: #fff;
  bottom: 2px;
  right: min(100px, 18vw);
  translate: 0 100%;
}
.hikaku-lst-wrap{
  width: 100%;
  overflow-y: scroll;
  padding-bottom: 10px;
}
.hikaku-list{
  display: grid;
  grid-template-columns: 10em 1fr 1fr;
  white-space: nowrap;
  font-size: min(24px,4vw);
}
.hikaku-list > li{
  padding: min(20px,3vw) min(15px,2vw) 0;
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 7;
  border-right: 2px solid #ccc;
  border-top: 2px solid #ccc;
  border-bottom: 2px solid #ccc;
}
.hikaku-list > li:nth-child(2){
  background-color: #c0e08b;
}
.hikaku-list > li:first-child{
  border-left: 2px solid #ccc;
}
.hikaku-list > li p{
  padding-top: .75em;
  padding-bottom: .75em;
}
.hikaku-list > li p:not(:last-child){
  border-bottom: 2px solid;
  border-color: #ccc;
}
.hikaku-list .in-title{
  font-size: min(30px,4.5vw);
  height: 2.2em;
  border-radius: 100vmax;
  display: grid;
  place-content:center;
  background-color: var(--ttl-clr);
  color: #fff;
  font-weight: 700;
  line-height: 1;
}
.hikaku-list .in-title span{
  translate:0 .1em;
}
.hikaku-list .in-title.org{
  --ttl-clr:var(--clr-org);
}
.hikaku-list .in-title.grn{
  --ttl-clr:var(--clr-grn);
}
.hikaku-list .in-title.blue{
  --ttl-clr:var(--clr-blue);
}

/*howto*/
.sec-howto-blc{
  background-color: var(--clr-grn);
  color: #fff;
  padding-top: min(100px,15vw);
  padding-bottom: min(100px,15vw);
}
.sec-howto-box{
  gap:min(60px,8vw);
}
.sec-title.howto {
  display: grid;
  grid-template-columns: 1em auto;
  -ms-align-items: center;
  align-items: center;
  gap:.25em;
}
.sec-howto-blc .lead-fkds{
  color: #000;
}
.step-list{
  font-size: min(20px,3.6vw);
  font-family: var(--fnt-ud);
}
.step-list > li{
  display: grid;
  grid-template-columns: min(8em,18vw) auto;
  font-weight: 500;
 -ms-align-items: center;
 align-items: center;
  gap:min(35px,2.5vw);
}
.step-list > li:nth-child(n+2){
  margin-top: min(30px,8vw);
}
.step-list > li:nth-child(n+2)::before{
  content: "";
  width: 4px;
  height: 100%;
  position: absolute;
  background-color: #fff;
  top: 0;
  left: min(4em,9vw);
  translate:0 -100%;
}
.step-list > li .num {
  display: grid;
  place-content:center;
  z-index: 1;
}
.step-list > li .num > p{
  width: 100%;
  aspect-ratio:1;
  display: grid;
  place-items:center;
  place-contents:center;
  font-size: min(30px,3.6vw);
  font-weight: 700;
  background-image: url("../images/icon/cycle-line.png");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  padding: .95em .85em .8em;
  background-color: var(--clr-grn);
}
.step-list > li .num > p span{
  font-size: min(2em,10vw);
}
.step-list > li .comment-area{
  line-height: calc(38/20);
  letter-spacing: .1em;
}
.step-list > li .comment-area .list-title{
  font-size: min(30px,4.5vw);
  font-weight: 600;
}

/*サポート*/
.sec-support-blc{
  padding-top: min(100px,15vw);
  padding-bottom: min(100px,15vw);
}
.support-title{
  width: min(880px,100%);
}
.support-contents{
  display: grid;
  grid-template-columns: 1fr 1fr;
  -ms-align-items: flex-start;
  align-items: flex-start;
  gap:min(60px,5vw) min(60px,5vw);
  margin-top: min(80px,10vw);
  counter-reset: count 0;
}
.support-item{
  display: grid;
  grid-template-columns: min(170px,20vw) auto;
  font-size: min(20px,3.6vw);
  -ms-align-items: center;
  align-items: center;
  font-weight: 500;
  font-family: var(--fnt-ud);
  gap:min(20px,5vw) min(20px,4vw);
}
.support-item .in-title{
  font-weight: 700;
  padding-left: 1.5em;
  font-size: min(25px,4.5vw);
  line-height: calc(33/28);
  letter-spacing: .025em;
  text-indent: .025em;
}
.support-item:nth-child(n+10) .in-title{
  padding-left: 2.5em;
}
.support-item .in-title::before{
  counter-increment: count 1;
  content: counter(count);
  position: absolute;
  left: 0;
  bottom: 0;
  font-size: min(35px,6vw);
  color: var(--clr-grn);
  line-height: 1;
}
.support-item .in-text{
  line-height: calc(30/20);
  margin-top: 1em;
}
.support-item .in-text span.att{
  font-size: min(14px,3vw);
  line-height: calc(24/14);
  display: block;
  margin-top: 1em;
}

/*voice*/
.sec-voice-blc{
  background-color: var(--wall-g-gry);
  padding-top: min(100px,15vw);
  padding-bottom: min(100px,15vw);
}
.sec-title.voice{
  color: #fff;
  display: grid;
  grid-template-columns: 1em auto;
  -ms-align-items: center;
  align-items: center;
  gap:.35em;
}
.voice-list{
  margin-top: min(30px,6vw);
}
.voice-items:nth-child(n+2){
  margin-top: min(50px,8vw);
}
.voice-items{
  display: grid;
/*  font-size: min(24px,3.6vw);*/
  font-size: clamp(0.8rem, 0.458rem + 1.39vw, 1.5rem);
  gap:10px min(40px,5vw);
}
.voice-items:nth-child(odd){
   grid-template-columns: min(240px,22vw) auto;
}
.voice-items:nth-child(even){
   grid-template-columns: auto min(240px,22vw);
}
.voice-items .thumb{
  display: grid;
  grid-template-columns: min(180px,100%);
  place-content:center;
}
.voice-fkds{
  align-content: center;
  grid-row: span 2;
}
.voice-items .data{
  text-align: center;
  word-break: keep-all;
  line-height: calc(30/24);
}
.voice-fkds p{
  background: #fff;
  border-radius: min(75px,10vw);
  padding: min(50px,5vw) min(60px,4vw);
  line-height: calc(50/24);
  letter-spacing: .05em;
}
.voice-fkds p::before{
  content: "";
  position: absolute;
  top: 4em;
  aspect-ratio:1/.82;
  width: min(60px,5vw);
  background-color: #fff;
}
.voice-items:nth-child(odd) .voice-fkds p::before{
  clip-path: polygon(100% 0, 0 0, 100% 100%);
  left: 1px;
  translate:-100% 0;
}
.voice-items:nth-child(even) .voice-fkds p::before{
  clip-path: polygon(100% 0, 0 0, 0 100%);
  right: 1px;
  translate:100% 0;
}
.voice-items:nth-child(even) .data{
  grid-area: 2/2;
}

/*inquiey*/
.sec-inquiry-blc{
  padding-top: min(100px,15vw);
  padding-bottom: min(80px,10vw);
  font-size: clamp(1rem, 0.667rem + 1.11vw, 1.5rem);/*16-24*/
  gap:min(80px,8vw);
}
.sec-title.inquiry{
  display: grid;
  grid-template-columns: 1em auto;
  gap:.25em;
  -ms-align-items: center;
  align-items: center;
  justify-content: center;
}
.sec-inquiry_intro .lead-text{
  line-height: calc(40/24);
  margin-top: 1em;
}
.sec-inquiry_form{
  
}
/*form setting*/
.form-list{
  width: min(555px,100%);
  margin-left: auto;
  margin-right: auto;
}
.form-list input[type="text"]
,.form-list input[type="email"]
,.form-list input[type="tel"]{
  width: 100%;
  height: 2.8em;
  border-radius: 10px;
  border: 3px solid #ccc;
  padding-left:1em;
  padding-right: 1em;
  font-size: clamp(1rem, 0.917rem + 0.28vw, 1.125rem); 
}
.select-wrap{
  width: 100%;
  height: 2.8em;
  border: 3px solid #ccc;
  border-radius: 10px;
  font-size: clamp(1rem, 0.917rem + 0.28vw, 1.125rem); 
}
.select-wrap::after{
  content: "";
  width: .5em;
  aspect-ratio:1;
  border: 3px solid;
  border-color: transparent #ccc #ccc  transparent;
  position: absolute;
  right: 0;
  top: 50%;
  translate:-100% -75%;
  border-radius: 3px;
  rotate:45deg;
}
.select-wrap select{
  height: 100%;
  width: 100%;
  font-size:1em;
  padding-left:1em;
  padding-right: 1em;
  color: #000;
}
.form-list textarea{
  border-radius: 10px;
  border: 3px solid #ccc;
  padding: .25em .5em;
  width: 100%;
  height: min(280px,35vw);
  font-size: clamp(1rem, 0.917rem + 0.28vw, 1.125rem);
}
.form-items:nth-child(n+2){
  margin-top: min(30px,5vw);
}
.form-items dt{
  letter-spacing: .1em;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: flex-start;
}
.form-items dt p.must{
  padding-right: 1.25em;
}
.form-items dt p.must::after{
  content: "※";
  position: absolute;
  right: 0;
  top: 0;
}
.form-items dd{
  margin-top: 10px;
}
.error-msg{
  color: #d00;
  font-size: min(12px,3vw);
  letter-spacing: .025em;
  margin-top: 4px;
  display: none;
}
.form-button-wrap{
  margin-top: min(65px,10vw);
  gap:min(30px,6vw);
}
.agree-check{
  font-size: min(16px,3.2vw);
}
.agree-check a{
  color: var(--clr-grn);
  text-decoration: underline;
}
.check-wrap{
  cursor: pointer;
}
.check-wrap > span{
  padding-left: 1.5em;
  display: block;
}
.check-wrap > span::before
,.check-wrap > span::after{
  content: "";
  width: calc(1em + 6px);
  aspect-ratio:1;
  position: absolute;
  left: 0;
  top: 50%;
  translate:0 -50%;
  box-sizing: border-box;
}
.check-wrap > span::before{
  border:2px solid #ccc;
  border-radius: 3px;
}
.check-wrap > span::after{
  background-image: url("../images/icon/check.svg");
  background-repeat: no-repeat;
  background-size: 70%;
  background-position: center;
  opacity: 0;
}
.check-wrap > input:checked + span::after{
  opacity: 1;
}
.submit-button{
  width: min(450px,100%);
  margin-right: auto;
  margin-left: auto;
  overflow: hidden;
  border-radius: 100vmax;
  background: var(--gra-grn);
  height: 3em;
  font-size: clamp(1rem, 0.667rem + 1.11vw, 1.5rem);
  color: #fff;
  font-family: var(--fnt-ud);
  font-weight: 700;
  letter-spacing: .05em;
  position: relative;
}
.submit-button::before{
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background:var(--hvr-gra-grn);
  opacity: 0;
  transition:opacity .3s ease;
  pointer-events: none;
}
.form-button-set{
  width: 100%;
  gap: min(20px, 4vw);
}
@media(hover){
  .submit-button:hover::before{
    opacity: 1;
  }
}
.form-wrap .lead-text{
  font-size: min(20px,3.8vw);
  display: grid;
  justify-content: center;
  line-height: calc(30/20);
}
#conf-form{
  display: none;
}
#conf-form .form-list{
  margin-top: min(50px, 6vw);
}
#conf-form .form-list dd p{
  background-color: #f1f1f1;
  min-height: 2.8em;
  padding-left: 1em;
  padding-right: 1em;
  font-size: clamp(1rem, 0.917rem + 0.28vw, 1.125rem);
  display: grid;
  -ms-align-items: center;
  align-items: center;
  border-radius: 10px;
}
#conf-form .form-list dd #conf-cmnt{
  line-height: 1.4;
  padding-top: .5em;
  padding-bottom: .5em;
}
.back-button{
  width: auto;
  margin-right: auto;
  padding-left: 1.25em;
  position: relative;
  font-size: min(16px,3.6vw);
}
.back-button::before
,.back-button::after{
  content: "";
  width: .4em;
  aspect-ratio:1;
  border: 1.5px solid;
  border-color: var(--clr-grn) transparent transparent var(--clr-grn);
  position: absolute;
  left: 0;
  top: 50%;
  rotate:-45deg;
  translate:0 -50%;
}
.back-button::before{
  translate:0 -50%;
}
.back-button::after{
  translate:50% -50%;
}
#conf-button:disabled{
  opacity: .65;
  cursor: not-allowed;
}
#conf-button:disabled:hover:before{
  content: none;
}

.rep-text{
  font-size: min(14px, 3.2vw);
  line-height: calc(24/16);
}
.rep-text a{
  color: var(--clr-grn);
  text-decoration: underline;
}

/*footer ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
footer{
  padding-bottom: min(20px,5vw);
  font-family: var(--fnt-ud);
}
.footer-inner{
  display: grid;
  grid-template-columns: min(950px,100%);
  justify-content: center;
  gap:min(20px,5vw);
}
.footer-nav{
  padding-top: min(50px,10vw);
  padding-bottom: min(30px,5vw);
  display: grid;
  grid-template-columns: min(200px,30vw) auto;
  justify-content: space-between;
  -ms-align-items: center;
  align-items: center;
}
.foot-link{
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  gap:10px 2em;
}

p.copy{
  font-size: min(12px,3.2vw);
  text-align: center;
  letter-spacing: .1em;
  text-indent: .1em;
}

/*under ++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
#hero.under{
  padding-top: min(80px,12vw);
}
#content.under-contents{
/*
  margin-top: 0;
  padding-top: min(50px,12vw);
*/
}
.page-thanks-blc{
  display: grid;
  grid-template-columns: min(780px,100%);
  justify-content: center;
}
.page-thanks-box{
  display: grid;
  place-content:center;
  place-items:center;
  border: 3px solid #ccc;
  border-radius: 10px;
  padding: min(50px,5vw) min(50px,4vw);
  gap:min(60px,8vw);
}
.page-thanks-box .in-text{
  line-height: calc(30/16);
  letter-spacing: .05em;
}
.page-thanks-box .round-button{
  width: min(300px,100%);
}
/*responsive ++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/

@media(max-width:1070px){
  .feature-list dd .num-list > li .pcView{
    display: none!important;
  }
}
@media(max-width:900px){
  .head_inner{
    height: min(70px,16vw);
    padding-top: 0;
    padding-bottom: 0;
  }
  .header-nav{
    display: none;
  }
  #hum-button{
    display: block;
  }
  
}
@media(max-width:768px){
  .hero-image{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap:min(160px,calc(100vw/4.25)) 4px;
  }
  .hero-image li{
    min-height: auto;
    max-height: none;
    aspect-ratio:1/1.35;
    overflow: hidden;
    align-content: flex-end;
  }

  .hero-image li img{
    object-fit: cover;
    height: 100%;
    object-position: center;
  }
  .hero-image li:nth-child(-n + 2) img {
    object-position: top;
  }
  .hero-image li .txt{
    font-size: min(24px,calc(100vw/20));
  }
  .hero-image li:nth-child(-n + 2) .txt{
    bottom: auto;
    top: 1em;
  }
  .hero-text{
    top: 50%;
    translate:0 -50%;
    padding-top: 0;
    padding-bottom: 0;
    height: min(160px,calc(100vw/4.25));
  }
  .hero-text span{
    font-size: min(42px, calc(100vw / 16));
  }
  
  /*feature*/
  .feature-title{
    font-size: min(50px,calc(100vw/14));
  }
  .box-feature_intro{
    grid-template-columns: auto;
  }
  .box-feature_intro .thumb-area{
    position: absolute;
    bottom: 0;
    right: 0;
    translate:0 10%;
    width: 35%;
    z-index: -1; 
  }
  .prop-thumb-list .thumb-item.clm2{
    grid-template-columns: 1fr;
  }
  .prop-thumb-list .thumb-item.clm3{
    grid-template-columns: repeat(2, 1fr);
  }
  .prop-thumb-list .thumb-item.clm3 > figure:last-child{
    grid-column: span 2;
    grid-template-columns: 50vw;
    display: grid;
    place-content: center;
  }
  
  /*support*/
  .support-contents{
    grid-template-columns: 1fr;
  }
}
@media(max-width:480px){
  .box-feature_intro{
    padding-bottom: min(200px,25vw);
  }
  .feature-list dt h3{
    font-size: min(1.6em,6vw);
  }
  .media-list > li{

    width: 100%;
  }
  .media-list > li.link{
    padding-right: 0;
  }
  .media-list > li a
  ,.media-list > li p{
    grid-template-columns: 1fr;
    padding-right: 1.5em;
  }
  .media-list > li a::after{
    right: 0;
    translate: 0 -50%;
  }
  .step-list > li{
    -ms-align-items: flex-start;
    align-items: flex-start;
  }
  
  .footer-nav{
    grid-template-columns: auto;
    place-items:center;
    gap:min(30px,5vw);
  }
  .foot-logo{
    width: 45%;
  }
}