@charset "UTF-8";

:root {
  --white-color: #fff;
  --black-color: #373737;
  --gray-color-650: #7F7F7F;
  --gray-color-500: #9B9B9B;
  --gray-color-200: #D7D7D7;
  --gray-color-150: #D9D9D9;
  --gray-color-100: #EBEBEB;
  --gray-color-50: #F5F5F5;
  --portal-color-100: #4AB783;
  --portal-color-10: #EDF8F3;
  --portal-gradient : linear-gradient(90deg, #C7F2DD 0%, #EDF8F3 60%, #CCEED6 100%);
  --house-color-100: #4AAEB7;
  --house-color-10: #EDF7F7;
  --house-gradient : linear-gradient(90deg, #ABE8EC 0%, #EDF8F3 60%, #C9E9DA 100%);
  --housingcomplex-color-100: #0470CA;
  --housingcomplex-color-10: #E9F0FA;
  --housingcomplex-gradient : linear-gradient(90deg, #A2CAEB 0%, #EDF8F3 60%, #C9E9DA 100%);
  --zehinfo-color-100: #013A76;
  --zehinfo-color-10: #E2E8EE;
  --zehinfo-gradient : linear-gradient(90deg, #649ad3 0%, #E2E8EE 60%, #C9E9DA 100%);
  --purple-color-100: #664CC4;
  --purple-color-10: #F0EDF9;
  --purple-gradient : linear-gradient(90deg, #A6ADE8 0%, #E6F1FA 60%, #B4D4EF 100%);
  --red-color-100: #FF0000;
  --red-color-50: #FFF2F2;
  --yellow-color-100: #FFCC00;
  --blue-color-100: #104BCD;
  --deep-blue-100: #013A76;
  --deep-blue-10: #ECF0F8;
  --sub-sky-100: #08C5D6;
  --sub-sky-10: #E3F6F7;
  --green-3: #8FC31F;
  --right-green-10: #e2f0d9;
  --registration-color-100: #EE8C1B;
  --registration-color-10: #FDF3E9;
  --registration-gradient : linear-gradient(90deg, #fad19f 0%, #FDF3E9 60%, #fad19f 100%);

  --primary-color-100: var(--portal-color-100);
  --primary-color-10: var(--portal-color-10);
  --primary-color-gradient: var(--portal-gradient);

  --font-size: 16;
}

.cat-portal {
  --primary-color-100: var(--portal-color-100);
  --primary-color-10: var(--portal-color-10);
  --primary-color-gradient: var(--portal-gradient);
}
.cat-house {
  --primary-color-100: var(--house-color-100);
  --primary-color-10: var(--house-color-10);
  --primary-color-gradient: var(--house-gradient);
}
.cat-housingcomplex {
  --primary-color-100: var(--housingcomplex-color-100);
  --primary-color-10: var(--housingcomplex-color-10);
  --primary-color-gradient: var(--housingcomplex-gradient);
}
.cat-registration {
  --primary-color-100: var(--registration-color-100);
  --primary-color-10: var(--registration-color-10);
  --primary-color-gradient: var(--registration-gradient);
}

.cat-zehinfo {
  --primary-color-100: var(--zehinfo-color-100);
  --primary-color-10: var(--zehinfo-color-10);
  --primary-color-gradient: var(--zehinfo-gradient);
}

/* ==========================================================================
  ELEMENT RESET
========================================================================== */

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  font-family: serif;
  scroll-behavior: smooth;
  scroll-padding: calc(80 / var(--font-size) * 1rem);
}
@media all and (max-width: 767px) {
  html {
    scroll-padding: calc(58 / var(--font-size) * 1rem);
  }
}

body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  color: var(--black-color, #000);
  font-weight: 400;
  font-family: 'Noto Sans JP', 'Hiragino Kaku Gothic ProN', 'Hiragino Sans', Meiryo, sans-serif;
}

h1,
h2,
h3,
h4,
h5,
h6,
p {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 1em;
  -webkit-margin-before: 0;
  -webkit-margin-after: 0;
}

ol,
ul,
dl {
  margin-top: 0;
  margin-bottom: 0;
}

dd {
  margin-left: 0;
}

ol,
ul {
  margin: 0;
  padding-left: 0;
  list-style: none;
}

a {
  color: inherit;
  text-decoration: none;
  cursor: pointer;
}

a {
  outline: 0;
}

a:focus,
button:focus {
  outline: 0;
}

em {
  font-style: normal;
}

figure {
  margin: 0;
}

table {
  border-collapse: collapse;
}

button {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
}

button:focus {
  outline: none;
}

input,
button,
select,
textarea {
  line-height: inherit;
}

textarea {
  resize: vertical;
}

fieldset {
  min-width: 0;
  margin: 0;
  padding: 0;
  border: 0;
}

legend {
  display: block;
  width: 100%;
  margin-bottom: 0;
  padding: 0;
  line-height: inherit;
}

hr {
  margin: 0;
}

hr {
  margin: 5rem 0;
  border: 1px #ccc solid;
}

img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

.scroll-auto {
  scroll-behavior: auto;
}
/* ==========================================================================
  UTILL
========================================================================== */

/* 画像置換 */

.u-ir {
  display: block;
  overflow: hidden;
  font: 0/0 a;
  white-space: nowrap;
  text-indent: 100%;
}

/* PC、タブレットで画像置換 */

@media all and (min-width: 768px), print {
  .u-ir--tab-pc {
    display: block;
    overflow: hidden;
    font: 0/0 a;
    white-space: nowrap;
    text-indent: 100%;
  }
}

/* --------------------------------------------------------------------------
  非表示
-------------------------------------------------------------------------- */

/* PCで非表示 */

@media all and (min-width: 1025px), print {
  .u-hide-pc {
    display: none;
  }
}

/* PC、タブレットで非表示 */

@media all and (min-width: 768px), print {
  .u-hide-tab-pc {
    display: none;
  }
}

/* タブレットのみ非表示 */

@media all and (min-width: 768px) and (max-width: 1024px) {
  .u-hide-tab {
    display: none;
  }
}

/* SPで非表示 */

@media all and (max-width: 767px) {
  .u-hide-sp {
    display: none;
  }
}

/* --------------------------------------------------------------------------
  行揃え
-------------------------------------------------------------------------- */

.u-center {
  text-align: center;
}

/* TAB,PCのみテキストセンター */

@media all and (min-width: 768px), print {
  .u-center-tab-pc {
    text-align: center;
  }
}

/* SPのみテキストセンター */

@media all and (max-width: 767px) {
  .u-center-sp {
    text-align: center;
  }
}

.u-left {
  text-align: left;
}

/* TAB,PCのみテキストレフト */

@media all and (min-width: 768px), print {
  .u-left-tab-pc {
    text-align: left;
  }
}

/* SPのみテキストレフト */

@media all and (max-width: 767px) {
  .u-left-sp {
    text-align: left;
  }
}

.u-right {
  text-align: right;
}

/* TAB,PCのみテキストライト */

@media all and (min-width: 768px), print {
  .u-right-tab-pc {
    text-align: right;
  }
}

/* SPのみテキストライト */

@media all and (max-width: 767px) {
  .u-right-sp {
    text-align: right;
  }
}

.u-justify {
  text-align: justify;
  text-justify: inter-ideograph;
}

.u-combine {
  text-combine-upright: all;
  -webkit-text-combine: horizontal;
  -ms-text-combine-horizontal: all;
}

/* --------------------------------------------------------------------------
  強調
-------------------------------------------------------------------------- */

.u-strong {
  font-weight: 700;
}

.u-bold {
  font-weight: 700;
}

.u-underline {
  text-decoration: underline;
}

/* --------------------------------------------------------------------------
  背景
-------------------------------------------------------------------------- */

/* primary */
.u-bg-primary-100 {
  background-color: var(--primary-color-100);
}
.u-bg-primary-10 {
  background-color: var(--primary-color-10);
}
/* gray */
.u-bg-primary-50 {
  background-color: var(--gray-color-50);
}
.u-bg-primary-150 {
  background-color: var(--gray-color-150);
}
.u-bg-gray-color-650 {
  background-color: var(--gray-color-650);
}

.u-bg-deep-blue-color-100 {
  background-color: var(--deep-blue-100);
}


/* --------------------------------------------------------------------------
  テキストカラー
-------------------------------------------------------------------------- */

/* primary */
.u-color-primary-100 {
  color: var(--primary-color-100);
}
.u-color-primary-10 {
  color: var(--primary-color-10);
}
.u-color-black {
  color: var(--black-color);
}
.u-color-white {
  color: var(--white-color);
}

.u-color-red-100 {
  color: var(--red-color-100);
}

.u-color-blue-100 {
  color: var(--blue-color-100);
}

.u-color-yellow-100 {
  color: var(--yellow-color-100);
}

.u-color-gray-650 {
  color: var(--gray-color-650);
}


/* ==========================================================================
  LAYOUT
========================================================================== */

/* --------------------------------------------------------------------------
  MAIN
-------------------------------------------------------------------------- */

@media all and (min-width: 768px), print {
  .l-main-container {
    padding-top: calc(106 / var(--font-size) * 1rem);
    /* padding-top: calc(132 / var(--font-size) * 1rem); */
  }
  .l-main-container__in {
    padding-bottom: calc(90 / var(--font-size) * 1rem);
  }
  .l-main-container__footer {
    margin-top: calc(60 / var(--font-size) * 1rem);
  }
}

@media all and (max-width: 767px) {
  .l-main-container {
  }
  .l-main-container__in {
    padding-bottom: calc(80 / var(--font-size) * 1rem);
  }
  .l-main-container__footer {
    margin-top: calc(60 / var(--font-size) * 1rem);
  }
}

/* --------------------------------------------------------------------------
  SECTION
-------------------------------------------------------------------------- */

@media all and (min-width: 768px), print {
  .l-sec {
  }
  .l-sec__in {
    max-width: calc(1060 / var(--font-size) * 1rem);
    margin: auto;
    padding: 0 calc(20 / var(--font-size) * 1rem);
  }
  .l-sec__body {
    padding: calc(120 / var(--font-size) * 1rem) 0;
  }
  .l-sec__header {
    margin-bottom: calc(40 / var(--font-size) * 1rem);
  }
  .l-sec__content {
  }
  .l-sec__lead {
    max-width: calc(780 /  var(--font-size) * 1rem);
    margin: auto;
  }
}

@media all and (max-width: 767px) {
  .l-sec {
  }
  .l-sec__in {
    max-width: calc(1052 / var(--font-size) * 1rem);
    margin: auto;
    padding: 0 calc(25 / var(--font-size) * 1rem);
  }
  .l-sec__body {
    padding: calc(80 / var(--font-size) * 1rem) 0;
  }
  .l-sec__header {
    margin-bottom: calc(40 / var(--font-size) * 1rem);
  }
  .l-sec__content {
  }
  .l-sec__lead {
    max-width: calc(780 /  var(--font-size) * 1rem);
    margin: auto;
  }
}

/* --------------------------------------------------------------------------
  BTN
-------------------------------------------------------------------------- */

@media all and (min-width: 768px), print {
  .l-btn-list {
    --col: 1;
    --gap-x: 20;
    --gap-y: 20;
    display: flex;
    gap: calc(var(--gap-y) / var(--font-size) * 1rem) calc(var(--gap-x) / var(--font-size) * 1rem);
    flex-wrap: wrap;
    justify-content: center;
  }
  .l-btn-list-item {
    width: calc((100% - var(--gap-x) / var(--font-size) * 1rem * (var(--col) - 1)) / var(--col));
  }

  /* size */
  .l-btn-list-item--xxl {
    width: calc(420 / var(--font-size) * 1rem);
  }
  .l-btn-list-item--xl {
    width: calc(400 / var(--font-size) * 1rem);
  }
  .l-btn-list-item--l {
    width: calc(300 / var(--font-size) * 1rem);
  }
  .l-btn-list-item--m {
    width: calc(260 / var(--font-size) * 1rem);
  }
  .l-btn-list-item--s {
    width: calc(240 / var(--font-size) * 1rem);
  }
  .l-btn-list-item--xs {
    width: calc(220 / var(--font-size) * 1rem);
  }

  /* postion */
  .l-btn-list--left {
    justify-content: left;
  }

  /* col */
  .l-btn-list--2col {
    --col: 2;
  }
  .l-btn-list--3col {
    --col: 3;
  }
  .l-btn-list--4col {
    --col: 4;
  }
  .l-btn-list--5col {
    --col: 5;
  }
  .l-btn-list--auto .l-btn-list-item {
    width: auto;
  }

  /* 背景色ボタンリストアイテム */
  .l-btn-list-item--box {
    background-color: var(--white-color);
    padding: calc(20 / var(--font-size) * 1rem) calc(28 / var(--font-size) * 1rem);
    border-radius: calc(20 / var(--font-size) * 1rem);
  }
  .l-btn-list-item--box .c-btn + .c-txt {
    margin-top: calc(16 / var(--font-size) * 1rem);
  }
}

@media all and (max-width: 767px) {
  .l-btn-list {
    --col: 1;
    --gap-x: 20;
    --gap-y: 20;
    display: flex;
    gap: calc(var(--gap-y) / var(--font-size) * 1rem) calc(var(--gap-x) / var(--font-size) * 1rem);
    flex-wrap: wrap;
    justify-content: center;
  }
  .l-btn-list-item {
    width: calc((100% - var(--gap-x) / var(--font-size) * 1rem * (var(--col) - 1)) / var(--col));
  }

  /* size */
  .l-btn-list-item--xxl {
    width: calc(295 / var(--font-size) * 1rem);
  }
  .l-btn-list-item--xl {
    width: calc(295 / var(--font-size) * 1rem);
  }
  .l-btn-list-item--l {
    width: calc(275 / var(--font-size) * 1rem);
  }
  .l-btn-list-item--m {
    width: calc(260 / var(--font-size) * 1rem);
  }
  .l-btn-list-item--s {
    width: calc(240 / var(--font-size) * 1rem);
  }
  .l-btn-list-item--xs {
    width: calc(220 / var(--font-size) * 1rem);
  }

  /* postion */
  .l-btn-list--left {
    justify-content: left;
  }

  /* col */
  .l-btn-list--2col {
    --col: 2;
  }
  .l-btn-list--3col {
    --col: 3;
  }
  .l-btn-list--4col {
    --col: 4;
  }
  .l-btn-list--5col {
    --col: 5;
  }
  .l-btn-list-sp--1col {
    --col: 1;
  }
  .l-btn-list-sp--2col {
    --col: 2;
  }
  .l-btn-list-sp--3col {
    --col: 3;
  }
  .l-btn-list-sp--4col {
    --col: 4;
  }
  .l-btn-list-sp--5col {
    --col: 5;
  }
  .l-btn-list--auto .l-btn-list-item {
    width: auto;
  }

  /* 背景色ボタンリストアイテム */
  .l-btn-list-item--box {
    background-color: var(--white-color);
    padding: calc(15 / var(--font-size) * 1rem) calc(20 / var(--font-size) * 1rem);
    border-radius: calc(20 / var(--font-size) * 1rem);
  }
  .l-btn-list-item--box .c-btn + .c-txt {
    --txt-font-size: 14;
    margin-top: calc(12 / var(--font-size) * 1rem);
  }
}

@media all and (min-width: 768px), print {
  .l-btn-back {
    margin-top: calc(120 / var(--font-size)* 1rem);
  }
  .l-btn-back--mt-s {
    margin-top: calc(80 / var(--font-size)* 1rem);
  }
}
@media all and (max-width: 767px) {
  .l-btn-back {
    margin-top: calc(80 / var(--font-size)* 1rem);
  }
}

/* --------------------------------------------------------------------------
  ACCORDION
-------------------------------------------------------------------------- */

@media all and (min-width: 768px), print {
  .l-accordion-box{
  }
  .l-accordion-box__in{
      padding: calc(64 / var(--font-size)* 1rem) calc(60 / var(--font-size)* 1rem);
      background-color: var(--primary-color-10);
      border-radius: calc(10 / var(--font-size)* 1rem);
  }
  .l-accordion-box__footer{
      margin-top: calc(14 / var(--font-size)* 1rem);
      text-align: center;
      display: flex;
      justify-content: center;
  }
  .l-accordion-box-arrow{
      display: flex;
      justify-content: center;
      align-items: center;
      margin-left: calc(20 / var(--font-size)* 1rem);
  }
  .l-accordion-box-arrow__label{
      width: 10px;
      height: 10px;
  }
  }

@media all and (min-width: 768px), print {
  .arrow-accordion {
    margin-top: calc(40 / var(--font-size) * 1rem);
    background-color: var(--primary-color-10);
    border-radius: calc(12 / var(--font-size)* 1rem);
  }
  .arrow-accordion__head {
    cursor: pointer;
    padding: calc(30 / var(--font-size)* 1rem) calc(40 / var(--font-size)* 1rem);
  }
  .arrow-example__inner {
    display: flex;
    align-items: center;
  }
  .arrow-example-ico {
    margin-right: calc(8 / var(--font-size)* 1rem);
  }
  .arrow-example-ico__label {
    width: calc(20 / var(--font-size)* 1rem);
    height: calc(20 / var(--font-size)* 1rem);
    background-color: var(--white-color);
    border: 1px solid var(--primary-color-100);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 100%;
  }
  .arrow-example-ico__label .c-svg {
    width: calc(12 / var(--font-size)* 1rem);
    fill: var(--primary-color-100);
    transition: all 0.2s;
  }
  .is-accordion-active .arrow-example-ico__label .c-svg {
    transform: rotate(90deg);
  }
  .arrow-accordion__body {
    padding: 0 calc(40 / var(--font-size)* 1rem) calc(30 / var(--font-size)* 1rem);
  }
}
@media all and (max-width: 767px) {
  .arrow-accordion {
    margin-top: calc(40 / var(--font-size) * 1rem);
    background-color: var(--primary-color-10);
    border-radius: calc(12 / var(--font-size)* 1rem);
  }
  .arrow-accordion__head {
    cursor: pointer;
    padding: calc(30 / var(--font-size)* 1rem) calc(25 / var(--font-size)* 1rem);
  }
  .arrow-example__inner {
    display: flex;
    align-items: center;
  }
  .arrow-example-ico {
    margin-right: calc(8 / var(--font-size)* 1rem);
  }
  .arrow-example-ico__label {
    width: calc(20 / var(--font-size)* 1rem);
    height: calc(20 / var(--font-size)* 1rem);
    background-color: var(--white-color);
    border: 1px solid var(--primary-color-100);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 100%;
  }
  .arrow-example-ico__label .c-svg {
    width: calc(12 / var(--font-size)* 1rem);
    fill: var(--primary-color-100);
    transition: all 0.2s;
  }
  .is-accordion-active .arrow-example-ico__label .c-svg {
    transform: rotate(90deg);
  }
  .arrow-example-text__label{
    font-weight: 700; 
  }
  .arrow-accordion__body {
    padding: 0 calc(25 / var(--font-size)* 1rem) calc(30 / var(--font-size)* 1rem);
  }
}

/* --------------------------------------------------------------------------
  PAGE
-------------------------------------------------------------------------- */

@media all and (min-width: 768px), print {
  .l-page-container {
  }
  .l-page-container__in {
    /* padding-bottom: calc(120 / var(--font-size) * 1rem); */
  }
  .l-page-container__footer {
    margin-top: calc(60 / var(--font-size) * 1rem);
  }
}

@media all and (max-width: 767px) {
  .l-page-container {
  }
  .l-page-container__in {
    /* padding-bottom: calc(120 / var(--font-size) * 1rem); */
  }
  .l-page-container__footer {
    margin-top: calc(60 / var(--font-size) * 1rem);
  }
}

/* sec */

@media all and (min-width: 768px), print {
  .l-page-sec {
    --page-sec-width: 1060;
  }
  .l-page-sec + .l-page-sec {
    margin-top: calc(96 / var(--font-size) * 1rem);
  }
  .l-page-sec__in {
    max-width: calc(var(--page-sec-width) / var(--font-size) * 1rem);
    margin: auto;
    padding: 0 calc(20 / var(--font-size) * 1rem);
  }
  .l-page-sec__header-above {
    margin-bottom: calc(96 / var(--font-size) * 1rem);
  }
  .l-page-sec__header-above .c-submit-box{
    margin-top: 0;
  }
  .l-page-sec__header {
    margin-bottom: calc(36 / var(--font-size) * 1rem);
  }
  .l-page-sec__content {
  }
  .l-page-sec__content + .l-page-sec__content {
    margin-top: calc(40 / var(--font-size) * 1rem);
  }
  .l-page-sec__footer {
    margin-top: calc(40 / var(--font-size) * 1rem);
  }

  .l-page-sec--wide {
    --page-sec-width: 1160;
  }
}

@media all and (max-width: 767px) {
  .l-page-sec {
    --page-sec-width: 1000;
  }
  .l-page-sec + .l-page-sec {
    margin-top: calc(50 / var(--font-size) * 1rem);
  }
  .l-page-sec__in {
    max-width: calc(var(--page-sec-width) / var(--font-size) * 1rem);
    margin: auto;
    padding: 0 calc(25 / var(--font-size) * 1rem);
  }
  .l-page-sec__header-above {
    margin-bottom: calc(50 / var(--font-size) * 1rem);
  }
  .l-page-sec__header-above .c-submit-box{
    margin-top: 0;
  }
  .l-page-sec__header {
    margin-bottom: calc(30 / var(--font-size) * 1rem);
  }
  .l-page-sec__content {
  }
  .l-page-sec__content + .l-page-sec__content {
    margin-top: calc(40 / var(--font-size) * 1rem);
  }
  .l-page-sec__footer {
    margin-top: calc(40 / var(--font-size) * 1rem);
  }

  .l-page-sec--wide {
    --page-sec-width: 1160;
  }
}

/* block */

@media all and (min-width: 768px), print {
  .l-page-block {
  }
  .l-page-block + .l-page-block {
    margin-top: calc(60 / var(--font-size) * 1rem);
  }
  .l-page-block__in {
  }
  .l-page-block__header {
    margin-bottom: calc(20 / var(--font-size) * 1rem);
  }
  .l-page-block__content {
  }
}

@media all and (max-width: 767px) {
  .l-page-block {
  }
  .l-page-block + .l-page-block {
    margin-top: calc(60 / var(--font-size) * 1rem);
  }
  .l-page-block__in {
  }
  .l-page-block__header {
    margin-bottom: calc(20 / var(--font-size) * 1rem);
  }
  .l-page-block__content {
  }
}

/* ==========================================================================
  HEADER COMPONENT
========================================================================== */

/* --------------------------------------------------------------------------
  下層
-------------------------------------------------------------------------- */

@media all and (min-width: 768px), print {
  .page-hero {
    --hero-bg-color: var(--primary-color-gradient);

    position: relative;
    overflow: hidden;
    background: var(--hero-bg-color);
    margin-bottom: calc(120 / var(--font-size) * 1rem);
  }
  .page-hero__in {
    padding: 0 calc(16 / var(--font-size) * 1rem);
    max-width: calc(1152 / var(--font-size) * 1rem);
    margin: auto;
  }
  .page-hero__body {
    position: relative;
    padding: 0;
    padding: calc(70 / var(--font-size) * 1rem) calc(290 / var(--font-size) * 1rem) calc(80 / var(--font-size) * 1rem) calc(50 / var(--font-size) * 1rem);
    min-height: calc(205 / var(--font-size) * 1rem);
  }
  .page-hero__body::before {
    content: "";
    display: block;
    width: calc(100% + 50vw - 50%);
    height: calc(100% - 40 / var(--font-size) * 1rem);
    position: absolute;
    top: 0;
    left: 0;
    background-color: var(--white-color);
    border-bottom-left-radius: calc(60 / var(--font-size) * 1rem);
  }
  .page-hero__body::after {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    right: -10px;
    margin-right: calc(-50vw + 50%);
    z-index: 2;
    background: url("/r07/assets/img/common/page_hero_deco_portal.png") center center no-repeat;
    background-size: contain;
    width: calc(500 / var(--font-size) * 1rem);
    height: calc(207.5 / var(--font-size) * 1rem);
  }
  .cat-house .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_house.png") center center no-repeat;
    background-size: contain;
    width: calc(500 / var(--font-size) * 1rem);
    height: calc(196 / var(--font-size) * 1rem);
  }
  .cat-housingcomplex .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_housingcomplex.png") center center no-repeat;
    background-size: contain;
    width: calc(500 / var(--font-size) * 1rem);
    height: calc(208 / var(--font-size) * 1rem);
  }
  .cat-housingcomplex .page-hero-housingcomplex-middle .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_housingcomplex-middle.png") center center no-repeat;
    background-size: contain;
    width: calc(500 / var(--font-size) * 1rem);
    height: calc(205 / var(--font-size) * 1rem);
  }
  .cat-housingcomplex .page-hero-housingcomplex-high .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_housingcomplex-high.png") center center no-repeat;
    background-size: contain;
    width: calc(500 / var(--font-size) * 1rem);
    height: calc(205 / var(--font-size) * 1rem);
  }
  .cat-housingcomplex .page-hero-housingcomplex-shigh .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_housingcomplex-shigh.png") center center no-repeat;
    background-size: contain;
    width: calc(500 / var(--font-size) * 1rem);
    height: calc(205 / var(--font-size) * 1rem);
  }
  .cat-housingcomplex .page-hero-housingcomplex-mix .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_housingcomplex-mix.png") center center no-repeat;
    background-size: contain;
    width: calc(500 / var(--font-size) * 1rem);
    height: calc(205 / var(--font-size) * 1rem);
  }
  .cat-registration.cat-registration-top .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_portal.png") center center no-repeat;
    background-size: contain;
    width: calc(500 / var(--font-size) * 1rem);
    height: calc(207.5 / var(--font-size) * 1rem);
    bottom: calc(12 / var(--font-size) * 1rem);
  }
  .cat-registration .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_registration.png") center center no-repeat;
    background-size: contain;
    width: calc(516 / var(--font-size) * 1rem);
    height: calc(217 / var(--font-size) * 1rem);
  }
  .cat-registration.cat-registration-builder .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_builder.png") center center no-repeat;
    background-size: contain;
    width: calc(500 / var(--font-size) * 1rem);
    height: calc(197 / var(--font-size) * 1rem);
    margin-bottom: calc(-1 / var(--font-size)* 1rem);
  }
  .cat-registration.cat-registration-developer .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_developer.png") center center no-repeat;
    background-size: contain;
    width: calc(500 / var(--font-size) * 1rem);
    height: calc(205 / var(--font-size) * 1rem);
  }
  .cat-registration.cat-battery .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_battery.png") center center no-repeat;
    background-size: contain;
    width: calc(500 / var(--font-size) * 1rem);
    height: calc(205 / var(--font-size) * 1rem);
  }
  .cat-zehinfo .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_zehinfo.png") center center no-repeat;
    background-size: contain;
    width: calc(474 / var(--font-size) * 1rem);
    height: calc(205 / var(--font-size) * 1rem);
  }
  .page-hero--cloud .page-hero__body::after{
    background: url("/r07/assets/img/common/page_hero_deco_portal_cloud.png") center right no-repeat;
    background-size: contain;
    width: calc(470 / var(--font-size) * 1rem);
    height: calc(150 / var(--font-size) * 1rem);
    margin-bottom: calc(40 / var(--font-size) * 1rem);
  }
  .page-hero__header {
    position: relative;
    z-index: 10;
  }
  .page-hero__header-cat {
    background-color: var(--primary-color-100);
    display: inline-block;
    padding: calc(2 / var(--font-size) * 1rem) calc(30 / var(--font-size) * 1rem);
    border-radius: 9999px;
    margin-bottom: calc(24 / var(--font-size) * 1rem);
  }
  .page-hero__header-cat__label {
    font-size: calc(20 / var(--font-size) * 1rem);
    font-weight: 700;
    color: var(--white-color);
    line-height: 1.6;
  }
  .page-hero__header-title {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: calc(10 / var(--font-size) * 1rem) calc(30 / var(--font-size) * 1rem);
  }
  .page-hero__header-title__main {
    font-size: calc(40 / var(--font-size) * 1rem);
    font-weight: 700;
    color: var(--primary-color-100);
    display: inline-block;
  }
  .page-hero__header-title__sub {
    font-size: calc(26 / var(--font-size) * 1rem);
    font-weight: 700;
    color: var(--primary-color-100);
    display: inline-block;
  }
}
@media all and (min-width: 768px) and (max-width: 1440px) {
  .page-hero__body::after {
    margin-right: calc(-160 / var(--font-size) * 1rem);
  }
}

