@charset "UTF-8";
@import url(https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;600;700&display=swap);
@import url(https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@300;400;500;600;700&display=swap);
@import url(https://fonts.googleapis.com/css2?family=Cormorant+Infant&family=Noto+Serif+JP:wght@300;400;500;600;700&display=swap);
@import url(https://fonts.googleapis.com/css2?family=Cormorant+Infant&family=Noto+Sans+JP:wght@400;500;700&display=swap);
@import url(https://fonts.googleapis.com/css2?family=Cormorant+Infant:wght@300;400;500;600;700&display=swap);
@import url(https://fonts.googleapis.com/icon?family=Material+Icons|Material+Icons+Outlined&display=swap);
@import url(https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@48,400,0,0);
*, :after, :before {
  box-sizing: border-box
}
:after, :before {
  text-decoration: inherit;
  vertical-align: inherit
}
html {
  -webkit-tap-highlight-color: transparent;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  cursor: default;
  line-height: 1.5;
  -moz-tab-size: 4;
  -o-tab-size: 4;
  tab-size: 4;
  word-break: break-word
}
body, dl dl, dl ol, dl ul, ol dl, ol ol, ol ul, ul dl, ul ol, ul ul {
  margin: 0
}
hr {
  color: inherit;
  height: 0;
  overflow: visible
}
main {
  display: block
}
nav ol, nav ul {
  list-style: none;
  padding: 0
}
pre {
  -ms-overflow-style: scrollbar;
  font-family: monospace, monospace;
  font-size: 1em;
  overflow: auto
}
a {
  background-color: transparent
}
abbr[title] {
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted
}
b, strong {
  font-weight: bolder
}
code, kbd, samp {
  font-family: monospace, monospace;
  font-size: 1em
}
small {
  font-size: 80%
}
audio, canvas, iframe, img, svg, video {
  vertical-align: middle
}
audio, video {
  display: inline-block
}
audio:not([controls]) {
  display: none;
  height: 0
}
iframe, img {
  border-style: none
}
svg:not([fill]) {
  fill: currentColor
}
svg:not(:root) {
  overflow: hidden
}
table {
  border-collapse: collapse;
  border-color: inherit;
  text-indent: 0
}
button, input, select {
  margin: 0
}
button {
  overflow: visible;
  text-transform: none;
  border: none;
}
[type=button], [type=reset], [type=submit], button {
  -webkit-appearance: button
}
fieldset {
  border: 1px solid #a0a0a0;
  padding: .35em .75em .625em
}
input {
  overflow: visible
}
legend {
  color: inherit;
  display: table;
  max-width: 100%;
  white-space: normal
}
progress {
  display: inline-block;
  vertical-align: baseline
}
select {
  text-transform: none
}
textarea {
  margin: 0;
  overflow: auto;
  resize: vertical;
  resize: block
}
[type=checkbox], [type=radio] {
  padding: 0
}
[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px
}
::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
  height: auto
}
::-webkit-input-placeholder {
  color: inherit;
  opacity: .54
}
::-webkit-search-decoration {
  -webkit-appearance: none
}
::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit
}
::-moz-focus-inner {
  border-style: none;
  padding: 0
}
:-moz-focusring {
  outline: 1px dotted ButtonText
}
:-moz-ui-invalid {
  box-shadow: none
}
details, dialog {
  display: block
}
dialog {
  background-color: #fff;
  border: solid;
  color: #000;
  height: -moz-fit-content;
  height: fit-content;
  left: 0;
  margin: auto;
  padding: 1em;
  position: absolute;
  right: 0;
  width: -moz-fit-content;
  width: fit-content
}
dialog:not([open]) {
  display: none
}
summary {
  display: list-item
}
canvas {
  display: inline-block
}
template {
  display: none
}
[tabindex], a, area, button, input, label, select, summary, textarea {
  -ms-touch-action: manipulation
}
[hidden] {
  display: none
}
[aria-busy=true] {
  cursor: progress
}
[aria-controls] {
  cursor: pointer
}
[aria-disabled=true], [disabled] {
  cursor: not-allowed
}
[aria-hidden=false][hidden] {
  display: initial
}
[aria-hidden=false][hidden]:not(:focus) {
  clip: rect(0, 0, 0, 0);
  position: absolute
}
.p-index-mv__heading {
  opacity: 0;
  transform: translateY(15px);
  transition: opacity .5s, visibility .5s, transform .5s;
  visibility: hidden
}
.p-index-mv__heading.is-fadeinup {
  opacity: 1;
  transform: translateY(0);
  visibility: visible
}
.p-index-mv__block {
  opacity: 0;
  transform: translateY(15px);
  transition: opacity .5s, visibility .5s, transform .5s;
  visibility: hidden
}
.p-index-mv__block.is-fadeinup {
  opacity: 1;
  transform: translateY(0);
  visibility: visible
}
.p-index-about__item {
  opacity: 0;
  transform: translateY(15px);
  transition: opacity .5s, visibility .5s, transform .5s;
  visibility: hidden
}
.p-index-about__item.is-fadeinup {
  opacity: 1;
  transform: translateY(0);
  visibility: visible
}
.p-company-mv__item {
  opacity: 0;
  transform: translateY(15px);
  transition: opacity .5s, visibility .5s, transform .5s;
  visibility: hidden
}
.p-company-mv__item.is-fadeinup {
  opacity: 1;
  transform: translateY(0);
  visibility: visible
}
body {
  font-feature-settings: "palt";
  color: #303030;
  font-family: "Noto Serif JP", serif
}
main {
  overflow: hidden
}
img {
  height: auto;
  max-width: 100%;
  vertical-align: baseline
}
h1, h2, h3, h4, h5 {
  font-size: 100%;
  font-weight: 400;
  margin: 0
}
p {
  font-size: 1rem;
  line-height: 1.7;
  margin: 0
}
a {
  color: #1f2356;
  text-decoration: none;
  transition: .3s ease-in-out
}
a:hover {
  filter: alpha(opacity=60);
  opacity: .5
}
@media screen and (min-width:768px) {
  .tel, a[href^="tel:"] {
    pointer-events: none
  }
}
nav {
  font-size: 0
}
strong {
  font-weight: 400
}
ul {
  list-style-type: none
}
dd, dl, dt, ul {
  margin: 0;
  padding: 0
}
input {
  font-feature-settings: "palt";
  color: #303030;
  font-family: "Noto Serif JP", serif
}
input[type=text] {
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  padding: 0
}
input[type=checkbox], input[type=radio] {
  
  position: absolute
}
select {
  border: none
}
select, textarea {
  font-feature-settings: "palt";
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  color: #303030;
  font-family: "Noto Serif JP", serif;
  outline: none
}
textarea {
  border: 0;
  padding: 0;
  resize: none
}
button,input[type=submit] {
  /* -webkit-appearance:none; */
  -moz-appearance: none;
  /* appearance:none; */
  /* background:transparent; */
  /* border:none; */
  outline: none;
  padding: 0
}
figure {
  margin: 0
}
:root {
  --leading-trim: calc(0.5em - 1lh/2)
}
@media screen and (max-width:767px) {
  .u-mt-sp5 {
    margin-top: 5px
  }
  .u-mt-sp10 {
    margin-top: 10px
  }
  .u-mt-sp15 {
    margin-top: 15px
  }
  .u-mt-sp70 {
    margin-top: 70px
  }
  .u-mt-sp75 {
    margin-top: 75px
  }
  .u-mt-sp80 {
    margin-top: 80px
  }
  .u-mt-sp90 {
    margin-top: 90px
  }
  .u-mt-sp105 {
    margin-top: 105px
  }
  .u-mt-sp110 {
    margin-top: 110px
  }
  .u-mt-sp115 {
    margin-top: 115px
  }
  .u-mt-sp125 {
    margin-top: 125px
  }
  .u-mt-sp130 {
    margin-top: 130px
  }
  .u-mt-sp135 {
    margin-top: 135px
  }
  .u-mt-sp140 {
    margin-top: 140px
  }
  .u-mt-sp145 {
    margin-top: 145px
  }
  .u-mt-sp155 {
    margin-top: 155px
  }
  .u-mt-sp160 {
    margin-top: 160px
  }
  .u-mt-sp165 {
    margin-top: 165px
  }
  .u-mt-sp170 {
    margin-top: 170px
  }
  .u-mt-sp175 {
    margin-top: 175px
  }
  .u-mt-sp180 {
    margin-top: 180px
  }
  .u-mt-sp185 {
    margin-top: 185px
  }
  .u-mt-sp190 {
    margin-top: 190px
  }
  .u-mt-sp195 {
    margin-top: 195px
  }
  .u-mt-sp200 {
    margin-top: 200px
  }
}
@media screen and (min-width:768px) {
  .u-mt-md5 {
    margin-top: 5px
  }
  .u-mt-md10 {
    margin-top: 10px
  }
  .u-mt-md15 {
    margin-top: 15px
  }
  .u-mt-md25 {
    margin-top: 25px
  }
  .u-mt-md35 {
    margin-top: 35px
  }
  .u-mt-md40 {
    margin-top: 40px
  }
  .u-mt-md45 {
    margin-top: 45px
  }
  .u-mt-md55 {
    margin-top: 55px
  }
  .u-mt-md75 {
    margin-top: 75px
  }
  .u-mt-md90 {
    margin-top: 90px
  }
  .u-mt-md105 {
    margin-top: 105px
  }
  .u-mt-md115 {
    margin-top: 115px
  }
  .u-mt-md125 {
    margin-top: 125px
  }
  .u-mt-md135 {
    margin-top: 135px
  }
  .u-mt-md140 {
    margin-top: 140px
  }
  .u-mt-md145 {
    margin-top: 145px
  }
  .u-mt-md155 {
    margin-top: 155px
  }
  .u-mt-md165 {
    margin-top: 165px
  }
  .u-mt-md170 {
    margin-top: 170px
  }
  .u-mt-md175 {
    margin-top: 175px
  }
  .u-mt-md185 {
    margin-top: 185px
  }
  .u-mt-md190 {
    margin-top: 190px
  }
  .u-mt-md195 {
    margin-top: 195px
  }
}
@media screen and (max-width:767px) {
  .u-mt-sp20 {
    margin-top: 20px
  }
  .u-mt-sp25 {
    margin-top: 25px
  }
  .u-mt-sp30 {
    margin-top: 30px
  }
  .u-mt-sp35 {
    margin-top: 35px
  }
  .u-mt-sp40 {
    margin-top: 40px
  }
  .u-mt-sp45 {
    margin-top: 45px
  }
  .u-mt-sp50 {
    margin-top: 50px
  }
  .u-mt-sp55 {
    margin-top: 55px
  }
  .u-mt-sp60 {
    margin-top: 60px
  }
  .u-mt-sp65 {
    margin-top: 65px
  }
  .u-mt-sp85 {
    margin-top: 85px
  }
  .u-mt-sp95 {
    margin-top: 95px
  }
  .u-mt-sp100 {
    margin-top: 100px
  }
  .u-mt-sp120 {
    margin-top: 120px
  }
  .u-mt-sp150 {
    margin-top: 150px
  }
}
@media screen and (min-width:768px) {
  .u-mt-md20 {
    margin-top: 20px
  }
  .u-mt-md30 {
    margin-top: 30px
  }
  .u-mt-md50 {
    margin-top: 50px
  }
  .u-mt-md60 {
    margin-top: 60px
  }
  .u-mt-md65 {
    margin-top: 65px
  }
  .u-mt-md70 {
    margin-top: 70px
  }
  .u-mt-md80 {
    margin-top: 80px
  }
  .u-mt-md85 {
    margin-top: 85px
  }
  .u-mt-md95 {
    margin-top: 95px
  }
  .u-mt-md100 {
    margin-top: 100px
  }
  .u-mt-md110 {
    margin-top: 110px
  }
  .u-mt-md120 {
    margin-top: 120px
  }
  .u-mt-md130 {
    margin-top: 130px
  }
  .u-mt-md150 {
    margin-top: 150px
  }
  .u-mt-md160 {
    margin-top: 160px
  }
  .u-mt-md180 {
    margin-top: 180px
  }
  .u-mt-md200 {
    margin-top: 200px
  }
  .u-mt-md250 {
    margin-top: 250px
  }
  .u-mt-md300 {
    margin-top: 300px
  }
}
@media screen and (max-width:767px) {
  .u-ptb-sp30 {
    padding-bottom: 30px;
    padding-top: 30px
  }
}
@media screen and (min-width:768px) {
  .u-ptb-md40 {
    padding-bottom: 40px;
    padding-top: 40px
  }
}
.u-plr-10 {
  padding: 0 10px
}
.u-plr-45 {
  padding: 0 45px
}
@media screen and (max-width:767px) {
  .u-pt-sp150 {
    margin-top: 150px
  }
}
@media screen and (min-width:768px) {
  .u-pt-md100 {
    padding-top: 100px
  }
}
.u-none-sm {
  display: none
}
@media screen and (min-width:576px) {
  .u-none-sm {
    display: block
  }
}
.u-none-md {
  display: none
}
@media screen and (min-width:768px) {
  .u-none-md {
    display: block
  }
}
.u-none-md02 {
  display: none
}
@media screen and (min-width:768px) {
  .u-none-md02 {
    display: inline
  }
}
.u-display-md {
  display: block
}
@media screen and (min-width:768px) {
  .u-display-md {
    display: none
  }
}
.u-display-md02 {
  display: inline
}
@media screen and (min-width:768px) {
  .u-display-md02 {
    display: none
  }
}
.u-center01 {
  display: block;
  text-align: center
}
.u-center02 {
  align-items: center;
  display: flex;
  justify-content: center
}
.u-br {
  display: inline-block
}
.u-br--done {
  display: block
}
.header {
  position: sticky;
  top: 0;
  z-index: 100
}
.header-inner {
  align-items: center;
  background-color: #30366d;
  display: flex;
  gap: 10px;
  height: 80px;
  justify-content: space-between;
  padding: 5px 0 5px 10px;
  width: 100%
}
@media screen and (min-width:768px) {
  .header-inner {
    gap: 10px;
    height: 96px;
    padding: 5px 8px 5px 10px
  }
}
@media screen and (min-width:876px) {
  .header-inner {
    gap: 20px
  }
}
@media screen and (min-width:1080px) {
  .header-inner {
    padding: 5px 48px 5px 10px
  }
}
.header__co-logo {
  display: block;
  margin-top: 7px;
  max-width: 180px;
  padding: 0;
  width: 100%
}
@media screen and (min-width:768px) {
  .header__co-logo {
    padding: 0 18px 0 0
  }
}
@media screen and (min-width:1080px) {
  .header__co-logo {
    max-width: 455px
  }
}
.header__co-logo img {
  height: auto;
  width: 100%
}
.header__contact-wrap {
  display: none
}
@media screen and (min-width:768px) {
  .header__contact-wrap {
    display: block
  }
}
.header__contact {
  gap: 14px
}
.header__contact, .header__contact-tel {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  align-items:center;
}
.header__contact-tel {
  gap: 10px
}
@media screen and (min-width:1300px) {
  .header__contact-tel {
    gap: 20px
  }
}
.header__contact-tel-inner {
  border: 2px solid #fff;
  border-radius: 16px;
  gap: 2px;
  height: 82px;
  padding: 8px 28px;
}
@media screen and (min-width:876px) {
  .header__contact-tel-inner {
  }
}
@media screen and (min-width:1300px) {
  .header__contact-tel-inner {
    gap: 5px;
    
  }
}

.inner2{
  display: flex;
  justify-content: center;
  
}

.header__contact-tel-inner .tttime{
  color: #fff;
  font-size: 13px;
  font-weight: 500;
  line-height: 1;
  display: flex;
  margin-bottom: 7px;
  justify-content: center;
  letter-spacing: 0.3px;
}

.header__contact-tel-head {
  color: #fff;
  font-size: 1.125rem;
  font-weight: 500
}
@media screen and (min-width:876px) {
  .header__contact-tel-head {
    font-size: 1.5rem
  }
}
@media screen and (min-width:1300px) {
  .header__contact-tel-head {
    font-size: 2rem
  }
}
.header__contact-tel-txt {
  color: #fff;
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 1;
  margin-top: 2px
}
@media screen and (min-width:876px) {
  .header__contact-tel-txt {
    font-size: 12px;
  }
}
@media screen and (min-width:1300px) {
  .header__contact-tel-txt {
    font-size: 12px;
  }
}


.header__contact-tel-num {
  text-wrap: nowrap;
  color: #fff;
  font-size: 36px;
  font-weight: 500;
  letter-spacing: .08em;
  line-height: 1;
}
@media screen and (min-width:1300px) {
  .header__contact-tel-num {
    font-size: 36px;
  }
}
.header__contact-form {
  cursor: pointer;
  display: block;
  margin-top: 7px;
  width: 78px
}
.header__contact-form-img {
  text-align: center
}
.header__contact-form-img img {
  height: 32px;
  width: 39px
}
.header__contact-form-txt {
  text-wrap: nowrap;
  color: #fff;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .08em
}
.header__contact-sp-wrap {
  display: flex;
  flex-wrap: nowrap
}
@media screen and (min-width:768px) {
  .header__contact-sp-wrap {
    display: none
  }
}
.header__contact-sp {
  align-items: center;
  display: flex;
  gap: 0;
  justify-content: space-between
}
@media screen and (min-width:768px) {
  .header__contact-sp {
    gap: 15px
  }
}
.header__contact-sp-form {
  align-items: center;
  border: none;
  border-radius: 15.8px;
  display: flex;
  gap: 0;
  height: 100%;
  padding: 5px 5px 5px 21px;
  width: 58px
}
@media screen and (min-width:768px) {
  .header__contact-sp-form {
    border: 1.979px solid #fff;
    border-radius: 12px;
    gap: 8px;
    height: 62px;
    padding: 3px 3px 3px 19px;
    width: 270px
  }
}
.header__contact-sp-form-icon {
  align-items: center;
  display: flex;
  height: 31px;
  justify-content: center;
  width: 39px
}
@media screen and (min-width:768px) {
  .header__contact-sp-form-icon {
    height: 31px;
    width: 39px
  }
}
.header__contact-sp-tel {
  align-items: center;
  border: none;
  border-radius: 15.8px;
  display: flex;
  gap: 0;
  height: 100%;
  justify-content: center;
  padding: 0;
  width: 58px
}
.header__contact-sp-tel-icon {
  margin-top: 2px
}
.header__btn-toggle {
  align-items: center;
  cursor: pointer;
  display: flex;
  flex-flow: column;
  height: 80px;
  justify-content: center;
  transition: all .3s;
  width: 80px
}
@media screen and (min-width:768px) {
  .header__btn-toggle {
    display: none
  }
}
.header__btn-toggle span {
  background-color: #fff;
  display: inline-block;
  height: 4px;
  margin: 6px 0;
  transition: all .4s;
  width: 45px
}
@media screen and (min-width:768px) {
  .header__btn-toggle span {
    margin: 6px 0
  }
}
@media screen and (min-width:1024px) {
  .header__btn-toggle span {
    margin: 8px 0
  }
}
.header__btn-toggle.active span:first-of-type {
  margin: 0;
  transform: translateY(2px) rotate(-45deg);
  transform-origin: center
}
.header__btn-toggle.active span:nth-of-type(2) {
  display: none;
  opacity: 0
}
.header__btn-toggle.active span:nth-of-type(3) {
  margin: 0;
  transform: translateY(-2px) rotate(45deg);
  transform-origin: center
}
.header__tel-toggle {
  box-shadow: 0 0 17px -9px #777;
  display: none;
  left: 50%;
  max-width: 100%;
  position: absolute;
  right: auto;
  top: 80px;
  transform: translateX(-50%);
  width: 100%;
  z-index: 100
}
@media screen and (min-width:400px) {
  .header__tel-toggle {
    height: 232px;
    left: auto;
    max-width: 295px;
    right: 81px;
    transform: translateX(0);
    width: 100%
  }
}
@media screen and (min-width:768px) {
  .header__tel-toggle {
    display: none
  }
}
.header__tel-toggle:before {
  border-style: solid;
  border-bottom: 19px solid #fff;
  border-left: 20px solid transparent;
  border-right: 20px solid transparent;
  border-top: 0;
  content: "";
  display: block;
  height: 0;
  position: absolute;
  right: 99px;
  top: -10px;
  transform: rotate(143deg);
  width: 0;
  z-index: 10
}
@media screen and (min-width:400px) {
  .header__tel-toggle:before {
    right: 19px
  }
}
.header__tel-toggle.active {
  display: block
}
@media screen and (min-width:768px) {
  .header__tel-toggle.active {
    display: none
  }
}
.header__tel-toggle-inner {
  background-color: #fff;
  border-radius: 12px;
  height: 182px;
  margin-inline: auto;
  max-width: 295px;
  padding: 25px 10px;
  position: relative;
  width: 100%
}
.header__tel-toggle-close {
  height: 30px;
  position: absolute;
  right: 15px;
  top: 15px;
  width: 30px;
  z-index: 100
}
.header__tel-toggle-close:before {
  transform: translate(-50%, -50%) rotate(45deg)
}
.header__tel-toggle-close:after, .header__tel-toggle-close:before {
  background: #000;
  content: "";
  display: block;
  height: 40px;
  left: 50%;
  position: absolute;
  top: 50%;
  width: 1px
}
.header__tel-toggle-close:after {
  transform: translate(-50%, -50%) rotate(-45deg)
}
.header__tel-toggle-head {
  font-size: 1.5rem;
  font-weight: 500;
  text-align: center
}
.header__tel-toggle-txt01 {
  font-size: .875rem;
  font-weight: 500;
  text-align: center
}
.header__tel-toggle-list-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  justify-content: center;
  margin-top: 20px
}
.header__tel-toggle-list-inner {
  align-items: center;
  background-color: #4a79ae;
  border-radius: 6px;
  display: flex;
  flex-wrap: nowrap;
  height: 40px;
  padding: 2px;
  width: 236px
}
.header__tel-toggle-icon {
  align-items: center;
  background-color: #262c62;
  border-radius: 4px 0 0 4px;
  display: flex;
  height: 35px;
  justify-content: center;
  width: 37px
}
.header__tel-toggle-icon img {
  height: 26px;
  width: 26px
}
.header__tel-toggle-index {
  color: #fff;
  font-size: .75rem;
  font-weight: 500;
  letter-spacing: 2px;
  margin-left: 3px;
  margin-right: 3px;
  writing-mode: vertical-rl
}
.header__tel-toggle-num {
  color: #fff;
  font-size: 1.625rem;
  font-weight: 500;
  margin-top: -2px
}
.header__tel-sm-bg {
  display: none;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 10
}
.header__tel-sm-bg.active {
  display: block
}
.header__nav02-wrap {
  display: flex;
  flex-wrap: nowrap
}
.header__nav02 {
  align-items: center;
  display: flex;
  gap: 0;
  justify-content: space-between
}
@media screen and (min-width:768px) {
  .header__nav02 {
    gap: 15px
  }
}
.header__nav02-contact {
  align-items: center;
  border: none;
  border-radius: 15.8px;
  display: flex;
  gap: 0;
  height: 100%;
  padding: 5px 5px 5px 21px;
  width: 58px
}
@media screen and (min-width:768px) {
  .header__nav02-contact {
    border: 1.979px solid #fff;
    border-radius: 12px;
    gap: 8px;
    height: 62px;
    padding: 3px 3px 3px 19px;
    width: 270px
  }
}
.header__nav02-contact-icon {
  align-items: center;
  display: flex;
  height: 31px;
  justify-content: center;
  width: 39px
}
@media screen and (min-width:768px) {
  .header__nav02-contact-icon {
    height: 31px;
    width: 39px
  }
}
.header__nav02-contact-txt {
  color: #fff;
  display: none;
  font-size: .875rem;
  font-weight: 500
}
@media screen and (min-width:768px) {
  .header__nav02-contact-txt {
    display: block
  }
}
.header__nav02-tel {
  align-items: center;
  border: none;
  border-radius: 15.8px;
  display: flex;
  gap: 0;
  height: 100%;
  justify-content: center;
  padding: 0;
  width: 58px
}
@media screen and (min-width:768px) {
  .header__nav02-tel {
    border: 1.979px solid #fff;
    border-radius: 12px;
    gap: 8px;
    height: 62px;
    padding: 0 10px;
    width: 290px
  }
}
.header__nav02-tel-detail {
  display: none
}
@media screen and (min-width:768px) {
  .header__nav02-tel-detail {
    display: block
  }
}
.header__nav02-tel-icon {
  margin-top: 2px
}
.header__nav02-tel-txt {
  color: #fff;
  font-size: .875rem;
  font-weight: 500;
  line-height: 1.3
}
@media screen and (min-width:768px) {
  .header__nav02-tel-txt {
    font-size: .875rem
  }
}
.header__nav02-tel-num {
  color: #fff;
  font-size: 1.3125rem;
  font-weight: 500;
  line-height: 1;
  white-space: nowrap
}
.header__nav-sp-wrap {
  background-color: rgba(48, 54, 109, .9);
  height: calc(100vh - 80px);
  opacity: 0;
  overflow-y: auto;
  overscroll-behavior-y: none;
  padding-bottom: 200px;
  position: absolute;
  top: 80px;
  transition: all .3s;
  visibility: hidden;
  width: 100%;
  z-index: -10
}
.header__nav-sp-wrap.active {
  opacity: 1;
  visibility: visible;
  z-index: 999
}
.header__nav-sp {
  display: flex;
  flex-flow: column;
  gap: 8px
}
.header__nav-sp li {
  margin-top: 28px;
  text-align: center
}
.header__nav-sp li a {
  color: #fff;
  font-size: 1rem
}
.footer {
  background-color: #30366d;
  margin-top: 80px;
  padding: 18px 10px 10px
}
@media screen and (min-width:768px) {
  .footer {
    padding: 45px 10px 20px
  }
}
.footer__cologo {
  display: block;
  margin-inline: auto;
  max-width: 215px;
  width: 100%
}
@media screen and (min-width:768px) {
  .footer__cologo {
    max-width: 290px
  }
}
.footer__nav {
  display: flex;
  flex-wrap: nowrap;
  gap: 20px;
  justify-content: center;
  margin-top: 10px
}
@media screen and (min-width:768px) {
  .footer__nav {
    gap: 24px;
    margin-top: 25px
  }
}
.footer__nav a {
  color: #fff;
  font-size: .625rem
}
@media screen and (min-width:768px) {
  .footer__nav a {
    font-size: .75rem
  }
}
.footer__copyright {
  color: #fff;
  display: block;
  font-size: .75rem;
  margin-top: 50px;
  text-align: center
}
@media screen and (min-width:768px) {
  .footer__copyright {
    margin-top: 25px
  }
}
.heading01 {
  padding: 0 45px;
  text-align: center
}
.heading01__txt {
  border-left: 3px solid #30366d;
  color: #222;
  display: inline-block;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 130%;
  padding-left: 10px;
  text-align: center
}
@media screen and (min-width:768px) {
  .heading01__txt {
    border-left: 5px solid #30366d;
    font-size: 2rem;
    padding-left: 15px
  }
}
.heading01__txt02 {
  font-size: 1.125rem;
  margin-top: 5px
}
@media screen and (min-width:768px) {
  .heading01__txt02 {
    font-size: 1.5rem
  }
}
.heading02 {
  padding-bottom: 6px;
  position: relative;
  text-align: center
}
.heading02__inner {
  display: inline-block;
  position: relative
}
.heading02__inner:before {
  background-color: #1f2356;
  transform: skewX(-12deg);
  z-index: 1
}
.heading02__inner:after, .heading02__inner:before {
  content: "";
  display: block;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%
}
.heading02__inner:after {
  background-color: transparent;
  border: 1px solid #1f2356;
  transform: translate(6px, 6px) skewX(-12deg);
  z-index: 0
}
.heading02__txt {
  color: #fff;
  display: inline-block;
  font-size: .875rem;
  padding: 7px 45px;
  position: relative;
  text-align: center;
  z-index: 2
}
@media screen and (min-width:768px) {
  .heading02__txt {
    font-size: 1.5rem
  }
}
.heading02__bg {
  bottom: 0;
  color: hsla(0, 0%, 61%, .25);
  font-size: 25vw;
  left: 0;
  line-height: 0;
  position: relative;
  top: -35px;
  transform: skew(-20deg);
  white-space: nowrap;
  z-index: 0
}
@media screen and (min-width:395px) {
  .heading02__bg {
    font-size: 6.17375rem
  }
}
@media screen and (min-width:768px) {
  .heading02__bg {
    font-size: 11.1875rem;
    left: 0;
    position: absolute;
    top: -25px
  }
}
@media screen and (min-width:1400px) {
  .heading02__bg {
    left: -340px;
    position: relative;
    top: -75px
  }
}
.heading03 {
  position: relative;
  text-align: center
}
.heading03__en {
  color: hsla(0, 0%, 61%, .3);
  display: inline-block;
  font-size: 4rem;
  line-height: 1;
  transform: skew(-20deg)
}
@media screen and (min-width:768px) {
  .heading03__en {
    font-size: 9.25rem
  }
}
.heading03__ja {
  bottom: 0;
  font-size: 1.5rem;
  left: 50%;
  position: absolute;
  transform: translateX(-50%)
}
@media screen and (min-width:768px) {
  .heading03__ja {
    font-size: 2.5rem
  }
}
.heading04 {
  font-size: 1.5rem;
  text-align: center
}
@media screen and (min-width:768px) {
  .heading04 {
    font-size: 2.5rem
  }
}
.p01 {
  font-size: 1.3125rem
}
@media screen and (min-width:768px) {
  .p01 {
    font-size: 2rem
  }
}
.p01 span {
  background: linear-gradient(transparent 80%, rgba(250, 255, 0, .6) 0)
}
.p02 {
  font-size: 1.5rem
}
@media screen and (min-width:768px) {
  .p02 {
    font-size: 2.25rem
  }
}
.p02 span {
  background: linear-gradient(transparent 80%, rgba(250, 255, 0, .6) 0)
}
.p03 {
  font-size: 1.125rem;
  line-height: 160%;
  text-align: center
}
@media screen and (min-width:768px) {
  .p03 {
    font-size: 2rem
  }
}
.p03 span {
  background: linear-gradient(transparent 80%, rgba(250, 255, 0, .6) 0)
}
.p04, .p__center {
  text-align: center
}
.p04 {
  font-size: .875rem;
  line-height: 170%
}
@media screen and (min-width:768px) {
  .p04 {
    font-size: 1.3125rem
  }
}
.p05 {
  align-items: center;
  color: #30366d;
  display: flex;
  font-family: "Noto Serif JP", serif;
  font-size: 3.8vw;
  font-weight: 600;
  height: 100px;
  justify-content: center;
  line-height: 180%;
  margin-inline: auto;
  max-width: 290px;
  padding: 10px;
  position: relative;
  text-align: center;
  width: 100%
}
@media screen and (min-width:350px) {
  .p05 {
    font-size: .8125rem
  }
}
@media screen and (min-width:768px) {
  .p05 {
    font-size: 1.75rem;
    height: 230px;
    max-width: 674px
  }
}
.p05:before {
  left: 50%;
  top: 50%;
  z-index: 2
}
.p05:after, .p05:before {
  border: 1px solid #000;
  content: "";
  height: 98%;
  position: absolute;
  transform: translate(-50%, -50%);
  width: 98%
}
.p05:after {
  left: 51%;
  top: 53%;
  z-index: 3
}
.p06 {
  font-size: 1rem;
  text-align: center
}
@media screen and (min-width:768px) {
  .p06 {
    font-size: 1.75rem
  }
}
.p07 {
  font-size: 1.125rem;
  line-height: 160%;
  text-align: center
}
@media screen and (min-width:768px) {
  .p07 {
    font-size: 1.5rem
  }
}
.p07 span {
  background: linear-gradient(transparent 80%, rgba(250, 255, 0, .6) 0);
  color: #30366d;
  font-size: 1.5rem;
  font-weight: 600
}
@media screen and (min-width:768px) {
  .p07 span {
    font-size: 2.25rem
  }
}
.p08 {
  font-size: .875rem;
  line-height: 160%;
  text-align: left
}
@media screen and (min-width:768px) {
  .p08 {
    font-size: 1.5rem;
    line-height: 200%;
    text-align: center
  }
}
.list01 {
  display: block;
  margin-inline: auto;
  margin-top: 25px;
  max-width: 300px;
  padding: 0 20px
}
@media screen and (min-width:768px) {
  .list01 {
    display: flex;
    gap: 85px;
    justify-content: center;
    max-width: 100%
  }
}
.list01__item {
  display: flex;
  margin-top: 15px
}
@media screen and (min-width:768px) {
  .list01__item {
    margin-top: 10px
  }
}
.list01__icon {
  height: 22px;
  margin-top: 3px;
  width: 21px
}
@media screen and (min-width:768px) {
  .list01__icon {
    height: 35px;
    margin-top: 12px;
    width: 35px
  }
}
.list01__txt {
  color: #222;
  font-size: 1.0625rem;
  line-height: 1.5;
  padding-left: 10px
}
@media screen and (min-width:768px) {
  .list01__txt {
    font-size: 2rem;
    padding-left: 25px
  }
}
.list02-wrap {
  background-color: #f6f6f6;
  margin-top: 40px;
  padding: 30px 0 50px
}
@media screen and (min-width:768px) {
  .list02-wrap {
    margin-top: 80px;
    padding: 70px 45px 65px
  }
}
.list02 {
  gap: 46px;
  margin-inline: auto;
  max-width: 1183px;
  width: 100%
}
.list02__item {
  background-color: #fff;
  display: block;
  margin-top: 30px;
  padding: 20px 30px
}
.list02__item:first-child {
  margin-top: 0
}
.list02__item:nth-child(odd) {
  margin-left: 16vw
}
@media screen and (min-width:768px) {
  .list02__item:nth-child(odd) {
    margin-left: 0
  }
}
.list02__item:nth-child(2n) {
  margin-right: 16vw
}
@media screen and (min-width:768px) {
  .list02__item:nth-child(2n) {
    margin-right: 0
  }
  .list02__item {
    display: flex;
    flex-wrap: nowrap;
    margin-top: 45px;
    padding: 20px 38px
  }
}
.list02__img {
  max-width: 100%;
  width: 100%
}
@media screen and (min-width:768px) {
  .list02__img {
    max-width: 340px
  }
}
.list02__img img {
  width: 100%
}
.list02__detail {
  padding-left: 0;
  width: 100%
}
@media screen and (min-width:768px) {
  .list02__detail {
    padding-left: 45px
  }
}
.list02__head {
  align-items: center;
  border-bottom: 1.5px solid #222;
  display: flex;
  flex-wrap: nowrap;
  margin-top: 0
}
@media screen and (min-width:768px) {
  .list02__head {
    display: inline-flex;
    margin-top: -10px
  }
}
.list02__head span:first-of-type {
  color: #222;
  flex-shrink: 0;
  font-size: 2.125rem;
  font-weight: 400;
  line-height: 1.4
}
@media screen and (min-width:768px) {
  .list02__head span:first-of-type {
    font-size: 2.8125rem
  }
}
.list02__head span:nth-of-type(2) {
  color: #222;
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.3;
  margin-top: 5px;
  padding-left: 3px
}
@media screen and (min-width:768px) {
  .list02__head span:nth-of-type(2) {
    font-size: 2rem;
    margin-top: 0;
    padding-left: 13px
  }
}
.list02__txt {
  color: #222;
  font-size: .875rem;
  line-height: 155.8%;
  margin-top: 10px
}
@media screen and (min-width:768px) {
  .list02__txt {
    font-size: 1.25rem;
    line-height: 170.8%;
    margin-top: 20px
  }
}
.list03 {
  padding: 0 10px
}
.list03__item {
  display: flex;
  gap: 10px;
  margin-inline: auto;
  margin-top: 50px;
  max-width: 1140px;
  width: 100%
}
@media screen and (min-width:768px) {
  .list03__item {
    gap: 70px;
    margin-top: 125px
  }
}
.list03__left {
  display: flex;
  justify-content: space-between;
  max-width: 150px;
  width: 100%
}
@media screen and (min-width:768px) {
  .list03__left {
    max-width: 442px
  }
}
.list03__right {
  width: 100%
}
.list03__index01 {
  color: hsla(0, 0%, 61%, .7);
  display: none;
  font-size: 8.75rem;
  line-height: .5;
  white-space: nowrap
}
@media screen and (min-width:768px) {
  .list03__index01 {
    display: block
  }
}
.list03__index02 {
  color: hsla(0, 0%, 61%, .7);
  display: block;
  font-size: 2.5rem;
  line-height: 1;
  white-space: nowrap
}
@media screen and (min-width:768px) {
  .list03__index02 {
    display: none
  }
}
.list03__img {
  max-width: 100%;
  width: 100%
}
@media screen and (min-width:768px) {
  .list03__img {
    max-width: 265px
  }
}
.list03__head {
  display: flex;
  gap: 5px
}
@media screen and (min-width:768px) {
  .list03__head {
    gap: 0
  }
}
.list03__head-txt01 {
  display: block;
  font-size: .6875rem
}
@media screen and (min-width:768px) {
  .list03__head-txt01 {
    font-size: 1.3125rem;
    max-width: 265px
  }
}
.list03__head-txt02 {
  display: block;
  font-size: 1.125rem
}
@media screen and (min-width:768px) {
  .list03__head-txt02 {
    font-size: 2rem
  }
}
.list03__head-txt02--bold {
  display: block;
  font-size: 1.125rem;
  font-weight: 700
}
@media screen and (min-width:768px) {
  .list03__head-txt02--bold {
    font-size: 2rem
  }
}
.list03__desc {
  font-size: .875rem;
  line-height: 150.5%;
  margin-top: 5px
}
@media screen and (min-width:768px) {
  .list03__desc {
    font-size: 1.5rem;
    line-height: 170.8%;
    margin-top: 15px
  }
}
.list03__desc br {
  display: none
}
@media screen and (min-width:768px) {
  .list03__desc br {
    display: block
  }
}
.list03__item-reverse .list03__left {
  order: 2
}
@media screen and (min-width:768px) {
  .list03__item-reverse .list03__left {
    order: 1
  }
}
.list03__item-reverse .list03__right {
  order: 1
}
@media screen and (min-width:768px) {
  .list03__item-reverse .list03__right {
    order: 2
  }
}
.list04-wrap {
  background-color: #fff;
  margin-top: 100px;
  padding: 20px 45px
}
@media screen and (min-width:768px) {
  .list04-wrap {
    background-color: #f6f6f6;
    margin-top: 145px;
    padding: 100px 45px
  }
}
.list04 {
  margin-inline: auto;
  max-width: 1185px;
  width: 100%
}
.list04__item {
  background-color: #fff;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 50px;
  padding: 0
}
@media screen and (min-width:768px) {
  .list04__item {
    flex-wrap: nowrap;
    gap: 45px;
    margin-top: 80px;
    padding: 17px 45px
  }
}
.list04__img {
  margin-top: 10px;
  order: 2
}
@media screen and (min-width:768px) {
  .list04__img {
    margin-top: 0;
    max-width: 415px;
    order: 1;
    width: 100%
  }
}
.list04__detail {
  order: 1;
  width: 100%
}
@media screen and (min-width:768px) {
  .list04__detail {
    order: 2
  }
}
.list04__head {
  align-items: center;
  border: none;
  display: inline-flex;
  flex-wrap: nowrap;
  gap: 10px;
  margin-top: -10px;
  padding: 0 10px
}
@media screen and (min-width:768px) {
  .list04__head {
    border-bottom: 1.5px solid #222;
    gap: 10px
  }
}
.list04__index {
  color: hsla(0, 0%, 61%, .7);
  display: inline-block;
  font-size: 2.25rem;
  line-height: 1.4;
  transform: skew(-20deg);
  white-space: nowrap
}
@media screen and (min-width:768px) {
  .list04__index {
    font-size: 3rem
  }
}
.list04__head-txt {
  font-size: 1.125rem;
  margin-top: 8px
}
@media screen and (min-width:768px) {
  .list04__head-txt {
    font-size: 2rem
  }
}
.list04__txt {
  font-size: .875rem;
  line-height: 150%;
  margin-top: 10px
}
@media screen and (min-width:768px) {
  .list04__txt {
    font-size: 1.3125rem;
    line-height: 170%;
    margin-top: 20px
  }
}
.list04__txt br {
  display: none
}
@media screen and (min-width:768px) {
  .list04__txt br {
    display: block
  }
}
.list05 {
  background: none;
  margin-top: 30px;
  overflow: hidden;
  padding-top: 0
}
@media screen and (min-width:768px) {
  .list05 {
    background-color: #f6f6f6;
    padding-top: 110px
  }
}
.list05__inner01 {
  background-color: #f6f6f6;
  margin-top: 25px;
  padding: 50px 0 180px
}
@media screen and (min-width:768px) {
  .list05__inner01 {
    background-color: none;
    margin-top: 0;
    padding: 110px 0 230px
  }
}
.list05__inner02 {
  margin-inline: auto;
  max-width: 1095px;
  width: 100%
}
.list05__img-wrap {
  padding-right: 19.4871vw
}
@media screen and (min-width:768px) {
  .list05__img-wrap {
    padding-right: 0
  }
}
.list05__img {
  max-width: 589px;
  width: 100%
}
.list05__detail-wrap {
  padding-left: 19.4871vw
}
@media screen and (min-width:768px) {
  .list05__detail-wrap {
    padding-left: 0
  }
}
.list05__detail {
  background-color: hsla(0, 0%, 100%, .9);
  float: right;
  margin-bottom: 75px;
  margin-top: -35px;
  max-width: 564px;
  padding: 18px;
  position: relative;
  width: 100%;
  z-index: 1
}
@media screen and (min-width:768px) {
  .list05__detail {
    margin-bottom: 55px;
    margin-top: -155px;
    padding: 20px 34px 40px
  }
}
.list05__head {
  align-items: flex-end;
  display: flex;
  flex-wrap: nowrap
}
.list05__head-index {
  color: hsla(0, 0%, 52%, .7);
  display: block;
  font-size: 2.25rem;
  line-height: .8;
  transform: skew(-20deg);
  white-space: nowrap
}
@media screen and (min-width:768px) {
  .list05__head-index {
    font-size: 4.0384375rem;
    line-height: .9
  }
}
.list05__head-txt {
  display: block;
  font-size: 1.125rem;
  font-weight: 500;
  line-height: 1;
  padding-left: 5px
}
@media screen and (min-width:768px) {
  .list05__head-txt {
    font-size: 2.01925rem;
    padding-left: 15px
  }
}
.list05__txt01 {
  font-size: .8125rem;
  line-height: 160.8%;
  margin-top: 15px
}
@media screen and (min-width:768px) {
  .list05__txt01 {
    font-size: 1.3125rem
  }
}
.list05__txt02 {
  color: #e20000;
  font-size: .8125rem;
  line-height: 160.8%
}
@media screen and (min-width:768px) {
  .list05__txt02 {
    font-size: .96875rem
  }
}
.card01 {
  display: grid;
  grid-template: "txt01"auto "img"auto "txt02"auto/1fr;
  margin-inline: auto;
  max-width: 746px;
  padding: 0 45px;
  text-align: left;
  width: 100%
}
@media screen and (min-width:768px) {
  .card01 {
    padding: 0;
    text-align: center
  }
}
.card01__img {
  grid-area: img;
  margin: 15px 0 12px;
  padding: 0
}
@media screen and (min-width:768px) {
  .card01__img {
    margin-bottom: 13px;
    padding: 0 33px
  }
}
.card01__txt01 {
  font-size: .875rem;
  grid-area: txt01;
  line-height: 150%
}
@media screen and (min-width:768px) {
  .card01__txt01 {
    font-size: 1.5rem;
    line-height: 180%
  }
}
.card01__txt02 {
  font-size: .875rem;
  grid-area: txt02;
  line-height: 150%;
  text-align: center
}
@media screen and (min-width:768px) {
  .card01__txt02 {
    font-size: 1.5rem;
    line-height: 180%
  }
  .card01 {
    display: grid;
    grid-template: "img"auto "txt01"auto "txt02"auto/1fr
  }
}
.media-harf01 {
  display: grid;
  grid-template: "txt01"auto "img"auto "txt02"auto/1fr;
  margin-inline: auto;
  max-width: 1105px;
  padding: 0 45px;
  width: 100%
}
@media screen and (min-width:1000px) {
  .media-harf01 {
    grid-template: "img txt01"auto "img txt02"1fr/1fr 1fr;
    padding: 0 10px
  }
}
.media-harf01__img {
  grid-area: img;
  margin-top: 15px;
  max-width: 100%;
  width: 100%
}
@media screen and (min-width:1000px) {
  .media-harf01__img {
    margin-top: 0;
    max-width: 536px
  }
}
.media-harf01__txt01 {
  grid-area: txt01;
  padding-left: 0
}
@media screen and (min-width:1000px) {
  .media-harf01__txt01 {
    padding-left: 40px
  }
}
.media-harf01__txt01 p {
  color: #222;
  font-size: .875rem;
  line-height: 180%;
  margin-top: 10px
}
@media screen and (min-width:1000px) {
  .media-harf01__txt01 p {
    font-size: 1.3125rem;
    line-height: 180%;
    margin-top: 12px
  }
}
.media-harf01__txt01 p:first-child {
  margin-top: 0
}
.media-harf01__txt02 {
  color: #222;
  font-size: .875rem;
  grid-area: txt02;
  line-height: 150%;
  margin-top: 10px;
  padding-left: 0
}
@media screen and (min-width:1000px) {
  .media-harf01__txt02 {
    font-size: 1.3125rem;
    line-height: 180%;
    margin-top: 12px;
    padding-left: 40px
  }
}
.media-harf01 br {
  display: none
}
@media screen and (min-width:1000px) {
  .media-harf01 br {
    display: block
  }
}
.media-harf01 br.display-md {
  display: none
}
@media screen and (min-width:1000px) {
  .media-harf01 br.display-md {
    display: inline
  }
}
.media-harf02 {
  padding: 0 45px
}
.media-harf02__inner {
  display: grid;
  grid-template: "txt01"auto "txt02"auto "img"auto "txt03"auto "imgdesc"auto;
  margin-inline: auto;
  max-width: 1095px;
  width: 100%
}
@media screen and (min-width:950px) {
  .media-harf02__inner {
    grid-template: "img txt01"auto "img txt02"auto "img txt03"auto "imgdesc txt03"1fr/auto auto
  }
}
.media-harf02__img {
  grid-area: img;
  margin-inline: auto;
  margin-top: 15px;
  max-width: 100%;
  width: 100%
}
@media screen and (min-width:950px) {
  .media-harf02__img {
    margin-top: 0;
    max-width: 528px
  }
}
.media-harf02__img img {
  width: 100%
}
.media-harf02__img-desc {
  font-size: .625rem;
  grid-area: imgdesc;
  line-height: 150.5%;
  margin-top: 15px;
  max-width: 528px;
  width: 100%
}
@media screen and (min-width:768px) {
  .media-harf02__img-desc {
    font-size: .8125rem;
    line-height: 150.5%;
    margin-top: 0
  }
}
.media-harf02__txt01 {
  font-size: .875rem;
  grid-area: txt01;
  line-height: 150%;
  padding-left: 0;
  text-align: justify;
  width: 100%
}
@media screen and (min-width:768px) {
  .media-harf02__txt01 {
    font-size: 1.3125rem;
    line-height: 180%;
    padding-left: 65px
  }
}
.media-harf02__txt02 {
  font-size: .875rem;
  grid-area: txt02;
  line-height: 150%;
  margin-top: 15px;
  padding-left: 0;
  text-align: justify
}
@media screen and (min-width:768px) {
  .media-harf02__txt02 {
    font-size: 1.3125rem;
    line-height: 180%;
    margin-top: 19px;
    padding-left: 65px
  }
}
.media-harf02__txt03 {
  font-size: .875rem;
  grid-area: txt03;
  line-height: 150%;
  margin-top: 15px;
  padding-left: 0;
  text-align: justify
}
@media screen and (min-width:768px) {
  .media-harf02__txt03 {
    font-size: 1.3125rem;
    line-height: 180%;
    margin-top: 19px;
    padding-left: 65px
  }
}
.media-harf03 {
  padding: 0 45px
}
.media-harf03__inner {
  display: grid;
  grid-template: "txt01"auto "img"auto "txt02"auto "txt03"auto "imgdesc"auto;
  margin-inline: auto;
  max-width: 1116px;
  width: 100%
}
@media screen and (min-width:950px) {
  .media-harf03__inner {
    grid-template: "img txt01"auto "img txt02"auto "img txt03"auto "imgdesc txt03"1fr/auto auto
  }
}
.media-harf03__img {
  grid-area: img;
  margin-inline: auto;
  margin-top: 15px;
  max-width: 528px;
  width: 100%
}
@media screen and (min-width:950px) {
  .media-harf03__img {
    margin-top: 0
  }
}
.media-harf03__img img {
  width: 100%
}
.media-harf03__img-desc {
  font-size: .625rem;
  grid-area: imgdesc;
  line-height: 150.5%;
  margin-top: 15px;
  max-width: 528px;
  width: 100%
}
@media screen and (min-width:768px) {
  .media-harf03__img-desc {
    font-size: .8125rem;
    line-height: 150.5%;
    margin-top: 0
  }
}
.media-harf03__txt01 {
  font-size: .875rem;
  grid-area: txt01;
  line-height: 150%;
  margin-top: 0;
  padding-left: 0;
  text-align: justify;
  width: 100%
}
@media screen and (min-width:768px) {
  .media-harf03__txt01 {
    font-size: 1.3125rem;
    line-height: 180%;
    margin-top: -10px;
    padding-left: 55px
  }
}
.media-harf03__txt02 {
  font-size: .875rem;
  grid-area: txt02;
  line-height: 150%;
  margin-top: 15px;
  padding-left: 0;
  text-align: justify
}
@media screen and (min-width:768px) {
  .media-harf03__txt02 {
    font-size: 1.3125rem;
    line-height: 180%;
    margin-top: 0;
    padding-left: 55px
  }
}
.media-harf03__txt03 {
  font-size: .875rem;
  grid-area: txt03;
  line-height: 150%;
  margin-top: 15px;
  padding-left: 0;
  text-align: justify
}
@media screen and (min-width:768px) {
  .media-harf03__txt03 {
    font-size: 1.3125rem;
    line-height: 180%;
    margin-top: 0;
    padding-left: 55px
  }
}
.media-harf04 {
  align-items: start;
  display: grid;
  gap: 0 39px;
  grid-template: "txt01"auto "img"auto "txt02"1fr/auto;
  margin-inline: auto;
  margin-top: 20px;
  max-width: 1095px;
  width: 100%
}
@media screen and (min-width:1000px) {
  .media-harf04 {
    align-items: flex-end;
    display: grid;
    grid-template: "txt01 img"1fr "txt02 img"1fr/auto minmax(200px, 545px);
    margin-top: 45px
  }
}
.media-harf04:first-child {
  margin-top: 20px
}
@media screen and (min-width:1000px) {
  .media-harf04:first-child {
    margin-top: 80px
  }
}
.media-harf04__img {
  grid-area: img;
  margin-top: 15px
}
@media screen and (min-width:1000px) {
  .media-harf04__img {
    margin-top: 0
  }
}
.media-harf04__img img {
  width: 100%
}
.media-harf04__txt01 {
  font-size: .875rem;
  grid-area: txt01;
  line-height: 150%;
  text-align: justify;
  width: 100%
}
@media screen and (min-width:1000px) {
  .media-harf04__txt01 {
    font-size: 1.3125rem;
    line-height: 180%
  }
}
.media-harf04__txt02 {
  align-self: flex-start;
  font-size: .875rem;
  grid-area: txt02;
  line-height: 150%;
  margin-top: 5px;
  text-align: justify;
  width: 100%
}
@media screen and (min-width:1000px) {
  .media-harf04__txt02 {
    font-size: 1.3125rem;
    line-height: 180%;
    margin-top: 0
  }
}
.media-harf05 {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-inline: auto;
  margin-top: 20px;
  max-width: 1095px;
  width: 100%
}
@media screen and (min-width:1000px) {
  .media-harf05 {
    flex-wrap: nowrap;
    gap: 48px;
    margin-top: 45px
  }
}
.media-harf05__img {
  max-width: 100%;
  width: 100%
}
@media screen and (min-width:1000px) {
  .media-harf05__img {
    max-width: 509px
  }
}
.media-harf05__detail, .media-harf05__img img {
  width: 100%
}
.media-harf05__txt01 {
  font-size: .875rem;
  line-height: 150%;
  text-align: justify
}
@media screen and (min-width:1000px) {
  .media-harf05__txt01 {
    font-size: 1.3125rem;
    line-height: 180%
  }
}
.media-harf06 {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  margin-inline: auto;
  max-width: 1120px;
  padding: 0;
  width: 100%
}
@media screen and (min-width:1000px) {
  .media-harf06 {
    flex-wrap: nowrap;
    gap: 65px;
    padding: 0 20px
  }
}
.media-harf06__img {
  max-width: 100%;
  order: 2;
  padding-right: 23vw;
  width: 100%
}
@media screen and (min-width:1000px) {
  .media-harf06__img {
    max-width: 506px;
    order: 1;
    padding-right: 0
  }
}
.media-harf06__img img {
  width: 100%
}
.media-harf06__detail {
  order: 1;
  width: 100%
}
@media screen and (min-width:1000px) {
  .media-harf06__detail {
    order: 2
  }
}
.media-harf06__head {
  display: block;
  margin-top: 0;
  position: relative
}
@media screen and (min-width:1000px) {
  .media-harf06__head {
    margin-top: -20px
  }
}
.media-harf06__head-en {
  color: hsla(0, 0%, 61%, .25);
  display: inline-block;
  font-size: 4rem;
  line-height: 1;
  position: static;
  text-align: left;
  transform: skew(-20deg);
  white-space: nowrap
}
@media screen and (min-width:400px) {
  .media-harf06__head-en {
    display: block;
    left: -75px;
    position: relative;
    text-align: center
  }
}
@media screen and (min-width:1000px) {
  .media-harf06__head-en {
    display: inline-block;
    font-size: 7.75rem;
    position: static
  }
}
.media-harf06__head-en02 {
  color: hsla(0, 0%, 61%, .25);
  display: block;
  font-size: 4rem;
  line-height: 1;
  position: static;
  text-align: right;
  transform: skew(-20deg);
  white-space: nowrap
}
@media screen and (min-width:400px) {
  .media-harf06__head-en02 {
    display: block;
    position: relative;
    right: -115px;
    text-align: center
  }
}
@media screen and (min-width:1000px) {
  .media-harf06__head-en02 {
    display: inline-block;
    font-size: 7.75rem;
    position: static
  }
}
.media-harf06__head-ja {
  bottom: 0;
  font-size: 1.5rem;
  font-weight: 500;
  left: 50%;
  position: absolute;
  right: auto;
  transform: translateX(-50%);
  white-space: nowrap
}
@media screen and (min-width:1000px) {
  .media-harf06__head-ja {
    font-size: 2.25rem;
    left: auto;
    right: 70px;
    transform: translateX(0)
  }
}
.media-harf06__txt01 {
  font-size: .875rem;
  line-height: 150%;
  margin-top: 15px;
  padding: 0 45px;
  text-align: justify
}
@media screen and (min-width:1000px) {
  .media-harf06__txt01 {
    font-size: 1.3125rem;
    margin-top: 60px;
    padding: 0
  }
}
.media-harf07 {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  margin-inline: auto;
  margin-top: 20px;
  max-width: 1095px;
  width: 100%
}
@media screen and (min-width:1000px) {
  .media-harf07 {
    flex-wrap: nowrap
  }
}
.media-harf07__txt01 {
  font-size: .875rem;
  line-height: 150%;
  margin-top: 15px;
  order: 2;
  padding: 0 45px;
  width: 100%
}
@media screen and (min-width:1000px) {
  .media-harf07__txt01 {
    font-size: 1.3125rem;
    line-height: 180%;
    margin-top: 0;
    order: 1;
    padding: 0 48px 0 0;
    text-align: justify
  }
}
.media-harf07__txt02 {
  font-size: .875rem;
  line-height: 150%;
  margin-top: 15px;
  order: 2;
  padding: 0 45px;
  width: 100%
}
@media screen and (min-width:1000px) {
  .media-harf07__txt02 {
    font-size: 1.3125rem;
    line-height: 180%;
    margin-top: 0;
    order: 1;
    padding: 0 70px 0 0;
    text-align: justify
  }
}
.media-harf07__img {
  max-width: 100%;
  order: 1;
  padding-left: 23vw;
  width: 100%
}
@media screen and (min-width:1000px) {
  .media-harf07__img {
    max-width: 537px;
    order: 2;
    padding-left: 0
  }
}
.media-harf07__img img {
  width: 100%
}
.cta {
  background-color: #f0f0f0;
  padding: 34px 20px 30px;
  text-align: center
}
.cta__contact {
  display: block;
  height: 37px;
  margin-inline: auto;
  margin-top: 10px;
  width: 222px
}
@media screen and (min-width:768px) {
  .cta__contact {
    height: 72px;
    width: 428px
  }
}
.cta__contact a {
  align-items: center;
  background: #30366d;
  border-radius: 5px;
  color: #fff;
  display: flex;
  font-size: .75rem;
  font-weight: 400;
  height: 100%;
  justify-content: center;
  line-height: 1;
  padding: 8px 5px 5px;
  width: 100%
}
@media screen and (min-width:768px) {
  .cta__contact a {
    border-radius: 11.3px;
    font-size: 1.5rem
  }
}
.cta__tel {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-inline: auto;
  margin-top: 10px;
  max-width: 200px;
  width: 100%
}
@media screen and (min-width:768px) {
  .cta__tel {
    margin-top: 10px;
    max-width: 297px
  }
}
.cta__tel-icon {
  align-items: center;
  display: flex
}
.cta__tel-icon img {
  height: 32px;
  width: 20px
}
@media screen and (min-width:768px) {
  .cta__tel-icon img {
    height: 50px;
    width: 34px
  }
}
.cta__tel-detail {
  margin-top: -3px
}
@media screen and (min-width:768px) {
  .cta__tel-detail {
    margin-top: -10px
  }
}
.cta__tel-num {
  color: #30366d;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.2
}
@media screen and (min-width:768px) {
  .cta__tel-num {
    font-size: 1.5rem
  }
}
.cta__tel-txt {
  color: #30366d;
  font-size: .6875rem;
  font-weight: 500;
  line-height: 1;
  margin-top: 5px
}
@media screen and (min-width:768px) {
  .cta__tel-txt {
    font-size: 1rem
  }
}
.cta02 {
  background-color: #f0f0f0;
  padding: 34px 20px 30px;
  text-align: center
}
.cta02__txt01 {
  font-size: .875rem;
  text-align: center
}
@media screen and (min-width:768px) {
  .cta02__txt01 {
    font-size: 1.5rem
  }
}
.cta02__txt01 span {
  position: relative;
  z-index: 2
}
.cta02__txt01 span:before {
  background: linear-gradient(transparent 30%, rgba(250, 255, 0, .6) 0) no-repeat;
  bottom: -3px;
  content: "";
  display: block;
  height: 20px;
  left: 0;
  position: absolute;
  width: 100%;
  z-index: -1
}
.cta02__txt02 {
  color: #30366d;
  font-size: .6875rem;
  font-weight: 500
}
@media screen and (min-width:768px) {
  .cta02__txt02 {
    font-size: 1.125rem
  }
}
.cta02__contact {
  display: block;
  height: 37px;
  margin-inline: auto;
  margin-top: 10px;
  width: 222px
}
@media screen and (min-width:768px) {
  .cta02__contact {
    height: 72px;
    margin-top: 20px;
    width: 428px
  }
}
.cta02__contact a {
  align-items: center;
  background: #30366d;
  border-radius: 5px;
  color: #fff;
  display: flex;
  font-size: .75rem;
  font-weight: 400;
  height: 100%;
  justify-content: center;
  line-height: 1;
  padding: 8px 5px 5px;
  width: 100%
}
@media screen and (min-width:768px) {
  .cta02__contact a {
    border-radius: 11.3px;
    font-size: 1.5rem
  }
}
.cta02__tel {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-inline: auto;
  margin-top: 10px;
  max-width: 200px;
  width: 100%
}
@media screen and (min-width:768px) {
  .cta02__tel {
    margin-top: 10px;
    max-width: 297px
  }
}
.cta02__tel-icon {
  align-items: center;
  display: flex
}
.cta02__tel-icon img {
  height: 32px;
  width: 20px
}
@media screen and (min-width:768px) {
  .cta02__tel-icon img {
    height: 50px;
    width: 34px
  }
}
.cta02__tel-detail {
  margin-top: -3px
}
@media screen and (min-width:768px) {
  .cta02__tel-detail {
    margin-top: -10px
  }
}
.cta02__tel-num {
  color: #30366d;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.2
}
@media screen and (min-width:768px) {
  .cta02__tel-num {
    font-size: 1.5rem
  }
}
.cta02__tel-txt {
  color: #30366d;
  font-size: .6875rem;
  font-weight: 500;
  line-height: 1;
  margin-top: 5px
}
@media screen and (min-width:768px) {
  .cta02__tel-txt {
    font-size: 1rem
  }
}
.cta02--bg-white {
  background-color: #fff
}
.cta03 {
  background-color: #f0f0f0;
  padding: 34px 20px 30px;
  text-align: center
}
.cta03__txt01 {
  font-size: .875rem;
  text-align: center
}
@media screen and (min-width:768px) {
  .cta03__txt01 {
    font-size: 1.5rem
  }
}
.cta03__txt01 span {
  position: relative;
  z-index: 2
}
.cta03__txt01 span:before {
  background: linear-gradient(transparent 30%, rgba(250, 255, 0, .6) 0) no-repeat;
  bottom: -3px;
  content: "";
  display: block;
  height: 20px;
  left: 0;
  position: absolute;
  width: 100%;
  z-index: -1
}
.cta03__contact {
  display: block;
  height: 37px;
  margin-inline: auto;
  margin-top: 10px;
  width: 266px
}
@media screen and (min-width:768px) {
  .cta03__contact {
    height: 72px;
    width: 428px
  }
}
.cta03__contact a {
  align-items: center;
  background: #30366d;
  border-radius: 5px;
  color: #fff;
  display: flex;
  font-size: .75rem;
  font-weight: 400;
  height: 100%;
  justify-content: center;
  line-height: 1;
  padding: 8px 5px 5px;
  width: 100%
}
@media screen and (min-width:768px) {
  .cta03__contact a {
    border-radius: 11.3px;
    font-size: 1.5rem
  }
}
.cta03__tel {
  margin-top: 8px
}
@media screen and (min-width:768px) {
  .cta03__tel {
    margin-top: 12px
  }
}
.cta03__tel-item {
  border-top: 1px solid #30366d;
  margin-inline: auto;
  max-width: 250px;
  padding: 5px 0 7px;
  width: 100%
}
@media screen and (min-width:768px) {
  .cta03__tel-item {
    border-top: 2px solid #30366d;
    max-width: 430px;
    padding: 8px 0 11px
  }
}
.cta03__tel-item:first-child {
  border-top: none
}
.cta03__tel-item-link {
  text-wrap: nowrap;
  color: #30366d;
  display: block;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1
}
@media screen and (min-width:768px) {
  .cta03__tel-item-link {
    font-size: 2rem
  }
}
.cta03__tel-item-link span {
  letter-spacing: .15em
}
.cta03__txt02 {
  color: #30366d;
  font-size: .75rem;
  font-weight: 500;
  line-height: 1;
  margin-top: 0
}
@media screen and (min-width:768px) {
  .cta03__txt02 {
    font-size: 1.25rem;
    margin-top: 5px
  }
}
.cta03--bg-white {
  background-color: #fff
}
.bg__color-gray {
  background-color: #f0f0f0
}
.bg__color-gray02 {
  background-color: #f6f6f6
}
/*!
 * Accordion v3.1.1
 * Simple accordion created in pure Javascript.
 * https://github.com/michu2k/Accordion
 *
 * Copyright (c) Michał Strumpf
 * Published under MIT License
 */ .ac .ac-trigger {
  cursor: pointer;
  position: relative;
  transition: color .25s ease
}
.ac .ac-trigger:after {
  background-image: url(../assets/images/lp/icon-arrow.png);
  background-repeat: no-repeat;
  background-size: 19px 11px;
  content: "";
  height: 11px;
  position: absolute;
  right: 10px;
  text-align: center;
  top: 50%;
  transform: translateY(-50%) rotate(0deg);
  transition: all .5s;
  width: 19px
}
@media screen and (min-width:768px) {
  .ac .ac-trigger:after {
    background-size: 37px 20px;
    height: 20px;
    width: 37px
  }
}
.ac .ac-trigger:focus {
  color: #8a8a8a
}
.ac .ac-panel {
  overflow: hidden
}
.ac.js-enabled .ac-panel {
  visibility: hidden
}
.ac.is-active .ac-panel {
  visibility: visible
}
.ac.is-active > .ac-trigger:after {
  background-image: url(../assets/images/lp/icon-arrow.png);
  content: "";
  transform: translateY(-50%) rotate(180deg)
}
.faq-wrap {
  padding: 0 20px
}
.faq {
  margin-bottom: 45px;
  margin-inline: auto;
  max-width: 700px;
  width: 100%
}
@media screen and (min-width:768px) {
  .faq {
    margin-bottom: 90px
  }
}
.faq:last-child {
  margin-bottom: 0
}
.faq__row {
  display: flex
}
.faq__row--question {
  border-bottom: 1px solid #222;
  padding-right: 30px
}
@media screen and (min-width:768px) {
  .faq__row--question {
    border-bottom: 2px solid #222
  }
}
.faq__row--question:hover {
  opacity: .7
}
.faq__row--answer {
  margin-top: 10px
}
@media screen and (min-width:768px) {
  .faq__row--answer {
    margin-top: 20px
  }
}
.faq__icon {
  align-items: baseline;
  display: flex;
  flex-shrink: 0;
  font-size: 1.3675625rem;
  height: auto;
  justify-content: center;
  width: 38px
}
@media screen and (min-width:768px) {
  .faq__icon {
    font-size: 2.7396875rem;
    min-height: 75px;
    width: 77px
  }
}
.faq__icon--question {
  background-color: #30366d;
  color: #fff
}
.faq__icon--answer {
  background-color: #ffe5e5;
  color: #1f2356
}
.faq__text {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  min-height: 35px;
  padding-left: 15px
}
@media screen and (min-width:768px) {
  .faq__text {
    min-height: 70px;
    padding-left: 24px
  }
}
.faq__text--question {
  font-size: .8889375rem
}
@media screen and (min-width:768px) {
  .faq__text--question {
    font-size: 1.7808125rem
  }
}
.faq__text--answer {
  font-size: .8889375rem;
  padding-left: 0
}
@media screen and (min-width:768px) {
  .faq__text--answer {
    font-size: 1.7808125rem
  }
}
.faq__tel, .faq__text--answer a {
  color: #185eba;
  text-decoration: underline;
  -webkit-text-decoration-skip-ink: none;
  text-decoration-skip-ink: none
}
.faq__cardicon {
  display: inline;
  height: 20px
}
.c-form-wrap {
  padding: 80px 45px 0
}
.c-form-wrap input, .c-form-wrap select, .c-form-wrap textarea {
  font-feature-settings: normal;
  color: #222;
  font-family: Noto Sans JP, sans-serif
}
.c-form__wrap02 {
  margin-inline: auto;
  max-width: 1000px;
  width: 100%
}
.c-form__title {
  font-size: 1.5rem;
  text-align: center
}
@media screen and (min-width:768px) {
  .c-form__title {
    font-size: 2rem
  }
}
.c-form__txt01 {
  font-size: .8125rem;
  margin-top: 14px;
  text-align: center
}
@media screen and (min-width:768px) {
  .c-form__txt01 {
    font-size: 1.3125rem;
    margin-top: 50px
  }
}
.c-form {
  border: 5px solid #5d63b8;
  margin-top: 30px
}
@media screen and (min-width:768px) {
  .c-form {
    margin-top: 75px
  }
}
.c-form__item {
  border-bottom: 1px solid #cecebf;
  display: flex;
  flex-wrap: wrap
}
@media screen and (min-width:768px) {
  .c-form__item {
    flex-wrap: nowrap
  }
}
.c-form__item:last-child {
  border-bottom: none
}
.c-form__item--full {
  flex-wrap: wrap
}
.c-form__item--full .c-form__head {
  flex-wrap: wrap;
  justify-content: center;
  max-width: 100%
}
@media screen and (min-width:768px) {
  .c-form__item--full .c-form__head {
    justify-content: start
  }
}
.c-form__item--full .c-form__head .c-form__name {
  text-align: center;
  width: 100%
}
@media screen and (min-width:768px) {
  .c-form__item--full .c-form__head .c-form__name {
    text-align: left;
    width: auto
  }
}
.c-form__item--full .c-form__head .c-form__required {
  margin-left: 5px;
  margin-top: 3px;
  width: 100%
}
@media screen and (min-width:768px) {
  .c-form__item--full .c-form__head .c-form__required {
    margin-top: 0;
    width: auto
  }
}
.c-form__item--full .c-form__head .c-form__optional {
  margin-left: 5px;
  margin-top: 3px
}
@media screen and (min-width:768px) {
  .c-form__item--full .c-form__head .c-form__optional {
    margin-top: 0;
    width: auto
  }
}
.c-form__item--full .c-form__input-wrap {
  display: block;
  max-width: 100%;
  width: 100%
}
.c-form__head {
  align-items: center;
  background-color: #eef0fb;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  max-width: 100%;
  padding: 15px 10px;
  width: 100%
}
@media screen and (min-width:768px) {
  .c-form__head {
    justify-content: space-between;
    max-width: 270px
  }
}
.c-form__name {
  font-weight: 700
}
.c-form__required {
  background-color: red;
  border-radius: 5px;
  color: #fff;
  display: block;
  font-size: .75rem;
  font-weight: 700;
  height: 23px;
  line-height: 1.5;
  margin-left: 10px;
  margin-right: 5px;
  min-width: 40px;
  padding: 2px 5.5px 2.4px;
  text-align: center
}
@media screen and (min-width:768px) {
  .c-form__required {
    margin-left: 0
  }
}
.c-form__optional {
  background-color: #00a3d9;
  border-radius: 5px;
  color: #fff;
  display: block;
  font-size: .75rem;
  font-weight: 700;
  height: 23px;
  line-height: 1.5;
  margin-left: 10px;
  margin-right: 5px;
  min-width: 40px;
  padding: 2px 5.5px 2.4px;
  text-align: center
}
@media screen and (min-width:768px) {
  .c-form__optional {
    margin-left: 0
  }
}
.c-form__input-wrap {
  border-left: 1px solid #cecebf;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  padding: 15px 10px;
  width: 100%
}
@media screen and (min-width:768px) {
  .c-form__input-wrap {
    flex-wrap: nowrap;
    justify-content: start
  }
}
.c-form__input-inner {
  align-items: center;
  display: flex;
  justify-content: center;
  margin-right: 0;
  margin-top: 12px;
  width: 100%
}
@media screen and (min-width:768px) {
  .c-form__input-inner {
    justify-content: start;
    margin-right: 20px;
    margin-top: 0;
    width: auto
  }
}
.c-form__input-inner:first-child {
  margin-top: 0
}
.c-form__input-txt {
  margin-right: 10px;
  word-break: keep-all
}
@media screen and (min-width:768px) {
  .c-form__input-txt {
    margin-right: 25px
  }
}
.c-form__input-txt-kana {
  margin-right: 10px
}
.c-form__input {
  text-align: center
}
@media screen and (min-width:768px) {
  .c-form__input {
    text-align: left
  }
}
.c-form__input .age input {
  text-align: right
}
.c-form__input input {
  border: 1px solid #cecebf;
  border-radius: 5px;
  font-size: 1.125rem;
  height: 30px;
  margin-right: 5px;
  max-width: 200px;
  padding: 0 5px;
  width: 100%
}
.c-form__input input:focus {
  border: 2px solid #6d6d5d !important
}
.c-form__input input::-moz-placeholder {
  font-size: 1rem
}
.c-form__input input::placeholder {
  font-size: 1rem
}
.c-form__input input[type=tel] {
  border: 1px solid #cecebf;
  border-radius: 5px;
  height: 30px;
  max-width: 200px;
  padding: 0 5px;
  width: 100%
}
.c-form__input input[type=tel]:focus {
  border: 2px solid #6d6d5d !important
}
.c-form__input input[type=tel]:focus-visible {
  border: none;
  outline: none
}
.c-form__input input[type=email] {
  border: 1px solid #cecebf;
  border-radius: 5px;
  height: 30px;
  max-width: 200px;
  padding: 0 5px;
  width: 100%
}
.c-form__input input[type=email]:focus {
  border: 2px solid #6d6d5d !important
}
.c-form__input input[type=email]:focus-visible {
  border: none;
  outline: none
}
.c-form__input textarea {
  border: 1px solid #cecebf;
  border-radius: 5px;
  font-size: 1.125rem;
  height: 150px;
  margin-right: 5px;
  max-width: 100%;
  padding: 5px;
  width: 100%
}
.c-form__input textarea:focus {
  border: 2px solid #6d6d5d !important
}
.c-form__input--small input, .c-form__input--small input[type=email] {
  max-width: 100px
}
.c-form__input--large input, .c-form__input--large input[type=email] {
  max-width: 600px
}
.c-form__input--full input {
  max-width: 100%
}
.c-form__birthday {
  flex-wrap: wrap
}
@media screen and (min-width:768px) {
  .c-form__birthday {
    flex-wrap: nowrap
  }
}
.c-form__birthday .c-form__input {
  margin-right: 0;
  margin-top: 10px;
  max-width: 100%;
  text-align: center;
  width: 100%
}
.c-form__birthday .c-form__input:first-child {
  margin-top: 0
}
@media screen and (min-width:768px) {
  .c-form__birthday .c-form__input {
    margin-right: 15px;
    margin-top: 0;
    max-width: 125px;
    text-align: left
  }
}
.c-form__birthday input {
  text-align: right
}
.c-form__input-select .wpcf7-form-control-wrap {
  align-items: center;
  border: 1px solid #cecebf;
  border-radius: 5px;
  display: flex;
  height: 30px;
  max-width: 220px;
  position: relative;
  z-index: 1
}
.c-form__input-select .wpcf7-form-control-wrap:after {
  border-bottom: 2px solid #cecebf;
  border-right: 2px solid #cecebf;
  content: "";
  height: 8px;
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  width: 8px;
  z-index: -1
}
.c-form__input-select select {
  font-size: 1rem;
  height: 100%;
  padding: 0 10px;
  width: 220px
}
.c-form__radio .wpcf7-list-item {
  margin: 0 1em 0 0
}
.c-form__radio .wpcf7-list-item-label {
  cursor: pointer;
  display: flex
}
.c-form__radio input[type=radio] {
  opacity: 0;
  position: absolute
}
.c-form__radio .wpcf7-list-item-label:before {
  background: #fff;
  border: 1px solid #333;
  border-radius: 100%;
  content: "";
  height: 1.2em;
  margin-bottom: auto;
  margin-right: .5em;
  margin-top: auto;
  width: 1.2em
}
.c-form__radio input[type=radio]:checked + .wpcf7-list-item-label:before {
  background-color: #5d63b8;
  box-shadow: inset 0 0 0 3px #fff
}
.c-form .c-form_textarea {
  width: 100%
}
.c-form .c-form_textarea .wpcf7-textarea {
  line-height: 1.5
}
.c-form__privacy-head {
  background-color: #e7e7e7;
  border-bottom: 1px solid #cecebf;
  color: #333;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.5;
  padding: 20px 10px;
  width: 100%
}
.c-form__privacy-desc {
  display: flex;
  flex-wrap: nowrap;
  padding: 15px 10px
}
.c-form__privacy-checkbox a {
  color: #5d63b8;
  font-weight: 700;
  text-decoration: underline;
  -webkit-text-decoration-skip-ink: none;
  text-decoration-skip-ink: none
}
.c-form__privacy-checkbox a:hover {
  opacity: .8
}
.c-form__privacy-checkbox .wpcf7-form-control.wpcf7-checkbox {
  display: flex;
  flex-wrap: wrap
}
.c-form__privacy-checkbox span.wpcf7-list-item {
  margin: 0 20px 0 0;
  position: relative
}
.c-form__privacy-checkbox .wpcf7-list-item-label {
  cursor: pointer
}
.c-form__privacy-checkbox input[type=checkbox] {
  opacity: 0;
  position: absolute
}
.c-form__privacy-checkbox .wpcf7-list-item-label:before {
  border: 2px solid #7e7e7b;
  content: "";
  cursor: pointer;
  display: inline-block;
  height: 20px;
  margin-right: 10px;
  position: relative;
  text-align: center;
  top: -2px;
  vertical-align: middle;
  width: 20px
}
.c-form__privacy-checkbox input[type=checkbox]:checked + .wpcf7-list-item-label:after {
  border-bottom: 3px solid #5d63b8;
  border-right: 3px solid #5d63b8;
  content: "";
  display: block;
  height: 18px;
  left: 7px;
  position: absolute;
  top: -4px;
  transform: rotate(40deg);
  width: 11px
}
.c-form__submit-wrap {
  margin-top: 50px
}
.c-form__submit p {
  display: flex;
  width: 100%
}
.c-form__submit p input {
  background-color: #5d63b8;
  border-radius: 5px;
  color: #fff;
  cursor: pointer;
  font-size: 1.25rem;
  font-weight: 700;
  height: 50px;
  margin: 0 auto;
  max-width: 200px;
  text-align: center;
  width: 100%
}
.c-form__submit p input:hover {
  opacity: .9;
  transition: all .3s
}
.c-form__prev p {
  margin-top: 20px
}
.c-form__prev p input {
  background-color: #5d63b8;
  border: none !important;
  border-radius: 5px;
  color: #fff;
  cursor: pointer;
  display: block;
  font-size: 1.25rem;
  font-weight: 700;
  height: 50px;
  margin: 0 auto;
  max-width: 200px;
  text-align: center;
  width: 100%
}
.c-form__prev p input:hover {
  opacity: .9;
  transition: all .3s
}
.wpcf7-spinner {
  display: none !important
}
.c-form-thanks {
  margin-top: 50px;
  text-align: center
}
.c-form-thanks__txt01 {
  font-size: 1.5625rem
}
.c-form-thanks__txt02 {
  font-size: 1rem;
  line-height: 1.8;
  margin-bottom: 20px;
  margin-top: 20px
}
.c-form-thanks a {
  text-align: center;
  text-decoration: underline;
  -webkit-text-decoration-skip-ink: none;
  text-decoration-skip-ink: none
}
.c-gototop {
  bottom: 20px;
  font-size: 1.2em;
  line-height: 1;
  position: fixed;
  right: 15px;
  transition: opacity .35s ease;
  z-index: 5
}
.c-gototop span {
  background-image: url(../assets/images/lp/icon-gototop.png);
  background-position: 50%;
  background-size: cover;
  border: 1px solid #fff;
  border-radius: 50%;
  bottom: 5px;
  cursor: pointer;
  display: block;
  height: 42px;
  position: relative;
  width: 42px;
  z-index: 999
}
@media screen and (min-width:385px) {
  .c-gototop span {
    bottom: 68px
  }
}
@media screen and (min-width:768px) {
  .c-gototop span {
    bottom: 80px;
    height: 55px;
    width: 55px
  }
}
.c-gototop.is-hide {
  opacity: 0
}
.c-form02-wrap {
  padding: 80px 45px 0
}
.c-form02-wrap input, .c-form02-wrap select, .c-form02-wrap textarea {
  font-feature-settings: normal;
  color: #222;
  font-family: Noto Sans JP, sans-serif
}
.c-form02-wrap02 {
  margin-inline: auto;
  max-width: 1000px;
  width: 100%
}
.c-form02-inner {
  border: 5px solid #5d63b8;
  margin-top: 20px
}
.c-form02__item {
  border-bottom: 1px solid #cecebf;
  display: flex;
  flex-wrap: wrap
}
@media screen and (min-width:768px) {
  .c-form02__item {
    flex-wrap: nowrap
  }
}
.c-form02__item:last-child {
  border-bottom: none
}
.c-form02__item--full {
  flex-wrap: wrap
}
.c-form02__item--full .c-form02__head {
  flex-wrap: wrap;
  justify-content: center;
  max-width: 100%
}
@media screen and (min-width:768px) {
  .c-form02__item--full .c-form02__head {
    justify-content: start
  }
}
.c-form02__item--full .c-form02__head .c-form02__name {
  text-align: center;
  width: 100%
}
@media screen and (min-width:768px) {
  .c-form02__item--full .c-form02__head .c-form02__name {
    text-align: left;
    width: auto
  }
}
.c-form02__item--full .c-form02__head .c-form02__required {
  margin-left: 5px;
  margin-top: 3px;
  width: 100%
}
@media screen and (min-width:768px) {
  .c-form02__item--full .c-form02__head .c-form02__required {
    margin-top: 0;
    width: auto
  }
}
.c-form02__item--full .c-form02__head .c-form02__optional {
  margin-left: 5px;
  margin-top: 3px
}
@media screen and (min-width:768px) {
  .c-form02__item--full .c-form02__head .c-form02__optional {
    margin-top: 0;
    width: auto
  }
}
.c-form02__item--full .c-form02__input-wrap {
  display: block;
  max-width: 100%;
  width: 100%
}
.c-form02__txt01 {
  font-size: .8125rem;
  margin-top: 14px;
  text-align: center
}
@media screen and (min-width:768px) {
  .c-form02__txt01 {
    font-size: 1.3125rem;
    margin-top: 50px
  }
}
.c-form02__title {
  font-size: 1.5rem;
  text-align: center
}
@media screen and (min-width:768px) {
  .c-form02__title {
    font-size: 2rem
  }
}
.c-form02__error-msg {
  color: #dc3232;
  font-size: 1em;
  font-weight: 400;
  text-align: center
}
@media screen and (min-width:768px) {
  .c-form02__error-msg {
    text-align: left
  }
}
.c-form02 input.error, .c-form02 input[type=email].error, .c-form02 input[type=tel].error, .c-form02 textarea.error {
  background-color: #f6cffc;
  border: 2px solid #4f4f4f;
  margin-bottom: 2px
}
.c-form02__errors-message {
  color: #dc3232;
  margin-top: 20px;
  text-align: left
}
@media screen and (min-width:768px) {
  .c-form02__errors-message {
    text-align: center
  }
}
.c-form02 .server-error {
  color: #dc3232
}
.c-form02__head {
  align-items: center;
  background-color: #eef0fb;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  max-width: 100%;
  padding: 15px 10px;
  width: 100%
}
@media screen and (min-width:768px) {
  .c-form02__head {
    justify-content: space-between;
    max-width: 270px
  }
}
.c-form02__name {
  font-weight: 700
}
.c-form02__required {
  background-color: red;
  border-radius: 5px;
  color: #fff;
  display: block;
  font-size: .75rem;
  font-weight: 700;
  height: 23px;
  line-height: 1.5;
  margin-left: 10px;
  margin-right: 5px;
  min-width: 40px;
  padding: 2px 5.5px 2.4px;
  text-align: center
}
@media screen and (min-width:768px) {
  .c-form02__required {
    margin-left: 0
  }
}
.c-form02__optional {
  background-color: #00a3d9;
  border-radius: 5px;
  color: #fff;
  display: block;
  font-size: .75rem;
  font-weight: 700;
  height: 23px;
  line-height: 1.5;
  margin-left: 10px;
  margin-right: 5px;
  min-width: 40px;
  padding: 2px 5.5px 2.4px;
  text-align: center
}
@media screen and (min-width:768px) {
  .c-form02__optional {
    margin-left: 0
  }
}
.c-form02__input-wrap {
  border-left: 1px solid #cecebf;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  padding: 15px 10px;
  width: 100%
}
@media screen and (min-width:768px) {
  .c-form02__input-wrap {
    flex-wrap: nowrap;
    justify-content: start
  }
}
.c-form02__input-inner {
  width: 100%
}
.c-form02__input-inner02 {
  display: block;
  margin-right: 0;
  margin-top: 12px;
  width: 100%
}
@media screen and (min-width:768px) {
  .c-form02__input-inner02 {
    justify-content: start;
    margin-right: 20px;
    margin-top: 0;
    width: auto
  }
}
.c-form02__input-inner02:first-child {
  margin-top: 0
}
.c-form02__input-txt {
  margin-right: 10px;
  word-break: keep-all
}
@media screen and (min-width:768px) {
  .c-form02__input-txt {
    margin-right: 25px
  }
}
.c-form02__input-txt-kana {
  margin-right: 10px
}
.c-form02__input {
  text-align: center
}
@media screen and (min-width:768px) {
  .c-form02__input {
    text-align: left
  }
}
.c-form02__input .age input {
  text-align: right
}
.c-form02__input input {
  border: 1px solid #cecebf;
  border-radius: 5px;
  font-size: 1.125rem;
  height: 30px;
  margin-right: 5px;
  max-width: 200px;
  padding: 0 5px;
  width: 100%
}
.c-form02__input input:focus {
  border: 2px solid #6d6d5d !important
}
.c-form02__input input::-moz-placeholder {
  font-size: 1rem
}
.c-form02__input input::placeholder {
  font-size: 1rem
}
.c-form02__input input[type=tel] {
  border: 1px solid #cecebf;
  border-radius: 5px;
  height: 30px;
  max-width: 200px;
  padding: 0 5px;
  width: 100%
}
.c-form02__input input[type=tel]:focus {
  border: 2px solid #6d6d5d !important
}
.c-form02__input input[type=tel]:focus-visible {
  border: none;
  outline: none
}
.c-form02__input input[type=email] {
  border: 1px solid #cecebf;
  border-radius: 5px;
  height: 30px;
  max-width: 200px;
  padding: 0 5px;
  width: 100%
}
.c-form02__input input[type=email]:focus {
  border: 2px solid #6d6d5d !important
}
.c-form02__input input[type=email]:focus-visible {
  border: none;
  outline: none
}
.c-form02__input textarea {
  border: 1px solid #cecebf;
  border-radius: 5px;
  font-size: 1.125rem;
  height: 150px;
  margin-right: 5px;
  max-width: 100%;
  padding: 5px;
  width: 100%
}
.c-form02__input textarea:focus {
  border: 2px solid #6d6d5d !important
}
.c-form02__input input[name=age] {
  text-align: right
}
.c-form02__input--small input, .c-form02__input--small input[type=email] {
  max-width: 100px
}
.c-form02__input--large {
  width: 100%
}
.c-form02__input--large input, .c-form02__input--large input[type=email] {
  max-width: 600px
}
.c-form02__input--full input {
  max-width: 100%
}
.c-form02__birthday {
  display: flex;
  gap: 10px 15px
}
.c-form02__birthday > div {
  display: flex;
  justify-content: center;
  width: 100%
}
@media screen and (min-width:768px) {
  .c-form02__birthday > div {
    justify-content: flex-start;
    width: auto
  }
}
.c-form02__input-select-item {
  align-items: center;
  border: 1px solid #cecebf;
  border-radius: 5px;
  display: flex;
  height: 30px;
  max-width: 220px;
  position: relative;
  z-index: 1
}
.c-form02__input-select-item:has(select:focus) {
  border: 2px solid #4f4f4f
}
.c-form02__input-select-item:after {
  border-bottom: 2px solid #cecebf;
  border-right: 2px solid #cecebf;
  content: "";
  height: 8px;
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  width: 8px;
  z-index: -1
}
.c-form02__input-select select {
  font-size: 1rem;
  height: 100%;
  padding: 0 10px;
  width: 220px
}
.c-form02__input-select02-inner {
  align-items: center;
  display: flex;
  flex-wrap: nowrap;
  gap: 5px
}
.c-form02__input-select02-item {
  align-items: center;
  border: 1px solid #cecebf;
  border-radius: 5px;
  display: flex;
  height: 30px;
  max-width: 75px;
  position: relative;
  z-index: 1
}
.c-form02__input-select02-item:has(select:focus) {
  border: 2px solid #4f4f4f
}
.c-form02__input-select02-item:after {
  border-bottom: 2px solid #cecebf;
  border-right: 2px solid #cecebf;
  content: "";
  height: 8px;
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  width: 8px;
  z-index: -1
}
.c-form02__input-select02 select {
  font-size: 1rem;
  height: 100%;
  padding: 0 10px;
  width: 75px
}
.c-form02__input-select03-inner {
  align-items: center;
  display: flex;
  flex-wrap: nowrap;
  gap: 5px
}
.c-form02__input-select03-item {
  align-items: center;
  border: 1px solid #cecebf;
  border-radius: 5px;
  display: flex;
  height: 30px;
  max-width: 55px;
  position: relative;
  z-index: 1
}
.c-form02__input-select03-item:after {
  border-bottom: 2px solid #cecebf;
  border-right: 2px solid #cecebf;
  content: "";
  height: 8px;
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  width: 8px;
  z-index: -1
}
.c-form02__input-select03 select {
  font-size: 1rem;
  height: 100%;
  padding: 0 10px;
  width: 55px
}
.c-form02__input-select04-item {
  align-items: center;
  border: 1px solid #cecebf;
  border-radius: 5px;
  display: flex;
  height: 30px;
  max-width: 110px;
  position: relative;
  z-index: 1
}
.c-form02__input-select04-item:has(select:focus) {
  border: 2px solid #4f4f4f
}
.c-form02__input-select04-item:after {
  border-bottom: 2px solid #cecebf;
  border-right: 2px solid #cecebf;
  content: "";
  height: 8px;
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  width: 8px;
  z-index: -1
}
.c-form02__input-select04 select {
  font-size: 1rem;
  height: 100%;
  padding: 0 10px;
  width: 110px
}
.c-form02__radio {
  display: flex;
  flex-wrap: wrap;
  gap: .5em 1em
}
.c-form02__radio label {
  cursor: pointer;
  display: inline-flex;
  font-size: .875rem;
  font-weight: 500;
  line-height: 150%;
  padding-left: 30px;
  position: relative
}
@media screen and (min-width:768px) {
  .c-form02__radio label {
    font-size: 1rem;
    line-height: 200%
  }
}
.c-form02__radio label:before {
  border: 1px solid #333;
  height: 20px;
  left: 0;
  width: 20px
}
.c-form02__radio input[type=radio] + label:after, .c-form02__radio label:before {
  border-radius: 50%;
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  transform: translateY(-50%)
}
.c-form02__radio input[type=radio] + label:after {
  background-color: #5d63b8;
  display: block;
  height: 12px;
  left: 4px;
  opacity: 0;
  transition: opacity .3s;
  width: 12px
}
.c-form02__radio input[type=radio]:checked + label:after {
  opacity: 1;
  transition: opacity .3s
}
.c-form02__textarea {
  width: 100%
}
.c-form02__privacy-head {
  background-color: #e7e7e7;
  border-bottom: 1px solid #cecebf;
  color: #333;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.5;
  padding: 20px 10px;
  width: 100%
}
.c-form02__privacy-desc {

}
.c-form02__privacy-desc label {

}
@media screen and (min-width:768px) {
  .c-form02__privacy-desc label {
    font-size: 1rem
  }
}
.c-form02__privacy-desc label a {

}
@media screen and (min-width:768px) {
  .c-form02__privacy-desc label a {
    font-size: 1rem
  }
}

@media screen and (min-width:768px) {
  .c-form02__privacy-desc-txt {
    font-size: 1rem
  }
}
.c-form02__privacy-checkbox a {

}
.c-form02__privacy-checkbox a:hover {

}
.c-form02__privacy-checkbox input[type=checkbox] {

}
.c-form02__submit-wrap {
  margin-top: 50px
}
.c-form02__submit {
  display: flex;
  width: 100%
}
.c-form02__submit button {
  background-color: #5d63b8;
  border-radius: 5px;
  color: #fff;
  cursor: pointer;
  font-size: 1.25rem;
  font-weight: 700;
  height: 50px;
  margin: 0 auto;
  max-width: 200px;
  padding-top: 2px;
  text-align: center;
  width: 100%
}
.c-form02__submit button:hover {
  opacity: .9;
  transition: all .3s
}
.c-form02__submit button:focus {
  opacity: .9
}
.c-form02__prev {
  margin-top: 20px
}
.c-form02__prev button {
  background-color: #5d63b8;
  border: none !important;
  border-radius: 5px;
  color: #fff;
  cursor: pointer;
  display: block;
  font-size: 1.25rem;
  font-weight: 700;
  height: 50px;
  margin: 0 auto;
  max-width: 200px;
  padding-top: 2px;
  text-align: center;
  width: 100%
}
.c-form02__prev button:hover {
  opacity: .8;
  transition: all .3s
}
.c-form02__prev button:focus {
  opacity: .8
}
.c-form02__confirm-textarea {
  height: 150px;
  overflow-y: auto;
  text-align: left
}
.grecaptcha-badge {
  bottom: 60px !important
}
.c-form02-thanks {
  margin-top: 50px;
  text-align: center
}
.c-form02-thanks__txt01 {
  font-size: 1.5625rem
}
.c-form02-thanks__txt02 {
  font-size: 1rem;
  line-height: 1.8;
  margin-bottom: 20px;
  margin-top: 20px
}
.c-form02-thanks a {
  text-align: center;
  text-decoration: underline;
  -webkit-text-decoration-skip-ink: none;
  text-decoration-skip-ink: none
}
.c-breadcrumbs-wrap {
  margin-inline: auto;
  max-width: 1440px;
  padding: 0 15px;
  width: 100%
}
@media screen and (min-width:768px) {
  .c-breadcrumbs-wrap {
    padding: 0 45px
  }
}
.c-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  font-size: 0;
  list-style-type: none
}
.c-breadcrumbs__item {
  font-size: .75rem;
  margin-right: 5px
}
@media screen and (min-width:768px) {
  .c-breadcrumbs__item {
    font-size: 1rem
  }
}
.c-breadcrumbs__item a {
  position: relative
}
.c-breadcrumbs__item a:before {
  border-bottom: 1px solid #000;
  bottom: 1px;
  content: "";
  display: block;
  height: 2px;
  left: 0;
  position: absolute;
  width: 94%
}
.c-breadcrumbs__item a:hover {
  opacity: .7
}
.lp {
  font-feature-settings: normal;
  color: #222;
  font-family: Noto Sans JP, sans-serif
}
.hero {
  display: block
}
.dr, .hero {
  width: 100%
}
.dr {
  margin-inline: auto;
  max-width: 1052px;
  padding: 0 45px
}
.dr__info {
  display: flex;
  flex-wrap: wrap;
  gap: 0
}
@media screen and (min-width:768px) {
  .dr__info {
    flex-wrap: nowrap;
    gap: 86px
  }
}
.dr__img {
  flex-shrink: 1;
  margin-inline: auto;
  max-width: 160px;
  width: 100%
}
@media screen and (min-width:768px) {
  .dr__img {
    flex-shrink: 0;
    max-width: 311px
  }
}
.dr__detail {
  margin-top: 10px;
  width: 100%
}
@media screen and (min-width:768px) {
  .dr__detail {
    margin-top: 0
  }
}
.dr__position {
  font-size: 1rem
}
@media screen and (min-width:768px) {
  .dr__position {
    font-size: 1.728rem;
    line-height: 1
  }
}
.dr__name-ja {
  display: block;
  font-size: 1.3125rem
}
@media screen and (min-width:768px) {
  .dr__name-ja {
    display: inline;
    font-size: 2.2679375rem
  }
}
.dr__name-en {
  display: block;
  font-size: .875rem;
  padding-left: 0
}
@media screen and (min-width:768px) {
  .dr__name-en {
    display: inline;
    font-size: 1.512rem;
    padding-left: 44px
  }
}
.dr__txt01 {
  font-size: .875rem;
  line-height: 160.8%;
  margin-top: 18px;
  margin-bottom: 18px;
  text-align: justify
}
@media screen and (min-width:768px) {
  .dr__txt01 {
    font-size: 1.3125rem
  }
}
.dr__career {
  display: flex;
  flex-wrap: wrap
}
@media screen and (min-width:768px) {
  .dr__career {
    flex-wrap: nowrap;
    gap: 75px;
    margin-top: 55px
  }
}
.dr__certification {
  margin-inline: auto;
  margin-top: 20px;
  max-width: 100%;
  width: 100%
}
@media screen and (min-width:768px) {
  .dr__certification {
    margin-top: 0;
    max-width: 325px
  }
}
.dr__certification img {
  width: 100%
}
.dr__certification-txt {
  font-size: .625rem
}
@media screen and (min-width:768px) {
  .dr__certification-txt {
    font-size: .6875rem
  }
}
.dr__career-list-wrap {
  display: flex;
  flex-wrap: wrap;
  margin-top: 30px;
  width: 100%
}
@media screen and (min-width:768px) {
  .dr__career-list-wrap {
    margin-top: 0
  }
}
.dr__career-list {
  width: 100%
}
@media screen and (min-width:867px) {
  .dr__career-list:first-of-type {
    width: 51%
  }
}
.dr__career-list:nth-of-type(2) {
  margin-top: 20px;
  padding-left: 0
}
@media screen and (min-width:867px) {
  .dr__career-list:nth-of-type(2) {
    margin-top: 0;
    padding-left: 18px;
    width: 49%
  }
}
.dr__career-head {
  font-size: 1rem;
  line-height: 180.3%
}
@media screen and (min-width:768px) {
  .dr__career-head {
    font-size: 1.125rem;
    margin-top: -10px
  }
}
.dr__career-item {
  display: flex;
  flex-wrap: nowrap;
  font-size: .8125rem;
  line-height: 180.3%
}
@media screen and (min-width:768px) {
  .dr__career-item {
    font-size: .875rem
  }
}
.dr__career-item div:first-of-type {
  flex-shrink: 0
}
.dr--md {
  max-width: 400px
}
@media screen and (min-width:768px) {
  .dr--md {
    max-width: 1052px
  }
}
.dr--md .dr__career {
  display: none
}
@media screen and (min-width:768px) {
  .dr--md .dr__career {
    display: flex
  }
}
.dr--md .dr__txt01 {
  display: none
}
@media screen and (min-width:768px) {
  .dr--md .dr__txt01 {
    display: block
  }
}
.dr--md .dr__link {
  align-items: center;
  background-color: #30366d;
  border-radius: 5px;
  color: #fff;
  display: flex;
  font-size: .875rem;
  height: 47px;
  justify-content: center;
  margin-inline: auto;
  
  max-width: 220px;
  width: 100%
}

