@charset "UTF-8";
html {
  font-size: calc(10vw / 5);
  -webkit-font-smoothing: antialiased; }

body {
  color: #000000;
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-size: 1.4rem;
  line-height: 1.64;
  font-weight: 500;
  background-color: #FFFFFF;
  -webkit-text-size-adjust: 100%;
  word-wrap: break-word;
  overflow-wrap: break-word;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden; }

body.lock,
body.loading {
  overflow: hidden;
  width: 100vw;
  height: 100vh; }

@media screen and (min-width: 769px) {
  html {
    font-size: 8px; }

  body {
    font-size: 1.6rem;
    line-height: 1; } }
@media screen and (min-width: 1000px) {
  html {
    font-size: 10px; } }
* {
  -webkit-tap-highlight-color: transparent; }

a {
  color: inherit;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0); }
  a.disabled {
    cursor: auto;
    pointer-events: none; }

p, dt, dd, li {
  word-break: break-word;
  word-wrap: normal; }

img {
  max-width: 100%;
  height: auto;
  vertical-align: top; }

button {
  cursor: pointer; }

figure img {
  width: 100%;
  height: auto; }

picture img {
  width: 100%;
  height: auto; }

.ib {
  display: inline-block;
  line-height: inherit;
  font-weight: inherit; }

.txtBold {
  font-weight: 700; }

.accordionTrigger {
  cursor: pointer;
  display: block; }

.accordionContent {
  display: none; }

input[type="submit"] {
  cursor: pointer; }

.slide .item {
  opacity: 0;
  position: absolute;
  top: 0; }
  .slide .item:first-child {
    opacity: 1;
    position: relative; }
.slide.slick-initialized .item {
  opacity: 1;
  position: relative; }
.slide .slick-dots {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  margin: 1rem 0 0 0; }
  .slide .slick-dots li {
    overflow: hidden;
    flex-basis: 10px;
    margin: 0 10px; }
    .slide .slick-dots li button {
      margin: 0;
      padding: 0;
      background: none;
      border: none;
      border-radius: 0;
      outline: none;
      -webkit-appearance: none;
      -moz-appearance: none;
      appearance: none;
      box-sizing: border-box;
      display: block;
      cursor: pointer;
      width: 100%;
      height: 10px;
      text-indent: -9999em;
      border-radius: 50%;
      transition: background-color 0.2s ease-out; }
    .slide .slick-dots li:first-child:last-child {
      display: none; }
.slide .slick-arrow {
  cursor: pointer;
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 10;
  width: 4.0rem;
  height: 4.0rem;
  text-indent: -9999em;
  margin: auto;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  box-sizing: border-box; }
  .slide .slick-arrow.slick-prev {
    right: 100%;
    background: url(../img/icon_arrow_next.png) center top no-repeat;
    background-size: contain;
    transform: rotate(180deg); }
  .slide .slick-arrow.slick-next {
    left: 100%;
    background: url(../img/icon_arrow_next.png) center top no-repeat;
    background-size: contain; }
  .slide .slick-arrow.slick-disabled {
    display: none !important; }

.grecaptcha-badge {
  visibility: hidden; }

.smf-form .p-country-name {
  display: none; }

#contactArea .smf-form .recaptcha_message {
  color: #707070;
  font-size: 1.1rem;
  line-height: 1.4;
  text-align: center;
  padding: 3em 0 0 0; }

#contactArea .smf-form .recaptcha_message a {
  color: inherit;
  text-decoration: underline; }

@media screen and (min-width: 769px) {
  .slide .slick-arrow {
    width: 8rem;
    height: 8rem; }
    .slide .slick-arrow.slick-prev {
      left: -4rem; }
    .slide .slick-arrow.slick-next {
      right: -4rem; }
    .slide .slick-arrow.slick-prev, .slide .slick-arrow.slick-next {
      transition: opacity 0.2s ease-out; }
      .slide .slick-arrow.slick-prev:hover, .slide .slick-arrow.slick-next:hover {
        opacity: 0.8; }

  /* mover */
  .mover {
    transition: opacity 0.2s ease-out;
    backface-visibility: hidden;
    zoom: 1; }
    .mover:hover {
      opacity: 0.7; }

  .moverContent > * {
    transition: all 0.2s ease-out;
    backface-visibility: hidden;
    zoom: 1; }
  .moverContent:hover > * {
    opacity: 0.7; }

  .moverColor {
    transition: color 0.2s ease-out; }
    .moverColor:after {
      transition: all 0.2s ease-out; }
    .moverColor:hover {
      color: #037e00; }
      .moverColor:hover:after {
        border-color: #037e00 !important; }

  .moverButton {
    transition: all 0.2s ease-out; }
    .moverButton:hover {
      color: #FFFFFF !important;
      background-color: #037e00 !important;
      border-color: #037e00 !important; }
      .moverButton:hover:after {
        border-color: #FFFFFF !important; } }
.modePC,
.modePCib {
  display: none; }
  .modePC.important,
  .modePCib.important {
    display: none !important; }

.modeSP {
  display: block; }
  .modeSP.important {
    display: block !important; }

@media screen and (min-width: 769px) {
  .modePC {
    display: block; }
    .modePC.important {
      display: block !important; }

  .modePCib {
    display: inline-block; }
    .modePCib.important {
      display: inline-block !important; }

  .modeSP {
    display: none; }
    .modeSP.important {
      display: none !important; } }
@keyframes fluffy {
  0% {
    transform: translateY(0); }
  50% {
    transform: translateY(-20px); }
  100% {
    transform: translateY(0); } }
.wrapper {
  overflow: hidden;
  position: relative; }
  .load_complete .wrapper {
    opacity: 1; }

.scrollPosition {
  margin: calc(-50 / 375 * 100%) 0 0 0;
  padding: calc(50 / 375 * 100%) 0 0 0; }

.content {
  position: relative; }

.contentInner {
  width: calc(345 / 375 * 100%);
  margin: auto; }

.fadeContent {
  opacity: 0;
  transition: opacity 1.0s ease-out; }

.fadeContent.current {
  opacity: 1; }

@media screen and (min-width: 769px) {
  .scrollPosition {
    margin: -74px 0 0 0;
    padding: 74px 0 0 0; }

  .contentInner {
    position: relative;
    width: 100%;
    max-width: 1020px;
    margin: auto;
    padding: 0 20px;
    box-sizing: border-box; } }
/* flow */
#flow.step2 .list .item:nth-child(1) {
  opacity: 0.3; }
#flow.step3 .list .item:nth-child(1), #flow.step3 .list .item:nth-child(2) {
  opacity: 0.3; }
#flow.step4 .list .item:nth-child(1), #flow.step4 .list .item:nth-child(2), #flow.step4 .list .item:nth-child(3) {
  opacity: 0.3; }
#flow .wrap {
  overflow: auto;
  width: 100%;
  margin: 0 0 2.6rem 0; }
#flow .list {
  display: flex; }
  #flow .list .item {
    flex-basis: 237px;
    flex-shrink: 0;
    position: relative;
    margin: 0 0 0 10px;
    border: 1px solid #037e00;
    border-radius: 1rem;
    box-sizing: border-box; }
    #flow .list .item:first-child {
      margin: 0; }
    #flow .list .item:last-child:after {
      display: none; }
    #flow .list .item:after {
      content: "";
      position: absolute;
      top: 0;
      bottom: 0;
      right: calc(-1.5rem - 5px);
      width: 3rem;
      height: 3rem;
      background: url(../img/icon_next.png) center top no-repeat;
      background-size: contain;
      margin: auto; }
    #flow .list .item .row {
      padding: 0.8rem 1rem; }
      #flow .list .item .row .head {
        color: #4faa74;
        font-size: 1.8rem;
        line-height: 1;
        letter-spacing: 0.1em;
        text-align: center;
        background-color: #e9f4e9;
        margin: 0 0 1rem 0;
        padding: 0.3em 0;
        border-radius: 1rem; }
      #flow .list .item .row .cont .summary {
        font-size: 2rem;
        line-height: 1.2;
        text-align: center;
        margin: 0 0 1rem 0; }
      #flow .list .item .row .cont .text {
        font-size: 1.2rem;
        line-height: 1.33;
        margin: 0 0.4rem 0.6rem 0.4rem; }

@media screen and (max-width: 768px) {
  #flow.step2 .list .item:nth-child(1) {
    display: none; }
  #flow.step2 .list .item:nth-child(2) {
    margin: 0; }
  #flow.step3 .list .item:nth-child(1), #flow.step3 .list .item:nth-child(2) {
    display: none; }
  #flow.step3 .list .item:nth-child(3) {
    margin: 0; }
  #flow.step4 .list .item:nth-child(1), #flow.step4 .list .item:nth-child(2), #flow.step4 .list .item:nth-child(3) {
    display: none; }
  #flow.step4 .list .item:nth-child(4) {
    margin: 0; }
  #flow .list .item {
    flex-basis: calc(345 / 375 * 100vw);
    margin: 0; }
    #flow .list .item:first-child {
      margin: 0; }
    #flow .list .item:after {
      right: 0; }
    #flow .list .item .cont {
      text-align: center; } }
