@media screen and (max-width: 500px) {
  .indent_content {
    padding: 60px 0;
  }
  .sp-none02 {
    display: none;
  }
  .none02 {
    display: inline;
  }
  #wrap {
    width: 100%;
    padding: 0;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  .sp_hamburger {
    position: fixed;
    width: 30px;
    height: 30px;
    top: 20px;
    right: 16px;
    z-index: 120;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-transition-delay: 0.1s;
            transition-delay: 0.1s;
  }
  .sp_hamburger .hamburger {
    width: 30px;
    height: 20px;
    z-index: 100;
    background: none;
    outline: none;
    border: none;
    margin: auto;
    position: relative;
  }
  .sp_hamburger .hamburger_bar {
    display: block;
    width: 100%;
    height: 1.2px;
    position: absolute;
    left: 0;
    background: #fff;
    -webkit-transition: top 0.24s, opacity 0.24s, -webkit-transform 0.24s;
    transition: top 0.24s, opacity 0.24s, -webkit-transform 0.24s;
    transition: top 0.24s, transform 0.24s, opacity 0.24s;
    transition: top 0.24s, transform 0.24s, opacity 0.24s, -webkit-transform 0.24s;
  }
  .sp_hamburger .hamburger_bar:nth-child(1) {
    top: 0;
  }
  .sp_hamburger .hamburger_bar:nth-child(2) {
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .sp_hamburger .hamburger_bar:nth-child(3) {
    top: 100%;
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  .sp_hamburger .hamburger_bar.is_active:nth-child(1) {
    top: 50%;
    -webkit-transform: translateY(-50%) rotate(135deg);
            transform: translateY(-50%) rotate(135deg);
    background: #fff;
  }
  .sp_hamburger .hamburger_bar.is_active:nth-child(2) {
    -webkit-transform: translate(50%, -50%);
            transform: translate(50%, -50%);
    opacity: 0;
  }
  .sp_hamburger .hamburger_bar.is_active:nth-child(3) {
    top: 50%;
    -webkit-transform: translateY(-50%) rotate(-135deg);
            transform: translateY(-50%) rotate(-135deg);
    background: #fff;
  }
  .navBox {
    width: 100%;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    padding: 0 16px;
  }
  .sp_nav {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    z-index: 110;
    opacity: 0;
    -webkit-transition: opacity 0.24s;
    transition: opacity 0.24s;
    pointer-events: none;
    width: 100%;
    height: 100%;
    background: #c98332;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 0 16px;
    color: #fff;
  }
  .sp_nav .titleBox .logo {
    width: 10%;
    margin-right: 10px;
  }
  .sp_nav .titleBox .txt01 {
    font-size: 7vw;
    font-weight: 500;
    line-height: 1;
    width: 25%;
  }
  .sp_nav .titleBox .txt02 {
    font-size: 3vw;
    margin-top: 10px;
    line-height: 1;
  }
  .sp_nav .nav-list {
    display: block;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    width: 100%;
    position: relative;
    z-index: 130;
    margin-top: 10%;
  }
  .sp_nav .nav-list li {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    font-size: 4vw;
    font-weight: 600;
    line-height: 1;
    box-sizing: border-box;
    border-bottom: 1px solid #fff;
    padding-bottom: 15px;
  }
  .sp_nav .nav-list li:nth-of-type(n + 2) {
    margin-top: 15px;
  }
  .sp_nav .tel {
    font-size: 5vw;
    margin: 5% auto 0;
    text-align: center;
    font-weight: 500;
    line-height: 1;
    -webkit-transition-duration: 0.4s;
            transition-duration: 0.4s;
  }
  .sp_nav .tel span {
    font-size: 8vw;
    padding-left: 5px;
  }
  .sp_nav .tel:hover {
    opacity: 0.7;
  }
  .sp_nav .btn {
    background: #fff;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    border-radius: 10px;
    -webkit-box-shadow: 0 2px 2px #bab4b4;
            box-shadow: 0 2px 2px #bab4b4;
    line-height: 1;
    color: #1b1b1b;
    -webkit-transition-duration: 0.4s;
            transition-duration: 0.4s;
    width: 70%;
    font-size: 3.5vw;
    margin: 25px auto 0;
    height: auto;
    padding: 20px 16px;
  }
  .sp_nav.is_active {
    opacity: 1;
    pointer-events: auto;
  }
  header {
    height: 70px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    padding: 0 16px;
  }
  header.active {
    padding-top: 0;
  }
  header .leftBox {
    width: 100%;
  }
  header .leftBox .logo {
    margin-right: 3%;
    width: 8%;
  }
  header .leftBox .title {
    font-size: 5.5vw;
    width: auto;
    height: 30px;
  }
  header .leftBox .title img {
    height: 100%;
  }
  header .leftBox .inner {
    display: block;
  }
  header .leftBox .minTxt {
    margin-left: 0;
    font-size: 3vw;
    margin-left: 7px;
    display: none;
  }
  header .rightBox {
    display: none;
  }
  .front_main_box .txtBox .txt01 {
    font-size: 12vw;
    letter-spacing: 2.5vw;
  }
  .front_main_box .txtBox .txt02 {
    font-size: 3.8vw;
    margin-top: 20px;
  }
  .front_main_box .txtBox .txt02.txt02_02 {
    margin-top: 5px;
  }
  #container .logo {
    width: 20%;
  }
  #container .logoTxt {
    width: 40%;
    margin-left: 16px;
  }
  .hoverBtn .arrow {
    right: 16px;
  }
  .hoverBtn .arrow.initialArrow {
    opacity: 0;
  }
  .hoverBtn .arrow.hoverArrow {
    opacity: 1;
  }
  .hoverBtnBrown {
    background: #c98332;
    color: #fff;
  }
  #index .box01 h2 {
    width: 100%;
    font-size: 6vw;
    text-align: center;
    letter-spacing: 0.5vw;
  }
  #index .box01 .text {
    font-size: 3.5vw;
    width: 100%;
    padding: 0 16px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  #index .box02 .minTitle {
    font-size: 3.5vw;
    letter-spacing: 0.2vw;
  }
  #index .box02 h2 {
    font-size: 6vw;
    letter-spacing: 0.5vw;
    margin-top: 10px;
  }
  #index .box02 .inner {
    margin-top: 40px;
  }
  #index .box02 .inner .imgBox {
    position: relative;
    right: inherit;
    top: inherit;
    padding: 0 16px;
  }
  #index .box02 .inner .imgBox .bg {
    display: none;
  }
  #index .box02 .inner h3 {
    font-size: 4.5vw;
    margin-top: 30px;
    padding: 0 16px;
    line-height: 1.7;
    text-align: center;
  }
  #index .box02 .inner .text {
    font-size: 3.5vw;
    line-height: 2;
    width: 100%;
    margin-top: 15px;
    padding: 0 16px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  #index .box02 .inner .btn {
    width: 70%;
    font-size: 3.5vw;
    margin: 25px auto 0;
    height: auto;
    padding: 30px 16px;
  }
  #index .box03 .con {
    height: 30vh;
  }
  #index .box03 .con .txtBox .txt01 {
    font-size: 4vw;
    letter-spacing: 0.3vw;
  }
  #index .box03 .con .txtBox h2 {
    font-size: 6vw;
    margin: 20px auto 30px;
  }
  #index .box03 .con .txtBox .txt02 {
    font-size: 3.5vw;
  }
  #index .box03 .con .txtBox .txt02:nth-of-type(n + 2) {
    margin-top: 15px;
  }
  #index .box03 .con .txtBox .txt01,
  #index .box03 .con .txtBox .txt02,
  #index .box03 .con .txtBox h2 {
    padding: 0;
  }
  #index .box03 .con .txtBox .txt01::before,
  #index .box03 .con .txtBox .txt02::before,
  #index .box03 .con .txtBox h2::before {
    display: none;
  }
  #index .box03 .con .shadow {
    display: none;
  }
  #index .box03 .con .arrowBox {
    display: none;
  }
  #index .box03 .con:hover .txtBox .txt01 span,
  #index .box03 .con:hover .txtBox .txt02 span,
  #index .box03 .con:hover .txtBox h2 span {
    color: #fff;
  }
  #index .box03 .inner {
    display: block;
  }
  #index .box04 .minTitle {
    font-size: 4vw;
    padding: 0 16px;
    letter-spacing: 0.3vw;
    text-align: center;
  }
  #index .box04 h2 {
    font-size: 6vw;
    letter-spacing: 0.5vw;
    text-align: center;
  }
  #index .box04 .inner {
    padding: 0 16px;
    margin-top: 40px;
    gap: 30px 16px;
  }
  #index .box04 .inner .item {
    width: calc((100% - 16px) / 2);
    padding-bottom: 20px;
  }
  #index .box04 .inner .item .circle {
    display: none;
  }
  #index .box04 .inner .item .tag {
    font-size: 3vw;
  }
  #index .box04 .inner .item h3 {
    font-size: 3.5vw;
    line-height: 1.7;
  }
  #index .box04 .inner .item:hover .imgBox .img {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1;
  }
  #index .box04 .btn {
    width: 70%;
    font-size: 3.5vw;
    margin: 25px auto 0;
    height: auto;
    padding: 30px 16px;
    position: relative;
    top: inherit;
    right: inherit;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  #index .box04 .btn .arrow {
    margin-left: 16px;
  }
  #index .box05 {
    padding-bottom: 60px;
  }
  #index .box05 .img01 {
    min-width: inherit;
    margin: 0;
    left: 0;
  }
  #index .box05 .txtBox {
    width: 100%;
    padding: 40px 16px;
    position: relative;
    right: inherit;
    top: inherit;
    border-radius: inherit;
    background: -webkit-gradient(linear, left top, right top, from(#c98332), to(#d2b694));
    background: linear-gradient(to right, #c98332, #d2b694);
  }
  #index .box05 .txtBox h2 {
    font-size: 3.5vw;
    letter-spacing: 0.2vw;
    text-align: center;
  }
  #index .box05 .txtBox .txt01 {
    font-size: 8vw;
    letter-spacing: 0.3vw;
    margin-top: 5px;
    text-align: center;
  }
  #index .box05 .txtBox .txt02 {
    font-size: 4vw;
    text-align: center;
  }
  #index .box05 .txtBox .txt03 {
    font-size: 4vw;
    margin-top: 30px;
    text-align: center;
    line-height: 2;
  }
  #index .box05 .txtBox .text {
    font-size: 3.5vw;
    letter-spacing: 0.1vw;
    width: 100%;
    margin-top: 25px;
  }
  #index .box05 .inner {
    margin-top: 50px;
    display: block;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    padding: 0 16px;
  }
  #index .box05 .inner .item {
    width: 100%;
    border-radius: 0;
  }
  #index .box05 .inner .item .img {
    width: 25%;
  }
  #index .box05 .inner .item .itemTxt01 {
    font-size: 3.5vw;
    letter-spacing: 0.3vw;
  }
  #index .box05 .inner .item .itemTxt02 {
    font-size: 5vw;
    letter-spacing: 0.5vw;
    margin-top: 10px;
  }
  #index .box05 .inner .item:nth-of-type(2) {
    margin-top: 20px;
  }
  #index .box05 .inner .item .arrow {
    right: 20px;
  }
  #index .box06 .minTitle {
    font-size: 4vw;
    padding: 0 16px;
    letter-spacing: 0.3vw;
    text-align: center;
  }
  #index .box06 h2 {
    font-size: 6vw;
    letter-spacing: 0.5vw;
    text-align: center;
  }
  #index .box06 .inner {
    padding: 0 16px;
    margin-top: 40px;
  }
  #index .box06 .btn {
    width: 70%;
    font-size: 3.5vw;
    margin: 25px auto 0;
    height: auto;
    padding: 30px 16px;
    position: relative;
    top: inherit;
    right: inherit;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  #index .box06 .btn .arrow {
    margin-left: 16px;
  }
  #index .box06 .item .over .time {
    font-size: 3vw;
    padding-right: 15px;
    margin-right: 15px;
  }
  #index .box06 .item .over .time .tag {
    font-size: 3vw;
  }
  #index .box06 .item h3 {
    font-size: 3.5vw;
  }
  #index .box07 {
    padding-bottom: 0;
  }
  #index .box07 .titleBox .minTitle {
    font-size: 4vw;
    padding: 0 16px;
    letter-spacing: 0.3vw;
    text-align: center;
  }
  #index .box07 .titleBox h2 {
    font-size: 6vw;
    letter-spacing: 0.5vw;
    text-align: center;
    margin-top: 10px;
  }
  #index .box07 .titleBox::before {
    margin-right: 16px;
  }
  #index .box07 .titleBox::after {
    margin-left: 16px;
  }
  #index .box07 .inner {
    display: block;
    margin-top: 30px;
  }
  #index .box07 .inner table {
    width: 100%;
  }
  #index .box07 .inner table tr th,
  #index .box07 .inner table tr td {
    font-size: 3.5vw;
  }
  #index .box07 .inner table tr th {
    font-size: 3.5vw;
    padding-right: 16px;
    word-break: keep-all;
  }
  #index .box07 .inner iframe {
    width: 100%;
    height: 45vh;
  }
  #index .box08 .minTitle {
    font-size: 4vw;
    padding: 0 16px;
    letter-spacing: 0.3vw;
    text-align: center;
  }
  #index .box08 h2 {
    font-size: 6vw;
    letter-spacing: 0.5vw;
    text-align: center;
  }
  #index .box08 .inner {
    gap: 10px;
    margin-top: 30px;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  #index .box08 .inner .item {
    width: 40%;
  }
  #contactBanner .txt01 {
    font-size: 3.5vw;
    letter-spacing: 0.2vw;
  }
  #contactBanner .txt02 {
    font-size: 7vw;
    letter-spacing: 0.5vw;
  }
  #contactBanner .inner {
    display: block;
    margin-top: 20px;
  }
  #contactBanner .inner .tel {
    font-size: 5vw;
    margin: 0 auto;
    text-align: center;
  }
  #contactBanner .inner .tel span {
    font-size: 8vw;
  }
  #contactBanner .inner .btn {
    width: 70%;
    font-size: 3.5vw;
    margin: 25px auto 0;
    height: auto;
    padding: 25px 16px;
  }
  footer .inner {
    padding: 30px 0;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  footer .inner .leftBox {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  footer .inner .leftBox .logo {
    width: 8%;
    margin-right: 10px;
  }
  footer .inner .leftBox .txt01 {
    font-size: 7vw;
    width: 17%;
  }
  footer .inner .leftBox .txt02 {
    font-size: 3vw;
    margin-left: 7px;
  }
  footer .inner .rightBox {
    display: none;
  }
  footer .copy {
    font-size: 3vw;
  }
  #pankuzu {
    padding: 40px 16px 0;
    line-height: 1.5;
    font-size: 3vw;
    letter-spacing: 0.1vw;
    margin: 0;
  }
  .thumb {
    height: 200px;
  }
  .thumb h1,
  .thumb .title {
    font-size: 5vw;
    margin-top: 60px;
  }
  .single_page {
    padding: 40px 16px;
  }
  #contact .tel_txt01 {
    font-size: 3.5vw;
  }
  #contact .tel {
    display: block;
    border-bottom: 2px solid #f00500;
    padding-bottom: 30px;
  }
  #contact .tel img {
    display: none;
  }
  #contact .tel .big {
    font-size: 8vw;
    text-align: center;
    margin: 0;
  }
  #contact .tel .min {
    font-size: 3.5vw;
    margin-top: 16px;
    text-align: center;
  }
  #contact .tel .min span {
    font-size: 3.5vw;
  }
  #contact .caution {
    font-size: 3.5vw;
    line-height: 2;
    margin: 0 auto 30px;
  }
  #contact .box01 h2 {
    margin-bottom: 30px;
  }
  #contact .box01 h2 span {
    font-size: 4vw;
    border-left: 3px solid #fff;
    padding: 5px 0 5px 10px;
  }
  #contact .box01 ul {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    padding: 0 16px;
  }
  #contact .box01 ul li {
    font-size: 3.5vw;
    line-height: 1.8;
  }
  #contact .box01 ul li:nth-of-type(n + 2) {
    margin-top: 16px;
  }
  #contact table tr th,
  #contact table tr td {
    display: block;
    width: 100%;
    padding: 20px 0;
  }
  #contact table tr th {
    border: none;
    padding-bottom: 0;
  }
  #contact .btn_box {
    width: calc(100% - 32px);
    height: auto;
    margin: 40px auto 0;
    padding: 20px 0;
    border-radius: 10vw;
  }
  #contact .btn_box p .arrow {
    right: 16px;
    font-size: 3vw;
  }
  #contact .btn_box input {
    font-size: 4vw;
  }
  #contact .thanks {
    font-size: 3.5vw;
    padding: 0 16px;
  }
  #news .list {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    padding: 0 16px;
  }
  #news .list .item {
    padding: 20px 0;
    width: 100%;
  }
  #news .list .item::before {
    bottom: -2px;
    width: 30%;
    height: 3px;
  }
  #news .list .item .over {
    font-size: 3.5vw;
  }
  #news .list .item .over .time {
    font-size: 3.5vw;
  }
  #news .list .item .over .tag {
    margin-left: 10px;
    width: 17%;
    height: auto;
    padding: 3px 0;
  }
  #news .list .item .over h3 {
    font-size: 3.5vw;
    margin-left: 10px;
  }
  #news .list .item .text {
    font-size: 3.5vw;
    margin-top: 10px;
    line-height: 1.6;
  }
  #single_news .box {
    padding: 30px 16px;
  }
  #single_news .box .over {
    font-size: 3.5vw;
    margin-bottom: 16px;
  }
  #single_news .box h1 {
    font-size: 4vw;
  }
  #single_news .box .text {
    font-size: 3.5vw;
    line-height: 2;
  }
  .navigation {
    padding: 0 16px;
    font-size: 3.2vw;
  }
  .navigation .nav_btn {
    width: 48%;
  }
  .navigation .nav_btn .btn {
    width: 48%;
    height: auto;
    padding: 10px 16px;
  }
  .navigation .nav_btn .btn:nth-of-type(2) {
    margin-left: 4%;
  }
  .navigation .nav_btn .btn .arrow {
    width: 10%;
  }
  .navigation .nav_archive_btn {
    width: 48%;
    height: auto;
    font-size: 3.5vw;
    padding: 0 16px;
  }
  .pagination_over {
    margin-bottom: 30px;
  }
  .pagination_under {
    margin-top: 30px;
  }
  #works .inner {
    margin-top: 0;
    gap: 30px 16px;
  }
  #works .inner .item {
    width: calc((100% - 16px) / 2);
    padding-bottom: 20px;
  }
  #works .inner .item .circle {
    display: none;
  }
  #works .inner .item .tag {
    font-size: 3vw;
  }
  #works .inner .item h2 {
    font-size: 3.5vw;
    line-height: 1.7;
  }
  #works .inner .item:hover .imgBox .img {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1;
  }
  #works .btn {
    width: 70%;
    font-size: 3.5vw;
    margin: 25px auto 0;
    height: auto;
    padding: 30px 16px;
    position: relative;
    top: inherit;
    right: inherit;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  #works .btn .arrow {
    margin-left: 16px;
  }
  #single_works .thumb_img {
    margin-top: 30px;
  }
  #single_works .txt_inner {
    font-size: 3.2vw;
    padding: 0 16px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  #single_works .txt_inner p {
    font-size: 3.2vw;
  }
  #single_works .txt_inner .tag {
    font-size: 3.2vw;
    padding: 5px 7px;
    margin-left: 10px;
  }
  #single_works h1 {
    font-size: 4vw;
    line-height: 1.8;
    padding: 0 16px;
  }
  #single_works .text {
    font-size: 3.5vw;
    line-height: 2;
    padding: 0 16px;
  }
  #single_works .movie_box {
    margin-top: 30px;
  }
  #single_works .movie_box video {
    width: 100%;
  }
  #single_works .movie_box .play-btn {
    display: none;
  }
  #single_works .gallery_list {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    padding: 0;
    margin-top: 30px;
  }
  #single_works .gallery_list .img {
    width: 48%;
    margin-right: 4%;
    margin-top: 0;
  }
  #single_works .gallery_list .img:nth-of-type(3n) {
    margin-right: 4%;
  }
  #single_works .gallery_list .img:nth-of-type(2n) {
    margin-right: 0;
  }
  #single_works .gallery_list .img:nth-of-type(n + 3) {
    margin-top: 4%;
  }
  #recruit .box {
    display: block;
  }
  #recruit .box:nth-of-type(n + 2) {
    margin-top: 60px;
  }
  #recruit .box .leftBox h2 {
    font-size: 4.5vw;
    margin: 0 auto;
    width: auto;
    padding: 15px 20px;
  }
  #recruit .box .leftBox .bdr {
    display: none;
  }
  #recruit .box table {
    margin: 40px auto 0;
  }
  #recruit .box table tr th,
  #recruit .box table tr td {
    font-size: 3.5vw;
    padding: 20px 16px;
    display: block;
  }
  #recruit .box table tr th {
    width: auto;
    word-break: keep-all;
    border-bottom: none;
    font-size: 4vw;
    padding-bottom: 0;
  }
  #recruit .box table tr td {
    padding-top: 10px;
  }
  #recruit .box table tr:nth-of-type(1) td {
    padding-top: 10px;
  }
}