@charset "UTF-8";
/*=========================================================================
MODULE
=========================================================================*/
.d_none {
  display: none !important;
}

@media screen and (min-width: 769px) {
  .for_sp {
    display: none !important;
  }
}
@media screen and (max-width: 768px) {
  .for_pc {
    display: none !important;
  }
}
#btnReturn a, #btnMore, #works_detailText, #projrct_single_titleBox, dl#works_singleConatiner dt, .news_textbox, .list_price, .store_info_bloc, ul.overview_list li, .div_catname p, dl.division_container dd {
  font-size: 14px;
  line-height: 180%;
}
@media screen and (max-width: 1919px) {
  #btnReturn a, #btnMore, #works_detailText, #projrct_single_titleBox, dl#works_singleConatiner dt, .news_textbox, .list_price, .store_info_bloc, ul.overview_list li, .div_catname p, dl.division_container dd {
    font-size: clamp(13px, 0.729vw, 14px);
  }
}
@media screen and (max-width: 1200px) {
  #btnReturn a, #btnMore, #works_detailText, #projrct_single_titleBox, dl#works_singleConatiner dt, .news_textbox, .list_price, .store_info_bloc, ul.overview_list li, .div_catname p, dl.division_container dd {
    font-size: clamp(12px, 1.083vw, 13px);
  }
}
@media screen and (max-width: 768px) {
  #btnReturn a, #btnMore, #works_detailText, #projrct_single_titleBox, dl#works_singleConatiner dt, .news_textbox, .list_price, .store_info_bloc, ul.overview_list li, .div_catname p, dl.division_container dd {
    font-size: clamp(12px, 2.343vw, 13px);
  }
}
@media screen and (max-width: 480px) {
  #btnReturn a, #btnMore, #works_detailText, #projrct_single_titleBox, dl#works_singleConatiner dt, .news_textbox, .list_price, .store_info_bloc, ul.overview_list li, .div_catname p, dl.division_container dd {
    font-size: clamp(11px, 3.125vw, 12px);
  }
}

#project_catName, .works_detail {
  font-size: 12px;
}
@media screen and (max-width: 1200px) {
  #project_catName, .works_detail {
    font-size: 11px;
  }
}
@media screen and (max-width: 768px) {
  #project_catName, .works_detail {
    font-size: clamp(11px, 1.692vw, 12px);
  }
}
@media screen and (max-width: 480px) {
  #project_catName, .works_detail {
    font-size: clamp(10px, 2.5vw, 11px);
  }
}

.news_update span {
  font-size: 10px;
}
@media screen and (max-width: 768px) {
  .news_update span {
    font-size: clamp(9px, 1.302vw, 10px);
  }
}
@media screen and (max-width: 480px) {
  .news_update span {
    font-size: clamp(9px, 2.083vw, 10px);
  }
}

#projectName {
  font-size: 36px;
}
@media screen and (min-width: 1200px) and (max-width: 1919px) {
  #projectName {
    font-size: clamp(32px, 1.8759vw, 36px);
  }
}
@media screen and (min-width: 769px) and (max-width: 1199px) {
  #projectName {
    font-size: clamp(30px, 2.668vw, 32px);
  }
}
@media screen and (max-width: 768px) {
  #projectName {
    font-size: clamp(26px, 3.906vw, 30px);
  }
}
@media screen and (max-width: 480px) {
  #projectName {
    font-size: clamp(24px, 5.416vw, 26px);
  }
}

#works_singleHeadline, .div_catname {
  font-size: 20px;
}
@media screen and (min-width: 1200px) and (max-width: 1919px) {
  #works_singleHeadline, .div_catname {
    font-size: clamp(18px, 1.042vw, 20px);
  }
}
@media screen and (min-width: 769px) and (max-width: 1199px) {
  #works_singleHeadline, .div_catname {
    font-size: clamp(16px, 1.334vw, 18px);
  }
}
@media screen and (max-width: 768px) {
  #works_singleHeadline, .div_catname {
    font-size: clamp(16px, 2.604vw, 18px);
  }
}
@media screen and (max-width: 480px) {
  #works_singleHeadline, .div_catname {
    font-size: clamp(15px, 3.125vw, 16px);
  }
}

