@charset "UTF-8";
/* var */
td.text-normal {
  font-size: 16px;
}

/* FORM 既存 */
.form__table .mod-table-purchaseForm .selectWrap .mod-select {
  width: 100% !important;
}

.form__table .mod-table-purchaseForm th {
  background-color: #138c64;
}
.form__table .mod-table-purchaseForm th.eng {
  background-color: #2487be;
}
.form__table .mod-table-purchaseForm th.cell-toric {
  background-color: #138c64;
}
.form__table .mod-table-purchaseForm th.cell-eng {
  background-color: #138c64;
}

.hanbai-purchaseForm-footerLine {
  margin-top: 40px;
}
.hanbai-purchaseForm-footerLine a.mod-btn-01.line_add_friend {
  width: 100%;
  background: #4cc764;
  max-width: 546px;
}

.hr {
  display: block;
  border: 0;
  outline: 0;
  width: 50%;
  margin: 4rem auto 0;
}
.hr.hr-toric {
  border-top: 2px dashed #138c64;
}

/* ------------------------ */
/* ------------------------ */
.btnArea .btn {
  cursor: pointer;
  position: relative;
  z-index: 7;
  display: flex;
  margin: 0 auto;
  padding: 0 0.5rem;
  gap: 0.5rem;
  width: 100%;
  max-width: 500px;
  height: 4rem;
  align-items: center;
  text-align: center;
  overflow-wrap: anywhere;
  border-radius: 4rem;
}
.btnArea .btn__icon {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  width: 3rem;
  height: 3rem;
  aspect-ratio: 1;
  padding: 0.25rem;
  overflow: hidden;
  border-radius: 50%;
}
.btnArea .btn__icon svg {
  position: relative;
  left: -0.05rem;
}
.btnArea .btn__text {
  flex-shrink: 1;
  width: 100%;
  display: flex;
  gap: 0.1rem;
  flex-direction: column;
  align-items: center;
  font-size: 1.25rem;
  color: white;
  font-weight: 700;
}
.btnArea .btn__text small {
  font-size: 0.85rem;
}
.btnArea .btn__text em {
  display: inline-block;
  background-color: #f4c300;
  color: #333;
  border-radius: 4px;
  margin-right: 0.25rem;
  padding: 0 0.25rem;
}
.btnArea .btn.btn-toric {
  background: linear-gradient(90deg, #73d1af, #2487be);
  margin-top: 20px;
}
.btnArea .btn.btn-toric .btn__icon svg {
  stroke: #138c64;
}

/* ------------------------ */
/* ------------------------ */
.spec-confirm {
  border: 1px solid #cc0000;
  border-radius: 4px;
  padding: 1rem 0.5rem 0.5rem 0.5rem;
}
.spec-confirm *, .spec-confirm p {
  font-size: 0.85rem;
}
.spec-confirm small {
  font-size: 0.75rem;
}
.spec-confirm__title {
  text-align: center;
  margin-bottom: 0.5rem;
  font-size: 1rem;
  font-weight: 700;
  color: #cc0000;
}
.spec-confirm__checkList {
  margin-bottom: 1rem;
}
.spec-confirm__checkList li {
  position: relative;
  padding-left: 1em;
  margin-bottom: 0.5em;
}
.spec-confirm__checkList li::before {
  content: "●";
  font-size: 0.5em;
  color: #cc0000;
  display: flex;
  width: 1em;
  height: 1.19rem;
  justify-content: flex-start;
  align-items: center;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
}
.spec-confirm__body > h6 {
  position: relative;
  margin-bottom: 0.25em;
  color: #138c64;
  font-weight: 700;
}
.spec-confirm__body > h6.eng {
  color: #2487be;
}
.spec-confirm__body .spec-list {
  width: 100%;
}
.spec-confirm__body .spec-list__header {
  position: relative;
  cursor: pointer;
  padding: 0.5rem 2rem 0.5rem 0.5rem;
  border-radius: 4px;
  border: 1px solid black;
  margin-bottom: -1px;
  background-color: black;
  color: white;
  font-weight: 700;
}
.spec-confirm__body .spec-list__header.open span svg {
  transform: rotate(180deg);
}
.spec-confirm__body .spec-list__header.open span svg line.close {
  opacity: 0;
}
.spec-confirm__body .spec-list__header span {
  position: absolute;
  top: 0;
  right: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  width: 2rem;
  z-index: 3;
}
.spec-confirm__body .spec-list__header span svg {
  stroke: white;
  transition: transform 0.3s ease;
  will-change: transform;
}
.spec-confirm__body .spec-list__body {
  display: none;
  padding-top: 0.5rem;
}
.spec-confirm__body .spec-list__body .spec-table {
  width: 100%;
  margin-bottom: 1rem;
}
.spec-confirm__body .spec-list__body .spec-table thead .title {
  border: none;
  text-align: left;
}
.spec-confirm__body .spec-list__body .spec-table th, .spec-confirm__body .spec-list__body .spec-table td {
  border: 1px solid white;
  text-align: center;
  padding: 0.25rem;
  font-size: 0.75rem;
  line-height: 1.25;
}
.spec-confirm__body .spec-list__body .spec-table th small, .spec-confirm__body .spec-list__body .spec-table td small {
  font-size: 0.5rem;
  font-weight: 300;
}
.spec-confirm__body .spec-list__body .spec-table th {
  font-weight: 700;
  color: white;
  background-color: #73d1af;
  font-size: 0.65rem;
  width: 16.6666666667%;
}
.spec-confirm__body .spec-list__body .spec-table th.toric {
  background-color: #138c64;
}
.spec-confirm__body .spec-list__body .spec-table th.eng {
  background-color: #2487be;
}
.spec-confirm__body .spec-list__body .spec-table th.pwr {
  width: 20%;
}
.spec-confirm__body .spec-list__body .spec-table td {
  background-color: #e6e6e6;
}
.spec-confirm__body .spec-list__body .spec-table td:nth-child(odd) {
  background-color: #fafafa;
}
.spec-confirm__body .spec-list__body .spec-picture h5 {
  text-align: center;
  display: block;
  background-color: white;
  position: relative;
}
.spec-confirm__body .spec-list__body .spec-picture h5 span {
  display: inline-block;
  padding: 0 0.25rem;
  font-weight: 700;
  background-color: white;
  position: relative;
  z-index: 1;
}
.spec-confirm__body .spec-list__body .spec-picture h5::before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  border-top: 1px dashed #138c64;
  position: absolute;
  z-index: 0;
  left: 0;
  top: 50%;
}
.spec-confirm__body .spec-list__body .spec-picture img {
  width: 100%;
  max-width: 600px;
}

