@charset "UTF-8";
.page_footer .flex .footer_right .footer_right_sub_in .footer_right_sub_in2 {
  width: 134px;
}
.page_footer .flex .footer_right .footer_right_sub_in .footer_right_sub_in2 .-collabo {
  margin-top: -65px;
}
.page_footer .flex .footer_right .footer_right_main_in {
  margin-bottom: 30px;
}
.page_footer .flex .footer_right .footer_right_sub_in .footer_right_sub_in2 ul {
  margin-bottom: 15px;
}
.page_header .header_right nav ul li.collabo a {
  border: 1px solid #000000;
  color: #000000;
  display: inline-block;
  padding: 4px 19px;
  line-height: 1.4;
  position: relative;
  top: -2px;
}
@media (min-width: 749px) {
    .page_header .header_right {
        width: 38rem;
    }
}

.sp_menu_in ul {
  margin-bottom: 20px;
}
.sp_menu .footer_right_sub_in .footer_right_sub_in2 {
  margin-bottom: 0;
}

.sp_menu_in .footer_right_sub_in2 .collabo a {
  border: 1px solid #000000;
  color: #000000;
  display: inline-block;
  padding: 7px 12px 6px;
  line-height: 1.0;
}
.sp_menu .sp_menu__header {
  display: flex;
  justify-content: space-between;
  margin-bottom: 12px;
}
@media (max-width: 749px) {
  .page_header {
    padding: 1.025rem 0 0 1.025rem;
  }
  .page_header .logo_green {
    width: 8.4rem;
  }
}
.page-head .lead_text {
  font-weight: normal;
  margin-top: 20px;
}

.sub_main_wrap .page_ttl.-collabo {
    height: 170px;
}


/* =========================================================
   コラボラボ 伝統工芸 ページ用スタイル
========================================================= */
.sub_main_wrap.collabo_main {
    background: url(../img/collabo/bg_pc.png) no-repeat center top;
    background-size: cover;
    height: 15rem;
}

/* --- 共通・レイアウト設定 --- */
.colab_page_inner {
    padding: 0 5%;
}
.sec_title {
    margin-bottom: 12px;
    position: relative;
    font-weight: bold;
}
/* --- ヒーローセクション --- */
#colab_hero {
    margin-bottom: 3rem;
}
.hero_visual {
    position: relative;
    width: 100%;
    /* 画像の高さなどは実寸に合わせて適宜調整してください */
}
.hero_visual img {
    width: 100%;
    height: auto;
    display: block;
}
.hero_title_box {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: rgba(255, 255, 255, 0.9);
    padding: 2rem 1rem;
    writing-mode: vertical-rl;
    text-orientation: upright;
    letter-spacing: 0.3em;
}
.hero_title_box h1 {
    display: flex;
    gap: 1rem;
    margin: 0;
}
.hero_text_area {
    text-align: center;
    padding: 4rem 5% 2rem;
    background-color: #f5f5f5; /* ヒーロー下の背景色（薄いグレー） */
}
.hero_text_area .catchcopy {
    margin-bottom: 2rem;
    line-height: 1.8;
}
.hero_text_area .lead_text {
    line-height: 2;
}
.page_ttl_sub {
    text-align: center;
    font-size: 1.125rem;
    font-weight: bold;
    letter-spacing: 0.02em;
    margin-bottom: 30px;
    padding-bottom: 12px;
    border-bottom: 1px solid #999999;
}

/* --- 理由セクション --- */
#colab_reason {
    margin-bottom: 45px;
}
#colab_works {
  margin-bottom: 45px;
}
#colab_service {
  margin-bottom: 45px;
}
#colab_flow {
  margin-bottom: 45px;
}
#colab_reason .sec_title::after {
    display: none; /* ここだけ下線なしのデザイン */
}