.news_title, .store_name {
  font-size: 18px;
}
@media screen and (min-width: 1200px) and (max-width: 1919px) {
  .news_title, .store_name {
    font-size: clamp(16px, 0.937vw, 18px);
  }
}
@media screen and (min-width: 769px) and (max-width: 1199px) {
  .news_title, .store_name {
    font-size: clamp(15px, 1.334vw, 16px);
  }
}
@media screen and (max-width: 768px) {
  .news_title, .store_name {
    font-size: clamp(15px, 2.083vw, 16px);
  }
}
@media screen and (max-width: 480px) {
  .news_title, .store_name {
    font-size: clamp(14px, 2.916vw, 15px);
  }
}

#projectCatech, .store_name p {
  font-size: 16px;
}
@media screen and (max-width: 1919px) {
  #projectCatech, .store_name p {
    font-size: clamp(14px, 0.833vw, 16px);
  }
}
@media screen and (max-width: 1200px) {
  #projectCatech, .store_name p {
    font-size: clamp(13px, 1.166vw, 14px);
  }
}
@media screen and (max-width: 900px) {
  #projectCatech, .store_name p {
    font-size: clamp(12px, 1.444vw, 13px);
  }
}
@media screen and (max-width: 768px) {
  #projectCatech, .store_name p {
    font-size: clamp(13px, 1.822vw, 14px);
  }
}
@media screen and (max-width: 480px) {
  #projectCatech, .store_name p {
    font-size: clamp(12px, 2.916vw, 13px);
  }
}

.news_update {
  font-size: 14px;
}
@media screen and (max-width: 1919px) {
  .news_update {
    font-size: clamp(13px, 0.833vw, 14px);
  }
}
@media screen and (max-width: 1200px) {
  .news_update {
    font-size: clamp(12px, 1.166vw, 13px);
  }
}
@media screen and (max-width: 768px) {
  .news_update {
    font-size: clamp(12px, 1.9531vw, 13px);
  }
}
@media screen and (max-width: 480px) {
  .news_update {
    font-size: clamp(11px, 2.708vw, 12px);
  }
}

/*=========================================================================
TOP PAGE：FIRST VIEW
=========================================================================*/
#firstview {
  width: 100%;
  height: auto;
  margin: 0 auto;
  overflow: hidden;
  position: relative;
  z-index: 1;
}
#firstview .swiper-pagination-bullet {
  opacity: 0.5;
  background: rgba(255, 255, 255, 0.6);
}
#firstview .swiper-pagination-bullet-active {
  opacity: 1;
  background: #fff;
}

.view_list {
  position: relative;
  z-index: 1;
}

/* ------------------------------------------------------------ */
ul#viewList {
  list-style-type: none;
  width: 100%;
  height: auto;
  margin: 0 auto;
}
ul#viewList li {
  width: 100%;
  height: auto;
}
ul#viewList li img {
  width: 100%;
  height: auto;
  display: block;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 768px) {
  ul#viewList li img {
    height: 100vh;
  }
}
@media screen and (max-width: 768px) {
  ul#viewList.inner_view li img {
    height: auto;
  }
}

/*=========================================================================
TOP PAGE：CONTENTS PAGE LINL
=========================================================================*/
#contents_pageLinks.section_basic {
  padding-top: 0;
}
@media screen and (max-width: 768px) {
  #contents_pageLinks.section_basic {
    padding-top: 0;
  }
}

/*=========================================================================
WORKS
=========================================================================*/
.works_detail {
  margin-top: 0.5rem;
  line-height: 160%;
}
.works_detail a {
  text-decoration: underline;
  color: #121212;
}
.works_detail a:hover {
  text-decoration: none;
  color: rgb(239, 49, 87);
}