@media all and (max-width: 767px) {
  .page-hero {
    --hero-bg-color: var(--primary-color-gradient);

    position: relative;
    background: var(--hero-bg-color);
    margin-bottom: calc(50 / var(--font-size) * 1rem);
  }
  .page-hero__in {
    padding: 0 calc(25 / var(--font-size) * 1rem);
    max-width: calc(1152 / var(--font-size) * 1rem);
    margin: auto;
  }
  .page-hero__body {
    position: relative;
    padding: 0;
    padding: calc(25 / var(--font-size) * 1rem) 0 calc(60 / var(--font-size) * 1rem) calc(25 / var(--font-size) * 1rem);
    min-height: calc(132 / var(--font-size) * 1rem);
  }
  .builder_report_application .page-hero__body{
    padding-bottom: calc(90 / var(--font-size) * 1rem);
  }
  .zehinfo_logo-bp .page-hero__body{
    padding-bottom: calc(100 / var(--font-size) * 1rem);
  }
  .zehinfo_example .page-hero__body{
    padding-bottom: calc(100 / var(--font-size) * 1rem);
  }
  .page-hero__body::before {
    content: "";
    display: block;
    width: calc(100% + 50vw - 50%);
    height: calc(100% - 22 / var(--font-size) * 1rem);
    position: absolute;
    top: 0;
    left: 0;
    background-color: var(--white-color);
    border-bottom-left-radius: calc(60 / var(--font-size) * 1rem);
  }
  .page-hero__body::after {
    content: "";
    display: block;
    position: absolute;
    bottom: 3px;
    right: 0;
    margin-right: calc(-50vw + 50%);
    z-index: 2;
    background: url("/r07/assets/img/common/page_hero_deco_portal.png") center center no-repeat;
    background-size: contain;
    width: calc(200 / var(--font-size) * 1rem);
    height: calc(110 / var(--font-size) * 1rem);
    margin-bottom: calc(30 / var(--font-size) * 1rem * -1);
  }
  .cat-house .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_house.png") center center no-repeat;
    background-size: contain;
    width: calc(200 / var(--font-size) * 1rem);
    height: calc(110 / var(--font-size) * 1rem);
    margin-bottom: calc(30 / var(--font-size) * 1rem * -1);
  }
  .cat-housingcomplex .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_housingcomplex.png") center center no-repeat;
    background-size: contain;
    width: calc(200 / var(--font-size) * 1rem);
    height: calc(110 / var(--font-size) * 1rem);
  }
  .cat-housingcomplex .page-hero-housingcomplex-middle .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_housingcomplex-middle.png") center center no-repeat;
    background-size: contain;
    width: calc(200 / var(--font-size) * 1rem);
    height: calc(110 / var(--font-size) * 1rem);
  }
  .cat-housingcomplex .page-hero-housingcomplex-high .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_housingcomplex-high.png") center center no-repeat;
    background-size: contain;
    width: calc(200 / var(--font-size) * 1rem);
    height: calc(110 / var(--font-size) * 1rem);
  }
  .cat-housingcomplex .page-hero-housingcomplex-shigh .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_housingcomplex-shigh.png") center center no-repeat;
    background-size: contain;
    width: calc(200 / var(--font-size) * 1rem);
    height: calc(110 / var(--font-size) * 1rem);
  }
  .cat-housingcomplex .page-hero-housingcomplex-mix .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_housingcomplex-mix.png") center center no-repeat;
    background-size: contain;
    width: calc(200 / var(--font-size) * 1rem);
    height: calc(110 / var(--font-size) * 1rem);
  }
  .cat-registration.cat-registration-top .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_portal.png") center center no-repeat;
    background-size: contain;
    width: calc(200 / var(--font-size) * 1rem);
    height: calc(110 / var(--font-size) * 1rem);
  }
  .cat-registration.cat-battery .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_battery.png") center center no-repeat;
    background-size: contain;
    width: calc(200 / var(--font-size) * 1rem);
    height: calc(110 / var(--font-size) * 1rem);
    bottom: -16px;
  }
  .cat-registration .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_registration_sp.png") center center no-repeat;
    background-size: contain;
    width: calc(230 / var(--font-size) * 1rem);
    height: calc(117 / var(--font-size) * 1rem);
    margin-bottom: calc(10 / var(--font-size) * 1rem * -1);
    bottom: 4px;
  }
  .cat-registration.cat-registration-builder .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_builder.png") center center no-repeat;
    background-size: contain;
    width: calc(200 / var(--font-size) * 1rem);
    height: calc(110 / var(--font-size) * 1rem);
    margin-bottom: calc(-12 / var(--font-size)* 1rem);
  }
  .cat-registration.cat-registration-developer .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_developer.png") center center no-repeat;
    background-size: contain;
    width: calc(200 / var(--font-size) * 1rem);
    height: calc(110 / var(--font-size) * 1rem);
    bottom: 0;
  }
  .cat-zehinfo .page-hero__body::after {
    background: url("/r07/assets/img/common/page_hero_deco_zehinfo.png") center center no-repeat;
    background-size: contain;
    width: calc(200 / var(--font-size) * 1rem);
    height: calc(110 / var(--font-size) * 1rem);
    margin-bottom: calc(10 / var(--font-size) * 1rem * -1);
  }
  .page-hero--cloud .page-hero__body::after{
    background: url("/r07/assets/img/common/page_hero_deco_portal_cloud.png") center right no-repeat;
    background-size: contain;
    width: calc(200 / var(--font-size) * 1rem);
    height: calc(110 / var(--font-size) * 1rem);
    margin-bottom: calc(8 / var(--font-size) * 1rem);
  }
  .page-hero__header {
    position: relative;
    z-index: 10;
  }
  .page-hero__header-cat {
    background-color: var(--primary-color-100);
    display: inline-block;
    padding: calc(2 / var(--font-size) * 1rem) calc(30 / var(--font-size) * 1rem);
    border-radius: 9999px;
    margin-bottom: calc(15 / var(--font-size) * 1rem);
  }
  .page-hero__header-cat__label {
    font-size: calc(12 / var(--font-size) * 1rem);
    font-weight: 700;
    color: var(--white-color);
    line-height: 1.6;
  }
  .page-hero__header-title {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: calc(10 / var(--font-size) * 1rem) calc(30 / var(--font-size) * 1rem);
    flex-direction: column;
  }
  .page-hero__header-title__main {
    font-size: calc(22 / var(--font-size) * 1rem);
    font-weight: 700;
    color: var(--primary-color-100);
    display: inline-block;
  }
  .page-hero__header-title__sub {
    font-size: calc(16 / var(--font-size) * 1rem);
    font-weight: 700;
    color: var(--primary-color-100);
    display: inline-block;
  }
}