/* --- 事例セクション --- */
.works_list {
    display: flex;
    flex-direction: column;
    gap: 4rem;
    margin-bottom: 70px;
}
.work_item {
    position: relative;
    text-align: center;
    margin: 0 auto;
    width: 100%;
}
.work_item img {
    width: 100%;
    height: auto;
    display: block;
}
.work_item .caption {
    margin-top: 15px;
    text-align: left;
}
.work_item .caption.-right {
  margin-left: 75px;
}
/* カテゴリラベル（画像に重なる四角いブロック） */
.work_item .label {
    position: absolute;
    top: -20px;
    left: -20px;
    width: 120px;
    height: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: #fff;
    line-height: 1.4;
    z-index: 2;
}
.work_item .label.label_right {
    left: auto;
    right: -20px;
}
.label_fashion { background-color: #a87b78; }
.label_interior { background-color: #849071; }
.label_souvenir { background-color: #a87b78; }
.label_tableware { background-color: #849071; }

/* ボタン */
.btn_wrap {
    margin-top: 4rem;
}
.guide_btn {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    max-width: 300px;
    padding: 1.5rem;
    border: 1px solid #333;
    text-decoration: none;
    color: #333;
    position: relative;
    transition: all 0.3s ease;
}
.guide_btn span {
    position: absolute;
    right: 1.5rem;
}
.guide_btn:hover {
    background-color: #333;
    color: #fff;
}

/* --- サービスセクション --- */
.service_content .service_name {
}
.service_content {
  margin-bottom: ;
}
.service_content p {
}
.service_img {
  margin-top: 30px;
}
.service_img img {
  width: 100%;
  height: auto;
}

/* --- 製作の流れセクション --- */
.flow_list {
    margin-bottom: 1.5rem;
}
.flow_item {
    border: 1px solid #999;
    padding: 16px 0;
    display: flex;
    align-items: center;
    background-color: #fff;
    font-weight: bold;
}
.flow_item .step_num {
    margin-right: 1.4rem;
    text-align: center;
    width: 60px;
    border-right: 1px solid #999;
}
.flow_arrow {
    text-align: center;
    padding: 1rem 0;
    width: 6px;
    margin: 0 auto;
}
.flow_arrow img {
  width: 100%;
  height: auto;
}
.flow_note {
    font-size: 0.9em;
}

/* --- お問い合わせ先セクション --- */
.contact_info h4 {
    margin-bottom: 1rem;
}
.contact_info p {
    line-height: 1.8;
}

@media (min-width: 749px) {
  .u-device-sp {
    display: none;
  }
}
/* =========================================================
   レスポンシブ調整 (スマホ)
========================================================= */
@media (max-width: 749px) {
    .sub_main_wrap.collabo_main {
        background: url(../img/collabo/bg_sp.png) no-repeat center top;
        background-size: cover;
        height: 15rem;
    }

  .sub_main_wrap.collabo_main {
    height: 11rem;
  }
  .sub_main_wrap .page_ttl.-collabo {
    height: max-content;
  }
  .page-head h2 {
    font-weight: bold;
    font-size: 1.16rem;
    line-height: 1.5;
  }
  .u-device-sp {
    display: block;
  }
    #shop_list.-collabo .page-head {
      text-align: left;
    }
    #shop_list.-collabo .page-head .lead_text br {
      display: none;
    }

    .works_list {
        gap: 2rem;
    }
    .work_item .caption.-right {
      margin-left: 32px;
    }
    .sec_title {
      font-size: 1.05rem;
    }
    .hero_title_box {
        padding: 1.5rem 0.8rem;
    }
    .hero_title_box h1 {
        gap: 0.5rem;
    }

    .hero_text_area {
        padding: 3rem 5% 1.5rem;
    }

    .work_item {
        margin-top: 1rem; /* ラベルが見切れないように余白追加 */
    }
    .work_item .label {
        width: 90px;
        height: 90px;
        top: -15px;
        left: -10px;
    }
    .work_item .label.label_right {
        left: auto;
        right: -10px;
    }

    .flow_item {
        padding: 1rem;
    }
    .flow_item .step_num {
        margin-right: 1rem;
        padding-right: 1rem;
        width: 30px;
    }
}

@media (min-width: 749px) {
    .footer_center_wrap {
        display: flex;
        justify-content: space-between;
    }
    .sns_follow {
        width: 600px;
    }
    .craft_bnr {
        flex: 1;
        width: 140px;
        a {
            text-decoration: underline;
        }
    }
}