#attention .block {
  background-color: #f4f4f4;
  margin: 0 0 1.7rem 0;
  padding: 2.4rem 3rem 3.5rem 3rem;
  border-radius: 1rem; }
  #attention .block .title {
    display: flex;
    align-items: center;
    font-size: 2rem;
    line-height: 1.4;
    font-weight: 700;
    margin: 0 0 1rem 0; }
    #attention .block .title:before {
      content: "";
      display: inline-block;
      width: 1rem;
      height: 1.6em;
      background-color: #037e00;
      margin: 0 1rem 0 0;
      border-radius: 0.3rem; }
  #attention .block .textWrap .row {
    margin: 0 0 2rem 0; }
    #attention .block .textWrap .row:last-child {
      margin: 0; }
    #attention .block .textWrap .row .head {
      font-size: 1.8rem;
      line-height: 1.56; }
    #attention .block .textWrap .row .cont {
      font-size: 1.8rem;
      line-height: 1.56; }
    #attention .block .textWrap .row .em {
      color: #f40000; }
  #attention .block .textWrap .text {
    font-size: 1.8rem;
    line-height: 1.56;
    margin: 0 0 2rem 0; }
    #attention .block .textWrap .text:last-child {
      margin: 0; }
    #attention .block .textWrap .text .em {
      color: #f40000; }
  #attention .block .table {
    max-width: 680px;
    font-size: 1.8rem;
    line-height: 1.33;
    border: 1px solid #000000;
    border-bottom: 0; }
    #attention .block .table .row {
      display: flex;
      width: 100%;
      margin: 0;
      border-bottom: 1px solid #000000; }
      #attention .block .table .row .head {
        flex-basis: calc(240 / 680 * 100%);
        text-align: center;
        background-color: #e0e0e0;
        padding: 0.9rem 0.5rem;
        border-right: 1px solid #000000;
        box-sizing: border-box; }
      #attention .block .table .row .cont {
        flex-basis: calc(440 / 680 * 100%);
        text-align: center;
        background-color: #FFFFFF;
        padding: 0.9rem 0;
        box-sizing: border-box; }
  #attention .block .note {
    font-size: 1.4rem;
    line-height: 2;
    margin: 1rem 0 0 0; }

#status .title {
  font-size: 2rem;
  line-height: 1.4;
  font-weight: 700;
  margin: 0 0 1rem 0; }
#status .notice {
  color: #d94236;
  font-weight: 700;
  margin: 0 0 1rem 0; }
#status .wrap {
  margin: 0 0 2rem 0; }
  #status .wrap .list {
    background-color: #e9f4e9;
    padding: 1.5rem;
    border: 2px solid #037e00;
    border-radius: 1rem; }
    #status .wrap .list .item {
      margin: 0 0 1.7rem 0; }
      #status .wrap .list .item .row .head {
        font-size: 1.8rem;
        line-height: 1.56;
        margin: 0 0 0.5rem 0; }
      #status .wrap .list .item .row .cont {
        display: flex;
        position: relative;
        min-height: 6.7rem;
        background-color: #FFFFFF;
        padding: 0.5rem 15rem 0.5rem 2rem;
        border: 1px solid #037e00;
        border-radius: 1rem; }
        #status .wrap .list .item .row .cont .studio {
          display: flex;
          align-items: center;
          margin: 0 1rem 0 0; }
          #status .wrap .list .item .row .cont .studio:before {
            content: "";
            display: block;
            flex-shrink: 0;
            width: 2.5rem;
            background: url(../img/icon_calendar.png) center center no-repeat;
            background-size: contain;
            margin: 0 1.5rem 0 0;
            aspect-ratio: 25 / 23; }
          #status .wrap .list .item .row .cont .studio .name {
            display: flex;
            align-items: center;
            width: 20rem;
            height: 100%;
            font-size: 1.6rem;
            line-height: 1.25;
            padding: 0.5rem 1rem;
            border: 1px solid #dbdbdb;
            border-radius: 0.5rem;
            box-sizing: border-box; }
        #status .wrap .list .item .row .cont .datetime {
          display: flex;
          font-size: 1.8rem;
          line-height: 1.56; }
          #status .wrap .list .item .row .cont .datetime .name {
            display: flex;
            align-items: center;
            justify-content: center;
            width: 6.3rem;
            height: 100%;
            font-size: 1.6rem;
            line-height: 1.25;
            background-color: #dbdbdb;
            margin: 0 1rem 0 0;
            border-radius: 0.5rem;
            box-sizing: border-box; }
          #status .wrap .list .item .row .cont .datetime .time {
            min-width: 17rem; }
          #status .wrap .list .item .row .cont .datetime .start {
            display: flex;
            align-items: center;
            margin: 0 1rem 0 0; }
          #status .wrap .list .item .row .cont .datetime .end {
            display: flex;
            align-items: center; }
        #status .wrap .list .item .row .cont .buttonArea {
          position: absolute;
          top: 0;
          bottom: 0;
          right: 2rem;
          width: 11rem;
          padding: 0.5rem 0; }
          #status .wrap .list .item .row .cont .buttonArea .clearButton {
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            width: 100%;
            height: 100%;
            color: #FFFFFF;
            font-size: 1.6rem;
            line-height: 1.75;
            background-color: #037e00;
            border-radius: 0.5rem;
            box-sizing: border-box;
            transition: all 0.2s ease-out; }
            #status .wrap .list .item .row .cont .buttonArea .clearButton.disabled {
              cursor: auto;
              background-color: #dbdbdb; }
            #status .wrap .list .item .row .cont .buttonArea .clearButton:not(.disabled):hover {
              color: #037e00;
              background-color: #FFFFFF;
              border: 1px solid #037e00; }
#status .toForm {
  margin: 0 0 5rem 0; }
  #status .toForm .button {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    min-height: 8rem;
    color: #FFFFFF;
    font-size: 2.4rem;
    line-height: 1;
    background-color: #037e00;
    border-radius: 0.5rem;
    box-sizing: border-box;
    transition: all 0.2s ease-out; }
    #status .toForm .button:before {
      content: "";
      display: block;
      position: absolute;
      top: 0;
      bottom: 0;
      left: 4rem;
      width: 3.4rem;
      background: url(../img/icon_calendar_white.png) center center no-repeat;
      background-size: contain;
      padding: 3.2rem 0 0 0;
      transition: all 0.2s ease-out; }
    #status .toForm .button.disabled {
      cursor: auto;
      background-color: #dbdbdb; }
    #status .toForm .button:not(.disabled):hover {
      color: #037e00;
      background-color: #FFFFFF;
      border: 1px solid #037e00; }
      #status .toForm .button:not(.disabled):hover:before {
        background: url(../img/icon_calendar.png) center center no-repeat;
        background-size: contain; }

@media screen and (max-width: 768px) {
  #status .wrap .list .item .row .cont {
    display: block;
    padding: 1rem 2rem 1rem 2rem; }
    #status .wrap .list .item .row .cont .studio {
      margin: 0 0 1rem 0; }
      #status .wrap .list .item .row .cont .studio .name {
        width: 100%; }
    #status .wrap .list .item .row .cont .datetime {
      display: block; }
      #status .wrap .list .item .row .cont .datetime .name {
        display: block;
        flex-shrink: 0;
        width: auto;
        padding: 0.5rem 1rem; }
        #status .wrap .list .item .row .cont .datetime .name br {
          display: none; }
      #status .wrap .list .item .row .cont .datetime .time {
        min-width: 0px; }
      #status .wrap .list .item .row .cont .datetime .start {
        margin: 0 0 1rem 0; }
      #status .wrap .list .item .row .cont .datetime .end {
        margin: 0 0 1rem 0; }
    #status .wrap .list .item .row .cont .buttonArea {
      position: static;
      width: 100%; }
      #status .wrap .list .item .row .cont .buttonArea .clearButton {
        padding: 0.5rem 0; } }
#fixedArea {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1000; }
  #fixedArea .content {
    background-color: #FFFFFF;
    padding: 1.3rem 0; }
  #fixedArea .messageArea #announce {
    display: none;
    color: #d94236;
    font-size: 1.6rem;
    line-height: 1.5;
    font-weight: 700;
    text-align: center;
    background-color: #ffdada;
    padding: 1rem 0; }
  #fixedArea .wrap {
    display: flex;
    justify-content: center;
    max-width: 810px;
    margin: auto;
    padding: 0.8rem 0;
    border: 2px solid #037e00;
    border-radius: 0.5rem;
    box-sizing: border-box; }
    #fixedArea .wrap .item {
      flex-basis: calc(380 / 810 * 100%);
      margin: 0 1.25rem; }
      #fixedArea .wrap .item .button {
        display: block;
        position: relative;
        height: 100%;
        font-size: 1.8rem;
        line-height: 1.33;
        text-align: center;
        padding: 3rem 0;
        border-radius: 0.5rem;
        box-sizing: border-box;
        transition: all 0.2s ease-out; }
        #fixedArea .wrap .item .button.scrollButton {
          color: #037e00;
          background-color: #e9f4e9;
          border: 1px solid #037e00; }
          #fixedArea .wrap .item .button.scrollButton:before {
            width: 2.4rem;
            background: url(../img/icon_checked.png) center center no-repeat;
            background-size: contain;
            aspect-ratio: 24 / 24; }
          #fixedArea .wrap .item .button.scrollButton:hover {
            color: #FFFFFF;
            background-color: #037e00;
            border: 1px solid #037e00; }
            #fixedArea .wrap .item .button.scrollButton:hover:before {
              background: url(../img/icon_checked_white.png) center center no-repeat;
              background-size: contain; }
        #fixedArea .wrap .item .button.toFormButton {
          color: #FFFFFF;
          background-color: #037e00; }
          #fixedArea .wrap .item .button.toFormButton:before {
            width: 2.5rem;
            background: url(../img/icon_calendar_white.png) center center no-repeat;
            background-size: contain;
            aspect-ratio: 25 / 23; }
          #fixedArea .wrap .item .button.toFormButton.disabled {
            cursor: auto;
            background-color: #dbdbdb; }
          #fixedArea .wrap .item .button.toFormButton:not(.disabled):hover {
            color: #037e00;
            background-color: #FFFFFF;
            border: 1px solid #037e00; }
            #fixedArea .wrap .item .button.toFormButton:not(.disabled):hover:before {
              background: url(../img/icon_calendar.png) center center no-repeat;
              background-size: contain; }
        #fixedArea .wrap .item .button:before {
          content: "";
          position: absolute;
          top: 0;
          bottom: 0;
          left: 2rem;
          margin: auto;
          transition: all 0.2s ease-out; }

@media screen and (max-width: 768px) {
  #fixedArea .wrap .item {
    flex-basis: calc(380 / 810 * 100%);
    margin: 0 1rem; }
    #fixedArea .wrap .item .button {
      padding: 1rem 0; }
      #fixedArea .wrap .item .button:before {
        display: block;
        position: static;
        margin: 0 auto 0.5rem auto; } }
