@charset "UTF-8";

.search-link-area {
  margin-top: 50px;
}

@media (max-width: 767px) {
  .search-link-area {
    margin-top: 40px;
  }
}

.search-link-area .search-link-ttl {
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-size: 18px;
  font-weight: 500;
  margin-bottom: 20px;
  letter-spacing: 0.1em;
  text-align: center;
}

@media (max-width: 767px) {
  .search-link-area .search-link-ttl {
    font-size: 16px;
  }
}

.search-link-area .search-link-btn {
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  background-color: #ffff00;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  max-width: 410px;
  width: 100%;
  margin: 0 auto;
  padding: 25px 0;
  border-radius: 50px;
  font-size: 24px;
  font-weight: 800;
  color: #000;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}

.search-link-area .search-link-btn:hover {
  background-color: #ffffff;
}

@media (max-width: 767px) {
  .search-link-area .search-link-btn {
    font-size: 20px;
    padding: 22px 0;
    max-width: 350px;
  }
}

.search-link-area .search-link-btn::after {
  content: "▶";
  position: relative;
  font-size: 20px;
  margin-left: 5px;
}

@media (max-width: 767px) {
  .search-link-area .search-link-btn::after {
    font-size: 15px;
    margin-left: 3px;
  }
}

#novelty-top-mainvisual .novelty-top-mainvisual-subttl {
  font-size: 23px;
  font-weight: bold;
  padding-top: 50px;
  margin-bottom: 90px;
}
#novelty-top-mainvisual .novelty-top-mainvisual-subttl span {
  display: inline-block;
  border-bottom: 2px solid #000029;
}

@media (max-width: 767px) {
    #novelty-top-mainvisual .novelty-top-mainvisual-subttl {
        font-size: 12px;
        padding-top: 23px;
        margin-bottom: 28px;
    }
}

#novelty-top-mainvisual {
  background: #000 url(../img/novelty-merge-top/mv.png);
  background-position: right top;
  background-size: 1536px 1143px;
  background-repeat: no-repeat;
  height: 736px;
}

#novelty-top-mainvisual .wrap {
  color: #fff;
}

#novelty-top-mainvisual .novelty-top-mainvisual-subttl {
  margin-bottom: 70px;
}

#novelty-top-mainvisual .novelty-top-mainvisual-subttl span {
  border-bottom: 2px solid #fff;
}

#novelty-top-mainvisual .novelty-top-mainvisual-companies-logo {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

#novelty-top-mainvisual .novelty-top-mainvisual-companies-ttl-sub-text {
  color: #fff;
  font-size: 26px;
  letter-spacing: 0.2em;
  line-height: 1.437039907;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  margin-bottom: 15px;
}

#novelty-top-mainvisual .novelty-top-mainvisual-companies-ttl-sub-text .dot-text {
  position: relative;
}

#novelty-top-mainvisual .novelty-top-mainvisual-companies-ttl-sub-text .dot-text::before {
  content: "";
  display: block;
  background: #fff;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  position: absolute;
  left: 0;
  right: 6px;
  margin: auto;
  top: -5px;
}

#novelty-top-mainvisual .novelty-top-mainvisual-companies-ttl-sub-text .dot-text.first::before {
  right: 9px;
}

#novelty-top-mainvisual .novelty-top-mainvisual-companies-ttl-main-text {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  color: #d4ae70;
  letter-spacing: 0.06em;
  font-size: 75px;
  line-height: 1.146917534;
}

#novelty-top-mainvisual .novelty-top-mainvisual-companies-logo-img {
  max-width: 238px;
  width: 100%;
  margin-right: 60px;
}

#novelty-top-mainvisual .novelty-top-mainvisual-companies-logo-txt {
  font-size: 27px;
  text-align: justify;
  -moz-text-align-last: justify;
  text-align-last: justify;
}

#novelty-top-mainvisual .novelty-top-mainvisual-companies-ttl {
  width: 100%;
}

#novelty-top-mainvisual .novelty-top-mainvisual-companies-txt {
  font-size: 18px;
  margin-top: 25px;
  letter-spacing: 0.08em;
  line-height: 1.73;
  font-weight: 500;
}

#novelty-top-mainvisual .novelty-top-mainvisual-companies-label {
  max-width: 548px;
  margin-top: 70px;
}

#novelty-top-mainvisual .novelty-top-mainvisual-cv {
  display: none;
}

@media (max-width: 1750px) {
  #novelty-top-mainvisual {
    background-size: 1024px 762px;
  }
}
@media (max-width: 1180px) {
  #novelty-top-mainvisual {
    background-position: top right -100px;
  }
}
@media (max-width: 1040px) {
  #novelty-top-mainvisual {
    background-position: top right -250px;
  }
  #novelty-top-mainvisual .novelty-top-mainvisual-companies-ttl-main-text {
    font-size: 70px;
  }
}
@media (max-width: 920px) {
  #novelty-top-mainvisual .novelty-top-mainvisual-companies-ttl-main-text {
    font-size: 65px;
  }
  #novelty-top-mainvisual .novelty-top-mainvisual-companies-txt {
    font-size: 16px;
    margin-top: 35px;
  }
}
@media (max-width: 860px) {
  #novelty-top-mainvisual .novelty-top-mainvisual-companies-ttl-main-text {
    font-size: 60px;
  }
  #novelty-top-mainvisual .novelty-top-mainvisual-companies-txt {
    margin-top: 55px;
    font-size: 15px;
  }
}
@media (max-width: 767px) {
  #novelty-top-mainvisual {
    background-image: url(../img/novelty-merge-top/mv_sp.jpg);
    background-position: top right;
    background-size: contain;
    height: 655px;
    background-color: #000;
  }
  #novelty-top-mainvisual .novelty-top-mainvisual-companies-txt {
    font-size: 13px;
  }
  #novelty-top-mainvisual .novelty-top-mainvisual-subttl {
    margin-bottom: 28px;
  }
  #novelty-top-mainvisual .novelty-top-mainvisual-companies-ttl-sub-text {
    font-size: 22px;
    margin-bottom: 8px;
  }
  #novelty-top-mainvisual .novelty-top-mainvisual-companies-ttl-main-text {
    font-size: 38px;
  }
  #novelty-top-mainvisual .novelty-top-mainvisual-companies-txt {
    margin-top: 10px;
  }
  #novelty-top-mainvisual .novelty-top-mainvisual-companies-label {
    margin-top: 65px;
  }
  #novelty-top-mainvisual .novelty-top-mainvisual-cv {
    padding: 0 10px;
    left: 0px;
    right: 0px;
    bottom: 0;
  }
}

/* 260212_メインビジュアル変更 */

#novelty-top-mainvisual.style-260212 {
  background: #000 url(../img/novelty-merge-top/mv.png);
  background-position: right top;
  background-size: 1536px 1143px;
  background-repeat: no-repeat;
  height: 736px;
}

#novelty-top-mainvisual.style-260212 .wrap {
  color: #fff;
}

#novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-subttl {
  margin-bottom: 70px;
}

#novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-subttl span {
  border-bottom: 2px solid #fff;
}

#novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-logo {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

#novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-ttl-sub-text {
  color: #fff;
  font-size: 26px;
  letter-spacing: 0.2em;
  line-height: 1.437039907;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  margin-bottom: 15px;
}

#novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-ttl-sub-text .dot-text {
  position: relative;
}

#novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-ttl-sub-text .dot-text::before {
  content: "";
  display: block;
  background: #fff;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  position: absolute;
  left: 0;
  right: 6px;
  margin: auto;
  top: -5px;
}

#novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-ttl-sub-text .dot-text.first::before {
  right: 9px;
}

#novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-ttl-main-text {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  color: #d4ae70;
  letter-spacing: 0.06em;
  font-size: 75px;
  line-height: 1.146917534;
}

#novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-logo-img {
  max-width: 238px;
  width: 100%;
  margin-right: 60px;
}

#novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-logo-txt {
  font-size: 27px;
  text-align: justify;
  -moz-text-align-last: justify;
  text-align-last: justify;
}

#novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-ttl {
  width: 100%;
}

#novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-txt {
  font-size: 18px;
  margin-top: 25px;
  letter-spacing: 0.08em;
  line-height: 1.73;
  font-weight: 500;
}

#novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-label {
  max-width: 548px;
  margin-top: 70px;
  position: relative;
}

#novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-label-txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 10px;
  font-weight: 400;
  position: absolute;
  bottom: 3px;
}

#novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-cv {
  display: none;
}

