@charset "UTF-8";
/* Scss Document */
/* ブレイクポイント */
/*　アニメーション準備用　*/
/*　flex　*/
/*　.mv用　*/
/* カラー設定 */
/* 共通設定 */
html, body {
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0; }

html {
  font-size: 62.5%; }
  html body {
    font-size: 14px;
    font-size: 1.4rem;
    letter-spacing: 0.06em;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 400;
    font-optical-sizing: auto;
    font-style: normal;
    color: #154615;
    -webkit-font-smoothing: antialiased;
    -webkit-text-size-adjust: 100%;
    position: relative;
    background: #FFFBF4; }
    html body img {
      border: none;
      line-height: 0;
      vertical-align: top;
      margin: 0;
      max-width: 100%;
      height: auto;
      width: auto; }
    html body a {
      color: #154615;
      text-decoration: underline;
      text-underline-offset: 2px;
      text-decoration-thickness: 1px; }
      html body a:hover {
        text-decoration: none; }

*, *:before, *:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box; }

body.is-loading {
  overflow: hidden; }
body #loading {
  width: 100%;
  height: 100svh;
  position: fixed;
  z-index: 9999;
  background: #FFFBF4;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 1.8s ease, visibility 1.8s ease;
  --p: 0;
  /* 0〜1 */
  --count: 0;
  /* 表示する文字数（JSから入れる） */ }
  body #loading .loading-inner {
    width: 170px;
    height: 284px;
    position: relative;
    text-align: center; }
    body #loading .loading-inner .loading-text {
      font-size: 1.0rem;
      font-weight: bold;
      color: #70422F;
      will-change: contents;
      /*position: absolute;
      left: 0;
      bottom: 42px;
      transform: rotate(83deg);*/ }
      body #loading .loading-inner .loading-text .loading-percentage {
        font-size: 1.0rem;
        font-weight: bold;
        letter-spacing: 0;
        color: #70422F;
        font-display: swap;
        font-variant-ligatures: none;
        font-feature-settings: "liga" off;
        font-synthesis: none;
        text-rendering: optimizeLegibility;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale; }
    body #loading .loading-inner .loading-progressbar {
      width: 48px;
      height: 30px;
      position: absolute;
      left: -40px;
      bottom: 42px;
      background: url("../images/index/bg_fukidashi.svg") no-repeat 0 0;
      background-size: cover;
      display: flex;
      align-items: center;
      justify-content: center; }
    body #loading .loading-inner .bar {
      /*width: 1px;
      height: 123px;
      background: $accent-color;
      border-radius: 1px;
      transform: rotate(-3deg);*/
      width: 1px;
      height: 123px;
      border-radius: 1px;
      transform: rotate(-3deg);
      background: transparent;
      position: relative;
      overflow: hidden; }
      body #loading .loading-inner .bar::before {
        content: "";
        position: absolute;
        left: 0;
        top: 0;
        width: 1px;
        height: calc(123px * var(--p));
        background: #70422F;
        border-radius: 1px;
        transition: height 0.15s linear; }
    body #loading .loading-inner .loading-movetext-t01 span,
    body #loading .loading-inner .loading-movetext-t02 span {
      opacity: 0; }
      body #loading .loading-inner .loading-movetext-t01 span.is-on,
      body #loading .loading-inner .loading-movetext-t02 span.is-on {
        opacity: 1; }
    body #loading .loading-inner .loading-movetext-t01 {
      position: absolute;
      top: 0;
      right: 42px; }
      body #loading .loading-inner .loading-movetext-t01 span {
        display: block; }
        body #loading .loading-inner .loading-movetext-t01 span:first-of-type {
          margin-bottom: 7px; }
        body #loading .loading-inner .loading-movetext-t01 span:nth-of-type(2) {
          margin-bottom: 8px;
          margin-right: 3px; }
        body #loading .loading-inner .loading-movetext-t01 span:nth-of-type(3) {
          margin-right: 5px; }
    body #loading .loading-inner .loading-movetext-t02 {
      position: absolute;
      top: 13px;
      right: 82px; }
      body #loading .loading-inner .loading-movetext-t02 span {
        display: block; }
        body #loading .loading-inner .loading-movetext-t02 span:nth-of-type(1) {
          margin-bottom: 7px; }
        body #loading .loading-inner .loading-movetext-t02 span:nth-of-type(2) {
          margin-bottom: 8px;
          margin-left: 4px; }
        body #loading .loading-inner .loading-movetext-t02 span:nth-of-type(3) {
          margin-bottom: 7px;
          margin-left: 7px; }
        body #loading .loading-inner .loading-movetext-t02 span:nth-of-type(4) {
          margin-bottom: 11px;
          margin-left: 12px; }
        body #loading .loading-inner .loading-movetext-t02 span:nth-of-type(5) {
          margin-left: 14px; }
    body #loading .loading-inner .loading-movetext-img {
      width: 170px;
      height: 109px;
      position: absolute;
      right: 0;
      bottom: 0; }
  body #loading.hidden {
    visibility: hidden;
    opacity: 0;
    pointer-events: none; }
