@charset "UTF-8";

:root {
  --color-white: #FFFFFF;
  --color-black: #3E3A39;
  --color-666666: #666666;
  --color-8a8a8a: #8a8a8a;
  --color-cdcdcd: #cdcdcd;
  --color-ebebeb: #ebebeb;
  --color-e1e1e2: #e1e1e2;
  --color-ececec: #ececec;
  --color-f3f3f3: #f3f3f3;
  --color-f6f6f6: #f6f6f6;
  --color-2b4cdb: #2b4cdb;
  --color-00B9EF: #00B9EF;
  --color-00AB5A: #00AB5A;
  --color-007320: #007320;
  --color-FDD000: #FDD000;
  --color-FFE901: #FFE901;
  --color-E8380D: #E8380D;
  --color-b89023: #b89023;
  --color-6b82e6: #6b82e6;
  --color-6878c1: #6878c1;
  --color-DDF3FA: #DDF3FA;
  --color-EAEDFB: #EAEDFB;
  --color-main: #FDD000;
  --color-main-light: #fcf9ed;
  --color-main-sub: #c5b054;
  --font10: 0.625rem;
  --font12: 0.75rem;
  --font13: 0.8125rem;
  --font14: 0.875rem;
  --font15: 0.9375rem;
  --font16: 1rem;
  --font17: 1.0625rem;
  --font18: 1.125rem;
  --font20: 1.25rem;
  --font21: 1.3125rem;
  --font24: 1.5rem;
  --font26: 1.625rem;
  --font28: 1.75rem;
  --font30: 1.875rem;
  --font32: 2rem;
  --font35: 2.1875rem;
  --font38: 2.1875rem;
  --font40: 2.5rem;
  --font43: 2.6875rem;
  --font45: 2.8125rem;
  --font50: 50px;
  --font60: 60px;
  --font70: 70px;
  --font80: 80px;
  --font90: 90px;

  --font-weight-bold: 700;
  --font-weight-normal: normal;
  --shape-triangle-top: polygon(50% 0, 100% 100%, 0 100%);
  --shape-triangle-right: polygon(0 0, 100% 50%, 0 100%);
  --shadow: 0 0.3rem 2.5rem -2rem rgba(85, 96, 96, 0.3), 0 0.3rem 0.5rem rgba(84, 96, 96, 0.376);
  --shadow2: 0 0.2rem 2rem -1rem rgba(85, 96, 96, 0.4), 0 0.2rem 0.3rem rgba(84, 96, 96, 0.4);
  --list-border: 1px solid var(--color-cfcfcf);
  --number-width: clamp(136px, 33.8vw, 180px);
  --stretch: stretch;
}