/* MODAL 確認用 */
.close-confirmation {
  display: flex;
  height: 45px;
  width: 45px;
  background-color: #138c64;
  justify-content: center;
  align-items: center;
  border-radius: 50%;
  cursor: pointer;
  position: absolute;
  top: 5px;
  right: 5px;
}
.close-confirmation svg {
  width: 35px;
  height: 35px;
  stroke: #fff;
}

.overlay {
  width: 100%;
  min-height: 100vh;
  height: 100dvh;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  padding: 0.5rem;
  position: fixed;
  top: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.75);
  opacity: 0;
  pointer-events: none;
  transition: 0.35s ease-in-out;
  max-height: 100dvh;
  overflow: hidden;
  box-sizing: border-box;
}
.overlay.open {
  opacity: 1;
  pointer-events: inherit;
}
.overlay .confirmation {
  opacity: 0;
  pointer-events: none;
  transition: 0.35s ease-in-out;
}
.overlay .confirmation.open {
  opacity: 1;
  pointer-events: inherit;
}
.overlay .confirmation.open .content {
  transform: translate(0, 0px);
  opacity: 1;
}
.overlay .confirmation .content {
  transform: translate(0, -10px);
  opacity: 0;
  transition: 0.35s ease-in-out;
}

.confirmation {
  position: relative;
  z-index: 3;
  background-color: #fff;
  padding: 55px 1rem 50px 1rem;
  box-shadow: 0px 1px 10px rgba(255, 255, 255, 0.35);
  height: 100%;
  width: 100%;
  max-width: 750px;
  overflow-y: auto;
  border-radius: 4px;
  font-size: 0.85rem;
}
.confirmation .color-important {
  color: #cc0000;
}
.confirmation__header {
  text-align: center;
}
.confirmation__header .important {
  margin-bottom: 1rem;
}
.confirmation__header .important > p {
  color: #cc0000;
  font-weight: 700;
  font-size: 0.85rem;
}
.confirmation__header h3 {
  font-weight: 700;
  font-size: 1.25rem;
  margin-bottom: 1rem;
}
.confirmation__header .text h5, .confirmation__header .text h6 {
  font-weight: 700;
  margin-bottom: 0.5rem;
}
.confirmation__header .text h5 {
  font-size: 1rem;
}
.confirmation__header .text h6 {
  font-size: 0.85rem;
  color: #3b3b66;
}
.confirmation__header .text p {
  font-size: 0.85rem;
  text-align: center;
}
.confirmation__body .text {
  margin-bottom: 0.5rem;
}
.confirmation__body .text p {
  font-size: 0.85rem;
  text-align: center;
}
.confirmation__table {
  width: 100%;
  max-width: 500px;
  margin: 0 auto 30px;
}
.confirmation__table th, .confirmation__table td {
  border: 1px solid #333;
  text-align: center;
  padding: 5px 5px;
}
.confirmation__table th.cell-toric, .confirmation__table td.cell-toric {
  background-color: #138c64;
}
.confirmation__table th.cell-eng, .confirmation__table td.cell-eng {
  background-color: #2487be;
}
.confirmation__table td.error {
  border: 2px solid #cc0000;
  background-color: rgba(204, 0, 0, 0.15);
}
.confirmation__table thead th {
  background-color: #138c64;
  color: #fff;
  font-weight: 700;
}
.confirmation__table tbody th {
  font-weight: 700;
  width: 50%;
}
.confirmation__table tbody td {
  min-width: 25%;
}
.confirmation__footer {
  border-radius: 5rem;
  max-width: 500px;
  margin: 0 auto;
}
.confirmation__footer .button {
  cursor: pointer;
  background: linear-gradient(#ff6666, #ff0000);
  border-radius: 5rem;
  max-width: 500px;
  margin: 0 auto;
}
.confirmation__footer .button.disable {
  cursor: no-drop;
  pointer-events: none;
  background: linear-gradient(#ddd, #ccc);
}
.confirmation__footer .button .btnInner {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  width: 100%;
  min-height: 76px;
  color: #fff;
  padding: 9px 65px 10px 45px;
  text-decoration: none !important;
  cursor: pointer;
  font-weight: 600;
  font-size: 28px;
  line-height: 1.2em;
  letter-spacing: 0em;
}
.confirmation .box {
  margin-bottom: 10px;
}
.confirmation .box h5 {
  font-weight: 700;
  margin-bottom: 10px;
}
.confirmation .box fieldset p {
  margin-top: 10px;
}
.confirmation .box fieldset label {
  display: inline-flex;
  height: 48px;
  align-items: center;
  gap: 0 0.5em;
  position: relative;
  cursor: pointer;
  font-weight: 700;
  font-size: 1.15rem;
}
.confirmation .box fieldset label::before, .confirmation .box fieldset label:has(:checked)::after {
  content: "";
  inset: 0;
}
.confirmation .box fieldset label::before {
  width: 24px;
  height: 24px;
  border-radius: 4px;
  background-color: #fff;
  border: 1px solid #333;
}
.confirmation .box fieldset label:has(:checked)::before {
  background-color: #138c64;
  border: 1px solid #138c64;
}
.confirmation .box fieldset label:has(:checked)::after {
  position: absolute;
  top: 16px;
  left: 8px;
  transform: rotate(45deg);
  width: 8px;
  height: 12px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
}
.confirmation .box fieldset input {
  display: none;
}

.hanbai-kv {
  background-color: #eaeaea;
}

.hanbai-kv-img {
  justify-items: center;
}
.hanbai-kv-img img {
  width: 50%;
  margin: auto;
}
@media only screen and (max-width: 1023px) {
  .hanbai-kv-img img {
    width: 100%;
  }
}

.hanbai-title {
  font-size: 27px;
  font-family: "Zen Kaku Gothic New", sans-serif;
  text-align: center;
  color: #3b3b66;
  font-weight: 700;
}
@media (min-width: 768px) {
  .hanbai-title {
    font-size: 46px;
  }
}
.hanbai-title.hanbai-title--white {
  color: #fff;
}
.hanbai-title .toric {
  color: #138c64;
}
.hanbai-title .eng {
  color: #2487be;
}

.hanbai-experience {
  text-align: center;
  padding-top: 60px;
}
.hanbai-experience-wrap {
  max-width: 390px;
  margin: auto;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 100%;
  gap: 10px;
}
.hanbai-experience-item {
  position: relative;
  width: fit-content;
  height: fit-content;
  text-align: center;
  margin: 20px auto 0;
  padding: 18px;
  border-radius: 16px;
  background-color: #fff;
  box-shadow: 0px 2px 8px 4px rgba(0, 0, 0, 0.1);
}
.hanbai-experience-item:nth-of-type(2) {
  margin-top: 32px;
}
.hanbai-experience-item:nth-of-type(3) {
  margin-top: 0;
}
.hanbai-experience-item img {
  max-width: 130px;
}
.hanbai-experience-item p {
  display: block;
  width: 100%;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 21px;
  font-weight: 700;
  text-align: center;
  line-height: 1.5em;
  letter-spacing: 0.02em;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 1023px) {
  .hanbai-experience-item p {
    font-size: 16px;
  }
}
.hanbai-experience-item p span {
  display: inline-block;
  position: relative;
}
.hanbai-experience-item p span:before {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 40%;
  bottom: 0;
  right: 50%;
  transform: translate(50%, 0);
  background-color: #ffc400;
  z-index: -1;
}
.hanbai-experience-img {
  display: block;
  height: 150px;
  position: relative;
  width: 100%;
  margin-bottom: 20px;
}
.hanbai-experience-img::before {
  content: "";
  background: url(../img/category/1day_clear_both/experience.png) no-repeat center;
  position: absolute;
  top: -10px;
  width: 100%;
  height: 100%;
  display: block;
  background-size: contain;
}

.hanbai-experience .hanbai-experience-footer:before {
  border-top: 20px solid #fff;
  border-top-width: 12px;
}

.hanbai-achievment {
  margin: auto;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding-bottom: 80px;
}
.hanbai-achievment img {
  max-width: 634px;
  width: 100%;
}
@media print, screen and (min-width: 1024px) {
  .hanbai-achievment img {
    width: 50%;
  }
}
.hanbai-achievment .hanbai-title {
  margin-bottom: 24px;
}

.hanbai-experience .hanbai-experience-footer {
  margin-top: 0;
}

.hanbai-experience-footerLine {
  padding: 1em;
  background-color: #d9f0ed;
}

.hanbai-mailSetting .hanbai-mailSetting-hl:before {
  background: url(../img/category/1day_clear_toric/mailsetting_hl_bg_01.png) no-repeat center/contain;
}

.hanbai-reason .hanbai-reason-list .listItem:first-of-type .listItem-img {
  background-image: url(../img/category/1day_clear_toric/reason_list_img_01.svg);
}

.hanbai-reason .hanbai-reason-list .listItem:nth-of-type(2) .listItem-img {
  background-image: url(../img/category/1day_clear_toric/reason_list_img_02.svg);
}

.hanbai-reason .hanbai-reason-list .listItem:nth-of-type(3) .listItem-img {
  background-image: url(../img/category/1day_clear_toric/reason_list_img_03.svg);
}

.hanbai-reason .hanbai-reason-list .listItem:nth-of-type(4) .listItem-img {
  background-image: url(../img/category/1day_clear_toric/reason_list_img_04.svg);
}

.hanbai-reason .hanbai-reason-list .listItem:nth-of-type(5) .listItem-img {
  background-image: url(../img/category/1day_clear_toric/reason_list_img_05.svg);
}

.hanbai-reason .hanbai-reason-list .listItem:nth-of-type(6) .listItem-img {
  background-image: url(../img/category/1day_clear_toric/reason_list_img_06.svg);
}

.hanbai-reason .hanbai-reason-list .listItem:nth-of-type(7) .listItem-img {
  background-image: url(../img/category/1day_clear_toric/reason_list_img_07.svg);
}

.hanbai-experience-footerLine .line_add_friend.mod-btn-01 {
  display: inline-flex;
  max-width: 375px;
  box-shadow: 7px 7px 5px 0px rgba(0, 0, 0, 0.15);
}
@media (min-width: 768px) {
  .hanbai-experience-footerLine .line_add_friend.mod-btn-01 {
    max-width: 480px;
  }
}
.hanbai-experience-footerLine .line_add_friend.mod-btn-01::before {
  content: "";
  position: relative;
  display: inline-block;
  background: url(../img/category/1day_clear_toric/icon_line.svg) no-repeat center/contain;
  width: 40px;
  height: 40px;
  align-self: center;
  left: 16px;
}

.sub-linkBlock .sub-linkBlock-btnContainer .sub-linkBlock-btn {
  margin: 20px auto !important;
}

.sub-linkBlock-btn__text.mod-btn-01 {
  display: inline-flex;
  background: linear-gradient(135deg, #138c64, #2487be);
  box-shadow: 7px 7px 5px 0px rgba(0, 0, 0, 0.15);
}
.sub-linkBlock-btn__text.mod-btn-01::after {
  right: 35px;
}
.sub-linkBlock-btn__text.mod-btn-01 .btnInner {
  position: relative;
  padding: 0 0 0 32px;
  justify-content: normal;
}
.sub-linkBlock-btn__text.mod-btn-01 .btnInner::before {
  content: "";
  position: relative;
  display: inline-block;
  background: url(../img/category/1day_clear_toric/icon_guide.svg) no-repeat center/contain;
  width: 40px;
  height: 40px;
  align-self: center;
}

.mod-btn-01.sub-linkBlock-btn {
  background: linear-gradient(90deg, #73d1af, #2487be);
  box-shadow: 7px 7px 5px 0px rgba(0, 0, 0, 0.15);
}

.mod-btn-01.sub-linkBlock-btn.sub-linkBlock-btn__icon {
  background: linear-gradient(90deg, #fe9a30, #ee4032);
}
.mod-btn-01.sub-linkBlock-btn.sub-linkBlock-btn__icon::before {
  background: url(../img/category/1day_clear_toric/label_recommend.svg) no-repeat center/contain;
  left: 40px;
}
.mod-btn-01.sub-linkBlock-btn.sub-linkBlock-btn__icon .btnInner::before {
  content: "";
  background: url(../img/category/1day_clear_toric/icon_track.svg) no-repeat center/contain;
  width: 40px;
  height: 40px;
  align-self: center;
  display: inline-block;
  margin-right: 6px;
}

.sub-linkBlock .sub-linkBlock-hl {
  color: #3b3b66;
  border-bottom: none;
  position: relative;
  z-index: 1;
}
.sub-linkBlock .sub-linkBlock-hl::before {
  content: "";
  position: absolute;
  height: 5px;
  width: 100%;
  background-color: #ffc400;
  opacity: 0.4;
  bottom: 5px;
  z-index: -1;
}

.hanbai-experience .hanbai-experience-footer,
.hanbai-flow,
.hanbai-reason,
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .plan-header {
  background: linear-gradient(135deg, #138c64, #2487be);
}

.hanbai-quality {
  background: linear-gradient(180deg, #138c64, #2487be);
}

.hanbai-quality .hanbai-quality-contents .contentsBox .content .content-txt__hl {
  color: #118d8b;
}

.content-txt ul {
  margin-top: 20px;
}
.content-txt li {
  position: relative;
  display: flex;
  align-items: baseline;
}
.content-txt li::before {
  content: "";
  width: 14px;
  height: 14px;
  border: 1px solid #138c64;
  display: inline-block;
  margin-right: 4px;
  flex-shrink: 0;
}
.content-txt .notice {
  margin-top: 12px;
  font-size: 0.8rem;
  color: #333;
}
.content-txt .text-alert {
  color: #cc0000;
}

@media (min-width: 768px) {
  .hanbai-lowPriced-flow img {
    width: 40%;
    margin: auto;
  }
}

.mod-hl-img.hanbai-lowPriced-simulator-hlSub img,
.result-body-hl__titleSub img {
  width: 100%;
}

.hanbai-lowPriced .hanbai-lowPriced-simulator {
  margin-top: 0;
}
.hanbai-lowPriced .hanbai-lowPriced-simulator .hanbai-title {
  margin-bottom: 20px;
}
.hanbai-lowPriced .hanbai-lowPriced-simulator .hanbai-lowPriced-simulator-result .result-body .result-body-hlInner {
  border: 2px solid #138c64;
}
.hanbai-lowPriced .hanbai-lowPriced-simulator .hanbai-lowPriced-simulator-result .result-body .result-body-hl__title {
  background-color: #138c64;
}
.hanbai-lowPriced .hanbai-lowPriced-simulator .hanbai-lowPriced-simulator-result .result-body .result-body-hl__price {
  color: #138c64;
}

.hanbai-purchaseForm .hanbai-purchaseForm-subscription .hanbai-purchaseForm-subscription-deaile .detaile-comparison .detaile-comparison-hl {
  color: #3b3b66;
}

.hanbai-purchaseForm-subSection.hanbai-purchaseForm-subscription {
  position: relative;
}
.hanbai-purchaseForm-subSection.hanbai-purchaseForm-subscription .hanbai-purchaseForm-subLabel-img {
  position: absolute;
  left: 7%;
  top: -25px;
  width: 60px;
  transform: translateX(-50%);
}
@media (min-width: 768px) {
  .hanbai-purchaseForm-subSection.hanbai-purchaseForm-subscription .hanbai-purchaseForm-subLabel-img {
    left: 29%;
    top: -45px;
    width: 100px;
  }
}

.hanbai-review-campaign-banner > img,
.hanbai-purchaseForm-subSection-img {
  width: 100%;
  margin: auto;
  display: block;
}
@media (min-width: 768px) {
  .hanbai-review-campaign-banner > img,
  .hanbai-purchaseForm-subSection-img {
    width: 50%;
  }
}

.hanbai-purchaseForm .hanbai-purchaseForm-subSection .subSection-cntents {
  margin: 10px auto 0;
}

.hanbai-spec {
  background-color: #fff;
  color: #3b3b66;
}
.hanbai-spec .itemBlock:nth-of-type(1) .itemBlock-hl {
  background: url(../img/category/1day_clear_both/spec_pkg_toric.png) no-repeat center/contain;
  height: 200px;
}
@media (min-width: 768px) {
  .hanbai-spec .itemBlock:nth-of-type(1) .itemBlock-hl {
    height: 463px;
  }
}
.hanbai-spec .itemBlock:nth-of-type(2) .itemBlock-hl {
  background: url(../img/category/1day_clear_both/spec_pkg_eng.png) no-repeat center/contain;
  height: 200px;
}
@media (min-width: 768px) {
  .hanbai-spec .itemBlock:nth-of-type(2) .itemBlock-hl {
    height: 463px;
  }
}
.hanbai-spec .itemBlock .itemBlock-contents-table th {
  color: #138c64;
}
.hanbai-spec .itemBlock .itemBlock-contents-table.itemBlock-contents-table--eng th {
  color: #24a0b9;
}
.hanbai-spec-accordion {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  cursor: pointer;
}
.hanbai-spec-accordion.open {
  transition: transform 0.3s ease, opacity 0.3s ease;
}
.hanbai-spec .hanbai-spec-items {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media (min-width: 768px) {
  .hanbai-spec .hanbai-spec-items {
    display: inline-flex;
    flex-direction: row;
  }
}
.hanbai-spec .hanbai-spec-items .itemBlock {
  width: 100%;
  padding: 32px;
  align-self: flex-start;
}
@media (min-width: 768px) {
  .hanbai-spec .hanbai-spec-items .itemBlock {
    width: 50%;
  }
}
.hanbai-spec .hanbai-spec-items .itemBlock:has(.hanbai-spec-accordion.open) {
  align-self: auto;
}
.hanbai-spec .hanbai-spec-items .itemBlock:nth-of-type(1) {
  background-color: #D9F0ED;
}
.hanbai-spec .hanbai-spec-items .itemBlock:nth-of-type(2) {
  background-color: #d3ecf1;
}
.hanbai-spec .item-name {
  text-align: center;
  font-size: 20px;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  color: #3b3b66;
  word-break: break-word;
}
.hanbai-spec .item-name span.tag {
  display: inline-block;
  margin-right: 6px;
  border-radius: 6px;
  color: #fff;
  padding: 4px 10px 6px;
}
.hanbai-spec .item-name span.tag {
  background-color: #138c64;
}
.hanbai-spec .item-name .tag.tag--eng {
  background-color: #2487be;
}

.accordion-btn {
  position: relative;
  display: inline-block;
  width: 14px;
  height: 14px;
  vertical-align: middle;
  margin-left: 8px;
  flex-shrink: 0;
}
.accordion-btn::before, .accordion-btn::after {
  content: "";
  position: absolute;
  background-color: #333;
  transition: transform 0.3s ease, opacity 0.3s ease;
  top: 50%;
  left: 50%;
}
.accordion-btn::before {
  width: 100%;
  height: 1px;
  transform: translate(-50%, -50%);
}
.accordion-btn::after {
  width: 1px;
  height: 100%;
  transform: translate(-50%, -50%);
}
.hanbai-spec-accordion.open .accordion-btn::before {
  transform: translate(-50%, -50%) rotate(180deg);
}
.hanbai-spec-accordion.open .accordion-btn::after {
  transform: translate(-50%, -50%) rotate(90deg) scale(0);
}

.hanbai-quality .contents-text-block {
  display: block;
  border-radius: 16px;
  background-color: #eaeaea;
  padding: 16px;
  position: relative;
  text-align: center;
  margin-top: 16px;
}
.hanbai-quality .contents-text-block::after {
  content: "";
  position: absolute;
  background: url(../img/category/1day_clear_toric/quality_anchor.svg) no-repeat center/contain;
  left: 50%;
  transform: translateX(-50%);
  width: 80%;
  height: 80%;
  top: 10%;
}
.hanbai-quality .contents-text-block p {
  color: #118d8b;
  font-size: 20px;
  position: relative;
  z-index: 1;
  font-weight: bold;
  text-align: center;
  word-break: normal;
}
.hanbai-quality .contents-text-block span {
  color: #118d8b;
  font-size: 12px;
  position: relative;
  z-index: 1;
}
.hanbai-quality .contents-text-block .notice {
  color: #000;
}
.hanbai-quality .contentsBox.contentsBox--trick {
  margin-top: 0;
}
@media (min-width: 768px) {
  .hanbai-quality .contentsBox.contentsBox--trick {
    margin-top: 52px;
  }
  .hanbai-quality .contentsBox.contentsBox--trick .content {
    flex-direction: column !important;
    width: 50%;
    margin: 0 auto;
    justify-content: flex-start;
  }
  .hanbai-quality .contentsBox.contentsBox--trick .content .content-img {
    width: 100%;
  }
  .hanbai-quality .contentsBox.contentsBox--trick .content:nth-of-type(n + 3) {
    margin-top: 20px;
  }
}
.hanbai-quality .hanbai-factory {
  width: 100%;
  display: block;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  -ms-overflow-style: -ms-autohiding-scrollbar;
  scrollbar-width: thin;
}
.hanbai-quality .hanbai-factory-wrap {
  display: flex;
  gap: 12px;
  padding: 12px 16px 12px 0;
  align-items: flex-start;
  scroll-snap-type: x mandatory;
}
.hanbai-quality .hanbai-factory-wrap img {
  flex: 0 0 80%;
  max-width: 80%;
  height: auto;
  display: block;
  scroll-snap-align: start;
}
@media (min-width: 768px) {
  .hanbai-quality .hanbai-factory-wrap img {
    flex: 0 0 calc(33.333% - 12px);
    max-width: calc(33.333% - 12px);
  }
}
.hanbai-quality .hanbai-factory-wrap:has(.certificate-wrap) {
  aspect-ratio: initial;
  max-height: inherit;
  gap: 20px;
}
.hanbai-quality .hanbai-factory-wrap:has(.certificate-wrap) img {
  flex: 0 0 auto;
  max-width: 100%;
}
@media (min-width: 768px) {
  .hanbai-quality .hanbai-factory-wrap:has(.certificate-wrap) {
    width: 50%;
  }
}
.hanbai-quality .hanbai-factory .certificate-wrap {
  flex-shrink: 0;
  width: 40%;
  display: block;
}
@media (min-width: 768px) {
  .hanbai-quality .hanbai-factory .certificate-wrap {
    width: 50%;
    height: fit-content;
    padding: 0 16px;
  }
}
.hanbai-quality .contentsBox.contentBox--factory {
  justify-content: center;
}
.hanbai-quality .contentsBox.contentBox--factory h3 {
  text-align: center;
}
.hanbai-quality .contentsBox.contentBox--factory p {
  text-align: center;
  margin-top: 12px;
  font-size: 14px;
}
@media (min-width: 768px) {
  .hanbai-quality .contentsBox.contentBox--factory p {
    font-size: 16px;
  }
}
.hanbai-quality .contentsBox.contentBox--factory .hanbai-title-wrap {
  margin-bottom: 20px;
}
.hanbai-quality .contentsBox.contentBox--factory .content {
  margin: auto;
}
.hanbai-quality .contentsBox.contentBox--factory .content img {
  width: 100%;
}
.hanbai-quality .contentsBox.contentBox--factory .notice {
  margin-top: 12px;
  font-size: 0.8rem;
  color: #333;
}
@media (min-width: 768px) {
  .hanbai-quality .contentsBox.contentBox--factory .content {
    margin: 63px 0 0;
  }
  .hanbai-quality .contentsBox.contentBox--factory .content .content-img {
    width: calc(50% - 16px);
  }
  .hanbai-quality .contentsBox.contentBox--factory .content .content-img img {
    margin: auto;
  }
}

.hanbai-faq .hanbai-faq-contents dl dt:before {
  background-color: #73d1af;
}

.hanbai-faq .hanbai-faq-contents dl dd {
  background-color: #eaeaea;
}

.mod-btn-01.hanbai-faq-moreBtn {
  background: linear-gradient(90deg, #73d1af, #2487be);
}

.hanbai-lowPricedInner {
  padding-bottom: 0;
}
@media only screen and (max-width: 1023px) {
  .hanbai-lowPricedInner {
    padding-bottom: 60px;
  }
}
.hanbai-lowPricedInner .notice {
  margin-top: 8px;
}

.hanbai-lowPriced .hanbai-lowPriced-lead em,
.hanbai-lowPriced .hanbai-lowPriced-flow .hanbai-lowPriced-flow-point .hanbai-lowPriced-flow-point-row > em {
  color: #3b3b66;
}
.hanbai-lowPriced .hanbai-lowPriced-lead em::after,
.hanbai-lowPriced .hanbai-lowPriced-flow .hanbai-lowPriced-flow-point .hanbai-lowPriced-flow-point-row > em::after {
  background-color: #3b3b66;
}

.hanbai-lowPriced .hanbai-lowPriced-comparisonChart {
  width: 100%;
  padding: 100px 16px 60px;
  margin: auto;
  /* --- プランカード --- */
  /* --- 価格セクション --- */
  /* --- 節約セクション --- */
  /* --- フッターカード --- */
}
@media only screen and (max-width: 1023px) {
  .hanbai-lowPriced .hanbai-lowPriced-comparisonChart {
    padding: 80px 16px 0;
  }
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart span.tag {
  color: #fff;
  font-size: 20px !important;
  padding: 4px 10px 5px;
  border-radius: 10px;
  display: inline-block;
  margin-right: 5px;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart span.tag:nth-of-type(1) {
  background-color: #138c64;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart span.tag:nth-of-type(3) {
  background-color: #2487be;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .hanbai-title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .hanbai-title-wrap {
  align-items: center;
  margin-bottom: 6px;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .hanbai-title-wrap .tag {
  margin-bottom: 8px;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .hanbai-title span {
  font-size: 27px;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .price-line, .hanbai-lowPriced .hanbai-lowPriced-comparisonChart .savings-line-wrap {
  display: inline-flex;
  font-weight: bold;
  text-align: center;
  line-height: 1.2;
  align-items: flex-end;
}
@media (min-width: 768px) {
  .hanbai-lowPriced .hanbai-lowPriced-comparisonChart .price-line, .hanbai-lowPriced .hanbai-lowPriced-comparisonChart .savings-line-wrap {
    font-size: 32px;
  }
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .savings-line {
  display: flex;
  flex-direction: column;
  margin-left: 6px;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .price-big {
  font-size: 45px;
  color: #E60012;
  margin: 0 5px;
  font-family: "Zen Kaku Gothic New", sans-serif;
}
@media (min-width: 768px) {
  .hanbai-lowPriced .hanbai-lowPriced-comparisonChart .price-big {
    font-size: 52px;
  }
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .price-unit {
  font-size: 16px;
  color: #E60012;
  font-weight: bold;
  display: flex;
  flex-direction: column;
  padding-bottom: 5px;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .price-unit:first-child {
  writing-mode: vertical-lr;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .price-black {
  font-size: 32px;
  font-weight: bold;
  text-align: center;
  margin-top: 4px;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .price-absolute {
  position: absolute;
  bottom: 35px;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  text-align: center;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .font-small {
  font-size: 8px;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .savings-line .price-unit {
  color: #E60012;
  display: inline;
  font-size: 20px;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .caption {
  font-size: 16px;
  text-align: center;
  margin-top: 5px;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .caption span {
  color: #999999;
  font-size: 12px;
  display: block;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .logo-box {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .logo-box .logo-inner {
  display: inline-flex;
  color: #fff;
  font-weight: bold;
  width: 100%;
  justify-content: center;
  margin-bottom: 10px;
  align-items: baseline;
  font-size: 20px;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .logo-box .dicon-logo {
  position: relative;
  display: block;
  mask-image: url(/libs/img/common/logo.svg);
  mask-repeat: no-repeat;
  mask-size: contain;
  background-color: #fff;
  height: 26px;
  width: 115px;
  margin-right: 4px;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .savings-section {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .plan-card {
  background-color: #eaeaea;
  margin-top: 24px;
  border-radius: 16px;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .plan-card:nth-of-type(2) {
  margin-top: 32px;
}
@media (min-width: 980px) {
  .hanbai-lowPriced .hanbai-lowPriced-comparisonChart .plan-card {
    width: 40%;
  }
  .hanbai-lowPriced .hanbai-lowPriced-comparisonChart .plan-card:nth-of-type(2) {
    margin-top: 24px;
  }
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .plan-card-wrap {
  display: inline-flex;
  gap: 24px;
  width: 100%;
  justify-content: center;
}
@media only screen and (max-width: 1023px) {
  .hanbai-lowPriced .hanbai-lowPriced-comparisonChart .plan-card-wrap {
    flex-direction: column;
    gap: 0;
  }
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .plan-body {
  padding: 0 16px 24px;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .plan-header {
  background-color: #138c64;
  padding: 15px;
  text-align: center;
  border-radius: 16px 16px 0 0;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .price-section {
  padding-bottom: 20px;
  margin: -20px auto 20px;
  text-align: center;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .example-title {
  position: absolute;
  font-size: 0.9rem;
  font-weight: bold;
  text-align: center;
  display: inline-block;
  border: 2px solid #3b3b66;
  border-radius: 32px;
  padding: 8px 16px;
  background-color: #fff;
  color: #3b3b66;
  top: -20px;
  left: 50%;
  transform: translateX(-50%);
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .example-text {
  font-size: 24px;
  font-weight: bold;
  text-align: center;
  margin: 24px auto 10px;
}
@media only screen and (max-width: 1023px) {
  .hanbai-lowPriced .hanbai-lowPriced-comparisonChart .example-text {
    font-size: 18px;
  }
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .example-image,
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .product-image {
  width: 100%;
  margin-top: 40px;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .tags-container {
  display: flex;
  justify-content: center;
  gap: 5px;
  margin-bottom: 10px;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .tags-container .tag-simple {
  font-size: 0.8rem;
  font-weight: bold;
  border: 1px solid #138c64;
  color: #138c64;
  padding: 3px 8px;
  border-radius: 5px;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .savings-badge {
  background-color: #3b3b66;
  color: white;
  font-size: 16px;
  font-weight: bold;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  height: 100px;
  width: 100px;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .logo-box img {
  width: 50%;
}
@media only screen and (max-width: 1023px) {
  .hanbai-lowPriced .hanbai-lowPriced-comparisonChart .logo-box img {
    width: 80%;
  }
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .summary-card {
  background-color: #ffc400;
  border-radius: 12px;
  padding: 20px;
  text-align: center;
  position: relative;
  margin: 32px auto 0;
  max-width: 500px;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .summary-card::after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  border-style: solid;
  border-width: 0 12.5px 10px 12.5px;
  border-color: transparent transparent #ffc400;
  translate: -50% -100%;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .summary-card .logo-box {
  margin-bottom: 16px;
  display: inline-flex;
  flex-direction: row;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .summary-card .logo-box p {
  font-size: 20px;
  text-align: left;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .summary-card .logo-box img {
  width: 50px;
  margin-right: 8px;
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .summary-card p {
  text-align: center;
}
@media (min-width: 768px) {
  .hanbai-lowPriced .hanbai-lowPriced-comparisonChart .summary-card p {
    font-size: 24px;
  }
}
.hanbai-lowPriced .hanbai-lowPriced-comparisonChart .summary-card span {
  font-weight: bold;
  display: block;
  font-size: 24px;
  margin-top: 4px;
}
@media (min-width: 768px) {
  .hanbai-lowPriced .hanbai-lowPriced-comparisonChart .summary-card span {
    margin-top: 10px;
    font-size: 42px;
  }
}

/* --- 比較例ボックス --- */
.example-box {
  border-radius: 16px;
  padding: 16px 16px 64px;
  margin: 32px auto;
  position: relative;
  border: 2px solid #3b3b66;
  background-color: #fff;
}
@media (min-width: 768px) {
  .example-box {
    padding: 16px 16px 0;
  }
}
.plan-card:nth-of-type(1) .example-box::before {
  content: "月額比較";
}
.plan-card:nth-of-type(2) .example-box::before {
  content: "年額比較";
}
.example-box::before {
  color: #fff;
  bottom: -28px;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
  font-size: 16px;
}
.example-box::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 90px solid transparent;
  border-left: 90px solid transparent;
  border-top: 40px solid #3b3b66;
  border-bottom: 0;
  bottom: -40px;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}

.data-check-section {
  margin-top: 24px;
  border-radius: 16px;
  border: 2px solid #033c4a;
}
@media (min-width: 768px) {
  .data-check-section {
    display: block;
  }
}
.data-check-section .plan-body {
  margin-bottom: 16px;
}
.data-check-section .plan-header {
  background-color: #033c4a;
  border-radius: 12px 12px 0 0;
  padding: 8px 16px;
  box-sizing: border-box;
  color: #fff;
}
.data-check-section .plan-header h2 {
  font-size: 18px;
  text-align: center;
}
.data-check-section .plan-header .plan-body {
  padding: 16px 32px;
}

.data-image-container {
  text-align: center;
  margin-bottom: 25px;
}

.lens-data-image {
  max-width: 90%;
  height: auto;
  margin: 20px auto 0;
}

.data-list {
  list-style: none;
  padding: 0 16px;
  margin: 0;
  text-align: left;
  justify-self: anchor-center;
}

.data-list li {
  font-size: 0.95rem;
  line-height: 1.6;
  margin-bottom: 8px;
  display: flex;
  align-items: flex-start;
}

.data-list li:last-child {
  margin-bottom: 0;
}

.data-list .list-num {
  margin-right: 8px;
  flex-shrink: 0;
}

.fixied-button {
  position: fixed;
  left: 0;
  bottom: 150px;
  display: block;
  height: 59px;
  width: 192px;
}
.fixied-button.fixied-button--line {
  bottom: 80px;
  width: 156px;
}
.fixied-button img {
  display: block;
  max-width: 100%;
  height: auto;
}

.fixied-wrap {
  position: fixed;
  right: 16px;
  bottom: 24px;
  z-index: 99;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
}

.fixied-button__close {
  position: absolute;
  top: -11px;
  right: -11px;
  width: 25px;
  height: 25px;
  border: 0;
  border-radius: 50%;
  background: #000;
  color: #fff;
  font-weight: 700;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  background: url(../img/category/1day_clear_toric/bnr_close.svg) no-repeat center/contain;
}

.fixied--hidden {
  display: none !important;
}