body #wrapper {
  width: 100%;
  min-height: 100vh;
  margin: 0 auto;
  position: relative;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex; }
  @media (max-width: 1499px) {
    body #wrapper {
      width: 100%;
      min-height: auto;
      display: block;
      position: relative;
      padding-top: 60px;
      /* スマホ用ヘッダーの高さ */ } }
  @media (max-width: 1499px) {
    body #wrapper .pc {
      display: none; } }
  body #wrapper .sp {
    display: none; }
    @media (max-width: 1499px) {
      body #wrapper .sp {
        display: block; } }
  body #wrapper .header {
    width: 250px;
    padding: 0;
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: flex-end; }
    @media (max-width: 1499px) {
      body #wrapper .header {
        width: 100%;
        height: 60px;
        display: block;
        background: #fff;
        z-index: 204;
        box-shadow: 0px 0px 4px rgba(0, 0, 0, 0.16);
        position: fixed;
        top: 0;
        left: 0; } }
    body #wrapper .header__inner {
      width: 100%;
      min-height: 100vh;
      position: sticky;
      left: 0;
      bottom: 0;
      padding: 60px 0; }
      @media (max-width: 1499px) {
        body #wrapper .header__inner {
          width: 100%;
          height: 60px;
          min-height: auto;
          position: relative;
          left: auto;
          bottom: auto;
          padding: 12px 0 0; } }
    body #wrapper .header__logo {
      width: 65px;
      margin: 0 auto 40px; }
      @media (max-width: 1499px) {
        body #wrapper .header__logo {
          width: 195px;
          margin: 0 auto; } }
      @media (max-width: 355px) {
        body #wrapper .header__logo {
          width: 60%; } }
    body #wrapper .header__nav {
      width: 120px;
      margin: 0 auto;
      padding: 34px 0 0;
      border-top: solid 1px #154615; }
      @media (max-width: 1499px) {
        body #wrapper .header__nav {
          display: none; } }
      body #wrapper .header__nav .navmenu {
        list-style: none;
        text-align: right; }
        body #wrapper .header__nav .navmenu__item {
          margin-bottom: 20px; }
          body #wrapper .header__nav .navmenu__item a {
            font-size: 1.8rem;
            font-family: "Zen Maru Gothic", sans-serif;
            font-weight: 700;
            letter-spacing: 0.02em;
            display: block;
            text-decoration: none; }
            body #wrapper .header__nav .navmenu__item a strong {
              font-weight: 700;
              display: inline-block;
              position: relative;
              padding-bottom: 4px; }
              body #wrapper .header__nav .navmenu__item a strong::before {
                width: 100%;
                height: 10px;
                display: block;
                content: "";
                background: #D9C5AD;
                border-radius: 10px;
                position: absolute;
                left: 0;
                bottom: 0;
                z-index: -1;
                opacity: 0;
                transition-duration: 0.4s;
                transform: translate(0, 5px);
                -webkit-transition-duration: 0.4s;
                -webkit-transform: translate(0, 5px);
                -moz-transition-duration: 0.4s;
                -moz-transform: translate(0, 5px);
                -ms-transition-duration: 0.4s;
                -ms-transform: translate(0, 5px);
                -o-transition-duration: 0.4s;
                -o-transform: translate(0, 5px); }
            body #wrapper .header__nav .navmenu__item a:hover strong::before {
              opacity: 1;
              transform: translate(0, 0);
              -webkit-transform: translate(0, 0);
              -moz-transform: translate(0, 0);
              -ms-transform: translate(0, 0);
              -o-transform: translate(0, 0); }
        body #wrapper .header__nav .navmenu__contact {
          margin-bottom: 29px; }
          body #wrapper .header__nav .navmenu__contact a {
            width: 100%;
            height: 40px;
            display: block;
            line-height: 40px;
            background: #154615;
            border-radius: 4px;
            text-align: center;
            color: #fff;
            font-size: 1.6rem;
            font-family: "Zen Maru Gothic", sans-serif;
            font-weight: 700;
            letter-spacing: 0.02em;
            text-decoration: none;
            transition: all 0.3s; }
            body #wrapper .header__nav .navmenu__contact a:hover {
              background: #fff;
              color: #154615; }
        body #wrapper .header__nav .navmenu__inst img {
          width: 24px; }
    body #wrapper .header .bt_menumodal {
      width: 60px;
      height: 60px;
      position: absolute;
      top: 0;
      left: 0;
      background: #154615; }
      body #wrapper .header .bt_menumodal a {
        width: 100%;
        height: 100%;
        display: block;
        position: relative;
        cursor: pointer; }
        body #wrapper .header .bt_menumodal a span {
          width: 20px;
          height: 2px;
          display: block;
          background: #fff;
          position: absolute;
          top: 25px;
          right: 16px;
          transition: all 0.3s;
          border-radius: 2px; }
          body #wrapper .header .bt_menumodal a span::before {
            width: 26px;
            height: 2px;
            display: block;
            content: "";
            background: #fff;
            border-radius: 2px;
            position: absolute;
            top: -9px;
            right: 0;
            transition: all 0.3s; }
          body #wrapper .header .bt_menumodal a span::after {
            width: 26px;
            height: 2px;
            display: block;
            content: "";
            background: #fff;
            border-radius: 2px;
            position: absolute;
            top: 9px;
            right: 0;
            transition: all 0.3s; }
        body #wrapper .header .bt_menumodal a strong {
          width: 100%;
          display: block;
          font-size: 0.9rem;
          font-family: "Zen Maru Gothic", sans-serif;
          font-weight: 700;
          color: #fff;
          text-align: center;
          position: absolute;
          left: 0;
          bottom: 10px; }
    body #wrapper .header .spinst {
      width: 29px;
      position: absolute;
      top: 19px;
      right: 23px; }
  body #wrapper .js-modal {
    display: none;
    width: 100%;
    height: 100vh;
    position: fixed;
    top: 0;
    /*background: $bg-color;*/
    background: rgba(255, 251, 244, 0.95);
    overflow-y: scroll;
    z-index: 90; }
    body #wrapper .js-modal .modal__bg {
      width: 100%;
      min-height: 100vh;
      position: absolute;
      z-index: 91; }
    body #wrapper .js-modal .modal__content {
      width: 100%;
      max-width: 100%;
      position: absolute;
      right: 0;
      top: 0;
      margin: 0;
      z-index: 92; }
    body #wrapper .js-modal .spnav {
      width: 100%;
      padding: 130px 0 60px; }
    body #wrapper .js-modal .spnavmenu {
      list-style: none; }
      body #wrapper .js-modal .spnavmenu__item {
        margin-bottom: 22px; }
        body #wrapper .js-modal .spnavmenu__item a {
          font-size: 2.1rem;
          font-family: "Zen Maru Gothic", sans-serif;
          font-weight: 700;
          letter-spacing: 0;
          display: block;
          text-align: center;
          padding: 5px 0;
          text-decoration: none; }
        body #wrapper .js-modal .spnavmenu__item:last-of-type {
          margin-bottom: 0; }
  body #wrapper .main {
    flex: 1;
    width: calc(100% - 250px);
    overflow: hidden;
    padding-top: 40px; }
    @media (max-width: 1499px) {
      body #wrapper .main {
        width: 100%;
        padding-top: 80px; } }
    body #wrapper .main .topicpass {
      width: 100%;
      margin: 0 0 120px;
      padding: 0 0 0 50px; }
      @media (max-width: 1499px) {
        body #wrapper .main .topicpass {
          display: none; } }
      body #wrapper .main .topicpass__list {
        display: flex;
        opacity: 0;
        transition-duration: 0.8s;
        transform: translate(15px, 0);
        -webkit-transition-duration: 0.8s;
        -webkit-transform: translate(15px, 0);
        -moz-transition-duration: 0.8s;
        -moz-transform: translate(15px, 0);
        -ms-transition-duration: 0.8s;
        -ms-transform: translate(15px, 0);
        -o-transition-duration: 0.8s;
        -o-transform: translate(15px, 0); }
        body #wrapper .main .topicpass__list.mv {
          opacity: 1;
          transform: translate(0, 0);
          -webkit-transform: translate(0, 0);
          -moz-transform: translate(0, 0);
          -ms-transform: translate(0, 0);
          -o-transform: translate(0, 0); }
        body #wrapper .main .topicpass__list-item {
          font-size: 1.4rem;
          color: #333;
          padding-right: 22px;
          position: relative; }
          @media (max-width: 1499px) {
            body #wrapper .main .topicpass__list-item {
              font-size: 1.0rem; } }
          body #wrapper .main .topicpass__list-item::after {
            width: 22px;
            height: 100%;
            display: block;
            content: "＞";
            text-align: center;
            position: absolute;
            top: 0;
            right: 0; }
          body #wrapper .main .topicpass__list-item a {
            color: #333;
            text-decoration: underline;
            transition: all 0.3s; }
            body #wrapper .main .topicpass__list-item a:hover {
              text-decoration: none; }
          body #wrapper .main .topicpass__list-item:last-of-type {
            padding-right: 0; }
            body #wrapper .main .topicpass__list-item:last-of-type::after {
              display: none; }
    body #wrapper .main .contents {
      width: 100%; }
      body #wrapper .main .contents .box {
        width: 100%; }
        body #wrapper .main .contents .box .inner {
          width: 1200px;
          margin: 0 auto; }
          @media (max-width: 1499px) {
            body #wrapper .main .contents .box .inner {
              width: 79.49%; } }
          @media (max-width: 743px) {
            body #wrapper .main .contents .box .inner {
              width: 100%;
              padding: 0 40px; } }
      body #wrapper .main .contents .pagetitle {
        text-align: center;
        margin-bottom: 80px;
        opacity: 0;
        transition-duration: 0.8s;
        transform: translate(0, 15px);
        -webkit-transition-duration: 0.8s;
        -webkit-transform: translate(0, 15px);
        -moz-transition-duration: 0.8s;
        -moz-transform: translate(0, 15px);
        -ms-transition-duration: 0.8s;
        -ms-transform: translate(0, 15px);
        -o-transition-duration: 0.8s;
        -o-transform: translate(0, 15px); }
        body #wrapper .main .contents .pagetitle.mv {
          opacity: 1;
          transform: translate(0, 0);
          -webkit-transform: translate(0, 0);
          -moz-transform: translate(0, 0);
          -ms-transform: translate(0, 0);
          -o-transform: translate(0, 0); }
        @media (max-width: 743px) {
          body #wrapper .main .contents .pagetitle {
            margin-bottom: 70px; } }
        body #wrapper .main .contents .pagetitle strong,
        body #wrapper .main .contents .pagetitle span {
          font-family: "Zen Maru Gothic", sans-serif;
          font-weight: 700; }
        body #wrapper .main .contents .pagetitle strong {
          font-size: 4.8rem;
          letter-spacing: 0.2em;
          position: relative;
          display: inline-block; }
          @media (max-width: 743px) {
            body #wrapper .main .contents .pagetitle strong {
              font-size: 3.6rem;
              letter-spacing: 0.1em; } }
          body #wrapper .main .contents .pagetitle strong::after {
            width: calc(100% + 6px);
            height: 5px;
            display: block;
            content: "";
            position: absolute;
            bottom: -18px;
            left: -3px; }
            @media (max-width: 743px) {
              body #wrapper .main .contents .pagetitle strong::after {
                bottom: -12px; } }
        body #wrapper .main .contents .pagetitle span {
          font-size: 1.8rem;
          display: block;
          margin-top: 30px; }
          @media (max-width: 743px) {
            body #wrapper .main .contents .pagetitle span {
              font-size: 1.6rem;
              margin-top: 23px;
              letter-spacing: 0.02em; } }
      body #wrapper .main .contents .leadtext {
        font-size: 2.1rem;
        line-height: 1.7;
        text-align: center;
        margin-bottom: 70px;
        opacity: 0;
        transition-duration: 0.8s;
        transform: translate(0, 15px);
        -webkit-transition-duration: 0.8s;
        -webkit-transform: translate(0, 15px);
        -moz-transition-duration: 0.8s;
        -moz-transform: translate(0, 15px);
        -ms-transition-duration: 0.8s;
        -ms-transform: translate(0, 15px);
        -o-transition-duration: 0.8s;
        -o-transform: translate(0, 15px); }
        body #wrapper .main .contents .leadtext.mv {
          opacity: 1;
          transform: translate(0, 0);
          -webkit-transform: translate(0, 0);
          -moz-transform: translate(0, 0);
          -ms-transform: translate(0, 0);
          -o-transform: translate(0, 0); }
        @media (max-width: 743px) {
          body #wrapper .main .contents .leadtext {
            font-size: 1.8rem;
            text-align: left;
            margin-bottom: 40px; } }
        @media (max-width: 743px) {
          body #wrapper .main .contents .leadtext br {
            display: none; } }
      body #wrapper .main .contents .linkbuttonbox {
        text-align: center; }
      body #wrapper .main .contents .linkbutton {
        width: auto;
        height: auto; }
        body #wrapper .main .contents .linkbutton a {
          width: auto;
          display: inline-block;
          vertical-align: top;
          background: #70422F;
          text-decoration: none;
          padding: 20px 48px 20px;
          border-radius: 40px;
          transition: all 0.3s; }
          @media (max-width: 743px) {
            body #wrapper .main .contents .linkbutton a {
              padding: 16px 38px; } }
          body #wrapper .main .contents .linkbutton a strong {
            font-size: 2.1rem;
            letter-spacing: 0.08em;
            color: #fff;
            display: inline-block;
            padding-right: 30px;
            position: relative; }
            @media (max-width: 743px) {
              body #wrapper .main .contents .linkbutton a strong {
                font-size: 1.8rem;
                padding-right: 26px; } }
            body #wrapper .main .contents .linkbutton a strong::before, body #wrapper .main .contents .linkbutton a strong::after {
              width: 14px;
              height: 2px;
              content: "";
              display: inline-block;
              background: #fff;
              border-radius: 2px;
              position: absolute;
              right: 0;
              transition: all 0.3s; }
              @media (max-width: 743px) {
                body #wrapper .main .contents .linkbutton a strong::before, body #wrapper .main .contents .linkbutton a strong::after {
                  width: 10px; } }
            body #wrapper .main .contents .linkbutton a strong::after {
              transform: rotate(45deg);
              top: 6px; }
            body #wrapper .main .contents .linkbutton a strong::before {
              transform: rotate(-45deg);
              bottom: 4px; }
          body #wrapper .main .contents .linkbutton a:hover {
            background: #154615; }
            body #wrapper .main .contents .linkbutton a:hover strong::before, body #wrapper .main .contents .linkbutton a:hover strong::after {
              right: -5px; }
  body #wrapper .footer {
    position: relative;
    margin-top: 120px; }
    @media (max-width: 1499px) {
      body #wrapper .footer {
        margin-top: 80px;
        z-index: 5; } }
    body #wrapper .footer__inner {
      width: 1200px;
      margin: 0 auto;
      padding: 71px 0 68px;
      position: relative; }
      @media (max-width: 1499px) {
        body #wrapper .footer__inner {
          width: 100%; } }
      @media (max-width: 743px) {
        body #wrapper .footer__inner {
          padding: 40px 0; } }
      body #wrapper .footer__inner::after {
        width: 100%;
        height: 8px;
        border: solid 1px #154615;
        border-radius: 4px;
        display: block;
        content: "";
        position: absolute;
        top: 0;
        left: 0; }
        @media (max-width: 1499px) {
          body #wrapper .footer__inner::after {
            width: 79.49%;
            left: 50%;
            transform: translateX(-50%); } }
        @media (max-width: 743px) {
          body #wrapper .footer__inner::after {
            width: calc(100% - 80px); } }
    body #wrapper .footer__copyright {
      font-size: 1.2rem;
      font-weight: 600;
      letter-spacing: 0.04em;
      text-align: center; }
      @media (max-width: 1499px) {
        body #wrapper .footer__copyright {
          text-align: center; } }