/* --------------------------------------------------------------------------
  HEADER COMPONENT
-------------------------------------------------------------------------- */

@media all and (min-width: 768px), print {
  .c-header-title {
    --header-font-size: 26;
    --header-color: var(--black-color);

    text-align: center;
  }
  .c-header-title__label {
    color: var(--header-color);
    font-size: calc(var(--header-font-size) / var(--font-size) * 1rem);
    font-weight: bold;
  }

  .c-header-title--primary {
    --header-color: var(--primary-color-100);
  }

  /* fontsize */
  .c-header-title--s {
    --header-font-size: 20;
  }

  /* position */
  .c-header-title--left {
    text-align: left;
  }
}
@media all and (max-width: 767px) {
  .c-header-title {
    --header-font-size: 26;
    --header-color: var(--black-color);

    text-align: center;
  }
  .c-header-title__label {
    color: var(--header-color);
    font-size: calc(var(--header-font-size) / var(--font-size) * 1rem);
    font-weight: bold;
    line-height: 1.46;
  }

  .c-header-title--primary {
    --header-color: var(--primary-color-100);
  }

  /* fontsize */
  .c-header-title.c-header-title--s {
    --header-font-size: 20;
  }
  .c-header-title.c-header-title-sp--s {
    --header-font-size: 20;
  }

  /* position */
  .c-header-title--left {
    text-align: left;
  }
}

/* under */
@media all and (min-width: 768px), print {
  .c-under-header {
    --header-font-size: 30;
    --header-color: var(--primary-color-100);

    text-align: center;
    position: relative;
    padding-bottom: calc(22 / var(--font-size) * 1rem);
  }
  .c-under-header::before {
    content: "";
    display: block;
    width: calc(40 / var(--font-size) * 1rem);
    height: calc(8/ var(--font-size) * 1rem);
    background-color: var(--header-color);
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    border-top-left-radius: calc(5 / var(--font-size) * 1rem);
    border-bottom-right-radius: calc(5 / var(--font-size) * 1rem);
  }
  .c-contact__in .c-under-header {
    padding-bottom: 0;
  }
  .c-contact__in .c-under-header::before {
    content: none;
  }
  .c-under-header__label {
    font-size: calc(var(--header-font-size) / var(--font-size) * 1rem);
    font-weight: 700;
    color: var(--header-color);
    line-height: 1.4;
  }
  .c-under-header__label small {
    font-size: calc(20 / 30 * 1em);
  }

  /* color */
  .u-bg-primary-100 .c-under-header,
  .u-bg-deep-blue-color-100 .c-under-header,
  .c-under-header--white {
    --header-color: var(--white-color);
  }
}
@media all and (max-width: 767px) {
  .c-under-header {
    --header-font-size: 26;
    --header-color: var(--primary-color-100);
    text-align: center;
    position: relative;
    padding-bottom: calc(20 / var(--font-size) * 1rem);
  }
  .c-contact .c-under-header {
    --header-font-size: 20;
  }
  .c-under-header::before {
    content: "";
    display: block;
    width: calc(35 / var(--font-size) * 1rem);
    height: calc(5/ var(--font-size) * 1rem);
    background-color: var(--header-color);
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    border-top-left-radius: calc(5 / var(--font-size) * 1rem);
    border-bottom-right-radius: calc(5 / var(--font-size) * 1rem);
  }
  .c-under-header__label {
    font-size: calc(var(--header-font-size) / var(--font-size) * 1rem);
    font-weight: 700;
    color: var(--header-color);
    line-height: 1.4;
  }
  .c-under-header__label small {
    font-size: calc(20 / 30 * 1em);
  }

  /* color */
  .u-bg-primary-100 .c-under-header,
  .u-bg-deep-blue-color-100 .c-under-header,
  .c-under-header--white {
    --header-color: var(--white-color);
  }
}

/* disc */
@media all and (min-width: 768px), print {
  .c-disc-header {
    --header-font-size: 26;
    --header-ratio: var(--header-font-size) / 26;
    --header-deco-color: var(--primary-color-100);

  }
  .c-disc-header__in {
    position: relative;
    padding-left: calc(30 * var(--header-ratio) / var(--font-size) * 1rem);
    display: flex;
  }
  .c-disc-header__in::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: calc(20 * var(--header-ratio) / var(--font-size) * 1rem);
    height: calc(20 * var(--header-ratio) / var(--font-size) * 1rem);
    -webkit-mask: url("/r07/assets/img/common/title_deco_disc.svg");
    mask: url("/r07/assets/img/common/title_deco_disc.svg");
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    background-color: var(--header-deco-color);
    margin-top: calc(11 * var(--header-ratio) / var(--font-size) * 1rem);
  }
  .c-disc-header__in::after {
    background: radial-gradient(circle farthest-side, var(--primary-color-100), var(--primary-color-100) 30%, transparent 30%, transparent);
    background-size: calc(6 / var(--font-size) * 1rem) calc(6 / var(--font-size) * 1rem);
    content: '';
    display: inline-block;
    height: calc(6 / var(--font-size) * 1rem);
    width: 100%;
    margin-left: calc(10 / var(--font-size) * 1rem);
    margin-top: calc(17 / var(--font-size) * 1rem);
  }
  .c-disc-header__head{
    display: block;
    margin-bottom: calc(4 / var(--font-size) * 1rem);
  }
  .c-disc-header__note{
    font-size: calc(14 / var(--font-size) * 1rem);
    font-weight: 500;
    line-height: 1.5;
    color: var(--red-color-100);
  }
  .c-disc-header__body {
    flex-shrink: 0;
  }
  .c-disc-header__label {
    font-size: calc(var(--header-font-size) / var(--font-size) * 1rem);
    font-weight: 700;
    line-height: 1.5;
  }
}
@media all and (max-width: 767px) {
  .c-disc-header {
    --header-font-size: 20;
    --header-ratio: var(--header-font-size) / 20;
    --header-deco-color: var(--primary-color-100);

  }
  .c-disc-header__in {
    position: relative;
    padding-left: calc(26 * var(--header-ratio) / var(--font-size) * 1rem);
    display: flex;
  }
  .c-disc-header__in::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: calc(20 * var(--header-ratio) / var(--font-size) * 1rem);
    height: calc(20 * var(--header-ratio) / var(--font-size) * 1rem);
    -webkit-mask: url("/r07/assets/img/common/title_deco_disc.svg");
    mask: url("/r07/assets/img/common/title_deco_disc.svg");
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    background-color: var(--header-deco-color);
    margin-top: calc(7 * var(--header-ratio) / var(--font-size) * 1rem);
  }
  .c-disc-header__in::after {
    background: radial-gradient(circle farthest-side, var(--primary-color-100), var(--primary-color-100) 30%, transparent 30%, transparent);
    background-size: calc(9.5 / var(--font-size) * 1rem) calc(9.5 / var(--font-size) * 1rem);
    content: '';
    display: inline-block;
    height: calc(6 / var(--font-size) * 1rem);
    width: 100%;
    margin-left: calc(6 / var(--font-size) * 1rem);
    margin-top: calc(11 / var(--font-size) * 1rem);
  }
  .c-disc-header__body {
    flex-shrink: 0;
    max-width: 100%;
  }
  .c-disc-header__label {
    font-size: calc(var(--header-font-size) / var(--font-size) * 1rem);
    font-weight: 700;
    line-height: 1.5;
  }
}

/* bar */
@media all and (min-width: 768px), print {
  .c-bar-header {
    --header-font-size: 20;
    --header-bg-color: var(--primary-color-100);

  }
  .c-bar-header__in {
    background-color: var(--header-bg-color);
    display: block;
    text-align: center;
    padding: 0 calc(12 / var(--font-size) * 1rem);
  }
  .c-bar-header__body {
    padding: calc(12 / var(--font-size) * 1rem) 0;
    display: block;
  }
  .c-bar-header__label {
    font-size: calc(var(--header-font-size) / var(--font-size) * 1rem);
    font-weight: 700;
    line-height: 1.6;
    color: var(--white-color);
  }
}
@media all and (max-width: 767px) {
  .c-bar-header {
    --header-font-size: 16;
    --header-bg-color: var(--primary-color-100);

  }
  .c-bar-header__in {
    background-color: var(--header-bg-color);
    display: block;
    text-align: center;
    padding: 0 calc(12 / var(--font-size) * 1rem);
  }
  .c-bar-header__body {
    padding: calc(12 / var(--font-size) * 1rem) 0;
    display: block;
  }
  .c-bar-header__label {
    font-size: calc(var(--header-font-size) / var(--font-size) * 1rem);
    font-weight: 700;
    line-height: 1.6;
    color: var(--white-color);
  }
}

/* ==========================================================================
  TEXT COMPONENT
========================================================================== */

/* --------------------------------------------------------------------------
  テキスト
-------------------------------------------------------------------------- */

@media all and (min-width: 768px), print {
  .c-txt {
    --txt-font-size: 16;
    --txt-line-height: 1.8;
    font-size: calc(var(--txt-font-size) / var(--font-size) * 1rem);
    line-height: var(--txt-line-height);
  }
  .c-txt sub,
  .c-txt sub {
    font-size: 0.5em;
  }

  .c-txt sub{
    top: -0.5em;
  }

  .c-txt sub {
    bottom: -0.1em;
  }

  /* L */
  .c-txt--xxxl {
    --txt-font-size: 28;
  }
  .c-txt--xxl {
    --txt-font-size: 24;
  }
  .c-txt--xl {
    --txt-font-size: 20;
  }
  .c-txt--l {
    --txt-font-size: 18;
  }

  /* M */
  .c-txt--m {
    --txt-font-size: 16;
  }

  /* S */
  .c-txt--s {
    --txt-font-size: 14;
  }
  .c-txt--xs {
    --txt-font-size: 12;
  }
  .c-txt--xxs {
    --txt-font-size: 11;
  }
  .c-txt--xxxs {
    --txt-font-size: 10;
  }
  /* リンク */
  .c-txt-link {
    text-decoration: underline;
  }
  .c-txt-link:hover {
    text-decoration: none;
  }

  .c-txt-underline {
    text-decoration: underline;
  }
}

