@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Roboto:wght@500;700&display=swap");
html {
  font-size: 62.5%;
}

body {
  color: #2d2d2d;
  font-family: Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Arial, "メイリオ", Meiryo, sans-serif, sans-serif;
  font-size: 1.6rem;
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
}

body main {
  display: block;
  min-height: 100vh;
  padding-bottom: 60px;
  background-color: #f7f7f6;
}

@media screen and (min-width: 1000px) {
  body main {
    padding-left: 265px;
    padding-bottom: 100px;
  }
}

body main[data-main="single"] {
  padding-left: 0;
}

body a {
  color: #e56813;
}

body a:hover {
  text-decoration: none;
}

body ul,
body ol {
  list-style: none;
}

body img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}

body input,
body button,
body textarea,
body select {
  font-family: Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Arial, "メイリオ", Meiryo, sans-serif;
}

body select::-ms-expand {
  display: none;
}

*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin: 0;
  padding: 0;
}

.c-alert {
  margin: 20px 0;
  padding: 14px 19px;
  color: #e56813;
  font-weight: 600;
  font-size: 1.4rem;
  line-height: 1.5;
  border: 1px solid #e56813;
  background-color: #f4e2d4;
}

.c-anchor__link {
  margin-bottom: 20px;
}

.c-anchor__link ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.c-anchor__link li {
  margin: 0 2.5px;
}

.c-anchor__link a {
  display: block;
  padding: 5px 16px;
  color: #2d2d2d;
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1.4;
  text-decoration: none;
  background-color: #fff;
  border: 1px solid #d9d9d9;
  border-radius: 16px;
  -webkit-transition: background-color 300ms, font-weight 300ms;
  transition: background-color 300ms, font-weight 300ms;
}

.c-anchor__link a:hover {
  font-weight: 600;
  background-color: #f7f7f6;
}

.c-button button,
.c-button__fixed button,
.c-button__text button {
  width: 100%;
  border: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: none;
  cursor: pointer;
}

.c-button a,
.c-button__fixed a,
.c-button__text a {
  display: inline-block;
  text-decoration: none;
}

.c-notification__detail .c-button,
.c-form__confirm[data-type="card"] + .c-button[data-button="primary"] {
  margin-top: 30px;
}

.c-plan__item .c-button {
  margin: 20px auto 10px;
}

.c-plan__item + .c-button {
  margin-bottom: 20px;
}

.c-button[data-button="primary"] {
  text-align: center;
}

.c-button[data-button="primary"][data-submit="disable"] {
  opacity: .3;
  pointer-events: none;
}

.c-button[data-button="primary"] button,
.c-button[data-button="primary"] a {
  background-color: #e56813;
  width: 255px;
  padding: 15px;
  color: #fff;
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1.8;
  border-radius: 70px;
  -webkit-transition: background-color 300ms;
  transition: background-color 300ms;
  -webkit-box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
          box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}

.c-button[data-button="primary"] button:hover,
.c-button[data-button="primary"] a:hover {
  background-color: #ce5607;
}

.c-button[data-button="secondary"] {
  text-align: center;
}

.c-button[data-button="secondary"] button {
  background-color: #128d70;
  width: 255px;
  padding: 15px;
  color: #fff;
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1.8;
  border-radius: 70px;
  -webkit-transition: background-color 300ms;
  transition: background-color 300ms;
  -webkit-box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
          box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}

.c-button[data-button="secondary"] button:hover {
  background-color: #08755c;
}

.c-button[data-button="disable"] {
  text-align: center;
}

.c-button[data-button="disable"] button {
  background-color: #8d8d8d;
  opacity: .5;
  pointer-events: none;
  width: 255px;
  padding: 15px;
  color: #fff;
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1.8;
  border-radius: 70px;
  -webkit-transition: background-color 300ms;
  transition: background-color 300ms;
  -webkit-box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
          box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}

.c-button[data-button="disable"] button:hover {
  background-color: #8d8d8d;
}

.c-button[data-button="attention"] {
  margin-top: 30px;
  text-align: center;
}

.c-button[data-button="attention"][data-status="disable"] button {
  opacity: .5;
  pointer-events: none;
}

.c-button[data-button="attention"] button {
  background-color: #c71a1a;
  width: 255px;
  padding: 15px;
  color: #fff;
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1.8;
  border-radius: 70px;
  -webkit-transition: background-color 300ms;
  transition: background-color 300ms;
  -webkit-box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
          box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}

.c-button[data-button="attention"] button:hover {
  background-color: #a21a1a;
}

.c-button[data-button="add"] {
  margin-bottom: 40px;
  text-align: center;
}

.c-button[data-button="add"] a,
.c-button[data-button="add"] button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: auto;
  margin: 0 auto;
  padding: 10px 30px;
  color: #fff;
  font-weight: 600;
  font-size: 1.4rem;
  line-height: 1.8;
  background-color: #2d2d2d;
  -webkit-box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
          box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
  -webkit-transition: background-color 300ms, -webkit-box-shadow 300ms;
  transition: background-color 300ms, -webkit-box-shadow 300ms;
  transition: background-color 300ms, box-shadow 300ms;
  transition: background-color 300ms, box-shadow 300ms, -webkit-box-shadow 300ms;
}

.c-button[data-button="add"] a:hover,
.c-button[data-button="add"] button:hover {
  background-color: #333;
  -webkit-box-shadow: 0 4px 10px rgba(0, 0, 0, 0);
          box-shadow: 0 4px 10px rgba(0, 0, 0, 0);
}

.c-button[data-button="add"] a {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  text-decoration: none;
}

.c-button[data-button="add"] span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-button[data-button="add"] span::before {
  display: block;
  content: "";
  margin-right: 10px;
  width: 13px;
  height: 13px;
  background-image: url("../image/icon-add-02.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.c-form__fixed .c-button__fixed {
  position: static;
}

.c-button[data-link="primary"] {
  text-align: center;
}

.c-button[data-link="primary"] a {
  background-color: #2d2d2d;
  width: 255px;
  padding: 15px;
  color: #fff;
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1.8;
  border-radius: 70px;
  -webkit-transition: background-color 300ms;
  transition: background-color 300ms;
  -webkit-box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
          box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}

.c-button[data-link="primary"] a:hover {
  background-color: #ce5607;
}

.c-button[data-link="secondary"] {
  text-align: center;
}

.c-button[data-link="secondary"] a {
  background-color: #2d2d2d;
  width: 255px;
  padding: 15px;
  color: #fff;
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1.8;
  border-radius: 70px;
  -webkit-transition: background-color 300ms;
  transition: background-color 300ms;
  -webkit-box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
          box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}

.c-button[data-link="secondary"] a:hover {
  background-color: #4c4c4c;
}

.c-button__fixed {
  position: fixed;
  right: 15px;
  bottom: 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  line-height: 1;
  z-index: 5;
}

@media screen and (min-width: 1000px) {
  .c-button__fixed {
    right: 30px;
    bottom: 30px;
  }
}

.c-button__fixed[data-fixed="tabbar"] {
  bottom: 60px;
  -webkit-transition: bottom 300ms;
  transition: bottom 300ms;
}

@media screen and (min-width: 1000px) {
  .c-button__fixed[data-fixed="tabbar"] {
    bottom: 30px;
  }
}

.c-button__fixed a,
.c-button__fixed button {
  display: block;
  padding: 11px 10px;
  min-width: 114px;
  color: #fff;
  font-size: 1.2rem;
  font-weight: 600;
  line-height: 1;
  letter-spacing: .05em;
  text-align: center;
  background-color: #8d8d8d;
  border-radius: 60px;
  text-decoration: none;
  -webkit-box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
          box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
  -webkit-transition: background-color 300ms, -webkit-box-shadow 300ms;
  transition: background-color 300ms, -webkit-box-shadow 300ms;
  transition: background-color 300ms, box-shadow 300ms;
  transition: background-color 300ms, box-shadow 300ms, -webkit-box-shadow 300ms;
}

.c-button__fixed a:hover,
.c-button__fixed button:hover {
  background-color: #2d2d2d;
  -webkit-box-shadow: 0 4px 10px rgba(0, 0, 0, 0);
          box-shadow: 0 4px 10px rgba(0, 0, 0, 0);
}

.c-button__fixed a[data-button="secondary"],
.c-button__fixed button[data-button="secondary"] {
  background-color: #e56813;
}

.c-button__fixed a[data-button="secondary"]:hover,
.c-button__fixed button[data-button="secondary"]:hover {
  background-color: #ce5607;
}

.c-button__fixed a[data-button="tertiary"],
.c-button__fixed button[data-button="tertiary"] {
  background-color: #2d2d2d;
}

.c-button__fixed a[data-button="tertiary"]:hover,
.c-button__fixed button[data-button="tertiary"]:hover {
  background-color: #333;
}

.c-button__fixed a[data-button="add"],
.c-button__fixed button[data-button="add"] {
  padding: 11px 20px;
  background-color: #128d70;
}

.c-button__fixed a[data-button="add"]:hover,
.c-button__fixed button[data-button="add"]:hover {
  background-color: #08755c;
}

.c-button__fixed button + button {
  margin-left: 10px;
}

.c-button__fixed button[data-button="add"] span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-button__fixed button[data-button="add"] span::before {
  display: block;
  content: "";
  width: 11px;
  height: 11px;
  margin-right: 4px;
  background-image: url("../image/icon-add-02.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-button__text {
  margin-top: 25px;
  text-align: center;
  line-height: 1;
}

.c-button__text[data-text="red"] {
  margin: 10px 0 30px;
}

.c-button__text[data-text="red"] button {
  color: #c71a1a;
}

.c-button__text button {
  font-size: 1.1rem;
  line-height: 1.8;
  text-decoration: underline;
}

.c-button__text button:hover {
  text-decoration: none;
}

.c-form__error[data-error="all"] + .c-button__text[data-text="red"] {
  margin-top: -20px;
}

.c-client-link .c-button__text {
  margin-top: 15px;
  text-align: right;
}

.c-client-link .c-button__text button {
  text-align: right;
}

.c-calendar {
  margin-bottom: 15px;
}

.c-calendar table {
  width: 100%;
  border: 1px solid #d9d9d9;
  background-color: #fff;
  border-collapse: collapse;
}

.c-calendar thead th {
  font-size: 1.1rem;
  line-height: 1.85;
  color: #8d8d8d;
}

.c-calendar thead th + th {
  border-left: 1px solid #d9d9d9;
}

.c-calendar tbody tr {
  border-top: 1px solid #d9d9d9;
}

.c-calendar tbody td {
  padding: 2px;
  font-size: 1.5rem;
  font-family: "Roboto", "Helvetica Neue", Helvetica, Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Arial, "メイリオ", Meiryo, sans-serif;
  font-weight: 600;
  letter-spacing: -.06em;
  line-height: 1.85;
  text-align: center;
}

.c-calendar tbody td + td {
  border-left: 1px solid #d9d9d9;
}

.c-calendar tbody td a,
.c-calendar tbody td span {
  display: block;
  color: #8d8d8d;
}

.c-calendar tbody td a {
  text-decoration: none;
  background-color: #fff;
  -webkit-transition: background-color 300ms;
  transition: background-color 300ms;
}

.c-calendar tbody td a:hover {
  background-color: #e8e8e8;
}

.c-calendar tbody td a[data-day="today"] {
  color: #333;
}

.c-calendar tbody td a[data-status="less"] {
  color: #c71a1a;
}

.c-calendar tbody td a[data-status="more"] {
  color: #128d70;
}

.c-calendar__text {
  margin-bottom: 10px;
  text-align: center;
}

.c-calendar__text p {
  font-size: 1.2rem;
  line-height: 1.85;
}

.c-calendar__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.c-calendar__link li {
  line-height: 1;
}

.c-calendar__link a {
  color: #2d2d2d;
  font-size: 1.3rem;
}

.c-calendar__link a:hover {
  text-decoration: none;
}

.c-client-link__list {
  max-width: 375px;
  margin: 0 auto 25px;
}

@media screen and (min-width: 767px) {
  .c-client-link__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    max-width: 100%;
  }
}

@media screen and (min-width: 767px) {
  .c-client-link__list li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 auto;
            flex: 0 0 auto;
    width: calc(50% - 10px);
  }
}

@media screen and (min-width: 767px) {
  .c-client-link__list li:nth-child(odd) {
    margin-right: 20px;
  }
}

.c-client-link__list li + li {
  margin-top: 10px;
}

@media screen and (min-width: 767px) {
  .c-client-link__list li + li {
    margin-top: 20px;
  }
}

@media screen and (min-width: 767px) {
  .c-client-link__list li:nth-child(2) {
    margin-top: 0;
  }
}

.c-client-link {
  display: block;
  width: 100%;
  color: #8d8d8d;
  padding: 10px 8px 10px 12px;
  background-color: #fff;
  border: 1px solid #d9d9d9;
}

@media screen and (min-width: 350px) {
  .c-client-link {
    padding: 13px 14px 13px 19px;
  }
}

a.c-client-link {
  position: relative;
  text-decoration: none;
  -webkit-transition: border 300ms;
  transition: border 300ms;
}

a.c-client-link:hover {
  border: 1px solid #e56813;
}