.layoutType01#areaDay #calendarNav .inner {
  width: 12em; }
.layoutType01#areaMonth #calendarNav .inner {
  width: 12em; }
.layoutType01#areaMonth .studioNav .list .item {
  flex-basis: calc(227 / 980 * 100%); }
.layoutType01 .titleWrap {
  display: flex;
  align-items: center;
  margin: 0 0 2.5rem 0; }
  .layoutType01 .titleWrap .title {
    font-size: 2.6rem;
    line-height: 1.23;
    margin: 0 1.2rem 0 0; }
  .layoutType01 .titleWrap .guide {
    font-size: 1.8rem;
    line-height: 1.78;
    letter-spacing: -0.06em; }
.layoutType01 .guideWrap {
  margin: 0 0 2.5rem 0; }
  .layoutType01 .guideWrap .guide {
    font-size: 1.8rem;
    line-height: 1.56; }
    .layoutType01 .guideWrap .guide.small {
      font-size: 1.6rem;
      line-height: 1.75; }
    .layoutType01 .guideWrap .guide .em {
      color: #f40000; }
.layoutType01 .tab .list {
  display: flex; }
  .layoutType01 .tab .list .item {
    flex-basis: calc(100% / 3);
    position: relative; }
    .layoutType01 .tab .list .item.current {
      position: relative;
      z-index: 5; }
      .layoutType01 .tab .list .item.current .block {
        background-color: #FFFFFF;
        border-bottom: 0; }
    .layoutType01 .tab .list .item:first-child .block {
      border-right: 0; }
    .layoutType01 .tab .list .item:last-child .block {
      border-left: 0; }
    .layoutType01 .tab .list .item .block {
      display: flex;
      align-items: center;
      justify-content: center;
      position: relative;
      width: 100%;
      height: 100%;
      font-size: 1.8rem;
      line-height: 1;
      font-weight: 500;
      background-color: #dbdbdb;
      padding: 1rem 0;
      border: 1px solid #000000;
      border-radius: 1rem 1rem 0 0;
      box-sizing: border-box; }
      .layoutType01 .tab .list .item .block.accordionTrigger:after {
        content: "";
        display: block;
        position: absolute;
        top: 0;
        bottom: 0;
        right: 1.2rem;
        width: 0.7rem;
        height: 0.7rem;
        border-bottom: 2px solid #000000;
        border-right: 2px solid #000000;
        margin: auto;
        transform: rotate(45deg); }
    .layoutType01 .tab .list .item .accordion.open .accordionTrigger:after {
      top: 0.6rem;
      transform: rotate(-135deg); }
    .layoutType01 .tab .list .item .accordionContent {
      position: absolute;
      left: 1px;
      z-index: 10;
      margin: 1px 0 0 0; }
      .layoutType01 .tab .list .item .accordionContent .child {
        min-width: 100%;
        background-color: #FFFFFF;
        padding: 1rem 2rem;
        border-radius: 1rem;
        box-shadow: 5px 9px 10px rgba(0, 0, 0, 0.15); }
        .layoutType01 .tab .list .item .accordionContent .child .childItem {
          border-bottom: 1px solid #cacaca; }
          .layoutType01 .tab .list .item .accordionContent .child .childItem:last-child {
            border-bottom: 0; }
          .layoutType01 .tab .list .item .accordionContent .child .childItem a {
            display: block;
            position: relative;
            padding: 2rem 2rem 2rem 0; }
            .layoutType01 .tab .list .item .accordionContent .child .childItem a:after {
              content: "";
              display: block;
              position: absolute;
              top: 0;
              bottom: 0;
              right: 0.5rem;
              width: 0.7rem;
              height: 0.7rem;
              border-top: 2px solid #000000;
              border-right: 2px solid #000000;
              margin: auto;
              transform: rotate(45deg); }
.layoutType01 .tabContent {
  position: relative;
  z-index: 2;
  margin: 0 0 2rem 0;
  padding: 3rem 1rem 1rem 1rem;
  border: 1px solid #333333;
  border-top: 0; }
.layoutType01 #calendarNav {
  overflow: hidden;
  display: flex;
  justify-content: center;
  margin: 0 0 3.4rem 0; }
  .layoutType01 #calendarNav .inner {
    position: relative;
    width: 22em;
    font-size: 2rem;
    line-height: 1.3;
    text-align: center;
    margin: auto; }
    .layoutType01 #calendarNav .inner br {
      display: none; }
  .layoutType01 #calendarNav .prev,
  .layoutType01 #calendarNav .next {
    display: block;
    position: absolute;
    top: 0.3rem;
    bottom: 0;
    width: 1.1rem;
    margin: auto;
    aspect-ratio: 11 / 18; }
    .layoutType01 #calendarNav .prev.slick-disabled,
    .layoutType01 #calendarNav .next.slick-disabled {
      display: none !important; }
    .layoutType01 #calendarNav .prev.text,
    .layoutType01 #calendarNav .next.text {
      display: flex;
      align-items: center;
      justify-content: center;
      color: #037e00;
      font-size: 2rem;
      line-height: 1.3; }
      .layoutType01 #calendarNav .prev.text.prev,
      .layoutType01 #calendarNav .next.text.prev {
        width: 10rem;
        padding: 0 3rem 0 0; }
      .layoutType01 #calendarNav .prev.text.next,
      .layoutType01 #calendarNav .next.text.next {
        width: 10rem;
        padding: 0 0 0 3rem; }
  .layoutType01 #calendarNav .prev {
    right: 100%;
    background: url(../img/icon_arrow_prev.png) right center no-repeat;
    background-size: auto 60%; }
  .layoutType01 #calendarNav .next {
    left: 100%;
    background: url(../img/icon_arrow_next.png) left center no-repeat;
    background-size: auto 60%; }
.layoutType01 .desc {
  display: flex;
  align-items: center;
  background-color: #f4f4f4;
  margin: 0 0 1.7rem 0;
  padding: 1.5rem 3.2rem;
  border-radius: 1rem; }
  .layoutType01 .desc p {
    display: flex;
    align-items: center;
    font-size: 1.8rem;
    line-height: 1.56;
    margin: 0 0 0 3rem; }
    .layoutType01 .desc p:first-child {
      margin: 0; }
    .layoutType01 .desc p .link {
      color: #037e00;
      font-size: 2.6rem;
      line-height: 1;
      font-weight: 700;
      text-decoration: underline;
      text-underline-offset: 4px;
      margin: 0 1.3rem 0 0; }
    .layoutType01 .desc p .nolink {
      color: #c4c3c3;
      font-size: 2.6rem;
      line-height: 1;
      font-weight: 700;
      margin: 0 1.3rem 0 0; }
  .layoutType01 .desc a {
    color: #037e00;
    text-decoration: underline; }