@media all and (max-width: 767px){
  .c-txt {
    --txt-font-size: 16;
    --txt-line-height: 1.8;
    font-size: calc(var(--txt-font-size) / var(--font-size) * 1rem);
    line-height: var(--txt-line-height);
  }
  .c-txt sub,
  .c-txt sub {
    font-size: 0.5em;
  }

  .c-txt sub{
    top: -0.5em;
  }

  .c-txt sub {
    bottom: -0.1em;
  }

  /* L */
  .c-txt--xxxl {
    --txt-font-size: 28;
  }
  .c-txt--xxl {
    --txt-font-size: 24;
  }
  .c-txt--xl {
    --txt-font-size: 20;
  }
  .c-txt--l {
    --txt-font-size: 18;
  }

  /* M */
  .c-txt--m {
    --txt-font-size: 16;
  }

  /* S */
  .c-txt--s {
    --txt-font-size: 14;
  }
  .c-txt--xs {
    --txt-font-size: 12;
  }
  .c-txt--xxs {
    --txt-font-size: 11;
  }
  .c-txt--xxxs {
    --txt-font-size: 10;
  }
  /* SPのみ */
  /* L */
  .c-txt-sp--l {
    --txt-font-size: 18;
  }
  /* M */
  .c-txt-sp--m {
    --txt-font-size: 16;
  }
  /* S */
  .c-txt-sp--s {
    --txt-font-size: 14;
  }

  /* リンク */
  .c-txt-link {
    text-decoration: underline;
  }

  .c-txt-underline {
    text-decoration: underline;
  }
}
/* --------------------------------------------------------------------------
  リスト テキスト
-------------------------------------------------------------------------- */

@media all and (min-width: 768px), print {
  .c-list {
    --list-font-size: 16;
    --list-line-height: 1.6;
  }
  .c-list--desc {
    --list-desc-color: var(--primary-color-100);
  }
  .c-list--gap {
    --list-gap-x: 24;
    --list-gap-y: 24;

    display: flex;
    gap: calc(var(--list-gap-y) / var(--font-size) * 1rem) calc(var(--list-gap-x) / var(--font-size) * 1rem);
    flex-wrap: wrap;
  }
  .c-list-item {
    position: relative;
    display: flex;
    font-size: calc(var(--list-font-size) / var(--font-size) * 1rem);
    line-height: var(--list-line-height);
  }
  .c-list-item::before {
    content: "・";
  }
  .c-list--num .c-list-item::before {
    display: none;
  }
  .c-list--desc .c-list-item::before {
    content: "";
    display: block;
    width: calc(var(--list-font-size) / var(--font-size) * 1rem);
    height: calc(var(--list-font-size) / var(--font-size) * 1rem);
    border-radius: 9999px;
    background-color: var(--list-desc-color);
    margin-top: calc((var(--list-font-size) * var(--list-line-height) - var(--list-font-size)) / 2 / var(--font-size) * 1rem);
    margin-right: calc(6 * var(--list-font-size) / var(--font-size) / var(--font-size) * 1rem);
    flex-shrink: 0;
  }
  .c-list--note .c-list-item::before {
    content: "※";
    line-height: 1.8;
  }
  .c-list--num > .c-list-item > .c-list-item__ico {
    width: calc(36 / var(--font-size) * 1rem);
    flex-shrink: 0;
  }
  .c-list--indent .c-list-item::before {
    content: "";
  }
  .c-list--indent .c-list-item__in--ico {
    flex-shrink: 0;
    line-height: 1.8;
  }
  .c-list-item__in {
  }
  .c-list-item__in > a {
    color: var(--primary-color-100);
    text-decoration: underline;
  }
  .c-list-item__in > a:hover {
    text-decoration: none;
  }

  /* L */
  .c-list--xl {
    --list-font-size: 20;
  }
  .c-list--l {
    --list-font-size: 18;
  }
  /* m */
  .c-list--m {
    --list-font-size: 16;
  }
  /* s */
  .c-list--s {
    --list-font-size: 14;
  }
  /* xs */
  .c-list--xs {
    --list-font-size: 12;
  }

}

@media all and (max-width: 767px) {
  .c-list {
    --list-font-size: 16;
    --list-line-height: 1.6;
  }
  .c-list--desc {
    --list-desc-color: var(--primary-color-100);
  }
  .c-list--gap {
    --list-gap-x: 24;
    --list-gap-y: 24;

    display: flex;
    gap: calc(var(--list-gap-y) / var(--font-size) * 1rem) calc(var(--list-gap-x) / var(--font-size) * 1rem);
    flex-wrap: wrap;
  }
  .c-list-item {
    position: relative;
    display: flex;
    font-size: calc(var(--list-font-size) / var(--font-size) * 1rem);
    line-height: var(--list-line-height);
  }
  .c-list-item::before {
    content: "・";
  }
  .c-list--num .c-list-item::before {
    display: none;
  }
  .c-list--desc .c-list-item::before {
    content: "";
    display: block;
    width: calc(var(--list-font-size) / var(--font-size) * 1rem);
    height: calc(var(--list-font-size) / var(--font-size) * 1rem);
    border-radius: 9999px;
    background-color: var(--list-desc-color);
    margin-top: calc((var(--list-font-size) * var(--list-line-height) - var(--list-font-size)) / 2 / var(--font-size) * 1rem);
    margin-right: calc(6 * var(--list-font-size) / var(--font-size) / var(--font-size) * 1rem);
    flex-shrink: 0;
  }
  .c-list--note .c-list-item::before {
    content: "※";
    line-height: 1.8;
  }
  .c-list--num > .c-list-item > .c-list-item__ico {
    width: calc(36 / var(--font-size) * 1rem);
    flex-shrink: 0;
  }
  .c-list--indent .c-list-item::before {
    content: "";
  }
  .c-list--indent .c-list-item__in--ico {
    flex-shrink: 0;
    line-height: 1.8;
  }
  .c-list-item__in {
  }
  .c-list-item__in > a {
    color: var(--primary-color-100);
    text-decoration: underline;
  }
  .c-list-item__in > a:hover {
    text-decoration: none;
  }

  /* L */
  .c-list--xl {
    --list-font-size: 20;
  }
  .c-list--l {
    --list-font-size: 18;
  }
  /* m */
  .c-list--m {
    --list-font-size: 16;
  }
  /* s */
  .c-list--s {
    --list-font-size: 14;
  }
  /* xs */
  .c-list--xs {
    --list-font-size: 12;
  }

  /* SPのみ */
  /* s */
  .c-list-sp--s {
    --list-font-size: 14;
  }

}

/* --------------------------------------------------------------------------
  番号付きリスト
-------------------------------------------------------------------------- */

@media all and (min-width: 768px), print {
  .c-num-list {
    --num-list-font-size: 16;
    --num-list-color: var(--primary-color-100);
  }
  .c-num-list__dl {
    position: relative;
    padding-left: 2rem;
  }
  .c-num-list__dt {
    position: absolute;
    top: 0;
    left: 0;
    width: 1.95em;
    color: var(--white-color);
    font-weight: 700;
    font-size: 0.75rem;
    line-height: 1.95;
    text-align: center;
    background-color:  var(--num-list-color);
    border-radius: 9999px;
  }
  .c-num-list__dd {
    line-height: 1.5;
    font-size: calc(var(--num-list-font-size) / var(--font-size) * 1rem);
  }
}

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

/* --------------------------------------------------------------------------
  注釈 テキスト
-------------------------------------------------------------------------- */

@media all and (min-width: 768px), print {
  .c-note .c-note--num {
    --note-txt-font-size: 16;
    --note-position: start;
    --note-txt-color: var(--black-color);
  }
  .c-note-txt {
    font-size: calc(var(--note-txt-font-size) / var(--font-size) * 1rem);
    display: flex;
    justify-content: var(--note-position);
    line-height: 1.8;
  }
  .c-note-txt::before {
    content: "※";
  }
  .c-note--num .c-note-txt::before {
    display: none;
  }
  .c-note--num .c-note-txt__ico {
    width: calc(36 / var(--font-size) * 1rem);
  }
  .c-note-txt__label {
    transform: all 0.3s;
  }
  .c-note-txt__label a {
    text-decoration: underline;
  }
  .c-note-txt__label a:hover {
    text-decoration: none;
  }

  /* CENTER */
  .c-note--center {
    --note-position: center;
  }

  /* M */
  .c-note--m {
    --note-txt-font-size: 16;
  }
  /* S */
  .c-note--s {
    --note-txt-font-size: 14;
  }
  /* XS */
  .c-note--xs {
    --note-txt-font-size: 12;
  }
  /* XXS */
  .c-note--xxs {
    --note-txt-font-size: 11;
  }
  /* XXXS */
  .c-note--xxxs {
    --note-txt-font-size: 10;
  }
}

@media all and (max-width: 767px) {
  .c-note .c-note--num {
    --note-txt-font-size: 16;
    --note-position: start;
    --note-txt-color: var(--black-color);
  }
  .c-note-txt {
    font-size: calc(var(--note-txt-font-size) / var(--font-size) * 1rem);
    display: flex;
    justify-content: var(--note-position);
    line-height: 1.8;
  }
  .c-note-txt::before {
    content: "※";
  }
  .c-note--num .c-note-txt::before {
    display: none;
  }
  .c-note--num .c-note-txt__ico {
    width: calc(32 / var(--font-size) * 1rem);
    flex-shrink: 0;
  }
  .c-note-txt__label {
    transform: all 0.3s;
  }
  .c-note-txt__label a {
    text-decoration: underline;
  }
  .c-note-txt__label a:hover {
    text-decoration: none;
  }

  /* CENTER */
  .c-note--center {
    --note-position: center;
  }

  /* M */
  .c-note--m {
    --note-txt-font-size: 16;
  }
  /* S */
  .c-note--s {
    --note-txt-font-size: 14;
  }
  /* XS */
  .c-note--xs {
    --note-txt-font-size: 12;
  }
  /* XXS */
  .c-note--xxs {
    --note-txt-font-size: 11;
  }
  /* XXXS */
  .c-note--xxxs {
    --note-txt-font-size: 10;
  }
  /* SPのみ */
  /* M */
  .c-note-sp--m {
    --note-txt-font-size: 16;
  }
  /* S */
  .c-note-sp--s {
    --note-txt-font-size: 14;
  }
  /* XS */
  .c-note-sp--xs {
    --note-txt-font-size: 12;
  }
  /* XXS */
  .c-note-sp--xxs {
    --note-txt-font-size: 11;
  }
  /* XXXS */
  .c-note-sp--xxxs {
    --note-txt-font-size: 10;
  }
  .c-note-sp--xs.c-note--num .c-note-txt__ico {
    width: calc(24 / var(--font-size) * 1rem);
    flex-shrink: 0;
  }

}

/* ==========================================================================
  BUTTON COMPONENT
========================================================================== */

/* --------------------------------------------------------------------------
  ボタン
-------------------------------------------------------------------------- */