.price {
  margin-inline: auto;
  max-width: 400px;
  padding: 0 45px;
  width: 100%
}
@media screen and (min-width:768px) {
  .price {
    max-width: 1343px;
    overflow-x: auto
  }
}
.price table {
  table-layout: fixed;
  width: 100%
}
@media screen and (min-width:768px) {
  .price table {
    width: 1253px
  }
}
@media screen and (min-width:1150px) {
  .price table {
    width: 100%
  }
}
.price tr {
  display: block;
  float: left;
  width: 100%
}
@media screen and (min-width:768px) {
  .price tr {
    display: table-row;
    float: none
  }
}
.price td, .price th {
  align-items: center;
  border-top: 1.5px solid #222;
  display: flex;
  flex-wrap: wrap;
  height: 63px;
  justify-content: center;
  white-space: nowrap;
  width: 100%
}
@media screen and (min-width:768px) {
  .price td, .price th {
    border: none;
    display: table-cell;
    height: auto
  }
}
.price td:first-child, .price th:first-child {
  border-top: none
}
.price th {
  font-size: 1rem;
  font-weight: 400;
  padding: 0
}
@media screen and (min-width:768px) {
  .price th {
    font-size: 1.3125rem;
    padding: 0 5px 18px
  }
}
.price td {
  padding: 8px 0
}
@media screen and (min-width:768px) {
  .price td {
    padding: 50px 5px
  }
}
.price td span {
  display: block;
  font-size: 1rem;
  text-align: center;
  width: 100%
}
@media screen and (min-width:768px) {
  .price td span {
    font-size: 1.3125rem;
    width: auto
  }
}
.price td span:nth-of-type(2) {
  font-size: .8125rem;
  margin-top: 0
}
@media screen and (min-width:768px) {
  .price td span:nth-of-type(2) {
    font-size: 1.125rem;
    margin-top: 3px
  }
}
.price thead {
  border-bottom: none;
  display: block;
  float: left;
  width: 30%
}
@media screen and (min-width:768px) {
  .price thead {
    border-bottom: 1.5px solid #222;
    display: table-header-group;
    float: none;
    width: auto
  }
}
.price tbody {
  border-bottom: none;
  display: block;
  float: left;
  width: 70%
}
@media screen and (min-width:768px) {
  .price tbody {
    border-bottom: 1.5px solid #222;
    display: table-row-group;
    float: none;
    width: auto
  }
}
.price-atn-wrap {
  margin-inline: auto;
  margin-top: 80px;
  max-width: 1190px;
  padding: 0 45px;
  width: 100%
}
@media screen and (min-width:768px) {
  .price-atn-wrap {
    margin-top: 150px
  }
}
.price-atn {
  background-color: rgba(233, 235, 240, .5);
  padding: 10px
}
@media screen and (min-width:768px) {
  .price-atn {
    padding: 60px 45px
  }
}
.price-atn p {
  color: #303030;
  font-size: .8125rem;
  line-height: 150%
}
@media screen and (min-width:768px) {
  .price-atn p {
    font-size: 1rem
  }
}
.price-atn a {
  color: #0c1bf8;
  display: block;
  text-decoration: underline;
  -webkit-text-decoration-skip-ink: none;
  text-decoration-skip-ink: none
}
.price-atn__list {
  padding-left: 20px
}
.price-atn__list-head {
  color: #303030;
  font-size: .9375rem;
  margin-top: 5px
}
.price-atn__list-desc {
  color: #303030;
  font-size: .9375rem;
  padding-left: 17px
}
.price-atn__order {
  counter-reset: list-order;
  list-style-type: none;
  margin: 5px 0 0;
  padding: 0 0 0 17px
}
.price-atn__order > :last-child {
  margin-bottom: 0
}
.price-atn__order-item {
  color: #303030;
  font-size: .9375rem;
  margin-bottom: 8px;
  padding-left: 2em;
  position: relative
}
.price-atn__order-item:before {
  color: #303030;
  content: "2-"counter(list-order) ". ";
  counter-increment: list-order;
  left: 0;
  position: absolute;
  top: 0
}
.price-atn__order-item a, .price-atn__order-item p {
  color: #303030;
  font-size: .9375rem
}
.access {
  margin-inline: auto;
  max-width: 1094px;
  padding: 0 20px;
  width: 100%
}
.access__item {
  display: flex;
  flex-wrap: wrap;
  gap: 0
}
@media screen and (min-width:950px) {
  .access__item {
    flex-wrap: nowrap;
    gap: 82px
  }
}
.access__map {
  margin-inline: auto;
  margin-top: 50px;
  order: 2;
  width: 100%
}
@media screen and (min-width:950px) {
  .access__map {
    margin-top: 0;
    order: 1;
    width: 46.618%
  }
}
.access__map-inner {
  height: 500px;
  padding: 0;
  position: relative;
  width: 100%
}
@media screen and (min-width:768px) {
  .access__map-inner {
    height: 537px
  }
}
.access__map-inner iframe {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%
}
.access__info {
  flex-shrink: 1;
  margin-inline: auto;
  order: 1;
  width: 353px
}
@media screen and (min-width:950px) {
  .access__info {
    flex-shrink: 0;
    margin: 0;
    order: 2;
    width: 502px
  }
}
.access__head-md {
  display: none;
  font-size: 2.25rem
}
@media screen and (min-width:950px) {
  .access__head-md {
    display: block
  }
}
.access__head-sp {
  text-align: center
}
.access__head-sp span {
  font-size: 1.5rem;
  line-height: 1;
  padding-left: 14px;
  position: relative
}
@media screen and (min-width:950px) {
  .access__head-sp span {
    display: none
  }
}
.access__head-sp span:before {
  background-color: #30366d;
  content: "";
  display: block;
  height: 26px;
  left: 0;
  position: absolute;
  top: 7px;
  width: 3px
}
.access__img {
  display: block;
  margin-top: 25px;
  width: 100%
}
@media screen and (min-width:950px) {
  .access__img {
    display: none
  }
}
.access__txt01 {
  font-size: 1rem;
  line-height: 1.7
}
@media screen and (min-width:950px) {
  .access__txt01 {
    font-size: 1.5rem;
    line-height: 1.5
  }
}
.access__txt01 span {
  color: #30366d;
  font-weight: 500
}
.access__txt02 {
  font-size: .8125rem
}
@media screen and (min-width:950px) {
  .access__txt02 {
    font-size: 1.125rem
  }
}
.access__open-head {
  font-size: 1.5rem;
  text-align: center
}
@media screen and (min-width:950px) {
  .access__open-head {
    font-size: 1.3125rem
  }
}
.access__open-table {
  margin-inline: auto;
  margin-top: 24px
}
@media screen and (min-width:380px) {
  .access__open-table {
    margin-inline: 0
  }
}
.access__open-table thead {
  border-bottom: 2px solid #222
}
.access__open-table thead th {
  font-size: .8125rem;
  font-weight: 400;
  padding: 0 5px 10px 15px
}
@media screen and (min-width:380px) {
  .access__open-table thead th {
    padding: 0 5px 10px 20px
  }
}
@media screen and (min-width:950px) {
  .access__open-table thead th {
    font-size: 1.5rem
  }
}
.access__open-table thead th:nth-last-child(2) {
  color: #3e49aa
}
.access__open-table thead th:last-child {
  color: #d42d2d
}
.access__open-table tbody {
  border-bottom: 2px solid #222
}
.access__open-tbody-head {
  font-size: .75rem;
  padding: 18px 0 15px
}
@media screen and (min-width:380px) {
  .access__open-tbody-head {
    padding: 18px 0 15px 10px
  }
}
@media screen and (min-width:950px) {
  .access__open-tbody-head {
    font-size: 1.125rem;
    padding: 25px 30px 25px 0
  }
}
.access__open-possible {
  position: relative
}
.access__open-possible:before {
  border: 1px solid #222;
  border-radius: 50%;
  content: "";
  display: block;
  height: 15px;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-2%, -50%);
  width: 15px
}
@media screen and (min-width:950px) {
  .access__open-possible:before {
    border: 2px solid #222;
    height: 22px;
    transform: translate(-16%, -50%);
    width: 22px
  }
}
.access__open-nopossible {
  position: relative
}
.access__open-nopossible:before {
  background-color: #222;
  content: "";
  display: block;
  height: 1px;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-10%, -50%) rotate(-45deg);
  width: 12px
}
@media screen and (min-width:950px) {
  .access__open-nopossible:before {
    transform: translate(-2%, -50%) rotate(-45deg);
    width: 18px
  }
}
.privacy {
  margin-inline: auto;
  max-width: 1090px;
  padding: 0 45px;
  width: 100%
}
.privacy ol {
  list-style-type: none;
  padding: 0
}
.privacy__head01 {
  font-size: 2rem;
  text-align: center
}
.privacy__head02 {
  display: flex;
  flex-wrap: nowrap;
  padding-top: 8px;
  position: relative
}
@media screen and (min-width:768px) {
  .privacy__head02 {
    padding-top: 10px
  }
}
.privacy__head02:before {
  background-color: #30366d;
  content: "";
  display: block;
  height: 4px;
  left: 0;
  position: absolute;
  top: 0;
  width: 60px
}
@media screen and (min-width:768px) {
  .privacy__head02:before {
    width: 100px
  }
}
.privacy__head02 span {
  font-size: 1.25rem;
  font-weight: 500
}
@media screen and (min-width:768px) {
  .privacy__head02 span {
    font-size: 1.5rem
  }
}
.privacy__head02 span:first-of-type {
  flex-shrink: 0
}
.privacy__txt01 {
  font-size: .875rem;
  line-height: 1.608
}
@media screen and (min-width:768px) {
  .privacy__txt01 {
    font-size: 1.125rem;
    line-height: 1.8
  }
}
.privacy__txt02 {
  font-size: .875rem;
  line-height: 1.608
}
@media screen and (min-width:768px) {
  .privacy__txt02 {
    font-size: 1.125rem
  }
}
.privacy__list01-item {
  display: flex;
  flex-wrap: nowrap;
  gap: 14px;
  margin-top: 8px
}
@media screen and (min-width:768px) {
  .privacy__list01-item {
    gap: 24px;
    margin-top: 12px
  }
}
.privacy__list01-item:first-child {
  margin-top: 0
}
.privacy__list01-item span {
  font-size: .875rem;
  font-weight: 500
}
@media screen and (min-width:768px) {
  .privacy__list01-item span {
    font-size: 1.0625rem
  }
}
.privacy__list01-item span:first-of-type {
  font-weight: 700
}
.privacy__list02-item {
  margin-top: 12px
}
@media screen and (min-width:768px) {
  .privacy__list02-item {
    margin-top: 24px
  }
}
.privacy__list02-item:first-child {
  margin-top: 0
}
.privacy__list02-head {
  display: flex;
  flex-wrap: nowrap;
  gap: 14px
}
@media screen and (min-width:768px) {
  .privacy__list02-head {
    gap: 24px
  }
}
.privacy__list02-head span {
  font-size: .875rem;
  font-weight: 500
}
@media screen and (min-width:768px) {
  .privacy__list02-head span {
    font-size: 1.0625rem
  }
}
.privacy__list02-head span:first-of-type {
  font-weight: 700
}
.privacy__list02-sublist {
  margin-top: 8px;
  padding-left: 23px
}
@media screen and (min-width:768px) {
  .privacy__list02-sublist {
    margin-top: 11px;
    padding-left: 35px
  }
}
.privacy__list02-sublist > li {
  display: flex;
  flex-wrap: nowrap;
  margin-top: 8px
}
.privacy__list02-sublist > li:first-child {
  margin-top: 0
}
.privacy__list02-sublist > li span {
  font-size: .875rem
}
@media screen and (min-width:768px) {
  .privacy__list02-sublist > li span {
    font-size: 1.0625rem
  }
}
.privacy__signature {
  font-size: .875rem;
  text-align: right
}
@media screen and (min-width:768px) {
  .privacy__signature {
    font-size: 1.125rem
  }
}


#privacy_policy{
  opacity: 0;
}