body.menu-open #wrapper .header .bt_menumodal a span {
  background: #154615; }
  body.menu-open #wrapper .header .bt_menumodal a span::before {
    top: 0;
    transform: rotate(45deg); }
  body.menu-open #wrapper .header .bt_menumodal a span::after {
    top: 0;
    transform: rotate(-45deg); }

#top {
  height: 100svh;
  overflow: hidden; }
  #top #wrapper {
    width: 100%;
    height: 100svh;
    overflow: hidden;
    position: relative; }
    @media (min-width: 1500px) {
      #top #wrapper .header {
        width: 100%;
        height: 100svh;
        overflow: hidden;
        justify-content: flex-start; } }
    @media (min-width: 1500px) {
      #top #wrapper .header__inner {
        min-height: 0;
        max-height: 100svh;
        overflow-y: auto;
        overscroll-behavior: contain;
        -webkit-overflow-scrolling: touch; } }
    @media (min-width: 1500px) {
      #top #wrapper .header__logo {
        margin-left: 94px;
        margin-right: 0; } }
    #top #wrapper .header__logo a img.pc {
      filter: brightness(0) invert(1); }
    #top #wrapper .header__nav {
      margin-left: 65px;
      margin-right: 0;
      border-top-color: #fff; }
      #top #wrapper .header__nav .navmenu__item a {
        color: #fff; }
      #top #wrapper .header__nav .navmenu__contact a {
        background: #fff;
        color: #154615; }
        #top #wrapper .header__nav .navmenu__contact a:hover {
          background: #154615;
          color: #fff; }
      #top #wrapper .header__nav .navmenu__inst a img {
        filter: brightness(0) invert(1); }
    #top #wrapper .main {
      width: 100%;
      height: 100svh;
      padding-top: 0;
      position: absolute;
      top: 0;
      left: 0;
      z-index: -1; }
      #top #wrapper .main .video {
        width: 100%;
        height: 100svh;
        position: relative; }
        #top #wrapper .main .video__image video {
          width: 100%;
          height: 100%;
          object-fit: cover;
          position: absolute;
          top: 0;
          left: 0;
          z-index: -2; }
          @media (max-width: 1499px) {
            #top #wrapper .main .video__image video {
              object-position: 50% 50%; } }
          @media (max-width: 743px) {
            #top #wrapper .main .video__image video {
              height: calc(100% - 60px);
              object-position: 50% 50%;
              top: 60px; } }
        @media (max-width: 743px) {
          #top #wrapper .main .video__image.pcmovie {
            display: none; } }
        #top #wrapper .main .video__image.spmovie {
          display: none; }
          @media (max-width: 743px) {
            #top #wrapper .main .video__image.spmovie {
              display: block; } }
      #top #wrapper .main .footer {
        width: calc(100% - 250px);
        position: absolute;
        right: 50px;
        bottom: 50px;
        margin-top: 0; }
        @media (max-width: 743px) {
          #top #wrapper .main .footer {
            display: none; } }
        #top #wrapper .main .footer__inner {
          width: 100%;
          margin: 0;
          padding: 0; }
          #top #wrapper .main .footer__inner::after {
            display: none; }
        #top #wrapper .main .footer__copyright {
          color: #fff;
          text-align: right; }