@media all and (min-width: 768px), print {
  .c-btn {
    --btn-bg-color: var(--primary-color-100);
    --btn-border-color: var(--primary-color-100);
    --btn-txt-color: var(--white-color);
    --btn-arrow-color: var(--white-color);
    --btn-txt-font-size: 16;
    --btn-min-height: 64;
    --btn-px: 43;
    --btn-ico-size: 11;
    --btn-radius: 9999;

    display: block;
    width: 100%;
  }
  a.c-btn:hover,
  a .c-btn:hover,
  button.c-btn:hover {
    --btn-bg-color: var(--white-color);
    --btn-txt-color: var(--btn-border-color);
    --btn-arrow-color: var(--btn-border-color);
  }
  .c-btn__in {
    background-color: var(--btn-bg-color);
    border-radius: calc(var(--btn-radius) / var(--font-size) * 1rem);
    border: calc(1 / var(--font-size) * 1rem) solid var(--btn-border-color);
    height: 100%;
    transition: all 0.2s;
  }
  .c-btn__body {
    position: relative;
    min-height: calc(var(--btn-min-height) / var(--font-size) * 1rem);
    display: flex;
    justify-content: center;
    align-items: center;
    padding: calc(8 / var(--font-size) * 1rem) calc(var(--btn-px) / var(--font-size) * 1rem);
  }
  .c-btn-txt {
    color: var(--btn-txt-color);
    text-align: center;
    width: 100%;
    transition: all 0.2s;
  }
  .c-btn-txt__label {
    font-size: calc(var(--btn-txt-font-size) / var(--font-size) * 1rem);
    font-weight: 500;
    line-height: 1.5;
  }
  .c-btn-arrow {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: calc(var(--btn-px) / var(--font-size) * 1rem);
    height: calc(var(--btn-min-height) / var(--font-size) * 1rem);
  }
  .c-btn-arrow--back{
    right: unset;
    left: 0;
  }
  /* c-btn--public */
  .c-btn.c-btn--public {
    --btn-bg-color: var(--primary-color-100);
    --btn-border-color: var(--primary-color-100);
    --btn-txt-color: var(--white-color);
    --btn-arrow-color: var(--white-color);
    --btn-txt-font-size: 16;
    --btn-min-height: 66;
    --btn-px: 52;
    --btn-ico-size: 14;
    --btn-radius: 5;
    display: block;
  }
  .c-btn--public {
    margin: auto;
    width: calc(330 / var(--font-size) * 1rem);
  }
  .c-btn--public-l {
    margin: auto;
    width: calc(390 / var(--font-size) * 1rem);
  }
  .c-btn--public.c-btn--disable{
    --btn-bg-color: var(--gray-color-650);
    --btn-border-color: var(--gray-color-650);
    pointer-events: none;
  }
  .c-btn--public .c-btn-txt {
    text-align: left;
    margin-left: calc(15 / var(--font-size) * 1rem);
  }
  .c-btn--public .c-btn__body {
    padding: calc(8 / var(--font-size) * 1rem) calc(var(--btn-px) / var(--font-size) * 1rem) calc(8 / var(--font-size) * 1rem) calc(20 / var(--font-size) * 1rem);
  }
  .c-btn-arrow__label {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
  }
  .c-btn-arrow__label .c-svg {
    width: calc(var(--btn-ico-size) / var(--font-size) * 1rem);
    fill: var(--btn-arrow-color);
    transition: all 0.2s;
  }

  /* square */
  .c-btn--square {
    --btn-radius: 0;
  }

  /* regulation */
  .c-btn.c-btn--regulation {
    --btn-bg-color: var(--primary-color-100);
    --btn-border-color: var(--primary-color-100);
    --btn-txt-color: var(--white-color);
    --btn-arrow-color: var(--white-color);
    --btn-min-height: 56;
    --btn-px: 32;
    --btn-ico-size: 14;
    --btn-radius: 5;

    display: block;
  }
  .c-btn--regulation {
    width: calc(80 / var(--font-size) * 1rem);
  }
  a.c-btn--regulation:hover,
  a .c-btn--regulation:hover,
  button.c-btn--regulation:hover {
    --btn-bg-color: var(--white-color);
    --btn-txt-color: var(--btn-border-color);
    --btn-arrow-color: var(--btn-border-color);
  }
  .c-btn--regulation .c-btn__in {
    background-color: var(--btn-bg-color);
    border-radius: calc(var(--btn-radius) / var(--font-size) * 1rem);
    border: calc(1 / var(--font-size) * 1rem) solid var(--btn-border-color);
    height: 100%;
    transition: all 0.2s;
  }
  .c-btn--regulation .c-btn__body {
    position: relative;
    min-height: calc(var(--btn-min-height) / var(--font-size) * 1rem);
    display: flex;
    justify-content: start;
    align-items: center;
    padding: calc(8 / var(--font-size) * 1rem) calc(16 / var(--font-size) * 1rem);
    padding-right: calc(var(--btn-px) / var(--font-size) * 1rem);
  }
  .c-btn--regulation .c-btn-txt {
    color: var(--btn-txt-color);
    text-align: center;
    width: 100%;
    transition: all 0.2s;
  }
  .c-btn--regulation .c-btn-txt__label {
    font-size: calc(var(--btn-txt-font-size) / var(--font-size) * 1rem);
    font-weight: 500;
    line-height: 1.5;
  }
  .c-btn--regulation .c-btn-arrow {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: calc(var(--btn-px) / var(--font-size) * 1rem);
    height: calc(var(--btn-min-height) / var(--font-size) * 1rem);
  }
  /* fontsize */
  .c-btn--xl {
    --btn-txt-font-size: 18;
  }
  .c-btn--l {
    --btn-txt-font-size: 16;
    --btn-min-height: 88;
    --btn-px: 78;
  }
  .c-btn--m {
    --btn-txt-font-size: 16;
  }
  .c-btn--s {
    --btn-txt-font-size: 14;
    --btn-min-height: 36;
    --btn-ico-size: 9;
    --btn-px: 30;
  }
  .c-btn--xs {
    --btn-txt-font-size: 12;
    --btn-min-height: 28;
    --btn-px: 6;
  }
  .c-btn--xs .c-btn-arrow {
    display: none;
  }

  /* color */
  .c-btn--gray {
    --btn-bg-color: var(--gray-color-100);
    --btn-txt-color: var(--black-color);
    --btn-arrow-color: var(--black-color);
    --btn-border-color: var(--gray-color-100);
  }
  a.c-btn.c-btn--gray:hover,
  a .c-btn.c-btn--gray:hover,
  button.c-btn.c-btn--gray:hover {
    --btn-bg-color: var(--white-color);
    --btn-txt-color: var(--black-color);
    --btn-arrow-color: var(--black-color);
  }

  .c-btn--white {
    --btn-bg-color: var(--white-color);
    --btn-txt-color: var(--black-color);
    --btn-arrow-color: var(--black-color);
    --btn-border-color: var(--white-color);
  }
  a.c-btn.c-btn--white:hover,
  a .c-btn.c-btn--white:hover,
  button.c-btn.c-btn--white:hover {
    --btn-bg-color: var(--black-color);
    --btn-txt-color: var(--white-color);
    --btn-arrow-color: var(--white-color);
  }

  .c-btn--stroke {
    --btn-bg-color: var(--white-color);
    --btn-txt-color: var(--btn-border-color);
    --btn-arrow-color: var(--btn-border-color);
  }
  a.c-btn.c-btn--stroke:hover,
  a .c-btn.c-btn--stroke:hover,
  button.c-btn.c-btn--stroke:hover  {
    --btn-bg-color: var(--btn-border-color);
    --btn-txt-color: var(--white-color);
    --btn-arrow-color: var(--white-color);
  }

  /* back */
  .c-btn--back .c-btn-arrow {
    left: 0;
    right: unset;
    transform: translateY(-50%) rotate(180deg);
  }

  .c-btn--before .c-btn-arrow {
    left: 0;
    right: unset;
  }

  /* search */
  .c-btn--search {
    --btn-ico-size: 16;
    --btn-px: 68;
  }

  /* dl */
  .c-btn--dl {
    --btn-ico-size: 16;
    --btn-px: 68;
  }
}
@media all and (max-width: 767px) {
  .c-btn {
    --btn-bg-color: var(--primary-color-100);
    --btn-border-color: var(--primary-color-100);
    --btn-txt-color: var(--white-color);
    --btn-arrow-color: var(--white-color);
    --btn-txt-font-size: 16;
    --btn-min-height: 56;
    --btn-px: 43;
    --btn-ico-size: 11;
    --btn-radius: 9999;

    display: block;
    width: 100%;
  }
  a.c-btn:hover,
  a .c-btn:hover,
  button.c-btn:hover {
    --btn-bg-color: var(--white-color);
    --btn-txt-color: var(--btn-border-color);
    --btn-arrow-color: var(--btn-border-color);
  }
  .c-btn__in {
    background-color: var(--btn-bg-color);
    border-radius: calc(var(--btn-radius) / var(--font-size) * 1rem);
    border: calc(1 / var(--font-size) * 1rem) solid var(--btn-border-color);
    height: 100%;
    transition: all 0.2s;
  }
  .c-btn__body {
    position: relative;
    min-height: calc(var(--btn-min-height) / var(--font-size) * 1rem);
    display: flex;
    justify-content: center;
    align-items: center;
    padding: calc(8 / var(--font-size) * 1rem) calc(var(--btn-px) / var(--font-size) * 1rem);
  }
  .c-btn-txt {
    color: var(--btn-txt-color);
    text-align: center;
    width: 100%;
    transition: all 0.2s;
  }
  .c-btn-txt__label {
    font-size: calc(var(--btn-txt-font-size) / var(--font-size) * 1rem);
    font-weight: 500;
    line-height: 1.5;
  }
  .c-btn-arrow {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: calc(var(--btn-px) / var(--font-size) * 1rem);
    height: calc(var(--btn-min-height) / var(--font-size) * 1rem);
  }
  .c-btn-arrow--back{
    right: unset;
    left: 0;
  }
  .c-btn-arrow__label {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
  }
  /* c-btn--public */
  .c-btn.c-btn--public {
    --btn-bg-color: var(--primary-color-100);
    --btn-border-color: var(--primary-color-100);
    --btn-txt-color: var(--white-color);
    --btn-arrow-color: var(--white-color);
    --btn-txt-font-size: 16;
    --btn-min-height: 56;
    --btn-px: 52;
    --btn-ico-size: 14;
    --btn-radius: 5;
    display: block;
  }
  .c-btn--public .c-btn-ico .c-ico-btn__label {
    display: block;
    width: calc(25 / var(--font-size) * 1rem);
    height: calc(29 / var(--font-size) * 1rem);
  }
  .c-btn--public {
    margin: auto;
    width: calc(330 / var(--font-size) * 1rem);
  }
  .c-btn--public-l {
    margin: auto;
    width: calc(390 / var(--font-size) * 1rem);
  }
  .c-btn--public.c-btn--disable{
    --btn-bg-color: var(--gray-color-650);
    --btn-border-color: var(--gray-color-650);
    pointer-events: none;
  }
  .c-btn--public .c-btn-txt {
    text-align: left;
    margin-left: calc(15 / var(--font-size) * 1rem);
  }
  .c-btn--public .c-btn__body {
    padding: calc(8 / var(--font-size) * 1rem) calc(var(--btn-px) / var(--font-size) * 1rem) calc(8 / var(--font-size) * 1rem) calc(20 / var(--font-size) * 1rem);
  }
  .c-btn-arrow__label .c-svg {
    width: calc(var(--btn-ico-size) / var(--font-size) * 1rem);
    fill: var(--btn-arrow-color);
    transition: all 0.2s;
  }
  /* regulation */
  .c-btn.c-btn--regulation {
    --btn-bg-color: var(--primary-color-100);
    --btn-border-color: var(--primary-color-100);
    --btn-txt-color: var(--white-color);
    --btn-arrow-color: var(--white-color);
    --btn-min-height: 56;
    --btn-px: 32;
    --btn-ico-size: 14;
    --btn-radius: 5;

    display: block;
  }
  .c-btn--regulation {
    width: calc(80 / var(--font-size) * 1rem);
  }
  a.c-btn--regulation:hover,
  a .c-btn--regulation:hover,
  button.c-btn--regulation:hover {
    --btn-bg-color: var(--white-color);
    --btn-txt-color: var(--btn-border-color);
    --btn-arrow-color: var(--btn-border-color);
  }
  .c-btn--regulation .c-btn__in {
    background-color: var(--btn-bg-color);
    border-radius: calc(var(--btn-radius) / var(--font-size) * 1rem);
    border: calc(1 / var(--font-size) * 1rem) solid var(--btn-border-color);
    height: 100%;
    transition: all 0.2s;
  }
  .c-btn--regulation .c-btn__body {
    position: relative;
    min-height: calc(var(--btn-min-height) / var(--font-size) * 1rem);
    display: flex;
    justify-content: start;
    align-items: center;
    padding: calc(8 / var(--font-size) * 1rem) calc(16 / var(--font-size) * 1rem);
    padding-right: calc(var(--btn-px) / var(--font-size) * 1rem);
  }
  .c-btn--regulation .c-btn-txt {
    color: var(--btn-txt-color);
    text-align: center;
    width: 100%;
    transition: all 0.2s;
  }
  .c-btn--regulation .c-btn-txt__label {
    font-size: calc(var(--btn-txt-font-size) / var(--font-size) * 1rem);
    font-weight: 500;
    line-height: 1.5;
  }
  .c-btn--regulation .c-btn-arrow {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: calc(var(--btn-px) / var(--font-size) * 1rem);
    height: calc(var(--btn-min-height) / var(--font-size) * 1rem);
  }

  /* square */
  .c-btn--square {
    --btn-radius: 0;
  }

  /* fontsize */
  .c-btn--xl {
    --btn-txt-font-size: 18;
  }
  .c-btn--l {
    --btn-txt-font-size: 16;
    --btn-min-height: 88;
    --btn-px: 78;
  }
  .c-btn--m {
    --btn-txt-font-size: 16;
  }
  .c-btn--s {
    --btn-txt-font-size: 14;
    --btn-min-height: 36;
    --btn-ico-size: 9;
    --btn-px: 30;
  }
  .c-btn--xs {
    --btn-txt-font-size: 12;
    --btn-min-height: 28;
    --btn-px: 6;
  }
  .c-btn--xs .c-btn-arrow {
    display: none;
  }

  /* color */
  .c-btn--gray {
    --btn-bg-color: var(--gray-color-100);
    --btn-txt-color: var(--black-color);
    --btn-arrow-color: var(--black-color);
    --btn-border-color: var(--gray-color-100);
  }
  a.c-btn.c-btn--gray:hover,
  a .c-btn.c-btn--gray:hover,
  button.c-btn.c-btn--gray:hover {
    --btn-bg-color: var(--white-color);
    --btn-txt-color: var(--black-color);
    --btn-arrow-color: var(--black-color);
  }
  .c-btn--white {
    --btn-bg-color: var(--white-color);
    --btn-txt-color: var(--black-color);
    --btn-arrow-color: var(--black-color);
    --btn-border-color: var(--white-color);
  }
  a.c-btn.c-btn--white:hover,
  a .c-btn.c-btn--white:hover,
  button.c-btn.c-btn--white:hover {
    --btn-bg-color: var(--black-color);
    --btn-txt-color: var(--white-color);
    --btn-arrow-color: var(--white-color);
  }

  .c-btn--stroke {
    --btn-bg-color: var(--white-color);
    --btn-txt-color: var(--btn-border-color);
    --btn-arrow-color: var(--btn-border-color);
  }
  .c-btn--stroke:hover {
    --btn-bg-color: var(--btn-border-color);
    --btn-txt-color: var(--white-color);
    --btn-arrow-color: var(--white-color);
  }

  /* back */
  .c-btn--back .c-btn-arrow {
    left: 0;
    right: unset;
    transform: translateY(-50%) rotate(180deg);
  }

  .c-btn--before .c-btn-arrow {
    left: 0;
    right: unset;
  }

  /* disable */
  .c-btn--disable {
    --btn-bg-color: var(--gray-color-100);
    --btn-border-color: var(--gray-color-100);
    pointer-events: none;
  }

  /* search */
  .c-btn--search {
    --btn-ico-size: 16;
    --btn-px: 68;
  }

  /* dl */
  .c-btn--dl {
    --btn-ico-size: 16;
    --btn-px: 68;
  }
}

/* --------------------------------------------------------------------------
  テキストボタン
-------------------------------------------------------------------------- */

@media all and (min-width: 768px), print {
  .c-link-btn {
    --link-arrow-color: var(--primary-color-100);
    --link-font-size: 14;
    --link-note-font-size: 12;
    --link-rate: var(--link-font-size) / 14;
    --link-txt-color: var(--blue-color-100);
  }
  a.c-link-btn:hover,
  a .c-link-btn:hover {
    --link-txt-color: var(--link-arrow-color);
  }
  .c-link-btn__in {
    display: flex;
  }
  .c-link-btn-ico {
    width: calc(26 * var(--link-rate) / var(--font-size) * 1rem);
    height: calc(26 * var(--link-rate) / var(--font-size) * 1rem);
    border: calc(1 / var(--font-size) * 1rem) solid var(--link-arrow-color);
    border-radius: 50%;
    margin-right: calc(8 / var(--font-size) * 1rem);
    flex-shrink: 0;
  }
  .c-link-btn-ico__label {
    display: flex;
    justify-content: center;
    align-self: center;
    height: 100%;
  }
  .c-link-btn-ico__label .c-svg {
    width: calc(9 / var(--font-size) * 1rem);
  }
  .c-link-btn-ico__label svg {
    fill: var(--link-arrow-color);
  }
  .c-link-btn-txt {
  }
  .c-link-btn-txt__label {
    font-size: calc(var(--link-font-size) / var(--font-size) * 1rem);
    line-height: 1.8;
    color: var(--link-txt-color);
    transition: all 0.2s;
    display: inline-block;
  }
  .c-link-btn-txt__label-note{
    font-size: calc(var(--link-note-font-size) / var(--font-size) * 1rem);
  }
  .c-link-btn-txt__ico {
    display: inline-block;
    width: calc(24 * var(--link-rate) / var(--font-size) * 1rem);
    vertical-align: text-top;
  }
  .c-link-btn-txt__ico svg {
    fill: var(--link-arrow-color);
  }

  /* fontsize */
  .c-link-btn--l {
    --link-font-size: 16;
    --link-note-font-size: 14;
  }
  .c-link-btn--m {
    --link-font-size: 14;
    --link-note-font-size: 12;
  }
  .c-link-btn--s {
    --link-font-size: 12;
    --link-note-font-size: 10;
  }

  .c-link-btn--ico .c-link-btn__in {
    align-items: flex-start;
  }
  .c-link-btn--ico .c-link-btn-ico {
    width: calc(16 * var(--link-rate) / var(--font-size) * 1rem);
    height: calc(18 * var(--link-rate) / var(--font-size) * 1rem);
    margin-right: calc(10 / var(--font-size) * 1rem);
    border: none;
    flex-shrink: 0;
    margin-top: 0.25em;
  }
}

