@charset "utf-8";
#hero {
  width: 100%;
  height: auto;
}
.hero__inner {
  width: 90%;
  max-width: 1000px;
  height: auto;
  margin: 0 auto;
}
.hero__copy {
  width: 100%;
  height: auto;
  margin: 40px auto 62px;
  font-size: 60px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.1em;
  text-align: center;
}
.hero__copy span {
  color: var(--color--red);
  position: relative;
}
.hero__copy span::after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: var(--color--red);
  position: absolute;
  bottom: -10px;
  left: 0;
}
.hero__txt {
  width: 100%;
  height: auto;
  font-size: 16px;
  font-weight: 500;
  line-height: calc(38 / 16);
  letter-spacing: 0em;
  text-align: center;
}

#txtband {
  width: 100%;
  height: auto;
  padding: 60px 0 64px;
  overflow: hidden;
}
.txtband__inner {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
}
.txtband__image {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  width: auto;
  height: auto;
  animation: infinity-scroll-left 80s infinite linear 0.5s both;
}
.txtband__image img {
  width: calc((1283 / 1200) * 100vw);
}
@keyframes infinity-scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}

#message {
  width: 100%;
  height: auto;
  padding: 0 0 50x;
  overflow: hidden;
}
.message__inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  width: 90%;
  max-width: 1000px;
  height: auto;
  margin: 0 auto;
}
.message__contents {
  width: 61%;
  height: auto;
  padding: 55px 0 0;
}
.message__heading {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  height: auto;
  margin: 0 auto 28px;
}
.message__heading__txt {
  font-size: 24px;
  font-weight: 500;
  line-height: 1;
  position: relative;
}
.message__heading__txt::after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: var(--color--red);
  position: absolute;
  bottom: -11px;
  left: 0;
}
.message__txt {
  width: 100%;
  height: auto;
  font-size: 16px;
  font-weight: 500;
  line-height: calc(36 / 16);
}
.message__image {
  width: 38.6%;
  height: auto;
}
.message__image__ceo {
  width: 100%;
  height: auto;
  margin: 0 auto 22px;
  position: relative;
  z-index: 1;
}

.container_frame::after {
  border-top: solid 1px var(--color--black);
}
.message__image__name {
  width: 296.12px;
  height: auto;
  margin: 0 auto 0 0;
  position: relative;
  z-index: 2;
}

#philosophy {
  width: 100%;
  height: auto;
  padding: 20px;
  background-color: var(--color--red);
  color: var(--color--white);
  overflow: hidden;
}
.philosophy__container {
  width: 100%;
  height: auto;
  padding: 60px 0 94px;
  border-radius: 20px;
  background-color: var(--color--black);
}
.philosophy__inner {
  width: 90%;
  max-width: 820px;
  height: auto;
  margin: 0 auto;
  position: relative;
}
.philosophy__heading {
  width: 40px;
  height: auto;
  position: absolute;
  top: 12px;
  left: 0;
  transform: translate(-100%, 0%);
}
.philosophy__heading__txt {
  font-size: 24px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.2em;
  -webkit-writing-mode: vertical-rl;
  -moz-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  -ms-writing-mode: vertical-rl;
  writing-mode: vertical-rl;
  white-space: nowrap;
}
.philosophy__heading__txt::after {
  content: "";
  display: block;
  width: 1px;
  height: calc(100% - 0.2em);
  background-color: var(--color--red);
  position: absolute;
  top: 0;
  right: 0;
}
.philosophy__logomark {
  width: 130px;
  height: auto;
  margin: 0 auto 36px;
}
.philosophy__copy {
  width: 100%;
  height: auto;
  margin: 0 auto 16px;
  font-size: 38px;
  font-weight: 600;
  line-height: calc(60 / 38);
  letter-spacing: 0.2em;
  text-align: center;
}
.philosophy__txt {
  width: 100%;
  height: auto;
  margin: 0 auto 108px;
  font-size: 20px;
  font-weight: 500;
  line-height: 1;
  text-align: center;
}
.philosophy__policy {
  width: 100%;
  height: auto;
  margin: 0 auto 21px;
  font-size: 24px;
  font-weight: 500;
  line-height: 1;
  text-align: center;
}
.philosophy__policy_txt {
  width: 100%;
  height: auto;
  font-size: 35px;
  font-weight: 600;
  line-height: 1;
  text-align: center;
}

