@charset "UTF-8";
@media screen and (min-width:961px) {
  * {
    margin: 0;
    padding: 0;
  }
  html {
    height: 100%;
    scroll-behavior: smooth;
  }
  body {
    font-family: "Protest Strike", "Zen Kaku Gothic New", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
    font-size: 18px;
    line-height: 2;
    height: auto;
    margin: 0;
    overflow-x: hidden;
    min-height: 100%;
    color: #6D3821;
    background-color: #FED429;
    font-weight: bold;
  }
  img {
    outline: none;
    border-style: none;
    vertical-align: bottom;
    width: 100%;
  }
  .flex_b {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .flex_s {
    display: flex;
    justify-content: start;
    flex-wrap: wrap;
  }
  .pagetop {
    position: fixed;
    bottom: 24px;
    right: 2%;
  }
  .pagetop a {
    margin: 40px 0 40px 0;
    border-bottom: 0px!important;
    text-decoration: none;
    cursor: pointer;
  }
  .pagetop img {
    width: 80px;
  }
  .kv_pc {}
  .kv_pc img {
    border-radius: 24px;
  }
  .kv_sp {
    display: none;
  }
  /* ------------------------------------bbs------------------------------------ */
  .bbs {
    align-items: center;
    color: #fff;
    display: flex;
    height: 40px;
    line-height: 40px;
    overflow: hidden;
    width: 100%;
    white-space: nowrap;
    z-index: 1;
  }
  .bbs ul {
    animation: flowing 47s linear infinite;
    font-size: 20px;
    transform: translateX(100%);
    margin: 0;
    padding: 0;
  }
  .bbs ul li {
    display: inline-block;
    padding-right: 10px;
  }
  @keyframes flowing {
    0% {
      transform: translateX(0);
    }
    100% {
      transform: translateX(-100%);
    }
  }
  /* ------------------------------------kv------------------------------------ */
  .kv {
    width: 90%;
    margin: 24px auto 0 auto;
  }
  .message_text {
    font-size: 120px;
    line-height: 1.3em;
    margin: 40px 0;
  }
  /* ------------------------------------insta------------------------------------ */
  .insta {}
  /* ------------------------------------menu------------------------------------ */
  .menu {
    background-color: #272829;
    color: #ffffff;
  }
  .menu_b {
    width: 48%;
    margin-bottom: 40px;
  }
  .menu h2 {
    font-size: 80px;
  }
  .menu .inner {
    width: 90%;
    margin: 80px auto;
    padding: 80px 0;
  }
  .menu .box {}
  .menu .box p {
    margin-bottom: 24px;
  }
  .menu .box h3 {
    font-size: 48px;
  }
  .menu .box .left {
    width: 48%;
  }
  .menu .box .right {
    width: 48%;
  }
  /* ------------------------------------message------------------------------------ */
  .message {
    background-color: #ffffff;
    width: 80%;
    margin: 0 auto;
    padding: 5%;
    border-radius: 24px;
  }
  .message h2 {
    font-size: 80px;
    line-height: 1.3em;
  }
  .message img {
    border-radius: 24px;
  }
  .sub {
    margin-bottom: 80px;
  }
  .message .text {
    text-align: center;
    line-height: 2em;
    font-size: 24px;
    margin-top: 40px;
  }
  .message .text p {
    margin-bottom: 40px;
  }
  /* ------------------------------------about------------------------------------ */
  .about {
    background-color: #ffffff;
    width: 80%;
    margin: 0 auto;
    padding: 5%;
    border-radius: 24px;
    margin-top: 80px;
  }
  .about h2 {
    font-size: 80px;
    line-height: 1.3em;
  }
  .about .box .left {
    width: 48%;
  }
  .about .box .left img {
    border-radius: 24px;
  }
  .about .box .right {
    width: 48%;
  }
  .about .box .right ul {}
  .about .box .right ul li {
    border-bottom: 1px solid #fed428;
    padding: 16px;
  }
  /* ------------------------------------access------------------------------------ */
  .access {
    background-color: #ffffff;
    width: 80%;
    margin: 0 auto;
    padding: 5%;
    border-radius: 24px;
    margin-top: 80px;
  }
  .access h2 {
    font-size: 80px;
    line-height: 1.3em;
  }
  /* ------------------------------------button------------------------------------ */
  .buttonbox {
    width: 90%;
    margin: 80px auto;
  }
  .buttonbox ul {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
  }
  .buttonbox ul li {
    width: 45%;
    display: inline-block;
    margin: 0 1%;
  }
  *, *:before, *:after {
    -webkit-box-sizing: inherit;
    box-sizing: inherit;
  }
  .btn, a.btn, button.btn {
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1.5;
    position: relative;
    display: inline-block;
    padding: 1rem 4rem;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    text-align: center;
    vertical-align: middle;
    text-decoration: none;
    letter-spacing: 0.1em;
    color: #212529;
    border-radius: 0.5rem;
  }
  a.btn-3d-flip {
    display: block;
    margin: 0 auto;
    padding: 0;
    -webkit-perspective: 600px;
    perspective: 600px;
  }
  a.btn-3d-flip:hover .btn-3d-flip-box {
    -webkit-transform: translateY(-50%) rotateX(90deg);
    transform: translateY(-50%) rotateX(90deg);
  }
  a.btn-3d-flip.btn-3d-flip2:hover .btn-3d-flip-box2 {
    -webkit-transform: translateX(-50%) rotateY(-90deg);
    transform: translateX(-50%) rotateY(-90deg);
  }
  .btn-3d-flip-box {
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
    margin: auto;
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
    -webkit-transform: rotateX(0);
    transform: rotateX(0);
    text-decoration: none;
    text-transform: uppercase;
    color: #fff;
    -webkit-transform-style: preserve-3d;
    transform-style: preserve-3d;
  }
  .btn-3d-flip-box2 {
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
    margin: auto;
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
    -webkit-transform: rotateY(0);
    transform: rotateY(0);
    text-decoration: none;
    text-transform: uppercase;
    color: #fff;
    -webkit-transform-style: preserve-3d;
    transform-style: preserve-3d;
  }
  .btn-3d-flip-box-face {
    display: block;
    position: relative;
    width: 100%;
    padding: 1.5rem 0;
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
    color: #6D3821;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
  }
  .btn-3d-flip-box-face--front {
    background: #ffffff;
  }
  .btn-3d-flip-box-face--back {
    position: absolute;
    top: 100%;
    left: 0;
    -webkit-transform: translateY(-1px) rotateX(-90deg);
    transform: translateY(-1px) rotateX(-90deg);
    -webkit-transform-origin: 50% 0;
    transform-origin: 50% 0;
    background: #eeeeee;
  }
  .btn-3d-flip-box-face--front2 {
    color: #000;
    border: 2px solid #000;
    background: #fff;
  }
  .btn-3d-flip-box-face--back2 {
    position: absolute;
    top: 0;
    left: 100%;
    -webkit-transform: translateX(-1px) rotateY(90deg);
    transform: translateX(-1px) rotateY(90deg);
    -webkit-transform-origin: 0 0;
    transform-origin: 0 0;
    color: #fff;
    border: 2px solid #000;
    background: #000;
  }
  .fa-position-right {
    position: absolute;
    top: calc(50% - 0.5em);
    right: 1rem;
  }
  /* ------------------------------------footer------------------------------------ */
  .footer {
    margin-bottom: 40px;
  }
  .footer img {
    width: 100px;
    margin-bottom: 16px;
  }
}

@media screen and (max-width:960px) {
  * {
    margin: 0;
    padding: 0;
  }
  html {
    height: 100%;
    scroll-behavior: smooth;
  }
  body {
    font-family: "Protest Strike", "Zen Kaku Gothic New", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
    font-size: 16px;
    line-height: 2;
    height: auto;
    margin: 0;
    overflow-x: hidden;
    min-height: 100%;
    color: #6D3821;
    background-color: #FED429;
    font-weight: bold;
  }
  img {
    max-width: 100%;
    height: auto;
  }
  .flex_b {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .flex_s {
    display: flex;
    justify-content: start;
    flex-wrap: wrap;
  }
  .pagetop {
    position: fixed;
    bottom: 24px;
    right: 2%;
  }
  .pagetop a {
    margin: 40px 0 40px 0;
    border-bottom: 0px!important;
    text-decoration: none;
    cursor: pointer;
  }
  .pagetop img {
    width: 80px;
  }
  .kv_pc {
    display: none;
  }
  .kv_sp {
    border-radius: 24px;
  }
  /* ------------------------------------bbs------------------------------------ */
  .bbs {
    align-items: center;
    color: #fff;
    display: flex;
    height: 40px;
    line-height: 40px;
    overflow: hidden;
    width: 100%;
    white-space: nowrap;
    z-index: 1;
  }
  .bbs ul {
    animation: flowing 47s linear infinite;
    font-size: 20px;
    transform: translateX(100%);
    margin: 0;
    padding: 0;
  }
  .bbs ul li {
    display: inline-block;
    padding-right: 10px;
  }
  @keyframes flowing {
    0% {
      transform: translateX(0);
    }
    100% {
      transform: translateX(-100%);
    }
  }
  /* ------------------------------------kv------------------------------------ */
  .kv {
    width: 90%;
    margin: 24px auto 0 auto;
  }
  .message_text {
    font-size: 40px;
    line-height: 1.3em;
    margin: 16px 0;
  }
  /* ------------------------------------insta------------------------------------ */
  .insta {}
  /* ------------------------------------menu------------------------------------ */
  .menu {
    background-color: #272829;
    color: #ffffff;
  }
  .menu_b {
    width: 100%;
    margin-bottom: 24px;
  }
  .menu h2 {
    font-size: 40px;
  }
  .menu .inner {
    width: 90%;
    margin: 40px auto;
    padding: 40px 0;
  }
  .menu .box {}
  .menu .box p {
    margin-bottom: 24px;
  }
  .menu .box h3 {
    font-size: 24px;
  }
  .menu .box .left {}
  .menu .box .right {}
  /* ------------------------------------message------------------------------------ */
  .message {
    background-color: #ffffff;
    width: 80%;
    margin: 0 auto;
    padding: 15% 5%;
    border-radius: 24px;
  }
  .message h2 {
    font-size: 40px;
    line-height: 1.3em;
  }
  .message img {
    border-radius: 24px;
  }
  .sub {
    margin-bottom: 32px;
  }
  .message .text {
    text-align: center;
    line-height: 2em;
    font-size: 16px;
    margin-top: 40px;
  }
  .message .text p {
    margin-bottom: 40px;
  }
  /* ------------------------------------about------------------------------------ */
  .about {
    background-color: #ffffff;
    width: 80%;
    margin: 0 auto;
    padding: 15% 5%;
    border-radius: 24px;
    margin-top: 40px;
  }
  .about h2 {
    font-size: 40px;
    line-height: 1.3em;
  }
  .about .box .left {}
  .about .box .right {}
  .about .box .left img {
    border-radius: 24px;
  }
  .about .box .right ul {}
  .about .box .right ul li {
    border-bottom: 1px solid #fed428;
    padding: 16px;
  }
  /* ------------------------------------access------------------------------------ */
  .access {
    background-color: #ffffff;
    width: 80%;
    margin: 0 auto;
    padding: 15% 5%;
    border-radius: 24px;
    margin-top: 40px;
  }
  .access h2 {
    font-size: 40px;
    line-height: 1.3em;
  }
  /* ------------------------------------button------------------------------------ */
  .buttonbox {
    width: 90%;
    margin: 40px auto 20px auto;
  }
  .buttonbox ul {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
  }
  .buttonbox ul li {
    width: 100%;
    display: inline-block;
    margin-bottom: 24px;
  }
  *, *:before, *:after {
    -webkit-box-sizing: inherit;
    box-sizing: inherit;
  }
  .btn, a.btn, button.btn {
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1.5;
    position: relative;
    display: inline-block;
    padding: 1rem 4rem;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    text-align: center;
    vertical-align: middle;
    text-decoration: none;
    letter-spacing: 0.1em;
    color: #212529;
    border-radius: 0.5rem;
  }
  a.btn-3d-flip {
    display: block;
    margin: 0 auto;
    padding: 0;
    -webkit-perspective: 600px;
    perspective: 600px;
  }
  a.btn-3d-flip:hover .btn-3d-flip-box {
    -webkit-transform: translateY(-50%) rotateX(90deg);
    transform: translateY(-50%) rotateX(90deg);
  }
  a.btn-3d-flip.btn-3d-flip2:hover .btn-3d-flip-box2 {
    -webkit-transform: translateX(-50%) rotateY(-90deg);
    transform: translateX(-50%) rotateY(-90deg);
  }
  .btn-3d-flip-box {
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
    margin: auto;
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
    -webkit-transform: rotateX(0);
    transform: rotateX(0);
    text-decoration: none;
    text-transform: uppercase;
    color: #fff;
    -webkit-transform-style: preserve-3d;
    transform-style: preserve-3d;
  }
  .btn-3d-flip-box2 {
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
    margin: auto;
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
    -webkit-transform: rotateY(0);
    transform: rotateY(0);
    text-decoration: none;
    text-transform: uppercase;
    color: #fff;
    -webkit-transform-style: preserve-3d;
    transform-style: preserve-3d;
  }
  .btn-3d-flip-box-face {
    display: block;
    position: relative;
    width: 100%;
    padding: 1.5rem 0;
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
    color: #6D3821;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
  }
  .btn-3d-flip-box-face--front {
    background: #ffffff;
  }
  .btn-3d-flip-box-face--back {
    position: absolute;
    top: 100%;
    left: 0;
    -webkit-transform: translateY(-1px) rotateX(-90deg);
    transform: translateY(-1px) rotateX(-90deg);
    -webkit-transform-origin: 50% 0;
    transform-origin: 50% 0;
    background: #eeeeee;
  }
  .btn-3d-flip-box-face--front2 {
    color: #000;
    border: 2px solid #000;
    background: #fff;
  }
  .btn-3d-flip-box-face--back2 {
    position: absolute;
    top: 0;
    left: 100%;
    -webkit-transform: translateX(-1px) rotateY(90deg);
    transform: translateX(-1px) rotateY(90deg);
    -webkit-transform-origin: 0 0;
    transform-origin: 0 0;
    color: #fff;
    border: 2px solid #000;
    background: #000;
  }
  .fa-position-right {
    position: absolute;
    top: calc(50% - 0.5em);
    right: 1rem;
  }
  /* ------------------------------------footer------------------------------------ */
  .footer {
    margin-bottom: 40px;
  }
  .footer img {
    width: 100px;
    margin-bottom: 16px;
  }
}