@media all and (max-width: 767px) {
  .c-link-btn {
    --link-arrow-color: var(--primary-color-100);
    --link-font-size: 14;
    --link-note-font-size: 12;
    --link-rate: var(--link-font-size) / 14;
    --link-txt-color: var(--blue-color-100);
  }
  a.c-link-btn:hover,
  a .c-link-btn:hover {
    --link-txt-color: var(--link-arrow-color);
  }
  .c-link-btn__in {
    display: flex;
  }
  .c-link-btn-ico {
    width: calc(26 * var(--link-rate) / var(--font-size) * 1rem);
    height: calc(26 * var(--link-rate) / var(--font-size) * 1rem);
    border: calc(1 / var(--font-size) * 1rem) solid var(--link-arrow-color);
    border-radius: 50%;
    margin-right: calc(8 / var(--font-size) * 1rem);
    flex-shrink: 0;
  }
  .c-link-btn-ico__label {
    display: flex;
    justify-content: center;
    align-self: center;
    height: 100%;
  }
  .c-link-btn-ico__label .c-svg {
    width: calc(9 / var(--font-size) * 1rem);
  }
  .c-link-btn-ico__label svg {
    fill: var(--link-arrow-color);
  }
  .c-link-btn-txt {
  }
  .c-link-btn-txt__label {
    font-size: calc(var(--link-font-size) / var(--font-size) * 1rem);
    line-height: 1.8;
    color: var(--link-txt-color);
    transition: all 0.2s;
    display: inline-block;
  }
  .c-link-btn-txt__label-note{
    font-size: calc(var(--link-note-font-size) / var(--font-size) * 1rem);
  }
  .c-link-btn-txt__ico {
    display: inline-block;
    width: calc(24 * var(--link-rate) / var(--font-size) * 1rem);
    vertical-align: text-top;
  }
  .c-link-btn-txt__ico svg {
    fill: var(--link-arrow-color);
  }

  /* fontsize */
  .c-link-btn--l {
    --link-font-size: 16;
    --link-note-font-size: 14;
  }
  .c-link-btn--m {
    --link-font-size: 14;
    --link-note-font-size: 12;
  }
  .c-link-btn--s {
    --link-font-size: 12;
    --link-note-font-size: 10;
  }

  .c-link-btn--ico .c-link-btn__in {
    align-items: flex-start;
  }
  .c-link-btn--ico .c-link-btn-ico {
    width: calc(16 * var(--link-rate) / var(--font-size) * 1rem);
    height: calc(18 * var(--link-rate) / var(--font-size) * 1rem);
    margin-right: calc(10 / var(--font-size) * 1rem);
    border: none;
    flex-shrink: 0;
    margin-top: 0.25em;
  }
}

/* --------------------------------------------------------------------------
  アイコンボタン
-------------------------------------------------------------------------- */

@media all and (min-width: 768px), print {
  .c-ico-btn {
    --btn-bg-color: var(--primary-color-100);
    --btn-border-color: var(--primary-color-100);
    --btn-txt-color: var(--white-color);
    --btn-arrow-color: var(--white-color);
    --btn-txt-font-size: 16;
    --btn-min-height: 180;
    --btn-px: 60;
    --btn-ico-size: 10;
    --btn-radius: 10;
    --btn-rate: var(--btn-txt-font-size) / 16;

    display: block;
    width: 100%;
  }
  .c-ico-btn:hover {
    --btn-bg-color: var(--white-color);
    --btn-txt-color: var(--btn-border-color);
    --btn-arrow-color: var(--btn-border-color);
  }
  .c-ico-btn__in {
    background-color: var(--btn-bg-color);
    border-radius: calc(var(--btn-radius) / var(--font-size) * 1rem);
    border: calc(1 / var(--font-size) * 1rem) solid var(--btn-border-color);
    height: 100%;
    transition: all 0.2s;
  }
  .c-ico-btn__body {
    position: relative;
    min-height: calc(var(--btn-min-height) * var(--btn-rate) / var(--font-size) * 1rem);
    display: flex;
    justify-content: center;
    align-items: center;
    padding: calc(20 * var(--btn-rate) / var(--font-size) * 1rem) calc(var(--btn-px) * var(--btn-rate) / var(--font-size) * 1rem);
    flex-direction: column;
  }
  .c-ico-btn-img {
    width: calc(64 * var(--btn-rate) / var(--font-size) * 1rem);
    height: calc(64 * var(--btn-rate) / var(--font-size) * 1rem);
    flex-shrink: 0;
    margin-bottom: calc(16 * var(--btn-rate) / var(--font-size) * 1rem);
  }
  .c-ico-btn-img__label {
    width: 100%;
    height: 100%;
  }
  .c-ico-btn-img.--zehinfo .c-ico-btn-img__label{
    display: block;
    mask: url(/assets/img/common/ico_zehinfo.svg) center / contain no-repeat; 
    background-color: var(--btn-arrow-color);
    transition: all 0.2s;
  }
  .c-ico-btn-txt {
    color: var(--btn-txt-color);
    text-align: center;
    width: 100%;
    transition: all 0.2s;
  }
  .c-ico-btn-txt__sub-label {
    font-size: calc(15 * var(--btn-rate) / var(--font-size) * 1rem);
    font-weight: bold;
    line-height: 1.5;
    display: block;
    margin-bottom: calc(4 * var(--btn-rate) / var(--font-size) * 1rem);
  }
  .c-ico-btn-txt__label {
    font-size: calc(var(--btn-txt-font-size) / var(--font-size) * 1rem);
    font-weight: bold;
    line-height: 1.5;
  }
  .c-ico-btn-arrow {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: calc(var(--btn-px) / var(--font-size)* 1rem);
    height: calc(var(--btn-min-height) / var(--font-size)* 1rem);
  }
  .c-ico-btn-arrow__label {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
  }
  .c-ico-btn-arrow__label .c-svg {
    width: calc(var(--btn-ico-size) * var(--btn-rate) / var(--font-size) * 1rem);
    fill: var(--btn-arrow-color);
    transition: all 0.2s;
  }
  .c-ico-btn-img__label .c-svg {
    fill: var(--btn-arrow-color);
    transition: all 0.2s;
}
/* c-ico-btn--light */
  .c-ico-btn--light {
    --btn-bg-color: var(--primary-color-10);
    --btn-border-color: var(--primary-color-100);
    --btn-txt-color: var(--primary-color-100);
    --btn-arrow-color: var(--primary-color-100);
    --btn-txt-font-size: 16;
    --btn-min-height: 180;
    --btn-px: 60;
    --btn-ico-size: 10;
    --btn-radius: 10;
    --btn-rate: var(--btn-txt-font-size) / 16;

    display: block;
    width: 100%;
  }
  /* c-ico-footer */
  .c-ico-btn-footer {
    position: relative;
    z-index: -1;
    margin-top: calc(-10 / var(--font-size) * 1rem);
  }
  .c-ico-btn-footer__in {
    padding: calc(30 / var(--font-size)* 1rem) calc(20 / var(--font-size)* 1rem) calc(30 / var(--font-size)* 1rem);
    background-color: var(--gray-color-50);
    border-radius: 0 0 calc(10 / var(--font-size)* 1rem) calc(10 / var(--font-size)* 1rem);
  }
  .l-btn-list--4col .c-ico-btn-footer__in {
    min-height: calc(240 / var(--font-size) * 1rem);
  }
/* 矢印下向きボタン */
.c-ico-btn--down .c-ico-btn-arrow {
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  height: calc(100% - calc(10 / var(--font-size) * 1rem));
}
.c-ico-btn--down .c-ico-btn-arrow__label {
  flex-direction: column;
  justify-content: end;
}
.c-ico-btn--down .c-ico-btn-arrow__label .c-svg {
  transform: rotate(90deg);
  
}

  /* size */
  .c-ico-btn--l {
    --btn-txt-font-size: 18;
  }
  .c-ico-btn--m {
    --btn-txt-font-size: 16;
  }
  .c-ico-btn--s {
    --btn-txt-font-size: 14;
  }
  .c-ico-btn--xs {
    --btn-txt-font-size: 12;
  }
  .c-ico-btn--xxs {
    --btn-txt-font-size: 10;
  }
}
@media all and (max-width: 767px) {
  .c-ico-btn {
    --btn-bg-color: var(--primary-color-100);
    --btn-border-color: var(--primary-color-100);
    --btn-txt-color: var(--white-color);
    --btn-arrow-color: var(--white-color);
    --btn-txt-font-size: 16;
    --btn-min-height: 180;
    --btn-px: 60;
    --btn-ico-size: 10;
    --btn-radius: 10;
    --btn-rate: var(--btn-txt-font-size) / 16;

    display: block;
    width: 100%;
  }
  .c-ico-btn:hover {
    --btn-bg-color: var(--white-color);
    --btn-txt-color: var(--btn-border-color);
    --btn-arrow-color: var(--btn-border-color);
  }
  .c-ico-btn__in {
    background-color: var(--btn-bg-color);
    border-radius: calc(var(--btn-radius) / var(--font-size) * 1rem);
    border: calc(1 / var(--font-size) * 1rem) solid var(--btn-border-color);
    height: 100%;
    transition: all 0.2s;
  }
  .c-ico-btn__body {
    position: relative;
    min-height: calc(var(--btn-min-height) * var(--btn-rate) / var(--font-size) * 1rem);
    display: flex;
    justify-content: center;
    align-items: center;
    padding: calc(20 * var(--btn-rate) / var(--font-size) * 1rem) calc(var(--btn-px) * var(--btn-rate) / var(--font-size) * 1rem);
    flex-direction: column;
  }
  .c-ico-btn-img {
    width: calc(64 * var(--btn-rate) / var(--font-size) * 1rem);
    height: calc(64 * var(--btn-rate) / var(--font-size) * 1rem);
    flex-shrink: 0;
    margin-bottom: calc(16 * var(--btn-rate) / var(--font-size) * 1rem);
  }
  .c-ico-btn-img__label {
    width: 100%;
    height: 100%;
  }
  .c-ico-btn-img.--zehinfo .c-ico-btn-img__label{
    display: block;
    mask: url(/assets/img/common/ico_zehinfo.svg) center / contain no-repeat; 
    background-color: var(--btn-arrow-color);
    transition: all 0.2s;
  }
  .c-ico-btn-txt {
    color: var(--btn-txt-color);
    text-align: center;
    width: 100%;
    transition: all 0.2s;
  }
  .c-ico-btn-txt__sub-label {
    font-size: calc(15 * var(--btn-rate) / var(--font-size) * 1rem);
    font-weight: bold;
    line-height: 1.5;
    display: block;
    margin-bottom: calc(4 * var(--btn-rate) / var(--font-size) * 1rem);
  }
  .c-ico-btn-txt__label {
    font-size: calc(var(--btn-txt-font-size) / var(--font-size) * 1rem);
    font-weight: bold;
    line-height: 1.5;
  }
  .c-ico-btn-arrow {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: calc(var(--btn-px) / var(--font-size)* 1rem);
    height: calc(var(--btn-min-height) / var(--font-size)* 1rem);
  }
  .c-ico-btn-arrow__label {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
  }
  .c-ico-btn-arrow__label .c-svg {
    width: calc(var(--btn-ico-size) * var(--btn-rate) / var(--font-size) * 1rem);
    fill: var(--btn-arrow-color);
    transition: all 0.2s;
  }
  .c-ico-btn-img__label .c-svg {
    fill: var(--btn-arrow-color);
    transition: all 0.2s;
}
  /* c-ico-btn--light */
  .c-ico-btn--light {
    --btn-bg-color: var(--primary-color-10);
    --btn-border-color: var(--primary-color-100);
    --btn-txt-color: var(--primary-color-100);
    --btn-arrow-color: var(--primary-color-100);
    --btn-txt-font-size: 16;
    --btn-min-height: 180;
    --btn-px: 60;
    --btn-ico-size: 10;
    --btn-radius: 10;
    --btn-rate: var(--btn-txt-font-size) / 16;

    display: block;
    width: 100%;
    }
      /* c-ico-footer */
    .c-ico-btn-footer {
      position: relative;
      z-index: -1;
      margin-top: calc(-10 / var(--font-size) * 1rem);
    }
    .c-ico-btn-footer__in {
      padding: calc(30 / var(--font-size)* 1rem) calc(15 / var(--font-size)* 1rem) calc(20 / var(--font-size)* 1rem);
      background-color: var(--gray-color-50);
      border-radius: 0 0 calc(10 / var(--font-size)* 1rem) calc(10 / var(--font-size)* 1rem);
    }
    /* 矢印下向きボタン */
    .c-ico-btn--down .c-ico-btn-arrow {
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    height: calc(100% - calc(10 / var(--font-size) * 1rem));
    }
    .c-ico-btn--down .c-ico-btn-arrow__label {
    flex-direction: column;
    justify-content: end;
    }
    .c-ico-btn--down .c-ico-btn-arrow__label .c-svg {
    transform: rotate(90deg);
    }
  /* size */
  .c-ico-btn--l {
    --btn-txt-font-size: 18;
  }
  .c-ico-btn--m {
    --btn-txt-font-size: 16;
  }
  .c-ico-btn--s {
    --btn-txt-font-size: 14;
  }
  .c-ico-btn--xs {
    --btn-txt-font-size: 12;
  }
  .c-ico-btn--xxs {
    --btn-txt-font-size: 10;
  }
}

@media all and (min-width: 768px), print {
  /* disable */
  .c-btn--disable {
    --btn-bg-color: var(--gray-color-100);
    --btn-border-color: var(--gray-color-100);
    pointer-events: none;
  }
}
@media all and (max-width: 767px) {
  /* disable */
  .c-btn--disable {
    --btn-bg-color: var(--gray-color-100);
    --btn-border-color: var(--gray-color-100);
    pointer-events: none;
  }
}