.layoutType01 .tableWrap {
  margin: 0 0 3rem 0; }
  .layoutType01 .tableWrap .tableType01 {
    overflow: hidden;
    display: flex;
    box-sizing: border-box; }
    .layoutType01 .tableWrap .tableType01 .column {
      border-top: 1px solid #333333; }
      .layoutType01 .tableWrap .tableType01 .column.head {
        width: calc(250 / 980 * 100%); }
        .layoutType01 .tableWrap .tableType01 .column.head .head {
          border-left: 1px solid #333333; }
        .layoutType01 .tableWrap .tableType01 .column.head .cell {
          display: flex;
          align-items: center;
          font-size: 1.6rem;
          line-height: 1.25;
          letter-spacing: -0.05em;
          padding: 1rem;
          border-left: 1px solid #333333; }
          .layoutType01 .tableWrap .tableType01 .column.head .cell.studio1 {
            background-color: #ffeaf0; }
          .layoutType01 .tableWrap .tableType01 .column.head .cell.studio3 {
            background-color: #defff0; }
          .layoutType01 .tableWrap .tableType01 .column.head .cell.studio4 {
            background-color: #f8e5ff; }
          .layoutType01 .tableWrap .tableType01 .column.head .cell.studio5 {
            background-color: #fff5db; }
      .layoutType01 .tableWrap .tableType01 .column .head {
        display: flex;
        align-items: center;
        justify-content: center;
        height: 4rem;
        font-size: 1.5rem;
        line-height: 1;
        text-align: center;
        background-color: #f4f4f4;
        border-bottom: 1px solid #333333;
        border-right: 1px solid #333333;
        box-sizing: border-box; }
        .layoutType01 .tableWrap .tableType01 .column .head.week0 {
          background-color: #ffd5d5; }
        .layoutType01 .tableWrap .tableType01 .column .head.week6 {
          background-color: #dbeeff; }
      .layoutType01 .tableWrap .tableType01 .column .cell {
        height: 7rem;
        box-sizing: border-box;
        border-bottom: 1px solid #333333;
        border-right: 1px solid #333333; }
    .layoutType01 .tableWrap .tableType01 .slideWrap {
      width: calc(730 / 980 * 100%); }
      .layoutType01 .tableWrap .tableType01 .slideWrap .slide {
        width: 100%; }
        .layoutType01 .tableWrap .tableType01 .slideWrap .slide .week2 {
          border-right: 1px solid #333333; }
          .layoutType01 .tableWrap .tableType01 .slideWrap .slide .week2 .weekInner {
            display: flex; }
          .layoutType01 .tableWrap .tableType01 .slideWrap .slide .week2 .column {
            flex-basis: calc(100% / 14);
            flex-shrink: 0;
            min-width: 3rem; }
            .layoutType01 .tableWrap .tableType01 .slideWrap .slide .week2 .column .cell .link,
            .layoutType01 .tableWrap .tableType01 .slideWrap .slide .week2 .column .cell .nolink {
              display: flex;
              align-items: center;
              justify-content: center;
              width: 100%;
              height: 100%;
              font-weight: 700; }
            .layoutType01 .tableWrap .tableType01 .slideWrap .slide .week2 .column .cell .link {
              color: #037e00;
              font-size: 2.6rem;
              line-height: 1;
              text-decoration: underline;
              text-underline-offset: 4px;
              transition: all 0.2s ease-out; }
              .layoutType01 .tableWrap .tableType01 .slideWrap .slide .week2 .column .cell .link:hover {
                color: #FFFFFF;
                background-color: #037e00 !important; }
            .layoutType01 .tableWrap .tableType01 .slideWrap .slide .week2 .column .cell .nolink {
              color: #c4c3c3;
              font-size: 2.6rem;
              line-height: 1; }
        .layoutType01 .tableWrap .tableType01 .slideWrap .slide .day {
          border-right: 1px solid #333333; }
          .layoutType01 .tableWrap .tableType01 .slideWrap .slide .day .dayInner {
            overflow-x: auto;
            overflow-y: hidden;
            display: flex; }
          .layoutType01 .tableWrap .tableType01 .slideWrap .slide .day .column {
            flex-basis: calc(100% / 48);
            flex-shrink: 0;
            min-width: 4.5rem; }
            .layoutType01 .tableWrap .tableType01 .slideWrap .slide .day .column .cell .link,
            .layoutType01 .tableWrap .tableType01 .slideWrap .slide .day .column .cell .nolink {
              display: flex;
              align-items: center;
              justify-content: center;
              width: 100%;
              height: 100%;
              font-weight: 700; }
            .layoutType01 .tableWrap .tableType01 .slideWrap .slide .day .column .cell .link {
              color: #037e00;
              font-size: 2.6rem;
              line-height: 1;
              text-decoration: underline;
              text-underline-offset: 4px;
              transition: all 0.2s ease-out; }
              .layoutType01 .tableWrap .tableType01 .slideWrap .slide .day .column .cell .link:hover {
                color: #FFFFFF;
                background-color: #037e00 !important; }
            .layoutType01 .tableWrap .tableType01 .slideWrap .slide .day .column .cell .nolink {
              color: #c4c3c3;
              font-size: 2.6rem;
              line-height: 1; }
        .layoutType01 .tableWrap .tableType01 .slideWrap .slide .week2 .column .cell .link.selected[data-studio="1"],
        .layoutType01 .tableWrap .tableType01 .slideWrap .slide .day .column .cell .link.selected[data-studio="1"] {
          background-color: #ffeaf0; }
        .layoutType01 .tableWrap .tableType01 .slideWrap .slide .week2 .column .cell .link.selected[data-studio="3"],
        .layoutType01 .tableWrap .tableType01 .slideWrap .slide .day .column .cell .link.selected[data-studio="3"] {
          background-color: #defff0; }
        .layoutType01 .tableWrap .tableType01 .slideWrap .slide .week2 .column .cell .link.selected[data-studio="4"],
        .layoutType01 .tableWrap .tableType01 .slideWrap .slide .day .column .cell .link.selected[data-studio="4"] {
          background-color: #f8e5ff; }
        .layoutType01 .tableWrap .tableType01 .slideWrap .slide .week2 .column .cell .link.selected[data-studio="5"],
        .layoutType01 .tableWrap .tableType01 .slideWrap .slide .day .column .cell .link.selected[data-studio="5"] {
          background-color: #fff5db; }
  .layoutType01 .tableWrap .tableType02 {
    overflow: hidden;
    display: flex;
    box-sizing: border-box; }
    .layoutType01 .tableWrap .tableType02 .slideWrap {
      width: 100%; }
      .layoutType01 .tableWrap .tableType02 .slideWrap .slide {
        width: 100%; }
        .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month {
          width: 100%;
          text-align: center;
          border-top: 1px solid #333333;
          box-sizing: border-box; }
          .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .week {
            display: flex; }
            .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .week .cell {
              flex-basis: calc(100% / 7);
              font-size: 1.8rem;
              line-height: 1;
              background-color: #f4f4f4;
              padding: 1rem 0;
              border-bottom: 1px solid #333333;
              border-right: 1px solid #333333;
              box-sizing: border-box; }
              .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .week .cell.week0 {
                background-color: #ffd5d5; }
              .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .week .cell.week6 {
                background-color: #dbeeff; }
              .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .week .cell:first-child {
                border-left: 1px solid #333333; }
          .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody {
            display: flex;
            flex-wrap: wrap; }
            .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody .cell {
              flex-basis: calc(100% / 7);
              border-bottom: 1px solid #333333;
              border-right: 1px solid #333333;
              box-sizing: border-box; }
              .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody .cell:nth-child(7n+1) {
                border-left: 1px solid #333333; }
              .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody .cell .link {
                display: block;
                height: 100%;
                background-color: #dbfbdb;
                transition: background-color 0.1s ease-out; }
                .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody .cell .link .cont {
                  background-color: #dbfbdb;
                  transition: background-color 0.1s ease-out; }
                .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody .cell .link.selected .cont:before {
                  content: "選択中";
                  display: block;
                  margin: 0 0 0.5rem 0;
                  border: 1px solid #000;
                  border-radius: 2rem; }
                .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody .cell .link.selected[data-studio="1"] {
                  background-color: #ffeaf0; }
                  .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody .cell .link.selected[data-studio="1"] .cont {
                    background-color: #ffeaf0; }
                .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody .cell .link.selected[data-studio="3"] {
                  background-color: #defff0; }
                  .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody .cell .link.selected[data-studio="3"] .cont {
                    background-color: #defff0; }
                .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody .cell .link.selected[data-studio="4"] {
                  background-color: #f8e5ff; }
                  .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody .cell .link.selected[data-studio="4"] .cont {
                    background-color: #f8e5ff; }
                .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody .cell .link.selected[data-studio="5"] {
                  background-color: #fff5db; }
                  .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody .cell .link.selected[data-studio="5"] .cont {
                    background-color: #fff5db; }
                .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody .cell .link:hover {
                  background-color: #4faa74 !important; }
                  .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody .cell .link:hover .cont {
                    background-color: #4faa74 !important; }
              .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody .cell .day {
                font-size: 1.8rem;
                line-height: 1;
                background-color: #FFFFFF;
                padding: 0.3rem 0;
                border-bottom: 1px solid #333333; }
              .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody .cell .cont {
                font-size: 1.6rem;
                line-height: 1.5;
                min-height: 10.7rem;
                text-align: center;
                background-color: #FFFFFF;
                padding: 0.5rem;
                box-sizing: border-box; }
                .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody .cell .cont .type {
                  font-size: 1.6rem;
                  line-height: 1;
                  background-color: #FFFFFF;
                  padding: 0.3rem 0;
                  border-radius: 0.3rem; }
                .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody .cell .cont .time {
                  font-size: 1.6rem;
                  line-height: 1.75;
                  margin: 0 0 0.5rem 0; }
.layoutType01 .studioNav {
  margin: 0 0 3rem 0; }
  .layoutType01 .studioNav .list {
    display: flex;
    align-items: center;
    justify-content: space-between; }
    .layoutType01 .studioNav .list .item {
      flex-basis: calc(180 / 980 * 100%); }
      .layoutType01 .studioNav .list .item .box {
        opacity: 0.3;
        display: flex;
        align-items: center;
        justify-content: center;
        width: 100%;
        height: 6rem;
        font-size: 1.6rem;
        line-height: 1.13;
        text-align: center;
        border: 1px solid #000000;
        border-radius: 0.5rem;
        box-sizing: border-box;
        transition: all 0.2s ease-out; }
        .layoutType01 .studioNav .list .item .box.current {
          opacity: 1; }
          .layoutType01 .studioNav .list .item .box.current.studio1 {
            background-color: #ffeaf0; }
          .layoutType01 .studioNav .list .item .box.current.studio3 {
            background-color: #defff0; }
          .layoutType01 .studioNav .list .item .box.current.studio4 {
            background-color: #f8e5ff; }
          .layoutType01 .studioNav .list .item .box.current.studio5 {
            background-color: #fff5db; }
        .layoutType01 .studioNav .list .item .box:hover {
          opacity: 1;
          color: #037e00;
          border: 1px solid #037e00; }
          .layoutType01 .studioNav .list .item .box:hover.studio1 {
            background-color: #ffeaf0; }
          .layoutType01 .studioNav .list .item .box:hover.studio3 {
            background-color: #defff0; }
          .layoutType01 .studioNav .list .item .box:hover.studio4 {
            background-color: #f8e5ff; }
          .layoutType01 .studioNav .list .item .box:hover.studio5 {
            background-color: #fff5db; }

@media screen and (max-width: 768px) {
  .layoutType01 .titleWrap {
    display: block; }
    .layoutType01 .titleWrap .title {
      margin: 0 0 1rem 0; }
  .layoutType01 #calendarNav .inner {
    width: 15em; }
    .layoutType01 #calendarNav .inner br {
      display: block; }
  .layoutType01 #calendarNav .prev {
    background: url(../img/icon_arrow_prev.png) right center no-repeat;
    background-size: 1rem 1.6rem; }
  .layoutType01 #calendarNav .next {
    background: url(../img/icon_arrow_next.png) left center no-repeat;
    background-size: 1rem 1.6rem; }
  .layoutType01 .desc {
    display: block;
    padding: 0.5rem 3.2rem; }
    .layoutType01 .desc p {
      margin: 1.5rem 0; }
      .layoutType01 .desc p:first-child {
        margin: 1.5rem 0; }
  .layoutType01 .tableWrap .tableType01 .slideWrap .slide .week2 .weekInner {
    overflow-x: auto;
    overflow-y: hidden; }
  .layoutType01 .tableWrap .tableType01 .slideWrap .slide .week2 .column {
    min-width: 5rem; }
  .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .monthInner {
    overflow-x: auto;
    overflow-y: hidden; }
  .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .week {
    width: calc(12rem * 7); }
    .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .week .cell {
      width: 12rem; }
  .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody {
    width: calc(12rem * 7); }
    .layoutType01 .tableWrap .tableType02 .slideWrap .slide .month .tbody .cell {
      width: 12rem; }
  .layoutType01 .studioNav .list {
    align-items: stretch; }
    .layoutType01 .studioNav .list .item {
      height: inherit; }
      .layoutType01 .studioNav .list .item .box {
        height: 100%;
        font-size: 1.5rem;
        line-height: 1.2;
        padding: 0.8rem 0.2rem; } }
#formArea .contentInner.narrow {
  max-width: 980px; }
#formArea .required {
  display: inline-block;
  color: #FFFFFF;
  font-size: 1.2rem;
  line-height: 1;
  vertical-align: middle;
  background-color: #d94236;
  margin: 0 0 0 1rem;
  padding: 0.2rem 0.5rem 0.35rem 0.5rem;
  border-radius: 0.25rem; }
#formArea input[type="text"],
#formArea input[type="tel"],
#formArea input[type="email"] {
  width: 100%;
  max-width: 38rem;
  font-size: 1.6rem;
  line-height: 1.75;
  padding: 0.55rem 1.5rem;
  border: 1px solid #333333;
  box-sizing: border-box; }
  #formArea input[type="text"].short,
  #formArea input[type="tel"].short,
  #formArea input[type="email"].short {
    max-width: 26rem; }
  #formArea input[type="text"].max,
  #formArea input[type="tel"].max,
  #formArea input[type="email"].max {
    max-width: 100%; }
#formArea textarea {
  width: 100%;
  max-width: 100%;
  height: 20rem;
  font-size: 1.6rem;
  line-height: 1.75;
  padding: 0.55rem 1.5rem;
  border: 1px solid #333333;
  box-sizing: border-box; }
#formArea input[type="radio"] {
  position: relative;
  width: 1.2rem;
  height: 1.2rem;
  background-color: #FFFFFF;
  margin: 0 1rem 0 0;
  border: 1px solid #7e7e7e;
  border-radius: 50%; }
  #formArea input[type="radio"]:checked:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 0.8rem;
    height: 0.8rem;
    background-color: #4faa74;
    margin: auto;
    border-radius: 50%; }
#formArea input[type="checkbox"] {
  position: relative;
  width: 1.2rem;
  height: 1.2rem;
  background-color: #FFFFFF;
  margin: 0 1rem 0 0;
  border: 1px solid #7e7e7e; }
  #formArea input[type="checkbox"]:checked:before {
    content: "";
    position: absolute;
    top: -0.5rem;
    bottom: 0;
    left: 0;
    right: 0;
    width: 0.8rem;
    height: 1.2rem;
    margin: auto;
    border-bottom: 3px solid #4faa74;
    border-right: 3px solid #4faa74;
    transform: rotate(45deg); }
#formArea .errorMessage {
  width: 100%;
  color: #f40000;
  font-size: 1.6rem;
  line-height: 1.75; }
#formArea .errorList p {
  font-size: 1.6rem;
  line-height: 1.25; }
#formArea .confirmText {
  margin: 0.55rem 0 0 0; }
#formArea .statusWrap {
  padding: 2.6rem 0 3rem 0; }
  #formArea .statusWrap .statusArea {
    background-color: #f4f4f4;
    margin: 0 0 1rem 0;
    padding: 3.2rem 3.8rem;
    border-radius: 1rem;
    border: 1px solid #4faa74; }
    #formArea .statusWrap .statusArea.hide {
      display: none; }
    #formArea .statusWrap .statusArea .title {
      color: #148202;
      font-size: 2rem;
      line-height: 1;
      font-weight: 700;
      margin: 0 0 1rem 0; }
      #formArea .statusWrap .statusArea .title:before {
        content: "■";
        margin: 0 1rem 0 0; }
    #formArea .statusWrap .statusArea .row {
      display: flex;
      font-size: 1.8rem;
      line-height: 1.56;
      padding: 1.6rem 0; }
      #formArea .statusWrap .statusArea .row.hide {
        display: none; }
      #formArea .statusWrap .statusArea .row .head {
        display: flex;
        align-items: center;
        flex-shrink: 0;
        width: 39%;
        font-weight: 700;
        padding: 0 0 0 0.5rem;
        box-sizing: border-box; }
      #formArea .statusWrap .statusArea .row .cont .inner {
        display: flex;
        align-items: center; }
      #formArea .statusWrap .statusArea .row .cont label {
        display: block;
        margin: 0 2rem 0 0; }
    #formArea .statusWrap .statusArea .wrap {
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap; }
      #formArea .statusWrap .statusArea .wrap .row {
        display: flex;
        flex-basis: calc(50% - 1rem);
        font-size: 1.8rem;
        line-height: 1.56;
        padding: 1.6rem 0; }
        #formArea .statusWrap .statusArea .wrap .row.studio {
          flex-basis: 100%; }
        #formArea .statusWrap .statusArea .wrap .row .head {
          width: 16.5rem;
          padding: 0 0 0 0.5rem; }
        #formArea .statusWrap .statusArea .wrap .row .cont {
          margin: 0; }
          #formArea .statusWrap .statusArea .wrap .row .cont .inner {
            display: flex;
            align-items: center;
            flex-wrap: wrap; }
    #formArea .statusWrap .statusArea .block {
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap;
      padding: 1rem 0; }
      #formArea .statusWrap .statusArea .block.open .about .aboutTitle:after {
        top: 0.5rem;
        transform: rotate(-135deg); }
      #formArea .statusWrap .statusArea .block .about {
        flex-basis: calc(50% - 1rem); }
        #formArea .statusWrap .statusArea .block .about .aboutTitle {
          position: relative;
          color: #4faa74;
          background-color: #FFFFFF;
          padding: 1rem 2rem;
          border: 1px solid #4faa74;
          border-radius: 0.5rem;
          box-sizing: border-box;
          transition: all 0.2s ease-out; }
          #formArea .statusWrap .statusArea .block .about .aboutTitle:after {
            content: "";
            display: block;
            position: absolute;
            top: 0;
            bottom: 0;
            right: 1rem;
            width: 0.7rem;
            height: 0.7rem;
            border-bottom: 2px solid #4faa74;
            border-right: 2px solid #4faa74;
            margin: auto;
            transform: rotate(45deg);
            transition: all 0.2s ease-out; }
          #formArea .statusWrap .statusArea .block .about .aboutTitle:hover {
            color: #FFFFFF;
            background-color: #4faa74;
            border: 1px solid #4faa74; }
            #formArea .statusWrap .statusArea .block .about .aboutTitle:hover:after {
              border-bottom: 2px solid #FFFFFF;
              border-right: 2px solid #FFFFFF; }
      #formArea .statusWrap .statusArea .block .link {
        flex-basis: calc(50% - 1rem); }
        #formArea .statusWrap .statusArea .block .link a {
          display: block;
          position: relative;
          color: #FFFFFF;
          background-color: #4faa74;
          padding: 1rem 2rem;
          border: 1px solid #4faa74;
          border-radius: 0.5rem;
          box-sizing: border-box;
          transition: all 0.2s ease-out; }
          #formArea .statusWrap .statusArea .block .link a:after {
            content: "";
            display: block;
            position: absolute;
            top: 0;
            bottom: 0;
            right: 1rem;
            width: 0.7rem;
            height: 0.7rem;
            border-bottom: 2px solid #FFFFFF;
            border-right: 2px solid #FFFFFF;
            margin: auto;
            transform: rotate(-45deg);
            transition: all 0.2s ease-out; }
          #formArea .statusWrap .statusArea .block .link a:hover {
            color: #4faa74;
            background-color: #FFFFFF;
            border: 1px solid #4faa74; }
            #formArea .statusWrap .statusArea .block .link a:hover:after {
              border-bottom: 2px solid #4faa74;
              border-right: 2px solid #4faa74; }
      #formArea .statusWrap .statusArea .block .aboutCont {
        flex-basis: 100%; }
        #formArea .statusWrap .statusArea .block .aboutCont .box {
          background-color: #FFFFFF;
          margin: 1.8rem 0 0 0;
          padding: 3.7rem 3.4rem;
          border: 1px solid #4faa74;
          border-radius: 0.5rem; }
          #formArea .statusWrap .statusArea .block .aboutCont .box .boxTitle {
            margin: 0 0 2.3rem 0; }
            #formArea .statusWrap .statusArea .block .aboutCont .box .boxTitle .large {
              font-size: 2rem;
              line-height: 1.2;
              font-weight: 700; }
            #formArea .statusWrap .statusArea .block .aboutCont .box .boxTitle .middle {
              font-size: 1.8rem;
              line-height: 1.33; }
            #formArea .statusWrap .statusArea .block .aboutCont .box .boxTitle .small {
              font-size: 1.6rem;
              line-height: 1.5; }
            #formArea .statusWrap .statusArea .block .aboutCont .box .boxTitle .em {
              color: #e10202;
              font-size: 2rem;
              line-height: 1.5;
              font-weight: 700;
              margin: 0 0 0 0.2rem; }
              #formArea .statusWrap .statusArea .block .aboutCont .box .boxTitle .em .num {
                font-size: 3rem;
                line-height: 1; }
          #formArea .statusWrap .statusArea .block .aboutCont .box .note {
            font-size: 1.2rem;
            line-height: 1.33; }
          #formArea .statusWrap .statusArea .block .aboutCont .box .buttonWrap {
            width: 100%;
            max-width: 480px;
            margin: 5rem auto 0 auto; }
            #formArea .statusWrap .statusArea .block .aboutCont .box .buttonWrap .button {
              padding: 1.6rem 0;
              border-radius: 5rem; }
    #formArea .statusWrap .statusArea .buttonArea {
      width: 18rem;
      margin: auto;
      padding: 2rem 0 0 0; }
      #formArea .statusWrap .statusArea .buttonArea .clearButton {
        display: block;
        position: relative;
        width: 100%;
        font-size: 1.2rem;
        line-height: 1;
        text-align: center;
        background-color: #FFFFFF;
        padding: 0.7rem 0 0.7rem 2rem;
        border: 1px solid #000000;
        border-radius: 2rem;
        transition: all 0.2s ease-out; }
        #formArea .statusWrap .statusArea .buttonArea .clearButton:before, #formArea .statusWrap .statusArea .buttonArea .clearButton:after {
          content: "";
          position: absolute;
          top: 0;
          bottom: 0;
          left: 1.5rem;
          width: 1rem;
          height: 1px;
          background-color: #000000;
          margin: auto;
          transform: rotate(45deg);
          transition: all 0.2s ease-out; }
        #formArea .statusWrap .statusArea .buttonArea .clearButton:after {
          transform: rotate(-45deg); }
        #formArea .statusWrap .statusArea .buttonArea .clearButton:hover {
          color: #FFFFFF;
          background-color: #000000;
          border: 1px solid #000000; }
          #formArea .statusWrap .statusArea .buttonArea .clearButton:hover:before, #formArea .statusWrap .statusArea .buttonArea .clearButton:hover:after {
            background-color: #FFFFFF; }