/*-- お問い合わせ内容
-----------------------------*/
.inquiry-wrapper{
  --inquiry-b-line: clamp(5px, 0.8vw, 8px);
  --inquiry-title: clamp(var(--font20), calc((0.0625rem * 20) + ((1vw - 3.8px) * (8 / 9.2))), var(--font28));
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(clamp(340px, 57vw / 1.3, 530px), 1fr));
  gap: clamp(2rem, 10vw / 1.3, 100px) 5.5%;
}
/*法人・個人*/
.inquiry-card{
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 3;
  gap: clamp(1rem, 3.2vw / 1.3,2rem);
}
.inquiry-card__header{
  display: grid;
  place-content: center;
  gap: 1rem;
  width: 100%;
  font-weight:  var(--font-weight-bold);
  margin-bottom: var(--inquiry-title);
  &::before{
    bottom: 0;
    left: 50%;
    transform: translate(-50%, 95%);
    --size: var(--inquiry-title);
  }
}
.inquiry-card__title{
  color: var(--color-white);
  font-size: var(--inquiry-title);
  padding-block: 1.5em 1em;
  span{
    color: var(--color-main);
  }
}
.inquiry-feature{
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(100% - 4px, 24em);
  background: var(--color-white);
  border: 2px solid;
  border-radius: 2em;
  text-align: center;
  white-space: nowrap;
  padding-block: 0.25em 0.3em;
}
.inquiry-text-box{
  display: grid;
  justify-items: center;
  align-content: center;
  height: 100%;
}
.inquiry-text{
  width: min(100%, 500px);
  margin-bottom: 0.8em;
  span{
    display: inline;
    font-weight: var(--font-weight-bold);
  }
  a{
    background: var(--color-main);
    border-radius: 1.2em;
    margin-left: 0.5em;
    padding-inline: 1em 1.5em;
    padding-top: 0.05em;
  }
}
.inquiry-contact-methods{
  container-type: inline-size;
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 2px;
}
.inquiry-method{
  display: grid;
  justify-items: center;
  grid-template-rows: auto 1fr;
  gap: 1em;
  background: var(--color-f3f3f3);
  padding-block: clamp(15px, 2vw / 1.3, 20px) clamp(25px, 3.5vw / 1.3, 35px);
}
.inquiry-method__title{
  font-size: clamp(var(--font17), 1.32cqi + 12.92px, var(--font21));
}
.inquiry-method__content{
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 0.5rem;
  width: min(100% - 4vw, 600px);
  background: var(--color-white);
  padding-block: 1rem;
}
.inquiry-method--form div > *{
  width: max(290px - 2em, 70%);
}
.c-button-link{
  display: grid;
  font-weight: var(--font-weight-bold);
  font-size: clamp(var(--font17), 1.645cqi + 10.9px, var(--font21));
  padding: .5em 1.5em .5em .5em;
}
.c-button-link__label{
  font-size: clamp(var(--font13), 1.974cqi + 5.882px, var(--font17));
  margin-bottom: 0.3em;
}
.inquiry-method__note, .inquiry-hours dt, .inquiry-hours dd{
  font-size: clamp(var(--font13), 0.987cqi + 9.941px, var(--font16));
}
.inquiry-tel span{
  font-size: clamp(18px, 0.987cqi + 14.941px, 21px);
}
.inquiry-tel__link{
  font-weight: var(--font-weight-bold);
  font-size: clamp(21px, 2.303cqi + 13.862px, 28px);
  margin-left: 0.3em;
}
.inquiry-hours{
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.5em;
  dt, dd{
    line-height: 1;
  }
}
.inquiry-hours__title{
  justify-self: end;
  border-left: 1px solid;
  border-right: 1px solid;
  padding-inline: 0.4em;
}
/*法人*/
.inquiry-card--business{
  border-bottom: var(--inquiry-b-line) solid;
  .inquiry-card__header{
    background: var(--color-black);
    &::before{
      background: var(--color-black);
    }
  }
  .btn--contact{
    border: 2px solid var(--color-black);
  }
}
/*個人*/
.inquiry-card--personal{
  border-bottom: var(--inquiry-b-line) solid var(--color-6878c1);
  .inquiry-card__header{
    background: var(--color-6b82e6);
    &::before{
      background: var(--color-6b82e6);
    }
  }
  h3, p, .inquiry-tel__link{
    color: var(--color-6878c1);
  }
  .c-button-link{
    &::after{
      right: 1em;
    }
    &:hover{
      background: var(--color-6878c1);
      &::after{
        right: 0.3em;
      }
    }
  }
}
/*取材・プレス関連*/
.inquiry-press{
  grid-column: 1 / -1;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: clamp(1rem, 3.2vw / 1.3,2rem) 5%;
  border-top: 2px solid;
  border-bottom: 2px solid;
  padding-block: clamp(1.5rem, 4.8vw / 1.3, 3rem);
}
.inquiry-press__title{
  font-size: var(--inquiry-title);
  margin-bottom: 0.5em;
  >div{
    width: clamp(310px, 40vw / 1.3, 400px);
  }
}