@media (max-width: 1750px) {
  #novelty-top-mainvisual.style-260212 {
    background-size: 1024px 762px;
  }
}
@media (max-width: 1180px) {
  #novelty-top-mainvisual.style-260212 {
    background-position: top right -100px;
  }
}
@media (max-width: 1040px) {
  #novelty-top-mainvisual.style-260212 {
    background-position: top right -250px;
  }
  #novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-ttl-main-text {
    font-size: 70px;
  }
}
@media (max-width: 920px) {
  #novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-ttl-main-text {
    font-size: 65px;
  }
  #novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-txt {
    font-size: 16px;
    margin-top: 35px;
  }
}
@media (max-width: 860px) {
  #novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-ttl-main-text {
    font-size: 60px;
  }
  #novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-txt {
    margin-top: 55px;
    font-size: 15px;
  }
}
@media (max-width: 767px) {
  #novelty-top-mainvisual.style-260212 {
    background-image: url(../img/novelty-merge-top/mv_sp.jpg);
    background-position: top right;
    background-size: contain;
    height: 835px;
    background-color: #000;
  }
  #novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-txt {
    font-size: 13px;
  }
  #novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-subttl {
    margin-bottom: 28px;
  }
  #novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-ttl-sub-text {
    font-size: 20px;
    margin-bottom: 8px;
    letter-spacing: 0.1em;
  }
  #novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-ttl-sub-text .dot-text::before {
    right: 2px;
  }
  #novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-ttl-sub-text .dot-text.first::before {
    right: 4px;
  }
  #novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-ttl-main-text {
    font-size: 38px;
  }
  #novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-txt {
    margin-top: 10px;
  }
  #novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-label {
    margin-top: 35px;
  }
  #novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-label-txt {
    font-size: 17.5px;
    bottom: -6px;
  }
  #novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-cv {
    padding: 0 10px;
    left: 0px;
    right: 0px;
    bottom: 0;
  }
}
@media (max-width: 574px) {
  #novelty-top-mainvisual.style-260212 {
    height: calc(337px + 86.5vw);
  }
  #novelty-top-mainvisual.style-260212 .novelty-top-mainvisual-companies-label-txt {
    font-size: 2.97vw;
    bottom: -1.08vw;
  }
}

/* 260212_メインビジュアル変更 ここまで */

.novelty-top .catalog-dw-btn {
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 0;
  -ms-flex: 0 0 50%;
  flex: 0 0 50%;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  max-width: 230px;
  width: 100%;
  position: fixed;
  right: 22px;
  bottom: 15px;
  z-index: 3;
}

.novelty-top .catalog-dw-btn-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding: 13px 10px;
  max-width: 230px;
  width: 100%;
  height: 74px;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}

.novelty-top .catalog-dw-btn-link img {
  max-width: 160px;
}

.novelty-top .catalog-dw-btn-link:nth-child(1) {
  background: #ffff00;
  border-radius: 10px 10px 0 0;
  padding: 14px 12px 14px 14px;
}

.novelty-top .catalog-dw-btn-link:nth-child(2) {
  background: #ffffff;
  border-radius: 0 0 10px 10px;
  padding: 12px 12px 12px 10px;
}

.novelty-top .catalog-dw-btn-link::after {
  content: "";
  display: inline-block;
  width: 6px;
  height: 5px;
  background: #000000;
  -webkit-clip-path: polygon(0 0, 0 100%, 100% 50%);
          clip-path: polygon(0 0, 0 100%, 100% 50%);
}

@media (hover: hover) {
  .novelty-top .catalog-dw-btn-link:hover:nth-child(1) {
    background: #fff;
  }
  .novelty-top .catalog-dw-btn-link:hover:nth-child(2) {
    background: #ffff00;
  }
}
@media (max-width: 767px) {
  .novelty-top .catalog-dw-btn {
    bottom: 0;
    left: 0;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    max-width: 100%;
  }
  .novelty-top .catalog-dw-btn .catalog-dw-btn-link {
    max-width: 100%;
    height: 52px;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
  }
  .novelty-top .catalog-dw-btn .catalog-dw-btn-link img {
    max-width: 100%;
    max-height: 50px;
    margin: 0 auto;
  }
  .novelty-top .catalog-dw-btn .catalog-dw-btn-link:nth-child(1) {
    border-radius: 5px 0 0 5px;
    padding: 0 23.5px;
  }
  .novelty-top .catalog-dw-btn .catalog-dw-btn-link:nth-child(2) {
    border-radius: 0 5px 5px 0;
    padding: 0 12.5px;
  }
  .novelty-top .catalog-dw-btn .catalog-dw-btn-link::after {
    content: "";
    display: none;
  }
}
.novelty-top .achievement-logo-area {
  background: #fff;
  position: relative;
  z-index: 2;
  padding: 18px;
}

.novelty-top .achievement-logo-area-inner {
  padding: 0 2%;
  background: url(../img/novelty-top/achievement-logo-list.jpg);
  background-repeat: repeat-x;
  background-size: cover;
  height: 68px;
  -webkit-animation: roop 130s linear infinite;
  animation: roop 130s linear infinite;
}

@-webkit-keyframes roop {
  from {
    background-position: 0 0;
  }
  to {
    background-position: -2060px 0;
  }
}
@keyframes roop {
  from {
    background-position: 0 0;
  }
  to {
    background-position: -2060px 0;
  }
}
@media (max-width: 767px) {
  .novelty-top .achievement-logo-area {
    padding: 20px 15px;
  }
  .novelty-top .achievement-logo-area-inner {
    height: 36px;
    -webkit-animation: roop 90s linear infinite;
    animation: roop 90s linear infinite;
    padding: 0;
  }
}
/*導入実績_メインビジュアル用_250718*/
.novelty-top .new-achievement-logo-area {
  background: #fff;
  position: relative;
  z-index: 2;
  padding: 20px 0 15px;
}

.novelty-top .new-achievement-logo-area-inner {
  padding: 0 2%;
  background: url(../img/novelty-top/new-achievement-logo-list.jpg?250718);
  background-repeat: repeat-x;
  background-size: cover;
  height: 68px;
  -webkit-animation: new-roop 130s linear infinite;
  animation: new-roop 130s linear infinite;
}

@-webkit-keyframes new-roop {
  from {
    background-position: 0 0;
  }
  to {
    background-position: -3875px 0;
  }
}
@keyframes new-roop {
  from {
    background-position: 0 0;
  }
  to {
    background-position: -3875px 0;
  }
}
@media (max-width: 767px) {
  .novelty-top .new-achievement-logo-area {
    padding: 10px 0;
  }
  .novelty-top .new-achievement-logo-area-inner {
    height: 51px;
    -webkit-animation: new-roop-sp 90s linear infinite;
    animation: new-roop-sp 90s linear infinite;
    padding: 0;
  }
}
@-webkit-keyframes new-roop-sp {
  from {
    background-position: 0 0;
  }
  to {
    background-position: -2906px 0;
  }
}
@keyframes new-roop-sp {
  from {
    background-position: 0 0;
  }
  to {
    background-position: -2906px 0;
  }
}
/*導入実績_メインビジュアル用_250718 ここまで*/
.novelty-top #heading-area {
  background: #1c3435;
}

.novelty-top #heading-area .heading-logo {
  top: -140px;
  top: -40px;
}

.novelty-top #heading-area .new-area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  position: relative;
  z-index: 2;
  margin-bottom: 40px;
}





#novelty-top-feature {
  background-color: #1f3929;
  color: #fff;
  padding-top: 168px;
  padding-bottom: 72px;
  position: relative;
  /*モーダル本体の擬似要素の指定*/
  /*モーダル本体に「active」クラス付与した時のスタイル*/
  /*モーダル枠の指定*/
  /*モーダルを閉じるボタンの指定*/
  /*モーダル内のコンテンツの指定*/
}

@media (max-width: 1240px) {
  #novelty-top-feature .wrap{
    padding: 0 20px;
  }
}

@media (max-width: 767px) {
  #novelty-top-feature .wrap{
    padding: 0 20px;
  }
}

#novelty-top-feature.style-260128 {
  padding-top: 112px;
  padding-bottom: 112px;
  background-color: #000000;
}

#novelty-top-feature .novelty-top-feature-logobg {
    max-width: 1310px;
    width: 100%;
    position: absolute;
    left: 0;
    right: 0;
    margin: auto;
}

@media (max-width: 767px) {
  #novelty-top-feature .novelty-top-feature-logobg {
    width: 95%;
  }
}
  
#novelty-top-feature .novelty-top-feature-wrap-ttl {
  color: #fff;
  font-size: clamp(40px, 6.5vw, 60px);
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-weight: 800;
  line-height: 1.5;
}

#novelty-top-feature .novelty-top-feature-wrap-txt {
  color: #fff;
  font-size: 18px;
  margin-top: 10px;
  margin-bottom: 40px;
}

#novelty-top-feature .novelty-top-feature-title .common-ttl-wrap {
  border-bottom: 1px solid #fff;
}

#novelty-top-feature .novelty-top-feature-item:not(:last-child) {
  margin-bottom: 30px;
}