#faq #wrapper .main .contents .pagetitle strong::after {
  background: url("../images/faq/titleline.webp") no-repeat 0 0;
  background-size: cover; }
  @media (max-width: 743px) {
    #faq #wrapper .main .contents .pagetitle strong::after {
      background-size: 100% auto; } }
@media (max-width: 743px) {
  #faq #wrapper .main .contents .leadtext br:last-of-type {
    display: block; } }
#faq #wrapper .main .contents .faqlist__q {
  width: 100%;
  background: #D9C5AD;
  border-radius: 10px;
  margin-bottom: 40px;
  opacity: 0;
  transition-duration: 0.8s;
  transform: translate(15px, 0);
  -webkit-transition-duration: 0.8s;
  -webkit-transform: translate(15px, 0);
  -moz-transition-duration: 0.8s;
  -moz-transform: translate(15px, 0);
  -ms-transition-duration: 0.8s;
  -ms-transform: translate(15px, 0);
  -o-transition-duration: 0.8s;
  -o-transform: translate(15px, 0); }
  #faq #wrapper .main .contents .faqlist__q.mv {
    opacity: 1;
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0);
    -moz-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    -o-transform: translate(0, 0); }
  @media (max-width: 1499px) {
    #faq #wrapper .main .contents .faqlist__q {
      display: flex; } }
  #faq #wrapper .main .contents .faqlist__q span,
  #faq #wrapper .main .contents .faqlist__q strong {
    font-size: 2.7rem;
    font-family: "Zen Maru Gothic", sans-serif;
    font-weight: 700;
    line-height: 60px; }
    @media (max-width: 1499px) {
      #faq #wrapper .main .contents .faqlist__q span,
      #faq #wrapper .main .contents .faqlist__q strong {
        display: flex;
        align-items: center; } }
    @media (max-width: 743px) {
      #faq #wrapper .main .contents .faqlist__q span,
      #faq #wrapper .main .contents .faqlist__q strong {
        font-size: 2.1rem; } }
  #faq #wrapper .main .contents .faqlist__q span {
    width: 65px;
    background: #70422F;
    display: inline-block;
    text-align: center;
    color: #fff;
    border-radius: 10px 0 0 10px;
    margin-right: 17px; }
    @media (max-width: 1499px) {
      #faq #wrapper .main .contents .faqlist__q span {
        display: flex;
        justify-content: center;
        line-height: 1.0;
        margin-right: 0; } }
    @media (max-width: 743px) {
      #faq #wrapper .main .contents .faqlist__q span {
        width: 50px; } }
  #faq #wrapper .main .contents .faqlist__q strong {
    color: #70422F;
    letter-spacing: 0.04em; }
    @media (max-width: 1499px) {
      #faq #wrapper .main .contents .faqlist__q strong {
        width: calc(100% - 65px);
        line-height: 1.2;
        padding: 16px 33px 16px 10px; } }
    @media (max-width: 743px) {
      #faq #wrapper .main .contents .faqlist__q strong {
        width: calc(100% - 50px); } }
#faq #wrapper .main .contents .faqlist__a {
  margin-bottom: 70px;
  padding-left: 92px;
  position: relative;
  opacity: 0;
  transition-duration: 0.8s;
  transform: translate(15px, 0);
  -webkit-transition-duration: 0.8s;
  -webkit-transform: translate(15px, 0);
  -moz-transition-duration: 0.8s;
  -moz-transform: translate(15px, 0);
  -ms-transition-duration: 0.8s;
  -ms-transform: translate(15px, 0);
  -o-transition-duration: 0.8s;
  -o-transform: translate(15px, 0); }
  #faq #wrapper .main .contents .faqlist__a.mv {
    opacity: 1;
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0);
    -moz-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    -o-transform: translate(0, 0); }
  @media (max-width: 743px) {
    #faq #wrapper .main .contents .faqlist__a {
      padding-left: 0; } }
  #faq #wrapper .main .contents .faqlist__a::after {
    width: 18px;
    height: 15px;
    display: block;
    content: "";
    background: url("../images/faq/arrow.svg") no-repeat 0 0;
    background-size: contain;
    position: absolute;
    top: 15px;
    left: 65px; }
    @media (max-width: 743px) {
      #faq #wrapper .main .contents .faqlist__a::after {
        top: 9px;
        left: -25px; } }
  #faq #wrapper .main .contents .faqlist__a-text {
    width: 880px;
    font-size: 2.1rem;
    line-height: 2.0;
    margin-bottom: 50px; }
    @media (max-width: 1499px) {
      #faq #wrapper .main .contents .faqlist__a-text {
        width: 100%;
        margin-bottom: 35px; } }
    @media (max-width: 743px) {
      #faq #wrapper .main .contents .faqlist__a-text {
        font-size: 1.8rem;
        line-height: 1.7; } }
    #faq #wrapper .main .contents .faqlist__a-text.visit {
      text-indent: -21px;
      padding-left: 21px; }
      @media (max-width: 743px) {
        #faq #wrapper .main .contents .faqlist__a-text.visit {
          text-indent: -18px;
          padding-left: 18px; } }
      @media (max-width: 743px) {
        #faq #wrapper .main .contents .faqlist__a-text.visit strong {
          display: block;
          margin-bottom: 10px; } }
      @media (max-width: 743px) {
        #faq #wrapper .main .contents .faqlist__a-text.visit br:first-of-type {
          display: none; } }
    #faq #wrapper .main .contents .faqlist__a-text:last-of-type {
      margin-bottom: 0; }

#greeting #wrapper .main .contents .pagetitle strong::after {
  background: url("../images/greeting/titleline.webp") no-repeat 0 0;
  background-size: cover; }
  @media (max-width: 743px) {
    #greeting #wrapper .main .contents .pagetitle strong::after {
      background-size: 100% auto; } }
#greeting #wrapper .main .contents .text {
  width: 800px;
  margin: 0 auto 60px;
  font-size: 2.1rem;
  line-height: 2.0;
  opacity: 0;
  transition-duration: 0.8s;
  transform: translate(0, 15px);
  -webkit-transition-duration: 0.8s;
  -webkit-transform: translate(0, 15px);
  -moz-transition-duration: 0.8s;
  -moz-transform: translate(0, 15px);
  -ms-transition-duration: 0.8s;
  -ms-transform: translate(0, 15px);
  -o-transition-duration: 0.8s;
  -o-transform: translate(0, 15px); }
  #greeting #wrapper .main .contents .text.mv {
    opacity: 1;
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0);
    -moz-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    -o-transform: translate(0, 0); }
  @media (max-width: 1499px) {
    #greeting #wrapper .main .contents .text {
      width: 66.67%; } }
  @media (max-width: 743px) {
    #greeting #wrapper .main .contents .text {
      width: 100%;
      font-size: 1.8rem;
      margin-bottom: 40px; } }
  #greeting #wrapper .main .contents .text:last-of-type {
    margin-bottom: 0; }

#profile #wrapper .main .contents .pagetitle strong::after {
  background: url("../images/profile/titleline.webp") no-repeat 0 0;
  background-size: cover; }
  @media (max-width: 743px) {
    #profile #wrapper .main .contents .pagetitle strong::after {
      background-size: 100% auto; } }
