@media screen and (max-width: 767px) {
  .breadcrumbs {
    margin-bottom: 40px;
  }
}


.heading-detail .heading__lead {
  margin-bottom: 16px;
  font-size: 1.6rem;
}

.heading-detail .list-label {
  margin-bottom: 8px;
}

.heading-detail .list-label .label {
  font-weight: normal;
}

.heading-detail .heading__ttl-Wrap {
  position: relative;
}

.heading-detail .heading__ttl {
  font-size: 2.4rem;
}

.heading-detail .heading__ttl h1 {
  line-height: 1.5;
}

.heading-detail .heading__ttl .heading__company {
  margin-top: 8px;
  padding-right: 85px;
  font-size: 1.8rem;
}

.heading-detail .heading__user {
  position: absolute;
  bottom: 2px;
  right: 0;
}

.heading-detail .heading__user .list-user {
  display: inline-flex;
}

.heading-detail .heading__user .list-user__item:nth-of-type(n+2) {
  margin-left: 8px;
}

label.user-favorite {
  display: block;
  width: 32px;
  height: 32px;
}

input.user-favorite__input {
  width: 32px;
  height: 32px;
  border: 1px solid var(--base);
  border-radius: 100vh;
  background-color: #FFF;
  background-image: url(../../img/common/icon/icon_favorite_off.svg);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 12px 12px;
  cursor: pointer;
}

input.user-favorite__input:checked {
  background-image: url(../../img/common/icon/icon_favorite_on.svg);
}

button.user-share {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border: 1px solid var(--base);
  border-radius: 100vh;
  background-color: #FFF;
}

button.user-share:hover,
input.user-favorite__input:hover,
input.user-favorite__input:checked {
  background-color: var(--hover);
}


.detail-summary {
  margin-top: 16px;
}

.detail-summary__grid {
  justify-content: space-between;
  margin-top: 0;
}

.detail-summary__grid .grid__item {
  margin-top: 0;
}

.detail-summary__table .table th,
.detail-summary__table .table td {
  font-size: 1.4rem;
}

.detail-summary__img img {
  width: 100%;
  height: auto;
}

.detail-summary__table .floor {
  display: flex;
  align-items: center;
}

.detail-summary__table .floor-detail {
  border-left: 1px solid #1A1A1A;
  padding: 0 8px;
}

.detail-summary__table .floor-detail:first-child {
  border-left: none;
  padding-left: 0;
}

@media screen and (max-width: 767px) {
  .detail-summary__grid .grid__item:nth-of-type(n+2) {
    margin-top: 32px;
  }
}


.chart {
  width: 100%;
  height: 100%;
  padding: 24px 48px;
  border: 1px solid #CCC;
}

.chart.chart1 {
  margin-top: 16px;
  padding: 6px 36px 24px;
}

.chart1__inner {
  display: flex;
  justify-content: space-between;
  flex-direction: row-reverse;
  align-items: center;
  width: 100%;
}

.chart1__scroll-x {
  width: 100%;
  max-width: 600px;
  overflow-x: visible;
}

.chart1__canvas {
  position: relative;
  width: 100%;
  max-width: 600px;
  height: 380px;
}

#chart1 {
  width: 600px !important;
  height: 100%;
  max-width: 100%;
  max-height: 380px;
  margin: 0 auto;
}

.chart1__legend {
  flex-shrink: 0;
  /* width: 80px; */
  margin-right: 16px;
  font-size: 1.2rem;
}

.chart1__legend-list {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  margin-top: -3px;
}

.chart1__legend-list li {
  position: relative;
  display: inline-flex;
  align-items: center;
  margin-top: 3px;
  padding-left: 28px;
}

.chart1__legend-list li::before {
  content: "";
  position: absolute;
  top: 3px;
  left: 0;
  display: block;
  width: 24px;
  height: 13px;
}

.chart2 {
  display: flex;
  align-items: center;
  justify-content: center;
}

.chart2__canvas {
  position: relative;
  width: 100%;
  max-width: 296px;
  height: 380px;
}

#chart2 {
  width: 100%;
  height: 100%;
  max-width: 296px;
  max-height: 380px;
}

@media screen and (max-width: 767px) {

  .chart,
  .chart.chart1 {
    padding: 0 16px 16px;
  }

  .chart1__inner {
    position: static;
    display: block;
    padding-right: 0;
  }

  .chart1__scroll-x {
    width: 100%;
    max-width: 100%;
    overflow-x: visible;
  }

  .chart1__canvas {
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
  }

  .chart1__legend {
    width: 100%;
    margin-left: 0;
  }

  .chart1__legend-list {
    flex-direction: row;
    padding-top: 16px;
    padding-left: 0;
  }

  .chart1__legend-list li {
    margin-right: 8px;
  }
}

@media screen and (max-width: 470px) {

  /* 調整 */
  .chart1__scroll-x {
    max-width: 100%;
    overflow-x: auto;
  }

  .chart1__canvas {
    width: 170%;
    max-width: 400px;
  }
}

.legend-kuutyou::before {
  background-color: var(--kuutyou);
}

.legend-kanki::before {
  background-color: var(--kanki);
}

.legend-syoumei::before {
  background-color: var(--syoumei);
}

.legend-kyuutou::before {
  background-color: var(--kyuutou);
}

.legend-syoukouki::before {
  background-color: var(--syoukouki);
}

.legend-others::before {
  background-color: var(--others);
}

.legend-kojene::before {
  background-color: var(--kojene);
}

.legend-saiene::before {
  background-color: var(--saiene);
}