#formArea .inputArea {
  margin: 0 0 4.5rem 0; }
  #formArea .inputArea .row {
    display: flex;
    font-size: 1.6rem;
    line-height: 1.75;
    margin: 0 0 2rem 0; }
    #formArea .inputArea .row.middle {
      align-items: center; }
      #formArea .inputArea .row.middle.wide .head {
        width: 32.5%;
        min-width: 20rem; }
      #formArea .inputArea .row.middle.wide .cont {
        width: calc(100% - 32.5%); }
    #formArea .inputArea .row.media {
      margin: 4.3rem 0 0 0;
      padding: 2.5rem 0;
      border-top: 1px solid #c2c2c2; }
      #formArea .inputArea .row.media .block {
        margin: 0 0 2rem 0; }
        #formArea .inputArea .row.media .block.open .accordionTrigger:before {
          opacity: 0;
          transform: rotate(180deg); }
        #formArea .inputArea .row.media .block.open .accordionTrigger:after {
          transform: rotate(270deg); }
        #formArea .inputArea .row.media .block .mediaTitle {
          font-size: 1.8rem;
          line-height: 1;
          font-weight: 700;
          padding: 1rem 0; }
        #formArea .inputArea .row.media .block .accordionTrigger {
          cursor: pointer;
          display: flex;
          align-items: center;
          position: relative;
          height: 6rem;
          color: #4faa74;
          font-size: 1.6rem;
          line-height: 1;
          padding: 0 0 0 3rem;
          border: 1px solid #4faa74;
          border-radius: 1px; }
          #formArea .inputArea .row.media .block .accordionTrigger:before, #formArea .inputArea .row.media .block .accordionTrigger:after {
            content: "";
            position: absolute;
            top: 0;
            bottom: 0;
            right: 3rem;
            width: 2px;
            height: 3rem;
            background-color: #4faa74;
            margin: auto;
            transition: all 0.2s ease-out; }
          #formArea .inputArea .row.media .block .accordionTrigger:after {
            transform: rotate(90deg); }
        #formArea .inputArea .row.media .block .mediaCont .inner {
          padding: 2rem 0 0 0; }
    #formArea .inputArea .row.purpos {
      padding: 2.5rem 0;
      border-top: 1px solid #c2c2c2; }
    #formArea .inputArea .row.purposDetail {
      padding: 2.5rem 0;
      border-top: 1px solid #c2c2c2; }
    #formArea .inputArea .row.actor {
      padding: 2.5rem 0;
      border-top: 1px solid #c2c2c2;
      border-bottom: 1px solid #c2c2c2; }
      #formArea .inputArea .row.actor .head {
        margin: 0 0 4.5rem 0; }
      #formArea .inputArea .row.actor .cont .inner {
        display: block !important; }
        #formArea .inputArea .row.actor .cont .inner label {
          display: inline-block;
          width: 100%;
          margin: 0; }
    #formArea .inputArea .row.purposDetail .cont textarea {
      height: 11rem; }
    #formArea .inputArea .row.note .head {
      margin: 0 0 3.5rem 0; }
    #formArea .inputArea .row.billing_note .cont textarea {
      height: 11rem; }
    #formArea .inputArea .row .head {
      flex-shrink: 0;
      width: 25.7%;
      min-width: 24rem;
      font-weight: 700;
      margin: 0.55rem 0 0 0;
      padding: 0 1.5rem 0 0;
      box-sizing: border-box; }
      #formArea .inputArea .row .head .memo {
        display: block;
        font-size: 1.4rem;
        line-height: 1.43; }
      #formArea .inputArea .row .head .guide {
        display: block;
        font-size: 1.4rem;
        line-height: 1.43;
        margin: 1rem 0 0 0; }
    #formArea .inputArea .row .cont {
      width: calc(100% - 25.7%); }
      #formArea .inputArea .row .cont .inner.horizontal {
        display: flex;
        align-items: center;
        flex-wrap: wrap; }
      #formArea .inputArea .row .cont label {
        display: block;
        margin: 0 2rem 0 0; }
      #formArea .inputArea .row .cont .note {
        font-size: 1.4rem;
        line-height: 1.43; }
      #formArea .inputArea .row .cont .else {
        display: flex;
        align-items: center;
        width: 100%;
        padding: 2rem 0 1.5rem 0; }
        #formArea .inputArea .row .cont .else span {
          display: inline-block;
          flex-shrink: 0;
          margin: 0 2rem 0 0; }
        #formArea .inputArea .row .cont .else input {
          max-width: 100%; }
      #formArea .inputArea .row .cont .add .about {
        padding: 1rem 0; }
        #formArea .inputArea .row .cont .add .about.open .aboutTitle:after {
          top: 0.6rem;
          transform: rotate(-135deg); }
        #formArea .inputArea .row .cont .add .about .aboutTitle {
          position: relative;
          max-width: 420px;
          color: #4faa74;
          font-size: 1.6rem;
          line-height: 1;
          background-color: #FFFFFF;
          padding: 1rem 2rem;
          border: 1px solid #4faa74;
          border-radius: 0.5rem;
          box-sizing: border-box;
          transition: all 0.2s ease-out; }
          #formArea .inputArea .row .cont .add .about .aboutTitle:after {
            content: "";
            display: block;
            position: absolute;
            top: 0;
            bottom: 0;
            right: 1rem;
            width: 0.7rem;
            height: 0.7rem;
            border-bottom: 2px solid #4faa74;
            border-right: 2px solid #4faa74;
            margin: auto;
            transform: rotate(45deg);
            transition: all 0.2s ease-out; }
          #formArea .inputArea .row .cont .add .about .aboutTitle:hover {
            color: #FFFFFF;
            background-color: #4faa74;
            border: 1px solid #4faa74; }
            #formArea .inputArea .row .cont .add .about .aboutTitle:hover:after {
              border-bottom: 2px solid #FFFFFF;
              border-right: 2px solid #FFFFFF; }
        #formArea .inputArea .row .cont .add .about .aboutCont .box {
          margin: calc(18 / 700 * 100%) 0 0 0;
          padding: calc(25 / 700 * 100%);
          border: 1px solid #4faa74;
          border-radius: 0.5rem; }
          #formArea .inputArea .row .cont .add .about .aboutCont .box h3 {
            font-size: 2rem;
            line-height: 1.3;
            font-weight: 700;
            margin: 0 0 1.5rem 0; }
          #formArea .inputArea .row .cont .add .about .aboutCont .box .desc {
            font-size: 1.6rem;
            line-height: 1.63; }
          #formArea .inputArea .row .cont .add .about .aboutCont .box .buttonWrap {
            padding: 2.5rem 0; }
            #formArea .inputArea .row .cont .add .about .aboutCont .box .buttonWrap .button {
              max-width: 280px;
              margin: auto; }
          #formArea .inputArea .row .cont .add .about .aboutCont .box .table {
            color: #333333;
            margin: 0 0 calc(25 / 700 * 100%) 0; }
            #formArea .inputArea .row .cont .add .about .aboutCont .box .table .tableHead {
              display: flex; }
              #formArea .inputArea .row .cont .add .about .aboutCont .box .table .tableHead .cell {
                color: #FFFFFF;
                font-size: 1.4rem;
                line-height: 1;
                font-weight: 700;
                text-align: center;
                background-color: #4faa74;
                padding: 1rem 0; }
                #formArea .inputArea .row .cont .add .about .aboutCont .box .table .tableHead .cell:nth-child(1) {
                  flex-basis: calc(225 / 650 * 100%); }
                #formArea .inputArea .row .cont .add .about .aboutCont .box .table .tableHead .cell:nth-child(2) {
                  flex-basis: calc(120 / 650 * 100%); }
                #formArea .inputArea .row .cont .add .about .aboutCont .box .table .tableHead .cell:nth-child(3) {
                  flex-basis: calc(305 / 650 * 100%); }
            #formArea .inputArea .row .cont .add .about .aboutCont .box .table .tableRow {
              display: flex;
              border-bottom: 1px solid #4faa74; }
              #formArea .inputArea .row .cont .add .about .aboutCont .box .table .tableRow .cell {
                display: flex;
                align-items: center;
                padding: 1rem 1.7rem;
                border-left: 1px solid #4faa74;
                box-sizing: border-box; }
                #formArea .inputArea .row .cont .add .about .aboutCont .box .table .tableRow .cell:nth-child(1) {
                  flex-basis: calc(225 / 650 * 100%); }
                #formArea .inputArea .row .cont .add .about .aboutCont .box .table .tableRow .cell:nth-child(2) {
                  flex-basis: calc(120 / 650 * 100%); }
                #formArea .inputArea .row .cont .add .about .aboutCont .box .table .tableRow .cell:nth-child(3) {
                  flex-basis: calc(305 / 650 * 100%);
                  border-right: 1px solid #4faa74; }
                #formArea .inputArea .row .cont .add .about .aboutCont .box .table .tableRow .cell p {
                  font-size: 1.4rem;
                  line-height: 1.57; }
                #formArea .inputArea .row .cont .add .about .aboutCont .box .table .tableRow .cell .image {
                  width: calc(179 / 191 * 100%); }
                  #formArea .inputArea .row .cont .add .about .aboutCont .box .table .tableRow .cell .image .caption {
                    font-size: 1.4rem;
                    line-height: 1.29;
                    margin: 1rem 0 0 0; }
                #formArea .inputArea .row .cont .add .about .aboutCont .box .table .tableRow .cell .price {
                  min-width: 9rem; }
                  #formArea .inputArea .row .cont .add .about .aboutCont .box .table .tableRow .cell .price .num {
                    font-size: 2rem;
                    line-height: 0.9; }
                  #formArea .inputArea .row .cont .add .about .aboutCont .box .table .tableRow .cell .price .unit {
                    font-size: 1rem;
                    line-height: 1.8; }
                #formArea .inputArea .row .cont .add .about .aboutCont .box .table .tableRow .cell .note {
                  font-size: 1rem;
                  line-height: 1.8; }
  #formArea .inputArea .customer {
    padding: 2.5rem 0 0 0; }
    #formArea .inputArea .customer .titleWrap {
      display: flex;
      margin: 0 0 2.5rem 0; }
      #formArea .inputArea .customer .titleWrap .title {
        flex-shrink: 0;
        width: 25.7%;
        min-width: 23rem;
        font-size: 2.6rem;
        line-height: 1.08;
        font-weight: 700; }
      #formArea .inputArea .customer .titleWrap .about.open .button:after {
        top: 0.5rem;
        transform: rotate(-135deg); }
      #formArea .inputArea .customer .titleWrap .about .button {
        display: block;
        position: relative;
        font-size: 1.4rem;
        line-height: 1;
        text-align: center;
        background-color: #FFFFFF;
        padding: 0.7rem 10rem 0.6rem 1.5rem;
        border: 1px solid #000000;
        border-radius: 2rem;
        transition: all 0.2s ease-out; }
        #formArea .inputArea .customer .titleWrap .about .button:after {
          content: "";
          display: block;
          position: absolute;
          top: 0;
          bottom: 0;
          right: 1rem;
          width: 0.7rem;
          height: 0.7rem;
          border-bottom: 2px solid #4faa74;
          border-right: 2px solid #4faa74;
          margin: auto;
          transform: rotate(45deg);
          transition: all 0.2s ease-out; }
        #formArea .inputArea .customer .titleWrap .about .button:hover {
          color: #FFFFFF;
          background-color: #000000;
          border: 1px solid #000000; }
          #formArea .inputArea .customer .titleWrap .about .button:hover:after {
            border-bottom: 2px solid #FFFFFF;
            border-right: 2px solid #FFFFFF; }
      #formArea .inputArea .customer .titleWrap .about .cont p {
        font-size: 1.6rem;
        line-height: 1.5;
        padding: 1rem 2rem; }
  #formArea .inputArea .billing {
    padding: 7.2rem 0 0 0; }
    #formArea .inputArea .billing .titleWrap {
      display: flex;
      align-items: center;
      margin: 0 0 2.5rem 0; }
      #formArea .inputArea .billing .titleWrap .title {
        flex-shrink: 0;
        width: 19%;
        min-width: 17rem;
        font-size: 2.6rem;
        line-height: 1.08;
        font-weight: 700; }
      #formArea .inputArea .billing .titleWrap .buttonArea {
        width: 81%;
        max-width: 76rem; }
        #formArea .inputArea .billing .titleWrap .buttonArea .copyButton {
          display: block;
          width: 100%;
          color: #148202;
          font-size: 2rem;
          line-height: 1;
          font-weight: 700;
          text-align: center;
          background-color: #f4f4f4;
          padding: 2.65rem 0;
          border: 1px solid #148202;
          border-radius: 1rem;
          transition: all 0.2s ease-out; }
          #formArea .inputArea .billing .titleWrap .buttonArea .copyButton:hover {
            color: #FFFFFF;
            background-color: #148202;
            border: 1px solid #148202; }
    #formArea .inputArea .billing .desc {
      font-size: 1.8rem;
      line-height: 1.56;
      margin: 0 0 3.3rem 0; }
