@charset "utf-8";

.Voice {
  line-height: 1.6;
  color: #333;
}

.Voice-inner {
  position: relative;
  width: 1100px;
  padding: 0 30px;
  margin: 0 auto;
}

.Voice-inner:not(.Voice-noline)::after {
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 1040px;
  height: 1px;
  content: '';
  background: #e0e0e0;
  transform: translate(-50%);
}

/* ライフネット生命の評判･口コミ
 --------------------------------------------------------- */
.Voice-header {
  position: relative;
  background: #f8fbf3;
}

.Voice-header .Voice-inner {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 0 30px 50px;
  background: #f8fbf3;
}

.Voice-head {
  width: 600px;
}

.Voice-head__ttl {
  margin: 0;
}

.Voice-head__ico {
  position: relative;
  display: inline-block;
  margin: 50px 0 12px 25px;
  font-size: 18px;
  font-style: normal;
}

.Voice-head__ico::after,
.Voice-head__ico::before {
  position: absolute;
  top: 50%;
  width: 1px;
  height: 40px;
  content: '';
  background: #333;
}

.Voice-head__ico::before {
  left: 0;
  transform: translate(-20px, -50%) rotate(-15deg);
}

.Voice-head__ico::after {
  right: 0;
  transform: translate(20px, -50%) rotate(15deg);
}

.Voice-head__ttl b {
  display: block;
  font-size: 30px;
}

.Voice-head__ttl strong {
  display: block;
  margin: 0 0 35px;
  font-size: 80px;
  line-height: 1.1;
  color: #8fb130;
}

.Voice-head p {
  margin: 0 0 1.5em;
  font-size: 18px;
  line-height: 1.6;
}

.Voice-header img {
  display: block;
  margin: 108px 0 0;
}

/* ネットプロモータースコア（NPS）®とは
 --------------------------------------------------------- */
.Voice-nps {
  display: flex;
  justify-content: space-between;
}

.Voice-nps dl {
  width: 480px;
  padding: 0 0 22px;
}

.Voice-nps dt {
  display: flex;
  align-items: center;
  height: 95px;
  padding: 15px 0 0;
  font-size: 20px;
}

.Voice-nps dd {
  align-items: center;
  font-size: 16px;
  line-height: 1.6;
}

.Voice-nps img {
  width: 520px;
  padding: 100px 0 0;
}

/* ライフネット生命を家族や友人にすすめたいですか
 --------------------------------------------------------- */
.Voice-chart {
  padding: 50px 30px 60px;
}

.Voice-chart__ttl {
  padding: 0 0 30px;
  margin: 0;
  font-size: 44px;
  line-height: 1.45;
  text-align: center;
}

.Voice-chart__ttl span {
  color: #8fb130;
}

.Voice-graph {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  width: 960px;
  margin: 0 auto;
}

#donutchart {
  width: 492px;
  height: 492px;
}

.Voice-legend {
  display: flex;
  flex-wrap: wrap;
  width: 440px;
  padding: 60px 0 0;
  margin: 0;
  line-height: 1;
}

.Voice-legend-box__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding: 0;
  margin: 0;
  line-height: 1;
  list-style: none;
}

.Voice-legend > .Voice-legend__item:nth-child(1) {
  width: 100%;
  padding: 0 20px;
  margin: 0 0 10px;
}

.Voice-legend__item {
  margin-top: 10px;
}

.Voice-legend-box {
  padding: 20px 20px 20px 25px;
  border: 1px solid #e0e0e0;
}

.Voice-legend-box__txt {
  margin: 0;
  font-size: 18px;
  font-weight: bold;
  text-indent: -20px;
}

.Voice-legend__item:nth-child(2n + 1) {
  width: 40%;
}

.Voice-legend__item:nth-child(2n) {
  width: 55%;
}

.Voice-legend dl,
.Voice-legend dt,
.Voice-legend dd {
  margin: 0;
}