/*フォーム
-----------------------------*/
.page-header__description p{
  margin-bottom: .5em;
}
.req{
  background: var(--color-main);
  border-radius: .1em;
  font-size: 85%;
  padding: 0.2em 0.5em;
}
.form-item{
  display: grid;
  font-size: clamp(var(--font16), calc((0.0625rem * 16) + ((1vw - 3.8px) * (2 / 9.2))), var(--font18));
  gap: clamp(.5rem, 1.6vw / 1.3,1rem);
  border-bottom: 1px solid var(--color-666666);
  padding-block: 2em;
  dt{
    font-weight: var(--font-weight-bold);
    span{
      margin-left: 1em;
    }
  }
}
.c-form{
  border-top: 1px solid;
}
.c-form-item{
  grid-template-columns: 19em 1fr;
  dd{
    font-size: clamp(var(--font14), calc((0.0625rem * 14) + ((1vw - 3.8px) * (6 / 9.2))), var(--font20));
  }
}
.form_box, .error-message, .modal {
  display: none;
}
.form_box.open, :is(.error-message, .modal).show{
  display: grid;
}
::placeholder{
  color: var(--color-cdcdcd);
}
:where(input[type="checkbox"], input[type="radio"]) + span::before, :where(input[type="checkbox"], input[type="radio"]) + span::after {
  content: "";
  position: absolute;
}
:where(input[type="text"], input[type="email"], input[type="tel"], textarea), :where(input[type="checkbox"], input[type="radio"]) + span::before {
  background: var(--color-white);
  border: 1px solid var(--color-cdcdcd);
  border-radius: 6px;
  box-sizing: border-box;
}
.c-form :where(input[type="text"], input[type="email"], input[type="tel"], .c-form textarea), .c-form :where(input[type="checkbox"], input[type="radio"]) + span::before {
  background: var(--color-f3f3f3);
}
:where(input[type="text"], input[type="email"], input[type="tel"], textarea) {
  width: 100%;
  padding: 10px 20px;
  outline: 0;
  transition: .3s;
}
input[type="checkbox"], input[type="radio"] {
  visibility: hidden;
  width: 1px;
}
:where(input[type="text"], input[type="email"], input[type="tel"], textarea):focus {
  background: var(--color-main-light);
  border: 1px solid var(--color-main);
}
.biz-radio{
  display: flex;
  flex-wrap: wrap;
  gap: 1em;
}
input[type="radio"] + span {
  position: relative;
  padding: 6px 0 6px 33px;
  &::before, &::after{
    top: 50%;
    transform: translateY(-50%);
    border-radius: 50%;
    aspect-ratio: 1;
    transition: .3s;
  }
  &::before{
    left: 0;
    width: 26px;
  }
  &::after{
    left: 6px;
    width: 14px;
    background: var(--color-main);
    opacity: 0;
  }
}
input[type="radio"]:checked + span::before {
  background: var(--color-white);
  border: 1px solid var(--color-main);
}
input[type="radio"]:checked+span::after {
  opacity: 1;
}
input[type="checkbox"] + span {
  position: relative;
  padding: 6px 0 6px 33px;
  &::before, &::after{
    top: .3em;
    transition: .3s;
  }
  &::before{
    left: 0;
    width: 1.4em;
    aspect-ratio: 1;
  }
  &::after{
    left: 7px;
    width: 7px;
    height: 13px;
    transform: rotate(45deg);
    border-right: 3px solid var(--color-white);
    border-bottom: 3px solid var(--color-white);
    opacity: 0;
  }
}
input[type="checkbox"]:checked + span:before {
  background: var(--color-main);
  border: 1px solid var(--color-main);
}
input[type="checkbox"]:checked + span:after {
  opacity: 1;
}
.form-item-list{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(clamp(160px, 30vw / 1.2, 300px), 1fr));
  gap: 0.5em 0;
  label{
    display: flex;
  }
}
.form-list-type{
  font-weight: var(--font-weight-bold);
  margin-block: .5rem;
}
.privacy-btn{
  border: 2px solid var(--color-black);
  font-weight: var(--font-weight-bold);
  font-size: var(--font16);
  padding: 0.2em 1.8em 0.2em 0.5em;
  margin-block: 0.8em 1em;
}
/*エラー*/
.error-message{
  position: relative;
  font-size: clamp(var(--font14), calc((0.0625rem * 14) + ((1vw - 3.8px) * (2 / 9.2))), var(--font16));
  margin-top: 0.5em;
  padding-left: 1.5em;
  &::before, &::after{
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
  }
  &::before{
    content: "";
    left: 0;
    width: 1.2em;
    aspect-ratio: 1;
    border: 1px solid;
    border-radius: 50%;
  }
  &::after{
    content: '!';
    left: 0.5em;
  }
}
/*reCAPTCHA*/
.from-footer{
  --recaptcha-margin: clamp(30px, 8vw, 80px);
  display: grid;
  justify-items: center;
  gap: var(--recaptcha-margin);
  margin-block: var(--recaptcha-margin);
}
.g-recaptcha{
  display: grid;
  justify-items: center;
}
/*ボタン*/
.from-btn{
  transition: .3s;
}
.submit-button, .validate-btn{
  background: var(--color-black);
  color: var(--color-white);
  &:hover{
    background: var(--color-main);
    color: var(--color-black);
  }
}
.validate-btn{
  width: 12em;
  font-size: clamp(var(--font18), calc((0.0625rem * 16) + ((1vw - 3.8px) * (2 / 9.2))), var(--font20));
  padding-block: 1.5em;
}
.submit-button, .edit-btn{
  width: 8.5em;
  font-size: clamp(var(--font16), calc((0.0625rem * 16) + ((1vw - 3.8px) * (2 / 9.2))), var(--font18));
  padding-block: 1em;
}
.edit-btn{
  background: var(--color-e1e1e2);
  &:hover{
    background: var(--color-cdcdcd);
  }
}
/*確認*/
.modal{
  position: fixed;
  inset: 0;
  place-content: center;
  background: rgba(27, 27, 27, 0.95);
  z-index: 11;
}
.modal-content{
  --modal-padding: clamp(1rem, 3.2vw, 2rem);
  overflow: auto;
  width: min(100vw - (var(--modal-padding) * 2) - 6vw, 650px);
  max-height: calc(90svh - (var(--modal-padding) * 2));
  background: var(--color-white);
  border-radius: var(--modal-padding);
  padding: var(--modal-padding);
  box-shadow: var(--shadow);
  &::-webkit-scrollbar{
      width: 12px;
  }
  &::-webkit-scrollbar-thumb{
      position: absolute;
      background: var(--color-main);
      border-radius: 6px;
  }
}
.button-box{
  display: flex;
  justify-content: center;
  gap: clamp(25px, 5vw, 50px);
}
.modal-list{
  padding-block: clamp(.7rem, 1.6vw, 1rem);
}
.modal-item{
  display: grid;
  grid-template-columns: 9em 1fr;
  gap: 1.5em;
  border-bottom: 1px solid var(--color-cdcdcd);
  font-size: clamp(var(--font15), calc((0.0625rem * 15) + ((1vw - 3.8px) * (1 / 9.2))), var(--font16));
  padding-block: 0.8em;
}
@media (width <=800px){
  .c-form-item, .modal-item{
    grid-template-columns: 1fr;
    gap: 1em;
  }
}
/*-- 法人用 --*/
/*-- 取材・プレス関連 --*/
/*-- 資料請求 --*/
.wrap__dr{
  display: grid;
  grid-template-columns: clamp(350px, 55vw / 1.4, 550px) 1fr;
  gap: clamp(25px, 6vw / 1.4, 60px);
}
.inquiry-body__dr{
  background: var(--color-f6f6f6);
  border: 1px solid var(--color-f3f3f3);
  margin-block: var(--page-header-pt) clamp(30px, 7vw / 1.5, 70px);
}
.material-content{
  background: var(--color-main-light);
  padding-block: clamp(.7rem, 2.4vw / 1.4, 1.5rem);
  padding-inline: clamp(.5rem, 3.2vw / 1.4, 2rem) clamp(.4rem, 1.6vw / 1.4, 1rem);
  margin-top: clamp(.7rem, 2.4vw / 1.4, 1.5rem);
  h2{
    font-size: clamp(var(--font17), calc((0.0625rem * 17) + ((1vw - 3.8px) * (3 / 10.2))), var(--font20));
    margin-bottom: .7em;
  }
  li{
    position: relative;
    margin-bottom: .5em;
    padding-left: 1.2em;
    &::before{
      content: '';
      position: absolute;
      inset: calc(50% - 1px) calc(100% - .8em) calc(50% - 1px) 0;
      background: var(--color-main);
    }
  }
}
.form__dr{
  padding-inline: 3%;
  .form-item-list{
    grid-template-columns: 1fr;
  }
}
@media (width <=900px){
  .wrap__dr{
    grid-template-columns: 1fr;
  }
  .inquiry-body__dr{
    margin-top: 0;
  }
}
/*サンクスページ
-----------------------------*/
.thanks-content{
  margin-bottom: clamp(25px, 6vw / 1.4, 60px);
}
.thanks-text{
  margin-bottom: .8em;
}
.thanks-links{
  display: flex;
  gap: clamp(25px, 6vw / 1.4, 60px);
  a{
    background: var(--color-main);
    padding: 1em 2em 1em 1em;
  }
}