#profile #wrapper .main .contents .prflist {
  width: 100%;
  margin-bottom: 93px;
  list-style-type: none; }
  @media (max-width: 743px) {
    #profile #wrapper .main .contents .prflist {
      margin-bottom: 60px; } }
  #profile #wrapper .main .contents .prflist__item {
    width: 100%;
    margin-bottom: 80px; }
    #profile #wrapper .main .contents .prflist__item:last-of-type {
      margin-bottom: 0; }
    #profile #wrapper .main .contents .prflist__item:nth-of-type(1) .prflist__caption {
      opacity: 0;
      transition-duration: 0.8s;
      transform: translate(15px, 0);
      -webkit-transition-duration: 0.8s;
      -webkit-transform: translate(15px, 0);
      -moz-transition-duration: 0.8s;
      -moz-transform: translate(15px, 0);
      -ms-transition-duration: 0.8s;
      -ms-transform: translate(15px, 0);
      -o-transition-duration: 0.8s;
      -o-transform: translate(15px, 0); }
      #profile #wrapper .main .contents .prflist__item:nth-of-type(1) .prflist__caption.mv {
        opacity: 1;
        transform: translate(0, 0);
        -webkit-transform: translate(0, 0);
        -moz-transform: translate(0, 0);
        -ms-transform: translate(0, 0);
        -o-transform: translate(0, 0); }
    #profile #wrapper .main .contents .prflist__item:nth-of-type(2) .prflist__figure {
      flex-direction: row-reverse; }
    #profile #wrapper .main .contents .prflist__item:nth-of-type(2) .prflist__caption {
      padding-left: 0;
      padding-right: 60px;
      opacity: 0;
      transition-duration: 0.8s;
      transform: translate(-15px, 0);
      -webkit-transition-duration: 0.8s;
      -webkit-transform: translate(-15px, 0);
      -moz-transition-duration: 0.8s;
      -moz-transform: translate(-15px, 0);
      -ms-transition-duration: 0.8s;
      -ms-transform: translate(-15px, 0);
      -o-transition-duration: 0.8s;
      -o-transform: translate(-15px, 0); }
      #profile #wrapper .main .contents .prflist__item:nth-of-type(2) .prflist__caption.mv {
        opacity: 1;
        transform: translate(0, 0);
        -webkit-transform: translate(0, 0);
        -moz-transform: translate(0, 0);
        -ms-transform: translate(0, 0);
        -o-transform: translate(0, 0); }
      @media (max-width: 743px) {
        #profile #wrapper .main .contents .prflist__item:nth-of-type(2) .prflist__caption {
          padding-right: 0; } }
  #profile #wrapper .main .contents .prflist__figure {
    width: 100%;
    display: flex; }
    @media (max-width: 1499px) {
      #profile #wrapper .main .contents .prflist__figure {
        display: block; } }
  #profile #wrapper .main .contents .prflist__img {
    width: 300px; }
    @media (max-width: 1499px) {
      #profile #wrapper .main .contents .prflist__img {
        width: 100%;
        margin-bottom: 40px;
        padding: 0 35px;
        text-align: center; } }
    #profile #wrapper .main .contents .prflist__img img {
      border-radius: 40px;
      opacity: 0;
      mask-image: linear-gradient(135deg, black 35%, transparent 65%);
      -webkit-mask-image: linear-gradient(135deg, black 35%, transparent 65%);
      mask-size: 300% 300%;
      -webkit-mask-size: 300% 300%;
      mask-position: bottom right;
      -webkit-mask-position: bottom right;
      transition: opacity 1.8s ease, mask-position 2.0s ease, -webkit-mask-position 2.0s ease; }
    #profile #wrapper .main .contents .prflist__img.mv img {
      opacity: 1;
      mask-position: top left;
      -webkit-mask-position: top left; }
  #profile #wrapper .main .contents .prflist__caption {
    width: calc(100% - 300px);
    padding: 30px 0 0 60px; }
    @media (max-width: 1499px) {
      #profile #wrapper .main .contents .prflist__caption {
        width: 100%;
        padding: 0; } }
  #profile #wrapper .main .contents .prflist__text-name {
    margin-bottom: 40px;
    padding-left: 30px;
    position: relative;
    display: flex;
    align-items: center; }
    @media (max-width: 743px) {
      #profile #wrapper .main .contents .prflist__text-name {
        margin-bottom: 29px;
        padding-left: 16px; } }
    #profile #wrapper .main .contents .prflist__text-name strong,
    #profile #wrapper .main .contents .prflist__text-name span {
      font-family: "Zen Maru Gothic", sans-serif;
      font-weight: 700;
      letter-spacing: 0.04em; }
    #profile #wrapper .main .contents .prflist__text-name strong {
      font-size: 3.6rem; }
      @media (max-width: 743px) {
        #profile #wrapper .main .contents .prflist__text-name strong {
          font-size: 2.7rem; } }
    #profile #wrapper .main .contents .prflist__text-name span {
      font-size: 2.1rem; }
      @media (max-width: 743px) {
        #profile #wrapper .main .contents .prflist__text-name span {
          font-size: 1.6rem; } }
    #profile #wrapper .main .contents .prflist__text-name::after {
      width: 10px;
      height: 100%;
      display: block;
      content: "";
      background: #D9C5AD;
      border-radius: 10px;
      position: absolute;
      top: 2px;
      left: 0; }
      @media (max-width: 743px) {
        #profile #wrapper .main .contents .prflist__text-name::after {
          width: 8px; } }
  #profile #wrapper .main .contents .prflist__text-desc {
    font-size: 2.1rem;
    line-height: 2.0; }
    @media (max-width: 743px) {
      #profile #wrapper .main .contents .prflist__text-desc {
        font-size: 1.8rem; } }

#group #wrapper .main .contents .pagetitle strong::after {
  background: url("../images/group/titleline.webp") no-repeat 0 0;
  background-size: cover; }
  @media (max-width: 743px) {
    #group #wrapper .main .contents .pagetitle strong::after {
      background-size: 100% auto; } }
#group #wrapper .main .contents .infobox {
  width: 800px;
  margin: 0 auto 56px;
  padding: 30px 50px;
  background: #fff;
  border: solid 2px #70422F;
  border-radius: 20px; }
  @media (max-width: 1499px) {
    #group #wrapper .main .contents .infobox {
      width: 66.67%; } }
  @media (max-width: 743px) {
    #group #wrapper .main .contents .infobox {
      width: 100%;
      margin-bottom: 40px;
      padding: 20px 25px; } }
  #group #wrapper .main .contents .infobox .movetext {
    opacity: 0;
    transition-duration: 0.8s;
    transform: translate(15px, 0);
    -webkit-transition-duration: 0.8s;
    -webkit-transform: translate(15px, 0);
    -moz-transition-duration: 0.8s;
    -moz-transform: translate(15px, 0);
    -ms-transition-duration: 0.8s;
    -ms-transform: translate(15px, 0);
    -o-transition-duration: 0.8s;
    -o-transform: translate(15px, 0); }
    #group #wrapper .main .contents .infobox .movetext.mv {
      opacity: 1;
      transform: translate(0, 0);
      -webkit-transform: translate(0, 0);
      -moz-transform: translate(0, 0);
      -ms-transform: translate(0, 0);
      -o-transform: translate(0, 0); }
  #group #wrapper .main .contents .infobox__text {
    display: flex;
    font-size: 2.1rem; }
    @media (max-width: 1499px) {
      #group #wrapper .main .contents .infobox__text {
        display: block; } }
    @media (max-width: 743px) {
      #group #wrapper .main .contents .infobox__text {
        font-size: 1.8rem; } }
    #group #wrapper .main .contents .infobox__text strong {
      font-weight: 700;
      letter-spacing: 0.04em;
      margin-right: 32px;
      padding-left: 16px;
      position: relative; }
      @media (max-width: 1499px) {
        #group #wrapper .main .contents .infobox__text strong {
          display: block;
          line-height: 1.3; } }
      #group #wrapper .main .contents .infobox__text strong::after {
        width: 6px;
        height: 100%;
        display: block;
        content: "";
        background: #D9C5AD;
        border-radius: 6px;
        position: absolute;
        top: 2px;
        left: 0; }
    @media (max-width: 1499px) {
      #group #wrapper .main .contents .infobox__text span {
        display: block;
        margin-top: 15px; } }
  #group #wrapper .main .contents .infobox .infolist {
    padding-top: 20px;
    padding-bottom: 20px; }
    @media (max-width: 743px) {
      #group #wrapper .main .contents .infobox .infolist {
        padding: 10px 0; } }
    #group #wrapper .main .contents .infobox .infolist__item {
      margin-bottom: 32px; }
      @media (max-width: 743px) {
        #group #wrapper .main .contents .infobox .infolist__item {
          margin-bottom: 25px; } }
      #group #wrapper .main .contents .infobox .infolist__item:last-of-type {
        margin-bottom: 0; }
  #group #wrapper .main .contents .infobox:first-of-type .infobox__text strong {
    width: 134px;
    margin-right: 0; }
  #group #wrapper .main .contents .infobox:last-of-type {
    margin-bottom: 48px; }