.Voice-legend > .Voice-legend__item:nth-child(1) dt {
  font-size: 32px;
}

.Voice-legend__item dt {
  font-size: 18px;
}

.Voice-legend__percent {
  display: flex;
  align-items: flex-end;
}

.Voice-legend > .Voice-legend__item:nth-child(1) p {
  margin: -10px 0 0.08em;
  font-size: 130px;
}

.Voice-legend__item p {
  margin: 0 0 0.1em;
  font-size: 62px;
}

.Voice-legend em {
  display: block;
  font-style: normal;
  font-weight: bold;
}

.Voice-legend__item:nth-child(1) em {
  color: #8fb130;
}

.Voice-legend__item:nth-child(2) em {
  color: #bcd083;
}

.Voice-legend__item:nth-child(3) em {
  color: #c6c6c6;
}

.Voice-legend__item:nth-child(4) em {
  color: #a6a6a6;
}

.Voice-legend span {
  margin: 0 0 0.1em 0.1em;
  font-size: 0.45em;
}

.Voice-legend__small {
  display: flex;
  align-items: center;
  font-size: 14px;
  white-space: nowrap;
}

.Voice-legend__small img {
  margin: 0 10px 0 0;
}

.Voice-graph__txt {
  width: 100%;
  margin: 35px 0 0;
  font-size: 14px;
  line-height: 1.8;
  text-align: center;
}

.Voice-graph__txt strong {
  display: block;
  font-size: 16px;
  font-weight: bold;
}

.Voice-graph__answer {
  font-style: normal;
}

/* これまでのご契約者さまの評価
 --------------------------------------------------------- */
.Voice-evaluation {
  padding: 48px 30px 85px;
}

.Voice-evaluation__ttl {
  padding: 0 0 20px;
  margin: 0;
  font-size: 44px;
  line-height: 1.45;
  text-align: center;
}

.Voice-evaluation__ttl span {
  color: #8fb130;
}

.Voice-filter__search {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  width: 940px;
  margin: 0 auto;
}

.Voice-filter {
  top: 0;
  width: 180px;
  padding: 25px 0 0;
}

.Voice-filter__text {
  padding: 0 0 5px;
  margin: 0;
  line-height: 1.4;
  white-space: nowrap;
}

.Voice-filter__count::after {
  font-size: 14px;
  font-weight: normal;
  content: '件';
}

.Voice-filter__count {
  font-size: 22px;
}

.Voice-filter__text span {
  font-size: 14px;
}

.Voice-filter__total::after {
  font-size: 14px;
  font-weight: normal;
  content: '件';
}

.Voice-filter__total {
  font-weight: normal;
}

.Voice-filter legend {
  display: block;
  padding: 8px 0 5px;
  margin: 0;
  font-size: 16px;
  font-weight: bold;
}

.Voice-filter__item {
  position: relative;
  display: block;
}

.Voice-filter__gender {
  display: flex;
  justify-content: space-between;
}

.Voice-filter__gender span {
  width: 86px;
}

.Voice-filter [type='checkbox'] {
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  opacity: 0;
}

.Voice-filter__field label {
  display: flex;
  align-items: center;
  width: 100%;
  height: 44px;
  padding: 0 0 0 8px;
  margin: 0 0 8px;
  font-size: 14px;
  cursor: pointer;
  user-select: none;
  background: #f3f6f7;
  border-radius: 3px;
}

.Voice-filter__field span {
  position: relative;
}

.Voice-filter__field svg {
  display: block;
  width: 20px;
  height: 20px;
  margin: 0 6px 0 0;
}

.Voice-filter__field rect {
  fill: #fff;
  stroke: #c4c4c4;
}

.Voice-filter__field path {
  display: none;
  fill: #8fb130;
}

.Voice-filter__field :checked + label path {
  display: block;
}

.Voice-filter__field select {
  width: 100%;
  height: 45px;
  color: #333;
  background: #fff;
  border-color: #c6c6c6;
  border-radius: 3px;
}