/* --------------------------------------------------------------------------
  矢印付きテキストボタン
-------------------------------------------------------------------------- */
@media all and (min-width:768px), print {
  .c-link-btn--arrow {
    display: inline-block;
    --link-rate: 6 / 14;
  }
  .c-link-btn--arrow .c-link-btn__in {
    align-items: center;
  }
  .c-link-btn--arrow .c-link-btn-txt__label {
    text-decoration: underline;
  }
  .c-link-btn--arrow:hover .c-link-btn-txt__label {
    text-decoration: none;
  }
  .c-link-btn--arrow .c-link-btn-ico {
    margin-right: 0;
    margin-left: calc(12 / var(--font-size) * 1rem);
  }
}
@media all and (max-width: 767px) {
  .c-link-btn--arrow {
    display: inline-block;
    --link-rate: 6 / 14;
  }
  .c-link-btn--arrow .c-link-btn__in {
    align-items: center;
  }
  .c-link-btn--arrow .c-link-btn-txt__label {
    text-decoration: underline;
  }
  .c-link-btn--arrow:hover .c-link-btn-txt__label {
    text-decoration: none;
  }
  .c-link-btn--arrow .c-link-btn-ico {
    margin-right: 0;
    margin-left: calc(12 / var(--font-size) * 1rem);
  }
}
/* --------------------------------------------------------------------------
  テキストリンク
-------------------------------------------------------------------------- */
@media all and (min-width: 768px), print {
  .c-link-txt {
    --link-font-size: 14;
    --link-txt-color: var(--blue-color-100);
    --link-hover-color: var(--primary-color-100);
    color: var(--link-txt-color);
    text-decoration: underline;
  }
  a.c-link-txt:hover,
  a .c-link-txt:hover {
    --link-txt-color: var(--link-hover-color);
  }

  /* fontsize */
  .c-link-txt--l {
    --link-font-size: 16;
    --link-note-font-size: 14;
  }
  .c-link-txt--m {
    --link-font-size: 14;
    --link-note-font-size: 12;
  }
  .c-link-txt--s {
    --link-font-size: 12;
    --link-note-font-size: 10;
  }

  .c-link-txt--red-100 {
    --link-txt-color: var(--red-color-100);
  }
}

@media all and (max-width: 767px) {
  .c-link-txt {
    --link-font-size: 14;
    --link-txt-color: var(--blue-color-100);
    --link-hover-color: var(--primary-color-100);
    color: var(--link-txt-color);
    text-decoration: underline;
  }
  a.c-link-txt:hover,
  a .c-link-txt:hover {
    --link-txt-color: var(--link-hover-color);
  }

  /* fontsize */
  .c-link-txt--l {
    --link-font-size: 16;
    --link-note-font-size: 14;
  }
  .c-link-txt--m {
    --link-font-size: 14;
    --link-note-font-size: 12;
  }
  .c-link-txt--s {
    --link-font-size: 12;
    --link-note-font-size: 10;
  }

  .c-link-txt--red-100 {
    --link-txt-color: var(--red-color-100);
  }
}

/* ==========================================================================
  TABLE COMPONENT
========================================================================== */

@media all and (min-width: 768px), print {
  .c-table {
  }
  .c-table--sub{
    --primary-color-100:var(--sub-sky-100);
    --primary-color-10:var(--sub-sky-10);
    --gray-color-200:var(--sub-sky-100);
  }
  .c-table__in {
  }
  .c-table__header {
    margin-bottom: calc(10 / var(--font-size) * 1rem);
  }
  .c-table__body {
  }
  .c-table-chart {
    background-color: var(--white-color);
    width: 100%;
    border-collapse: collapse;
  }
  .c-table-chart__thead {
  }
  .c-table-chart__thead + .c-table-chart__tbody {
    border-top: var(--secondary-color-200) calc(2 / var(--font-size) * 1rem) solid;
  }
  .c-table-chart__thead .c-table-chart__tr {
    text-align: left;
  }
  .c-table-chart__tr {
  }
  .c-table-chart-cell {
    padding: calc(16 / var(--font-size) * 1rem);
    border: calc(1 / var(--font-size) * 1rem) solid var(--gray-color-200);
    text-align: center;
    font-weight: 500;
  }
  .c-table-chart-cell--left {
    text-align: start;
  }
  .c-table-chart-cell--line {
    position: relative;
  }
  .c-table-chart-cell--line::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: linear-gradient(to right top, transparent calc(50% - 0.5px), var(--primary-color-100) 50%, var(--primary-color-100) calc(50% + 0.5px), transparent calc(50% + 1px))
  }
  .c-table-chart-cell-vertical{
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  * + .c-table-chart-btn {
    margin-top: calc(6 / var(--font-size) * 1rem);
  }
  .c-table-chart-btn .c-btn__body {
    padding-top: calc(4 / var(--font-size)* 1rem);
    padding-bottom: calc(4 / var(--font-size)* 1rem);
  }
  .c-table-chart-btn .c-btn--disable{
    --btn-bg-color: var(--portal-color-100);
    --btn-border-color: var(--portal-color-100);
  }
  .c-table__footer {
    margin-top: calc(10 / var(--font-size) * 1rem);
  }

  .table-cell-size {
  }
  .table-cell-size--50{
    width: 50%;
  }
  .table-cell-size--l {
    width: calc(300 / var(--font-size) * 1rem);
  }
  .table-cell-size--m {
    width: calc(200 / var(--font-size) * 1rem);
  }
  .table-cell-size--s {
    width: calc(100 / var(--font-size) * 1rem);
  }

}

@media all and (max-width: 767px) {
  .c-table {
    overflow-x: scroll;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
  }
  #result-table .c-table {
    position: relative;
  }
  /* #result-table .c-table {
    overflow: auto;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
  } */
  /* #result-table .c-table__in {
    overflow-x: scroll;
  } */
  /* .js-scrollable-result {
    position: relative;
    overflow: auto hidden;
  } */
  .c-table--sub{
    --primary-color-100:var(--sub-sky-100);
    --primary-color-10:var(--sub-sky-10);
    --gray-color-200:var(--sub-sky-100);
  }
  .c-table__in {

  }
  .c-table__header {
    margin-left: calc(25 / var(--font-size)* 1rem);
    margin-bottom: calc(10 / var(--font-size)* 1rem);
    padding-top: calc(30 / var(--font-size)* 1rem);
  }
  .c-table__body {
  }
  .c-table-chart {
    position: relative;
    margin-left: calc(25 / var(--font-size) * 1rem);
    background-color: var(--white-color);
    width: calc(748 / var(--font-size) * 1rem);
    border-collapse: collapse;
  }
  .c-table-chart::after{
    content: "";
    display: block;
    position: absolute;
    right: 0;
    top: 0;
    margin-right: calc(25 / var(--font-size)* 1rem * -1);
    width: calc(25 / var(--font-size)* 1rem);
    height: 100%;
  }
  .c-table-chart__thead {
  }
  .c-table-chart__thead + .c-table-chart__tbody {
    border-top: var(--secondary-color-200) calc(2 / var(--font-size) * 1rem) solid;
  }
  .c-table-chart__thead .c-table-chart__tr {
    text-align: left;
  }
  .c-table-chart__tr {
  }
  .c-table-chart-cell {
    padding: calc(12 / var(--font-size) * 1rem);
    border: calc(1 / var(--font-size) * 1rem) solid var(--gray-color-200);
    text-align: center;
    font-weight: 500;
    min-width: 6em;
  }
  .c-table-chart-cell--left {
    text-align: left;
  }
  .c-table-chart-cell--line {
    position: relative;
  }
  .c-table-chart-cell--line::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: linear-gradient(to right top, transparent calc(50% - 0.5px), var(--primary-color-100) 50%, var(--primary-color-100) calc(50% + 0.5px), transparent calc(50% + 1px))
  }
  .c-table-chart-cell-vertical{
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  * + .c-table-chart-btn {
    margin-top: calc(6 / var(--font-size) * 1rem);
  }
  .c-table-chart-btn .c-btn__body {
    padding-top: calc(4 / var(--font-size)* 1rem);
    padding-bottom: calc(4 / var(--font-size)* 1rem);
  }
  .c-table-chart-btn .c-btn--disable{
    --btn-bg-color: var(--portal-color-100);
    --btn-border-color: var(--portal-color-100);
  }
  .c-table__footer {
    margin-top: calc(10 / var(--font-size) * 1rem);
  }

  .table-cell-size {
  }
  .table-cell-size--50{
    width: 50%;
  }
  .table-cell-size--l {
    width: calc(300 / var(--font-size) * 1rem);
  }
  .table-cell-size--m {
    width: calc(200 / var(--font-size) * 1rem);
  }
  .table-cell-size--s {
    width: calc(100 / var(--font-size) * 1rem);
  }

  .c-table-chart__thead .c-table-chart-cell .c-txt{
    --txt-font-size: 16;
  }
  .c-table-chart__tbody .c-table-chart-cell .c-txt{
    --txt-font-size: 14;
  }
}
/* ==========================================================================
  PUBLIC TABLE COMPONENT
========================================================================== */
@media all and (min-width: 768px), print {
  .public-table {
    margin-top: calc(20 / var(--font-size) * 1rem);
  }
  .public-table .c-table-chart__thead .c-table-chart-cell {
    text-align-last: center;
    position: relative;
  }
  .public-table .c-table-chart__thead .c-table-chart-cell:not(:last-child):before {
    content: "";
    display: block;
    background: var(--white-color);
    width: calc(1 / var(--font-size) * 1rem);
    /* height: calc(100% - (20 / var(--font-size) * 1rem)); */
    height: 100%;
    position: absolute;
    top: 50%;
    right: calc(-1 / var(--font-size) * 1rem);
    transform: translateY(-50%);
  }
  .public-table th.c-table-chart-cell {
    font-weight: bold;
  }
  .public-table .c-table-chart-cell {
    text-align-last: left;
    text-align: left;
    padding: calc(20 / var(--font-size) * 1rem);
  }
  .public-table .c-table-chart-cell.u-center {
    text-align-last: center;
  }
  .public-btn-note{
    margin-top: calc(4 / var(--font-size) * 1rem);
  }
  .public-btn-note--l{
    margin-left: auto;
    margin-right: auto;
    width: calc(390 / var(--font-size)* 1rem);
  }
  .public-btn-note__thum{
    margin-top: calc(8 / var(--font-size) * 1rem);
  }
  .public-btn-note__unit{

  }
  .public-btn-note__unit+.public-btn-note__unit{
    margin-top: calc(12 / var(--font-size) * 1rem);
  }
  .public-btn-name-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: calc(16 / var(--font-size) * 1rem);
  }
}
@media all and (max-width: 767px) {
  .public-table {
    margin-top: calc(20 / var(--font-size) * 1rem);
  }
  .public-table .c-table-chart__thead .c-table-chart-cell {
    text-align-last: center;
    position: relative;
  }
  .public-table .c-table-chart__thead .c-table-chart-cell:not(:last-child):before {
    content: "";
    display: block;
    background: var(--white-color);
    width: calc(1 / var(--font-size) * 1rem);
    /* height: calc(100% - (20 / var(--font-size) * 1rem)); */
    height: 100%;
    position: absolute;
    top: 50%;
    right: calc(-1 / var(--font-size) * 1rem);
    transform: translateY(-50%);
  }
  .public-table th.c-table-chart-cell {
    font-weight: bold;
  }
  .public-table .c-table-chart-cell {
    text-align-last: left;
    padding: calc(20 / var(--font-size) * 1rem);
  }
  .public-table .c-table-chart-cell.u-center {
    text-align-last: center;
  }
  .public-btn-note{
    margin-top: calc(4 / var(--font-size) * 1rem);
  }
  .public-btn-note--l{
    margin-left: auto;
    margin-right: auto;
    width: calc(390 / var(--font-size)* 1rem);
  }
  .public-btn-note__thum{
    margin-top: calc(8 / var(--font-size) * 1rem);
  }
  .public-btn-note__unit{

  }
  .public-btn-note__unit+.public-btn-note__unit{
    margin-top: calc(12 / var(--font-size) * 1rem);
  }
  .public-btn-name-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: calc(40 / var(--font-size) * 1rem);
  }
  .public-btn-name-container--narrow {
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    gap: calc(8 / var(--font-size) * 1rem);
  }
}

/* --------------------------------------------------------------------------
  narrow table
-------------------------------------------------------------------------- */
@media all and (min-width: 768px), print {
  .narrow-table {
    margin-top: calc(20 / var(--font-size) * 1rem);
  }
  .narrow-table th.c-table-chart-cell {
    font-weight: bold;
  }
  .narrow-table .c-table-chart {
    width: fit-content;
  }
}
@media all and (max-width: 767px) {
  .narrow-table {
    margin-top: calc(20 / var(--font-size) * 1rem);
  }
  .narrow-table th.c-table-chart-cell {
    font-weight: bold;
  }
  .narrow-table .c-table-chart {
    width: calc(600 / var(--font-size) * 1rem);
  }
}
/* ==========================================================================
  IMG SVG COMPONENT
========================================================================== */

/* --------------------------------------------------------------------------
  img
-------------------------------------------------------------------------- */

@media all and (min-width: 768px), print {
  .c-img {
  }
  .c-img__label {
    width: 100%;
  }
  .c-img__caption {
    margin-top: calc(16 / var(--font-size) * 1rem);
  }
}

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

/* --------------------------------------------------------------------------
  svg
-------------------------------------------------------------------------- */

.c-svg {
  position: relative;
  display: block;
  width: 100%;
}

.c-svg::before {
  display: block;
  padding-top: 100%;
  content: '';
}

.c-svg > svg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* --------------------------------------------------------------------------
  STICKY