.legend-saiene-off::before {
  background-color: var(--saiene-off);
}


.detail-performance__grid {
  justify-content: space-between;
  align-items: stretch;
  margin-top: -16px !important;
}

.detail-performance__chart {
  min-width: 310px;
  flex-shrink: 0;
}

@media screen and (max-width: 880px) {

  /* 調整 */
  .detail-performance__table {
    overflow-x: auto;
  }

  .detail-performance__table .table {
    width: 150%;
    max-width: 600px;
    overflow: visible;
  }
}

@media screen and (max-width: 767px) {
  .detail-performance__table .table {
    width: 100%;
    max-width: 100%;
  }
}

@media screen and (max-width: 500px) {

  /* 調整 */
  .detail-performance__table .table {
    width: 130%;
    max-width: 500px;
    overflow: visible;
  }
}


:root {
  --heightlines: 0;
}

.tableset {
  font-size: 1.3rem;
  overflow: hidden;
}

.tableset__head,
.tableset__body {
  display: flex;
  justify-content: space-between;
  flex-wrap: nowrap;
  width: 100%;
}

.tableset__head .tableset__col .cell {
  justify-content: center;
  font-weight: normal;
  background-color: #E8F7F9;
}

.tableset__col {
  width: 100%;
}

.tableset__col.-fixed {
  flex-shrink: 0;
}

.tableset__col .cell {
  display: flex;
  width: 100%;
  align-items: center;
  padding: 6px 5px 4px;
  font-size: 1.3rem;
  line-height: 1.5em;
  border-right: 2px solid #FFF;
  border-bottom: 2px solid #FFF;
  background-color: #F6F6F6;
}

.tableset__col .cell.-th {
  justify-content: center;
  background-color: #EFEFEF;
}

.tableset__col .cell.-td {
  justify-content: flex-end;
  height: var(--heightlines);
}

.tableset .js-accordion-trg {
  pointer-events: none;
}

.tableset .-sp {
  display: none;
}

@media screen and (max-width: 767px) {
  .table-scroll-x .tableset {
    width: 100%;
    max-width: 100%;
    overflow: auto;
  }

  .tableset {
    font-size: 1.4rem;
  }

  .tableset__head {
    display: none;
  }

  .tableset__body {
    flex-direction: column;
  }

  .tableset__col {
    width: 100% !important;
  }

  .tableset__col .cell.-th {
    padding: 12px 8px 8px;
  }

  .tableset__col .-th.cell[data-label] {
    justify-content: center;
  }

  .tableset__col .-th.cell[data-label]::before {
    text-align: center;
  }

  .tableset__col .cell[data-label] {
    display: flex;
    justify-content: flex-end;
    position: relative;
    padding-left: calc(72% + 16px);
  }

  .tableset__col .cell[data-label]:before {
    content: attr(data-label);
    display: flex;
    align-items: center;
    width: 72%;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    padding: 6px 5px 4px;
    line-height: 1.3em;
    white-space: pre;
    border-right: 2px solid #FFF;
    background-color: #EFEFEF;
    text-align: left;
  }

  .tableset__col .-td.cell {
    font-size: 1.3rem;
    height: 60px;
    /* 2行分 */
  }

  .tableset .js-accordion-trg {
    position: relative;
    border-top: 3px solid #FFF;
    pointer-events: auto;
    cursor: pointer;
  }

  .tableset .js-accordion-trg::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 16px;
    display: block;
    width: 24px;
    height: 24px;
    background-image: url(../../img/common/icon/icon_angtrg_down.svg);
    background-repeat: no-repeat;
    background-size: 16px 8px;
    background-position: center center;
    transform: translateY(-50%);
    transition: 0.3s ease;
  }

  .tableset .js-accordion-trg.-open::after {
    transform: translateY(-50%) rotate(180deg);
  }

  .tableset .js-accordion-target {
    display: none;
  }

  .tableset .-pc {
    display: none;
  }

  .tableset .-sp {
    display: inline-block;
  }
}

.table .total {
  font-weight: bold;
  color: #FFF;
  background-color: var(--total);
}

.table .total span {
  display: block;
  margin: 1px 0 2px;
  font-size: 1.1rem;
  font-weight: normal;
  line-height: 1.6rem;
}

.table .kuutyou {
  background-color: var(--kuutyou);
}

.table .kanki {
  background-color: var(--kanki);
}

.table .syoumei {
  background-color: var(--syoumei);
}

.table .kyuutou {
  background-color: var(--kyuutou);
}

.table .syoukouki {
  background-color: var(--syoukouki);
}

.table .others {
  background-color: var(--others);
}

.table .saiene {
  background-color: var(--saiene);
}

.table .kojene {
  background-color: var(--kojene);
}


.wrap-shareButton {
  display: flex;
  justify-content: space-around;
  padding: 0;
}

.popover-body {
  padding: 0;
}

.popover {
  height: 46px;
}

button:focus,
input:focus {
  outline: none !important;
}

.proc-block {
  margin-top: 16px !important;
}

.proc-heading {
  font-size: 2.4rem;
  line-height: 1.5;
}

.proc-grid {
  justify-content: space-between;
  align-items: stretch;
}

.proc-table td {
  height: 6rem;
}

.proc-table table {
  margin-bottom: 0;
}

.proc-table .comment {
  font-size: 1.1rem;
  line-height: 1.3rem;
}

@media screen and (max-width: 880px) {

  /* 調整 */
  .proc-table {
    overflow-x: auto;
  }

  .proc-table .table {
    min-width: 350px;
    max-width: 600px;
    overflow: visible;
  }
}