/*=========================================================================
DIVISION
=========================================================================*/
dl.division_container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  width: 100%;
  max-width: 980px;
  height: auto;
  margin: 90px auto;
}
dl.division_container:last-of-type {
  margin-bottom: 0;
}
@media screen and (max-width: 768px) {
  dl.division_container {
    display: block;
    margin: 16% auto;
  }
}
dl.division_container dt, dl.division_container dd {
  height: auto;
  position: relative;
  z-index: 1;
}
dl.division_container dt {
  width: 40%;
  margin-right: 3%;
}
@media screen and (max-width: 768px) {
  dl.division_container dt {
    width: 100%;
    margin: 0 auto 6%;
  }
}
dl.division_container dd {
  width: 57%;
}
@media screen and (max-width: 768px) {
  dl.division_container dd {
    width: 100%;
  }
}
dl.division_container dd p {
  margin-bottom: 1rem;
}
dl.division_container dd p:last-of-type {
  margin-bottom: 0;
}
dl.division_container .swiper-pagination-bullet {
  opacity: 1;
  background: #fff;
  width: 7px;
  height: 7px;
}
dl.division_container .swiper-pagination-bullet-active {
  opacity: 1;
  background: #afafaf;
}

/* ------------------------------------------------------------ */
ul.div_photolist {
  list-style-type: none;
  width: 100%;
  height: auto;
}
ul.div_photolist li {
  width: 100%;
  height: auto;
  display: block;
}
ul.div_photolist li img {
  width: 100%;
  height: auto;
  display: block;
  -o-object-fit: cover;
     object-fit: cover;
}

/* ------------------------------------------------------------ */
.div_catname {
  line-height: 140%;
  margin-bottom: 4%;
}
.div_catname p {
  border-top: 1px solid #afafaf;
  line-height: 140%;
  padding-top: 15px;
  margin-top: 5px;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .div_catname p {
    margin-top: 0.1rem;
    padding-top: 1rem;
  }
}

/* ------------------------------------------------------------ */
.overview_box {
  margin-top: 12%;
  background: #f9f9f9;
  padding: 4% 4% 2%;
}
@media screen and (max-width: 768px) {
  .overview_box {
    margin-top: 6%;
    padding: 3% 3% 2%;
  }
}

ul.overview_list {
  list-style-type: none;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media screen and (max-width: 768px) {
  ul.overview_list {
    width: 100%;
  }
}
ul.overview_list li {
  width: 49%;
  margin: 0 2% 3% 0;
}
@media screen and (max-width: 768px) {
  ul.overview_list li {
    margin-bottom: 1%;
  }
}
ul.overview_list li:nth-of-type(even) {
  margin-right: 0;
}

/*
/* STORE LIST
/* ------------------------------------------------------------ */
ul#storeList {
  list-style-type: none;
  width: 100%;
  height: auto;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
ul#storeList li {
  width: 45%;
  margin-right: 10%;
  height: auto;
}
@media screen and (max-width: 768px) {
  ul#storeList li {
    width: 47.5%;
    margin-right: 5%;
  }
}
ul#storeList li:nth-of-type(even) {
  margin-right: 0;
}

/* ------------------------------------------------------------ */
.store_photo, .store_photo img {
  width: 100%;
  height: auto;
  display: block;
}

.store_photo {
  padding: 0;
  margin: 0 auto 4%;
}

.store_name {
  line-height: 160%;
  font-weight: 600;
  border-bottom: 1px solid #E4E4E4;
  margin-bottom: 15px;
  padding-bottom: 15px;
}
@media screen and (max-width: 768px) {
  .store_name {
    margin-bottom: 2%;
    padding-bottom: 2%;
  }
}
.store_name p {
  line-height: 160%;
  color: #969696;
  margin-top: 0.3rem;
}

.store_info_bloc {
  line-height: 200%;
  color: #969696;
  font-weight: 500;
}

/*=========================================================================
COMPANY
=========================================================================*/
#Biography dl.division_container dt {
  max-width: 500px;
}

ul#partnersList {
  list-style-type: none;
  width: 100%;
  height: auto;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