#group #wrapper .main .contents .infonote {
  width: 800px;
  margin: 0 auto;
  font-size: 1.6rem;
  line-height: 1.5;
  letter-spacing: 0.02em;
  text-indent: -16px;
  padding-left: 16px;
  opacity: 0;
  transition-duration: 0.8s;
  transform: translate(15px, 0);
  -webkit-transition-duration: 0.8s;
  -webkit-transform: translate(15px, 0);
  -moz-transition-duration: 0.8s;
  -moz-transform: translate(15px, 0);
  -ms-transition-duration: 0.8s;
  -ms-transform: translate(15px, 0);
  -o-transition-duration: 0.8s;
  -o-transform: translate(15px, 0); }
  #group #wrapper .main .contents .infonote.mv {
    opacity: 1;
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0);
    -moz-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    -o-transform: translate(0, 0); }
  @media (max-width: 1499px) {
    #group #wrapper .main .contents .infonote {
      width: 66.67%; } }
  @media (max-width: 743px) {
    #group #wrapper .main .contents .infonote {
      width: 100%;
      font-size: 1.4rem;
      text-indent: -14px;
      padding-left: 14px; } }

@media (max-width: 743px) {
  #activity #wrapper .main .contents .box .inner {
    padding-left: 0;
    padding-right: 0; } }
#activity #wrapper .main .contents .pagetitle strong::after {
  background: url("../images/activity/titleline.webp") no-repeat 0 0;
  background-size: cover; }
  @media (max-width: 743px) {
    #activity #wrapper .main .contents .pagetitle strong::after {
      background-size: 100% auto; } }
@media (max-width: 743px) {
  #activity #wrapper .main .contents .leadtext {
    padding: 0 40px; } }
#activity #wrapper .main .contents .instfeed ul {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px; }
  @media (max-width: 743px) {
    #activity #wrapper .main .contents .instfeed ul {
      grid-template-columns: repeat(3, 1fr); } }
  #activity #wrapper .main .contents .instfeed ul li img {
    opacity: 0;
    mask-image: linear-gradient(135deg, black 35%, transparent 65%);
    -webkit-mask-image: linear-gradient(135deg, black 35%, transparent 65%);
    mask-size: 300% 300%;
    -webkit-mask-size: 300% 300%;
    mask-position: bottom right;
    -webkit-mask-position: bottom right;
    transition: opacity 1.8s ease, mask-position 2.0s ease, -webkit-mask-position 2.0s ease; }
  #activity #wrapper .main .contents .instfeed ul li.mv img {
    opacity: 1;
    mask-position: top left;
    -webkit-mask-position: top left; }

@media (max-width: 743px) {
  #access #wrapper .main .contents .box .inner {
    padding: 0; } }
#access #wrapper .main .contents .pagetitle strong::after {
  background: url("../images/access/titleline.webp") no-repeat 0 0;
  background-size: cover; }
  @media (max-width: 743px) {
    #access #wrapper .main .contents .pagetitle strong::after {
      background-size: 100% auto; } }
#access #wrapper .main .contents .mapbox {
  margin-bottom: 48px; }
  @media (max-width: 743px) {
    #access #wrapper .main .contents .mapbox {
      margin-bottom: 30px; } }
  #access #wrapper .main .contents .mapbox__mi {
    font-size: 2.4rem;
    font-family: "Zen Maru Gothic", sans-serif;
    font-weight: 700;
    margin-bottom: 24px;
    padding-left: 20px;
    position: relative;
    opacity: 0;
    transition-duration: 0.8s;
    transform: translate(15px, 0);
    -webkit-transition-duration: 0.8s;
    -webkit-transform: translate(15px, 0);
    -moz-transition-duration: 0.8s;
    -moz-transform: translate(15px, 0);
    -ms-transition-duration: 0.8s;
    -ms-transform: translate(15px, 0);
    -o-transition-duration: 0.8s;
    -o-transform: translate(15px, 0); }
    #access #wrapper .main .contents .mapbox__mi.mv {
      opacity: 1;
      transform: translate(0, 0);
      -webkit-transform: translate(0, 0);
      -moz-transform: translate(0, 0);
      -ms-transform: translate(0, 0);
      -o-transform: translate(0, 0); }
    @media (max-width: 743px) {
      #access #wrapper .main .contents .mapbox__mi {
        font-size: 1.8rem;
        margin-left: 40px;
        margin-bottom: 20px;
        padding-left: 14px; } }
    #access #wrapper .main .contents .mapbox__mi::after {
      width: 8px;
      height: 100%;
      display: block;
      content: "";
      background: #D9C5AD;
      border-radius: 10px;
      position: absolute;
      top: 2px;
      left: 0; }
      @media (max-width: 743px) {
        #access #wrapper .main .contents .mapbox__mi::after {
          width: 6px; } }
  #access #wrapper .main .contents .mapbox__map {
    width: 100%;
    height: 726px; }
    @media (max-width: 743px) {
      #access #wrapper .main .contents .mapbox__map {
        height: 236px; } }
    #access #wrapper .main .contents .mapbox__map iframe {
      border-radius: 40px; }
      @media (max-width: 743px) {
        #access #wrapper .main .contents .mapbox__map iframe {
          border-radius: 0; } }
#access #wrapper .main .contents .address {
  font-style: normal;
  opacity: 0;
  transition-duration: 0.8s;
  transform: translate(15px, 0);
  -webkit-transition-duration: 0.8s;
  -webkit-transform: translate(15px, 0);
  -moz-transition-duration: 0.8s;
  -moz-transform: translate(15px, 0);
  -ms-transition-duration: 0.8s;
  -ms-transform: translate(15px, 0);
  -o-transition-duration: 0.8s;
  -o-transform: translate(15px, 0); }
  #access #wrapper .main .contents .address.mv {
    opacity: 1;
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0);
    -moz-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    -o-transform: translate(0, 0); }
  #access #wrapper .main .contents .address__text {
    display: flex;
    align-items: center; }
    @media (max-width: 743px) {
      #access #wrapper .main .contents .address__text {
        display: block;
        margin-left: 40px; } }
    #access #wrapper .main .contents .address__text strong {
      width: 96px;
      /*height: 36px;*/
      background: #70422F;
      font-size: 1.8rem;
      font-family: "Zen Maru Gothic", sans-serif;
      font-weight: 700;
      color: #fff;
      display: block;
      padding: 8px 0 9px;
      text-align: center;
      /*display: flex;
      align-items: center;
      justify-content: center;*/
      border-radius: 4px; }
      @media (max-width: 743px) {
        #access #wrapper .main .contents .address__text strong {
          width: 70px;
          padding: 7px 0 8px;
          /*height: 32px;*/
          font-size: 1.6rem; } }
    #access #wrapper .main .contents .address__text span {
      font-size: 2.1rem;
      padding-left: 15px; }
      @media (max-width: 743px) {
        #access #wrapper .main .contents .address__text span {
          font-size: 1.8rem;
          display: block;
          margin-top: 16px;
          padding-left: 0; } }