#novelty-top-feature .novelty-top-feature-item.second .novelty-top-feature-banner::before {
  background: url(../img/novelty-merge-top/feature-bg02.jpg) no-repeat;
  background-position: center center;
}

#novelty-top-feature .novelty-top-feature-item.second .project-detail-bk {
  background-image: url(../img/novelty-merge-top/feature-mv-detail-02.jpg);
}

#novelty-top-feature .novelty-top-feature-item.second .novelty-top-feature-banner-txt {
  max-width: 480px;
}

#novelty-top-feature.style-260128 .novelty-top-feature-item.second .novelty-top-feature-banner-txt {
  max-width: 370px;
}

#novelty-top-feature .novelty-top-feature-banner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  height: 380px;
  border-radius: 20px;
  padding: 0 30px;
  cursor: pointer;
  position: relative;
  z-index: 1;
  overflow: hidden;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  border: 1px solid #ffffff;
}

#novelty-top-feature .novelty-top-feature-banner::before {
  content: "";
  background: url(../img/novelty-merge-top/feature-bg01.jpg) no-repeat;
  background-size: cover;
  background-position: center right;
  position: absolute;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  width: 100%;
  height: 100%;
  inset: 0;
  margin: auto;
  border-radius: 20px;
  z-index: -1;
}

#novelty-top-feature .novelty-top-feature-banner-ttl {
  font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho Pro", serif;
  font-weight: 500;
  font-size: 32px;
  letter-spacing: 0.12em;
}

#novelty-top-feature .novelty-top-feature-banner-ttl:not(:last-child) {
  margin-bottom: 22px;
}

#novelty-top-feature .novelty-top-feature-banner-ttl span {
  background-color: #000;
  padding: 6px 0 6px 10px;
}

#novelty-top-feature .novelty-top-feature-banner-txt {
  margin-top: 30px;
  max-width: 330px;
  width: 100%;
  border: 1px solid #fff;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 14px;
  letter-spacing: 0.05em;
  padding: 3px 0 3px 8px;
}

#novelty-top-feature.style-260128 .novelty-top-feature-banner-txt {
	display: flex;
	background-color: hsla(0,0%,0%,0.50);
	padding: 6px 0 9px 10px;
}

#novelty-top-feature .novelty-top-feature-banner-txt span {
  padding-right: 8px;
  font-family: "Outfit", sans-serif;
}

#novelty-top-feature.style-260128 .novelty-top-feature-banner-txt .client{
  padding-right: 8px;
  font-family: "Outfit", sans-serif;
}

#novelty-top-feature.style-260128 .novelty-top-feature-banner-txt .name{
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 19px;
	line-height: 1.4;
}

#novelty-top-feature.style-260128 .novelty-top-feature-banner-txt .name large{
	font-size: 20px;
	font-weight: bold;
}

#novelty-top-feature .novelty-top-feature-banner-btn {
  background-color: #fff;
  max-width: 140px;
  width: 100%;
  color: #000;
  text-align: center;
  border-radius: 50px;
  line-height: 1;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 0.04em;
  position: relative;
  padding: 15.5px 0;
  margin-top: 40px;
}

#novelty-top-feature .novelty-top-feature-banner-btn::after {
  content: "";
  position: absolute;
  background: url(../img/novelty-merge-top/feature-plus.png) no-repeat;
  background-size: cover;
  width: 10px;
  height: 10px;
  top: 0;
  bottom: 0;
  right: 18px;
  margin: auto;
}

#novelty-top-feature .novelty-top-feature-modal-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-align: center;
  background: rgba(0, 0, 0, 0.5);
  opacity: 0;
  visibility: hidden;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  z-index: 10000;
}

#novelty-top-feature .novelty-top-feature-modal-container:before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  height: 100%;
}

#novelty-top-feature .novelty-top-feature-modal-container.active {
  opacity: 1;
  visibility: visible;
}

#novelty-top-feature .novelty-top-feature-modal-body {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  max-width: 1000px;
  width: 100%;
  height: 95%;
  overflow: auto;
}

#novelty-top-feature .novelty-top-feature-modal-close {
  position: absolute;
  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;
  top: 10px;
  right: 20px;
  width: 40px;
  height: 40px;
  font-size: 40px;
  color: #000000;
  background-color: #fff;
  border-radius: 50px;
  cursor: pointer;
  z-index: 10;
  -webkit-box-shadow: 0 2px 5px #1e1e1e;
  box-shadow: 0 2px 5px #1e1e1e;
}

#novelty-top-feature .novelty-top-feature-modal-close span {
  position: absolute;
  width: 2px;
  height: 20px;
  background-color: #000;
  inset: 0;
  margin: auto;
}

#novelty-top-feature .novelty-top-feature-modal-close span:first-child {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

#novelty-top-feature .novelty-top-feature-modal-close span:last-child {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

#novelty-top-feature .novelty-top-feature-modal-content {
  background: #fff;
  text-align: left;
  padding: 0 0;
  color: #000;
  font-family: YakuHanJP, "Zen Kaku Gothic Antique", sans-serif;
}

#novelty-top-feature .novelty-top-feature-modal-content .Outfit {
  font-family: "Outfit", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
}

#novelty-top-feature .novelty-top-feature-modal-content .yumin {
  font-family: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho Pro", serif;
  font-weight: 300;
  font-style: normal;
}

#novelty-top-feature .project-detail-bk {
  background: url(../img/novelty-merge-top/feature-mv-detail-01.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: right center;
  height: 704px;
  padding-top: 240px;
  padding-top: 180px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

#novelty-top-feature .project-detail-wrap {
  max-width: 804px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}

#novelty-top-feature .mv-warp {
  max-width: 680px;
  max-width: 804px;
  width: 100%;
  margin: 0 auto;
  position: relative;
}

#novelty-top-feature .mv-img-title {
  max-width: 126px;
  width: 100%;
  margin-bottom: 132px;
}

#novelty-top-feature .mv-text-title {
  font-size: 35px;
  letter-spacing: 0.12em;
  line-height: 1.6571428571;
  margin-bottom: 36px;
}

#novelty-top-feature .mv-text-title .text-bk {
  background: #000000;
  padding-left: 5px;
  color: #fff;
}

#novelty-top-feature .mv-text-title .text-bk.top {
  margin-bottom: 9px;
}

#novelty-top-feature .mv-company {
  background: #fff;
  color: #000;
  font-weight: 500;
  font-size: 18px;
  letter-spacing: 0.05em;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 0 10px;
  margin-bottom: 70px;
}

#novelty-top-feature .mv-company .client {
  font-size: 16px;
  font-weight: 300;
  margin-right: 14px;
}

#novelty-top-feature .project-contens {
  padding: 90px 0 50px;
}

#novelty-top-feature .project-contens-wrap {
  max-width: 804px;
  width: 100%;
  margin: 0 auto;
}

#novelty-top-feature .project-contens-wrap.second {
  padding-top: 115px;
}

#novelty-top-feature .project-contens-wrap.third {
  padding-top: 90px;
}

#novelty-top-feature .project-contens-title {
  font-size: 32px;
  letter-spacing: 0.15em;
  line-height: 1.65625;
  margin-bottom: 70px;
  text-align: justify;
}

#novelty-top-feature .project-contens-title.flex {
  margin-bottom: 5px;
}

#novelty-top-feature .project-contens-number {
  width: 120px;
  margin-bottom: 60px;
}

#novelty-top-feature .project-contens-text {
  font-size: 17px;
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 2;
  margin-bottom: 90px;
  text-align: justify;
}

#novelty-top-feature .project-contens-text.pc-mb {
  margin-bottom: 60px;
}

#novelty-top-feature .project-contens-text.sp-mb {
  margin-bottom: 60px;
}

#novelty-top-feature .project-contens-text.text-b {
  font-size: 21px;
  font-weight: bold;
}

#novelty-top-feature .project-contens-main-img-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

#novelty-top-feature .project-contens-main-img-flex-box.single {
  max-width: 804px;
  width: 100%;
  margin: 0 auto;
}

#novelty-top-feature .project-contens-main-img {
  width: 100%;
}

#novelty-top-feature .manager-area {
  background: #ffff00;
  padding: 60px;
  margin-bottom: 100px;
}

#novelty-top-feature .manager-area .wrap {
  max-width: 760px;
  width: 100%;
  margin: 0 auto;
}

#novelty-top-feature .manager-area .manager-text {
  font-size: 36px;
  letter-spacing: 0.12em;
  line-height: 1.8385650224;
  margin-bottom: 50px;
}

#novelty-top-feature .manager-name {
  font-size: 16px;
  letter-spacing: 0.08em;
  line-height: 1.75;
  font-weight: 400;
  margin-bottom: 90px;
}

#novelty-top-feature .border-line {
  background: #1e1e1e;
  height: 1px;
  width: 100%;
  margin: 0 auto 90px;
}