ul#partnersList li {
  margin: 0 3% 3% 0;
}
ul#partnersList li a.img {
  height: auto;
}
ul#partnersList li a {
  display: block;
  height: auto;
  width: 100%;
  max-width: 100%;
}
ul#partnersList li a:hover {
  opacity: 0.75;
}
ul#partnersList li img {
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  width: auto;
  height: auto;
  max-height: 50px;
}
@media screen and (max-width: 768px) {
  ul#partnersList li img {
    max-height: 6vw;
  }
}

/*=========================================================================
GENERAL STORE
=========================================================================*/
.list_price {
  line-height: 140%;
  font-weight: 600;
  counter-reset: #121212;
}

/*=========================================================================
NEWS
=========================================================================*/
ul#newsList {
  width: 100%;
  height: auto;
  margin: 0 auto;
}
ul#newsList li {
  width: 100%;
  height: auto;
  padding: 30px 0 0;
  margin-bottom: 90px;
  border-top: 1px solid #e4e4e4;
}
@media screen and (max-width: 768px) {
  ul#newsList li {
    padding-top: 4%;
  }
}
ul#newsList li:last-of-type {
  margin-bottom: 0;
}

/* ------------------------------------------------------------ */
dl.news_container {
  width: 100%;
  height: auto;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media screen and (max-width: 768px) {
  dl.news_container {
    display: block;
  }
}
dl.news_container dt, dl.news_container dd {
  height: auto;
}
dl.news_container dt {
  width: 24%;
  margin-right: 6%;
}
@media screen and (max-width: 768px) {
  dl.news_container dt {
    width: 100%;
    margin: 0 auto 4%;
  }
}
dl.news_container dd {
  width: 70%;
}
@media screen and (max-width: 768px) {
  dl.news_container dd {
    width: 100%;
  }
}

/* ------------------------------------------------------------ */
.news_pic {
  width: 100%;
  height: auto;
  display: block;
  padding: 0;
  margin: auto;
}
.news_pic img {
  width: 100%;
  height: auto;
  display: block;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center top;
}

/* ------------------------------------------------------------ */
.news_title {
  line-height: 140%;
  color: #121212;
  font-weight: 600;
  margin-bottom: 0.1rem;
}

.news_update {
  color: #8f8f8f;
  font-weight: 500;
}
.news_update span {
  padding-left: 0.8rem;
}

/* ------------------------------------------------------------ */
.news_textbox {
  margin-top: 1.5rem;
}
.news_textbox p {
  margin-bottom: 1rem;
}
.news_textbox img {
  max-width: 100%;
  display: inline-block;
  height: auto;
}
.news_textbox a {
  color: #121212;
  text-decoration: underline;
}
.news_textbox a:hover {
  color: rgb(243, 21, 91);
  text-decoration: none;
}
.news_textbox iframe {
  max-width: 640px;
  width: 100%;
  height: 100%;
  min-height: 360px;
}
@media screen and (max-width: 768px) {
  .news_textbox iframe {
    min-height: 270px;
  }
}

/*=========================================================================
WORKS：2025.11.28追加
=========================================================================*/
#mainContents.single {
  padding-top: 30px !important;
}
@media screen and (max-width: 768px) {
  #mainContents.single {
    margin-top: 2% !important;
  }
}

#Works.section_basic.single {
  width: 96%;
  margin-bottom: 120px;
  max-width: inherit;
}

#firstView.single {
  width: 100%;
  height: auto;
  display: block;
  position: relative;
  z-index: 1;
  overflow: hidden;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

#single_mainVisual {
  display: block;
  width: 100%;
  height: auto;
  margin: 0 auto;
  padding: 0;
}
#single_mainVisual img {
  width: 100%;
  height: auto;
  display: block;
  -o-object-fit: cover;
     object-fit: cover;
}

/* ----------------------------------------------------------------------- */
dl#works_singleConatiner {
  width: 100%;
  height: auto;
  margin: 0 auto 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media screen and (max-width: 768px) {
  dl#works_singleConatiner {
    display: block;
    margin-bottom: 5%;
  }
}
dl#works_singleConatiner dt, dl#works_singleConatiner dd {
  height: auto;
}
dl#works_singleConatiner dt {
  width: 48%;
  margin-right: 4%;
}
@media screen and (max-width: 768px) {
  dl#works_singleConatiner dt {
    width: 90%;
    margin: 0 auto 4%;
  }
}
dl#works_singleConatiner dd {
  width: 48%;
}
@media screen and (max-width: 768px) {
  dl#works_singleConatiner dd {
    width: 90%;
    margin: 0 auto;
  }
}