#profile {
  width: 100%;
  height: auto;
  padding: 85px 0 112px;
  background-image: url("../image/corporate/section-bg_image.webp");
  background-position: center;
  background-repeat: repeat-y;
  background-size: 100% auto;
}
.profile__inner {
  width: 90%;
  max-width: 840px;
  height: auto;
  margin: 0 auto;
}
.profile__heading {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: auto;
  margin: 0 auto 54px;
}
.profile__heading__txt {
  font-size: 24px;
  font-weight: 500;
  line-height: 1;
  color: var(--color--black);
  position: relative;
}
.profile__heading__txt::after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: var(--color--red);
  position: absolute;
  bottom: -11px;
  left: 0;
}
.profile__list {
  width: 100%;
  height: auto;
}
.profile__list__item {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  width: 100%;
  height: auto;
  padding: 16px 0;
  font-size: 16px;
  font-weight: 500;
  line-height: calc(36 / 16);
  color: var(--color--black);
}
.profile__list__item:not(:last-of-type) {
  border-bottom: dotted 1px var(--color--black);
}
.profile__list__item dt {
  width: 150px;
  height: auto;
}
.profile__list__item dd {
  flex: 1;
}
.profile__list__item dd.partner {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.profile__list__item dd p {
  font-size: 18px;
}
.profile__list__item dd p.small {
  font-size: 14px;
  font-weight: 500;
  line-height: 2;
  text-decoration: underline;
}
.profile__list__item dd p.small:not(:last-of-type) {
  margin-bottom: 20px;
}
.profile__list__item dd p.small:last-of-type {
  margin-bottom: 6px;
}
.profile__list__item dd.partner ul {
  width: 50%;
}

#chart {
  width: 100%;
  height: auto;
  padding: 10px 0;
  background: linear-gradient(135deg, #f2f2f2, #dcdcdc, #b0b0b0, #808080);
}
.chart__inner {
  width: 90%;
  max-width: 840px;
  height: auto;
  margin: 0 auto;
  position: relative;
}
.chart__heading {
  width: 40px;
  height: auto;
  position: absolute;
  top: 40px;
  left: 0;
}
.chart__heading__txt {
  color: var(--color--black);
  font-size: 24px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.2em;
  -webkit-writing-mode: vertical-rl;
  -moz-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  -ms-writing-mode: vertical-rl;
  writing-mode: vertical-rl;
  white-space: nowrap;
}
.chart__heading__txt::after {
  content: "";
  display: block;
  width: 1px;
  height: calc(100% - 0.2em);
  background-color: var(--color--red);
  position: absolute;
  top: 0;
  right: -5px;
}
.chart__image {
  width: 100%;
  height: auto;
  padding: 80px 0 0;
}

#achievements {
  width: 100%;
  height: auto;
  padding: 85px 0 112px;
  background-image: url("../image/corporate/section-bg_image.webp");
  background-position: center;
  background-repeat: repeat-y;
  background-size: 100% auto;
}
.achievements__inner {
  width: 90%;
  max-width: 840px;
  height: auto;
  margin: 0 auto;
}
.achievements__heading {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: auto;
  margin: 0 auto 54px;
}
.achievements__heading__txt {
  font-size: 24px;
  font-weight: 500;
  line-height: 1;
  color: var(--color--black);
  position: relative;
}
.achievements__heading__txt::after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: var(--color--red);
  position: absolute;
  bottom: -11px;
  left: 0;
}
.achievements__list {
  display: flex;
  flex-direction: column;
  row-gap: 5px;
  width: 100%;
  height: auto;
}
.achievements__list__head {
  position: relative;
  z-index: 2;
}
.achievements__list__head,
.achievements__list__body__item {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  column-gap: 5px;
  width: 100%;
  height: auto;
}
.achievements__list__head__cell,
.achievements__list__body__cell {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 56px;
  position: relative;
}
.achievements__list__head__cell {
  background-color: var(--color--black);
}
.achievements__list__body__cell {
  background-color: var(--color--white);
  padding: 14px 10px;
}
.achievements__list__head__cell:nth-of-type(1),
.achievements__list__body__cell:nth-of-type(1) {
  width: 192px;
}
.achievements__list__head__cell:nth-of-type(1) {
  z-index: 3;
}
.achievements__list__body__cell:nth-of-type(1) {
  background-color: #d1d1d1;
}
.achievements__list__head__cell:nth-of-type(2),
.achievements__list__body__cell:nth-of-type(2) {
  width: 162px;
}
.achievements__list__head__cell:nth-of-type(2) {
  z-index: 2;
}
.achievements__list__head__cell:nth-of-type(3),
.achievements__list__body__cell:nth-of-type(3) {
  flex: 1;
}
.achievements__list__head__cell:nth-of-type(3) {
  z-index: 1;
}
.achievements__list__body__cell:nth-of-type(3) {
  justify-content: flex-start;
  padding: 14px 20px;
}
.achievements__list__head__cell__txt {
  height: auto;
  color: var(--color--white);
}
.achievements__list__sort_btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 22px;
  height: 22px;
  padding: 1px 0 0;
  border-radius: 9999px;
  background-color: var(--color--white);
  position: absolute;
  top: 50%;
  right: 8px;
  transform: translate(0%, -50%);
  cursor: pointer;
}
.achievements__list__sort_btn svg {
  width: 7px;
  fill: var(--color--black);
}
.achievements__list__sort_btn._open svg {
  transform: scale(1, -1);
}
.achievements__sort_window {
  width: auto;
  min-width: 120px;
  height: auto;
  padding: 10px 14px;
  border-radius: 6px;
  background-color: #f2f2f2;
  box-shadow: 0px 0px 5px rgba(25, 25, 25, 0.3);
  position: absolute;
  top: 8px;
  left: 10px;
  z-index: 10;
  opacity: 0;
  pointer-events: none;
  transition: 0.3s;
}
.achievements__sort_window._active {
  top: 18px;
  opacity: 1;
  pointer-events: auto;
}
.achievements__sort_window__list {
  width: auto;
  height: auto;
}
.achievements__sort_window__list__item {
  width: auto;
  height: auto;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
  white-space: nowrap;
  color: var(--color--black);
  cursor: pointer;
}
.achievements__sort_window__list__item:not(:last-of-type) {
  margin-bottom: 3px;
}
.achievements__list__body {
  height: 500px;
  overflow-y: scroll;
  display: flex;
  flex-direction: column;
  row-gap: 5px;
  position: relative;
  z-index: 1;
}
.achievements__list__body__cell__txt {
  color: var(--color--black);
}