#link #wrapper .main .contents .pagetitle {
  margin-bottom: 94px; }
  #link #wrapper .main .contents .pagetitle strong::after {
    background: url("../images/link/titleline.webp") no-repeat 0 0;
    background-size: cover; }
    @media (max-width: 743px) {
      #link #wrapper .main .contents .pagetitle strong::after {
        background-size: 100% auto; } }
#link #wrapper .main .contents .linklist {
  width: 800px;
  margin: 0 auto; }
  @media (max-width: 1499px) {
    #link #wrapper .main .contents .linklist {
      width: 100%; } }
  #link #wrapper .main .contents .linklist__item {
    margin-bottom: 80px;
    opacity: 0;
    transition-duration: 0.8s;
    transform: translate(15px, 0);
    -webkit-transition-duration: 0.8s;
    -webkit-transform: translate(15px, 0);
    -moz-transition-duration: 0.8s;
    -moz-transform: translate(15px, 0);
    -ms-transition-duration: 0.8s;
    -ms-transform: translate(15px, 0);
    -o-transition-duration: 0.8s;
    -o-transform: translate(15px, 0); }
    #link #wrapper .main .contents .linklist__item.mv {
      opacity: 1;
      transform: translate(0, 0);
      -webkit-transform: translate(0, 0);
      -moz-transform: translate(0, 0);
      -ms-transform: translate(0, 0);
      -o-transform: translate(0, 0); }
    @media (max-width: 743px) {
      #link #wrapper .main .contents .linklist__item:first-of-type .linklist__term {
        margin-bottom: 60px; } }
    #link #wrapper .main .contents .linklist__item:last-of-type {
      margin-bottom: 0; }
  #link #wrapper .main .contents .linklist__term {
    font-size: 2.7rem;
    font-family: "Zen Maru Gothic", sans-serif;
    font-weight: 700;
    letter-spacing: 0.04em;
    margin-bottom: 30px;
    padding-left: 20px;
    position: relative; }
    @media (max-width: 743px) {
      #link #wrapper .main .contents .linklist__term {
        font-size: 2.1rem;
        line-height: 1.3; } }
    #link #wrapper .main .contents .linklist__term::after {
      width: 8px;
      height: 100%;
      display: block;
      content: "";
      background: #D9C5AD;
      border-radius: 10px;
      position: absolute;
      top: 2px;
      left: 0; }
    #link #wrapper .main .contents .linklist__term-ytlogo {
      display: inline-block;
      padding-left: 15px; }
      @media (max-width: 743px) {
        #link #wrapper .main .contents .linklist__term-ytlogo {
          width: 94px;
          position: absolute;
          left: 0;
          bottom: -51px;
          padding-left: 0; } }
      #link #wrapper .main .contents .linklist__term-ytlogo img {
        vertical-align: baseline; }
  #link #wrapper .main .contents .linklist__desc {
    padding-left: 20px; }
    @media (max-width: 743px) {
      #link #wrapper .main .contents .linklist__desc {
        padding-left: 0; } }
    #link #wrapper .main .contents .linklist__desc-text {
      font-size: 2.1rem;
      line-height: 1.7;
      margin-bottom: 22px; }
      @media (max-width: 743px) {
        #link #wrapper .main .contents .linklist__desc-text {
          font-size: 1.8rem;
          margin-bottom: 30px; } }
#link #wrapper .main .contents .linkbutton a {
  padding: 14px 26px;
  border-radius: 22px; }
  #link #wrapper .main .contents .linkbutton a strong {
    font-size: 1.6rem;
    padding-right: 26px; }
    #link #wrapper .main .contents .linkbutton a strong::before, #link #wrapper .main .contents .linkbutton a strong::after {
      width: 10px; }
    #link #wrapper .main .contents .linkbutton a strong::after {
      top: 5px; }
    #link #wrapper .main .contents .linkbutton a strong::before {
      bottom: 3px; }

#contact #wrapper .main .contents .pagetitle strong::after,
#thanks #wrapper .main .contents .pagetitle strong::after {
  background: url("../images/contact/titleline.webp") no-repeat 0 0;
  background-size: cover; }
  @media (max-width: 743px) {
    #contact #wrapper .main .contents .pagetitle strong::after,
    #thanks #wrapper .main .contents .pagetitle strong::after {
      background-size: 100% auto; } }

#contact #wrapper .main .contents .formbox .recaptchabox {
  padding-top: 50px; }
  #contact #wrapper .main .contents .formbox .recaptchabox .recaptchabox_inner {
    width: 100%;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: center; }
