.pic_notice {
  padding: 35px 80px;
  background-color: #efefef;
}

.pic_h1 {
  margin-bottom: 25px;
  font-size: 26px;
  line-height: calc(44 / 27);
  font-weight: 700;
}

.pic_h2 {
  margin-bottom: 5px;
  font-size: 15px;
  line-height: calc(22 / 13);
  font-weight: 700;
}

.pic_p {
  font-size: 13px;
  line-height: calc(22 / 13);
  font-weight: 400;
  margin-bottom: 15px;
}

.pic_p:last-of-type {
  margin-bottom: 0;
}

.pic_p-wrapper {
  position: relative;
  overflow: hidden;
  transition: max-height 0.25s ease;
  background-color: #efefef; /* 背景色に合わせる */
  margin-bottom: 15px;
}

/* 下部フェード */
.pic_p-wrapper::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 30px; /* フェードの高さ */
  background: linear-gradient(to bottom, rgba(239, 239, 239, 0) 0%, #efefef 100%);
  pointer-events: none;
  display: none;
}

/* フェード表示 */
.collapsed::after {
  display: block;
}

.toggle-btn {
  display: block !important;
  margin: auto;
  margin-top: 6px;
  padding: 4px 8px;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  border: none;
  border-radius: 3px;
  background-color: transparent;
}

.toggle-btn[aria-hidden="true"] {
  display: none !important;
}

.pic_free-text {
  text-align: center;
  margin-top: 85px;
  margin-bottom: 85px;
}

.pic_category-links {
  margin-top: 85px;
  margin-bottom: 85px;
}

.pic_category-label {
  margin-bottom: 5px;
  font-size: 16px;
  line-height: calc(22 / 16);
  font-weight: 700;
}

.pic_category-link {
  line-height: calc(25 / 13);
}

.pic_category-link > span {
  padding: 0 0.5em;
}

.pic_category-link > span:last-of-type {
  display: none;
}

.pic_category-link > a {
  font-size: 13px;
}

.pic_buttons {
  margin-top: 85px;
  margin-bottom: 85px;
  display: flex;
  justify-content: center;
  gap: 15px 25px;
}

.pic_buttons a.pic_btn {
  box-sizing: border-box;
  width: 225px;
  height: 60px;
  display: flex;
  justify-content: center;
  font-size: 16px;
  border: 1px solid #333;
  align-items: center;
  text-decoration: none;
}

.pic_snap-grid {
  width: 1035px;
  margin: auto;
  margin-top: 85px;
  margin-bottom: 85px;
  display: flex;
  justify-content: center;
  gap: 25px;
}

.pic_snap-grid .block_coord {
  width: 240px;
}

.pic_banner{
   margin: 0 auto;
   width: fit-content;
}

.pic_banner-links {
  margin-top: 85px;
  margin-bottom: 85px;
  display: flex;
  justify-content: center;
  gap: 35px;
}

.pic_banner-link {
  display: inline-block;
  height: 300px;
}

.pic_banner-link img {
  width: auto;
  height: 100%;
}

.pic_items {
  margin-top: 85px;
  margin-bottom: 85px;
}

.pic_items-title {
  margin-bottom: 25px;
  font-size: 26px;
  line-height: calc(32 / 32);
  font-weight: 700;
  text-align: center;
}

.pic_items-sub-title {
  display: block;
  margin-top: 10px;
  font-size: 13px;
  line-height: calc(12 / 12);
  font-weight: 700;
}

.pic_item-list.list_search-result {
  width: 1190px;
  display: flex;
  flex-wrap: wrap;
  margin: 0 auto;
  gap: 23px;
}

.pic_item-list.list_search-result .block_item {
  width: 280px;
  margin: 0;
}

.pic_item-list.list_search-result .block_item .search-result__item--photo img {
  width: 100%;
  height: auto;
}

.pic_items a.pic_item-btn {
  box-sizing: border-box;
  width: 225px;
  height: 60px;
  margin: auto;
  margin-top: 65px;
  display: flex;
  justify-content: center;
  font-size: 15px;
  border: 1px solid #333;
  background-color: #333;
  color: #fff;
  align-items: center;
  text-decoration: none;
}

.pic_blog {
  margin-top: 85px;
  margin-bottom: 85px;
}

.pic_blog-label {
  margin-bottom: 12px;
  font-size: 16px;
  line-height: calc(22 / 16);
  font-weight: 700;
}

.pic_blog-grid {
  display: flex;
  gap: 20px;
}

.pic_blog-grid .block_coord {
  width: 380px;
}

.pic_blog-grid .block_coord > a {
  width: 100%;
  display: flex;
  gap: 20px;
}

.pic_blog-grid .block_coord .photo_coord img {
  width: 160px;
  height: 160px;
}

.pic_blog-grid .block_coord .inner_wrap {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.pic_blog-grid .block_coord .txt_comment {
  margin: 0;
}

.pic_blog-grid .block_coord .wrap_description {
  padding: 0;
}

.pic_blog-grid .block_coord .wrap_description .txt_model-name {
  margin: 15px 0 0 10px;
}

.pic_blog-grid .block_coord .wrap_description .txt_model-photo {
  width: 50px;
  height: 50px;
  font-size: 13px;
}