/* ----------------------------------------------------------------------- */
#works_singlePic {
  width: 100%;
  height: auto;
  margin: 0 auto;
  padding: 0;
  display: block;
}
#works_singlePic img {
  width: 100%;
  height: auto;
  display: block;
}

/* ----------------------------------------------------------------------- */
#projrct_single_titleBox {
  margin-bottom: 1rem;
}

/* ----------------------------------------------------------------------- */
#project_catName {
  display: inline-block;
  background: #BDBDBD;
  color: #fff;
  font-weight: 600;
  line-height: 100%;
  padding: 0.2rem 0.4rem 0.3rem;
  margin-bottom: 10px;
}
@media screen and (max-width: 768px) {
  #project_catName {
    margin-bottom: 1.5%;
  }
}

#projectName {
  font-weight: 500;
  line-height: 140%;
  margin-bottom: 0.6rem;
}

#projectCatech {
  font-weight: 600;
  line-height: 160%;
  color: #333;
}

/* ----------------------------------------------------------------------- */
#works_singleHeadline {
  margin-bottom: 1rem;
  padding-bottom: 0.4rem;
  line-height: 140%;
  font-weight: 600;
  border-bottom: 1px solid #BDBDBD;
}

/* ----------------------------------------------------------------------- */
#works_detailText {
  line-height: 18px;
  height: 54px;
  overflow: hidden;
  -webkit-transition: 0.2s all;
  transition: 0.2s all;
}
#works_detailText a {
  text-decoration: underline;
  color: #121212;
}
#works_detailText a:hover {
  color: #f20;
  text-decoration: none;
}
#works_detailText p {
  margin-bottom: 1rem;
}
#works_detailText p:last-of-type {
  margin-bottom: 0;
}
#works_detailText img {
  max-width: 100%;
  display: inline-block;
  height: auto;
}
@media screen and (max-width: 768px) {
  #works_detailText img {
    max-width: 100%;
  }
}
#works_detailText a {
  color: #121212;
  text-decoration: underline;
}
#works_detailText a:hover {
  color: rgb(243, 21, 91);
  text-decoration: none;
}
#works_detailText iframe {
  max-width: 640px;
  width: 100%;
  height: 100%;
  min-height: 360px;
}
@media screen and (max-width: 768px) {
  #works_detailText iframe {
    min-height: 270px;
  }
}
#works_detailText.expanded {
  height: auto;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
}

/* ----------------------------------------------------------------------- */
:root {
  interpolate-size: allow-keywords;
}

#btnMore {
  margin-top: 30px;
  display: inline-block;
  cursor: pointer;
  padding: 0.2rem 0.5rem 0.4rem;
  line-height: 100%;
  background: #BDBDBD;
  font-weight: 600;
  color: #fff;
  text-decoration: none;
  -webkit-transition: height 0.3s ease;
  transition: height 0.3s ease;
}
@media screen and (max-width: 768px) {
  #btnMore {
    margin-top: 1.5rem;
  }
}
#btnMore:hover {
  background: #ccc;
  opacity: 0.75;
}

#btnReturn {
  margin-top: 90px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  #btnReturn {
    margin-top: 12%;
  }
}
#btnReturn a {
  text-decoration: none;
  display: inline-block;
  background: #BDBDBD;
  color: #fff;
  font-weight: 600;
  line-height: 100%;
  padding: 0.2rem 0.4rem 0.4rem;
}
#btnReturn a:hover {
  opacity: 0.75;
}

#single_blockEdotor figure {
  padding: 0;
  width: auto;
  height: auto;
  max-width: 100%;
  margin: 0 auto !important;
}
#single_blockEdotor img {
  width: auto;
  height: auto;
  max-width: 100%;
  display: inline-block;
}