.Voice-filter__msg {
  margin: 1rem 0 0;
  color: #f00;
}

.Voice-filter-apply__btn {
  display: block;
  width: 100%;
  height: 48px;
  margin: 22px 0 0;
  font-size: 16px;
  color: #fff;
  user-select: none;
  background: #8fb130;
  border: none;
  border-radius: 3px;
}

/* 投稿一覧
 ---------------------------- */
.Voice-list {
  width: 706px;
}

.Voice-list ul {
  padding: 0;
  margin: 0;
  list-style: none;
}

.Voice-list li {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding: 32px 0 40px 106px;
  margin: 0;
}

.Voice-list li::after,
.Voice-list li::before {
  position: absolute;
  left: 0;
  content: '';
}

.Voice-list li::after {
  bottom: 0;
  width: 100%;
  height: 1px;
  background-image: linear-gradient(
    to right,
    #c6c6c6,
    #c6c6c6 2px,
    transparent 2px,
    transparent 4px
  );
  background-repeat: repeat-x;
  background-position: left bottom;
  background-size: 4px 1px;
}

.Voice-list li::before {
  top: 32px;
  width: 70px;
  height: 40px;
  background-image: url(/review/nps/pc/img/nps_splite.svg);
  background-repeat: no-repeat;
  background-size: 70px 440px;
}

.Voice-list li.Voice-nps10::before {
  background-position: 0 0;
}

.Voice-list li.Voice-nps9::before {
  background-position: 0 -40px;
}

.Voice-list li.Voice-nps8::before {
  background-position: 0 -80px;
}

.Voice-list li.Voice-nps7::before {
  background-position: 0 -120px;
}

.Voice-list li.Voice-nps6::before {
  background-position: 0 -160px;
}

.Voice-list li.Voice-nps5::before {
  background-position: 0 -200px;
}

.Voice-list li.Voice-nps4::before {
  background-position: 0 -240px;
}

.Voice-list li.Voice-nps3::before {
  background-position: 0 -280px;
}

.Voice-list li.Voice-nps2::before {
  background-position: 0 -320px;
}

.Voice-list li.Voice-nps1::before {
  background-position: 0 -360px;
}

.Voice-list li.Voice-nps0::before {
  background-position: 0 -400px;
}

.Voice-list .Voice-age {
  margin: 0 1em 0 0;
  font-weight: bold;
}

.Voice-list .Voice-gender {
  flex-grow: 1;
  font-weight: bold;
}

.Voice-list .Voice-date {
  padding: 0 0 0 459px;
}

.Voice-com {
  width: 100%;
  margin: 10px 0 0;
}

.Voice-next__btn {
  display: none;
  width: 400px;
  height: 56px;
  margin: 45px auto 0;
  color: #333;
  user-select: none;
  background: #fff;
  border: solid 1px #8fb130;
  border-radius: 3px;
}

.Voice-area-loading {
  padding: 80px 0 0 300px;
  margin: 0 0 8px;
  font-size: 21px;
  font-weight: bold;
  color: #8fb130;
}

.Voice-area-not-found {
  display: none;
  padding: 80px 0 0 200px;
  margin: 0 0 8px;
  font-size: 21px;
  font-weight: bold;
  color: #8fb130;
}

/* フッタ
 --------------------------------------------------------- */
.Voice-footer {
  padding: 25px 30px 100px;
  font-size: 14px;
}

.Voice-footer h3 {
  margin: 20px 0 8px;
  font-size: 16px;
  font-weight: bold;
}

.Voice-footer__txt {
  margin: 0;
}

.Voice-footer ul {
  padding: 0;
  margin: 0;
  list-style: none;
  counter-reset: item;
}

.decimal li::before {
  content: '（' counter(item) '）';
  counter-increment: item;
}

.dot li {
  padding: 0 0 0 1em;
  text-indent: -1em;
}

.dot li::before {
  content: '・';
}