-------------------------------------------------------------------------- */
@media all and (min-width: 768px), print {
  .sticky-nav {
    position: fixed;
    bottom: calc(170 / var(--font-size) * 1rem);
    right: 0;
    transform: translate(0%, 0%);
    width: 100%;
    max-width: calc(180 / var(--font-size) * 1rem);
    z-index: 100;
  }
  .sticky-nav__item {
    filter:drop-shadow(0px 0px 16px rgba(0, 0, 0, 0.16));
    position: relative;
    background-color: #E85287;
    border-radius: calc(10 / var(--font-size) * 1rem) 0 0 calc(10 / var(--font-size) * 1rem);
    border: calc(2 / var(--font-size) * 1rem) solid var(--white-color);
  }
  .sticky-nav--registration .sticky-nav__item{
    background-color: var(--yellow-color-100);
  }
  .sticky-nav__item__in{
    padding: calc(8 / var(--font-size) * 1rem) calc(16 / var(--font-size) * 1rem) calc(10 / var(--font-size) * 1rem);
  }
  .fixed-bottom-nav__btn{
    display: flex;
    align-items: center;
    gap: calc(8 / var(--font-size) * 1rem);
  }
  .sticky-nav-icon{
    width: calc(40 / var(--font-size) * 1rem);
    aspect-ratio: 1/1;
    background-color: var(--white-color);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }
  .sticky-nav-icon img{
    width: calc(26 / var(--font-size) * 1rem);
  }
  .sticky-nav--registration .sticky-nav-icon img{
    width: calc(22 / var(--font-size) * 1rem);
  }
  .sticky-nav-txt{
  }
  .sticky-nav-txt__label{
    font-weight: bold;
    color: var(--white-color);
    font-size: calc(12 / var(--font-size) * 1rem);
    line-height: 1.5;
  }
  .sticky-nav--registration .sticky-nav-txt__label{
    color: var(--black-color);
  }
  .sticky-nav__item + .sticky-nav__item {
    margin-top: calc(20 / var(--font-size) * 1rem);
  }
  .sticky-close {
    position: absolute;
    left: calc(-8 / var(--font-size) * 1rem);
    top: calc(-8 / var(--font-size) * 1rem);
    max-width: calc(28 / var(--font-size) * 1rem);
    cursor: pointer;
    z-index: 10;
  }
}
@media all and (max-width: 767px) {
  .sticky-nav {
    position: fixed;
    bottom: calc(140 / var(--font-size) * 1rem);
    right: 0;
    transform: translate(0%, 0%);
    width: 100%;
    max-width: calc(168 / var(--font-size) * 1rem);
    z-index: 100;
  }
  .cat-registration-builder .sticky-nav {
    max-width: calc(180 / var(--font-size) * 1rem);
  }
  .sticky-nav__item {
    filter:drop-shadow(0px 0px 16px rgba(0, 0, 0, 0.16));
    position: relative;
    background-color: #E85287;
    border-radius: calc(10 / var(--font-size) * 1rem) 0 0 calc(10 / var(--font-size) * 1rem);
    border: calc(2 / var(--font-size) * 1rem) solid var(--white-color);
  }
  .sticky-nav--registration .sticky-nav__item{
    background-color: var(--yellow-color-100);
  }
  .sticky-nav__item__in{
    padding: calc(8 / var(--font-size) * 1rem) calc(16 / var(--font-size) * 1rem) calc(10 / var(--font-size) * 1rem);
  }
  .fixed-bottom-nav__btn{
    display: flex;
    align-items: center;
    gap: calc(8 / var(--font-size) * 1rem);
  }
  .sticky-nav-icon{
    width: calc(40 / var(--font-size) * 1rem);
    aspect-ratio: 1/1;
    background-color: var(--white-color);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }
  .sticky-nav-icon img{
    width: calc(26 / var(--font-size) * 1rem);
  }
  .sticky-nav--registration .sticky-nav-icon img{
    width: calc(22 / var(--font-size) * 1rem);
  }
  .sticky-nav-txt{
  }
  .sticky-nav-txt__label{
    font-weight: bold;
    color: var(--white-color);
    font-size: calc(12 / var(--font-size) * 1rem);
    line-height: 1.5;
  }
  .sticky-nav--registration .sticky-nav-txt__label{
    color: var(--black-color);
  }
  .sticky-nav__item {
    position: relative;
  }
  .sticky-nav__item + .sticky-nav__item {
    margin-top: calc(20 / var(--font-size) * 1rem);
  }
  .sticky-close {
    position: absolute;
    left: calc(-8 / var(--font-size) * 1rem);
    top: calc(-8 / var(--font-size) * 1rem);
    max-width: calc(28 / var(--font-size) * 1rem);
    cursor: pointer;
    z-index: 10;
  }
}
/* --------------------------------------------------------------------------
  PAGE TOP
-------------------------------------------------------------------------- */
@media all and (min-width: 768px), print {
  .page-top {
    position: relative;
    z-index: 10;
  }
  .page-top__inner {
    position: fixed;
    bottom: calc(84 / var(--font-size) * 1rem);
    right: calc(74 / var(--font-size) * 1rem);
    max-width: calc(60 / var(--font-size)* 1rem);
  }
}
@media all and (max-width: 767px) {
  .page-top {
    position: relative;
    z-index: 10;
  }
  .page-top__inner {
    position: fixed;
    bottom: calc(60 / var(--font-size) * 1rem);
    right: calc(10 / var(--font-size) * 1rem);
    max-width: calc(50 / var(--font-size)* 1rem);
  }
}

/* --------------------------------------------------------------------------
  交付決定
-------------------------------------------------------------------------- */
@media all and (min-width: 768px), print {
  .c-update-date{
    margin-bottom: calc(10 / var(--font-size) * 1rem);
    color: var(--red-color-100);
  }
  .c-line-header {
    --header-font-size: 26;
    --header-ratio: var(--header-font-size) / 26;
    --header-deco-color: var(--primary-color-100);

  }
  .c-line-header__in {
    position: relative;
    display: flex;
    flex-direction: column;
  }

  .c-line-header__in::after {
    background-color: var(--primary-color-100);
    content: '';
    display: block;
    height: 1px;
    width: 100%;
    margin-top: calc(10 / var(--font-size) * 1rem); 
  }
  .c-line-header__body {
    flex-shrink: 0;
  }
  .c-line-header__label {
    font-size: calc(var(--header-font-size) / var(--font-size) * 1rem);
    font-weight: 700;
    line-height: 1.5;
  }
  .c-table-note {
    margin-top:  calc(15 / var(--font-size) * 1rem);
  }
  .c-table-note::before {
    content: "（注）";
  }
}
@media all and (max-width: 767px) {
  .c-update-date{
    margin-bottom: calc(10 / var(--font-size) * 1rem);
    color: var(--red-color-100);
  }
  .c-line-header {
    --header-font-size: 20;
    --header-ratio: var(--header-font-size) / 20;
    --header-deco-color: var(--primary-color-100);

  }
  .c-line-header__in {
    position: relative;
    display: flex;
    flex-direction: column;
  }
  .c-line-header__in::after {
    background-color: var(--primary-color-100);
    content: '';
    display: block;
    height: 1px;
    width: 100%;
    margin-top: calc(11 / var(--font-size) * 1rem); 
  }
  .c-line-header__body {
    flex-shrink: 0;
    max-width: 100%;
  }
  .c-line-header__label {
    font-size: calc(var(--header-font-size) / var(--font-size) * 1rem);
    font-weight: 700;
    line-height: 1.5;
  }
  .c-table-note::before {
    content: "（注）";
  }
}

/* news */
@media all and (min-width: 768px), print {
  .top-news:not(.cat-portal .top-news){
    margin-top: calc(90 / var(--font-size) * 1rem);
  }
  .top-news__body {
    display: flex;
    padding: calc(90 / var(--font-size) * 1rem) 0;
  }
  .top-news__header {
    flex-shrink: 0;
    margin-right: calc(90 / var(--font-size) * 1rem);
    margin-bottom: 0;
  }
  .top-news__header-btn {
    width: calc(140 / var(--font-size) * 1rem);
    margin-top: calc(18 / var(--font-size) * 1rem);
  }
  .top-news__header-title .c-header-title {
    text-align: left;
  }
}
@media all and (max-width: 767px) {
  .top-news:not(.cat-portal .top-news) {
    margin-top: calc(50 / var(--font-size) * 1rem);
  }
  .top-news__body {
    display: flex;
    flex-direction: column;
  }
  .top-news__header-btn {
    width: calc(140 / var(--font-size) * 1rem);
    margin-top: calc(20 / var(--font-size) * 1rem);
  }
  .top-news__header-title .c-header-title {
    text-align: left;
  }
}


/* 余白 */
.u-mt-1{
  margin-top: 1rem;
}
.u-ml-1{
  margin-left: 1rem;
}
.u-pl-1{
  padding-left: 1rem;
}


/* ページ内タブ */
[data-tab-content]{
  display: none
}
[data-tab-content].active{
  display: block;
}
@media all and (min-width: 768px), print {
  .tabs__nav{
  }
  .tabs__item {
    display: block;
    position: relative;
    width: 100%;
    height: auto;
    padding: calc(32 / var(--font-size) * 1rem) calc(var(--tab-px-size) / var(--font-size) * 1rem);
    text-align: center;
    font-size: calc(16 / var(--font-size) * 1rem);
    font-weight: 700;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: 0.3s all;
  }
  .tabs__item::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: calc(100% - calc(30 / var(--font-size) * 1rem) * 2);
    height: calc(6 / var(--font-size) * 1rem);
    margin-left: calc(30 / var(--font-size) * 1rem);
    margin-right: calc(30 / var(--font-size) * 1rem);
    background-color: var(--tab-current-deco-color);
    opacity: 0;
    transition: 0.3s all;
  }
  .tabs__item.active::before {
    opacity: 1;
    transition: 0.3s all;
  }
  .tabs__item.active {
    background: var(--primary-color-10);
    color: var(--tab-current-deco-color);
  }
  .tabs__item:hover::before {
    opacity: 1;
    transition: 0.3s all;
  }
  .tabs__content {
    padding-top: calc(32 / var(--font-size) * 1rem);
  }

  /* もっと見る */
  .more {
    margin: 0 auto;
    box-sizing: border-box;
  }
  .more__content {
    position: relative;
    height: auto;
    max-height: 500px; 
    overflow: hidden;
    transition: max-height 1s;
    margin-bottom: calc(32 / var(--font-size) * 1rem);
  }
  /* コンテンツを隠すグラデーション */
  .more__content::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    display: block;
    width: 100%;
    height: 100%;
    transition: 1s;
    background: linear-gradient(
      to bottom,
      transparent 0%,
      #fff 100%
    );
  }
  /* コンテンツの開閉で追加・削除するクラス */
  .more__content.open:after {
    z-index: -1;
    opacity: 0;
  }
   /* もっと見るボタン */
  .more__btn {
    display: block;
    margin: 0 auto;
    padding: calc(16 / var(--font-size) * 1rem) calc(40 / var(--font-size) * 1rem);
    border: 0;
    color: #fff;
    font-weight: 700;
    background: var(--primary-color-100);
    cursor: pointer;
    transition: all 0.5s;
  }
  .more__btn:hover{
    filter: brightness(1.1);
    transition: all 0.5s;
  }


}
@media all and (max-width: 767px) {
  .tabs__nav{
  }
  .tabs__item {
    display: block;
    position: relative;
    width: 100%;
    height: auto;
    padding: calc(8 / var(--font-size) * 1rem) calc(var(--tab-px-size) / var(--font-size) * 1rem);
    text-align: center;
    font-size: calc(13 / var(--font-size) * 1rem);
    font-weight: 700;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: 0.3s all;
    line-height: calc(21 / 13);
  }
  .tabs__item::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: calc(100% - calc(12 / var(--font-size) * 1rem) * 2);
    height: calc(4 / var(--font-size) * 1rem);
    margin-left: calc(12 / var(--font-size) * 1rem);
    margin-right: calc(12 / var(--font-size) * 1rem);
    background-color: var(--tab-current-deco-color);
    opacity: 0;
    transition: 0.3s all;
  }
  .tabs__item.active::before {
    opacity: 1;
    transition: 0.3s all;
  }
  .tabs__item.active {
    background: var(--primary-color-10);
    color: var(--tab-current-deco-color);
  }
  .tabs__item:hover::before {
    opacity: 1;
    transition: 0.3s all;
  }
  .tabs__content {
    padding-top: calc(32 / var(--font-size) * 1rem);
  }

  /* もっと見る */
  .more {
    margin: 0 auto;
    box-sizing: border-box;
  }
  .more__content {
    position: relative;
    height: auto;
    max-height: 500px; 
    overflow: hidden;
    transition: max-height .7s;
    margin-bottom: calc(32 / var(--font-size) * 1rem);
  }
  /* コンテンツを隠すグラデーション */
  .more__content::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    display: block;
    width: 100%;
    height: 100%;
    transition: .7s;
    background: linear-gradient(
      to bottom,
      transparent 0%,
      #fff 100%
    );
  }
  /* コンテンツの開閉で追加・削除するクラス */
  .more__content.open:after {
    z-index: -1;
    opacity: 0;
  }
   /* もっと見るボタン */
  .more__btn {
    display: block;
    margin: 0 auto;
    padding: calc(10 / var(--font-size) * 1rem) calc(36 / var(--font-size) * 1rem);
    border: 0;
    color: #fff;
    font-size: calc(14 / var(--font-size) * 1rem);
    font-weight: 700;
    background: var(--primary-color-100);
    cursor: pointer;
  }

}


/* ボタン非活性 */
.link-inactive .c-btn {
  --btn-bg-color: var(--gray-color-200) !important;
  --btn-border-color: var(--gray-color-200) !important;
  pointer-events: none !important;
}


/* ヘッダー上お知らせ */
@media all and (min-width: 768px), print {
  .gheader-top-info{
    padding: 0 calc(16 / var(--font-size) * 1rem);
    font-feature-settings: "palt";
  }
  .gheader-top-info__in{
    padding: 0 calc(16 / var(--font-size) * 1rem);
    max-width: calc(1312 / var(--font-size) * 1rem);
    margin: auto;
  }
  .cat-portal .gheader-top-info{
    background: var(--portal-color-100);
  }
  .cat-house .gheader-top-info{
    background: var(--house-color-100);
  }
  .cat-housingcomplex .gheader-top-info{
    background: var(--housingcomplex-color-100);
  }
  .cat-registration .gheader-top-info{
    background: var(--registration-color-100);
  }
  .cat-zehinfo .gheader-top-info{
    background: var(--zehinfo-color-100);
  }
  .gheader-top-info-text{
    text-align: center;
    color: #fff;
  }
  .gheader-top-info.urgent{
    background: var(--red-color-100) !important;
  }
  .gheader-top-info .col--2{
    position: relative;
  }
  .gheader-top-info .col--2::before{
    content: '';
    width: 100vw;
    margin: 0 calc(50% - 50vw);
    height: .5px;
    background: #fff;
    position: absolute;
    top: 0;
    left: 0;
  }

}
@media all and (max-width: 767px) {
  .gheader-top-info{
    padding: 0 calc(16 / var(--font-size) * 1rem);
    font-feature-settings: "palt";
  }
  .cat-portal .gheader-top-info{
    background: var(--portal-color-100);
  }
  .cat-house .gheader-top-info{
    background: var(--house-color-100);
  }
  .cat-housingcomplex .gheader-top-info{
    background: var(--housingcomplex-color-100);
  }
  .cat-registration .gheader-top-info{
    background: var(--registration-color-100);
  }
  .cat-zehinfo .gheader-top-info{
    background: var(--zehinfo-color-100);
  }
  .gheader-top-info-text{
    text-align: center;
    color: #fff;
    font-size: calc(14 / var(--font-size) * 1rem);
  }
  .gheader-top-info.urgent{
    background: var(--red-color-100) !important;
  }
  .gheader-top-info .col--2{
    position: relative;
  }
  .gheader-top-info .col--2::before{
    content: '';
    width: 100vw;
    margin: 0 calc(50% - 50vw);
    height: .5px;
    background: #fff;
    position: absolute;
    top: 0;
    left: 0;
  }
}

/* リンク非活性（アーカイブ） */
.link-inactive{
  pointer-events: none;
  color: var(--black-color) !important;
  --link-txt-color: var(--black-color) !important;
  --btn-bg-color: var(--gray-color-200) !important;
  --btn-border-color: var(--gray-color-200) !important;
  text-decoration: none !important;
}