#contact #wrapper .main .contents .formbox .form {
  width: 800px;
  margin: 0 auto; }
  @media (max-width: 1499px) {
    #contact #wrapper .main .contents .formbox .form {
      width: 66.67%; } }
  @media (max-width: 743px) {
    #contact #wrapper .main .contents .formbox .form {
      width: 100%; } }
  #contact #wrapper .main .contents .formbox .form__mi {
    font-size: 2.1rem;
    font-family: "Zen Maru Gothic", sans-serif;
    font-weight: 700;
    margin-bottom: 24px; }
    @media (max-width: 743px) {
      #contact #wrapper .main .contents .formbox .form__mi {
        font-size: 1.8rem;
        margin-bottom: 15px; } }
    #contact #wrapper .main .contents .formbox .form__mi strong {
      width: 43px;
      height: 24px;
      font-size: 1.4rem;
      font-family: "Noto Sans JP", sans-serif;
      font-weight: 600;
      line-height: 24px;
      text-align: center;
      color: #fff;
      background: #BE0000;
      border-radius: 3px;
      display: inline-block;
      margin-right: 8px; }
      @media (max-width: 1499px) {
        #contact #wrapper .main .contents .formbox .form__mi strong {
          width: 40px;
          height: 20px;
          font-size: 1.2rem;
          line-height: 20px; } }
  #contact #wrapper .main .contents .formbox .form__input {
    font-size: 1.6rem;
    margin-bottom: 48px; }
    @media (max-width: 743px) {
      #contact #wrapper .main .contents .formbox .form__input {
        font-size: 1.4rem;
        margin-bottom: 30px; } }
    #contact #wrapper .main .contents .formbox .form__input .form__error {
      color: #BE0000;
      margin-top: 10px; }
      @media (max-width: 743px) {
        #contact #wrapper .main .contents .formbox .form__input .form__error {
          font-size: 1.2rem; } }
    #contact #wrapper .main .contents .formbox .form__input textarea,
    #contact #wrapper .main .contents .formbox .form__input input {
      margin: 0;
      padding: 0;
      border: none;
      background: none;
      font: inherit;
      color: inherit;
      box-sizing: border-box;
      appearance: none;
      -webkit-appearance: none;
      -moz-appearance: none;
      border: solid 1px #DCDCDC;
      background: #fff;
      border-radius: 5px;
      padding: 10px;
      font-size: 1.6rem; }
      @media (max-width: 1499px) {
        #contact #wrapper .main .contents .formbox .form__input textarea,
        #contact #wrapper .main .contents .formbox .form__input input {
          font-size: 1.4rem; } }
    #contact #wrapper .main .contents .formbox .form__input.wtypeta {
      line-height: 1.8; }
      #contact #wrapper .main .contents .formbox .form__input.wtypeta textarea {
        width: 100%;
        line-height: 1.6; }
    #contact #wrapper .main .contents .formbox .form__input.wtype01 input {
      width: 270px; }
      @media (max-width: 743px) {
        #contact #wrapper .main .contents .formbox .form__input.wtype01 input {
          width: 70%; } }
    #contact #wrapper .main .contents .formbox .form__input.wtype02 input {
      width: 400px; }
      @media (max-width: 743px) {
        #contact #wrapper .main .contents .formbox .form__input.wtype02 input {
          width: 100%; } }
    #contact #wrapper .main .contents .formbox .form__input.wtype03 input {
      width: 315px; }
      @media (max-width: 743px) {
        #contact #wrapper .main .contents .formbox .form__input.wtype03 input {
          width: 100%; } }
    #contact #wrapper .main .contents .formbox .form__input-text {
      font-size: 1.2rem;
      padding-top: 8px;
      display: block; }
      @media (max-width: 1499px) {
        #contact #wrapper .main .contents .formbox .form__input-text {
          font-size: 1.0rem; } }
    #contact #wrapper .main .contents .formbox .form__input:last-of-type {
      margin-bottom: 0; }
    #contact #wrapper .main .contents .formbox .form__input.radiolist input[type="radio"] {
      opacity: 0;
      visibility: hidden;
      position: absolute; }
    #contact #wrapper .main .contents .formbox .form__input.radiolist .wpcf7-radio {
      display: flex; }
      @media (max-width: 1499px) {
        #contact #wrapper .main .contents .formbox .form__input.radiolist .wpcf7-radio {
          display: block; } }
    #contact #wrapper .main .contents .formbox .form__input.radiolist .wpcf7-list-item {
      margin-left: 0;
      margin-left: 16px;
      display: block; }
      @media (max-width: 1499px) {
        #contact #wrapper .main .contents .formbox .form__input.radiolist .wpcf7-list-item {
          margin-left: 0;
          margin-top: 10px;
          display: block; } }
    #contact #wrapper .main .contents .formbox .form__input.radiolist .wpcf7-list-item.first {
      margin-left: 0; }
      @media (max-width: 1499px) {
        #contact #wrapper .main .contents .formbox .form__input.radiolist .wpcf7-list-item.first {
          margin-top: 0; } }
    #contact #wrapper .main .contents .formbox .form__input.radiolist span.wpcf7-list-item-label {
      width: auto;
      position: relative;
      display: flex;
      align-items: center;
      cursor: pointer;
      padding: 14px 20px 14px 40px;
      border: solid 1px #DCDCDC;
      border-radius: 5px;
      background: #fff;
      font-size: 1.8rem; }
      @media (max-width: 1499px) {
        #contact #wrapper .main .contents .formbox .form__input.radiolist span.wpcf7-list-item-label {
          padding: 10px;
          padding-left: 37px; } }
      @media (max-width: 743px) {
        #contact #wrapper .main .contents .formbox .form__input.radiolist span.wpcf7-list-item-label {
          font-size: 1.6rem; } }
    #contact #wrapper .main .contents .formbox .form__input.radiolist span.wpcf7-list-item-label::before {
      width: 20px;
      height: 20px;
      display: block;
      content: "";
      border-radius: 50%;
      border: 1px solid #154615;
      /*margin-right: 12px;*/
      position: absolute;
      top: 50%;
      left: 12px;
      margin-top: 1px;
      transform: translateY(-50%); }
      @media (max-width: 1499px) {
        #contact #wrapper .main .contents .formbox .form__input.radiolist span.wpcf7-list-item-label::before {
          width: 18px;
          height: 18px;
          margin-right: 8px; } }
    #contact #wrapper .main .contents .formbox .form__input.radiolist span.wpcf7-list-item-label::after {
      display: block;
      position: absolute;
      content: "";
      border-radius: 50%;
      width: 14px;
      height: 14px;
      background-color: #154615;
      left: 15px;
      top: 50%;
      margin-top: 1px;
      transform: translateY(-50%);
      display: none; }
      @media (max-width: 1499px) {
        #contact #wrapper .main .contents .formbox .form__input.radiolist span.wpcf7-list-item-label::after {
          width: 12px;
          height: 12px;
          left: 15px; } }
    #contact #wrapper .main .contents .formbox .form__input.radiolist input[type="radio"]:checked + span.wpcf7-list-item-label::after {
      display: block; }
#contact #wrapper .main .contents .formbox#cf7-confirm-area .form__input {
  line-height: 1.6; }
#contact #wrapper .main .contents .btsousin {
  margin-top: 80px; }
  @media (max-width: 743px) {
    #contact #wrapper .main .contents .btsousin {
      margin-top: 50px; } }
  #contact #wrapper .main .contents .btsousin__wrap {
    width: 200px;
    height: 44px;
    margin: 0 auto;
    position: relative; }
    #contact #wrapper .main .contents .btsousin__wrap p {
      width: 100%;
      height: 100%;
      position: relative; }
      #contact #wrapper .main .contents .btsousin__wrap p::before, #contact #wrapper .main .contents .btsousin__wrap p::after {
        width: 8px;
        /* 矢印の長さ */
        height: 2px;
        content: "";
        display: inline-block;
        background: #fff;
        border-radius: 2px;
        position: absolute;
        top: 50%;
        right: 26px;
        transition: all 0.3s; }
      #contact #wrapper .main .contents .btsousin__wrap p::after {
        transform: rotate(45deg);
        margin-top: -3px; }
      #contact #wrapper .main .contents .btsousin__wrap p::before {
        transform: rotate(-45deg);
        margin-top: 2px; }
      #contact #wrapper .main .contents .btsousin__wrap p input {
        margin: 0;
        border: none;
        box-sizing: border-box;
        appearance: none;
        -webkit-appearance: none;
        -moz-appearance: none;
        width: 100%;
        height: 100%;
        line-height: 44px;
        display: inline-block;
        font-size: 1.6rem;
        font-weight: bold;
        letter-spacing: 0.08em;
        color: #fff;
        vertical-align: top;
        background: #70422F;
        text-decoration: none;
        padding: 0;
        border-radius: 22px;
        transition: all 0.3s;
        cursor: pointer; }
      #contact #wrapper .main .contents .btsousin__wrap p:hover::before, #contact #wrapper .main .contents .btsousin__wrap p:hover::after {
        right: 21px; }
      #contact #wrapper .main .contents .btsousin__wrap p:hover input {
        background: #154615; }
      #contact #wrapper .main .contents .btsousin__wrap p.bt_back {
        text-align: center;
        margin-top: 20px; }
        #contact #wrapper .main .contents .btsousin__wrap p.bt_back input {
          height: auto;
          line-height: 1.0;
          font-size: 1.4rem;
          color: #999;
          background: none; }
    #contact #wrapper .main .contents .btsousin__wrap .bt_kakunin_d {
      width: 200px;
      height: 44px;
      position: absolute;
      top: 0;
      left: 0;
      z-index: 10; }
      #contact #wrapper .main .contents .btsousin__wrap .bt_kakunin_d .bt_kakunin_d_text {
        width: 100%;
        height: 100%;
        line-height: 44px;
        display: inline-block;
        font-size: 1.6rem;
        letter-spacing: 0.08em;
        color: #fff;
        vertical-align: top;
        background: #ccc;
        text-decoration: none;
        padding: 0;
        border-radius: 22px;
        text-align: center; }
        #contact #wrapper .main .contents .btsousin__wrap .bt_kakunin_d .bt_kakunin_d_text::before, #contact #wrapper .main .contents .btsousin__wrap .bt_kakunin_d .bt_kakunin_d_text::after {
          width: 8px;
          /* 矢印の長さ */
          height: 2px;
          content: "";
          display: inline-block;
          background: #fff;
          border-radius: 2px;
          position: absolute;
          top: 50%;
          right: 26px;
          transition: all 0.3s; }
        #contact #wrapper .main .contents .btsousin__wrap .bt_kakunin_d .bt_kakunin_d_text::after {
          transform: rotate(45deg);
          margin-top: -3px; }
        #contact #wrapper .main .contents .btsousin__wrap .bt_kakunin_d .bt_kakunin_d_text::before {
          transform: rotate(-45deg);
          margin-top: 2px; }
