@charset "utf-8";
/* CSS Document */

@media (max-width: 767px) {

/* common */

.heading-dot{
  font-size: 10px;
  margin-right: 7px;
}

.heading-main{
  font-size: 24px;
}

.heading-sub{
  font-size: 10px;
}


h2{
  font-size: 21px;
  .sub-title{
    margin-top: 2px;
  }
}

h3{
  font-size: 17px;
  .sub-title{
    margin-top: 1px;
  }
}

/* button */

.pagetop {
  display: none !important;
}

/* header */

/* header logo */

header .logo{
  width:225px;
  height: auto;
  padding-left: 20px;
}

/* breadcrumbs */

.breadcrumbs{
  padding-right: 20px;
}

/* PCロゴを隠してSPロゴを表示する */

header .menu-wrapper{
  position: relative;

  .menu-icon {
  width: 30px;
  height: 30px;
  position: fixed; 
  top: 22px;
  right: 20px;
  cursor: pointer;
  z-index: 3;
  display: inline-block;
  }

  .menu-icon span {
    display: block;
    height: 2px;
    margin: 6px 0;
    background: #6f6e46;
    border-radius: 4px;
    transition: 0.4s;
  }

  /* ハンバーガーがXに変形 */
  #menu-toggle:checked + .menu-icon span:nth-child(1) {
    transform: translateY(8px) rotate(45deg);
  }
  #menu-toggle:checked + .menu-icon span:nth-child(2) {
    opacity: 0;
  }
  #menu-toggle:checked + .menu-icon span:nth-child(3) {
    transform: translateY(-8px) rotate(-45deg);
  }

  /* オーバーレイ背景 */
  .overlay {
    position: fixed;
    inset: 0;
    background: rgb(111, 110, 70, 0.6);
    opacity: 0;
    pointer-events: none;
    transition: 0.4s;
    z-index: 1;
  }

  #menu-toggle:checked ~ .overlay {
    opacity: 1;
    pointer-events: auto;
  }

  .menu {
    position: fixed;
    top: 0;
    left: -250px; 
    width: 250px;
    height: 100%;
    background: #fffdf9;
    transition: left 0.4s ease;
    z-index: 2;
  }

  #menu-toggle:checked ~ .menu {
    left: 0; 
  }

  .menu ul {
    list-style: none;
    padding: 40px 50px;
    display: flex;
    flex-direction: column;
    text-align: center;
  }

  .menu li {
    margin: 5px 0;
  }

  .menu a {
    text-decoration: none;
    color: #403c34;
    font-size: 1.2rem;
    transition: color 0.3s;
  }
  .menu .btn-nav{
    color: #fff;
  }
}

/* footer */

footer{
  padding-top: 5px;
  background-position: right;
}

.footer-box{
  flex-direction: column;
  align-items: center;
  margin-bottom: 40px;
  gap: 40px;
}

.footer-info{
  margin-bottom: 40px;
}

.sns-icons{
  gap: 40px;
  margin: 0 auto;
}

footer nav{
  a{
  color: #6f6e46;
  font-size: 17px;
  }
  ul{
  text-align: center;
  }
}

/* introduction */
.introduction{
  width: 100%;
  padding: 120px 20px 0;
  margin-bottom: 50px;
}

/* top */

.hero{
  margin-bottom: 80px;
}

.video-header h1{
  font-size: 30px;
  padding: 0 20px;
}

.top-about{
  margin-bottom: 80px;
  flex-direction: column-reverse;
  gap: 30px;
  .txt{
    padding: 0 20px;
  }
}

.top-prequality{
  margin-bottom: 80px;
  padding: 60px 0 60px;
}

.top-quality{
  padding: 0 20px;
}

.top-works{
  margin-bottom: 80px;
}

.top-works-box{
  padding: 0 20px;
}

.works-slider li {
  height: 350px;
  overflow: hidden;
}

.faq-access-box {
  flex-direction: column;
  margin-bottom: 80px;
}

.top-faq, .top-access{
  padding: 50px 0;
}

.top-contact{
  padding: 0 20px;
  margin-bottom: 80px;
}

/* about */



/* access */

.studio-info, .awards, .location h2, .location .info-box{
  padding: 0 20px;
}

.studio-info, .awards, .location{
  margin-bottom: 80px;
  h2{
    margin-bottom: 30px;
  }
}

.info-box img{
  width: 80%;
  margin-bottom: 20px;
}

.studio-table th,
.studio-table td {
  padding-top: 15px;
  padding-bottom: 15px;
  vertical-align: middle;
}

.location{
  .access-box{
    flex-direction: column;
    gap: 30px;
  }
  iframe{
    width: 100%;
  }
  .txt-box{
    gap: 10px;
  }
}

/* contact */

.contact .contact-form hr{
  display: none;
}

.contact .contact-form {
  padding: 0 20px;
}

.contact form{
  gap: 35px;
  padding-top: 0px;
}

.contact textarea{
  width: 100%;
}

.contact label .radio-item{
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
}

.contact label p{
  margin-bottom: 16px;
}

/* faq */

.faq-item summary {
  padding: 25px 20px 25px 50px;
  /* iOS Safari　タップ時のハイライトをなくす */
  -webkit-tap-highlight-color: transparent;
}

.faq-list{
  padding: 0 20px;
  margin-bottom: 100px;
  summary{
    font-size: 17px;
  }
}

.faq-item summary {
  display: flex;
  align-items: center;
}

.faq-summary {
  flex: 1;
  min-width: 0;
}

.faq-item summary::after {
  flex-shrink: 0;
}

.faq-contact-box{
  padding: 0 20px;
}

.faq-contact{
  padding:70px 0px;
  margin-bottom: 80px;
}

/* privacy */

.privacy-content{
  padding: 0 20px;
  margin-bottom: 80px;
}

/* quality */



/* works */

.works-list{
  width: 100%;
  margin-bottom: 80px;
  padding: 0 20px 0;
  gap: 40px;
}

.works-list-box{
  flex-direction: column;
  gap: 40px;
}

/* example-common */

.requests-txt, .works-requests .caption, .works-concept, .works-gallery h2 {
  padding: 0 20px;
}

.works-requests, .works-concept{
  margin-bottom: 80px;
}

.works-gallery{
  margin-bottom:100px;
}

.requests-txt h2, .works-concept h2, .works-gallery h2{
  margin-bottom: 30px;
}

.works-requests{
  flex-direction: column;
  gap: 40px;
}

}