.technology__contents {
  width: 100%;
  height: auto;
  margin: 0 auto;
  padding: 0px 0 40px 0px;
  color: #000000;
  display: flex;
  flex-direction: row-reverse;
  justify-content: center;
  align-items: center;
  gap: 8%;
}

/* 六角形 */
.honeycomb-image-area {
  width: 50%;
  display: flex;
  justify-content: center;
}

.hexagon5__wrapper {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  --wrapper-width: 100%;
  width: 100%;
  margin-top: 20%;
  position: relative;
}
.hexagons {
  width: auto;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1px;
}
.hexagons-top {
}
.hexagons-center {
  margin-top: -51px;
}
.hexagons-bottom {
  margin-top: -51px;
}
.hexagon_item {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  max-width: 220px;
  width: 180px;
  aspect-ratio: 259.8 / 300;
  background-color: #000;
  clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
  background-size: cover;
  background-position: center;
  position: relative;
  z-index: 1;
}
@media (max-width: 768px) {
  .hexagon5__wrapper {
    --wrapper-width: 100%;
    font-size: 3vw;
  }
}
.hexagon_item a {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 20;
}
.hexagon_item:not(.hexagon_image04)::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  transition: 0.3s;
}
.hexagon_item:not(.hexagon_image04)::after {
  display: block;
  font-size: 20px;
  color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  white-space: nowrap;
  z-index: 11;
}
.hexagon_item:not(.hexagon_image04):hover::before {
  background-color: rgba(0, 0, 0, 0);
  transition: 0.3s;
  cursor: pointer;
}