@media (hover: hover) {
  #novelty-top-feature .novelty-top-feature-banner:hover {
    opacity: 0.7;
  }
  #novelty-top-feature .novelty-top-feature-banner:hover::before {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }
  #novelty-top-feature .novelty-top-feature-modal-close {
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
  }
  #novelty-top-feature .novelty-top-feature-modal-close:hover {
    opacity: 0.7;
  }
}
@media (max-width: 1025px) {
  #novelty-top-feature .novelty-top-feature-modal-body {
    width: 95%;
  }
  #novelty-top-feature .mv-warp {
    width: 95%;
  }
  #novelty-top-feature .project-contens-wrap {
    width: 95%;
  }
}
@media (max-width: 767px) {
  #novelty-top-feature {
    padding-top: 30px;
    padding-bottom: 5px;
  }
  #novelty-top-feature.style-260128 {
    padding-top: 30px;
    padding-bottom: 30px;
  }
  #novelty-top-feature .novelty-top-feature-wrap-ttl {
    font-size: clamp(30px, 7.87vw, 60px);
  }
  #novelty-top-feature .novelty-top-feature-wrap-txt {
    font-size: 14px;
  }
  
  #novelty-top-feature .novelty-top-feature-title {
    margin-bottom: 23px;
  }
  #novelty-top-feature .novelty-top-feature-item:not(:last-child) {
    margin-bottom: 20px;
  }
  #novelty-top-feature .novelty-top-feature-item.second .novelty-top-feature-banner::before {
    background: url(../img/novelty-merge-top/feature-bg02_sp.jpg) no-repeat;
    background-position: top right;
  }
  #novelty-top-feature .novelty-top-feature-item.second .project-detail-bk {
    background-image: url(../img/novelty-merge-top/feature-mv-detail-02-sp.jpg);
  }
  #novelty-top-feature .novelty-top-feature-item.second .novelty-top-feature-banner-txt {
    max-width: 308px;
  }
  #novelty-top-feature.style-260128 .novelty-top-feature-banner-txt .name{
    font-size: 18px;
    letter-spacing: -0.02em;
  }
  #novelty-top-feature.style-260128 .novelty-top-feature-banner-txt .name large{
	font-size: 19px;
  }
  #novelty-top-feature.style-260128 .novelty-top-feature-item.second .novelty-top-feature-banner-txt {
    max-width: 364px;
  }
  #novelty-top-feature .novelty-top-feature-banner {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: end;
    height: 468px;
    border-radius: 10px;
    padding: 0 10px 25px 10px;
  }
  #novelty-top-feature .novelty-top-feature-banner::before {
    content: "";
    background: url(../img/novelty-merge-top/feature-bg01_sp.jpg) no-repeat;
    background-size: cover;
    background-position: top right;
    border-radius: 10px;
  }
  #novelty-top-feature .novelty-top-feature-banner-ttl {
    font-size: 20px;
  }
  #novelty-top-feature .novelty-top-feature-banner-ttl:not(:last-child) {
    margin-bottom: 20px;
  }
  #novelty-top-feature .novelty-top-feature-banner-ttl span {
    background-color: #000;
    padding: 5px 0 5px 10px;
  }
  #novelty-top-feature .novelty-top-feature-banner-txt {
    margin-top: 15px;
    max-width: 308px;
    font-size: 13px;
    padding: 2px 0 2px 8px;
  }
  #novelty-top-feature .novelty-top-feature-banner-btn {
    max-width: 132px;
    font-size: 14px;
    padding: 14px 0;
    margin-top: 20px;
  }
  #novelty-top-feature .novelty-top-feature-banner-btn::after {
    width: 8px;
    height: 8px;
    right: 16px;
  }
  #novelty-top-feature .novelty-top-feature-modal-body {
    height: 80%;
  }
  #novelty-top-feature .novelty-top-feature-modal-close {
    top: 2%;
    right: 8px;
  }
  #novelty-top-feature .mv-warp {
    width: 100%;
  }
  #novelty-top-feature .project-contens-wrap {
    width: 100%;
  }
  #novelty-top-feature .project-detail-wrap {
    padding: 0 13px;
  }
  #novelty-top-feature .project-detail-bk {
    padding-top: 35px;
    background: url(../img/novelty-merge-top/feature-mv-detail-01-sp.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    height: 502px;
  }
  #novelty-top-feature .mv-img-title {
    max-width: 108px;
    margin-bottom: 230px;
  }
  #novelty-top-feature .mv-img-title.second {
    margin-bottom: 365px;
  }
  #novelty-top-feature .mv-text-title {
    font-size: 27px;
    line-height: 1.65;
    margin-bottom: 25px;
  }
  #novelty-top-feature .mv-text-title .sp-text-bk {
    padding-left: 5px;
  }
  #novelty-top-feature .mv-text-title .text-bk {
    max-width: 330px;
    padding-left: 3px;
  }
  #novelty-top-feature .mv-text-title .text-bk.second {
    height: 235px;
    width: 48px;
  }
  #novelty-top-feature .mv-text-title .text-bk.second.p-top {
    height: 310px;
  }
  #novelty-top-feature .mv-text-title .text-bk.second.p-top.pcv {
    height: 0;
    display: none;
  }
  #novelty-top-feature .mv-text-title .text-bk .spv {
    display: inline-block;
  }
  #novelty-top-feature .mv-text-title .text-bk.third {
    max-width: 322px;
  }
  #novelty-top-feature .mv-company {
    font-size: 15px;
    padding: 0 8px;
    margin-bottom: 36px;
  }
  #novelty-top-feature .mv-company .client {
    font-size: 14px;
    margin-right: 10px;
  }
  #novelty-top-feature .mv-company.second {
    max-width: 335px;
  }
  #novelty-top-feature .project-contens {
    padding: 64px 0 32px 0;
  }
  #novelty-top-feature .project-contens-wrap {
    padding: 0 15px;
  }
  #novelty-top-feature .project-contens-wrap.second {
    padding-top: 70px;
  }
  #novelty-top-feature .project-contens-wrap.third {
    padding-top: 50px;
  }
  #novelty-top-feature .project-contens-title {
    font-size: 24px;
    letter-spacing: 0.05em;
    line-height: 1.65625;
    margin-bottom: 45px;
  }
  #novelty-top-feature .project-contens-title.second {
    font-size: 21px;
    letter-spacing: 0.01em;
  }
  #novelty-top-feature .project-contens-number {
    width: 90px;
    margin-bottom: 50px;
  }
  #novelty-top-feature .project-contens-text {
    font-size: 15px;
    line-height: 2;
    margin-bottom: 60px;
  }
  #novelty-top-feature .project-contens-text.text-b {
    font-size: 19px;
    font-weight: bold;
    line-height: 1.6315789474;
    margin-bottom: 20px;
  }
  #novelty-top-feature .project-contens-text.sp-mb {
    margin-bottom: 20px;
  }
  #novelty-top-feature .project-contens-text.sp-mb-second {
    margin-bottom: 40px;
  }
  #novelty-top-feature .project-contens-main-img {
    width: calc(100% - 20px);
  }
  #novelty-top-feature .project-contens-main-img-flex {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
  #novelty-top-feature .manager-name {
    font-size: 16px;
    letter-spacing: 0.08em;
    line-height: 1.75;
    font-weight: 400;
    margin-bottom: 60px;
  }
  #novelty-top-feature .border-line {
    margin-bottom: 60px;
  }
}
body.modal-open {
  overflow: hidden;
  width: 100%;
}






.novelty-top #heading-area .news-tite-area {
  width: 17%;
  padding-top: 40px;
}

.novelty-top #heading-area .en-news-tite {
  font-family: "Open Sans", sans-serif;
  font-weight: bold;
  font-size: 22px;
  letter-spacing: 0.06em;
  line-height: 1;
  text-align: center;
  color: #fff;
}

.novelty-top #heading-area .ja-news-tite {
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1.75;
  text-align: center;
  color: #fff;
}

.novelty-top #heading-area .news-article {
  width: 82%;
  background: #fff;
  border-radius: 7px;
}

.novelty-top #heading-area .news-article-list {
  border-bottom: 1px solid #d3d3d3;
}

.novelty-top #heading-area .news-article-list:last-child {
  border-bottom: none;
}

.novelty-top #heading-area .news-article-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding: 25px;
}

.novelty-top #heading-area .news-article-time {
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 2.0986666667;
  width: 100px;
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

.novelty-top #heading-area .news-article-name {
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 2.0986666667;
  width: calc(100% - 130px);
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

.novelty-top #heading-area span.news-article-name::after {
  content: "";
  display: inline-block;
  background: url(../img/novelty-top/article-link-icon.png);
  background-repeat: no-repeat;
  background-size: 12px 10px;
  background-position: center;
  width: 12px;
  height: 10px;
  margin-left: 5px;
}