#formArea .attention {
  font-size: 1.6rem;
  line-height: 1.75;
  margin: 0 0 2rem 0;
  padding: 1.5rem 2.7rem;
  border: 1px solid #7e7e7e; }
  #formArea .attention .row .head {
    font-size: 1.8rem;
    line-height: 1.11;
    margin: 0 0 0.5rem 0; }
  #formArea .attention .row .cont ul li {
    font-size: 1.4rem;
    line-height: 1.43; }
#formArea .checkArea {
  font-size: 1.6rem;
  line-height: 1.75;
  text-align: center; }
  #formArea .checkArea .inner {
    display: inline-block;
    text-align: left; }
    #formArea .checkArea .inner a {
      text-decoration: underline; }
#formArea .submitArea {
  width: 100%;
  max-width: 63rem;
  font-size: 1.6rem;
  line-height: 1.75;
  margin: auto;
  padding: 4rem 0 6.5rem 0; }
  #formArea .submitArea.confirm {
    display: flex;
    justify-content: space-between;
    max-width: 100%; }
    #formArea .submitArea.confirm > * {
      flex-basis: calc(50% - 1rem);
      width: auto; }
  #formArea .submitArea .submitButton {
    display: block;
    width: 100%;
    color: #FFFFFF;
    font-size: 2rem;
    line-height: 1;
    text-align: center;
    background-color: #4faa74;
    padding: 3rem;
    border: 2px solid #4faa74;
    border-radius: 4rem;
    transition: all 0.2s ease-out; }
    #formArea .submitArea .submitButton:hover {
      color: #4faa74;
      background-color: #FFFFFF; }
  #formArea .submitArea .backButton {
    display: block;
    width: 100%;
    color: #000000;
    font-size: 2rem;
    line-height: 1;
    text-align: center;
    background-color: #cacaca;
    padding: 3rem;
    border: 2px solid #cacaca;
    border-radius: 4rem;
    transition: all 0.2s ease-out; }
    #formArea .submitArea .backButton:hover {
      background-color: #FFFFFF; }

