@charset "utf-8";

/* ==========================================================================
パーツ
========================================================================== */
.dc_w-003 section {
  padding-top: 80px;
}

@media screen and (max-width: 767px) {
  .dc_w-003 section {
    padding-top: 75px;
  }
}

/* ==========================================================================
section_01
========================================================================== */
.dc_w-003 #section_01 {
  padding-top: 60px;
}
.dc_w-003 #section_01 .tc_comp_anchorlinklist > .tc_dp_flex {
  padding: 56px 0 0;
}

@media screen and (max-width: 767px) {
  .dc_w-003 #section_01 {
    padding-top: 64px;
  }
  .dc_w-003 #section_01 .tc_section_heading_01 .tc_title {
    font-size: 30px;
  }
  .dc_w-003 #section_01 .tc_comp_anchorlinklist > .tc_dp_flex {
    grid-template-columns: 1fr;
    padding: 32px 0 0;
  }
}

/* ==========================================================================
section_02
========================================================================== */
.dc_w-003 #section_02 .section_02_00 .tc_section_img_01 {
  margin-top: 56px;
}

.dc_w-003 #section_02 .section_02_00 .tc_section_img_01 ~ .tc_section_title_03 {
  margin-top: 10px;
}

.dc_w-003 #section_02 .section_02_00 .tc_section_clm_04 {
  margin-top: 32px;
}
@media screen and (max-width: 767px) {
}

/* ==========================================================================
動的コンテンツ
========================================================================== */
.tc_ctm_dynamic_content .tc_section_heading03_01 {
  justify-content: space-between;
  padding: 30px 20px;
}
@media screen and (max-width: 767px) {
  .tc_ctm_dynamic_content .tc_section_heading03_01 {
    flex-direction: row;
    align-items: center;
    padding: 30px 0 12px;
  }
}

/* ==========================================================================
section_03
========================================================================== */
.dc_w-003 #section_03 .tc_section_clm_03 {
  gap: 45px 24px;
}
.dc_w-003 #section_03 .tc_section_clm_03 .tc_comp_clm_plus .tc_comp_all_clm:nth-child(2) {
  gap: 16px;
  margin-top: 8px;
}
.dc_w-003 #section_03 .tc_section_clm_03 .tc_comp_clm_plus .tc_comp_all_clm:nth-child(2) .tc_section_honbun_03 {
  margin-top: 0;
}
.dc_w-003 #section_03 .tc_section_clm_03 .tc_comp_clm_plus .tc_comp_all_clm:nth-child(2) .tc_comp_all_thum {
  flex: 0 0 114px;
  height: auto;
}
@media screen and (min-width: 768px) {
  .dc_w-003 #section_03 .tc_section_clm_03 .tc_comp_clm_plus {
    width: calc((100% - 48px) / 3);
  }
  .dc_w-003 #section_03 .tc_section_clm_03 .tc_comp_clm_plus .tc_comp_all_clm {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .dc_w-003 #section_03 .tc_section_clm_03 {
    gap: 55px;
  }
  .dc_w-003 #section_03 .tc_section_clm_03 .tc_comp_clm_plus .tc_comp_all_clm:nth-child(1) .tc_text {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 100%;
  }
  .dc_w-003 #section_03 .tc_section_clm_03 .tc_comp_clm_plus .tc_comp_all_clm:nth-child(2) {
    gap: 12px;
    margin-top: 12px;
  }
}

/* ==========================================================================
section_05
========================================================================== */
.dc_w-003 #section_05 .tc_ranking_img_wrap {
  max-width: 400px;
  margin: 0 auto;
}
.dc_w-003 #section_05 .tc_ranking_img_wrap a {
  display: block;
  transition: all 0.2s;
}
@media (any-hover: hover) {
  .dc_w-003 #section_05 .tc_ranking_img_wrap a:hover {
    opacity: 0.7;
  }
}
@media screen and (max-width: 767px) {
}