.novelty-top #heading-area .novelty-contact-btn-area {
  background: #152728 url(../img/novelty-top/novelty-contact-bk.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: right center;
  height: 378px;
  border-radius: 10px;
  padding-top: 52px;
  padding-left: 48px;
  position: relative;
  z-index: 1;
}

.novelty-top #heading-area .novelty-contact-btn-title {
  color: #88ca1f;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 30px;
  line-height: 1.4293333333;
  font-weight: 900;
  letter-spacing: 0.06em;
  margin-bottom: 25px;
}

.novelty-top #heading-area .novelty-contact-btn-text {
  color: #fff;
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 2.0986666667;
  margin-bottom: 38px;
}

.novelty-top #heading-area .novelty-contact-btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  height: 74px;
  background: #ffff00;
  width: 360px;
  border-radius: 60px;
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.06em;
  color: #000029;
  position: relative;
  padding-left: 58px;
  border: 1px solid transparent;
}

.novelty-top #heading-area .novelty-contact-btn-icon {
  width: 68px;
  height: 52px;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 25px;
  margin: auto;
}

@media (hover: hover) {
  .novelty-top #heading-area .novelty-contact-btn:hover {
    background: #86c927;
    color: #fff;
  }
  .novelty-top #heading-area a.news-article-link:hover .news-article-time {
    color: #88ca1f;
  }
  .novelty-top #heading-area a.news-article-link:hover .news-article-name {
    color: #88ca1f;
  }
}
@media (max-width: 767px) {
  .novelty-top #heading-area {
    padding-top: 25px;
  }
  .novelty-top #heading-area .heading-logo {
    top: 0px;
  }
  .novelty-top #heading-area .new-area {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
  .novelty-top #heading-area .news-tite-area {
    width: 100%;
    padding-top: 0;
    margin-bottom: 15px;
  }
  .novelty-top #heading-area .en-news-tite {
    line-height: 1.4309090909;
  }
  .novelty-top #heading-area .news-article {
    width: 100%;
  }
  .novelty-top #heading-area .news-article-link {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    padding: 10px 15px 12px;
  }
  .novelty-top #heading-area .news-article-time {
    width: 100%;
    font-size: 13px;
    line-height: 2.4215384615;
  }
  .novelty-top #heading-area .news-article-name {
    width: 100%;
    font-size: 13px;
    line-height: 1.3446153846;
  }
  .novelty-top #heading-area .novelty-contact-btn-area {
    background-image: none;
    height: auto;
    padding: 20px 20px 18px;
  }
  .novelty-top #heading-area .novelty-contact-btn-title {
    font-size: 16px;
    line-height: 1.3125;
    margin-bottom: 14px;
  }
  .novelty-top #heading-area .novelty-contact-btn-text {
    font-size: 13px;
    line-height: 1.5692307692;
    margin-bottom: 16px;
  }
  .novelty-top #heading-area .novelty-contact-btn {
    border-radius: 7px;
  }
  .novelty-top #heading-area .novelty-contact-image-sp {
    margin-bottom: 15px;
  }
  .novelty-top #heading-area .novelty-contact-btn {
    width: 100%;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    height: 51px;
    font-size: 13px;
    padding-left: 0;
  }
  .novelty-top #heading-area .novelty-contact-btn-icon {
    width: 44px;
    height: 34px;
    right: 9px;
  }
}

.novelty-top #heading-area .novelty-invitation-area {
  background-color: transparent;
  padding: 0;
  position: relative;
  z-index: 1;
  margin-top: -20px;
}

.novelty-top #heading-area .novelty-invitation-btn-text {
  color: #fff;
  font-size: 17px;
  font-weight: bold;
  letter-spacing: 0.12em;
  line-height: 2.0986666667;
  text-align: center;
}

@media (max-width: 767px) {
  .novelty-top #heading-area .novelty-invitation-area {
    height: auto;
    padding-bottom: 30px;
    margin-top: -25px;
  }
  .novelty-top #heading-area .novelty-invitation-btn-text {
    font-size: 15px;
    line-height: 1.5692307692;
	letter-spacing: 0.03em;
  }
}

.novelty-top #reason {
  padding: 80px 0;
}

@media (max-width: 767px) {
  .novelty-top #reason {
    padding: 50px 0;
  }
}

/* 私たちが選ばれる理由 セクション全体 */
#reason {
    background-color: #000000;
    padding: 80px 0 100px;
    font-family: YakuHanJP, "Noto Sans JP", sans-serif;
}

#reason .reason-title {
    color: #fff;
    margin-bottom: 20px;
    font-size: clamp(34px, 6.5vw, 50px);
    font-weight: 800;
}

.reason-subtitle {
    color: #fff;
    font-size: 18px;
    margin-top: 10px;
    margin-bottom: 40px;
}

.reason-container {
    display: flex;
    flex-direction: column;
    gap: 50px;
}

/* 横長の独立したボックス */
.reason-box {
    background-color: #2b2c2c;
    border-radius: 12px;
    padding: 50px 60px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    border: 1px solid #444; /* 枠線をうっすらと配置して高級感を */
}

.reason-box-wrap {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 50px;
}

/* ボックス内 左側（テキストエリア） */
.reason-box-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.reason-box-ttl-img {
    max-width: 543px;
    width: 100%;
    margin-bottom: 25px;
}

.reason-box-ttl-img img {
    width: 100%;
    height: auto;
}

.reason-box-subhd {
    color: #fff;
    font-size: clamp(17px, 1.9vw, 25px);
    font-weight: 800;
    margin-bottom: 15px;
    line-height: 1.5;
}

.reason-box-desc {
    color: #fff;
    font-size: 15px;
    line-height: 1.8;
    font-weight: normal;
}

.reason-box-note {
    color: #fff;
    font-size: 12px;
    margin-top: -15px;
    margin-bottom: 25px;
}

/* ボックス内 右側（画像エリア） */
.reason-box-img {
    width: 45%;
    max-width: 400px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.reason-box-img img {
    width: 100%;
    height: auto;
    object-fit: contain;
}

/* イラスト画像用 */
.reason-box-img.type-illustration {
    max-width: 450px;
}


@media (max-width: 1025px) {
    .reason-box {
        padding: 40px 30px;
    }
}


/* スマホ対応（レスポンシブ） */
@media (max-width: 767px) {
    #reason {
        padding: 50px 0 60px;
    }

    #reason .reason-title {
        margin-bottom: 15px;
    }

    .reason-subtitle {
        font-size: 14px;
        line-height: 1.6;
        margin-bottom: 35px;
    }

    .reason-container {
        gap: 30px;
    }

    .reason-box {
        flex-direction: column;
        padding: 35px 25px;
        align-items: flex-start;
    }
  
    .reason-box-wrap{
        max-width: 450px;
        width: 100%;
        margin: 0 auto;
        flex-direction: column;
        gap: 30px;
        align-items: flex-start;
    }

    .reason-box-ttl-img {
        max-width: 100%;
        margin-bottom: 20px;
    }

    .reason-box-subhd {
        font-size: 18px;
        line-height: 1.5;
    }

    .reason-box-desc {
        font-size: 14px;
        line-height: 1.7;
    }

    .reason-box-note {
        margin-top: -10px;
        margin-bottom: 20px;
    }

    .reason-box-img {
        width: 100%;
        max-width: none;
    }
    
    .reason-box-img.type-illustration {
        max-width: 100%;
    }
}

.novelty-top #point {
  padding: 63px 0 0;
}

.novelty-top #point .point-content {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  gap: 40px;
}

@media (max-width: 767px) {
  .novelty-top #point {
    padding: 30px 0 0;
  }
}


/* おすすめノベルティ セクション全体 */
#commodity-list {
    background-color: #4d4d4d;
    color: #fff;
    padding: 80px 0;
    font-family: "Open Sans", YakuHanJP, "Noto Sans JP", sans-serif;
}

#commodity-list .commodity-list-title {
    color: #fff;
    font-size: clamp(34px, 6.5vw, 50px);
    font-weight: 800;
    margin-bottom: 20px;
}

#commodity-list .commodity-list-subtitle {
    color: #fff;
    font-size: 18px;
    margin-top: 10px;
    margin-bottom: 40px;
}

/* 上部 バナーGrid */
.commodity-list-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 25px;
    margin-bottom: 80px;
}

.commodity-grid-item {
    display: flex;
    flex-direction: column;
    border-radius: 10px;
    padding: 30px;
    text-decoration: none;
    transition: opacity 0.3s !important;
    position: relative;
    height: 100%;
    min-height: 380px;
    overflow: hidden;
    background-size: cover;
    background-position: center right;
    background-repeat: no-repeat;
}

@media (hover: hover) {
    .commodity-grid-item:hover {
        opacity: 0.7 !important;
    }
}