@media screen and (max-width: 768px) {
  #formArea .statusWrap {
    padding: 2.6rem 0 3rem 0; }
    #formArea .statusWrap .statusArea .row {
      display: block; }
      #formArea .statusWrap .statusArea .row .head {
        width: 100%;
        padding: 0; }
    #formArea .statusWrap .statusArea .wrap .row {
      display: block; }
      #formArea .statusWrap .statusArea .wrap .row .head {
        width: 100%;
        padding: 0; }
    #formArea .statusWrap .statusArea .block .about {
      flex-basis: 100%;
      order: 1;
      margin: 0 0 2rem 0; }
    #formArea .statusWrap .statusArea .block .link {
      flex-basis: 100%;
      order: 3; }
    #formArea .statusWrap .statusArea .block .aboutCont {
      flex-basis: 100%;
      order: 2; }
      #formArea .statusWrap .statusArea .block .aboutCont .box {
        margin: 0 0 2rem 0; }
        #formArea .statusWrap .statusArea .block .aboutCont .box .buttonWrap {
          margin: 3rem auto 0 auto; }
          #formArea .statusWrap .statusArea .block .aboutCont .box .buttonWrap .button {
            padding: 1rem 0 1.2rem 0; }
  #formArea .inputArea .row {
    display: block; }
    #formArea .inputArea .row.middle.wide .head {
      width: 100%; }
    #formArea .inputArea .row.middle.wide .cont {
      width: 100%; }
    #formArea .inputArea .row.actor .head {
      margin: 0 0 0.5rem 0; }
    #formArea .inputArea .row.actor .cont .inner label {
      width: 100%;
      margin: 0; }
    #formArea .inputArea .row.note .head {
      margin: 0 0 0.5rem 0; }
    #formArea .inputArea .row.billing_note .cont textarea {
      height: 11rem; }
    #formArea .inputArea .row .head {
      width: 100%;
      margin: 0 0 0.5rem 0; }
      #formArea .inputArea .row .head .guide {
        display: inline-block;
        margin: 0 0 0 2rem; }
    #formArea .inputArea .row .cont {
      width: 100%; }
  #formArea .inputArea .customer .titleWrap {
    display: block; }
    #formArea .inputArea .customer .titleWrap .about {
      margin: 2rem 0 0 0; }
      #formArea .inputArea .customer .titleWrap .about a {
        padding: 0.8rem 0; }
  #formArea .inputArea .billing .titleWrap {
    display: block; }
    #formArea .inputArea .billing .titleWrap .buttonArea {
      width: 100%;
      margin: 2rem 0 0 0; }
      #formArea .inputArea .billing .titleWrap .buttonArea .copyButton {
        padding: 1.5rem 0; } }
#thanksArea .title {
  font-size: 3.2rem;
  line-height: 1.5;
  text-align: center;
  margin: 0 0 3rem 0;
  padding: 2rem 0 0 0; }
#thanksArea .textWrap {
  max-width: 600px;
  text-align: center;
  margin: 0 auto 10rem auto; }
  #thanksArea .textWrap .text {
    font-size: 2rem;
    line-height: 2;
    margin: 0 0 2rem 0; }
    #thanksArea .textWrap .text .em {
      color: #f40000;
      font-weight: 700;
      font-family: sans-serif; }

@media screen and (max-width: 768px) {
  #thanksArea .title {
    margin: 0 0 4rem 0; } }