a.c-client-link::after {
  position: absolute;
  top: calc(50% - 6px);
  right: 15px;
  display: block;
  content: "";
  width: 12px;
  height: 12px;
  -webkit-transform: rotate(-90deg);
          transform: rotate(-90deg);
  background-image: url("../image/icon-arrow-02.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-client-link__name {
  margin-bottom: 6px;
}

.c-client-link__name ruby {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}

.c-client-link__name h2 {
  color: #2d2d2d;
  font-weight: 600;
  font-size: 1.8rem;
  line-height: 1.5;
}

.c-client-link__name h2 span {
  display: inline-block;
  margin-left: 5px;
  font-size: 1.2rem;
}

.c-client-link__name rp,
.c-client-link__name rt {
  color: #8d8d8d;
  font-size: 1rem;
  line-height: 1.5;
}

.c-client-link__status {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-client-link__status-wrapper > h3 {
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.54;
}

.c-client-link__achievement {
  margin-top: 12px;
  line-height: 1;
}

@media screen and (min-width: 767px) {
  .c-client-link__achievement {
    margin-right: 22px;
  }
}

.c-client-link__achievement > h3 {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  width: 100%;
  color: #8d8d8d;
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.54;
}

.c-client-link__achievement > a {
  display: inline-block;
  margin-top: 5px;
  color: #8d8d8d;
  font-size: 1rem;
  line-height: 1.54;
}

.c-client-link__achievement > a:hover {
  text-decoration: none;
}

.c-client-link__progress {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-line-pack: center;
      align-content: center;
  width: 100px;
}

@media screen and (min-width: 350px) {
  .c-client-link__progress {
    width: 140px;
  }
}

.c-client-link__progress-bar {
  position: relative;
  margin-top: 5px;
  width: 100px;
  height: 4px;
  background-color: #c0c0c0;
  border-radius: 6px;
  overflow: hidden;
}

.c-client-link__progress-fill {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 10%;
  background-color: #128d70;
}

.c-client-link__progress-percent {
  margin-left: 5px;
  font-family: "Roboto", "Helvetica Neue", Helvetica, Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Arial, "メイリオ", Meiryo, sans-serif;
  color: #128d70;
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1;
}

.c-client-link__progress-percent span {
  font-size: 1rem;
}

.c-client-link__progress[data-progress="few"] .c-client-link__progress-fill {
  background-color: #c71a1a;
}

.c-client-link__progress[data-progress="few"] .c-client-link__progress-percent {
  color: #c71a1a;
}

.c-client-link__status-level {
  margin-top: 2px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  min-width: 146px;
  margin-left: auto;
}

.c-client-link__status-level::before {
  display: block;
  content: "";
  margin-right: 3px;
  width: 24px;
  height: 24px;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-client-link__status-level[data-level="dissatisfaction"]::before {
  background-image: url("../image/icon-status-01.svg");
}

.c-client-link__status-level[data-level="usually"]::before {
  background-image: url("../image/icon-status-02.svg");
}

.c-client-link__status-level[data-level="satisfaction"]::before {
  background-image: url("../image/icon-status-03.svg");
}

.c-client-link__status-level[data-level="unregistered"]::before {
  display: none;
}

.c-client-link__status-level[data-level="unregistered"] span {
  color: #8d8d8d;
  font-size: 1.3rem;
}

.c-client-link__status-level dt {
  font-weight: 600;
  font-size: 1.3rem;
  line-height: 1.38;
  color: #2d2d2d;
}

.c-client-link__status-level[data-level="dissatisfaction"] dt {
  color: #c71a1a;
}

.c-client-link__status-level dd {
  font-size: 1.1rem;
  line-height: 1;
}

.c-client-link__status-date {
  margin-top: 12px;
  margin-left: auto;
  min-width: 146px;
  color: #8d8d8d;
}

.c-client-link__status-date dl > div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.c-client-link__status-date dt,
.c-client-link__status-date dd {
  font-size: 1rem;
  line-height: 1.54;
}

.c-client-link__status-date dt {
  min-width: 70px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-line-pack: center;
      align-content: center;
}

.c-client-link__status-date dt::after {
  display: inline-block;
  content: "：";
  margin-left: auto;
}

.c-client-link__archive div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-client-link__archive dt,
.c-client-link__archive dd {
  color: #8d8d8d;
  font-size: 1rem;
  line-height: 1.54;
}

.c-client-link__archive dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-client-link__archive dt::after {
  display: block;
  content: "：";
}

.c-client-link__archive p {
  color: #c71a1a;
  font-size: 1.3rem;
  line-height: 1.54;
}

.c-client-link__archive a {
  color: #c71a1a;
}

.c-client-link__default {
  margin-top: 10px;
  text-align: right;
  line-height: 1;
}

.c-client-link__default a {
  color: #2d2d2d;
  font-size: 1.3rem;
  line-height: 1.85;
}

.c-client-select {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  border-bottom: 1px solid #d9d9d9;
}

.c-client-select a {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 40px;
  min-height: 40px;
  background-color: rgba(141, 141, 141, 0.25);
}

@media screen and (min-width: 1000px) {
  .c-client-select a {
    width: 62px;
    min-height: 62px;
  }
}

.c-client-select a::before {
  display: block;
  content: "";
  width: 6px;
  height: 10px;
  background-image: url("../image/icon-arrow-04.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

@media screen and (min-width: 1000px) {
  .c-client-select a::before {
    width: 9px;
    height: 16px;
  }
}

.c-client-select a span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}

.c-client-select__current {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 7px 40px 7px 0;
  width: calc(100% - 40px);
  background-color: #fff;
}

@media screen and (min-width: 1000px) {
  .c-client-select__current {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    padding-left: 18px;
  }
}

.c-client-select__status {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 20px;
  height: 20px;
  margin-right: 6px;
}

@media screen and (min-width: 1000px) {
  .c-client-select__status {
    width: 32px;
    height: 32px;
  }
}

@media screen and (min-width: 1000px) {
  .c-client-select__status img {
    width: 100%;
    height: auto;
  }
}

.c-client-select__name {
  font-size: 1.4rem;
  line-height: 1.85;
  letter-spacing: .05em;
}

@media screen and (min-width: 1000px) {
  .c-client-select__name {
    font-size: 1.8rem;
  }
}

.c-client-select__name > span {
  color: #8d8d8d;
  font-size: 1.2rem;
}

@media screen and (min-width: 1000px) {
  .c-client-select__name > span {
    font-size: 1.4rem;
  }
}

.c-client-select__name > span span {
  color: #2d2d2d;
}

.c-content {
  margin-bottom: 25px;
}

.c-content[data-text="center"] {
  margin-bottom: 20px;
  text-align: center;
}

.c-content[data-separate="header"] {
  margin-top: 24px;
}

.c-content[data-border="top"] {
  margin-top: 40px;
  border-top: 1px solid #d9d9d9;
  padding-top: 35px;
}

.c-content p {
  font-size: 1.4rem;
  line-height: 1.85;
}

.c-content p sup {
  color: #c71a1a;
  font-size: 1.4rem;
  vertical-align: baseline;
}

.c-content p + p {
  margin-top: 18px;
}

.c-content a[data-color="normal"] {
  color: #2d2d2d;
}

.c-content > h2 {
  margin-bottom: 10px;
  font-size: 1.4rem;
  line-height: 1.5;
}

.c-content p + h2 {
  margin-top: 28px;
}

.c-content p em {
  font-style: normal;
  color: #c71a1a;
}

.c-content p em b {
  font-weight: 600;
}

.c-content p strong {
  color: #c71a1a;
  font-weight: 600;
}

.c-content > em {
  font-style: normal;
  color: #c71a1a;
  font-size: 1.2rem;
  line-height: 1.85;
}

.c-content > em sup {
  font-size: 1.2rem;
  vertical-align: baseline;
}

.c-content ul {
  margin-bottom: 20px;
}

.c-content ul li {
  font-size: 1.4rem;
  line-height: 1.85;
}

.c-content ul li::before {
  display: inline-block;
  content: "・";
}

.c-plan__heading + .c-content {
  margin-top: 10px;
}

.c-content__attention {
  margin-bottom: 30px;
}

.c-content__attention p {
  color: #c71a1a;
  font-size: 1.2rem;
  line-height: 1.55;
}

.c-link-list + .c-content__attention {
  margin-top: 10px;
}

.c-link-list + .c-content__attention p {
  color: #2d2d2d;
}

.c-content__attention-box {
  padding: 14px 19px 17px;
  margin-bottom: 20px;
  border: 1px solid #c71a1a;
  background-color: #f2e1e0;
}

.c-content__attention-box p,
.c-content__attention-box a {
  color: #c71a1a;
  font-size: 1.4rem;
  line-height: 1.85;
}

.c-content__attention-box em {
  font-style: normal;
  font-weight: 600;
}

@media screen and (min-width: 767px) {
  .c-content__service {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
}

@media screen and (min-width: 767px) {
  .c-content__service li {
    width: calc(50% - 10px);
  }
}

.c-content__service li h3 {
  margin-bottom: 10px;
  line-height: 1;
}

.c-content__service li a {
  display: block;
  opacity: 1;
  -webkit-transition: opacity 300ms;
  transition: opacity 300ms;
}

.c-content__service li a:hover {
  opacity: .9;
}

.c-content__service li p {
  font-size: 1.2rem;
  line-height: 1.55;
}

.c-content__service li p span {
  color: #c71a1a;
}

.c-content__service li + li {
  margin-top: 30px;
}

@media screen and (min-width: 767px) {
  .c-content__service li + li {
    margin: 0 0 0 20px;
  }
}

.c-content + .c-content__service {
  margin-top: -5px;
}

.c-content__page {
  margin-bottom: 15px;
  text-align: center;
}

@media screen and (min-width: 1000px) {
  .c-content__page {
    text-align: left;
  }
}

.c-content__page p {
  font-weight: 600;
  font-size: 1.2rem;
  line-height: 1.55;
}

.c-content__page p span {
  margin-left: 5px;
  font-size: 1.5rem;
}

.c-content__page p span:first-child {
  margin-left: 0;
}

.c-content__back {
  text-align: center;
}

@media screen and (min-width: 1000px) {
  .c-content__back {
    text-align: left;
  }
}

.c-content__back a {
  color: #2d2d2d;
  font-size: 1.3rem;
  line-height: 1.8;
}

.c-content__back:hover {
  text-decoration: none;
}

.c-form__confirm + .c-content__back,
.c-pagination + .c-content__back {
  margin-top: 30px;
}

.c-content__link {
  margin-top: 15px;
  line-height: 1;
}

.c-content__link[data-link="attention"] {
  margin-top: 20px;
  text-align: center;
}

.c-content__link[data-link="attention"] a {
  color: #c71a1a;
}

.c-content__link[data-link="pdf"] {
  margin-bottom: 25px;
}

.c-content__link a {
  color: #2d2d2d;
  font-size: 1.2rem;
  line-height: 1.55;
}

.c-content__link a:hover {
  text-decoration: none;
}

.c-content__link[data-link="back"] {
  margin: -10px 0 30px;
  font-size: 1rem;
  line-height: 1;
  text-align: left;
}

@media screen and (min-width: 1000px) {
  .c-content__link[data-link="back"] {
    margin-top: 0;
  }
}

.c-content__link[data-link="back"] a {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  color: #8d8d8d;
  font-size: 1.1rem;
  line-height: 1.45;
}

.c-content__link[data-link="back"] a::before {
  display: block;
  content: "";
  margin-right: 5px;
  width: 4px;
  height: 6px;
  background-image: url("../image/icon-arrow-04.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-record-list + .c-content__link[data-link="back"],
.c-alert + .c-content__link[data-link="back"] {
  margin-top: 10px;
}

.c-content__box {
  margin-bottom: 20px;
  padding: 15px 20px 17px;
  line-height: 1;
  background-color: #fff;
  border: 1px solid #d9d9d9;
}

.c-content__box p {
  font-size: 1.4rem;
  line-height: 1.7;
}

.c-content__box p + p {
  margin-top: 15px;
}

.c-content__box ul li {
  position: relative;
  padding-left: 9px;
  font-size: 1.3rem;
  line-height: 1.75;
}

.c-content__box ul li::before {
  position: absolute;
  top: 0;
  left: -3px;
  display: block;
  content: "・";
  font-size: 1.3rem;
  line-height: 1.75;
}

.c-content__box ul li + li {
  margin-top: 15px;
}

.c-content__box ul li strong {
  color: #c71a1a;
  font-weight: 600;
}

.c-content__box ul a {
  color: #2d2d2d;
}

.c-content__desicription {
  margin-bottom: 20px;
  background-color: #fff;
  border: 1px solid #d9d9d9;
}

.c-content__desicription > div {
  padding: 16px 14px 19px;
}

.c-content__desicription > div + div {
  border-top: 1px solid #d9d9d9;
}

.c-content__desicription dt {
  margin-bottom: 5px;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.85;
}

.c-content__desicription dd {
  font-size: 1.3rem;
  line-height: 1.75;
}

.c-content__desicription dd + dd {
  margin-top: 5px;
  margin-bottom: 5px;
}

.c-content__desicription dd ol {
  margin-bottom: 15px;
  padding: 9px 10px 11px;
  background-color: #f7f7f6;
}

.c-content__desicription dd ol li {
  font-size: 1.3rem;
  line-height: 1.75;
}

.c-content__information {
  background-color: #fff;
}

.c-content__information div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  padding: 15px 20px 14px;
}

.c-content__information div + div {
  border-top: 1px solid #d9d9d9;
}

.c-content__information dt,
.c-content__information dd {
  font-size: 1.4rem;
  line-height: 1.85;
}

.c-content__information dt {
  width: 95px;
  font-weight: 600;
}

.c-content__information ul li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.c-content__information ul li::before {
  display: block;
  content: "・";
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
}

.c-flow {
  margin-bottom: 20px;
}

.c-flow[data-flow="secondary"] {
  margin-bottom: 10px;
}

.c-flow[data-flow="secondary"] li {
  font-size: 1.2rem;
  letter-spacing: .05em;
}

.c-flow[data-flow="secondary"] li[data-flow="medium"] {
  width: 71px;
}

.c-flow ol {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-flow li {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  width: 58px;
  margin-right: 12px;
  padding: 7px 7px 7px 8px;
  color: #2d2d2d;
  font-weight: 600;
  font-size: 1rem;
  line-height: 1.3;
  background-color: #fff;
  border: 1px solid #d9d9d9;
  border-radius: 2px;
}

.c-flow li span {
  color: #e56813;
}

.c-flow li::after {
  position: absolute;
  top: calc(50% - 2.5px);
  right: -8.5px;
  display: block;
  content: "";
  width: 5px;
  height: 5px;
  background-image: url("../image/icon-arrow-01.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-flow li:last-child {
  margin-right: 0;
}

.c-flow li:last-child::after {
  display: none;
}

.c-flow li[data-flow="medium"] {
  width: 67px;
}

.c-flow li[data-flow="large"] {
  width: 82px;
}

.c-flow li[data-flow="long"] {
  width: 108px;
}

.c-flow li[aria-current="page"] {
  color: #fff;
  background-color: #2d2d2d;
  border-color: #2d2d2d;
}

.c-footer {
  padding: 26px 25px 75px;
  line-height: 1;
  background-color: #2d2d2d;
}

@media screen and (min-width: 1000px) {
  .c-footer {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    padding: 35px 45px 35px 265px;
  }
}

.c-footer__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  width: 280px;
  margin-bottom: 25px;
}

@media screen and (min-width: 1000px) {
  .c-footer__link {
    margin: 0 0 0 45px;
  }
}

.c-footer__link li {
  margin: 0 15px 5px 0;
  line-height: 1;
}

@media screen and (min-width: 1000px) {
  .c-footer__link li:last-child {
    margin-bottom: 0;
  }
}

.c-footer__link a {
  color: #fff;
  font-size: 1.2rem;
  line-height: 1.85;
  text-decoration: none;
}

.c-footer__link a:hover {
  text-decoration: underline;
}

.c-footer__copyright {
  color: #8d8d8d;
  font-size: 1rem;
  line-height: 1.54;
}

@media screen and (min-width: 1000px) {
  .c-footer__copyright {
    margin: auto 0 0 auto;
  }
}

.c-forclient-detail {
  padding-top: 30px;
  margin-bottom: 40px;
}

.c-forclient-detail h2 {
  margin-bottom: 13px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  font-size: 1.6rem;
  line-height: 1.5;
}

.c-forclient-detail h2::before {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  display: block;
  content: "";
  margin: 2px 7px 2px 0;
  width: 3px;
  min-height: 19px;
  background-color: #e56813;
}

.c-forclient-detail ul + h2,
.c-forclient-detail dl + h2,
.c-forclient-detail .c-program-status__nutrition-intake + h2 {
  margin-top: 30px;
}

.c-forclient-detail > ul li {
  margin-bottom: 10px;
  padding-left: 1.5rem;
  text-indent: -.7rem;
  font-size: 1.5rem;
  line-height: 1.55;
}

.c-forclient-detail > ul li::before {
  display: inline-block;
  content: "・";
}

.c-forclient-detail > p {
  margin-bottom: 40px;
  font-size: 1.4rem;
  line-height: 1.85;
}

.c-forclient-detail > dl dt,
.c-forclient-detail > dl dd {
  font-size: 1.4rem;
  line-height: 1.55;
}

.c-forclient-detail > dl dt {
  font-weight: 600;
  margin-bottom: 10px;
}

.c-forclient-detail > dl dd {
  margin-bottom: 15px;
  padding-left: 1.5rem;
  text-indent: -.7rem;
}

.c-forclient-detail > dl dd::before {
  display: inline-block;
  content: "・";
}

.c-forclient-detail__heading {
  margin-bottom: 20px;
}

.c-forclient-detail__heading span {
  color: #8d8d8d;
  font-size: 1.1rem;
  line-height: 1.3;
}

.c-forclient-detail__heading h1 {
  font-size: 1.8rem;
  line-height: 1.3;
}

.c-forclient-detail__heading-en {
  margin-top: 5px;
  color: #8d8d8d;
  font-family: "Roboto", "Helvetica Neue", Helvetica, Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Arial, "メイリオ", Meiryo, sans-serif;
  font-size: 1.1rem;
  line-height: 1.18;
}

.c-forclient-detail__video {
  position: relative;
  margin-bottom: 25px;
  width: 100%;
  padding-bottom: 56%;
}

.c-forclient-detail__video iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.c-form__confirm + .c-form__content {
  margin-top: 30px;
}

.c-form__card {
  padding: 17px 19px 0;
  margin-bottom: 30px;
  background-color: #fff;
  border: 1px solid #d9d9d9;
}

.c-form__card > h2 {
  margin-bottom: 10px;
  font-size: 1.4rem;
  line-height: 1.8;
}

p + .c-form__card {
  margin-top: 10px;
}

.c-form__confirm .c-form__card {
  pointer-events: none;
}

.c-form__confirm .c-form__confirm-type + .c-form__card {
  border-top: none;
}

.c-form__card-button {
  margin: 15px 0 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  width: 100%;
}

@media screen and (min-width: 767px) {
  .c-form__card-button {
    width: 303px;
  }
}

.c-form__card-button li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.c-form__card-button li + li {
  margin-left: 9px;
}

.c-form__card-button button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 12px;
  width: 100%;
  min-width: 105px;
  color: #fff;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.5;
  -webkit-transition: background-color 300ms;
  transition: background-color 300ms;
}

.c-form__card-button button.c-form__card-prev-button {
  width: 105px;
  background-color: #8d8d8d;
}

.c-form__card-button button.c-form__card-prev-button:hover {
  background-color: #333;
}

.c-form__card-button button.c-form__card-next-button {
  width: 189px;
  background-color: #128d70;
}

@media screen and (max-width: 350px) {
  .c-form__card-button button.c-form__card-next-button {
    max-width: calc(126 / 320 * 100vw);
  }
}

.c-form__card-button button.c-form__card-next-button:hover {
  background-color: #08755c;
}

.c-form__item {
  margin-bottom: 20px;
}

.c-form__item[aria-hidden="true"] {
  display: none;
}

.c-form__item[data-item="blood"], .c-form__item[data-item="blood-free"] {
  margin-bottom: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  padding: 16px 20px 12px;
  background-color: #fff;
  border: 1px solid #d9d9d9;
  border-bottom: none;
}

.c-form__item[data-item="blood-free"] {
  margin-bottom: 30px;
  border-bottom: 1px solid #d9d9d9;
}

@media screen and (min-width: 767px) {
  .c-form__item[data-item="blood-free"] {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.c-form__item[data-item="blood-free"] h2 {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  width: 100%;
  margin-bottom: 10px;
  font-size: 1.2rem;
  line-height: 1.8;
}

.c-form__item[data-item="height-weight"] {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.c-form__item[data-item="height-weight"] .c-form__item {
  margin-bottom: 0;
}

.c-form__item > p {
  font-size: 1.3rem;
  line-height: 1.8;
  margin-bottom: 8px;
}

.c-form__item > p em {
  color: #c71a1a;
  font-style: normal;
}

.c-program-status .c-form__item {
  margin-top: 18px;
}

.c-program-status .c-form__item > p {
  margin-top: 10px;
}

.c-form__card .c-form__item {
  margin-bottom: 10px;
}

.c-program__exercise-item .c-form__item {
  margin-bottom: 5px;
}

.c-form__accordion-button[data-button="secondary"] + .c-form__item {
  margin-top: 20px;
}

.c-form__card-delete {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 20px 0 16px auto;
  color: #c71a1a;
  font-size: 1.4rem;
  line-height: 1.8;
  text-decoration: underline;
}

.c-form__card-delete:hover {
  text-decoration: none;
}

.c-form__item-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-form__item-wrapper[data-wrapper="many"] > span {
  margin: 0 6px 0 9px;
}

.c-form__item-wrapper > span {
  display: inline-block;
  margin: 0 12px 0 10px;
  font-size: 1.4rem;
  line-height: 1.85;
  letter-spacing: .05em;
}

.c-form__item-wrapper > span:first-child {
  margin-left: 0;
}

.c-form__item[data-item="separate"] .c-form__item-wrapper {
  width: 100%;
}

.c-form__item[data-item="separate"] .c-form__item-wrapper[data-item="long"] {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}

.c-form__item[data-item="separate"] .c-form__item-wrapper + .c-form__item-wrapper {
  margin-top: 10px;
}

.c-form__radio li .c-form__item-wrapper {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  margin: 5px 0 0 20px;
  width: 100%;
}

.c-form__item-blood {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  width: 50%;
  margin-bottom: 8px;
}

@media screen and (min-width: 767px) {
  .c-form__item-blood {
    width: 33.33%;
    margin-bottom: 12px;
  }
}

.c-form__item-blood .c-form__item-wrapper > span {
  margin: 0 0 0 8px;
  font-size: 1.2rem;
  line-height: 1.8;
}

.c-form__item-free-wrapper {
  margin-bottom: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-form__item-free-wrapper ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-form__item-free-wrapper li {
  margin-right: 10px;
}

.c-form__item-free-wrapper li:nth-child(1) {
  width: 102px;
}

.c-form__item-free-wrapper li:nth-child(2) {
  width: 65px;
}

.c-form__item-free-wrapper li:nth-child(3) {
  width: 62px;
}

.c-form__item-free-add,
.c-form__item-free-delete {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
}

.c-form__item-free-delete {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-left: auto;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  width: 30px;
  height: 30px;
  background-color: rgba(162, 26, 26, 0.15);
  border-radius: 50%;
  -webkit-transition: background-color 300ms;
  transition: background-color 300ms;
}

.c-form__item-free-delete:hover {
  background-color: rgba(162, 26, 26, 0.3);
}

.c-form__item-free-delete::before {
  display: block;
  content: "";
  width: 10px;
  height: 10px;
  background-image: url("../image/icon-delete-01.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.c-form__item-free-delete span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}

.c-form__item-free-add {
  margin: 10px 0 5px auto;
  font-size: 1.2rem;
  line-height: 1.8;
  text-decoration: underline;
}

.c-form__item-free-add:hover {
  text-decoration: none;
}

.c-form__label {
  display: block;
  margin-bottom: 10px;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.85;
}

.c-form__label[data-label="center"] {
  text-align: center;
  font-size: 1.6rem;
}

.c-form__label[data-label="center"] span {
  font-size: 1.6rem;
}

.c-form__label span {
  margin-right: 5px;
  color: #c71a1a;
  line-height: 1.8;
}

.c-form__label small {
  font-size: 1rem;
}

.c-form__label button,
.c-form__label a {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: none;
  border: none;
  cursor: pointer;
  display: inline-block;
  margin-left: 4px;
  color: #2d2d2d;
  font-size: 1.1rem;
  font-weight: 300;
  line-height: 1.7;
  text-decoration: underline;
}

.c-form__label button:hover,
.c-form__label a:hover {
  text-decoration: none;
}

.c-form__item-blood .c-form__label,
.c-form__item-free-wrapper .c-form__label {
  margin-bottom: 5px;
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1.8;
}

.c-form__item-blood .c-form__label span,
.c-form__item-free-wrapper .c-form__label span {
  margin-right: 0;
  color: #2d2d2d;
  font-size: 1rem;
}

.c-form__item-blood .c-form__label sup,
.c-form__item-free-wrapper .c-form__label sup {
  margin-left: 3px;
  color: #c71a1a;
  font-size: 1.2rem;
  vertical-align: baseline;
}

.c-form__item[data-item="separate"] .c-form__label {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  width: 82px;
  font-size: 1.2rem;
  font-weight: 400;
}

.c-form__text[data-status="hidden"] input,
.c-form__email[data-status="hidden"] input,
.c-form__password[data-status="hidden"] input,
.c-form__number[data-status="hidden"] input {
  background-color: #d9d9d9;
}

.c-form__text input,
.c-form__email input,
.c-form__password input,
.c-form__number input {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  padding: 12px 15px;
  width: 100%;
  font-size: 1.6rem;
  border: 1px solid #d9d9d9;
  border-radius: 2px;
}

.c-form__text input[aria-invaild="true"],
.c-form__email input[aria-invaild="true"],
.c-form__password input[aria-invaild="true"],
.c-form__number input[aria-invaild="true"] {
  border: 1px solid #c71a1a;
}

.c-form__item-free-wrapper .c-form__text input,
.c-form__item-free-wrapper .c-form__number input {
  padding: 3px 10px;
  border-radius: 0;
}

.c-modal__wrapper[data-modal="secondary"] .c-form__text {
  position: relative;
}

.c-modal__wrapper[data-modal="secondary"] .c-form__text > a {
  position: absolute;
  top: 15px;
  right: 16px;
  color: #2d2d2d;
  font-size: 1.4rem;
  line-height: 1.5;
}

.c-modal__wrapper[data-modal="secondary"] .c-form__text > a:hover {
  text-decoration: none;
}

.c-form__select {
  position: relative;
}

.c-form__select[data-status="hidden"] select {
  background-color: #d9d9d9;
}

.c-form__select::before {
  position: absolute;
  top: 21px;
  right: 19px;
  display: block;
  content: "";
  width: 8px;
  height: 8px;
  background-image: url("../image/icon-arrow-02.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-form__select[data-width="long"] {
  width: 255px;
}

.c-form__select[data-width="large"] {
  width: 233px;
}

.c-form__select[data-width="medium"] {
  width: 105px;
}

.c-form__select[data-width="small"] {
  width: 85px;
}

.c-form__select[data-width="minimum"] {
  width: 78px;
}

.c-form__select select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 100%;
  padding: 12px 30px 12px 15px;
  font-size: 1.6rem;
  background-color: #fff;
  border: 1px solid #d9d9d9;
  border-radius: 2px;
}

.c-form__select select[aria-hidden="true"] {
  display: none;
}

.c-form__item-wrapper .c-form__number + .c-form__select {
  margin-left: 5px;
}

.c-form__item-wrapper .c-form__select + .c-form__select {
  margin-left: 10px;
}

.c-form__radio li .c-form__select[data-status="hidden"] select {
  color: #fff;
  background-color: #8d8d8d;
}

.c-form__radio li .c-form__select::before {
  top: 13px;
  right: 14px;
  background-image: url("../image/icon-arrow-06.svg");
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

.c-form__radio li .c-form__select select {
  padding: 4px 8px;
}

.c-form__item[data-item="separate"] .c-form__select {
  width: 100%;
}

.c-form__number[data-width="long"] {
  max-width: 95px;
}

.c-form__number[data-width="large"] {
  max-width: 89px;
}

.c-form__number[data-width="default"] {
  max-width: 85px;
}

.c-form__number[data-width="medium"] {
  max-width: 78px;
}

.c-form__number[data-width="small"] {
  max-width: 68px;
}

.c-form__number[data-width="minimum"] {
  max-width: 50px;
}

.c-form__number[data-width="blood"], .c-form__number[data-width="credit"] {
  max-width: 72px;
}

.c-form__number[data-width="credit"] + .c-form__number[data-width="credit"] {
  margin-left: 5px;
}

.c-form__number[data-status="hidden"] input {
  font-weight: 600;
}

.c-form__item-blood .c-form__number {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
}

.c-form__item-blood .c-form__number input {
  padding: 3px 10px;
  border-radius: 0;
}

.c-form__radio li .c-form__number[data-status="hidden"] input {
  background-color: #8d8d8d;
}

.c-form__radio li .c-form__number input {
  padding: 4px 8px;
}

.c-form__textarea {
  line-height: 1;
}

.c-form__textarea[data-height="minimum"] textarea {
  min-height: 24px;
}

.c-form__textarea[data-height="medium"] textarea {
  min-height: 120px;
}

.c-form__textarea[data-height="large"] textarea {
  min-height: 135px;
}

.c-form__textarea[data-height="maximum"] textarea {
  min-height: 200px;
}

.c-form__textarea[data-status="disable"] {
  pointer-events: none;
}

.c-form__textarea[data-status="disable"] textarea {
  background-color: #d9d9d9;
}

.c-form__textarea textarea {
  padding: 12px 15px;
  width: 100%;
  min-height: 80px;
  font-size: 1.6rem;
  resize: vertical;
  border: 1px solid #d9d9d9;
  border-radius: 2px;
}

.c-form__textarea textarea[aria-invaild="true"] {
  border: 1px solid #c71a1a;
}

.c-program__exercise-item .c-form__textarea[data-height="medium"] textarea {
  min-height: 110px;
}

.c-form__profile {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-form__profile label {
  position: relative;
  width: 125px;
  padding: 7px 10px 8px;
  color: #fff;
  font-weight: 600;
  font-size: 1.4rem;
  line-height: 1.8;
  text-align: center;
  background-color: #2d2d2d;
  border-radius: 2px;
  cursor: pointer;
  -webkit-box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
          box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
  -webkit-transition: background-color 300ms, -webkit-box-shadow 300ms;
  transition: background-color 300ms, -webkit-box-shadow 300ms;
  transition: background-color 300ms, box-shadow 300ms;
  transition: background-color 300ms, box-shadow 300ms, -webkit-box-shadow 300ms;
}

.c-form__profile label:hover {
  background-color: #333;
  -webkit-box-shadow: 0 4px 10px rgba(0, 0, 0, 0);
          box-shadow: 0 4px 10px rgba(0, 0, 0, 0);
}

.c-form__profile label input {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  z-index: 10;
  cursor: pointer;
}

.c-form__profile-thumbnail {
  margin-right: 20px;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  width: 100px;
  height: 100px;
  background-image: url("../image/dummy-profile.svg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #fff;
  border: 1px solid #d9d9d9;
  border-radius: 50%;
  overflow: hidden;
}

.c-form__profile-name {
  font-weight: 600;
  font-size: 1.3rem;
  line-height: 1.85;
  letter-spacing: .05em;
}

.c-form__profile-name span {
  display: block;
  font-weight: 300;
}

.c-form__record-image {
  margin: 8px 0 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-form__record-image[aria-hidden="true"] {
  display: none;
}

.c-form__record-image-thumbnail {
  margin-right: 11px;
  width: 120px;
  background-color: #8d8d8d;
}

.c-form__record-image-delete {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  color: #c71a1a;
  font-size: 1.4rem;
  line-height: 1.8;
  text-decoration: underline;
}

.c-form__record-image-delete:hover {
  text-decoration: none;
}

.c-form__record-image-add {
  position: relative;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  padding: 7px 14px;
  background-color: #2d2d2d;
  -webkit-transition: backgorund-color 300ms;
  transition: backgorund-color 300ms;
}

.c-form__record-image-add:hover {
  background-color: #333;
}

.c-form__record-image-add input {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  z-index: 10;
  cursor: pointer;
}

.c-form__record-image-add span {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  color: #fff;
  font-size: 1.3rem;
  font-weight: 600;
  line-height: 1.8;
}

.c-form__record-image-add span::before {
  display: inline-block;
  content: "";
  width: 11px;
  height: 11px;
  margin-right: 4px;
  background-image: url("../image/icon-add-02.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

p + .c-form__record-image-add {
  margin-top: 10px;
}

.c-form__submit-check {
  margin-bottom: 20px;
  position: relative;
  text-align: center;
}

.c-form__submit-check[data-check="left"] label {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-form__submit-check input {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  z-index: 10;
  cursor: pointer;
}

.c-form__submit-check label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  color: #333;
  font-size: 1.4rem;
  line-height: 1.8;
  font-family: "Noto Sans CJK JP", Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Arial, "メイリオ", Meiryo, sans-serif;
}

.c-form__submit-check label::before {
  display: block;
  content: "";
  margin: 0 10px 1px 0;
  width: 16px;
  height: 16px;
  background-color: #fff;
  border: 1px solid #d9d9d9;
}

.c-form__submit-check input:hover + label,
.c-form__submit-check input:checked + label {
  color: #e56813;
}

.c-form__submit-check input:checked + label::before {
  background-color: #e56813;
}

.c-program__exercise-item .c-form__submit-check {
  margin: 5px 0 0;
}

.c-form__note {
  margin-top: 10px;
}

.c-form__note[data-type="secondary"] li {
  color: #8d8d8d;
  padding: 0;
  text-indent: 0;
}

.c-form__note li {
  font-size: 1.1rem;
  line-height: 1.5;
  padding-left: 1em;
  padding-right: 20px;
  text-indent: -1em;
  font-family: "Noto Sans CJK JP", Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Arial, "メイリオ", Meiryo, sans-serif;
}

.c-form__note li strong {
  color: #c71a1a;
}

.c-form__note li em {
  font-style: normal;
  color: #c71a1a;
}

.c-form__note li + li {
  margin-top: 3px;
}

.c-form__item[data-item="height-weight"] .c-form__note {
  width: 100%;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
}

.c-form__attention {
  margin-top: 10px;
  color: #c71a1a;
  font-size: 1.2rem;
  line-height: 1.65;
  letter-spacing: .05em;
}

.c-form__attention b {
  font-weight: 600;
}

.c-form__confirm dd .c-form__attention {
  margin-top: 5px;
}

.c-form__link {
  margin-top: 10px;
  text-align: right;
  line-height: 1;
}

.c-form__link a {
  color: #2d2d2d;
  font-size: 1.2rem;
  line-height: 1.8;
}

.c-form__read {
  display: block;
  margin-bottom: 20px;
  padding: 20px;
  max-height: 163px;
  background-color: #fff;
  border: 1px solid #d9d9d9;
  border-radius: 2px;
  overflow-y: scroll;
}

.c-form__read h2 {
  margin-bottom: 15px;
  font-weight: 600;
  font-size: 1.3rem;
  line-height: 1.9;
}

.c-form__read p,
.c-form__read dt,
.c-form__read dd {
  font-size: 1.2rem;
  line-height: 1.8;
}

.c-form__read p,
.c-form__read dd {
  margin-bottom: 10px;
}

.c-form__read dt {
  font-weight: 600;
  margin-bottom: 5px;
}

.c-form__item .c-form__read {
  margin-bottom: 10px;
}

.c-form__confirm {
  margin-bottom: 5px;
}

.c-form__confirm[data-type="card"] {
  padding: 20px 20px 10px;
  margin-bottom: 20px;
  background-color: #fff;
  border: 1px solid #d9d9d9;
}

.c-form__confirm[data-type="card"] dl > div:last-child {
  margin-bottom: 10px;
}

.c-form__confirm dl > div {
  margin-bottom: 20px;
}

.c-form__confirm dl dt,
.c-form__confirm dl dd {
  font-size: 1.4rem;
  line-height: 1.85;
  letter-spacing: .05em;
}

.c-form__confirm dl dt {
  margin-bottom: 5px;
  font-weight: 600;
}

.c-form__confirm dl div dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.c-form__confirm dl div dl div {
  margin-right: 20px;
  margin-bottom: 0;
}

.c-form__confirm .c-form__confirm-blood {
  background-color: #fff;
  border: 1px solid #d9d9d9;
}

.c-form__confirm .c-form__confirm-blood > dl,
.c-form__confirm-blood > dl {
  padding: 14px 4px 6px 19px;
}

.c-form__confirm .c-form__confirm-blood > dl,
.c-form__confirm .c-form__confirm-blood > dl dl,
.c-form__confirm-blood > dl,
.c-form__confirm-blood > dl dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.c-form__confirm .c-form__confirm-blood > dl + dl,
.c-form__confirm-blood > dl + dl {
  border-top: 1px solid #d9d9d9;
}

.c-form__confirm .c-form__confirm-blood > dl div,
.c-form__confirm-blood > dl div {
  margin: 0 14px 10px 0;
}

.c-form__confirm .c-form__confirm-blood > dl div[data-box="free"],
.c-form__confirm-blood > dl div[data-box="free"] {
  margin: 0;
}

.c-form__confirm .c-form__confirm-blood dt,
.c-form__confirm .c-form__confirm-blood dd,
.c-form__confirm-blood dt,
.c-form__confirm-blood dd {
  font-size: 1.4rem;
  line-height: 1.85;
  letter-spacing: .05em;
}

.c-form__confirm .c-form__confirm-blood > dl dt,
.c-form__confirm-blood > dl dt {
  margin-bottom: 3px;
  font-weight: 600;
}

.c-form__confirm .c-form__confirm-blood > dl dt[data-title="free"],
.c-form__confirm-blood > dl dt[data-title="free"] {
  margin-bottom: 7px;
}

.c-form__confirm .c-form__confirm-blood dd span,
.c-form__confirm-blood dd span {
  font-size: 1.2rem;
}

.c-form__confirm .c-form__confirm-blood sup,
.c-form__confirm-blood sup {
  color: #a21a1a;
  font-size: 1.4rem;
  line-height: 1.85;
  vertical-align: baseline;
}

.c-form__confirm .c-form__confirm-blood h2,
.c-form__confirm-blood h2 {
  margin-bottom: 10px;
  font-size: 1.4rem;
  line-height: 1.85;
}

.c-form__confirm .c-form__confirm-type {
  padding: 14px 15px 19px;
  background-color: #fff;
  border: 1px solid #d9d9d9;
}

.c-form__confirm .c-form__confirm-type dl {
  display: block;
}

.c-form__confirm .c-form__confirm-type dl dt {
  margin-bottom: 3px;
  color: #e56813;
  font-size: 1.4rem;
  line-height: 1.8;
}

.c-form__confirm .c-form__confirm-type dl dd {
  font-size: 1.2rem;
  line-height: 1.7;
}

.c-form__error {
  margin-top: 10px;
  padding: 11px 15px;
  border: 1px solid #c71a1a;
  border-radius: 2px;
  background-color: #f5e6e6;
}

.c-form__error[data-error="all"] {
  background-color: #c71a1a;
  margin: 0 0 30px;
}

.c-form__error[data-error="all"] p {
  color: #fff;
}

.c-form__error p {
  color: #c71a1a;
  font-weight: 600;
  font-size: 1.4rem;
  line-height: 1.85;
  letter-spacing: .05em;
}

.c-form__radio ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.c-form__radio ul[data-list="column"] {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.c-form__radio li {
  margin-right: 10px;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  font-size: 1rem;
  line-height: 1;
}

.c-form__radio li[data-radio="inactive"] {
  pointer-events: none;
  opacity: .4;
}

.c-form__radio input[type="radio"] {
  position: relative;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  margin-top: 4px;
  margin-right: 5px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: none;
  background-color: #fff;
  border: 1px solid #d9d9d9;
  cursor: pointer;
}

@media screen and (min-width: 767px) {
  .c-form__radio input[type="radio"] {
    width: 18px;
    height: 18px;
    margin-right: 10px;
  }
}

.c-form__radio input[type="radio"]:checked {
  border: 1px solid #e56813;
  background-color: none;
}

.c-form__radio input[type="radio"]:checked::before {
  display: block;
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: #e56813;
}

@media screen and (min-width: 767px) {
  .c-form__radio input[type="radio"]:checked::before {
    width: 12px;
    height: 12px;
  }
}

.c-form__radio input[type="radio"]:checked + label {
  color: #e56813;
  font-weight: 700;
}

.c-form__radio label {
  margin-bottom: 0;
  width: calc(100% - 21px);
  color: #2d2d2d;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.8;
  cursor: pointer;
}

@media screen and (min-width: 767px) {
  .c-form__radio label {
    font-size: 1.5rem;
  }
}

.c-modal .c-form__radio li {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.c-form__credit-item .c-form__radio {
  padding: 14px 15px;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  font-size: 1rem;
  line-height: 1;
}

.c-form__radiolist {
  width: 100%;
  padding: 10px 14px;
  background-color: #fff;
  border-radius: 2px;
  border: 1px solid #d9d9d9;
}

.c-form__radiolist[aria-hidden="true"] {
  display: none;
}

.c-form__radiolist span {
  display: block;
  font-size: 1.3rem;
  font-weight: 600;
  line-height: 1.8;
}

.c-form__radiolist .c-form__radio + span,
.c-form__radiolist ul + span {
  margin-top: 10px;
}

.c-form__radiolist > p {
  font-size: 1.4rem;
  line-height: 1.47;
}

.c-form__item-text + .c-form__radio {
  margin-top: 7px;
}

.c-modal .c-form__radio ul[data-list="column"] li + li {
  margin-top: 6px;
}

.c-form__checkbox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-form__checkbox + .c-form__checkbox {
  margin-top: 5px;
}

.c-form__checkbox[data-checkbox="disable"] {
  pointer-events: none;
}

.c-form__checkbox[data-checkbox="disable"] input[type="checkbox"] {
  background-color: #d9d9d9;
}

.c-form__checkbox > input[type="checkbox"] {
  position: relative;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  margin-top: 1px;
  margin-right: 5px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 16px;
  height: 16px;
  background: none;
  background-color: #f7f7f6;
  border: 1px solid #d9d9d9;
  border-radius: 0;
  cursor: pointer;
}

@media screen and (min-width: 767px) {
  .c-form__checkbox > input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin-right: 10px;
  }
}

.c-form__checkbox > input[type="checkbox"]:checked {
  border: 1px solid #f7f7f6;
}

.c-form__checkbox > input[type="checkbox"]:checked::before {
  display: block;
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 10px;
  height: 10px;
  background-color: #e56813;
}

@media screen and (min-width: 767px) {
  .c-form__checkbox > input[type="checkbox"]:checked::before {
    width: 12px;
    height: 12px;
  }
}

.c-form__checkbox > input[type="checkbox"]:checked + label {
  color: #e56813;
  font-weight: 600;
}

.c-form__checkbox > label {
  margin-bottom: 0;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.5;
  cursor: pointer;
}

@media screen and (min-width: 767px) {
  .c-form__checkbox > label {
    font-size: 1.5rem;
  }
}

.c-registered__item-check .c-form__checkbox > input[type="checkbox"] {
  background-color: #d9d9d9;
  border: 1px solid #d9d9d9;
}

.c-form__item-text p {
  margin-top: 6px;
  font-size: 1.2rem;
  line-height: 1.7;
}

.c-form__item-text p span {
  color: #c71a1a;
}

.c-form__item-text p span strong {
  font-weight: 600;
}

.c-form__item-text p strong {
  color: #c71a1a;
  font-weight: 500;
}

.c-form__label + .c-form__item-text p {
  margin: 0 0 10px;
}

.c-form__pdf {
  padding: 16px 20px;
  margin-bottom: 7px;
  line-height: 1;
  background-color: #fff;
  border: 1px solid #d9d9d9;
}

.c-form__pdf a {
  color: #2d2d2d;
  font-size: 1.3rem;
  line-height: 1.46;
}

.c-form__pdf a:hover {
  text-decoration: none;
}

.c-form__picture-list {
  margin-top: 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.c-form__picture-list li {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  margin: 0 10px 10px 0;
  width: 120px;
}

.c-form__record .c-form__picture-list {
  margin-top: 10px;
}

.c-form__record {
  padding: 20px 20px 10px;
  background-color: #fff;
  border: 1px solid #d9d9d9;
}

.c-form__record + .c-form__record {
  margin-top: 10px;
}

.c-form__record p {
  margin-bottom: 10px;
  font-size: 1.4rem;
  line-height: 1.85;
  letter-spacing: .05em;
}

.c-form__record dl div:last-child {
  margin-bottom: 0;
}

.c-form__confirm .c-form__record dl {
  display: block;
}

.c-form__confirm .c-form__record dl div + div {
  margin-left: 0;
}

.c-form__confirm .c-form__record dl > div {
  margin-bottom: 15px;
}

.c-form__confirm .c-form__record dl > div:last-child {
  margin-bottom: 0;
}

.c-form__credit {
  margin-bottom: 30px;
}

.c-plan__heading + .c-form__credit {
  margin-top: 15px;
}

.c-form__credit-item {
  border: 1px solid #d9d9d9;
  background-color: #fff;
}

.c-form__credit-item + .c-form__credit-item {
  margin-top: 10px;
}

.c-form__credit-information {
  padding: 15px 16px 8px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  border-top: 1px solid #d9d9d9;
}

.c-form__credit-information[aria-hidden="true"] {
  display: none;
}

.c-form__credit-information div {
  margin: 0 20px 8px 0;
}

.c-form__credit-information dt,
.c-form__credit-information dd {
  font-size: 1.4rem;
  line-height: 1.85;
}

.c-form__credit-information dt {
  margin-bottom: 3px;
  font-weight: 600;
}

.c-form__card .c-form__credit-information {
  padding: 0 0 9px;
  border-top: none;
}

.c-form__credit-register {
  padding: 19px 16px 0;
  margin-bottom: 30px;
  background-color: #fff;
  border: 1px solid #d9d9d9;
}

.c-form__credit-register > p {
  font-size: 1.1rem;
  line-height: 1.45;
}

.c-form__credit-item .c-form__credit-register {
  border: none;
  border-top: 1px solid #d9d9d9;
}

.c-form__credit-item .c-form__credit-register[aria-hidden="true"] {
  display: none;
}

.c-form__credit-register-image {
  margin: 10px 0 15px;
  height: 18px;
  background-color: #8d8d8d;
}

.c-form__fixed {
  position: fixed;
  bottom: 45px;
  left: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 100%;
  padding: 8px 10px 7px 14px;
  line-height: 1.45;
  background-color: rgba(45, 45, 45, 0.95);
}

@media screen and (min-width: 1000px) {
  .c-form__fixed {
    bottom: 0;
    left: auto;
    right: 0;
    width: 400px;
  }
}

.c-form__fixed h2,
.c-form__fixed p {
  color: #fff;
}

.c-form__fixed h2 {
  font-size: 1.3rem;
}

.c-form__fixed h2 span {
  font-size: 1.8rem;
}

.c-form__fixed p {
  font-size: 1.1rem;
}

.c-form__accordion-button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  margin-bottom: 0;
  width: 100%;
  padding: 13px 20px 14px;
  color: #fff;
  font-size: 1.4rem;
  line-height: 1.8;
  background-color: #8d8d8d;
  -webkit-transition: margin-bottom 300ms;
  transition: margin-bottom 300ms;
}

.c-form__accordion-button[aria-expanded="false"] {
  margin-bottom: 30px;
}

.c-form__accordion-button[aria-expanded="true"] span::after {
  -webkit-transform: rotate(0deg);
          transform: rotate(0deg);
}

.c-form__accordion-button[aria-expanded="false"] span::after {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

.c-form__accordion-button[data-button="secondary"] {
  padding: 0;
  color: #2d2d2d;
  font-size: 1.2rem;
  background-color: transparent;
  text-decoration: underline;
}

.c-form__accordion-button[data-button="secondary"][aria-expanded="true"] {
  color: #e56813;
}

.c-form__accordion-button[data-button="secondary"][aria-expanded="true"] span::after {
  background-image: url("../image/icon-arrow-01.svg");
  -webkit-transform: rotate(30deg);
          transform: rotate(30deg);
}

.c-form__accordion-button[data-button="secondary"]:hover {
  text-decoration: none;
}

.c-form__accordion-button[data-button="secondary"] span::after {
  margin-left: 6px;
  background-image: url("../image/icon-arrow-02.svg");
  -webkit-transform: rotate(0deg);
          transform: rotate(0deg);
}

.c-form__accordion-button span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-form__accordion-button span::after {
  display: block;
  content: "";
  margin-left: auto;
  width: 8px;
  height: 8px;
  background-image: url("../image/icon-arrow-06.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  -webkit-transition: -webkit-transform 300ms;
  transition: -webkit-transform 300ms;
  transition: transform 300ms;
  transition: transform 300ms, -webkit-transform 300ms;
}

.c-form__record-input {
  margin-top: 15px;
}

.c-form__record-input > p {
  margin-top: 10px;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.5;
}

.c-form__record-input-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-form__record-input-wrapper input {
  margin-right: 6px;
  max-width: 59px;
  padding: 2px 6px;
  font-size: 1.6rem;
  line-height: 1;
  border-radius: 0;
  border: 1px solid #d9d9d9;
}

.c-form__record-input-wrapper span {
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.46;
}

.c-form__record-input-degree {
  margin-top: 10px;
}

.c-form__record-input-degree dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 5px;
}

.c-form__record-input-degree dl dt,
.c-form__record-input-degree dl dd {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  font-size: 1.1rem;
}

.c-form__record-input-degree dl dt::after {
  display: block;
  content: "...";
}

.c-form__record-input-degree dl dd + dt::before {
  display: block;
  content: "/";
}

.c-form__record-input-degree-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border: 1px solid #d9d9d9;
}

.c-form__record-input-degree-wrapper li {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 10%;
  text-align: center;
}

.c-form__record-input-degree-wrapper li + li {
  border-left: 1px solid #d9d9d9;
}

.c-form__record-input-degree-wrapper input {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  opacity: 0;
}

.c-form__record-input-degree-wrapper input:checked + label {
  color: #fff;
  background-color: #128d70;
}

.c-form__record-input-degree-wrapper label {
  width: 100%;
  color: #2d2d2d;
  font-family: "Roboto", "Helvetica Neue", Helvetica, Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Arial, "メイリオ", Meiryo, sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  background-color: #fff;
  -webkit-transition: color 300ms, background-color 300ms;
  transition: color 300ms, background-color 300ms;
  cursor: pointer;
}

.c-form__record-errror {
  margin-top: 15px;
}

.c-form__record-errror p {
  color: #c71a1a;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.5;
}

.c-form__program-check input {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: none;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid #d9d9d9;
  background-color: #fff;
  -webkit-transition: background-color 300ms;
  transition: background-color 300ms;
}

.c-form__program-check input:hover {
  border: 1px solid #128d70;
}

.c-form__program-check input:focus {
  border: 1px solid #d9d9d9;
}

.c-form__program-check input:checked {
  background-color: #128d70;
  border: 1px solid #128d70;
}

.c-form__program-check input:checked::before {
  background-image: url("../image/icon-check-01.svg");
}

.c-form__program-check input::before {
  display: block;
  content: "";
  width: 12px;
  height: 10px;
  background-image: url("../image/icon-check-03.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background-color: #2d2d2d;
}

.c-header[data-header="forclient"] {
  border-bottom: 1px solid #d9d9d9;
}

@media screen and (min-width: 1000px) {
  .c-header {
    position: fixed;
    top: 0;
    left: 0;
    display: block;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 auto;
            flex: 0 0 auto;
    height: 100vh;
    width: 265px;
    background-color: #fff;
    -webkit-box-shadow: 0 1px 10px rgba(0, 0, 0, 0.1);
            box-shadow: 0 1px 10px rgba(0, 0, 0, 0.1);
  }
}

.c-header__wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
}

@media screen and (min-width: 1000px) {
  .c-header__wrapper {
    background-color: #2d2d2d;
  }
}

.c-header__logo {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
}

.c-header__logo a {
  line-height: 1;
}

@media screen and (min-width: 1000px) {
  .c-header__logo img {
    width: 63px;
    height: auto;
  }
}

.c-header__title {
  width: calc(100% - 60px);
  padding: 24px;
  text-align: center;
  line-height: 0;
}

.c-header__title[data-title="client"] {
  padding: 17px 20px 13px;
  background-color: #fff;
}

@media screen and (min-width: 1000px) {
  .c-header__title {
    width: 100%;
    max-width: 202px;
  }
}

.c-header__title a {
  font-size: 1rem;
  line-height: 1;
}

.c-header__menu-button,
.c-header__search-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (min-width: 1000px) {
  .c-header__menu-button,
  .c-header__search-button {
    display: none;
  }
}

.c-header__menu-button button,
.c-header__search-button button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 60px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  background-color: rgba(255, 255, 255, 0.15);
  cursor: pointer;
}

.c-header__menu-button span,
.c-header__search-button span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}

.c-header__title[data-title="client"] + .c-header__menu-button button,
.c-header__title[data-title="client"] + .c-header__search-button button {
  background-color: #2d2d2d;
}

.c-header__menu-button button {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.c-header__menu-button button::before,
.c-header__menu-button button::after {
  display: block;
  content: "";
  margin: 2px 0;
  width: 20px;
  height: 1px;
  background-color: #fff;
}

.c-header__search-button button::before {
  display: block;
  content: "";
  width: 30px;
  height: 30px;
  background-image: url("../image/icon-search-01.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-heading__page {
  margin-bottom: 25px;
  padding: 24px 20px 25px;
  text-align: center;
  background-color: #fff;
  border-bottom: 1px solid #d9d9d9;
}

@media screen and (min-width: 1000px) {
  .c-heading__page {
    padding: 55px 44px;
    text-align: left;
  }
}

.c-heading__page span {
  display: block;
  font-weight: 600;
  font-size: 1.1rem;
  line-height: 1.45;
}

@media screen and (min-width: 1000px) {
  .c-heading__page span {
    font-size: 1.4rem;
    line-height: 1;
  }
}

.c-heading__page h1,
.c-heading__page h2 {
  color: #2d2d2d;
  font-size: 1.6rem;
  line-height: 1.5;
}

@media screen and (min-width: 1000px) {
  .c-heading__page h1,
  .c-heading__page h2 {
    font-size: 2.2rem;
  }
}

.c-heading__center {
  margin-bottom: 15px;
  text-align: center;
}

.c-heading__center[data-separate="header"] {
  margin-top: 20px;
}

.c-heading__center h2 {
  font-size: 1.6rem;
  line-height: 1.85;
}

.c-record-list + .c-heading__center,
.c-package__list + .c-heading__center {
  margin-top: 30px;
}

.c-heading {
  margin-bottom: 10px;
}

.c-heading h2 {
  font-size: 1.4rem;
  line-height: 1.85;
}

.c-heading h2 span {
  display: inline-block;
  margin-left: 5px;
  color: #e56813;
  font-weight: 600;
  font-size: 1.2rem;
  line-height: 1.85;
}

.c-link-list {
  width: 100%;
}

@media screen and (min-width: 767px) {
  .c-link-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

.c-link-list[data-separate="header"] {
  margin-top: 20px;
}

@media screen and (min-width: 1000px) {
  .c-link-list[data-separate="header"] {
    margin-top: 30px;
  }
}

.c-link-list[data-list="category"] > li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: stretch;
      -ms-flex-pack: stretch;
          justify-content: stretch;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.c-link-list[aria-hidden="true"] {
  display: none;
}

.c-link-list[data-list="secondary"] a span,
.c-link-list[data-list="secondary"] button span {
  display: block;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  width: 100%;
  margin: 4px 0 0 0;
  padding: 0;
  font-weight: 400;
  font-size: 1.2rem;
  text-align: left;
  border: none;
}

.c-link-list[data-list="secondary"] a,
.c-link-list[data-list="secondary"] button {
  text-align: left;
}

.c-link-list[data-list="tertiary"] button span {
  display: block;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  margin: 0;
  padding: 0;
  width: 100%;
  color: #2d2d2d;
  font-size: 1.1rem;
  font-weight: 400;
  line-height: 1.45;
  text-align: left;
  border: none;
}

.c-link-list[data-list="tertiary"] button span b {
  color: #2d2d2d;
  font-weight: 600;
}

@media screen and (min-width: 767px) {
  .c-link-list > li {
    width: calc(50% - 10px);
    margin-bottom: 15px;
  }
}

.c-link-list > li + li {
  margin-top: 10px;
}

@media screen and (min-width: 767px) {
  .c-link-list > li:nth-child(2) {
    margin-top: 0;
  }
}

@media screen and (min-width: 767px) {
  .c-link-list > li:nth-child(even) {
    margin-left: 20px;
  }
}

.c-link-list button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  width: 100%;
}

.c-link-list a,
.c-link-list button {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  padding: 17px 21px 16px 20px;
  color: #2d2d2d;
  font-size: 1.4rem;
  line-height: 1.5;
  text-align: left;
  background-color: #fff;
  border: 1px solid #d9d9d9;
  -webkit-transition: border 300ms;
  transition: border 300ms;
}

.c-link-list a:hover,
.c-link-list button:hover {
  border: 1px solid #e56813;
}

.c-link-list a::after,
.c-link-list button::after {
  position: absolute;
  top: calc(50% - 4px);
  right: 22px;
  display: block;
  content: "";
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  width: 8px;
  height: 8px;
  margin-left: auto;
  -webkit-transform: rotate(30deg);
          transform: rotate(30deg);
  background-image: url("../image/icon-arrow-02.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-link-list a span,
.c-link-list button span {
  display: inline-block;
  margin-left: 14px;
  padding: 1px 8px;
  color: #e56813;
  font-weight: 600;
  font-size: 1rem;
  line-height: 1.5;
  border: 1px solid #d9d9d9;
}

.c-link-list a b,
.c-link-list button b {
  font-weight: 500;
  color: #c71a1a;
}

.c-link-list a sup,
.c-link-list button sup {
  color: #c71a1a;
}

.c-link-list a {
  text-decoration: none;
}

.c-link-list a[data-status="inactive"] {
  opacity: .5;
  pointer-events: none;
}

.c-link-list a[data-link="category"] {
  font-weight: 600;
}

.c-link-list dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 100%;
  padding: 17px 20px;
  background-color: #fff;
  border: 1px solid #d9d9d9;
  border-top: none;
}

.c-link-list dl dt,
.c-link-list dl dd {
  font-size: 1.2rem;
  line-height: 1.5;
}

.c-link-list dl dt {
  margin-bottom: 8px;
  font-weight: 600;
}

.c-link-list dl ol li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  font-size: 1.2rem;
  line-height: 1.8;
}

.c-link-list dl ol span {
  display: inline-block;
  margin-right: 10px;
}

.c-menu {
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  min-height: 100%;
  z-index: 15;
  overflow: scroll;
  visibility: visible;
  opacity: 1;
  -webkit-transition: visibility 300ms, opacity 300ms;
  transition: visibility 300ms, opacity 300ms;
}

.c-menu[aria-hidden="true"] {
  visibility: hidden;
  opacity: 0;
}

.c-menu__wrapper {
  position: absolute;
  top: 0;
  right: 0;
  padding: 80px 20px 60px;
  width: 300px;
  min-height: 100vh;
  background-color: #2d2d2d;
  z-index: 16;
  -webkit-box-shadow: -10px 0 10px rgba(0, 0, 0, 0.1);
          box-shadow: -10px 0 10px rgba(0, 0, 0, 0.1);
  -webkit-transition: right 300ms;
  transition: right 300ms;
}

.c-menu[aria-hidden="true"] .c-menu__wrapper {
  right: -300px;
}

.c-menu[aria-hidden="false"] .c-menu__wrapper {
  right: 0;
}

.c-menu__nav {
  margin-bottom: 15px;
}

.c-menu__nav ul[aria-hidden="true"] {
  display: none;
}

.c-menu__nav li + li {
  margin-top: 5px;
}

.c-menu__nav li ul a {
  padding: 9px 20px 7px 15px;
  background-color: rgba(255, 255, 255, 0.7);
}

.c-menu__nav a {
  display: block;
  padding: 15px 20px 13px 15px;
  color: #2d2d2d;
  font-size: 1.3rem;
  line-height: 1.85;
  text-decoration: none;
  background-color: #fff;
  opacity: 1;
  -webkit-transition: opacity 300ms;
  transition: opacity 300ms;
}

.c-menu__nav a:hover {
  opacity: .85;
}

.c-menu__nav span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.c-menu__nav span::after {
  display: block;
  content: "";
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  margin-left: 6px;
  width: 8px;
  height: 8px;
  background-image: url("../image/icon-arrow-02.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  -webkit-transform: rotate(-90deg);
          transform: rotate(-90deg);
}

.c-menu__nav .c-menu__nav-accordion {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 15px 20px 13px 15px;
  width: 100%;
  color: #2d2d2d;
  font-size: 1.3rem;
  line-height: 1.85;
  text-decoration: none;
  background-color: #fff;
  opacity: 1;
  -webkit-transition: opacity 300ms;
  transition: opacity 300ms;
}

.c-menu__nav .c-menu__nav-accordion:hover {
  opacity: .85;
}

.c-menu__nav .c-menu__nav-accordion[aria-expanded="true"] {
  margin-bottom: 5px;
}

.c-menu__nav .c-menu__nav-accordion[aria-expanded="true"] span::after {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

.c-menu__nav .c-menu__nav-accordion span::after {
  -webkit-transform: rotate(0deg);
          transform: rotate(0deg);
}

.c-menu__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.c-menu__link li {
  margin: 0 15px 5px 0;
  line-height: 1;
}

@media screen and (min-width: 1000px) {
  .c-menu__link li:last-child {
    margin-bottom: 0;
  }
}

.c-menu__link a {
  color: #fff;
  font-size: 1.2rem;
  line-height: 1.85;
  text-decoration: none;
}

.c-menu__link a:hover {
  text-decoration: underline;
}

.c-menu__close {
  position: absolute;
  top: 0;
  right: 0;
}

.c-menu__close-button {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 60px;
  height: 60px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: none;
  border: none;
  cursor: pointer;
  background-color: #fff;
  opacity: 1;
  -webkit-transition: opacity .5;
  transition: opacity .5;
}

.c-menu__close-button:hover {
  opacity: .9;
}

.c-menu__close-button::before, .c-menu__close-button::after {
  position: absolute;
  top: 50%;
  left: calc(50% - 10px);
  display: block;
  content: "";
  width: 20px;
  height: 1px;
  background-color: #2d2d2d;
  -webkit-transform-origin: center;
          transform-origin: center;
}

.c-menu__close-button::before {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}

.c-menu__close-button::after {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

.c-menu__close-button span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}

.c-menu__background {
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  min-height: 100vh;
  background-color: rgba(45, 45, 45, 0.5);
  z-index: 15;
}

.c-menu__plan {
  position: relative;
  padding-bottom: 40px;
  line-height: 1;
}

.c-menu__plan::after {
  position: absolute;
  left: 0;
  bottom: 20px;
  display: block;
  content: "";
  width: 100%;
  height: 1px;
  background-color: rgba(255, 255, 255, 0.2);
}

.c-menu__plan-information {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  margin-bottom: 4px;
}

.c-menu__plan-information div {
  margin-right: 10px;
}

.c-menu__plan-information dt {
  color: #8d8d8d;
  font-size: 1.1rem;
  line-height: 1.45;
}

.c-menu__plan-information dd {
  color: #fff;
  font-size: 1.2rem;
  font-weight: 600;
  line-height: 1.5;
}

.c-menu__plan-information dd span {
  font-size: 1.8rem;
}

.c-menu__plan-change {
  color: #faff00;
  font-size: 1.2rem;
  line-height: 1.5;
}

.c-modal {
  position: fixed;
  top: 0;
  left: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  min-height: 100%;
  z-index: 15;
  overflow: scroll;
  visibility: visible;
  opacity: 1;
  -webkit-transition: visibility 300ms, opacity 300ms;
  transition: visibility 300ms, opacity 300ms;
}

.c-modal[aria-hidden="true"] {
  visibility: hidden;
  opacity: 0;
}

.c-modal__wrapper {
  position: relative;
  width: calc(100% - 40px);
  max-width: 335px;
  z-index: 15;
}

.c-modal__wrapper[data-modal="secondary"] {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  max-width: 100%;
  min-height: 100%;
  background-color: #f7f7f6;
}

.c-modal__wrapper[data-modal="secondary"] h2 {
  color: #2d2d2d;
  margin-bottom: 0;
  font-size: 2rem;
}

.c-modal__wrapper[data-modal="secondary"] h2 span {
  font-size: 1.2rem;
}

.c-modal__wrapper h2 {
  margin-bottom: 20px;
  color: #fff;
  font-size: 1.8rem;
  line-height: 1.5;
  text-align: center;
}

.c-modal__box {
  padding: 20px 20px 30px;
  background-color: #fff;
}

.c-modal__box[data-box="typecheck"] {
  padding: 0;
}

.c-modal__box[data-box="label"] {
  padding-top: 15px;
}

.c-modal__box h3 {
  margin-bottom: 15px;
  color: #2d2d2d;
  font-size: 1.5rem;
  line-height: 1.3;
}

.c-modal__box h3 span {
  display: block;
  margin-bottom: 5px;
  color: #8d8d8d;
  font-size: 1.2rem;
  line-height: 1.5;
}

.c-modal__box dl {
  margin-bottom: 15px;
}

.c-modal__box dl dt {
  color: #2d2d2d;
}

.c-modal__box dl dd {
  color: #8d8d8d;
}

.c-modal__box p {
  margin-bottom: 15px;
  color: #2d2d2d;
  font-size: 1.4rem;
  line-height: 1.85;
}

.c-modal__box p span {
  color: #c71a1a;
}

.c-modal__box p em {
  color: #c71a1a;
  font-weight: 600;
  font-style: normal;
}

.c-package__item .c-modal__box h3 span {
  display: block;
  padding: 0;
  margin: 0 0 5px;
  color: #8d8d8d;
  font-size: 1.2rem;
  line-height: 1.5;
}

.c-modal__button-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.c-modal__button-list li {
  width: calc(50% - 4.5px);
}

.c-modal__button-list li + li {
  margin-left: 9px;
}

.c-modal__button-list button,
.c-modal__button-list a {
  display: block;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  width: 100%;
  padding: 9px;
  color: #fff;
  font-weight: 600;
  font-size: 1.4rem;
  line-height: 1.85;
  text-align: center;
  text-decoration: none;
  border-radius: 25px;
  -webkit-box-shadow: 0 6px 10px rgba(0, 0, 0, 0.15);
          box-shadow: 0 6px 10px rgba(0, 0, 0, 0.15);
  -webkit-transition: background-color 300ms, -webkit-box-shadow 300ms;
  transition: background-color 300ms, -webkit-box-shadow 300ms;
  transition: background-color 300ms, box-shadow 300ms;
  transition: background-color 300ms, box-shadow 300ms, -webkit-box-shadow 300ms;
}

.c-modal__button-list button:hover,
.c-modal__button-list a:hover {
  -webkit-box-shadow: 0 4px 10px rgba(0, 0, 0, 0);
          box-shadow: 0 4px 10px rgba(0, 0, 0, 0);
}

.c-modal__button-list button.c-modal__cancel-button,
.c-modal__button-list a.c-modal__cancel-button {
  background-color: #8d8d8d;
}

.c-modal__button-list button.c-modal__cancel-button:hover,
.c-modal__button-list a.c-modal__cancel-button:hover {
  background-color: #333;
}

.c-modal__button-list button.c-modal__delete-button,
.c-modal__button-list a.c-modal__delete-button {
  background-color: #c71a1a;
}

.c-modal__button-list button.c-modal__delete-button:hover,
.c-modal__button-list a.c-modal__delete-button:hover {
  background-color: #a21a1a;
}

.c-modal__button-list button.c-modal__restart-button,
.c-modal__button-list a.c-modal__restart-button {
  background-color: #128d70;
}

.c-modal__button-list button.c-modal__restart-button:hover,
.c-modal__button-list a.c-modal__restart-button:hover {
  background-color: #08755c;
}

.c-modal__close-button {
  position: fixed;
  top: 0;
  right: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-width: 60px;
  min-height: 60px;
  background-color: #fff;
  -webkit-transition: background-color 300ms;
  transition: background-color 300ms;
  z-index: 15;
}

.c-modal__close-button:hover {
  background-color: #e8e8e8;
}

.c-modal__close-button::before {
  display: block;
  content: "";
  width: 15px;
  height: 15px;
  background-image: url("../image/icon-close-01.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-modal__close-button span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}

.c-modal__wrapper[data-modal="secondary"] + .c-modal__close-button {
  background-color: #333;
}

.c-modal__wrapper[data-modal="secondary"] + .c-modal__close-button:hover {
  background-color: #2d2d2d;
}

.c-modal__wrapper[data-modal="secondary"] + .c-modal__close-button::before {
  background-image: url("../image/icon-delete-02.svg");
}

.c-modal__label {
  display: inline-block;
  margin: 0 0 10px -20px;
  padding: 4px 10px 5px;
  color: #fff;
  font-size: 1.2rem;
  font-weight: 600;
  line-height: 1.5;
}

.c-modal__label[data-label="other"] {
  background-color: #8d8d8d;
}

.c-modal__background {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #2d2d2d;
  z-index: 14;
}

.c-modal__box .c-modal__box-typecheck {
  margin-bottom: 0;
}

.c-modal__box .c-modal__box-typecheck div {
  padding: 17px 15px 20px;
}

.c-modal__box .c-modal__box-typecheck div + div {
  border-top: 1px solid #d9d9d9;
}

.c-modal__box .c-modal__box-typecheck dt {
  margin-bottom: 5px;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.85;
}

.c-modal__box .c-modal__box-typecheck dd {
  color: #2d2d2d;
  font-size: 1.3rem;
  line-height: 1.75;
}

.c-modal__box .c-modal__box-typecheck dd ol {
  margin: 5px 0 15px;
  padding: 10px;
  background-color: #f7f7f6;
}

.c-modal__box .c-modal__box-typecheck dd ol li {
  font-size: 1.3rem;
  line-height: 1.75;
}

.c-modal__header {
  padding: 14px;
  line-height: 1;
  background-color: #fff;
  border-bottom: 1px solid #d9d9d9;
}

.c-modal__back {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-width: 32px;
  min-height: 32px;
  background-color: #4c4c4c;
  border-radius: 50%;
  -webkit-transition: background-color 300ms;
  transition: background-color 300ms;
}

.c-modal__back:hover {
  background-color: #2d2d2d;
}

.c-modal__back::before {
  display: block;
  content: "";
  width: 6px;
  height: 10px;
  background-image: url("../image/icon-arrow-07.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-modal__back span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}

.c-modal__heading {
  line-height: 1;
  margin-bottom: 6px;
}

.c-modal__heading h3 {
  font-size: 1.4rem;
  line-height: 1.85;
}

.c-modal__heading h3 + span {
  display: block;
  margin-bottom: 20px;
  color: #e56813;
  font-size: 1.2rem;
  line-height: 1.5;
}

.c-modal__select-list {
  margin-bottom: 24px;
}

@media screen and (min-width: 767px) {
  .c-modal__select-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

@media screen and (min-width: 767px) {
  .c-modal__select-list li {
    width: calc(50% - 10px);
    margin-bottom: 15px;
  }
}

.c-modal__select-list li > span {
  display: block;
  margin-left: 0;
  border: 1px solid #d9d9d9;
  background-color: #fff;
}

@media screen and (min-width: 767px) {
  .c-modal__select-list li:nth-child(2) {
    margin-top: 0;
  }
}

@media screen and (min-width: 767px) {
  .c-modal__select-list li:nth-child(even) {
    margin-left: 20px;
  }
}

.c-modal__select-list li + li {
  margin-top: 5px;
}

.c-modal__select-list a,
.c-modal__select-list button {
  position: relative;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: none;
  cursor: pointer;
  border: 1px solid #d9d9d9;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  width: 100%;
  background-color: #fff;
}

.c-modal__select-list a {
  text-decoration: none;
  color: #2d2d2d;
}

.c-modal__select-list a::before,
.c-modal__select-list button::before {
  display: block;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 29px;
  height: 100%;
  background-image: url("../image/icon-arrow-07.svg");
  background-size: 6px 10px;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #8d8d8d;
}

.c-modal__select-list span {
  display: block;
  margin-left: 29px;
  padding: 13px 15px 14px;
  font-size: 1.2rem;
  line-height: 1.5;
}

.c-modal__program-list {
  height: 100%;
  overflow: scroll;
}

@media screen and (min-width: 767px) {
  .c-modal__program-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

.c-modal__program-list[data-plan="free"] {
  opacity: .5;
}

.c-modal__program-list[data-program="add"] > li {
  margin-bottom: 10px;
}

@media screen and (min-width: 767px) {
  .c-modal__program-list[data-program="add"] > li {
    margin-bottom: 20px;
  }
}

.c-modal__program-list > li {
  padding: 14px 15px 15px;
  border: 1px solid #d9d9d9;
  background-color: #fff;
}

@media screen and (min-width: 767px) {
  .c-modal__program-list > li {
    width: calc(50% - 10px);
    margin-bottom: 15px;
  }
}

@media screen and (min-width: 767px) {
  .c-modal__program-list > li:nth-child(2) {
    margin-top: 0;
  }
}

@media screen and (min-width: 767px) {
  .c-modal__program-list > li:nth-child(even) {
    margin-left: 20px;
  }
}

.c-modal__program-list > li > a,
.c-modal__program-list span {
  display: inline-block;
  margin-bottom: 20px;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.46;
  color: #2d2d2d;
}

.c-modal__program-list-thumbnail {
  max-width: 304px;
}

.c-modal__program-list-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-modal__program-list-wrapper .c-modal__program-list-thumbnail {
  max-width: 168px;
}

.c-modal__program-list-select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  margin-left: 20px;
  padding: 8px 25px 9px;
  color: #fff;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1;
  text-decoration: none;
  background-color: #e56813;
  -webkit-transition: background-color 300ms;
  transition: background-color 300ms;
}

.c-modal__program-list-select:hover {
  background-color: #ce5607;
}

.c-modal__program-list-tag {
  margin-top: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.c-modal__program-list-tag li {
  margin: 5px 8px 0 0;
  color: #8d8d8d;
  font-size: 1.2rem;
  line-height: 1.5;
}

.c-modal__back-select-button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: none;
  border: none;
  cursor: pointer;
  margin-bottom: 20px;
  font-size: 1.2rem;
  line-height: 1.85;
  text-decoration: underline;
}

.c-modal__back-select-button:hover {
  text-decoration: none;
}

@media screen and (min-width: 767px) {
  .c-notification__list {
    max-width: 640px;
    margin: 20px auto 0;
    border: 1px solid #d9d9d9;
    border-bottom: none;
  }
}

@media screen and (min-width: 1000px) {
  .c-notification__list {
    margin: 30px auto 0 44px;
  }
}

.c-notification__list li {
  border-bottom: 1px solid #d9d9d9;
}

.c-notification__list a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  padding: 20px 18px 17px 20px;
  color: #2d2d2d;
  text-decoration: none;
  background-color: #fff;
  -webkit-transition: background-color 300ms;
  transition: background-color 300ms;
  opacity: .7;
}

.c-notification__list a[data-notification="unread"] {
  opacity: 1;
}

.c-notification__list a:hover {
  background-color: #f7f7f6;
}

.c-notification__list a[data-icon="record"] p em,
.c-notification__list a[data-icon="status01"] p em,
.c-notification__list a[data-icon="graph"] p em {
  color: #c71a1a;
}

.c-notification__list a[data-icon="status03"] p em {
  color: #128d70;
}

.c-notification__list a[data-icon="status01"]::before, .c-notification__list a[data-icon="status02"]::before, .c-notification__list a[data-icon="status03"]::before, .c-notification__list a[data-icon="record"]::before, .c-notification__list a[data-icon="graph"]::before {
  display: block;
  content: "";
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  width: 37px;
  margin-right: 13px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.c-notification__list a[data-icon="status01"]::before, .c-notification__list a[data-icon="status02"]::before, .c-notification__list a[data-icon="status03"]::before {
  height: 37px;
}

.c-notification__list a[data-icon="record"]::before {
  height: 40px;
  background-image: url("../image/icon-record-02.svg");
}

.c-notification__list a[data-icon="graph"]::before {
  height: 29px;
  background-image: url("../image/icon-graph-01.svg");
}

.c-notification__list a[data-icon="status01"]::before {
  background-image: url("../image/icon-status-01.svg");
}

.c-notification__list a[data-icon="status02"]::before {
  background-image: url("../image/icon-status-02.svg");
}

.c-notification__list a[data-icon="status03"]::before {
  background-image: url("../image/icon-status-03.svg");
}

.c-notification__list a > div {
  width: calc(100% - 50px);
}

.c-notification__list a p {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  width: 100%;
  margin-bottom: 5px;
  font-size: 1.2rem;
  line-height: 1.6;
}

.c-notification__list a p span[data-text="name"] {
  font-weight: 600;
}

.c-notification__list a p em {
  font-style: normal;
  font-weight: 600;
}

.c-notification__list a p + span {
  display: block;
  color: #8d8d8d;
  font-size: 1rem;
  line-height: 1.65;
}

.c-notification__list a > div.c-notification__list-thumbnail {
  width: 100%;
  padding-bottom: 40%;
  margin-bottom: 17px;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-notification__tab {
  width: 100%;
  background-color: #fff;
}

.c-notification__tab ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  width: 100%;
}

@media screen and (min-width: 1000px) {
  .c-notification__tab ul {
    max-width: 690px;
  }
}

.c-notification__tab li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  width: 50%;
}

.c-notification__tab a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 15px 20px 17px;
  width: 100%;
  font-weight: 500;
  color: #8d8d8d;
  font-size: 1.4rem;
  line-height: 1.85;
  text-decoration: none;
  background-color: #fff;
  border-bottom: 1px solid #d9d9d9;
  -webkit-transition: font-weight 300ms, color 300ms;
  transition: font-weight 300ms, color 300ms;
}

.c-notification__tab a:hover {
  color: #2d2d2d;
  font-weight: 700;
}

.c-notification__tab a[aria-current="page"] {
  color: #2d2d2d;
  font-weight: 700;
  border-bottom: 1px solid #2d2d2d;
}

.c-notification__continue {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  display: block;
  margin: 27px auto 0;
  font-size: 1.3rem;
  line-height: 1.6;
  text-decoration: underline;
}

.c-notification__continue:hover {
  text-decoration: none;
}

.c-notification__detail {
  padding-top: 20px;
}

.c-notification__detail h1 {
  margin-bottom: 6px;
  font-size: 1.5rem;
  line-height: 1.6;
}

.c-notification__detail p {
  margin-bottom: 20px;
  font-size: 1.4rem;
  line-height: 1.85;
}

.c-notification__detail-hero {
  width: 100%;
  padding-bottom: 40%;
  margin-bottom: 12px;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-notification__detail-meta {
  margin-bottom: 20px;
  line-height: 1;
}

.c-notification__detail-meta span {
  color: #8d8d8d;
  font-size: 1rem;
  line-height: 1.65;
}

.c-package__list + .c-package__list {
  margin-top: 40px;
}

.c-package__item {
  padding: 15px;
  line-height: 1;
  background-color: #fff;
  border: 1px solid #d9d9d9;
}

.c-package__item + .c-package__item {
  margin-top: 15px;
}

.c-package__item h2,
.c-package__item h3 {
  margin-bottom: 4px;
  font-size: 1.5rem;
  line-height: 1.47;
}

.c-package__item h2 span,
.c-package__item h3 span {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  display: inline-block;
  margin-left: 5px;
  padding: 1px 6px 2px;
  color: #fff;
  font-size: 1.1rem;
  line-height: 1.45;
}

.c-package__item h2 span[data-status="progress"],
.c-package__item h3 span[data-status="progress"] {
  background-color: #2d2d2d;
}

.c-package__item h2 span[data-status="stop"],
.c-package__item h3 span[data-status="stop"] {
  background-color: #8d8d8d;
}

.c-package__item h4 {
  margin-top: 5px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-package__item h4 a {
  color: #2d2d2d;
  font-size: 1.5rem;
  line-height: 1.47;
}

.c-package__item h4 span {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  display: inline-block;
  margin-left: 5px;
  padding: 1px 6px 2px;
  color: #fff;
  font-size: 1.1rem;
  line-height: 1.45;
}

.c-package__item h4 span[data-status="progress"] {
  background-color: #2d2d2d;
}

.c-package__item h4 span[data-status="stop"] {
  background-color: #8d8d8d;
}

.c-package__item a {
  color: #2d2d2d;
  font-size: 1.3rem;
  line-height: 1.46;
}

.c-package__item a:hover {
  text-decoration: none;
}

.c-package__item > dl {
  margin-top: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  border: 1px solid #d9d9d9;
}

.c-package__item > dl div {
  width: 50%;
  border-top: 1px solid #d9d9d9;
}

.c-package__item > dl div:nth-child(1),
.c-package__item > dl div:nth-child(2) {
  border-top: none;
}

.c-package__item > dl div:nth-child(even) {
  border-left: 1px solid #d9d9d9;
}

.c-package__item > dl dt,
.c-package__item > dl dd {
  text-align: center;
}

.c-package__item > dl dt {
  padding: 4px 10px;
  font-size: 1.2rem;
  line-height: 1.5;
  background-color: #f7f7f6;
}

.c-package__item > dl dd {
  padding: 6px 10px 10px;
  color: #8d8d8d;
  font-size: 1rem;
  line-height: 1.15;
}

.c-package__item > dl dd span {
  display: inline-block;
  margin-right: 4px;
  color: #2d2d2d;
  font-family: "Roboto", "Helvetica Neue", Helvetica, Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Arial, "メイリオ", Meiryo, sans-serif;
  font-size: 2rem;
  letter-spacing: -.1em;
}

.c-package__item-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.c-package__item-delete-button {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  -webkit-transition: font-weight 300ms;
  transition: font-weight 300ms;
}

.c-package__item-delete-button:hover {
  font-weight: 600;
}

.c-package__item-delete-button span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.c-package__item-delete-button span::before {
  display: block;
  content: "";
  width: 10px;
  height: 10px;
  background-image: url("../image/icon-delete-01.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.c-package__heading h2 {
  margin-bottom: 15px;
  font-size: 1.6rem;
  line-height: 1.5;
  text-align: center;
}

.c-package__item-button {
  margin-top: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}

.c-package__item-button button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  -webkit-transition: font-weight 300ms;
  transition: font-weight 300ms;
}

.c-package__item-button button:hover {
  font-weight: 600;
}

.c-package__item-button li + li {
  margin-left: 17px;
}

.c-package__item-edit-button span,
.c-package__item-delete-button span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-package__item-edit-button span::before,
.c-package__item-delete-button span::before {
  display: block;
  content: "";
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-package__item-edit-button span {
  color: #128d70;
}

.c-package__item-edit-button span::before {
  margin-right: 4px;
  width: 13px;
  height: 13px;
  background-image: url("../image/icon-edit-01.svg");
}

.c-package__item-delete-button span {
  color: #c71a1a;
}

.c-package__item-delete-button span::before {
  margin-right: 6px;
  width: 10px;
  height: 10px;
  background-image: url("../image/icon-delete-01.svg");
}

.c-pagination {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media screen and (min-width: 1000px) {
  .c-pagination {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
}

.c-link-list + .c-pagination,
.c-package__list + .c-pagination,
.c-record-list + .c-pagination {
  margin-top: 25px;
}

.c-pagination__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  justify-self: center;
  margin: 0;
  width: 20px;
}

@media screen and (min-width: 1000px) {
  .c-pagination__link {
    width: 31px;
  }
}

.c-pagination__link[data-link="prev"] img {
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
}

.c-pagination__link[data-link="next"] img {
  -webkit-transform: rotate(-90deg);
          transform: rotate(-90deg);
}

.c-pagination__link a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.c-pagination__link a[data-disabled="true"] {
  opacity: .2;
  pointer-events: none;
}

.c-pagination__link img {
  -webkit-transform-origin: center;
          transform-origin: center;
}

@media screen and (min-width: 1000px) {
  .c-pagination__link img {
    width: 31px;
    height: auto;
  }
}

.c-pagination__numbers {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  justify-self: center;
  margin: 0 15px;
}

.c-pagination__number {
  margin: 0 5px;
}

.c-pagination__number a {
  min-width: 32px;
  min-height: 32px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  color: #2d2d2d;
  font-weight: 600;
  font-size: 1.3;
  line-height: 1;
  text-decoration: none;
  background-color: #fff;
  border: 1px solid #d9d9d9;
  border-radius: 50%;
  -webkit-transition: color 300ms, background-color 300ms, border 300ms;
  transition: color 300ms, background-color 300ms, border 300ms;
}

@media screen and (min-width: 1000px) {
  .c-pagination__number a {
    min-width: 50px;
    min-height: 50px;
    font-family: "Roboto", "Helvetica Neue", Helvetica, Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Arial, "メイリオ", Meiryo, sans-serif;
    font-size: 1.5rem;
  }
}

.c-pagination__number a:hover,
.c-pagination__number a[aria-current="page"] {
  color: #fff;
  background-color: #2d2d2d;
  border: 1px solid #2d2d2d;
}

.c-pagination__date {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 20px 0;
  border: 1px solid #d9d9d9;
}

@media screen and (min-width: 1000px) {
  .c-pagination__date {
    width: 541px;
    margin: 30px auto 20px;
  }
}

.c-pagination__date-link {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 58px;
}

@media screen and (min-width: 1000px) {
  .c-pagination__date-link {
    width: 88px;
  }
}

@media screen and (min-width: 1000px) {
  .c-pagination__date[data-date="small"] .c-pagination__date-link {
    width: 60px;
  }
}

.c-pagination__date-prev,
.c-pagination__date-next {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  padding: 12px 13px;
  color: #8d8d8d;
  font-weight: 600;
  font-size: 1rem;
  line-height: 1;
  text-decoration: none;
  background-color: #fff;
  -webkit-transition: background-color 300ms, color 300ms;
  transition: background-color 300ms, color 300ms;
}

@media screen and (min-width: 1000px) {
  .c-pagination__date-prev,
  .c-pagination__date-next {
    width: 100%;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

.c-pagination__date-prev:hover,
.c-pagination__date-next:hover {
  color: #128d70;
  background-color: #f7f7f6;
}

.c-pagination__date-prev::before,
.c-pagination__date-next::before {
  position: absolute;
  top: 44px;
  left: 25px;
  display: block;
  content: "";
  width: 10px;
  height: 16px;
  background-image: url("../image/icon-arrow-04.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

@media screen and (min-width: 1000px) {
  .c-pagination__date-prev::before,
  .c-pagination__date-next::before {
    left: auto;
  }
}

.c-pagination__date-prev span,
.c-pagination__date-next span {
  font-family: "Roboto", "Helvetica Neue", Helvetica, Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Arial, "メイリオ", Meiryo, sans-serif;
  font-weight: 600;
  font-size: 1.2rem;
  line-height: 1;
}

.c-pagination__date-next::before {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

.c-pagination__date-today {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  width: calc(100% - 116px);
  padding: 18px 16px 15px;
  text-align: center;
  background-color: #fff;
  border-right: 1px solid #d9d9d9;
  border-left: 1px solid #d9d9d9;
}

@media screen and (min-width: 1000px) {
  .c-pagination__date-today {
    width: 363px;
  }
}

.c-pagination__date-today > a {
  display: inline-block;
  margin-bottom: 8px;
  color: #8d8d8d;
  font-size: 1.4rem;
}

.c-pagination__date-today h2 {
  margin-bottom: 8px;
  font-family: "Roboto", "Helvetica Neue", Helvetica, Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Arial, "メイリオ", Meiryo, sans-serif;
  font-weight: 600;
  font-size: 2.4rem;
  line-height: 1;
}

.c-pagination__date-today h2 span {
  font-family: Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Arial, "メイリオ", Meiryo, sans-serif;
  font-size: 1.3rem;
}

@media screen and (min-width: 1000px) {
  .c-pagination__date[data-date="small"] .c-pagination__date-today {
    width: calc(100% - 120px);
  }
}

.c-pagination__date-progress {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.c-pagination__date-progress-bar {
  position: relative;
  margin-right: 7px;
  width: 106px;
  height: 6px;
  background-color: #c0c0c0;
  border-radius: 6px;
  overflow: hidden;
}

.c-pagination__date-progress-fill {
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 6px;
  background-color: #128d70;
}

.c-pagination__date-number {
  font-family: "Roboto", "Helvetica Neue", Helvetica, Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Arial, "メイリオ", Meiryo, sans-serif;
  color: #128d70;
  font-weight: 600;
  font-size: 1.2rem;
  line-height: 1;
  letter-spacing: -.03em;
}

.c-pagination__date-number span {
  font-size: 1.9rem;
}

.c-pagination__date[data-date="small"] {
  margin-bottom: 0;
  border-bottom: none;
}

@media screen and (min-width: 1000px) {
  .c-pagination__date[data-date="small"] {
    width: 100%;
  }
}

.c-pagination__date[data-date="small"] .c-pagination__date-prev,
.c-pagination__date[data-date="small"] .c-pagination__date-next {
  width: 100%;
}

.c-pagination__date[data-date="small"] .c-pagination__date-prev::before,
.c-pagination__date[data-date="small"] .c-pagination__date-next::before {
  top: calc(50% - 8px);
  background-image: url("../image/icon-arrow-04.svg");
}

.c-pagination__date[data-date="small"] .c-pagination__date-prev span,
.c-pagination__date[data-date="small"] .c-pagination__date-next span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}

.c-pagination__date[data-date="small"] .c-pagination__date-today h2 {
  font-size: 1.6rem;
  font-family: Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Arial, "メイリオ", Meiryo, sans-serif;
}

.c-pagination__date[data-date="small"] .c-pagination__date-today h2 span {
  font-size: 1.1rem;
}

.c-pagination__date[data-date="forclient"] {
  margin: 0;
  border: none;
  border-bottom: 1px solid #d9d9d9;
  background-color: #fff;
}

@media screen and (min-width: 1000px) {
  .c-pagination__date[data-date="forclient"] {
    width: 100%;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
}

.c-pagination__date[data-date="forclient"] .c-pagination__date-prev::before,
.c-pagination__date[data-date="forclient"] .c-pagination__date-next::before {
  background-image: url("../image/icon-arrow-05.svg");
}

.c-pagination__date[data-date="forclient"] .c-pagination__date-today {
  max-width: 255px;
  width: calc(100% - 116px);
}

.c-pagination__date-trainer {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  padding: 7px 20px;
  background-color: #fff;
  border-bottom: 1px solid #d9d9d9;
}

@media screen and (min-width: 1000px) {
  .c-pagination__date-trainer {
    padding: 20px;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
}

.c-pagination__date-trainer-thumbnail {
  margin-right: 8px;
  width: 41px;
  height: 41px;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  border-radius: 50%;
}

.c-pagination__date-trainer-name {
  color: #8d8d8d;
  font-size: 1rem;
  line-height: 1.5;
}

.c-pagination__date-trainer-name span {
  display: block;
  color: #2d2d2d;
  font-size: 1.4rem;
  font-weight: 600;
}

.c-payment-list {
  margin-bottom: 32px;
}

@media screen and (min-width: 767px) {
  .c-payment-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

.c-payment-list li {
  padding: 19px 19px 16px;
  background-color: #fff;
  border: 1px solid #d9d9d9;
}

@media screen and (min-width: 767px) {
  .c-payment-list li {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 auto;
            flex: 0 0 auto;
    width: calc(50% - 10px);
    margin-bottom: 10px;
  }
}

.c-payment-list li + li {
  margin-top: 10px;
}

@media screen and (min-width: 767px) {
  .c-payment-list li:nth-child(2) {
    margin-top: 0;
  }
}

.c-payment-list li:nth-child(even) {
  margin-left: 20px;
}

.c-payment-list dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-payment-list dl div {
  margin-right: 29px;
}

.c-payment-list dl dt {
  color: #8d8d8d;
  font-size: 1.1rem;
  line-height: 1.45;
}

.c-payment-list dl dd {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.48;
}

.c-payment-list dl dd span {
  font-size: 2.5rem;
}

.c-payment-list__head {
  margin-bottom: 13px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.c-payment-list__head h2 {
  font-size: 1.4rem;
  line-height: 1.5;
}

.c-payment-list__head h2 span {
  display: inline-block;
}

.c-payment-list__head h2 span::after {
  display: inline-block;
  content: "：";
}

.c-payment-list__button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  font-size: 1.4rem;
  line-height: 1.5;
  text-decoration: underline;
}

.c-payment-list__button:hover {
  text-decoration: none;
}

.c-payment-list__detail {
  position: relative;
  margin: 20px 0 35px;
  padding: 20px 20px 30px;
  background-color: #fff;
  border: 1px solid #d9d9d9;
}

.c-payment-list__detail > p {
  margin-bottom: 20px;
  font-size: 1.2rem;
  line-height: 1.5;
}

.c-payment-list__detail > h3 {
  margin-bottom: 4px;
}

.c-payment-list__detail > h3,
.c-payment-list__detail > dl dt,
.c-payment-list__detail > dl dd {
  font-size: 1rem;
  line-height: 1.5;
}

.c-payment-list__detail > dl div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-payment-list__detail > dl dt {
  margin-right: 5px;
  font-weight: 600;
}

.c-payment-list__detail > dl + dl {
  margin-top: 30px;
}

.c-payment-list__detail > dl + dl dt {
  font-weight: 300;
}

.c-payment-list__detail > dl + dl dt,
.c-payment-list__detail > dl + dl dd {
  font-size: 1.2rem;
}

.c-payment-list__detail-meta {
  margin-bottom: 20px;
}

.c-payment-list__detail-meta p {
  margin-bottom: 3px;
  font-size: 1.1rem;
  line-height: 1.45;
}

.c-payment-list__detail-meta dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-payment-list__detail-meta dl dt,
.c-payment-list__detail-meta dl dd {
  font-size: 1.1rem;
  line-height: 1.45;
}

.c-payment-list__detail-meta dl dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-payment-list__detail-meta dl dt::after {
  display: block;
  content: "：";
}

.c-payment-list__detail-name {
  margin-bottom: 20px;
  font-size: 1.5rem;
  font-weight: 600;
}

.c-payment-list__detail-name span {
  display: inline-block;
  margin-left: 5px;
  font-size: 1rem;
}

.c-payment-list__detail-price {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  margin-bottom: 20px;
  padding-bottom: 9px;
  border-bottom: 2px solid #333;
}

.c-payment-list__detail-price h2,
.c-payment-list__detail-price p {
  font-weight: 300;
  font-size: 1.4rem;
  line-height: 1.5;
}

.c-payment-list__detail-price h2 {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-payment-list__detail-price h2::after {
  display: inline-block;
  content: "：";
}

.c-payment-list__detail-copy {
  position: absolute;
  top: 20px;
  right: 20px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  color: #e56813;
  font-size: 1.3rem;
  line-height: 1.46;
  text-decoration: underline;
}

.c-payment-list__detail-copy:hover {
  text-decoration: none;
}

.c-plan__heading {
  margin-bottom: 15px;
  font-size: 1rem;
  line-height: 1;
}

.c-plan__heading[data-heading="center"] {
  text-align: center;
}

@media screen and (min-width: 1000px) {
  .c-plan__heading[data-heading="center"] {
    text-align: left;
  }
}

.c-plan__heading h2 {
  font-size: 1.5rem;
  line-height: 1.47;
}

.c-plan__heading small {
  font-size: 1.1rem;
  line-height: 1.45;
}

.c-plan__note + .c-plan__heading {
  margin-top: 25px;
}

.c-content__attention-box + .c-plan__heading {
  margin-top: 30px;
}

.c-plan__item {
  margin: 15px 0 20px;
  padding: 19px;
  width: 100%;
  background-color: #fff;
  border: 1px solid #d9d9d9;
}

.c-plan__item[data-item="change"] {
  margin-bottom: 40px;
}

.c-plan__item[data-item="now"] {
  position: relative;
  margin-bottom: 47px;
}

.c-plan__item[data-item="now"]::after {
  position: absolute;
  left: 50%;
  right: 50%;
  bottom: -30px;
  display: block;
  content: "";
  width: 12px;
  height: 12px;
  background-image: url("../image/icon-arrow-02.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.c-plan__item h3 {
  margin-bottom: 15px;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.5;
}

.c-plan__item dl {
  margin-bottom: 10px;
}

.c-plan__item .c-plan__note + dl {
  margin-top: 20px;
}

.c-plan__item dl dt,
.c-plan__item dl dd {
  font-size: 1.4rem;
  line-height: 1.85;
}

.c-plan__item dl dt {
  font-weight: 700;
}

.c-plan__item dl dd {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.c-plan__item dl dd::before {
  display: block;
  content: "・";
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
}

.c-plan__item dl dd[data-bullet="none"]::before {
  display: none;
}

.c-plan__item > p {
  font-size: 1.2rem;
  line-height: 1.65;
}

.c-plan__item > p em {
  font-style: normal;
  color: #c71a1a;
}

.c-plan__item > p em a {
  color: #c71a1a;
}

.c-plan__item > p a {
  color: #2d2d2d;
}

.c-plan__item > p a:hover {
  text-decoration: none;
}

.c-plan__item ul {
  margin-top: 10px;
}

.c-plan__item ul li {
  font-size: 1.1rem;
  line-height: 1.45;
}

.c-plan__item ul li + li {
  margin-top: 5px;
}

.c-plan__price {
  margin: 10px 0;
}

.c-plan__price table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid #d9d9d9;
}

.c-plan__price th,
.c-plan__price td {
  text-align: center;
}

.c-plan__price thead {
  background-color: #2d2d2d;
}

.c-plan__price thead th {
  padding: 8px 14px 10px;
  color: #fff;
  font-size: 1.1rem;
}

.c-plan__price thead th + th {
  border-left: 1px solid #d9d9d9;
}

.c-plan__price thead sup {
  color: #faff00;
  font-size: 1rem;
  vertical-align: baseline;
}

.c-plan__price thead a {
  color: #fff;
}

.c-plan__price thead a:hover {
  text-decoration: none;
}

.c-plan__price tbody {
  background-color: #fff;
}

.c-plan__price tbody tr {
  border-top: 1px solid #d9d9d9;
}

.c-plan__price tbody th,
.c-plan__price tbody td {
  padding: 4px 10px;
  font-size: 1rem;
  line-height: 1.5;
}

.c-plan__price tbody th span,
.c-plan__price tbody td span {
  font-size: 1.5rem;
}

.c-plan__price tbody th {
  font-weight: 700;
}

.c-plan__price tbody td {
  border: 1px solid #d9d9d9;
}

.c-plan__note {
  font-size: 1.1rem;
  line-height: 1.45;
}

.c-plan__note a {
  color: #2d2d2d;
}

.c-plan__note a:hover {
  text-decoration: none;
}

.c-form .c-plan__note {
  margin: -10px 0 20px;
}

.c-plan__item .c-plan__status,
.c-plan__status {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 5px;
}

.c-plan__item .c-plan__status div,
.c-plan__status div {
  margin-right: 28px;
}

.c-plan__item .c-plan__status dt,
.c-plan__status dt {
  color: #8d8d8d;
  font-size: 1.1rem;
  line-height: 1.45;
}

.c-plan__item .c-plan__status dd,
.c-plan__status dd {
  display: block;
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.47;
}

.c-plan__item .c-plan__status dd::before,
.c-plan__status dd::before {
  display: none;
}

.c-plan__item .c-plan__status dd b,
.c-plan__status dd b {
  color: #c71a1a;
}

.c-plan__item .c-plan__status dd span,
.c-plan__status dd span {
  font-size: 2.5rem;
}

.c-profile__client {
  padding: 13px 36px 14px 46px;
  background-color: #fff;
  border-bottom: 1px solid #d9d9d9;
}

@media screen and (min-width: 1000px) {
  .c-profile__client {
    padding: 34px 44px;
  }
}

.c-profile__trainer {
  margin: 0 0 20px;
  padding: 15px 66px;
  width: 100%;
  background-color: #fff;
  border-bottom: 1px solid #d9d9d9;
}

@media screen and (min-width: 1000px) {
  .c-profile__trainer {
    padding-left: 44px;
  }
}

.c-profile__trainer-wrapper {
  margin: 0 auto;
  max-width: 243px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

@media screen and (min-width: 1000px) {
  .c-profile__trainer-wrapper {
    margin: 0;
  }
}

.c-profile__trainer-thumbnail {
  margin-right: 15px;
  width: 70px;
  height: 70px;
  background-image: url("../image/dummy-profile.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  border-radius: 50%;
  overflow: hidden;
}

.c-profile__trainer-information dt,
.c-profile__trainer-information dd {
  font-size: 1.2rem;
  line-height: 1.5;
}

.c-profile__trainer-name {
  margin-bottom: 2px;
}

.c-profile__trainer-name h2 {
  font-size: 1.6rem;
  line-height: 1.5;
}

.c-profile__trainer-name h2 span {
  font-size: 1.2rem;
}

.c-program__heading h2,
.c-program__heading h3 {
  padding: 17px;
  color: #fff;
  font-weight: 600;
  font-size: 1.6rem;
  line-height: 1.4;
  text-align: center;
  background-color: #2d2d2d;
}

.c-program__link-more + .c-program__heading {
  margin-top: 40px;
}

.c-package__list + .c-program__heading {
  margin-top: 20px;
}

.c-program__item {
  margin-bottom: 20px;
  border: 1px solid #d9d9d9;
  border-top: none;
  background-color: #fff;
}

@media screen and (min-width: 1000px) {
  .c-program__item {
    margin-bottom: 35px;
  }
}

.c-program__item[aria-hidden="true"] {
  display: none;
}

.c-program__tab {
  border-bottom: 1px solid #d9d9d9;
}

.c-program__tab ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  padding: 15px;
}

.c-program__tab li {
  border: 1px solid #d9d9d9;
}

.c-program__tab li + li {
  border-left: none;
}

.c-program__tab button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  padding: 5px 16px;
  color: #8d8d8d;
  font-weight: 600;
  font-size: 1.4rem;
  background-color: #fff;
  -webkit-transition: color 300ms;
  transition: color 300ms;
}

.c-program__tab button[aria-selected="true"] {
  color: #fff;
  background-color: #2d2d2d;
}

.c-program__tab button[aria-selected="true"]:hover {
  color: #fff;
}

.c-program__tab button:hover {
  color: #2d2d2d;
}

.c-program__exercise-item {
  padding: 15px;
  border-bottom: 1px solid #d9d9d9;
}

@media screen and (min-width: 1000px) {
  .c-program__exercise-item:nth-child(1), .c-program__exercise-item:nth-child(2) {
    border-top: none;
  }
}

.c-program__exercise-item:last-child {
  border-bottom: none;
}

.c-program__exercise-item[data-item="select"] {
  padding-top: 10px;
}

.c-program__exercise-item[data-item="other"] {
  padding-top: 10px;
}

.c-program__exercise-item[data-check="disable"] > p {
  margin-top: 10px;
  color: #c71a1a;
  font-size: 1.2rem;
  line-height: 1.6;
  letter-spacing: .05em;
}

.c-program__exercise-label {
  display: inline-block;
  margin: 0 0 5px -15px;
  padding: 4px 10px 5px;
  color: #fff;
  font-size: 1.2rem;
  font-weight: 600;
  line-height: 1.5;
  background-color: #2d2d2d;
}

.c-program__exercise-label[data-label="delete"] {
  background-color: #c71a1a;
  margin-bottom: 10px;
}

.c-program__exercise-label[data-label="other"] {
  background-color: #8d8d8d;
  margin-bottom: 10px;
}

.c-program__item-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-bottom: 7px;
}

.c-program__exercise-item[data-check="disable"] .c-program__item-header,
.c-program__exercise-item[data-check="disable"] .c-program__exercise-contents,
.c-program__exercise-item[data-check="disable"] .c-program__item-information,
.c-program__exercise-item[data-item="other"] .c-program__item-header,
.c-program__exercise-item[data-item="other"] .c-program__exercise-contents,
.c-program__exercise-item[data-item="other"] .c-program__item-information {
  opacity: .5;
}

.c-program__item-meta {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  margin-right: 13px;
  max-width: 250px;
}

@media screen and (min-width: 1000px) {
  .c-program__item-meta {
    margin-right: 0;
  }
}

.c-program__item-title {
  margin-bottom: 12px;
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1.47;
}

.c-program__item-title a {
  color: #2d2d2d;
}

.c-program__chief-complaint {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-program__chief-complaint dt,
.c-program__chief-complaint dd {
  color: #8d8d8d;
  font-size: 1.3rem;
  line-height: 1.5;
}

.c-program__chief-complaint dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-program__chief-complaint dt::after {
  display: block;
  content: "：";
}

.c-program__item-button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: none;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid #d9d9d9;
  background-color: #d9d9d9;
  -webkit-transition: background-color 300ms;
  transition: background-color 300ms;
}

.c-program__item-button:hover, .c-program__item-button[data-status="checked"] {
  background-color: #128d70;
  border: 1px solid #128d70;
}

.c-program__item-button:hover::before, .c-program__item-button[data-status="checked"]::before {
  background-image: url("../image/icon-check-01.svg");
}

.c-program__item-button[data-check="client"] {
  background-color: #fff;
}

.c-program__item-button[data-check="client"]::before {
  background-image: url("../image/icon-check-03.svg");
}

.c-program__item-button::before {
  display: block;
  content: "";
  width: 12px;
  height: 10px;
  background-image: url("../image/icon-check-02.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-program__item-button span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}

.c-program__exercise-contents {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-program__exercise-thumbnail {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  margin-right: 12px;
  width: 110px;
  height: 65px;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-program__item-information {
  width: 100%;
  border: 1px solid #d9d9d9;
}

.c-program__item-information[data-info="lifestyle"] dt {
  min-width: 40px;
}

.c-program__item-information div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.c-program__item-information div + div {
  border-top: 1px solid #d9d9d9;
}

.c-program__item-information dt,
.c-program__item-information dd {
  font-size: 1.3rem;
  line-height: 1.3;
}

.c-program__item-information dt {
  padding: 7px 8px 5px 7px;
  min-width: 55px;
  font-weight: 600;
  background-color: #f7f7f6;
  border-right: 1px solid #d9d9d9;
}

.c-program__item-information dd {
  padding: 6px 8px 5px;
}

.c-program__item-information dd span {
  color: #c71a1a;
}

.c-program__item-information a {
  color: #2d2d2d;
}

.c-form__card .c-program__item-information {
  margin-bottom: 16px;
}

@media screen and (min-width: 1000px) {
  .c-program__item-list > ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

.c-program__item-list > ul[aria-hidden="true"] {
  display: none;
}

@media screen and (min-width: 1000px) {
  .c-program__item-list > ul > li {
    width: 50%;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 auto;
            flex: 0 0 auto;
  }
}

@media screen and (min-width: 1000px) {
  .c-program__item-list > ul > li:nth-child(odd) {
    border-right: 1px solid #d9d9d9;
  }
}

.c-program__link-graph {
  margin-top: -1px;
  padding: 20px;
  text-align: center;
  line-height: 1;
  border-top: 1px solid #d9d9d9;
}

.c-program__link-graph a {
  color: #2d2d2d;
  font-size: 1.4rem;
  line-height: 1.4;
  -webkit-transition: color 300ms;
  transition: color 300ms;
}

.c-program__link-graph a:hover {
  color: #e56813;
  text-decoration: none;
}

.c-program__item-text + .c-program__link-graph {
  border-top: none;
}

.c-program__item-text {
  padding: 15px;
  border-bottom: 1px solid #d9d9d9;
}

.c-program__item-text h4 {
  font-size: 1.5rem;
}

.c-program__item-text a {
  color: #2d2d2d;
}

.c-program__item-text p {
  font-size: 1.4rem;
  line-height: 1.5;
}

.c-program__item-list + .c-program__item-text {
  border-top: 1px solid #d9d9d9;
}

.c-program__nutrition-item {
  padding: 15px 15px 18px;
}

.c-program__nutrition-item + .c-program__nutrition-item {
  border-top: 1px solid #d9d9d9;
}

.c-program__nutrition-item[data-status="delete"] {
  padding-top: 10px;
}

.c-program__nutrition-item[data-status="delete"] dl {
  color: #8d8d8d;
}

.c-program__nutrition-item[data-item="confirm"] {
  position: relative;
}

.c-program__nutrition-item[data-item="confirm"] dt {
  margin-right: 40px;
}

.c-program__nutrition-item dt,
.c-program__nutrition-item dd {
  font-size: 1.4rem;
  line-height: 1.6;
}

.c-program__nutrition-item dt {
  font-weight: 600;
  margin-bottom: 10px;
}

.c-program__item-comment {
  margin-top: 15px;
}

.c-program__item-comment h4,
.c-program__item-comment p {
  font-size: 1.4rem;
  line-height: 1.5;
}

.c-program__item-comment h4 {
  margin-bottom: 6px;
}

.c-program__item-delete-button,
.c-program__edit-button,
.c-program__change-button,
.c-program__today-button {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  -webkit-transition: background-color 300ms;
  transition: background-color 300ms;
}

.c-program__item-delete-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 30px;
  height: 30px;
  background-color: rgba(162, 26, 26, 0.15);
  border-radius: 50%;
}

.c-program__item-delete-button:hover {
  background-color: rgba(162, 26, 26, 0.3);
}

.c-program__item-delete-button[data-item="advice"] {
  position: absolute;
  top: 15px;
  right: 15px;
}

.c-program__item-delete-button::before {
  display: block;
  content: "";
  width: 10px;
  height: 10px;
  background-image: url("../image/icon-delete-01.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.c-program__item-delete-button span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}

.c-program__edit-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  margin-left: auto;
  text-decoration: none;
}

.c-program__edit-button span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  color: #128d70;
  font-size: 1.4rem;
  line-height: 1.5;
}

.c-program__edit-button span::before {
  display: block;
  content: "";
  margin-right: 4px;
  width: 13px;
  height: 13px;
  background-image: url("../image/icon-edit-01.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-program__exercise-contents + .c-program__edit-button,
.c-program__item-information + .c-program__edit-button {
  margin-top: 10px;
}

.c-program__change-button {
  margin-top: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  margin-left: auto;
}

.c-program__change-button span {
  color: #128d70;
  font-size: 1.4rem;
  line-height: 1.5;
}

.c-program__item-disable,
.c-program__nutrition-attention {
  margin-top: 5px;
  color: #8d8d8d;
  font-size: 1.2rem;
  line-height: 1.6;
  letter-spacing: .05em;
}

.c-program__nutrition-attention {
  color: #c71a1a;
}

.c-program__link-more {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  display: block;
  margin: 0 auto 20px;
  color: #2d2d2d;
  font-size: 1.4rem;
  line-height: 1.5;
  text-align: center;
  text-decoration: underline;
}

.c-program__link-more:hover {
  text-decoration: none;
}

.c-program__item-attention {
  padding: 15px 19px 16px;
  color: #c71a1a;
  font-size: 1.4rem;
  line-height: 1.85;
}

.c-program__attention {
  margin-top: 8px;
  color: #c71a1a;
  font-size: 1.3rem;
  line-height: 1.46;
}

.c-program__attention[data-text="normal"] {
  color: #2d2d2d;
}

.c-program__attention a {
  color: #c71a1a;
}

.c-program__attention em {
  font-style: normal;
}

.c-program__record {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
}

.c-program__record dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-program__record dl dt,
.c-program__record dl dd {
  color: #8d8d8d;
  font-size: 1rem;
  line-height: 1.5;
}

.c-program__record dl dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-program__record dl dt::after {
  display: block;
  content: "：";
}

.c-program__record-now {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  color: #128d70;
  font-size: 1.8rem;
  font-weight: 600;
  line-height: 1.4;
}

.c-program__record-now[data-now="none"] {
  color: #8d8d8d;
}

.c-program__record-now span {
  font-size: 1.2rem;
}

.c-program__not-today {
  display: block;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  color: #c71a1a;
  font-size: 1.3rem;
  line-height: 1.3;
  text-decoration: underline;
}

.c-program__not-today:hover {
  text-decoration: none;
}

.c-program__today-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  margin: 10px 0 0 auto;
  color: #128d70;
  font-size: 1.4rem;
  line-height: 1.5;
  text-decoration: underline;
}

.c-program__today-button:hover {
  text-decoration: none;
}

.c-program__recorded {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  padding: 10px 20px;
  margin-top: 15px;
  border: 1px solid #d9d9d9;
}

.c-program__recorded > span {
  display: block;
  margin-right: 20px;
  color: #128d70;
  font-family: "Roboto", "Helvetica Neue", Helvetica, Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Arial, "メイリオ", Meiryo, sans-serif;
  font-size: 2.6rem;
  line-height: 1.15;
}

.c-program__recorded-text {
  line-height: 1;
}

.c-program__recorded-text p {
  font-size: 1.3rem;
  line-height: 1.38;
}

.c-program__recorded-fix-button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  color: #128d70;
  font-size: 1.3rem;
  line-height: 1.46;
  text-decoration: underline;
}

.c-program__recorded-fix-button:hover {
  text-decoration: none;
}

.c-program__item-free-text {
  margin: -2px 0 15px;
  font-size: 1.3rem;
  line-height: 1.46;
}

.c-program__item-evaluation {
  padding: 16px 16px 20px;
}

.c-program__item-evaluation > p {
  margin-bottom: 20px;
  font-size: 1.3rem;
  line-height: 1.46;
}

.c-program__item-evaluation h4 {
  margin-bottom: 4px;
  font-size: 1.2rem;
  line-height: 1.5;
}

.c-program__item-evaluation-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  margin-bottom: 9px;
}

.c-program__item-evaluation-box[aria-hidden="true"] {
  display: none;
}

.c-program__item-evaluation-wrapper[aria-hidden="true"] {
  display: none;
}

.c-program__item-evaluation-change[aria-hidden="true"] {
  display: none;
}

.c-program__item-evaluation-button-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  margin: 10px 0 15px;
}

.c-program__item-evaluation-button-list li + li {
  margin-left: 15px;
}

.c-program__item-date {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-program__item-date dt,
.c-program__item-date dd {
  color: #8d8d8d;
  font-size: 1rem;
  line-height: 1.5;
}

.c-program__item-date dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-program__item-date dt::after {
  display: block;
  content: "：";
}

.c-program__item-evaluation-image {
  margin-right: 7px;
}

.c-program__item-evaluation-image img {
  width: 34px;
  height: 34px;
}

.c-program__item-evaluation-status {
  margin-right: 10px;
  color: #8d8d8d;
  font-size: 1.3rem;
  line-height: 1.4;
}

.c-program__item-evaluation-status span {
  display: block;
  color: #2d2d2d;
  font-size: 1.5rem;
  font-weight: 600;
}

.c-program__item-evaluation-button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  padding: 5px 21px;
  color: #fff;
  font-size: 1.3rem;
  font-weight: 600;
  line-height: 1.54;
  background-color: #2d2d2d;
  border-radius: 2px;
}

.c-program__input {
  margin-bottom: 23px;
  text-align: center;
}

.c-program__input p {
  font-size: 1rem;
  line-height: 1.5;
}

.c-program__input-status {
  font-size: 1.2rem;
  font-weight: 600;
  line-height: 1.5;
}

.c-program__input-status span {
  font-family: "Roboto", "Helvetica Neue", Helvetica, Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Arial, "メイリオ", Meiryo, sans-serif;
  font-size: 2.2rem;
}

.c-program__item-evaluation-radio li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-program__item-evaluation-radio li + li {
  margin-top: 17px;
}

.c-program__item-evaluation-radio input[type="radio"] {
  position: relative;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  margin: 9px 15px 0 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: none;
  background-color: #fff;
  border: 1px solid #d9d9d9;
  cursor: pointer;
}

@media screen and (min-width: 767px) {
  .c-program__item-evaluation-radio input[type="radio"] {
    width: 18px;
    height: 18px;
    margin-top: 13px;
    margin-right: 10px;
  }
}

.c-program__item-evaluation-radio input[type="radio"]:checked {
  border: 1px solid #e56813;
  background-color: none;
}

.c-program__item-evaluation-radio input[type="radio"]:checked::before {
  display: block;
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: #e56813;
}

@media screen and (min-width: 767px) {
  .c-program__item-evaluation-radio input[type="radio"]:checked::before {
    width: 12px;
    height: 12px;
  }
}

.c-program__item-evaluation-radio label {
  margin-bottom: 0;
  position: relative;
  padding-left: 41px;
  color: #8d8d8d;
  font-size: 1.3rem;
  line-height: 1.54;
  cursor: pointer;
}

@media screen and (min-width: 767px) {
  .c-program__item-evaluation-radio label {
    font-size: 1.4rem;
  }
}

.c-program__item-evaluation-radio label::before {
  display: block;
  content: "";
  position: absolute;
  top: calc(50% - 17px);
  left: 0;
  width: 34px;
  height: 34px;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-program__item-evaluation-radio label span {
  display: block;
  color: #2d2d2d;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.54;
}

.c-program__item-evaluation-radio li[data-icon="01"] label::before {
  background-image: url("../image/icon-status-01.svg");
}

.c-program__item-evaluation-radio li[data-icon="02"] label::before {
  background-image: url("../image/icon-status-02.svg");
}

.c-program__item-evaluation-radio li[data-icon="03"] label::before {
  background-image: url("../image/icon-status-03.svg");
}

.c-program__not-change-button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: none;
  border: none;
  cursor: pointer;
  margin: 12px 0 10px;
  color: #c71a1a;
  font-size: 1.3rem;
  text-decoration: underline;
}

.c-program__not-change-button:hover {
  text-decoration: none;
}

.c-program__item-evaluation-change .c-program__not-change-button {
  margin: 0;
}

.c-program__date {
  margin: 10px 0 3px;
}

.c-program__date dl {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  padding: 8px 10px 9px;
  border: 1px solid #d9d9d9;
}

.c-program__date dt {
  margin-right: 6px;
  color: #8d8d8d;
  font-size: 1.1rem;
  line-height: 1.45;
}

.c-program__date dd {
  font-size: 1.3rem;
  line-height: 1.3;
}

.c-program__date dd span {
  margin-right: 4px;
  color: #128d70;
  font-size: 2.1rem;
  font-weight: 600;
  line-height: 1.3;
}

.c-program__celebrate-message {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  margin: 2px 0 3px;
}

.c-program__celebrate-message::before {
  display: block;
  content: "";
  margin-right: 10px;
  width: 44px;
  height: 44px;
  background-image: url("../image/icon-celebrate-01.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-program__celebrate-message p {
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.5;
}

.c-program__celebrate-message p::first-letter {
  color: #e56813;
  font-size: 1.9rem;
}

.c-program-status__list {
  margin-bottom: 30px;
  border: 1px solid #d9d9d9;
  background-color: #fff;
}

.c-program-status + .c-program-status {
  border-top: 1px solid #d9d9d9;
}

.c-program-status h3 a {
  display: inline-block;
  margin-bottom: 8px;
  color: #2d2d2d;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.47;
}

.c-program-status__list > .c-program-status {
  padding: 17px 18px;
}

.c-program-status__chief-complaint {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  margin-bottom: 18px;
}

.c-program-status__chief-complaint dt,
.c-program-status__chief-complaint dd {
  color: #8d8d8d;
  font-size: 1.4rem;
  line-height: 1.5;
}

.c-program-status__chief-complaint dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-program-status__chief-complaint dt::after {
  display: block;
  content: "：";
}

.c-program-status__checklist {
  position: relative;
  z-index: 0;
  padding-top: 19px;
  margin: 12px 0;
  width: calc(100% - 14px);
  max-width: 270px;
}

.c-program-status__checklist ul + .c-program-status__date {
  right: 0;
}

.c-program-status__checklist ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  width: 257px;
  min-height: 25px;
  border-right: 1px solid #d9d9d9;
  border-left: 1px solid #d9d9d9;
}

.c-program-status__checklist li {
  position: relative;
  margin-bottom: 1px;
}

.c-program-status__checklist li[data-unit="first"], .c-program-status__checklist li[data-unit="while"], .c-program-status__checklist li[data-unit="last"] {
  background-color: rgba(18, 141, 112, 0.3);
}

.c-program-status__checklist li[data-unit="first"] {
  border-top-left-radius: 50%;
  border-bottom-left-radius: 50%;
}

.c-program-status__checklist li[data-unit="last"] {
  border-top-right-radius: 50%;
  border-bottom-right-radius: 50%;
}

.c-program-status__checklist li[data-status="ok"]::before, .c-program-status__checklist li[data-status="check"]::before {
  display: block;
  content: "";
  position: absolute;
  border-radius: 50%;
}

.c-program-status__checklist li[data-status="ok"]::before {
  top: 0;
  left: 0;
  width: 17px;
  height: 17px;
  border: 1px solid #e56813;
  background-color: rgba(229, 104, 19, 0.3);
  border-radius: 50%;
  z-index: 2;
}

.c-program-status__checklist li[data-status="check"]::before {
  top: 3px;
  left: 3px;
  width: 11px;
  height: 11px;
  background-color: #128d70;
}

.c-program-status__checklist li::after {
  display: block;
  content: "";
  width: 17px;
  height: 17px;
  border: 1px solid #128d70;
  background-color: #fff;
  border-radius: 50%;
  z-index: 1;
}

.c-program-status__checklist li span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}

.c-program-status__date {
  position: absolute;
  top: 0;
  font-family: "Roboto", "Helvetica Neue", Helvetica, Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Arial, "メイリオ", Meiryo, sans-serif;
  font-size: 1.3rem;
  line-height: 1.2;
}

.c-program-status__date:nth-child(1) {
  left: 0;
}

.c-program-status__date span {
  font-family: Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Arial, "メイリオ", Meiryo, sans-serif;
  font-size: 1rem;
  font-weight: 600;
}

.c-program-status__accordion-button-list {
  margin-top: 24px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-program-status__accordion-button-list button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  text-decoration: underline;
  font-size: 1.2rem;
  line-height: 1.5;
}

.c-program-status__accordion-button-list button:hover {
  text-decoration: none;
}

.c-program-status__accordion-button-list button[aria-expanded="true"] {
  color: #e56813;
}

.c-program-status__accordion-button-list button[aria-expanded="true"] span::after {
  background-image: url("../image/icon-arrow-01.svg");
  -webkit-transform: rotate(30deg);
          transform: rotate(30deg);
}

.c-program-status__accordion-button-list button + button {
  margin-left: 16px;
}

.c-program-status__accordion-button-list button span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-program-status__accordion-button-list button span::after {
  display: block;
  content: "";
  width: 8px;
  height: 8px;
  margin-left: 6px;
  background-image: url("../image/icon-arrow-02.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-program-status__frequency {
  margin-top: 15px;
}

.c-program-status__frequency[aria-hidden="true"] {
  display: none;
}

.c-program-status__frequency-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  max-width: 335px;
}

.c-program-status__frequency-item + .c-program-status__frequency-item {
  margin-top: 10px;
}

.c-program-status__frequency-item h4 {
  font-size: 1.3rem;
  font-weight: 600;
  line-height: 1.15;
}

.c-program-status__frequency-item h4 span {
  font-size: 1.6rem;
  font-family: "Roboto", "Helvetica Neue", Helvetica, Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Arial, "メイリオ", Meiryo, sans-serif;
}

.c-program-status__frequency-item dl {
  width: 197px;
  border: 1px solid #d9d9d9;
}

.c-program-status__frequency-item dl[data-item="nutrition"] dt {
  min-width: 54px;
}

.c-program-status__frequency-item dl div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-program-status__frequency-item dl div + div {
  border-top: 1px solid #d9d9d9;
}

.c-program-status__frequency-item dl dt,
.c-program-status__frequency-item dl dd {
  padding: 4px 7px;
  font-size: 1.3rem;
  line-height: 1.3;
}

.c-program-status__frequency-item dl dt {
  font-weight: 600;
  text-align: center;
  border-right: 1px solid #d9d9d9;
  background-color: #f7f7f6;
}

.c-program-status__frequency-item dl a {
  color: #2d2d2d;
}

.c-program-status__frequency-item dl dd span {
  display: inline-block;
  margin-right: 5px;
  font-weight: 600;
}

.c-program-status__table {
  margin-top: 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-program-status__table[aria-hidden="true"] {
  display: none;
}

.c-program-status__table[data-table="max"] table {
  width: 100%;
}

.c-program-status__table[data-table="max"] thead th {
  width: auto;
}

.c-program-status__table table {
  width: calc(50% - 6.5px);
  border-collapse: collapse;
  border: 1px solid #d9d9d9;
}

.c-program-status__table table + table {
  margin-left: 13px;
}

.c-program-status__table table th,
.c-program-status__table table td {
  padding: 5px 5px 7px;
  font-size: 1.2rem;
  line-height: 1.5;
  text-align: center;
}

.c-program-status__table thead tr {
  background-color: #f7f7f6;
}

.c-program-status__table thead th {
  width: 50%;
  font-weight: 400;
}

.c-program-status__table thead th + th {
  border-left: 1px solid #d9d9d9;
}

.c-program-status__table tbody tr {
  border-top: 1px solid #d9d9d9;
}

.c-program-status__table tbody th {
  font-family: "Roboto", "Helvetica Neue", Helvetica, Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ ProN W3", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Arial, "メイリオ", Meiryo, sans-serif;
}

.c-program-status__table tbody td {
  border-left: 1px solid #d9d9d9;
}

@media screen and (min-width: 1000px) {
  .c-program-status__nutrition-intake {
    margin-bottom: 8px;
  }
}

.c-program-status__nutrition-intake ul {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  border: 1px solid #d9d9d9;
}

.c-program-status__nutrition-intake li {
  width: 62px;
}

.c-program-status__nutrition-intake li + li {
  border-left: 1px solid #d9d9d9;
}

.c-program-status__information {
  margin-bottom: 23px;
  max-width: 320px;
}

.c-program-status__information dl {
  border: 1px solid #d9d9d9;
}

.c-program-status__information dl div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-program-status__information dl div + div {
  border-top: 1px solid #d9d9d9;
}

.c-program-status__information dt,
.c-program-status__information dd {
  padding: 4px 8px;
  font-size: 1.3rem;
  line-height: 1.46;
}

.c-program-status__information dt {
  min-width: 40px;
  font-weight: 600;
  text-align: center;
  border-right: 1px solid #d9d9d9;
  background-color: #f7f7f6;
}

.c-program-status__information a {
  color: #2d2d2d;
}

.c-program-status__food-table {
  margin-top: 15px;
}

.c-program-status__food-table table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid #d9d9d9;
}

.c-program-status__food-table thead th {
  color: #fff;
  background-color: #f7f7f6;
}

.c-program-status__food-table thead th[data-th="progress"] {
  background-color: #8d8d8d;
}

.c-program-status__food-table thead th[data-th="content"] {
  background-color: #2d2d2d;
}

.c-program-status__food-table thead th + th {
  border-left: 1px solid #d9d9d9;
}

.c-program-status__food-table tbody tr {
  border-top: 1px solid #d9d9d9;
}

.c-program-status__food-table tbody th {
  background-color: #f7f7f6;
}

.c-program-status__food-table tbody th a {
  color: #2d2d2d;
}

.c-program-status__food-table tbody td {
  border-left: 1px solid #d9d9d9;
}

.c-program-status__food-table th,
.c-program-status__food-table td {
  text-align: left;
  padding: 6px 7px 5px;
  font-size: 1.3rem;
  line-height: 1.3;
}

.c-program-status__food-table th,
.c-program-status__food-table td span {
  font-weight: 600;
}

.c-program-status__food-table td span {
  display: inline-block;
  margin-right: 4px;
}

.c-program-status__food-table > p {
  margin-top: 10px;
  font-size: 1.3rem;
  line-height: 1.46;
}

.c-program-status__accodion-button-list {
  margin-bottom: 10px;
}

.c-program-status__accodion-button-list button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: none;
  border: none;
  cursor: pointer;
  color: #2d2d2d;
  font-size: 1.4rem;
  line-height: 1;
  text-decoration: underline;
}

.c-program-status__accodion-button-list button:hover {
  text-decoration: none;
}

.c-program-status__accodion-button-list button span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-program-status__accodion-button-list button span::after {
  display: block;
  content: "";
  margin-left: 6px;
  width: 6px;
  height: 10px;
  background-image: url("../image/icon-arrow-03.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  -webkit-transform: rotate(-90deg);
          transform: rotate(-90deg);
}

.c-program-status__label {
  display: inline-block;
  margin: 0 0 5px -15px;
  padding: 4px 10px 5px;
  color: #fff;
  font-size: 1.2rem;
  font-weight: 600;
  line-height: 1.5;
}

.c-program-status__label[data-label="progress"] {
  background-color: #8d8d8d;
}

.c-program-status__label[data-label="new"] {
  background-color: #128d70;
}

.c-record-list {
  margin-top: 20px;
}

.c-heading__center + .c-record-list {
  margin-top: 0;
}

.c-record-list__item {
  padding: 15px;
  border: 1px solid #d9d9d9;
  background-color: #fff;
}

.c-record-list__item + .c-record-list__item {
  margin-top: 15px;
}

.c-record-list__header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.c-record-list__header h3,
.c-record-list__header h4 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-record-list__header h3 a,
.c-record-list__header h4 a {
  color: #2d2d2d;
  font-size: 1.5rem;
  line-height: 1.47;
}

.c-record-list__header h3 span,
.c-record-list__header h4 span {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  display: inline-block;
  margin-left: 5px;
  padding: 1px 6px 2px;
  color: #fff;
  font-size: 1.1rem;
  line-height: 1.45;
}

.c-record-list__header h3 span[data-status="progress"],
.c-record-list__header h4 span[data-status="progress"] {
  background-color: #2d2d2d;
}

.c-record-list__header h3 span[data-status="stop"],
.c-record-list__header h4 span[data-status="stop"] {
  background-color: #8d8d8d;
}

.c-record-list__header-meta {
  margin-bottom: 10px;
}

.c-record-list__header-meta ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  margin-top: 4px;
}

.c-record-list__header-meta li {
  color: #8d8d8d;
  font-size: 1.2rem;
  line-height: 1.5;
}

.c-record-list__header-meta li + li {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-record-list__header-meta li + li::before {
  display: inline-block;
  content: "＞";
  margin: 0 6px;
}

.c-record-list__header .c-record-list__header-meta h4 a {
  font-weight: 500;
}

.c-record-list__button {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  -webkit-transition: background-color 300ms;
  transition: background-color 300ms;
}

.c-record-list__button::before {
  display: block;
  content: "";
}

.c-record-list__button[data-type="stop"] {
  background-color: rgba(162, 26, 26, 0.15);
}

.c-record-list__button[data-type="stop"]:hover {
  background-color: rgba(162, 26, 26, 0.3);
}

.c-record-list__button[data-type="restart"] {
  background-color: rgba(18, 141, 112, 0.15);
}

.c-record-list__button[data-type="restart"]:hover {
  background-color: rgba(18, 141, 112, 0.3);
}

.c-record-list__button[data-type="stop"]::before {
  width: 10px;
  height: 10px;
  background-color: #a21a1a;
}

.c-record-list__button[data-type="restart"]::before {
  margin-left: 2px;
  width: 11.5px;
  height: 12px;
  border-top: 6px solid transparent;
  border-right: 0 solid transparent;
  border-bottom: 6px solid transparent;
  border-left: 11.5px solid #128d70;
}

.c-record-list__button span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}

.c-record-list__information {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.c-record-list__information dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-record-list__information dl dt,
.c-record-list__information dl dd {
  color: #8d8d8d;
  font-size: 1rem;
  line-height: 1.5;
}

.c-record-list__information dl dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-record-list__information dl dt::after {
  display: block;
  content: "：";
}

.c-record-list__edit-button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
}

.c-record-list__edit-button:hover {
  font-weight: 600;
}

.c-record-list__edit-button span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  color: #128d70;
  font-size: 1.4rem;
  line-height: 1.5;
}

.c-record-list__edit-button span::before {
  display: block;
  content: "";
  margin-right: 4px;
  width: 13px;
  height: 13px;
  background-image: url("../image/icon-edit-01.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-record-list__package {
  margin-top: 12px;
}

.c-record-list__package dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  border: 1px solid #d9d9d9;
}

.c-record-list__package dt,
.c-record-list__package dd {
  font-size: 1.4rem;
  line-height: 1.3;
}

.c-record-list__package dt {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  padding: 10px 14px;
  min-width: 98px;
  font-weight: 600;
  border-right: 1px solid #d9d9d9;
  background-color: #f7f7f6;
}

.c-record-list__package dd {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 100%;
  padding: 7px 15px 8px 10px;
}

.c-record-list__package dd[data-status="before"] span {
  color: #8d8d8d;
}

.c-record-list__package dd a {
  color: #2d2d2d;
}

.c-record-list__create-button,
.c-record-list__edit-button {
  padding-left: 19px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
}

.c-record-list__create-button:hover,
.c-record-list__edit-button:hover {
  font-weight: 600;
}

.c-record-list__create-button span,
.c-record-list__edit-button span {
  color: #128d70;
  font-size: 1.4rem;
  line-height: 1.5;
}

.c-record-list__package dd a.c-record-list__create-button {
  color: #128d70;
  text-decoration: none;
}

.c-form__confirm .c-record-list__edit-button {
  display: block;
  margin: -7px 0 7px auto;
}

.c-record-list__create-button {
  position: relative;
}

.c-record-list__create-button::before, .c-record-list__create-button::after {
  position: absolute;
  top: calc(50% - 2px);
  left: 0;
  display: block;
  content: "";
  width: 14px;
  height: 2px;
  background-color: #128d70;
  border-radius: 1px;
}

.c-record-list__create-button::after {
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
}

.c-record-list__edit-button span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-record-list__edit-button span::before {
  display: block;
  content: "";
  margin-right: 4px;
  width: 13px;
  height: 13px;
  background-image: url("../image/icon-edit-01.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-record-list__link {
  margin-bottom: 30px;
  padding: 20px;
  text-align: center;
  background-color: #fff;
  border: 1px solid #d9d9d9;
}

.c-record-list__link a {
  color: #2d2d2d;
  font-size: 1.4rem;
  line-height: 1.5;
}

.c-package__item + .c-record-list__link,
.c-record-list__item + .c-record-list__link {
  border-top: none;
}

.c-record-list__delete-button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: none;
  border: none;
  cursor: pointer;
  margin: 14px 0 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  color: #c71a1a;
  font-size: 1.4rem;
  line-height: 1.5;
  -webkit-transition: font-weight 300ms;
  transition: font-weight 300ms;
}

.c-record-list__delete-button:hover {
  font-weight: 600;
}

.c-record-list__delete-button span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-record-list__delete-button span::before {
  display: block;
  content: "";
  margin-right: 6px;
  width: 10px;
  height: 10px;
  background-image: url("../image/icon-delete-01.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.c-registered {
  margin-bottom: 25px;
}

@media screen and (min-width: 767px) {
  .c-registered {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

.c-registered button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
}

.c-registered__item {
  background-color: #fff;
  border: 1px solid #d9d9d9;
}

@media screen and (min-width: 767px) {
  .c-registered__item {
    width: calc(50% - 10px);
    margin-bottom: 15px;
  }
}

.c-registered__item + .c-registered__item {
  margin-top: 10px;
}

@media screen and (min-width: 767px) {
  .c-registered__item:nth-child(2) {
    margin-top: 0;
  }
}

@media screen and (min-width: 767px) {
  .c-registered__item:nth-child(even) {
    margin-left: 20px;
  }
}

.c-registered__default {
  position: relative;
  padding: 13px 20px 18px;
  background-color: #fff;
  -webkit-transition: background-color 300ms;
  transition: background-color 300ms;
}

.c-registered__default[data-expanded="true"] {
  background-color: #e8e8e8;
}

.c-registered__default-information dt,
.c-registered__default-information dd {
  font-size: 1.4rem;
  line-height: 1.6;
}

.c-registered__default-information dt {
  color: #8d8d8d;
}

.c-registered__default-information dd {
  margin-bottom: 4px;
  font-weight: 600;
}

.c-registered__default-footer {
  margin-top: 8px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.c-registered__default-footer dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-registered__default-footer dt,
.c-registered__default-footer dd {
  color: #8d8d8d;
  font-size: 1rem;
  line-height: 1.54;
}

.c-registered__default-footer dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-registered__default-footer dt::after {
  display: block;
  content: "：";
}

.c-registered__accordion-button {
  font-size: 1.2rem;
  line-height: 1.54;
  text-decoration: underline;
}

.c-registered__accordion-button:hover {
  text-decoration: none;
}

.c-registered__accordion-button[aria-expanded="false"] span::after {
  -webkit-transform: rotate(0deg);
          transform: rotate(0deg);
}

.c-registered__accordion-button[aria-expanded="true"] span::after {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

.c-registered__accordion-button span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-registered__accordion-button span::after {
  display: block;
  content: "";
  margin-left: 5px;
  width: 8px;
  height: 8px;
  background-image: url("../image/icon-arrow-02.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  -webkit-transition: -webkit-transform 300ms;
  transition: -webkit-transform 300ms;
  transition: transform 300ms;
  transition: transform 300ms, -webkit-transform 300ms;
}

.c-registered .c-registered__delete-button {
  position: absolute;
  top: 16px;
  right: 16px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 30px;
  height: 30px;
  background-color: rgba(162, 26, 26, 0.15);
  border-radius: 50%;
  -webkit-transition: background-color 300ms;
  transition: background-color 300ms;
}

.c-registered .c-registered__delete-button:hover {
  background-color: rgba(162, 26, 26, 0.3);
}

.c-registered .c-registered__delete-button::before {
  display: block;
  content: "";
  width: 10px;
  height: 10px;
  background-image: url("../image/icon-delete-01.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.c-registered .c-registered__delete-button span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}

.c-registerd__blood-item[aria-hidden="true"] {
  display: none;
}

.c-registerd__blood-item-type {
  padding: 15px 16px 19px;
  border-bottom: 1px solid #d9d9d9;
}

.c-registerd__blood-item-type dt {
  margin-bottom: 3px;
  color: #e56813;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.8;
}

.c-registerd__blood-item-type dd {
  font-size: 1.2rem;
  line-height: 1.7;
}

.c-registerd__blood-item-blood-wrapper > dt {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}

.c-registerd__blood-item-blood > h3 {
  padding: 15px 16px 0;
  font-size: 1.4rem;
  line-height: 1.85;
}

.c-registerd__blood-item-blood > h3 + dl {
  margin-top: -5px;
}

.c-registerd__blood-item-blood dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  padding: 15px 16px 9px;
  border-bottom: 1px solid #d9d9d9;
}

.c-registerd__blood-item-blood dl > div {
  margin: 0 15px 10px 0;
}

.c-registerd__blood-item-blood dt,
.c-registerd__blood-item-blood dd {
  font-size: 1.4rem;
  line-height: 1.85;
}

.c-registerd__blood-item-blood dt {
  margin-bottom: 3px;
  font-weight: 600;
}

.c-registerd__blood-item-blood dt sup {
  color: #c71a1a;
  font-size: 1.4rem;
  line-height: 1.85;
  vertical-align: baseline;
}

.c-registerd__blood-item-blood dd {
  letter-spacing: .05em;
}

.c-registerd__blood-item-blood dd span {
  font-size: 1.2rem;
}

.c-registered__edit-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 13px 17px 14px auto;
  color: #128d70;
  font-size: 1.4rem;
  -webkit-transition: font-weight 300ms;
  transition: font-weight 300ms;
}

.c-registered__edit-button:hover {
  font-weight: 600;
}

.c-registered__edit-button span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.c-registered__edit-button span::before {
  display: block;
  content: "";
  margin-right: 4px;
  width: 13px;
  height: 13px;
  background-image: url("../image/icon-edit-01.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-registered__item-check {
  padding: 17px 19px 0;
}

.c-registered__item-check[aria-hidden="true"] {
  display: none;
}

.c-search__text {
  margin-bottom: 25px;
  padding: 20px;
  background-color: #fff;
  border-bottom: 1px solid #d9d9d9;
}

.c-wrapper .c-search__text {
  background-color: transparent;
  padding: 0 0 15px;
}

.c-heading__page + .c-search__text {
  margin-top: -25px;
}

.c-search__text-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding-right: 10px;
  background-color: #fff;
  border: 1px solid #d9d9d9;
}

@media screen and (min-width: 1000px) {
  .c-search__text-wrapper {
    width: 445px;
  }
}

.c-search__text-wrapper label {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}

.c-search__text-wrapper input {
  padding: 12px 10px 14px 20px;
  width: calc(100% - 48px);
  font-size: 1.6rem;
  line-height: 1.85;
  border: none;
}

@media screen and (min-width: 1000px) {
  .c-search__text-wrapper input {
    padding: 20px 26px 23px;
  }
}

.c-search__text-wrapper input::-webkit-input-placeholder {
  font-size: 1.4rem;
  color: #8d8d8d;
}

.c-search__text-wrapper input::-moz-placeholder {
  font-size: 1.4rem;
  color: #8d8d8d;
}

.c-search__text-wrapper input:-ms-input-placeholder {
  font-size: 1.4rem;
  color: #8d8d8d;
}

.c-search__text-wrapper input::-ms-input-placeholder {
  font-size: 1.4rem;
  color: #8d8d8d;
}

.c-search__text-wrapper input::placeholder {
  font-size: 1.4rem;
  color: #8d8d8d;
}

.c-search__text-wrapper button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  width: 38px;
  height: 38px;
  background: none;
  background-color: #2d2d2d;
  background-image: url("../image/icon-search-01.svg");
  background-size: 19px 19px;
  background-position: center;
  background-repeat: no-repeat;
  border-radius: 50%;
  cursor: pointer;
}

@media screen and (min-width: 1000px) {
  .c-search__text-wrapper button {
    width: 50px;
    height: 50px;
    background-size: 25px 25px;
  }
}

.c-search__text-wrapper button span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}

.c-sort {
  position: relative;
  width: 250px;
  margin: 0 auto 20px;
}

@media screen and (min-width: 1000px) {
  .c-sort {
    margin-left: 0;
  }
}

.c-sort::before {
  position: absolute;
  top: 21px;
  right: 19px;
  display: block;
  content: "";
  width: 8px;
  height: 8px;
  background-image: url("../image/icon-arrow-02.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-sort select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 100%;
  padding: 12px 30px 12px 15px;
  font-size: 1.6rem;
  background-color: #fff;
  border: 1px solid #d9d9d9;
  border-radius: 2px;
}

.c-sort__year-month {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: 20px;
}

@media screen and (min-width: 1000px) {
  .c-sort__year-month {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    margin-top: 30px;
    margin-bottom: 30px;
  }
}

.c-sort__year-month > div + div {
  margin-left: 10px;
}

.c-tab-bar {
  position: fixed;
  right: 0;
  bottom: 0;
  width: 100%;
  background-color: #fff;
  z-index: 10;
}

@media screen and (min-width: 1000px) {
  .c-tab-bar {
    position: static;
  }
}

.c-tab-bar[data-only="pc"] {
  display: none;
}

@media screen and (min-width: 1000px) {
  .c-tab-bar[data-only="pc"] {
    display: block;
  }
}

.c-tab-bar ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  width: 100%;
}

@media screen and (min-width: 1000px) {
  .c-tab-bar ul {
    display: block;
  }
}

.c-tab-bar li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  width: 20%;
}

@media screen and (min-width: 1000px) {
  .c-tab-bar li {
    width: 100%;
    border-bottom: 1px solid #d9d9d9;
  }
}

.c-tab-bar a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 7px;
  width: 100%;
}

@media screen and (min-width: 1000px) {
  .c-tab-bar a {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    padding: 18px 20px;
    color: #8d8d8d;
    font-size: 1.5rem;
    text-decoration: none;
  }
}

.c-tab-bar a:hover {
  color: #e56813;
}

@media screen and (min-width: 1000px) {
  .c-tab-bar a[aria-describedby="current"] {
    color: #2d2d2d;
  }
}

.c-tab-bar a::before {
  display: block;
  content: "";
  width: 31px;
  height: 31px;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.c-tab-bar a span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}

@media screen and (min-width: 1000px) {
  .c-tab-bar a span {
    position: static;
    width: auto;
    height: auto;
    overflow: auto;
    clip: none;
    margin-left: 11px;
  }
}

.c-tab-bar li[data-nav="account"] a::before {
  display: none;
}

.c-tab-bar li[data-nav="client"] a:hover::before, .c-tab-bar li[data-nav="client"] a[aria-describedby="current"]::before {
  background-image: url("../image/icon-client-01-current.svg");
}

.c-tab-bar li[data-nav="client"] a::before {
  background-image: url("../image/icon-client-01.svg");
}

.c-tab-bar li[data-nav="record"] a:hover::before, .c-tab-bar li[data-nav="record"] a[aria-describedby="current"]::before {
  background-image: url("../image/icon-record-01-current.svg");
}

.c-tab-bar li[data-nav="record"] a::before {
  background-image: url("../image/icon-record-01.svg");
}

.c-tab-bar li[data-nav="create"] a:hover::before, .c-tab-bar li[data-nav="create"] a[aria-describedby="current"]::before {
  background-image: url("../image/icon-add-01-current.svg");
}

.c-tab-bar li[data-nav="create"] a::before {
  background-image: url("../image/icon-add-01.svg");
}

.c-tab-bar li[data-nav="notification"] a:hover::before, .c-tab-bar li[data-nav="notification"] a[aria-describedby="current"]::before {
  background-image: url("../image/icon-notification-01-current.svg");
}

.c-tab-bar li[data-nav="notification"] a::before {
  background-image: url("../image/icon-notification-01.svg");
}

.c-tab-bar li[data-nav="program"] a:hover::before, .c-tab-bar li[data-nav="program"] a[aria-describedby="current"]::before {
  background-image: url("../image/icon-program-01-current.svg");
}

.c-tab-bar li[data-nav="program"] a::before {
  background-image: url("../image/icon-program-01.svg");
}

.c-tab-bar li[data-nav="graph"] a:hover::before, .c-tab-bar li[data-nav="graph"] a[aria-describedby="current"]::before {
  background-image: url("../image/icon-graph-02-current.svg");
}

.c-tab-bar li[data-nav="graph"] a::before {
  background-image: url("../image/icon-graph-02.svg");
}

.c-tab-bar li[data-nav="setting"] a:hover::before, .c-tab-bar li[data-nav="setting"] a[aria-describedby="current"]::before {
  background-image: url("../image/icon-setting-01-current.svg");
}

.c-tab-bar li[data-nav="setting"] a::before {
  background-image: url("../image/icon-setting-01.svg");
}

.c-tab-bar__account {
  width: 31px;
  height: 31px;
  background-image: url("../image/dummy-profile.svg");
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  border-radius: 50%;
  overflow: hidden;
}

.c-tab__client {
  padding: 0 10px;
  margin-bottom: 20px;
  background-color: #fff;
  border-bottom: 1px solid #d9d9d9;
}

@media screen and (min-width: 1000px) {
  .c-tab__client {
    padding: 0 46px;
    margin-bottom: 30px;
  }
}

.c-tab__client[data-tab="modal"] {
  margin: -25px 0 20px;
}

@media screen and (min-width: 1000px) {
  .c-tab__client[data-tab="modal"] ul {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

.c-tab__client ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

@media screen and (min-width: 1000px) {
  .c-tab__client ul {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
}

.c-tab__client li {
  margin: 0 7.5px;
  line-height: 1;
}

.c-tab__client a {
  display: block;
  color: #2d2d2d;
  text-decoration: none;
}

.c-tab__client button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: none;
  cursor: pointer;
}

.c-tab__client a,
.c-tab__client button {
  padding: 16px 0 18px;
  font-size: 1.4rem;
  line-height: 1.2;
  border-bottom: 1px solid #fff;
  -webkit-transition: font-weight 300ms, border-bottom 300ms;
  transition: font-weight 300ms, border-bottom 300ms;
}

.c-tab__client a:hover,
.c-tab__client a[data-link="current"],
.c-tab__client button:hover,
.c-tab__client button[aria-selected="true"] {
  font-weight: 600;
  border-bottom: 1px solid #000;
}

.c-tab__client-notification {
  position: relative;
}

.c-tab__client-notification-mark {
  position: absolute;
  top: 13px;
  right: -2px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background-color: #c71a1a;
}

.c-tab__client-notification-mark span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}

.c-wrapper {
  max-width: 730px;
  padding: 0 20px;
  margin: 0 auto;
}

@media screen and (min-width: 1000px) {
  .c-wrapper {
    max-width: 690px;
    padding: 0;
    margin-left: 44px;
  }
}

.c-wrapper[data-genre="form"] {
  max-width: 640px;
}

.c-wrapper[data-genre="minimum"] {
  padding-top: 20px;
}

@media screen and (min-width: 1000px) {
  .c-wrapper[data-genre="minimum"] {
    max-width: 640px;
    margin: 0 auto;
  }
}

.c-wrapper[data-separate="header"] {
  margin-top: 20px;
}

.c-modal__wrapper[data-modal="secondary"] .c-wrapper {
  margin: 0 auto;
  padding-bottom: 60px;
}

.p-front {
  padding: 95px 0 0;
  width: 100%;
  min-height: 100vh;
  color: #fff;
  background-image: url("../image/bg-front-sp.jpg");
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
}

@media screen and (min-width: 767px) {
  .p-front {
    padding: 162px 0 0;
    background-image: url("../image/bg-front-pc.jpg");
  }
}

.p-front a {
  color: #fff;
}

.p-front__wrapper {
  width: 225px;
  margin: 0 auto;
}

.p-front__site-name {
  margin-bottom: 28px;
  text-align: center;
}

.p-front__site-name p {
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.47;
}

.p-front__site-logo {
  margin-bottom: 30px;
}

.p-front__button-list {
  margin-bottom: 20px;
}

.p-front__button-list li + li {
  margin-top: 10px;
}

.p-front__button-list a {
  display: block;
  width: 100%;
  padding: 16px 15px 17px;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.8;
  text-align: center;
  text-decoration: none;
  background-color: #e56813;
  -webkit-transition: background-color 300ms;
  transition: background-color 300ms;
}

.p-front__button-list a:hover {
  background-color: #ce5607;
}

.p-front__button-list a[data-link="login"] {
  background-color: rgba(255, 255, 255, 0.25);
}

.p-front__button-list a[data-link="login"]:hover {
  background-color: rgba(255, 255, 255, 0.35);
}

.p-front__login-link,
.p-front__footer-link {
  font-size: 1.3rem;
  font-weight: 600;
  line-height: 1.46;
  text-align: center;
}

.p-front__login-link {
  margin-bottom: 76px;
}
/*# sourceMappingURL=style.css.map */