/* ★各バナーの背景画像設定（適宜パスを調整してください） */
.commodity-grid-item.woodtee {
    background-image: url(../img/novelty-merge-top/commodity-list-bg-woodtee.jpg); 
    background-color: #009378; /* 画像がない場合の仮色 */
    color: #fff;
}
.commodity-grid-item.marker {
    background-image: url(../img/novelty-merge-top/commodity-list-bg-marker.jpg); 
    background-color: #f2f0eb;
    color: #000;
}
.commodity-grid-item.cap {
    background-image: url(../img/novelty-merge-top/commodity-list-bg-cap.jpg); 
    background-color: #008781;
    color: #fff;
}
.commodity-grid-item.bagtag {
    background-image: url(../img/novelty-merge-top/commodity-list-bg-bagtag.jpg);
    background-color: #222222;
    color: #fff;
    border: 1px solid #444;
    background-position-y: 70%;
}

/* 丸いバッジ（キャップ用） */
.commodity-badge-circle {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 90px;
    height: 90px;
    background-color: #00b8c0;
    color: #fff;
    border-radius: 50%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: bold;
    line-height: 1.2;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
    z-index: 10;
}
.commodity-badge-circle span {
    color: #ffff00;
    font-size: 18px;
}

/* バナー内 情報エリア */
.commodity-item-info {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    height: 100%;
}

.commodity-store-name {
    font-size: 13px;
    font-weight: bold;
    text-decoration: underline;
    margin-bottom: 15px;
}

.commodity-title-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
}

.commodity-prefix {
    font-size: 22px;
    font-weight: 900;
}

.commodity-tag {
    background-color: #002244;
    color: #fff;
    font-size: 13px;
    font-weight: bold;
    padding: 4px 9px;
    border-radius: 18px;
}
.commodity-tag.line {
    background-color: transparent;
    border: 1px solid #fff;
}

.commodity-name {
    font-size: 38px;
    font-weight: 900;
    color: #d3ff02;
    line-height: 1.2;
    margin-bottom: 15px;
    letter-spacing: -0.02em;
}
.commodity-grid-item.marker .commodity-name {
    color: #88ca1f;
}

.commodity-catch {
    font-size: 15px;
    font-weight: bold;
    color: #d3ff02;
    margin-bottom: 15px;
}

.commodity-desc {
    font-size: 15px;
    font-weight: 500;
    line-height: 1.6;
    margin-bottom: 20px;
}

.commodity-grid-item.bagtag .commodity-img {
    width: 200px;
    margin-bottom: 20px;
}

.commodity-grid-item.bagtag .commodity-img img {
    width: 100%;
    height: auto;
    object-fit: cover;
}




/* 価格エリア */
.commodity-price-area {
    margin-bottom: 5px;
    margin-top: auto;
}
.commodity-price-area.inline {
    display: flex;
    align-items: baseline;
    gap: 5px;
}

.commodity-price-unit {
    font-size: 18px;
    font-weight: bold;
    margin-bottom: -5px;
}

.commodity-price-main {
    display: flex;
    align-items: flex-end;
}

.commodity-price-main .price-num {
    font-size: 55px;
    font-weight: bold;
    font-family: "Open Sans", sans-serif;
    line-height: 1;
    color: #d3ff02;
}

.commodity-grid-item.marker .commodity-price-main .price-num{
    color: #88ca1f;
}

.price-sub {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    margin-left: 2px;
}

.price-sub .tax {
    font-size: 12px;
    line-height: 1;
    margin-bottom: 5px;
}

.price-sub .yen {
    font-size: 20px;
    font-weight: bold;
    line-height: 1;
}

.commodity-price-note {
    font-size: 13px;
    margin-bottom: 15px;
}

/* ボタン */
.commodity-btn {
    display: inline-block;
    background-color: #fff;
    color: #000;
    font-size: 14px;
    font-weight: bold;
    padding: 12px 25px;
    border-radius: 50px;
    margin-top: auto; /* 下揃え維持 */
}
.commodity-grid-item.woodtee .commodity-btn,
.commodity-grid-item.marker .commodity-btn,
.commodity-grid-item.cap .commodity-btn {
    background-color: #000;
    color: #fff;
}

.commodity-btn::after {
    content: "▶";
    font-size: 9px;
    margin-left: 8px;
    vertical-align: middle;
}

/* スマホ対応 */
@media (max-width: 767px) {
    #commodity-list .commodity-list-subtitle {
        font-size: 14px;
        margin-top: 0;
    }
    .commodity-list-grid {
        grid-template-columns: 1fr;
    }
    
    .commodity-grid-item {
        padding: 25px 20px;
        min-height: 320px;
    }
    
    .commodity-name {
        font-size: 30px;
        margin-bottom: 5px;
    }
    .commodity-desc{
      margin-bottom: 10px;
    }
    .commodity-price-main .price-num {
        font-size: 40px;
    }
    .commodity-badge-circle {
        top: 10px;
        right: 10px;
        width: 70px;
        height: 70px;
        font-size: 12px;
    }
    .commodity-badge-circle span {
        font-size: 18px;
    }
    .commodity-grid-item.bagtag .commodity-img {
        width: 150px;
    }
    .price-sub .tax{
      font-size: 10px;
      margin-bottom: 2px;
    }
    .price-sub .yen{
      margin-bottom: 3px;
    }
}

/* 下部 アイコンリスト */
.commodity-other-wrap {
}

.commodity-other-title {
    color: #fff;
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 40px;
    text-align: left;
}

.commodity-icon-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(133px, 1fr));
    gap: 30px 20px;
    margin-bottom: 50px;
}

.commodity-icon-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-decoration: none;
    color: #fff;
    transition: opacity 0.3s;
}

.commodity-icon-item:hover {
    opacity: 0.7;
}

.commodity-icon-circle {
    width: 120px;
    height: 120px;
    background-color: #fff;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 12px;
    overflow: hidden;
}

.commodity-icon-circle img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.commodity-icon-item p {
    text-align: center;
    font-size: 15px;
    line-height: 1.4;
    font-weight: normal;
}

/* スマホ対応 */
@media (max-width: 767px) {
    #commodity-list {
        padding: 50px 0;
    }
    
    .commodity-list-grid {
        grid-template-columns: 1fr;
        gap: 15px;
    }
    
    .commodity-grid-item {
        padding: 25px 20px;
        min-height: 220px;
    }
    
    .commodity-desc {
        font-size: 13px;
    }
    
    .commodity-item-img {
        width: 40%;
        max-width: 150px;
        position: absolute;
        right: -10px;
        bottom: 10px;
    }
    
    .commodity-other-title {
        font-size: 16px;
        line-height: 1.6;
    }
    
    .commodity-icon-list {
        grid-template-columns: repeat(4, 1fr);
        gap: 20px 10px;
    }
    
    .commodity-icon-circle {
        width: 90px;
        height: 90px;
    }
    
    .commodity-icon-item p {
        font-size: 13px;
    }
}

@media (max-width: 425px) {
    .commodity-icon-list {
        grid-template-columns: repeat(3, 1fr);
    }
}


.novelty-top .novelty-top-bnr {
  background: #1c3435;
  padding: 73px 0 114px;
}

@media (max-width: 767px) {
  .novelty-top .novelty-top-bnr {
    padding: 40px 0 32px;
  }
}
@media (hover: hover) {
  .novelty-top .novelty-top-bnr #brand-novelty-bnr {
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
  }
  .novelty-top .novelty-top-bnr #brand-novelty-bnr:hover {
    opacity: 0.6;
  }
}

/* お客様の声 セクション全体 */
#production-example {
    padding: 40px 0 80px;
    background-color: #000000;
}

#production-example .wrap {
  padding: 0 20px;
}

#production-example .overflow-right__sliderWrap {
    padding-left: 0;
}

#production-example .production-example-title {
    color: #fff;
    font-size: clamp(34px, 6.5vw, 50px);
    font-weight: 800;
    line-height: 1.5em;
    font-family: YakuHanJP, "Noto Sans JP", sans-serif;
    margin-bottom: 40px;
    letter-spacing: 0;
}

#production-example .pagination{
  color: #fff;
  display: none;
}

/* ★ロゴが左・上にはみ出るため、スライダー全体に余白を持たせて見切れを防ぐ */
#example-slider .splide__list {
    padding-top: 30px;
    padding-left: 30px;
}

/* カードのラッパー（はみ出し配置の基準点） */
.voice-card-wrapper {
    position: relative;
    height: 100%;
}

/* 企業ロゴ（カードの左上に浮かせて配置） */
.voice-company-logo {
    position: absolute;
    top: -25px;
    left: -25px;
    width: 120px;
    height: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    padding: 0; /* アイコンの余白はなし */
}

.voice-company-logo img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

/* カード本体 */
.voice-card {
    font-family: YakuHanJP, "Noto Sans JP", sans-serif;
    background: #fff;
    border-radius: 10px;
    padding: 45px 25px 30px; /* 上部はロゴが被るので少し広めに空ける */
    height: 100%;
    display: flex;
    flex-direction: column;
}