#modalArea {
  display: none;
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 2000; }
  #modalArea .content {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.7); }
  #modalArea .box {
    width: 90%;
    max-width: 840px;
    text-align: center;
    background-color: #FFFFFF;
    padding: 9.5rem 4rem 12.5rem 4rem;
    box-sizing: border-box; }
    #modalArea .box .title {
      font-size: 3rem;
      line-height: 1;
      margin: 0 0 4.5rem 0; }
    #modalArea .box .text {
      font-size: 1.8rem;
      line-height: 1;
      margin: 0 0 3rem 0; }
    #modalArea .box .button {
      display: flex;
      align-items: center;
      justify-content: center;
      position: relative;
      max-width: 680px;
      min-height: 8rem;
      color: #FFFFFF;
      font-size: 2.4rem;
      line-height: 1;
      background-color: #037e00;
      margin: auto;
      border-radius: 1rem;
      box-sizing: border-box;
      transition: all 0.2s ease-out; }
      #modalArea .box .button:before {
        content: "";
        display: block;
        position: absolute;
        top: 0;
        bottom: 0;
        left: 4rem;
        width: 3.4rem;
        background: url(../img/icon_calendar_white.png) center center no-repeat;
        background-size: contain;
        padding: 3.2rem 0 0 0;
        transition: all 0.2s ease-out; }
      #modalArea .box .button.disabled {
        cursor: auto;
        background-color: #dbdbdb; }
      #modalArea .box .button:not(.disabled):hover {
        color: #037e00;
        background-color: #FFFFFF;
        border: 1px solid #037e00; }
        #modalArea .box .button:not(.disabled):hover:before {
          background: url(../img/icon_calendar.png) center center no-repeat;
          background-size: contain; }

#page404 .title {
  font-size: 2.4rem;
  line-height: 1.33;
  font-weight: 700;
  text-align: center;
  padding: calc(54 / 345 * 100%) 0 calc(36 / 345 * 100%) 0; }
#page404 .textWrap {
  margin: 0 0 calc(45 / 345 * 100%) 0; }
  #page404 .textWrap .text {
    font-size: 1.5rem;
    line-height: 2;
    text-indent: -1em;
    margin: 0 0 0.5em 0;
    padding: 0 0 0 1em; }
    #page404 .textWrap .text:before {
      content: "・";
      font-family: sans-serif; }
#page404 .buttonArea {
  margin: 0 0 calc(80 / 345 * 100%) 0; }

@media screen and (min-width: 769px) {
  #page404 .title {
    padding: 5.1% 0 calc(51 / 1000 * 100%) 0; }
  #page404 .textWrap {
    max-width: 750px;
    margin: 0 auto calc(52 / 1000 * 100%) auto; }
  #page404 .buttonArea {
    margin: 0 0 calc(80 / 1000 * 100%) 0; } }
#header {
  position: relative;
  z-index: 200;
  aspect-ratio: 375 / 50;
  margin: 0 0 5rem 0; }
  #header .content {
    width: 100%;
    height: 100%; }
  #header .contentInner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    max-width: 100%;
    height: 100%;
    padding: 0; }
  #header .logoArea {
    display: flex;
    align-items: center;
    flex-basis: calc(240 / 375 * 100%);
    flex-shrink: 0;
    position: relative;
    height: 100%; }
    #header .logoArea .logo {
      flex-basis: calc(80 / 240 * 100%);
      position: relative;
      height: 100%; }
      #header .logoArea .logo img {
        position: absolute;
        top: 0;
        left: 0; }
    #header .logoArea .name {
      font-size: 2.6rem;
      line-height: 1;
      white-space: nowrap;
      margin: 0 0 0 2.5rem; }
  #header .menu .menuButton {
    position: relative;
    z-index: 2000;
    text-indent: -9999em;
    padding: 1rem;
    margin: 0 2rem 0 0; }
    #header .menu .menuButton .wrap {
      position: absolute;
      top: 0;
      bottom: 0;
      left: 0;
      right: 0;
      width: 3rem;
      height: 2.5rem;
      margin: auto; }
      #header .menu .menuButton .wrap span {
        position: absolute;
        left: 0;
        right: 0;
        height: 2px;
        background-color: #000000;
        margin: auto;
        transition: all 0.2s; }
        #header .menu .menuButton .wrap span:nth-of-type(1) {
          top: 0; }
        #header .menu .menuButton .wrap span:nth-of-type(2) {
          top: calc(50% - 1px); }
        #header .menu .menuButton .wrap span:nth-of-type(3) {
          bottom: 0; }
  #header .menu .menuContent {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 999;
    height: 100vh; }
    #header .menu .menuContent .bg {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      height: 100vh;
      background-color: #FFFFFF; }
    #header .menu .menuContent .list {
      position: relative;
      z-index: 2;
      width: 80%;
      font-size: 1.8rem;
      line-height: 1;
      margin: auto;
      padding: calc(80 / 375 * 100%) 0 0 0; }
      #header .menu .menuContent .list .item {
        margin: 0 0 2rem 0; }
        #header .menu .menuContent .list .item p .block {
          display: block;
          position: relative;
          font-size: 2.4rem;
          line-height: 1;
          font-weight: 700;
          margin: 0 0 1rem 0;
          padding: 1.5rem 0;
          border-bottom: 1px solid #000000; }
          #header .menu .menuContent .list .item p .block.link {
            padding-right: 2rem; }
            #header .menu .menuContent .list .item p .block.link:before {
              content: "";
              position: absolute;
              top: 0;
              bottom: 0;
              right: 0.4em;
              width: 0.6em;
              height: 0.6em;
              margin: auto;
              border-top: 1px solid #000000;
              border-right: 1px solid #000000;
              transform: rotate(45deg); }
        #header .menu .menuContent .list .item .child {
          padding: 0 0 0 2rem; }
          #header .menu .menuContent .list .item .child .childItem a {
            display: block;
            position: relative;
            padding: 1rem 0 1rem 2rem; }
            #header .menu .menuContent .list .item .child .childItem a:before {
              content: "";
              position: absolute;
              top: 0;
              bottom: 0;
              left: 0;
              width: 0.5em;
              height: 0.5em;
              margin: auto;
              border-top: 1px solid #000000;
              border-right: 1px solid #000000;
              transform: rotate(45deg); }
  #header .menu .open .menuButton .wrap span:nth-of-type(1) {
    bottom: 0;
    left: 0;
    transform: translateY(50%) translateY(-1px) rotate(-45deg); }
  #header .menu .open .menuButton .wrap span:nth-of-type(2) {
    opacity: 0;
    left: 0; }
  #header .menu .open .menuButton .wrap span:nth-of-type(3) {
    top: 0;
    left: 0;
    transform: translateY(-50%) translateY(1px) rotate(45deg); }
  #header .nav {
    flex-basis: calc(180 / 375 * 100%);
    margin: 0 calc(20 / 1440 * 100%) 0 0; }
    #header .nav .list .item .block {
      display: flex;
      align-items: center;
      justify-content: center;
      position: relative;
      width: 100%;
      height: 100%;
      font-size: 1.8rem;
      line-height: 1;
      border: 1px solid #000000;
      border-radius: 0.5rem;
      box-sizing: border-box; }
      #header .nav .list .item .block.accordionTrigger:after {
        content: "";
        display: block;
        position: absolute;
        top: 0;
        bottom: 0;
        right: 1rem;
        width: 0.7rem;
        height: 0.7rem;
        border-bottom: 2px solid #000000;
        border-right: 2px solid #000000;
        margin: auto;
        transform: rotate(45deg); }
    #header .nav .list .item .accordion.open .accordionTrigger:after {
      top: 0.2rem;
      transform: rotate(-135deg); }
    #header .nav .list .item .accordionContent {
      position: absolute;
      margin: 1rem 0 0 0; }
      #header .nav .list .item .accordionContent .child {
        background-color: #FFFFFF;
        padding: 1rem 2rem;
        border-radius: 1rem;
        box-shadow: 5px 9px 10px rgba(0, 0, 0, 0.15); }
        #header .nav .list .item .accordionContent .child .childItem {
          border-bottom: 1px solid #cacaca; }
          #header .nav .list .item .accordionContent .child .childItem:last-child {
            border-bottom: 0; }
          #header .nav .list .item .accordionContent .child .childItem a {
            display: block;
            position: relative;
            padding: 2rem 2rem 2rem 0; }
            #header .nav .list .item .accordionContent .child .childItem a:after {
              content: "";
              display: block;
              position: absolute;
              top: 0;
              bottom: 0;
              right: 0.5rem;
              width: 0.7rem;
              height: 0.7rem;
              border-top: 2px solid #000000;
              border-right: 2px solid #000000;
              margin: auto;
              transform: rotate(45deg); }

@media screen and (min-width: 769px) {
  #header {
    height: 74px;
    margin: 0 0 46px 0;
    aspect-ratio: auto; }
    #header .logoArea {
      flex-basis: calc(400 / 1440 * 100%);
      flex-shrink: 0;
      position: relative;
      z-index: 1010; }
      #header .logoArea .logo {
        flex-basis: calc(161 / 400 * 100%);
        min-width: 120px; }
    #header .nav {
      flex-basis: calc(530 / 1440 * 100%);
      min-width: 450px; }
      #header .nav .list {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%; }
        #header .nav .list .item {
          flex-basis: calc(171 / 530 * 100%); }
          #header .nav .list .item .block {
            aspect-ratio: 171 / 52; } }
#footer .content {
  padding: 4rem 0 15rem 0; }
#footer .copyright {
  text-align: center; }
  #footer .copyright small {
    font-size: 1.2rem;
    line-height: 2.33;
    letter-spacing: 0.1em; }

/* linkType01 */
/* buttonType01 */
.buttonType01 {
  display: block;
  position: relative;
  width: 100%;
  color: #FFFFFF;
  font-size: 1.6rem;
  line-height: 1;
  font-weight: 700;
  text-align: center;
  background-color: #4faa74;
  padding: 1.75rem 0;
  border: 1px solid #4faa74;
  border-radius: 3rem;
  box-sizing: border-box;
  transition: color 0.3s ease; }
  .buttonType01.next:after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 2rem;
    width: 0.7rem;
    height: 0.7rem;
    border-bottom: 2px solid #FFFFFF;
    border-right: 2px solid #FFFFFF;
    margin: auto;
    transform: rotate(-45deg);
    transition: all 0.2s ease-out; }

@media screen and (min-width: 769px) {
  .buttonType01:hover {
    color: #4faa74;
    background-color: #FFFFFF; }
  .buttonType01.next:hover:after {
    border-bottom: 2px solid #4faa74;
    border-right: 2px solid #4faa74; } }