.hexagon_item {
  opacity: 0;
  transform: translateX(30px);
  transition: opacity 1.3s, transform 1.3s;
}
.hexagon_item.hexagon-fadein {
  opacity: 1;
  transform: translateX(0);
}
.hexagon_image04 {
  opacity: 1 !important; /* 4番だけ常に表示 */
}

.hexagon_item_wrap {
  position: relative;
}
.hexagon_item_wrap .hexagon_item_label {
  color: var(--color--white);
  position: absolute;
  font-size: 10px;
  font-weight: 600;
  white-space: nowrap;
  line-height: 1.1;
  z-index: 10;
}

.hexagon_image01 {
  background-image: url("../image/index/hexagon_image01.jpg");
}
.hexagon_image01::after {
  content: "仮設工事";
}
.hexagon_item_wrap_01 .hexagon_item_label {
  top: 10px;
  left: -10px;
  transform: rotate(-30deg);
}
.hexagon_item_wrap_02 .hexagon_item_label {
  top: -8px;
  left: 96px;
  transform: rotate(30deg);
}
.hexagon_item_wrap_03 .hexagon_item_label {
  top: 12px;
  left: -11px;
  transform: rotate(-30deg);
}
.hexagon_item_wrap_05 .hexagon_item_label {
  top: -7px;
  left: 94px;
  transform: rotate(30deg);
}
.hexagon_item_wrap_06 .hexagon_item_label {
  bottom: 14px;
  left: -11px;
  transform: rotate(30deg);
}
.hexagon_item_wrap_07 .hexagon_item_label {
  bottom: -6px;
  right: 21px;
  transform: rotate(-30deg);
}

.hexagon_image02 {
  background-image: url("../image/index/hexagon_image02.jpg");
}
.hexagon_image02::after {
  content: "土工事";
}
.hexagon_image03 {
  background-image: url("../image/index/hexagon_image03.jpg");
}
.hexagon_image03::after {
  content: "コンクリート工事";
}
/* ロゴ */
.hexagon_image04 {
  background-image: url("../image/index/hexagon_image04.jpg?v=20250611");
}
.hexagon_image05 {
  background-image: url("../image/index/hexagon_image05.jpg");
}
.hexagon_image05::after {
  content: "リニューアル工事";
}
.hexagon_image06 {
  background-image: url("../image/index/hexagon_image06.jpg");
}
.hexagon_image06::after {
  content: "解体工事";
}
.hexagon_image07 {
  background-image: url("../image/index/hexagon_image07.jpg");
}
.hexagon_image07::after {
  content: "外構工事";
}

/* PC ================================================== */
@media all and (min-width: 1101px) {
}

@media all and (min-width: 769px) {
}

@media all and (max-width: 1100px) {
  /* hero */
  .hero__copy {
    margin: 0 auto 30px;
    font-size: 40px;
  }
}