/* 商品画像（上部） */
.voice-product-img {
    width: 100%;
    margin-bottom: 25px;
}

.voice-product-img img {
    width: 100%;
    height: auto;
    object-fit: cover;
}

/* 企業名・コメント（下部） */
.voice-card-body {
    flex-grow: 1;
}

.voice-company-name {
    font-size: 19px;
    font-weight: 800;
    color: #000;
    line-height: 1.5;
    margin-bottom: 15px;
}

.voice-text {
    font-size: 15px;
    line-height: 1.8;
    color: #000;
    margin-bottom: 0;
    text-align: justify;
}

#example-slider .splide__slide {
    padding: 30px 25px 0 25px;
    margin-left: 5px;
    border: none;
}

#example-slider .splide__slide.is-active {
}

/* スマホ対応 */
@media (max-width: 1025px) {
    #example-slider .splide__list {
        padding-top: 25px;
        padding-left: 20px;
    }
    #example-slider .splide__slide {
      padding: 20px 20px 0 20px;
      margin-left: 4.25px;
    }
    .voice-company-logo {
        width: 90px;
        height: 90px;
        top: -25px;
        left: -25px;
    }
    .voice-card {
        padding: 35px 20px 20px;
    }
    .voice-company-name {
        font-size: 17px;
    }
    .voice-text {
        font-size: 14px;
    }
}
@media (max-width: 768px) {
    #production-example .production-example-title{
      margin-bottom: 20px;
    }
}
@media (max-width: 425px) {
    #example-slider .splide__slide {
      padding: 20px 30px 0 30px;
      margin-left: 4.25px;
    }
    .voice-company-logo {
        top: -20px;
        left: -20px;
    }
}


.novelty-top #support-results {
  padding: 68px 0 116px;
  background: #1c3435;
}

@media (max-width: 767px) {
  .novelty-top #support-results {
    padding: 35px 0 38px;
  }
}
.novelty-top #faq {
  padding: 73px 0 150px;
}

.novelty-top #faq .faq-q {
  cursor: pointer;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.novelty-top #faq .faq-a-icon-span {
  margin-top: 0;
}

@media (max-width: 767px) {
  .novelty-top #faq {
    padding: 35px 0 35px;
  }
  .novelty-top #faq .faq-q-icon-span {
    margin-top: 0;
  }
  .novelty-top #faq .faq-q {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
  }
}
.novelty-top .novelty-top-contact-area #contact-area {
  margin-top: -38px;
}

.novelty-top .novelty-top-contact-area .contact-area-btn {
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

@media (hover: hover) {
  .novelty-top .novelty-top-contact-area #contact-area .contact-area-btn:hover {
    background: #86c927;
    color: #fff;
  }
}
@media (max-width: 767px) {
  .novelty-top .novelty-top-contact-area {
    background: #1c3435;
    padding-bottom: 38px;
  }
  .novelty-top .novelty-top-contact-area #contact-area {
    margin-top: 0px;
  }
}
.novelty-top .novelty-top-contact-area.second {
  background-color: #dedde1;
}

.novelty-top .novelty-top-contact-area.second #contact-area {
  margin-top: -106px;
  margin-bottom: -76px;
  z-index: 1;
  position: relative;
}

@media (max-width: 767px) {
  .novelty-top .novelty-top-contact-area.second {
    background-color: #1c3435;
    padding-top: 35px;
  }
  .novelty-top .novelty-top-contact-area.second #contact-area {
    margin: 0;
  }
}
.novelty-top .scroll_up {
  -webkit-transition: 0.6s ease-in-out;
  transition: 0.6s ease-in-out;
  -webkit-transform: translateY(30px);
  transform: translateY(30px);
  opacity: 0;
}

.novelty-top .scroll_up.second, .novelty-top .scroll_up.sp-second {
  -webkit-transform: translateY(60px);
  transform: translateY(60px);
}

.novelty-top .scroll_up.third {
  -webkit-transform: translateY(90px);
  transform: translateY(90px);
}

.novelty-top .scroll_up.four {
  -webkit-transform: translateY(120px);
  transform: translateY(120px);
}

.novelty-top .scroll_up.on {
  -webkit-transform: translateY(0);
  transform: translateY(0);
  opacity: 1;
}

@media (max-width: 767px) {
  .novelty-top .scroll_up.second {
    -webkit-transform: translateY(30px);
    transform: translateY(30px);
  }
  .novelty-top .scroll_up.third {
    -webkit-transform: translateY(30px);
    transform: translateY(30px);
  }
  .novelty-top .scroll_up.four {
    -webkit-transform: translateY(30px);
    transform: translateY(30px);
  }
  .novelty-top .scroll_up.on {
    -webkit-transform: translateY(0);
    transform: translateY(0);
    opacity: 1;
  }
}
@media (max-width: 767px) {
  footer {
    margin-bottom: 58px;
  }
}


/* -------------------------------------------
   コンバージョンエリア
------------------------------------------- */

.novelty-top .novelty-top-conversion {
  background: url(../img/novelty-merge-top/conversion-bg.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  background-color: #000000;
  padding: 150px 0 150px;
}

.novelty-top .novelty-top-conversion-wrap-ttl {
  color: #ffffff;
  text-align: center;
  font-size: clamp(29px, 5.75vw, 50px);
  line-height: 1.5em;
  font-weight: 800;
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-feature-settings: "palt";
}

.novelty-top .novelty-top-conversion #contact-area{
  margin-top: clamp(30px, 4.6vw, 40px);
}

@media (max-width: 767px) {
  .novelty-top .novelty-top-conversion {
    background-position: center -67vw;
    padding: 120px 0 120px;
  }
}


/* -------------------------------------------
   展示会エリア
------------------------------------------- */

.novelty-top .novelty-top-exhibition {
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
	background: #4d4d4d;
}

.novelty-top .novelty-top-exhibition.show-exhibition {
  padding-top: 40px;
  padding-bottom: 40px;
}

.novelty-top .novelty-top-exhibition-wrap-ttl {
  color: #fff;
  font-size: clamp(34px, 6.5vw, 50px);
  font-weight: 800;
  line-height: 1.5em;
}

.novelty-top .novelty-top-exhibition-wrap-txt {
  color: #fff;
  font-size: 22px;
  font-weight: bold;
  margin-top: 10px;
  margin-bottom: 40px;
}

@media (max-width: 767px) {
  .novelty-top .novelty-top-exhibition-wrap-txt {
    font-size: 14px;
  }
}

/* -------------------------------------------
   セクション全体
------------------------------------------- */
#exhibition-section {
    background: #2b2c2c;
    color: #fff;
    padding: 0;
    margin-bottom: 50px;
    font-family: "Noto Sans JP", sans-serif;
	font-feature-settings: "palt";
    overflow: hidden;
    border-radius: 10px;
    border: 1px solid #808080;
    position: relative;
    z-index: 3;
    transition: z-index 0.1s;
}
#heading-area.hide-exhibition #exhibition-section {
    margin-top: 0px;
    margin-bottom: 0px;
}
#exhibition-section.is-modal-active { z-index: 2000; }

/* ヘッダー・スライダー */
.ex-header-area { padding-bottom: 20px; text-align: left; }
.ex-date { font-family: "Open Sans", "Noto Sans JP", sans-serif; font-size: 16px; font-weight: bold; color: #d4ae70; margin-bottom: 10px; letter-spacing: 0.05em; }
.ex-title-row { display: flex; justify-content: flex-start; align-items: center; gap: 15px; flex-wrap: wrap; }
.ex-badge { background: #fff; color: #2b2c2c; padding: 4px 12px; font-size: 14px; font-weight: bold; border-radius: 4px; white-space: nowrap; }
.ex-title { font-size: 28px; font-weight: 800; line-height: 1.3; margin: 0; color: #fff; }

.ex-container-fluid { width: 100%; }
.ex-content-wrapper { max-width: 1000px; margin: 0 auto; padding: 30px 20px; }
.ex-slider-wrapper { width: 100%; padding: 0; margin-bottom: 0; }
.ex-slider img { width: 100%; height: 350px; object-fit: cover; display: block; }
.ex-slide-btn { padding: 0; border: none; background: none; width: 100%; cursor: pointer; display: block; }

/* 説明文・フッター */
.ex-body-area { padding-top: 30px; }
.ex-description { font-size: 15px; line-height: 2; white-space: pre-wrap; text-align: left; }

.ex-footer {
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: 20px;
    background: rgba(255, 255, 255, 0.05); padding: 25px 30px;
    border-radius: 10px; border: 1px solid rgba(255, 255, 255, 0.1);
	margin-top: 20px;
}

.ex-booth-text {
    display: flex; align-items: center; gap: 10px;
    font-weight: bold; font-size: 16px;
}
.ex-arrow-icon {
    display: inline-block; width: 8px; height: 8px;
    border-top: 2px solid #fff; border-right: 2px solid #fff;
    transform: rotate(45deg); margin: 0 5px;
}
.booth-num { font-size: 20px; color: #fff; font-family: "Open Sans", sans-serif; }

.ex-footer-buttons { display: flex; align-items: center; gap: 15px; flex-wrap: wrap; }

.ex-map-btn {
    background: #d4ae70; color: #000; border: none; padding: 12px 30px;
    border-radius: 50px; cursor: pointer; font-weight: bold; font-size: 14px;
    transition: all 0.3s; line-height: 1;
}
.ex-map-btn:hover { background: #997438; }

.ex-site-link {
    display: inline-block; background: #fff; color: #152728; border: none;
    padding: 12px 30px; border-radius: 50px; font-weight: bold;
    text-decoration: none; transition: all 0.3s; font-size: 14px; line-height: 1;
}
.ex-site-link:hover { background: #e6e6e6; color: #000; }

/* モーダル */
.ex-modal-overlay {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(0, 0, 0, 0.9); z-index: 9999;
    display: flex; justify-content: center; align-items: center;
    opacity: 0; visibility: hidden; transition: all 0.3s ease; padding: 0;
}
.ex-modal-overlay.is-open { opacity: 1; visibility: visible; }
.ex-modal-content {
    background: transparent; width: 100%; height: 100%;
    display: flex; flex-direction: column; position: relative;
}

.ex-modal-header {
    position: absolute; top: 0; left: 0; width: 100%;
    display: flex; justify-content: space-between; align-items: center;
    padding: 15px 20px; background: rgba(0, 0, 0, 0.6); z-index: 100;
}

.ex-zoom-controls { display: flex; align-items: center; gap: 8px; }
.ex-divider { width: 1px; height: 20px; background: rgba(255,255,255,0.3); margin: 0 4px; }

/* アイコンボタン共通 */
.ex-zoom-btn, .ex-modal-close, .ex-reset-btn {
    width: 36px; height: 36px;
    background: rgba(255, 255, 255, 0.2);
    border: 1px solid rgba(255, 255, 255, 0.5);
    border-radius: 4px; cursor: pointer; color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-size: 20px; transition: background 0.2s; padding: 0;
}
.ex-zoom-btn:hover, .ex-modal-close:hover, .ex-reset-btn:hover { background: rgba(255, 255, 255, 0.4); }

/* 印刷ボタン */
.ex-print-btn {
    height: 36px;
    padding: 0 10px;
    background: #d4ae70;
    border: none; border-radius: 4px; color: #000;
    font-weight: bold; font-size: 13px; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: opacity 0.3s;
	margin-right: 7px;
}
.ex-print-btn:hover { opacity: 0.8; }

.ex-zoom-level { font-family: "Open Sans", "Noto Sans JP", sans-serif; font-size: 14px; font-weight: 500; min-width: 45px; text-align: center; color: #fff; }

.ex-modal-body {
    flex: 1; width: 100%; height: 100%; overflow: hidden;
    background: rgba(0, 0, 0, 0.75); display: flex; justify-content: center; align-items: center;
    cursor: grab; position: relative;
}
.ex-modal-body:active { cursor: grabbing; }

.ex-image-container {
    display: flex; justify-content: center; align-items: center;
    width: 100%; height: 100%;
    transform-origin: center center;
    transition: transform 0.1s linear; 
    will-change: transform, opacity;
}

#ex-modal-image {
    max-width: 100%; max-height: 100%; object-fit: contain;
    user-select: none; -webkit-user-drag: none; touch-action: none;
}

.anim-slide-out-left { transition: transform 0.3s ease, opacity 0.3s ease; transform: translateX(-50px) !important; opacity: 0; }
.anim-slide-out-right { transition: transform 0.3s ease, opacity 0.3s ease; transform: translateX(50px) !important; opacity: 0; }
.anim-slide-in-left { animation: slideInLeft 0.3s ease forwards; }
.anim-slide-in-right { animation: slideInRight 0.3s ease forwards; }
@keyframes slideInLeft { from { transform: translateX(-50px); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
@keyframes slideInRight { from { transform: translateX(50px); opacity: 0; } to { transform: translateX(0); opacity: 1; } }

.ex-nav-btn {
    position: absolute; top: 50%; transform: translateY(-50%);
    width: 50px; height: 80px; background: rgba(0,0,0,0.3); color: #fff;
    border: none; font-size: 24px; cursor: pointer; z-index: 50; display: none;
    align-items: center; justify-content: center; transition: background 0.3s;
}
.ex-nav-btn:hover { background: rgba(0,0,0,0.6); }
.ex-prev { left: 0; }
.ex-next { right: 0; }

@media (max-width: 767px) {
    #exhibition-section { margin-top: 40px; }
    .ex-title { font-size: 24px; }
    .ex-slider img { height: 200px; }
    .ex-footer { flex-direction: column; text-align: center; }
    .ex-booth-text { flex-direction: column; gap: 5px; }
    .ex-arrow-icon { transform: rotate(135deg); margin: 5px 0; }
    .ex-footer-buttons { width: 100%; flex-direction: column; gap: 10px; }
    .ex-map-btn, .ex-site-link { width: 100%; box-sizing: border-box; }
}

/* 印刷時は不要要素を隠すだけ（JSで別窓を開くため、スタイルは最小限でOK） */
@media print {
    .ex-modal-header, .ex-nav-btn, .ex-footer, header, footer { display: none !important; }
}

/* ===================================================
   導入実績エリア（メインビジュアル直下）
=================================================== */
.new-achievement-logo-area {
  background: #fff;
  position: relative;
  z-index: 2;
  padding: 30px 0; /* 余白を少し広めに調整 */
}

.new-achievement-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 25px;
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
}

.new-achievement-title {
  font-size: clamp(17px, 2.4vw, 26px);
  font-weight: 800;
  color: #000;
}

.new-achievement-btn {
  background-color: #d4ae70;
  padding: 12px 25px;
  border-radius: 50px;
  border: none;
  cursor: pointer;
  transition: all 0.3s;
}

.new-achievement-btn:hover {
  background-color: #b5925a;
}

.new-achievement-btn-txt {
  color: #000;
  font-size: 15px;
  font-weight: bold;
  white-space: nowrap;
}

.new-achievement-btn-txt .dounyuu{
  display: inline-block;
}

.new-achievement-btn-txt::after {
  content: "";
  display: inline-block;
  width: 6px;
  height: 5px;
  background: #000000;
  -webkit-clip-path: polygon(0 0, 0 100%, 100% 50%);
          clip-path: polygon(0 0, 0 100%, 100% 50%);
  margin-left: 5px;
  margin-bottom: 3px;
}

/* 導入実績 モーダル */
.achievement-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.9);
    z-index: 10000;
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
}

.achievement-modal-overlay.is-open {
    opacity: 1;
    visibility: visible;
}

.achievement-modal-content {
    background: #fff;
    width: 90%;
    max-width: 1000px;
    border-radius: 10px;
    padding: 60px 40px;
    position: relative;
    max-height: 90vh;
    overflow-y: auto;
    font-family: YakuHanJP, "Noto Sans JP", sans-serif;
}

.achievement-modal-body {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.achievement-modal-title {
    font-size: clamp(23px, 2.8vw, 28px);
    font-weight: 800;
    margin-bottom: 40px;
    text-align: center;
}

.achievement-modal-logos {
    width: 100%;
    margin-bottom: 30px;
}

.achievement-modal-logos img {
    width: 100%;
    height: auto;
}

.achievement-modal-note {
    font-size: 14px;
    font-weight: 500;
    margin-bottom: 40px;
}

.achievement-modal-close {
    background-color: #000;
    color: #fff;
    font-size: 16px;
    font-weight: bold;
    padding: 15px 50px;
    border-radius: 50px;
    border: none;
    cursor: pointer;
    transition: opacity 0.3s;
}

.achievement-modal-close:hover {
    opacity: 0.7;
}

/* スマホ対応 */
@media (max-width: 767px) {
  .new-achievement-logo-area {
    padding: 25px 0;
  }
  .new-achievement-header {
    gap: 0px;
    margin-bottom: 20px;
  }
  .new-achievement-title {
    font-size: clamp(13px, 3.5vw, 24px);
  }
  .new-achievement-btn {
    padding: 12px clamp(14px, 2.7vw, 20px);
    align-self: center;
  }
  .new-achievement-btn-txt {
    font-size: 14px;
  }
  .new-achievement-btn-txt .dounyuu{
    display: none;
  }
  .achievement-modal-content {
    padding: 40px 20px;
  }
  .achievement-modal-title {
    font-size: clamp(16px, 3.7vw, 25px);
    margin-bottom: 25px;
    line-height: 1.5;
  }
  .achievement-modal-note {
    font-size: 12px;
    margin-bottom: 30px;
  }
}