/* Tablet ================================================== */
@media all and (max-width: 768px) {
  /* hero */
  .hero__inner {
    width: calc((344 / 390) * 100%);
  }
  .hero__copy {
    margin: 40px auto;
    font-size: 30px;
    line-height: 2.1;
  }
  .hero__txt {
    font-size: 14px;
    text-align: left;
  }

  #txtband {
    padding: 60px 0;
  }
  .txtband__image img {
    width: calc((797 / 390) * 100vw);
  }

  #message {
    padding: 30px 0 40px;
  }
  .message__inner {
    display: block;
    width: calc((344 / 390) * 100%);
  }
  .message__contents {
    width: 100%;
    padding: 0;
    margin: 0 auto 45px;
  }
  .message__heading__txt::after {
    bottom: -5px;
  }
  .message__txt {
    font-size: 13px;
    letter-spacing: 0.01em;
  }
  .message__image {
    width: 100%;
    height: auto;
  }
  .message__image__ceo {
    width: 100%;
    height: auto;
    aspect-ratio: 4 / 3;
    margin: 0 auto 16px;
  }
  .message__image__ceo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 0%;
  }
  .message__image__ceo::after {
    width: 100px;
    height: 42px;
  }
  .message__image__ceo::after {
    bottom: 13px;
    right: 14px;
  }
  .message__image__name {
    width: calc(296.12px * 0.75);
    margin: 0 0 0 auto;
  }

  #philosophy {
    padding: 26px 0;
  }
  .philosophy__container {
    width: calc((360 / 390) * 100%);
    padding: 50px 0 70px;
    margin: 0 auto;
    border-radius: 10px;
  }
  .philosophy__inner {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    width: 90%;
  }
  .philosophy__heading {
    display: block;
    width: initial;
    margin-bottom: 40px;
    position: initial;
    transform: initial;
  }
  .philosophy__heading__txt {
    letter-spacing: 0.08em;
    -webkit-writing-mode: initial;
    -moz-writing-mode: initial;
    -ms-writing-mode: initial;
    -ms-writing-mode: initial;
    writing-mode: initial;
    transform: translate(0%, 0%);
  }
  .philosophy__heading__txt::after {
    width: 100%;
    height: 1px;
    top: initial;
    bottom: -5px;
    right: 0;
  }
  .philosophy__logomark {
    width: 60px;
    margin: 0 auto 18px;
  }
  .philosophy__copy {
    margin: 0 auto 24px;
    font-size: 28px;
    letter-spacing: 0.1em;
  }
  .philosophy__txt {
    margin: 0 auto 80px;
    font-size: 16px;
    line-height: 1.5;
  }
  .philosophy__policy {
    margin: 0 auto 18px;
    font-size: 18px;
    line-height: 1.6;
  }
  .philosophy__policy_txt {
    font-size: 24px;
    line-height: 1.5;
  }

  #profile {
    padding: 80px 0;
  }
  .profile__inner {
    width: calc((344 / 390) * 100%);
  }
  .profile__heading {
    margin: 0 auto 30px;
  }
  .profile__heading__txt::after {
    bottom: -5px;
  }
  .profile__list__item {
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    padding: 12px 0;
    font-size: 14px;
  }
  .profile__list__item dt {
    width: 100%;
    height: auto;
    font-size: 16px;
    font-weight: 600;
  }
  .profile__list__item dd {
    flex: initial;
    width: 100%;
    padding-left: 14px;
  }
  .profile__list__item dd p {
    font-size: 16px;
  }
  .profile__list__item dd p.small {
    font-size: 12px;
  }
  .profile__list__item dd p.small:not(:last-of-type) {
    margin-bottom: 14px;
  }
  .profile__list__item dd p.small:last-of-type {
    margin-bottom: 4px;
  }

  #chart {
    padding: 50px 0 80px;
    overflow: hidden;
  }
  .chart__inner {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    width: 100%;
  }
  .chart__heading {
    display: block;
    width: initial;
    margin-bottom: 10px;
    position: initial;
    transform: initial;
  }
  .chart__heading__txt {
    letter-spacing: 0.08em;
    -webkit-writing-mode: initial;
    -moz-writing-mode: initial;
    -ms-writing-mode: initial;
    -ms-writing-mode: initial;
    writing-mode: initial;
    transform: translate(0%, 0%);
  }
  .chart__heading__txt::after {
    width: 100%;
    height: 1px;
    top: initial;
    bottom: -5px;
    right: 0;
  }
  .chart__image {
    max-width: 420px;
    padding: 0;
    margin: 0 auto;
  }

  /* technology */
  #technology {
    width: 100%;
    height: auto;
    background-color: var(--color--white);
    background-image: url("../image/index/technology_bg_sp.jpg");
    background-size: cover;
    background-position: top center;
    background-repeat: no-repeat;
  }
  .technology__inner {
    padding: 10px 10px 50px 10px;
  }
  .technology__heading__title {
    font-size: 54px;
  }
  .technology__contents {
    width: 100%;
    padding: 0;
    flex-direction: column-reverse;
  }
  .tech_text_area {
    width: 100%;
    padding: 0;
  }
  .technology__heading h2 {
    font-size: 20px;
  }
  .technology__text {
    font-size: 14px;
  }
  #technology .more_btn {
    justify-content: center;
    margin-top: 40px;
  }
  .technology__hexsagon {
    width: 100%;
    padding: 0;
    margin: 0px auto 0;
  }
  .honeycomb-image-area {
    width: 100%;
    padding: 0;
  }

  .hexagon_item {
    width: 120px;
  }

  .hexagons-center {
    margin-top: -33px;
  }
  .hexagons-bottom {
    margin-top: -33px;
  }
  .hexagon_item:not(.hexagon_image04)::after {
    font-size: 11px;
  }
  .hexagon_item_label {
    line-height: 1;
  }

  .hexagon_item_wrap_01 .hexagon_item_label {
    top: -3px;
    left: -10px;
  }
  .hexagon_item_wrap_02 .hexagon_item_label {
    top: 6px;
    left: 69px;
  }
  .hexagon_item_wrap_03 .hexagon_item_label {
    top: -7px;
    left: -4px;
  }
  .hexagon_item_wrap_05 .hexagon_item_label {
    top: -6px;
    left: 63px;
  }
  .hexagon_item_wrap_06 .hexagon_item_label {
    bottom: 1px;
    left: -10px;
  }
  .hexagon_item_wrap_07 .hexagon_item_label {
    bottom: -2px;
    right: 2px;
  }

  #achievements {
    padding: 60px 0 80px;
  }
  .achievements__inner {
    width: 92%;
  }
  .achievements__heading {
    margin: 0 auto 40px;
  }
  .achievements__heading__txt::after {
    bottom: -5px;
  }
  .achievements__list {
    row-gap: 2px;
  }
  .achievements__list__head,
  .achievements__list__body__item {
    column-gap: 2px;
  }
  .achievements__list__head__cell,
  .achievements__list__body__cell {
    min-height: 48px;
  }
  .achievements__list__body__cell {
    padding: 10px 6px;
  }
  .achievements__list__head__cell:nth-of-type(1),
  .achievements__list__body__cell:nth-of-type(1) {
    width: 86px;
  }
  .achievements__list__head__cell:nth-of-type(2),
  .achievements__list__body__cell:nth-of-type(2) {
    width: 80px;
  }
  .achievements__list__head__cell:nth-of-type(1),
  .achievements__list__head__cell:nth-of-type(2) {
    padding-right: 7px;
  }
  .achievements__list__body__cell:nth-of-type(3) {
    padding: 10px;
  }
  .achievements__list__head__cell__txt {
    height: auto;
    font-size: 12px;
    line-height: 1.4;
    text-align: center;
  }
  .achievements__list__sort_btn {
    width: 18px;
    height: 18px;
    border-radius: 0;
    top: 100%;
    right: 0;
    transform: translate(0%, -100%);
  }
  .achievements__sort_window {
    top: 6px;
  }
  .achievements__sort_window._active {
    top: 16px;
  }
  .achievements__sort_window__list__item {
    font-size: 12px;
  }
  .achievements__sort_window__list__item:not(:last-of-type) {
    margin-bottom: 2px;
  }
  .achievements__list__body {
    row-gap: 2px;
  }
  .achievements__list__body__cell__txt {
    font-size: 13px;
    color: var(--color--black);
  }
}

/* SP ================================================== */
@media all and (max-width: 575px) {
}
