@media print {
  body {
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
}
html {
  font-size: 62.5%;
  height: 100%;
}
body {
  color: #1a1c21;
  font-size: 1.4rem;
  line-height: 1.8;
  font-family: "Arial", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Meiryo", sans-serif;
  font-weight: normal;
  margin: 0;
  padding: 0;
  position: relative;
  background: #fff;
  letter-spacing: 0.12em;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
}
@media (min-width: 768px) {
  body {
    font-size: 1.6rem;
    line-height: 2;
  }
}
* {
  box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
}
h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
li,
figure {
  margin: 0;
  padding: 0;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: bold;
}
ul,
li {
  list-style: none;
}
input,
textarea,
select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none;
}
a {
  background-color: transparent;
}
a,
a:link,
a:visited {
  outline: none;
  text-decoration: none;
  color: #009ce5;
  cursor: pointer;
}
@media (min-width: 480px) {
  a,
  a:link,
  a:visited {
    transition: all 0.3s ease;
  }
  a:hover,
  a:link:hover,
  a:visited:hover {
    text-decoration: none;
    color: #009ce5;
  }
}
.assistive_text {
  display: none;
}
.supplement {
  color: #979ca1;
  font-size: 1.2rem;
}
@media (min-width: 768px) {
  .supplement {
    font-size: 1.4rem;
  }
}
.link-target {
  position: relative;
  z-index: -1;
  padding-top: 80px;
  margin-top: -80px;
}
@media (min-width: 768px) {
  .link-target {
    padding-top: 120px;
    margin-top: -120px;
  }
}
.se-none {
  display: none !important;
}
@media (min-width: 321px) {
  .se-none {
    display: block !important;
  }
}
.se-none-pc {
  display: none !important;
}
@media (min-width: 321px) {
  .se-none-pc {
    display: block !important;
  }
}
@media (min-width: 768px) {
  .se-none-pc {
    display: none !important;
  }
}
.sp {
  display: block !important;
}
@media (min-width: 480px) {
  .sp {
    display: none !important;
  }
}
.tablet {
  display: block !important;
}
@media (min-width: 768px) {
  .tablet {
    display: none !important;
  }
}
.pc {
  display: none !important;
}
@media (min-width: 768px) {
  .pc {
    display: block !important;
  }
}
.pc-1080 {
  display: none !important;
}
@media (min-width: 1080px) {
  .pc-1080 {
    display: block !important;
  }
}
/* destyle.css v1.0.15 | MIT License | https://github.com/nicolas-cusan/destyle.css */
* {
  box-sizing: border-box;
}
::before,
::after {
  box-sizing: inherit;
}
html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
}
body {
  margin: 0;
}
main {
  display: block;
}
p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  margin: 0;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
  margin: 0;
}
ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
}
dd {
  margin-left: 0;
}
hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
  border: 0;
  border-top: 1px solid;
  margin: 0;
  clear: both;
  color: inherit;
}
pre {
  font-family: monospace, monospace; /* 1 */
  font-size: inherit; /* 2 */
}
address {
  font-style: inherit;
}
a {
  background-color: transparent;
  text-decoration: none;
  color: inherit;
}
abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  text-decoration: underline dotted; /* 2 */
}
b,
strong {
  font-weight: bolder;
}
code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: inherit; /* 2 */
}
small {
  font-size: 80%;
}
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sub {
  bottom: -0.25em;
}
sup {
  top: -0.5em;
}
img {
  border-style: none;
  vertical-align: bottom;
}
embed,
object,
iframe {
  border: 0;
  vertical-align: bottom;
}
button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  border: 0;
  background: transparent;
  padding: 0;
  margin: 0;
  outline: 0;
  border-radius: 0;
  text-align: inherit;
}
[type="checkbox"] {
  -webkit-appearance: checkbox;
  appearance: checkbox;
}
[type="radio"] {
  -webkit-appearance: radio;
  appearance: radio;
}
button,
input {
/* 1 */
  overflow: visible;
}
button,
select {
/* 1 */
  text-transform: none;
}
button,
[type="button"],
[type="reset"],
[type="submit"] {
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
}
button[disabled],
[type="button"][disabled],
[type="reset"][disabled],
[type="submit"][disabled] {
  cursor: default;
}
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}
select::-ms-expand {
  display: none;
}
option {
  padding: 0;
}
fieldset {
  margin: 0;
  padding: 0;
  border: 0;
  min-width: 0;
}
legend {
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}
progress {
  vertical-align: baseline;
}
textarea {
  overflow: auto;
}
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}
[type="search"] {
  outline-offset: -2px; /* 1 */
}
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}
label[for] {
  cursor: pointer;
}
details {
  display: block;
}
summary {
  display: list-item;
}
[contenteditable] {
  outline: none;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
caption {
  text-align: left;
}
td,
th {
  vertical-align: top;
  padding: 0;
}
th {
  text-align: left;
  font-weight: bold;
}
template {
  display: none;
}
[hidden] {
  display: none;
}
.page-influenza_a1 .l-footer {
  background: #005bac;
}
.page-influenza_a1 .l-footer__links {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px 0;
  border-bottom: 1px solid #fff;
}
@media (max-width: 1079px) {
  .page-influenza_a1 .l-footer__links {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
    padding: 32px;
    border-bottom: 1px solid #fff;
  }
}
.page-influenza_a1 .l-footer__link {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #fff;
  font-size: 1.4rem;
  line-height: 1;
  letter-spacing: 1.68px;
  white-space: nowrap;
  text-decoration: none;
  padding: 0 32px;
  border-left: 1px solid #979ca1;
}
.page-influenza_a1 .l-footer__link:first-child {
  border-left: none;
}
@media (max-width: 1079px) {
  .page-influenza_a1 .l-footer__link {
    font-size: 1.2rem;
    letter-spacing: 1.44px;
    padding: 0;
    border-left: none;
  }
}
@media (max-width: 1079px) {
  .page-influenza_a1 .l-footer__link:before {
    content: '';
    display: block;
    width: 12px;
    height: 12px;
    background: url("/common/img/icon/icon_link_arrow_white.svg") center center no-repeat;
    background-size: contain;
    flex-shrink: 0;
  }
}
.page-influenza_a1 .l-footer__link:hover {
  text-decoration: underline;
}
.page-influenza_a1 .l-footer__logo-area--sp {
  display: none;
}
@media (max-width: 1079px) {
  .page-influenza_a1 .l-footer__logo-area--sp {
    display: flex;
    flex-direction: column;
    padding: 16px 16px 18.5px 16px;
    background: linear-gradient(90deg, #00b3fe 0%, #039 100%);
    position: relative;
    overflow: hidden;
  }
}
@media (max-width: 1079px) {
  .page-influenza_a1 .l-footer__logo-area--sp:after {
    position: absolute;
    bottom: 0;
    right: -4px;
    content: '';
    width: 91px;
    height: 24px;
    background: url("../../../common/img/footer/footer_bland_2.png") no-repeat;
    background-size: contain;
  }
}
.page-influenza_a1 .l-footer__logo-first--sp {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.page-influenza_a1 .l-footer__logo-company {
  width: 160px;
  height: 18px;
}
@media (max-width: 1079px) {
  .page-influenza_a1 .l-footer__logo-company {
    width: 104px;
    height: 11px;
  }
}
.page-influenza_a1 .l-footer__logo-catch {
  width: 200px;
  height: 19px;
}
@media (max-width: 1079px) {
  .page-influenza_a1 .l-footer__logo-catch {
    width: 140px;
    height: 14px;
  }
}
.page-influenza_a1 .l-footer__logo-copy {
  color: #fff;
  font-size: 12px;
  line-height: 18px;
  letter-spacing: 1px;
}
@media (max-width: 1079px) {
  .page-influenza_a1 .l-footer__logo-copy {
    color: #fff;
    text-align: right;
    font-size: 10.5px;
    font-weight: 400;
    line-height: 11px;
  }
}
.page-influenza_a1 .l-footer__logo-area--pc {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 19px 116px 19px 120px;
  background: linear-gradient(90deg, #00b3fe 0%, #039 100%);
  position: relative;
  overflow: hidden;
}
@media (max-width: 1079px) {
  .page-influenza_a1 .l-footer__logo-area--pc {
    display: none;
  }
}
.page-influenza_a1 .l-footer__logo-area--pc:after {
  position: absolute;
  bottom: 0;
  right: -4px;
  content: '';
  width: 116px;
  height: 32px;
  background: url("../../../common/img/footer/footer_bland_2.png") no-repeat;
  background-size: contain;
}
.page-influenza_a1 .l-footer__logo-second {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}
.l-footer {
  z-index: 3;
  background: #393939;
}
.l-footer__contact {
  padding: 40px 32px;
  background: #000;
  color: #fff;
  text-align: center;
}
@media (min-width: 768px) {
  .l-footer__contact {
    padding: 48px 120px 56px;
  }
}
.l-footer__contact-intro {
  padding-bottom: 24px;
  font-size: 1.6rem;
}
@media (min-width: 768px) {
  .l-footer__contact-intro {
    font-size: 1.8rem;
  }
}
.l-footer__contact-btn-wrap {
  gap: 24px;
}
@media (min-width: 768px) {
  .l-footer__contact-btn-wrap {
    max-width: 686px;
    margin: 0 auto;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    height: 88px;
  }
}
@media (min-width: 1080px) {
  .l-footer__contact-btn-wrap {
    max-width: 726px;
    gap: 80px;
  }
}
.l-footer__contact-btn-wrap--sp {
  display: grid;
}
@media (min-width: 480px) {
  .l-footer__contact-btn-wrap--sp {
    display: none;
  }
}
.l-footer__contact-btn-wrap--pc {
  display: none;
}
@media (min-width: 480px) {
  .l-footer__contact-btn-wrap--pc {
    display: grid;
  }
}
.l-footer__list {
  padding: 32px 24px;
  border-bottom: 1px solid #9babc0;
  margin: 0 24px;
}
@media (min-width: 321px) {
  .l-footer__list {
    padding: 32px;
  }
}
@media (min-width: 768px) {
  .l-footer__list {
    padding: 16px 24px;
    text-align: center;
    margin: 0 48px;
  }
}
.l-footer__item {
  padding-bottom: 16px;
}
.l-footer__item:last-child {
  padding-bottom: 0;
}
@media (min-width: 768px) {
  .l-footer__item {
    display: inline-block;
    padding: 0;
    border-right: 1px solid #9babc0;
  }
  .l-footer__item:last-child {
    border: none;
  }
}
.l-footer__item a {
  display: block;
  color: #fff;
  position: relative;
  padding-left: 20px;
  font-size: 1.2rem;
  line-height: 1.2;
}
@media (min-width: 768px) {
  .l-footer__item a {
    padding-left: 16px;
    padding-right: 16px;
    font-size: 1.4rem;
  }
}
.l-footer__item a:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 14px;
  height: 14px;
  margin: auto;
  background: url("/common/img/icon/icon_link_arrow_white.svg") center center no-repeat;
  background-size: contain;
}
@media (min-width: 768px) {
  .l-footer__item a:before {
    background: none;
  }
}
.l-footer__item a:hover {
  color: #fff;
  text-decoration: underline;
}
.l-footer__logo-area-inner {
  background: #393939;
  padding: 32px 14px 32px 14px;
  display: grid;
  gap: 16px;
}
@media (min-width: 768px) {
  .l-footer__logo-area-inner {
    padding: 28px 48px;
    max-width: 1920px;
    margin: 0 auto;
  }
}
.l-footer__logo {
  margin: 0 auto;
  width: 192px;
  height: 25px;
  grid-column: 1/3;
}
@media (min-width: 768px) {
  .l-footer__logo {
    margin: 0;
    grid-column: 1/2;
    width: 193px;
    height: 100%;
    grid-row: 1/3;
    display: flex;
    align-items: center;
  }
}
.l-footer__logo img {
  vertical-align: top;
  width: 100%;
}
.l-footer__catch {
  grid-column: 1/3;
  grid-row: 1;
  width: 160px;
  height: 22px;
  display: block;
  margin: 0 auto;
}
@media (min-width: 768px) {
  .l-footer__catch {
    grid-column: 2/3;
    width: 201px;
    height: 22px;
    margin: 0 0 0 auto;
  }
}
.l-footer__catch img {
  width: 100%;
  vertical-align: top;
}
.l-footer__copyright {
  grid-column: 1/3;
  display: block;
  margin: 4px 0 1px;
  font-size: 1.2rem;
  text-align: center;
  color: #fff;
  line-height: 1.1;
  margin-top: 12px;
}
@media (min-width: 768px) {
  .l-footer__copyright {
    text-align: right;
    margin-top: 2px;
    grid-column: 2/3;
  }
}
.l-header {
  background: #fff;
  z-index: 4;
}
.l-header__gradation {
  height: 11px;
  background: background linear-gradient(90deg, #00b3fe, #039);
  display: flex;
  justify-content: flex-end;
}
@media (min-width: 1080px) {
  .l-header__gradation {
    height: 15px;
  }
}
.l-header__gradation img {
  height: 11px;
  width: auto;
}
@media (min-width: 1080px) {
  .l-header__gradation img {
    height: 15px;
  }
}
.l-header__inner {
  padding: 13px 10px;
  display: flex;
  justify-content: center;
}
@media (min-width: 1080px) {
  .l-header__inner {
    justify-content: space-between;
    padding: 13px 16px;
    max-width: 1920px;
    margin: 0 auto;
  }
}
@media (min-width: 1320px) {
  .l-header__inner {
    padding: 13px 32px;
  }
}
.l-header__inner.claim {
  padding: 0;
}
@media (min-width: 1080px) {
  .l-header__inner.claim {
    padding: 0 16px;
  }
}
.l-header__inner.claim .header-title img {
  height: 20px;
  padding-left: 12px;
}
@media (min-width: 321px) {
  .l-header__inner.claim .header-title img {
    height: 24px;
  }
}
@media (min-width: 1080px) {
  .l-header__inner.claim .header-title img {
    height: 32px;
  }
}
.l-header__infomation {
  display: none;
}
@media (min-width: 1080px) {
  .l-header__infomation {
    display: flex;
    align-items: center;
    gap: 8px;
  }
}
@media (min-width: 1320px) {
  .l-header__infomation {
    gap: 16px;
  }
}
.l-header__infomation-link {
  text-align: left;
  display: block;
  margin-right: 8px;
}
@media (min-width: 1320px) {
  .l-header__infomation-link {
    display: flex;
  }
}
.header-title {
  display: flex;
  align-items: center;
}
.header-title a {
  display: block;
}
.header-title img {
  height: 22px;
  width: auto;
}
@media (min-width: 321px) {
  .header-title img {
    height: 25px;
  }
}
@media (min-width: 1080px) {
  .header-title img {
    height: 32px;
    width: auto;
  }
}
.header-link {
  margin: 0;
  display: flex;
  align-items: center;
  flex-shrink: 0;
  gap: 4px;
  color: #1a1c21;
  font-size: 1.2rem;
}
@media (min-width: 1320px) {
  .header-link {
    margin-left: 16px;
  }
  .header-link:first-child {
    margin-left: 0;
  }
}
.header-link,
.header-link:link,
.header-link:visited {
  color: #1a1c21;
}
.header-link:hover,
.header-link:link:hover,
.header-link:visited:hover {
  color: #1a1c21;
  text-decoration: underline;
}
.header-link img {
  width: 12px;
  height: 12px;
}
.header-menu {
  position: sticky;
  position: -webkit-sticky;
  top: 0;
  left: 0;
  right: 0;
  height: 58px;
  width: 100%;
  z-index: 4;
  margin: 0 auto;
  background: #000;
}
@media (min-width: 768px) {
  .header-menu {
    height: 64px;
  }
}
@media (min-width: 1080px) {
  .header-menu {
    height: 80px;
  }
}
.header-menu.claim {
  position: relative;
  background: #005bac;
  width: auto;
  left: auto;
  margin-right: 0;
}
.header-menu__wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 100%;
}
@media (min-width: 1080px) {
  .header-menu__wrap {
    max-width: 1920px;
    margin: 0 auto;
  }
}
.header-menu.top {
  transition: all 0.3s ease;
}
.header-menu.top .nav__item--contact {
  width: auto;
  flex-grow: 1;
  transform: translateX(0px);
  transition: all 0.2s ease;
}
.header-nav-wrap {
  width: 40%;
  min-width: 260px;
}
@media (min-width: 321px) {
  .header-nav-wrap {
    min-width: 280px;
  }
}
@media (min-width: 1080px) {
  .header-nav-wrap {
    width: 100%;
    height: 100%;
  }
}
.header-nav-wrap--sp {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  padding-right: 8px;
}
@media (min-width: 1080px) {
  .header-nav-wrap--sp {
    display: none;
  }
}
.header-nav-wrap--pc {
  display: none;
}
@media (min-width: 768px) {
  .header-nav-wrap--pc {
    display: block;
  }
}
.nav {
  display: none;
  width: 100%;
  height: 100%;
}
@media (min-width: 1080px) {
  .nav {
    display: block;
    margin-left: auto;
  }
}
.nav__list {
  display: flex;
  gap: 0 16px;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.nav__item {
  text-align: center;
  flex-grow: 1;
}
.nav__item a {
  height: 100%;
  font-size: 1.5rem;
  font-weight: bold;
  color: #fff;
}
.nav__item a,
.nav__item a:link,
.nav__item a:visited {
  color: #fff;
}
.nav__item a:hover {
  color: #fff;
}
.nav__item--contact {
  width: 0;
  flex-grow: 0;
  transform: translateX(300px);
  transition: all 0.2s ease;
}
.nav__item--contact a:hover {
  opacity: 0.8;
}
.nav__item--current a {
  position: relative;
}
.nav__item--current a:after {
  content: '';
  background: #fff;
  height: 2px;
  width: 48px;
  position: absolute;
  bottom: 14px;
  left: 0;
  right: 0;
  margin: auto;
}
.nav__link {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding-bottom: 8px;
  height: 100%;
}
.nav__link:hover {
  background: #1c1c1c;
}
.nav__link img {
  height: 10px;
}
.nav__link-policy img {
  height: 14px;
}
.menu-trigger,
.menu-trigger span {
  display: inline-block;
  transition: all 0.4s;
}
.menu-trigger {
  display: block;
  position: relative;
  width: 48px;
  height: 48px;
  cursor: pointer;
  margin: 0 1px 0 0;
  z-index: 1000;
}
@media (min-width: 321px) {
  .menu-trigger {
    margin: 0 1px 0 5px;
  }
}
@media (min-width: 1080px) {
  .menu-trigger {
    display: none;
  }
}
.menu-trigger span {
  position: absolute;
  left: 15px;
  height: 2px;
  background-color: #fff;
}
.menu-trigger span:nth-of-type(1) {
  top: 10px;
  width: 16px;
}
.menu-trigger span:nth-of-type(2) {
  top: 16.5px;
  width: 16px;
}
.menu-trigger span:nth-of-type(3) {
  bottom: 23px;
  width: 16px;
}
.menu-trigger p {
  position: absolute;
  bottom: 1px;
  left: 0;
  font-size: 0.9rem;
  font-weight: bold;
  color: #fff;
  width: 100%;
  text-align: center;
}
.menu-trigger.open span {
  left: 13px;
}
.menu-trigger.open span:nth-of-type(1) {
  transform: translateY(20px) rotate(-45deg);
  top: -3px;
  width: 20px;
}
.menu-trigger.open span:nth-of-type(2) {
  opacity: 0;
}
.menu-trigger.open span:nth-of-type(3) {
  transform: translateY(-20px) rotate(45deg);
  width: 20px;
  bottom: 9px;
}
.l-drawer {
  display: none;
  position: absolute;
  z-index: 9999;
  background: #000;
  width: 100%;
  height: 0;
  opacity: 0;
}
@media (min-width: 1080px) {
  .l-drawer {
    display: none;
  }
}
.l-drawer.show {
  display: block;
  height: 100vh !important;
  overflow: scroll;
  animation: fade-in 0.5s ease 0s 1 normal;
  animation-fill-mode: forwards;
}
@media (min-width: 1080px) {
  .l-drawer.show {
    display: none;
  }
}
.l-drawer.hide {
  animation: fade-out 0.5s ease 0s 1 normal;
  animation-fill-mode: forwards;
}
.l-drawer.claim {
  top: 69px;
  background: #fff;
}
.l-drawer.claim .drawer__top-menu {
  padding: 0;
}
.l-drawer.claim .drawer__item {
  padding: 20px 16px;
  border-bottom: 1px solid #dbdee3;
}
.l-drawer.claim .drawer__item a {
  color: #009ce5;
}
.l-drawer.claim .drawer__item a,
.l-drawer.claim .drawer__item a:link,
.l-drawer.claim .drawer__item a:visited {
  color: #009ce5;
}
.drawer__top-menu {
  padding: 20px 6vw 24px;
}
@media (min-width: 768px) {
  .drawer__top-menu {
    padding: 20px 6vw 32px;
  }
}
.drawer__bottom-menu {
  padding: 24px 6vw 120px;
}
@media (min-width: 768px) {
  .drawer__bottom-menu {
    padding: 32px 6vw 160px;
  }
}
.drawer__title {
  position: absolute;
  right: 6vw;
  top: -12px;
  font-weight: 500;
}
.drawer__title span {
  color: #009ce5;
  font-weight: bold;
}
.drawer__item {
  font-size: 1.4rem;
  padding-bottom: 3.2vh;
}
@media (min-width: 768px) {
  .drawer__item {
    padding-bottom: 32px;
  }
}
.drawer__item:last-child {
  padding-bottom: 0;
}
.drawer__item a {
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: flex-start;
  color: #fff;
}
.drawer__item a,
.drawer__item a:link,
.drawer__item a:visited {
  color: #fff;
}
.drawer__item a:hover,
.drawer__item a:link:hover,
.drawer__item a:visited:hover {
  opacity: 0.8;
  text-decoration: none;
  color: #fff;
}
.drawer__item span {
  font-size: 1.5rem;
  font-weight: bold;
}
.drawer__item img {
  height: 11px;
}
.drawer__item img.top-page {
  height: 13px;
}
.drawer__item--insurance-policy img {
  height: 14px;
}
.drawer__item--contact a {
  align-items: center;
  font-size: 1.5rem;
  height: 52px;
  margin-top: 16px;
}
.drawer__item--external-link a {
  position: relative;
  flex-direction: row;
  align-items: center;
  padding: 0;
  gap: 8px;
  line-height: 1;
}
.drawer__item--external-link a img {
  height: 12px;
}
@-moz-keyframes fade-in {
  0% {
    height: 0;
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  99% {
    height: 100vh;
  }
  100% {
    height: 100vh;
    opacity: 1;
  }
}
@-webkit-keyframes fade-in {
  0% {
    height: 0;
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  99% {
    height: 100vh;
  }
  100% {
    height: 100vh;
    opacity: 1;
  }
}
@-o-keyframes fade-in {
  0% {
    height: 0;
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  99% {
    height: 100vh;
  }
  100% {
    height: 100vh;
    opacity: 1;
  }
}
@keyframes fade-in {
  0% {
    height: 0;
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  99% {
    height: 100vh;
  }
  100% {
    height: 100vh;
    opacity: 1;
  }
}
@-moz-keyframes fade-out {
  0% {
    height: 100vh;
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
  99% {
    height: 100vh;
    opacity: 0;
  }
  100% {
    height: 0;
    opacity: 0;
  }
}
@-webkit-keyframes fade-out {
  0% {
    height: 100vh;
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
  99% {
    height: 100vh;
    opacity: 0;
  }
  100% {
    height: 0;
    opacity: 0;
  }
}
@-o-keyframes fade-out {
  0% {
    height: 100vh;
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
  99% {
    height: 100vh;
    opacity: 0;
  }
  100% {
    height: 0;
    opacity: 0;
  }
}
@keyframes fade-out {
  0% {
    height: 100vh;
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
  99% {
    height: 100vh;
    opacity: 0;
  }
  100% {
    height: 0;
    opacity: 0;
  }
}
.l-body {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
.l-wrap {
  flex-grow: 1;
}
.l-content--top,
.l-content--service {
  overflow-x: hidden;
}
.l-page-content {
  background: #fff;
  position: relative;
}
.l-page-content:before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 0 64px 100vw;
  border-color: transparent transparent #fff transparent;
  position: absolute;
  top: -64px;
}
@media (min-width: 768px) {
  .l-page-content:before {
    border-width: 0 0 160px 100vw;
    top: -160px;
  }
}
@media (min-width: 1080px) {
  .l-page-content:before {
    border-width: 0 0 280px 100vw;
    top: -280px;
  }
}
.l-page-content__inner {
  padding: 32px 4.27vw 128px;
  max-width: 1160px;
  margin: 0 auto;
}
@media (min-width: 768px) {
  .l-page-content__inner {
    padding: 48px 12vw 184px;
  }
}
@media (min-width: 1080px) {
  .l-page-content__inner {
    padding: 48px 40px 184px;
  }
}
.l-page-content__inner--small {
  max-width: 1000px;
  margin: 0 auto;
}
@media (min-width: 1080px) {
  .l-page-content__inner--two-column {
    display: flex;
    justify-content: space-between;
  }
}
.l-page-content__inner--service {
  padding-left: 0;
  padding-right: 0;
  overflow: hidden;
}
@media (min-width: 768px) {
  .l-page-content__inner--service {
    padding-left: 0;
    padding-right: 0;
  }
}
@media (min-width: 1080px) {
  .l-page-content__inner--service {
    overflow: visible;
  }
}
.l-page-content__inner--process {
  padding-left: 0;
  padding-right: 0;
}
@media (min-width: 768px) {
  .l-page-content__inner--process {
    padding-top: 24px;
  }
}
@media (min-width: 1080px) {
  .l-page-content__inner--process {
    padding-top: 8px;
  }
}
@media (min-width: 1080px) {
  .l-page-content__main {
    width: calc(100% - (50px + 280px));
  }
}
.l-page-content__sub-column {
  margin-top: 80px;
}
@media (min-width: 1080px) {
  .l-page-content__sub-column {
    margin-top: 0;
    width: 280px;
    flex-shrink: 0;
  }
}
.l-hero {
  background: #000;
  min-height: 148px;
}
@media (min-width: 768px) {
  .l-hero {
    min-height: 280px;
  }
}
.l-hero__inner {
  padding: 28px 4.27vw 84px;
  max-width: 1160px;
  margin: 0 auto;
}
@media (min-width: 768px) {
  .l-hero__inner {
    padding: 22px 4.27vw 168px;
  }
}
@media (min-width: 1080px) {
  .l-hero__inner {
    padding: 22px 40px 168px;
  }
}
.l-breadcrumb--sp {
  display: block;
  border-top: 1px solid #dbdee3;
}
@media (min-width: 768px) {
  .l-breadcrumb--sp {
    display: none;
  }
}
.l-breadcrumb--pc {
  display: none;
}
@media (min-width: 768px) {
  .l-breadcrumb--pc {
    display: block;
    background: #000;
  }
}
.l-error-content__inner {
  display: flex;
  flex-direction: column;
  padding: 48px 4.27vw 128px;
  max-width: 1080px;
  margin: 0 auto;
  text-align: center;
}
@media (min-width: 768px) {
  .l-error-content__inner {
    padding: 80px 4.27vw 184px;
  }
}
@media (min-width: 1080px) {
  .l-error-content__inner {
    padding: 120px 0 184px;
  }
}
.l-error-content .btn {
  margin-top: 40px;
}
@media (min-width: 768px) {
  .l-error-content .btn {
    margin-top: 48px;
  }
}
.l-error-content p {
  padding-bottom: 16px;
}
.l-error-content p:last-child {
  padding: 0;
}
.l-pagetop {
  position: sticky;
  position: -webkit-sticky;
  bottom: 24px;
  width: 56px;
  height: 56px;
  margin-left: auto;
  margin-top: -80px;
  margin-bottom: 24px;
  margin-right: 16px;
  z-index: 3;
}
@media (min-width: 768px) {
  .l-pagetop {
    bottom: 40px;
    width: 64px;
    height: 64px;
    margin-right: 40px;
    margin-top: -96px;
    margin-bottom: 32px;
  }
}
.index {
  padding: 24px 4.27vw;
  max-width: 1080px;
  margin: 0 auto;
}
@media (min-width: 768px) {
  .index {
    padding: 48px 4.27vw;
  }
}
@media (min-width: 1080px) {
  .index {
    padding: 48px 0;
  }
}
.index__list dt {
  margin-top: 16px;
}
.index__list dt:before {
  content: "";
  background: #1a1c21;
  width: 6px;
  height: 6px;
  display: inline-block;
  vertical-align: middle;
  border-radius: 50%;
  margin-right: 4px;
}
.accordion__box,
.accordion__content {
  display: flex;
  align-items: flex-start;
}
.accordion__box img,
.accordion__content img {
  flex-shrink: 0;
}
@media (min-width: 768px) {
  .accordion__box img,
  .accordion__content img {
    width: 20px;
  }
}
.accordion__box a:hover,
.accordion__content a:hover {
  text-decoration: underline;
}
.accordion__box {
  cursor: pointer;
  padding: 16px 48px 16px 16px;
  border-bottom: 1px solid #dbdee3;
  position: relative;
  z-index: 1;
}
@media (min-width: 768px) {
  .accordion__box {
    padding: 32px 64px 32px 32px;
  }
}
.accordion__box:first-of-type {
  border-top: 1px solid #dbdee3;
}
.accordion__box:after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 16px;
  margin: auto;
  width: 16px;
  height: 16px;
  background: url("/common/img/icon/icon_link_arrow.svg") center center no-repeat;
  background-size: cover;
  transform: rotate(90deg);
  transition: all 0.3s ease;
}
@media (min-width: 768px) {
  .accordion__box:after {
    right: 32px;
  }
}
.accordion__box:hover {
  opacity: 0.8;
  background: rgba(242,243,245,0.6);
  transition: all 0.3s ease;
}
.accordion__box.open:after {
  transform: rotate(-90deg);
  transition: all 0.3s ease;
}
.accordion__box span {
  flex-grow: 1;
}
.accordion__box img,
.accordion__box b {
  margin-right: 16px;
}
@media (min-width: 768px) {
  .accordion__box img,
  .accordion__box b {
    margin-right: 32px;
  }
}
.accordion__box b {
  flex-shrink: 0;
}
.accordion__content {
  display: none;
  width: 100%;
  overflow: hidden;
  background: #f2f3f5;
  padding: 16px;
}
@media (min-width: 768px) {
  .accordion__content {
    padding: 32px;
  }
}
.accordion__content--intro {
  padding: 16px;
  background: #fff;
}
.accordion__content--section {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  padding-bottom: 32px;
}
@media (min-width: 768px) {
  .accordion__content--section {
    padding-bottom: 40px;
  }
}
.accordion__content--section:last-child {
  padding-bottom: 0;
}
.accordion__content--section table {
  background: #fff;
}
.accordion__content--title {
  font-weight: bold;
  font-size: 2rem;
}
@media (min-width: 768px) {
  .accordion__content--title {
    font-size: 2.2rem;
  }
}
.toggle {
  display: none;
}
.accordion-customer .link-pdf {
  display: inline !important;
}
.banner-box {
  margin-top: 40px;
}
@media (min-width: 768px) {
  .banner-box {
    margin-top: 80px;
  }
}
.banner-box a {
  display: block;
  padding: 24px;
  background: #fff;
  color: #1a1c21;
  border: 1px solid #dbdee3;
  text-align: center;
}
@media (min-width: 768px) {
  .banner-box a {
    padding: 40px;
  }
}
.banner-box a:hover,
.banner-box a:link:hover,
.banner-box a:visited:hover {
  color: #1a1c21;
  background: #f2f3f5;
  text-decoration: none;
}
@media (min-width: 768px) {
  .banner-box__title-box {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 24px;
  }
}
.banner-box__logo {
  display: block;
  width: 100px;
  margin: 0 auto 16px;
}
@media (min-width: 768px) {
  .banner-box__logo {
    margin: 0;
  }
}
.banner-box__title {
  font-weight: bold;
  font-size: 1.6rem;
  display: inline-block;
  padding-right: 20px;
  position: relative;
  margin-bottom: 16px;
}
@media (min-width: 768px) {
  .banner-box__title {
    margin-bottom: 0;
    font-size: 2rem;
    padding-left: 80px;
    padding-right: 24px;
  }
}
.banner-box__title:before,
.banner-box__title:after {
  content: "";
  position: absolute;
}
@media (min-width: 768px) {
  .banner-box__title:before {
    left: 40px;
    width: 1px;
    height: 100%;
    background: #dbdee3;
  }
}
.banner-box__title:after {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  background: url("/common/img/icon/icon_window.svg") right center no-repeat;
  width: 16px;
  height: 16px;
  background-size: 16px 16px;
  flex-shrink: 0;
}
.breadcrumb {
  max-width: 1160px;
  margin: 0 auto;
  padding: 10px 4.27vw;
  position: relative;
  z-index: 1;
}
@media (min-width: 768px) {
  .breadcrumb {
    padding: 22px 4.27vw 0;
  }
}
@media (min-width: 1080px) {
  .breadcrumb {
    padding: 22px 40px 0;
  }
}
.breadcrumb__list {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
.breadcrumb__item {
  font-size: 1.2rem;
  position: relative;
  margin: 2px 0;
  display: flex;
  align-items: flex-start;
  color: #1a1c21;
}
@media (min-width: 768px) {
  .breadcrumb__item {
    margin: 4px 0;
    font-size: 1.4rem;
    color: #fff;
    align-items: center;
  }
}
.breadcrumb__item:before {
  content: "";
  display: block;
  background: url("/common/img/icon/icon_link_arrow_grey.svg") center center no-repeat;
  width: 16px;
  height: 16px;
  background-size: 16px 16px;
  flex-shrink: 0;
  margin: 2px 4px 0;
}
@media (min-width: 768px) {
  .breadcrumb__item:before {
    margin: 0 6px;
  }
}
.breadcrumb__item:first-child:before {
  content: none;
}
.breadcrumb__item a {
  display: block;
  color: #1a1c21;
}
@media (min-width: 768px) {
  .breadcrumb__item a {
    color: #fff;
  }
}
.breadcrumb__item a,
.breadcrumb__item a:link,
.breadcrumb__item a:visited {
  color: #1a1c21;
}
@media (min-width: 768px) {
  .breadcrumb__item a,
  .breadcrumb__item a:link,
  .breadcrumb__item a:visited {
    color: #fff;
  }
}
.breadcrumb__item a:hover,
.breadcrumb__item a:link:hover,
.breadcrumb__item a:visited:hover {
  text-decoration: underline;
}
.btn {
  width: 100%;
}
@media (min-width: 480px) {
  .btn {
    transition: all 0.3s ease;
  }
}
.btn,
.btn:link,
.btn:visited {
  color: #fff;
  text-decoration: none;
}
.btn:hover,
.btn:link:hover,
.btn:visited:hover {
  opacity: 0.8;
  text-decoration: none;
  color: #fff;
}
.btn--main {
  min-height: 52px;
  padding: 8px 16px;
  margin: 40px auto 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: 1.6rem;
  font-weight: bold;
  background: #000;
  box-shadow: 0 8px 20px rgba(0,0,0,0.16);
  max-width: 540px;
}
@media (min-width: 768px) {
  .btn--main {
    min-height: 72px;
    font-size: 1.8rem;
    box-shadow: 0 10px 30px rgba(0,0,0,0.16);
    margin: 80px auto 0;
  }
}
.btn--small {
  font-size: 1.4rem;
  margin: 24px auto 0;
}
@media (min-width: 768px) {
  .btn--small {
    min-height: 56px;
    font-size: 1.6rem;
    max-width: 248px;
    margin: 0;
  }
}
.btn--medium {
  font-size: 1.6rem;
  margin: 16px auto 0;
}
@media (min-width: 768px) {
  .btn--medium {
    min-height: 56px;
    max-width: 360px;
    margin: 0;
  }
}
.btn--medium-wide {
  font-size: 1.6rem;
  margin: 16px auto 0;
}
@media (min-width: 768px) {
  .btn--medium-wide {
    min-height: 56px;
    max-width: 540px;
    margin: 0;
  }
}
.btn--top-pickup {
  margin-top: 40px;
}
@media (min-width: 768px) {
  .btn--top-pickup {
    margin-top: 104px;
  }
}
.btn--site-policy {
  border: none !important;
  padding: 8px 16px !important;
  font-size: 1.6rem !important;
  transition: all 0.3s ease !important;
  line-height: 1.8 !important;
  letter-spacing: 0.12em !important;
}
.btn--site-policy:after {
  content: "";
  display: block;
  background: url("/common/img/icon/icon_window_white.svg") center center no-repeat;
  width: 16px;
  height: 16px;
  background-size: 16px 16px;
  flex-shrink: 0;
}
.btn--site-policy,
.btn--site-policy:link,
.btn--site-policy:visited {
  color: #fff !important;
  text-decoration: none !important;
}
.btn--site-policy:hover,
.btn--site-policy:link:hover,
.btn--site-policy:visited:hover {
  opacity: 0.8 !important;
  text-decoration: none !important;
  color: #fff !important;
  background: #000 !important;
}
.btn--pagetop {
  width: 100%;
  height: 100%;
  display: block;
  background: #000;
  box-shadow: 0 8px 20px rgba(0,0,0,0.16);
  background: #000 url("/common/img/icon/icon_pagetop.svg") top 8px center no-repeat;
  text-align: center;
}
@media (min-width: 768px) {
  .btn--pagetop {
    background-position: top 12px center;
  }
}
.btn--pagetop span,
.btn--pagetop:link span,
.btn--pagetop:visited span {
  color: #fff;
}
.btn--pagetop span {
  display: block;
  padding-top: 24px;
}
@media (min-width: 768px) {
  .btn--pagetop span {
    padding-top: 28px;
  }
}
.btn--error {
  margin: 16px auto 0;
}
@media (min-width: 768px) {
  .btn--error {
    margin: 24px auto 0;
  }
}
.btn-rainbow,
.btn-blue,
.btn-border {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 64px;
  font-size: 1.6rem;
  font-weight: bold;
}
.btn-rainbow {
  color: #fff;
  background: linear-gradient(106deg, #79c5ff 5%, #65aeff 15%, #687cff 35%, #c464f1 50%, #ff6d64 70%, #ff9b52 85%, #fab87a 95%);
}
.btn-rainbow,
.btn-rainbow:link,
.btn-rainbow:visited {
  color: #fff;
}
.btn-rainbow:hover,
.btn-rainbow:link:hover,
.btn-rainbow:visited:hover {
  color: #fff;
}
@media (min-width: 768px) {
  .btn-rainbow {
    max-width: 323px;
    font-size: 1.8rem;
  }
}
.btn-rainbow--01 {
  background: linear-gradient(106deg, #79c5ff 5%, #65aeff 20%, #687cff 50%, #c464f1 80%, #e369a7 95%);
}
.btn-rainbow--02 {
  background: linear-gradient(106deg, #9970f8 5%, #c464f1 20%, #ff6d64 50%, #ff9b52 80%, #fab87a 95%);
}
.btn-blue {
  background: #005bac;
  color: #fff;
}
.btn-blue,
.btn-blue:link,
.btn-blue:visited {
  color: #fff;
}
.btn-blue:hover,
.btn-blue:link:hover,
.btn-blue:visited:hover {
  color: #fff;
  opacity: 0.8;
}
.btn-border {
  background: #fff;
  color: #005bac;
}
@media (min-width: 1080px) {
  .btn-border {
    border: 3px solid #005bac;
  }
}
.btn-border,
.btn-border:link,
.btn-border:visited {
  color: #005bac;
}
.btn-border:hover,
.btn-border:link:hover,
.btn-border:visited:hover {
  color: #005bac;
  opacity: 0.8;
}
.btn-header {
  min-height: 42px;
  width: 100%;
  font-size: 1.1rem;
  padding: 8px 2px;
  gap: 2px;
}
@media (min-width: 321px) {
  .btn-header {
    padding: 8px;
    gap: 6px;
  }
}
.btn-header img {
  width: 12px;
  height: 12px;
}
@media (min-width: 321px) {
  .btn-header img {
    width: 14px;
    height: 14px;
  }
}
.btn-header-info {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  height: 38px;
  width: 150px;
  min-height: 0;
  font-size: 1.2rem;
}
.btn-header-info img {
  width: 12px;
  height: 12px;
}
.btn-header-info--inquiry {
  width: 114px;
}
@media (min-width: 1320px) {
  .btn-header-info--inquiry {
    width: 150px;
  }
}
.btn-header-insurance {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  height: 38px;
  width: 150px;
  background: #005bac;
  color: #fff;
  font-size: 1.25rem;
}
.btn-header-insurance,
.btn-header-insurance:link,
.btn-header-insurance:visited {
  color: #fff;
}
.btn-header-insurance:hover,
.btn-header-insurance:link:hover,
.btn-header-insurance:visited:hover {
  color: #fff;
  background: rgba(232,0,61,0.1);
  opacity: 0.8;
}
.btn-header-insurance img {
  width: 12px;
  height: 12px;
}
.btn-header-insurance--inquiry {
  width: 114px;
}
@media (min-width: 1320px) {
  .btn-header-insurance--inquiry {
    width: 150px;
  }
}
.btn-footer {
  min-height: 64px;
  font-size: 1.5rem;
}
.btn-wrap--policy {
  margin-top: 16px;
}
body.no-scroll {
  overflow: hidden;
}
.claim .l-page-content {
  padding: 24px 4.27vw;
  background: none;
}
@media (min-width: 1080px) {
  .claim .l-page-content {
    padding: 0 40px 80px;
    max-width: 1160px;
    margin: 0 auto;
  }
}
.claim .l-page-content:before {
  border: none;
  top: 0;
  left: 0;
}
.claim--hero {
  padding: 24px 4.27vw;
  position: relative;
  z-index: 3;
}
@media (min-width: 1080px) {
  .claim--hero {
    padding: 80px 40px;
    max-width: 1160px;
    margin: 0 auto;
  }
}
.claim--hero a:hover {
  text-decoration: underline;
}
.claim--hero-lead {
  color: #1a1c21;
}
.claim--hero-title,
.claim--sub-title,
.claim--service-title {
  font-weight: bold;
  letter-spacing: 0.2em;
}
.claim--hero-title {
  font-size: 2.4rem;
  margin-bottom: 12px;
}
@media (min-width: 768px) {
  .claim--hero-title {
    font-size: 4.8rem;
  }
}
.claim--sub-title {
  font-size: 2.4rem;
  margin-bottom: 16px;
}
@media (min-width: 768px) {
  .claim--sub-title {
    font-size: 4rem;
    margin-bottom: 24px;
  }
}
.claim--service-title {
  font-size: 1.7rem;
}
@media (min-width: 768px) {
  .claim--service-title {
    font-size: 1.8rem;
  }
}
.claim--content {
  margin-bottom: 56px;
}
@media (min-width: 768px) {
  .claim--content {
    margin-bottom: 120px;
  }
}
.claim--service-block-wrap {
  display: grid;
  gap: 48px;
  margin-top: 24px;
}
@media (min-width: 768px) {
  .claim--service-block-wrap {
    gap: 64px;
    margin-top: 32px;
    grid-template-columns: 1fr 1fr;
  }
}
.claim .full {
  grid-column: 1/-1;
}
.claim--service-block {
  width: 100%;
}
.claim--service-list {
  background: #f8f9fd;
  border-radius: 4px;
  margin-top: 12px;
  overflow: hidden;
}
@media (min-width: 768px) {
  .claim--service-list {
    margin-top: 16px;
    border-radius: 8px;
  }
}
.claim--service-list li:last-child a:after {
  background: none;
}
.claim--service-list a {
  position: relative;
  color: #6b7075;
  font-weight: bold;
  display: block;
  padding: 16px;
  padding-right: 42px;
  background: url("/common/img/icon/icon_window_green.svg") center right 18px no-repeat;
  background-size: 14px 14px;
}
@media (min-width: 768px) {
  .claim--service-list a {
    background-position: center right 20px;
    background-size: 16px 16px;
    padding-right: 48px;
  }
}
.claim--service-list a:hover {
  color: #629d9e;
  background-color: #f2f3f5;
}
.claim--service-list a:after {
  content: '';
  position: absolute;
  right: 16px;
  left: 16px;
  bottom: 0;
  height: 1px;
  width: calc(100% - 32px);
  background: #dbdee3;
}
a.upload {
  border: 1px solid #629d9e;
  color: #629d9e;
  font-weight: bold;
  display: inline-block;
  padding: 16px;
  border-radius: 4px;
  margin-top: 24px;
}
a.upload:hover {
  background: #629d9e;
  color: #fff;
}
.tab--list {
  list-style-type: none;
  padding: 0;
  display: flex;
  gap: 8px;
  border-bottom: 2px solid #629d9e;
}
@media (min-width: 768px) {
  .tab--list {
    gap: 24px;
    border-width: 3px;
  }
}
.tab--item {
  padding: 10px 16px;
  text-align: center;
  cursor: pointer;
  background-color: #f0f0f0;
  width: 100%;
  max-width: 280px;
  border-radius: 4px 4px 0 0;
}
@media (min-width: 768px) {
  .tab--item {
    font-size: 2rem;
    padding: 16px;
    border-radius: 8px 8px 0 0;
  }
}
.tab--item:hover {
  background-color: rgba(98,157,158,0.2);
  transition: all 0.3s ease;
}
.tab--item.active {
  background-color: #629d9e;
  color: #fff;
  font-weight: bold;
}
.tab--content {
  display: none;
  border-left: 1px solid #ddd;
  border-right: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
  padding: 8px 18px 24px;
}
@media (min-width: 768px) {
  .tab--content {
    padding: 16px 48px 64px;
  }
}
.tab--content.active {
  display: block !important;
}
.popup {
  display: none;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0,0.5);
  z-index: 1000;
}
.popup.active {
  display: flex;
}
.popup--trigger {
  cursor: pointer;
}
.popup--trigger img {
  width: 20px;
  height: 20px;
  vertical-align: text-top;
  margin-left: 2px;
}
.popup--close {
  cursor: pointer;
  position: absolute;
  top: -40px;
  right: 0;
  width: 32px;
  height: 32px;
  background: url("/common/img/icon/icon_close_white.svg") center center no-repeat;
  background-size: cover;
}
.popup--title {
  font-size: 1.6rem;
  padding-bottom: 4px;
}
@media (min-width: 768px) {
  .popup--title {
    font-size: 1.8rem;
    padding-bottom: 8px;
  }
}
.popup--content {
  position: relative;
  background: #fff;
  margin: 50px auto 30px;
  height: auto;
  width: 90%;
  max-height: 84vh;
  max-width: 600px;
  align-self: center;
  word-break: break-all;
}
.popup--content-inner {
  max-height: 84vh;
  overflow-y: scroll;
  padding: 24px;
}
@media (min-width: 768px) {
  .popup--content-inner {
    padding: 40px 48px;
    max-height: 84vh;
  }
}
.popup--content-inner ul {
  margin: 8px 0;
}
.popup--content-inner ul li {
  position: relative;
  padding-left: 12px;
  padding-bottom: 2px;
}
@media (min-width: 768px) {
  .popup--content-inner ul li {
    padding-left: 16px;
    padding-bottom: 4px;
  }
}
.popup--content-inner ul li:last-child {
  padding-bottom: 0;
}
.popup--content-inner ul li:before {
  content: '';
  position: absolute;
  left: 0;
  top: 12px;
  width: 4px;
  height: 4px;
  background: #979ca1;
}
@media (min-width: 768px) {
  .popup--content-inner ul li:before {
    top: 14px;
  }
}
.popup--content-inner ol {
  margin: 8px 0;
}
.popup--content-inner ol > li {
  position: relative;
  padding-left: 20px;
  padding-bottom: 2px;
}
@media (min-width: 768px) {
  .popup--content-inner ol > li {
    padding-left: 24px;
    padding-bottom: 4px;
  }
}
.popup--content-inner ol > li:before {
  position: absolute;
  top: 0;
  left: 0;
  width: auto;
  height: auto;
  background: none;
}
.popup--content-inner ol > li:first-child:before {
  content: "①";
}
.popup--content-inner ol > li:nth-child(2):before {
  content: "②";
}
.popup--content-inner ol > li:nth-child(3):before {
  content: "③";
}
.popup--content-inner ol > li:nth-child(4):before {
  content: "④";
}
.popup--content-inner ol > li:nth-child(5):before {
  content: "⑤";
}
.popup--content-inner ol > li:nth-child(6):before {
  content: "⑥";
}
.popup--content-inner ol > li:nth-child(7):before {
  content: "⑦";
}
.popup--content-inner ol > li:nth-child(8):before {
  content: "⑧";
}
.popup--content-inner ol > li:nth-child(9):before {
  content: "⑨";
}
.popup--content-inner ol > li:nth-child(10):before {
  content: "⑩";
}
.popup--content-inner ol > li:nth-child(11):before {
  content: "⑪";
}
.popup--content-inner ol > li:nth-child(12):before {
  content: "⑫";
}
.popup--content-inner ol > li:nth-child(13):before {
  content: "⑬";
}
.popup--content-inner ol > li:nth-child(14):before {
  content: "⑭";
}
.popup--content-inner ol > li:nth-child(15):before {
  content: "⑮";
}
.popup--content-inner ol > li:nth-child(16):before {
  content: "⑯";
}
.popup--content-inner ol > li:nth-child(17):before {
  content: "⑰";
}
.popup--content-inner ol > li:nth-child(18):before {
  content: "⑱";
}
.popup--content-inner ol > li:nth-child(19):before {
  content: "⑲";
}
.popup--content-inner ol > li:nth-child(20):before {
  content: "⑳";
}
.popup--content-inner a:hover {
  text-decoration: underline;
}
.popup--content-inner table {
  margin-top: 4px;
}
@media (min-width: 768px) {
  .popup--content-inner table {
    margin-top: 8px;
  }
}
.popup--content-inner table th,
.popup--content-inner table td {
  border-collapse: collapse;
  border: 1px solid #dbdee3;
  font-weight: normal;
  padding: 8px;
}
@media (min-width: 768px) {
  .popup--content-inner table th,
  .popup--content-inner table td {
    padding: 16px;
  }
}
.popup--content-inner table th {
  background: #f2f3f5;
}
.popup--content-inner table tbody th {
  min-width: 92px;
}
@media (min-width: 768px) {
  .popup--content-inner table tbody th {
    min-width: 120px;
  }
}
.company ul {
  padding-top: 2px;
}
.company ul li {
  position: relative;
  z-index: 2;
  position: relative;
  padding-left: 20px;
  padding-bottom: 2px;
}
@media (min-width: 768px) {
  .company ul li {
    padding-left: 24px;
    padding-bottom: 4px;
  }
}
.company ul li:last-child {
  padding-bottom: 0;
}
.company ul li:before {
  content: '';
  position: absolute;
  left: 8px;
  top: 12px;
  width: 4px;
  height: 4px;
  background: #979ca1;
}
@media (min-width: 768px) {
  .company ul li:before {
    top: 14px;
  }
}
.company__menu-box {
  position: relative;
  margin-bottom: 32px;
}
@media (min-width: 1080px) {
  .company__menu-box {
    display: none;
  }
}
.company__menu-box:after {
  content: "";
  display: block;
  position: absolute;
  top: 17px;
  right: 17px;
  transform: rotate(90deg);
  background: url("/common/img/icon/icon_link_arrow.svg") center center no-repeat;
  background-size: 16px 16px;
  width: 16px;
  height: 16px;
  pointer-events: none;
}
.company__menu-box select {
  display: block;
  width: 100%;
  height: 50px;
  line-height: 42px;
  padding: 0 40px 0 16px;
  border: 2px solid #000;
  color: #1a1c21;
  font-size: 1.6rem;
  letter-spacing: 0.12em;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.company__description {
  margin-top: 56px;
}
@media (min-width: 1080px) {
  .company__description {
    margin-top: 80px;
  }
}
.company__box-wrap {
  margin-top: 24px;
}
@media (min-width: 768px) {
  .company__box-wrap {
    margin-top: 40px;
  }
}
.company__box {
  border: 1px solid #000;
  padding: 20px 4.27vw;
  text-align: center;
  position: relative;
  margin-top: 56px;
}
.company__box:first-child {
  margin-top: 0;
}
@media (min-width: 1080px) {
  .company__box {
    margin-top: 80px;
    padding: 32px 40px;
  }
}
.company__box:after {
  content: "";
  display: block;
  width: 100%;
  height: 56px;
  clip-path: polygon(0 0, 100% 0, 88% 100%, 12% 100%);
  background: linear-gradient(110.8deg, #a8faff 2.55%, #65aeff 27.42%, #687cff 40.61%, #c464f1 52.29%, #ff6d64 64.47%, #ff9b52 76.65%, #eff0c4 100%);
  opacity: 0.24;
  position: absolute;
  bottom: -57px;
  left: 0;
}
@media (min-width: 1080px) {
  .company__box:after {
    height: 80px;
    bottom: -81px;
  }
}
.company__box:last-child:after {
  display: none;
}
.company__text {
  margin-top: 16px;
  font-size: 1.2rem;
}
@media (min-width: 321px) {
  .company__text {
    font-size: 1.4rem;
  }
}
@media (min-width: 768px) {
  .company__text {
    font-size: 1.8rem;
  }
}
.company__text span.strong {
  font-weight: bold;
}
@media (min-width: 1080px) {
  .company__about-list {
    display: flex;
    flex-wrap: wrap;
  }
}
.company__about-list dt {
  margin-top: 24px;
  font-weight: bold;
  font-size: 1.6rem;
}
@media (min-width: 1080px) {
  .company__about-list dt {
    width: 124px;
    flex-shrink: 0;
    margin-right: 40px;
    margin-top: 32px;
  }
}
.company__about-list dd {
  margin-top: 8px;
}
@media (min-width: 1080px) {
  .company__about-list dd {
    width: calc(100% - (124px + 40px));
    margin-top: 32px;
  }
}
.company__about-list dd p {
  margin-top: 8px;
}
@media (min-width: 1080px) {
  .company__about-list dd p {
    margin-top: 0;
  }
}
.company__about-list dd p:first-child {
  margin-top: 0;
}
.company__about-list dd b {
  display: block;
  margin-top: 12px;
}
.company__about-list dd a:hover {
  text-decoration: underline;
}
.company__message .right {
  text-align: right;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.company__message .right span.name {
  display: inline-block;
  width: 102px;
  margin-left: 16px;
}
@media (min-width: 768px) {
  .company__message .right span.name {
    width: 112px;
    margin-left: 24px;
  }
}
.company__message .right span.name img {
  display: block;
  width: 100%;
}
.company__message-section {
  padding-bottom: 32px;
}
@media (min-width: 768px) {
  .company__message-section {
    padding-bottom: 48px;
  }
}
.company__message-section > * {
  padding-bottom: 24px;
}
@media (min-width: 768px) {
  .company__message-section > * {
    padding-bottom: 40px;
  }
}
.company__message-section > *:last-child {
  padding-bottom: 0;
}
.company__message-section img {
  max-width: 100%;
}
.company__message-section .supplement {
  color: #979ca1;
  font-size: 1.2rem;
}
@media (min-width: 768px) {
  .company__message-section .supplement {
    font-size: 1.4rem;
  }
}
.company__philosophy-section {
  padding: 32px 24px;
  border: 6px solid #b2e9ff;
  border-image: linear-gradient(to right, #b2e9ff 0%, #9aa2fe 25%, #ffa090 50%, #f8e1bc 100%);
  border-image-slice: 1;
}
@media (min-width: 768px) {
  .company__philosophy-section {
    padding: 40px 32px;
  }
}
@media (min-width: 1080px) {
  .company__philosophy-section {
    padding: 56px 64px;
  }
}
.company__philosophy-text-box {
  margin-top: 56px;
}
.company__philosophy-text-box:first-child {
  margin-top: 0;
}
@media (min-width: 1080px) {
  .company__philosophy-text-box {
    margin-top: 104px;
  }
}
.company__philosophy-text {
  font-size: 1.6rem;
  text-align: center;
  line-height: 2;
}
.company__philosophy-text:before {
  content: "";
  width: 38px;
  height: 28px;
  display: block;
  margin: 0 auto 12px;
}
.company__philosophy-text--01:before {
  background: url("/common/img/company/number_01.svg") center top no-repeat;
  background-size: 38px 28px;
}
.company__philosophy-text--02:before {
  background: url("/common/img/company/number_02.svg") center top no-repeat;
  background-size: 38px 28px;
}
.company__philosophy-text--03:before {
  background: url("/common/img/company/number_03.svg") center top no-repeat;
  background-size: 38px 28px;
}
.company__philosophy-text--04:before {
  background: url("/common/img/company/number_04.svg") center top no-repeat;
  background-size: 38px 28px;
}
.company__philosophy-text--05:before {
  background: url("/common/img/company/number_05.svg") center top no-repeat;
  background-size: 38px 28px;
}
.company__philosophy-text--06:before {
  background: url("/common/img/company/number_06.svg") center top no-repeat;
  background-size: 38px 28px;
}
@media (min-width: 768px) {
  .company__philosophy-text {
    text-align: left;
    display: flex;
    align-items: center;
  }
  .company__philosophy-text:before {
    width: 52px;
    height: 40px;
    flex-shrink: 0;
    margin: 0 40px 0 0;
  }
  .company__philosophy-text--01:before {
    background: url("/common/img/company/number_01.svg") left top no-repeat;
    background-size: 52px 40px;
  }
  .company__philosophy-text--02:before {
    background: url("/common/img/company/number_02.svg") left top no-repeat;
    background-size: 52px 40px;
  }
  .company__philosophy-text--03:before {
    background: url("/common/img/company/number_03.svg") left top no-repeat;
    background-size: 52px 40px;
  }
  .company__philosophy-text--04:before {
    background: url("/common/img/company/number_04.svg") left top no-repeat;
    background-size: 52px 40px;
  }
  .company__philosophy-text--05:before {
    background: url("/common/img/company/number_05.svg") left top no-repeat;
    background-size: 52px 40px;
  }
  .company__philosophy-text--06:before {
    background: url("/common/img/company/number_06.svg") left top no-repeat;
    background-size: 52px 40px;
  }
}
@media (min-width: 1080px) {
  .company__philosophy-text {
    font-size: 1.8rem;
  }
}
.company__financial-section {
  padding-bottom: 80px;
}
@media (min-width: 768px) {
  .company__financial-section {
    padding-bottom: 120px;
  }
}
.company__financial-section:last-child {
  padding-bottom: 0;
}
.company .financial__list {
  border-top: 1px solid #dbdee3;
}
.company .financial__disclosure {
  width: 100%;
}
.company .financial__disclosure p {
  color: #979ca1;
  font-size: 1.3rem;
  padding-top: 12px;
  margin-left: 20px;
}
@media (min-width: 1080px) {
  .company .financial__disclosure p {
    font-size: 1.5rem;
    margin-left: 32px;
    padding-bottom: 12px;
  }
}
.company .financial__item {
  padding: 0;
}
.company .financial__item:before {
  background: none;
  width: 0;
  height: 0;
}
.company .financial__item.disclosure {
  display: flex;
  flex-direction: column;
  padding: 20px 0 12px;
  border-bottom: 1px solid #dbdee3;
}
@media (min-width: 768px) {
  .company .financial__item.disclosure {
    padding: 32px 0 32px 16px;
  }
}
@media (min-width: 1080px) {
  .company .financial__item.disclosure {
    flex-direction: row;
    padding: 16px 0 16px 32px;
  }
}
.company .financial__item.disclosure a {
  border: none;
  padding: 20px 40px 20px 20px;
}
@media (min-width: 768px) {
  .company .financial__item.disclosure a {
    padding: 20px;
  }
}
@media (min-width: 1080px) {
  .company .financial__item.disclosure a {
    padding: 24px 0;
  }
}
.company .financial__item.disclosure .financial__title {
  margin-top: 0;
}
.company .financial__item.disclosure .financial__date {
  margin-left: 20px;
}
@media (min-width: 1080px) {
  .company .financial__item.disclosure .financial__date {
    flex-shrink: 0;
    margin-left: 0;
    padding-top: 26px;
  }
}
.company .financial__item a {
  display: block;
  padding: 20px 40px 20px 20px;
  border-bottom: 1px solid #dbdee3;
  color: #1a1c21;
  position: relative;
}
@media (min-width: 768px) {
  .company .financial__item a {
    padding: 32px 72px 32px 32px;
  }
}
@media (min-width: 1080px) {
  .company .financial__item a {
    display: flex;
    align-items: center;
    padding: 32px 80px 32px 32px;
  }
}
.company .financial__item a:after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 12px;
  margin: auto;
  width: 16px;
  height: 16px;
  background: url("/common/img/icon/icon_link_arrow.svg") center center no-repeat;
  background-size: cover;
}
@media (min-width: 768px) {
  .company .financial__item a:after {
    right: 32px;
  }
}
.company .financial__item a:hover,
.company .financial__item a:link:hover,
.company .financial__item a:visited:hover {
  color: #1a1c21;
  background: #f2f3f5;
  text-decoration: none;
}
.company .financial__item a.link-external-news:after {
  content: '';
  background: url("/common/img/icon/icon_window.svg") center center no-repeat;
  width: 20px;
  height: 20px;
}
.company .financial__item a.pdf:after {
  content: '';
  background: url("/common/img/icon/icon_download_black.svg") center center no-repeat;
  width: 20px;
  height: 20px;
}
.company .financial__date {
  font-size: 1.3rem;
  color: #979ca1;
}
@media (min-width: 768px) {
  .company .financial__date {
    font-size: 1.5rem;
    width: 122px;
  }
}
.company .financial__title {
  font-size: 1.4rem;
  margin-top: 8px;
}
@media (min-width: 1080px) {
  .company .financial__title {
    font-size: 1.6rem;
    margin-top: 0;
    margin-left: 32px;
  }
}
.company .history__list {
  border-top: 1px solid #dbdee3;
}
.company .history__item {
  display: block;
  padding: 20px;
  border-bottom: 1px solid #dbdee3;
  color: #1a1c21;
}
@media (min-width: 768px) {
  .company .history__item {
    display: flex;
    align-items: center;
    padding: 32px;
  }
}
.company .history__item:before {
  background: none;
  width: 0;
  height: 0;
}
.company .history__item:last-child {
  padding-bottom: 20px;
}
@media (min-width: 768px) {
  .company .history__item:last-child {
    padding-bottom: 32px;
  }
}
.company .history__date {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 1.3rem;
  color: #979ca1;
}
@media (min-width: 768px) {
  .company .history__date {
    font-size: 1.5rem;
    flex-shrink: 0;
    justify-content: flex-end;
  }
}
.company .history__title {
  font-size: 1.4rem;
  margin-top: 8px;
}
@media (min-width: 768px) {
  .company .history__title {
    font-size: 1.6rem;
    margin-top: 0;
    margin-left: 32px;
  }
}
.company__compliance .right {
  text-align: right;
}
.company__compliance a {
  color: #009ce5;
  text-decoration: underline;
  cursor: pointer;
}
@media (min-width: 1080px) {
  .company__compliance a {
    text-decoration: none;
  }
}
.company__compliance a:hover {
  text-decoration: underline;
}
.company__compliance dl dt {
  font-weight: bold;
  font-size: 2rem;
  padding-bottom: 16px;
}
@media (min-width: 768px) {
  .company__compliance dl dt {
    font-size: 2.4rem;
  }
}
.company__compliance dl dt span {
  font-weight: normal;
  font-size: 1.4rem;
}
@media (min-width: 768px) {
  .company__compliance dl dt span {
    font-size: 1.6rem;
  }
}
.company__compliance dl dd {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  padding-bottom: 32px;
}
@media (min-width: 768px) {
  .company__compliance dl dd {
    padding-bottom: 40px;
  }
}
.company__compliance ol > li {
  list-style-type: none;
  padding-left: 32px;
  padding-bottom: 8px;
  position: relative;
  counter-increment: section;
}
@media (min-width: 768px) {
  .company__compliance ol > li {
    padding-left: 40px;
  }
}
.company__compliance ol > li:last-child {
  padding-bottom: 0;
}
.company__compliance ol > li:before {
  position: absolute;
  left: 0;
  content: "1-" counter(section) ". ";
  font-weight: bold;
}
.company__compliance .dl-1 > li:before {
  content: "1-" counter(section) ". ";
}
.company__compliance .dl-2 > li:before {
  content: "2-" counter(section) ". ";
}
.company__compliance .dl-3 > li:before {
  content: "3-" counter(section) ". ";
}
.company__compliance .dl-4 > li:before {
  content: "4-" counter(section) ". ";
}
.company__compliance .dl-4 > li p,
.company__compliance .dl-4 > li a {
  padding-top: 4px;
}
.company__compliance .dl-4 > li ul {
  padding: 8px 0;
}
@media (min-width: 768px) {
  .company__compliance .dl-4 > li ul {
    padding: 12px 0;
  }
}
.company .compliance__section {
  padding-bottom: 80px;
}
@media (min-width: 768px) {
  .company .compliance__section {
    padding-bottom: 120px;
  }
}
.company .compliance__section:last-child {
  padding-bottom: 0;
}
.company .compliance__summary {
  padding-bottom: 32px;
}
@media (min-width: 768px) {
  .company .compliance__summary {
    padding-bottom: 40px;
  }
}
.company .compliance__btn-box {
  margin-top: 16px;
}
.company .compliance__sub-text {
  font-size: 1.2rem;
  color: #6b7075;
  margin-top: 16px;
}
@media (min-width: 768px) {
  .company .compliance__sub-text {
    font-size: 1.4rem;
  }
}
.company__organization .right {
  text-align: right;
}
.company__organization img {
  display: block;
  width: 100%;
  max-width: 400px;
  margin: 0 auto 40px;
}
@media (min-width: 768px) {
  .company__organization img {
    max-width: 640px;
    margin-bottom: 80px;
  }
}
@media (min-width: 1080px) {
  .company__organization img {
    max-width: 750px;
    padding: 0 40px;
  }
}
.contact__category {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding-bottom: 80px;
}
@media (min-width: 768px) {
  .contact__category {
    gap: 24px;
    padding-bottom: 120px;
  }
}
.contact__category:last-child {
  padding-bottom: 0;
}
.contact__handicapped {
  margin-top: 32px;
  width: 100%;
}
.contact__handicapped--title {
  font-weight: bold;
  font-size: 1.8rem;
  margin-bottom: 16px;
}
@media (min-width: 768px) {
  .contact__handicapped--title {
    font-size: 2rem;
  }
}
.contact__handicapped ul li {
  position: relative;
  padding-left: 20px;
  margin-bottom: 8px;
}
@media (min-width: 768px) {
  .contact__handicapped ul li {
    padding-left: 24px;
    margin-bottom: 12px;
  }
}
.contact__handicapped ul li:last-child {
  margin-bottom: 0;
}
.contact__handicapped ul li:before {
  content: '' !important;
  position: absolute;
  left: 8px;
  top: 12px;
  width: 4px;
  height: 4px;
  background: #979ca1;
}
@media (min-width: 768px) {
  .contact__handicapped ul li:before {
    top: 14px;
  }
}
.fadein {
  transform: translateY(80px);
  opacity: 0;
}
.anime_out {
  transform: translateY(0);
  opacity: 1;
}
@media (min-width: 768px) {
  .anime_out {
    transform: translateY(80px);
    opacity: 0;
  }
}
.scrollin {
  animation-name: fadeup;
  animation-fill-mode: forwards;
  animation-duration: 1s;
  position: relative;
  z-index: 2;
}
@media (min-width: 768px) {
  .anime_in {
    animation-name: fadeup;
    animation-fill-mode: forwards;
    animation-duration: 1s;
  }
}
.page-scrollin {
  position: relative;
  animation-name: fadeinpage;
  animation-fill-mode: forwards;
  animation-duration: 0.8s;
}
@-moz-keyframes fadeup {
  0% {
    opacity: 0;
    transform: translateY(80px);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}
@-webkit-keyframes fadeup {
  0% {
    opacity: 0;
    transform: translateY(80px);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}
@-o-keyframes fadeup {
  0% {
    opacity: 0;
    transform: translateY(80px);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}
@keyframes fadeup {
  0% {
    opacity: 0;
    transform: translateY(80px);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}
@-moz-keyframes fadeinpage {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes fadeinpage {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-o-keyframes fadeinpage {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadeinpage {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@media (min-width: 1080px) {
  .faq--page {
    display: flex;
    flex-direction: row-reverse;
  }
}
.faq__list-box-wrap {
  display: grid;
  grid-template-columns: 1fr;
  grid-row-gap: 32px;
  padding-bottom: 48px;
}
@media (min-width: 768px) {
  .faq__list-box-wrap {
    grid-template-columns: 1fr 1fr;
    grid-column-gap: 56px;
    grid-row-gap: 80px;
  }
}
@media (min-width: 1080px) {
  .faq__list-box-wrap {
    grid-template-columns: 1fr 1fr 1fr;
    padding-bottom: 64px;
  }
}
.faq__list-box-wrap--nav {
  margin-top: 48px;
}
@media (min-width: 768px) {
  .faq__list-box-wrap--nav {
    display: grid;
    grid-template-columns: 1fr;
    grid-row-gap: 48px;
  }
}
@media (min-width: 1080px) {
  .faq__list-box-wrap--nav {
    display: block;
    margin-top: 0;
    margin-right: 50px;
    width: 280px;
    flex-shrink: 0;
  }
}
@media (min-width: 1080px) {
  .faq__list-box-wrap--nav .faq__list-box {
    margin-top: 48px;
  }
  .faq__list-box-wrap--nav .faq__list-box:first-child {
    margin-top: 0;
  }
}
@media (min-width: 768px) {
  .faq__list-box-wrap--nav .faq__list {
    padding-left: 16px;
  }
}
.faq__list {
  padding-left: 16px;
}
@media (min-width: 1080px) {
  .faq__list {
    padding-left: 24px;
  }
}
.faq__item {
  margin-top: 8px;
}
.faq__item:first-child {
  margin-top: 0;
}
.faq__item--current span {
  font-weight: bold;
  display: block;
  font-size: 1.5rem;
  min-height: 40px;
  border-left: 5px solid #000;
  padding: 6px 0 6px 20px;
  display: flex;
  align-items: center;
}
@media (min-width: 768px) {
  .faq__item--current span {
    font-size: 1.6rem;
  }
}
.faq__item a {
  min-height: 40px;
  border-left: 5px solid #f2f3f5;
  padding: 6px 0 6px 20px;
  display: flex;
  align-items: center;
  color: #1a1c21;
}
.faq__item a:hover,
.faq__item a:link:hover,
.faq__item a:visited:hover {
  color: #1a1c21;
  background: #f2f3f5;
  text-decoration: none;
}
.faq__item a span {
  display: flex;
  align-items: center;
  font-size: 1.5rem;
}
@media (min-width: 768px) {
  .faq__item a span {
    font-size: 1.6rem;
  }
}
.faq__item a span:after {
  content: "";
  display: block;
  background: url("/common/img/icon/icon_link_arrow.svg") center center no-repeat;
  background-size: 16px 16px;
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  margin-left: 8px;
}
.faq__number {
  margin-top: 24px;
  text-align: right;
}
@media (min-width: 768px) {
  .faq__number {
    margin-top: 32px;
  }
}
.faq__text {
  margin-top: 24px;
}
@media (min-width: 768px) {
  .faq__text {
    margin-top: 40px;
  }
}
.faq__box-wrap {
  border-top: 1px solid #dbdee3;
}
.faq__box-title {
  font-weight: bold;
  margin: 40px 0 8px;
}
.faq__box-title:first-child {
  margin-top: 0;
}
@media (min-width: 768px) {
  .faq__box-title {
    margin: 48px 0 16px;
  }
}
.faq__box {
  padding-top: 80px;
  margin-top: -80px;
}
@media (min-width: 768px) {
  .faq__box {
    padding-top: 120px;
    margin-top: -120px;
  }
}
.faq__box .question {
  border-bottom: 1px solid #dbdee3;
  cursor: pointer;
  display: block;
  width: 100%;
  height: 100%;
  padding: 16px 48px 16px 16px;
  position: relative;
  z-index: 1;
}
@media (min-width: 768px) {
  .faq__box .question {
    padding: 32px 64px 32px 32px;
  }
}
.faq__box .question:after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 16px;
  margin: auto;
  width: 16px;
  height: 16px;
  background: url("/common/img/icon/icon_link_arrow.svg") center center no-repeat;
  background-size: cover;
  transform: rotate(90deg);
  transition: all 0.3s ease;
}
@media (min-width: 768px) {
  .faq__box .question:after {
    right: 32px;
  }
}
.faq__box .question:hover {
  opacity: 0.8;
  background: rgba(242,243,245,0.6);
  transition: all 0.3s ease;
}
.faq__box .question span {
  display: flex;
}
.faq__box .question span:before {
  content: "";
  display: block;
  background: url("/common/img/icon/icon_faq_q.svg") center center no-repeat;
  background-size: 16px 25px;
  width: 16px;
  height: 25px;
  margin-right: 16px;
  flex-shrink: 0;
}
@media (min-width: 768px) {
  .faq__box .question span:before {
    background: url("/common/img/icon/icon_faq_q.svg") center center no-repeat;
    background-size: 20px 32px;
    width: 20px;
    height: 32px;
    margin-right: 32px;
  }
}
.faq__box .question.open:after {
  transform: rotate(-90deg);
  transition: all 0.3s ease;
}
.faq__box .answer {
  background: #f2f3f5;
  border-bottom: 1px solid #dbdee3;
  display: none;
}
.faq__box .answer__box {
  display: flex;
  padding: 16px;
}
@media (min-width: 768px) {
  .faq__box .answer__box {
    padding: 32px;
  }
}
.faq__box .answer__box:before {
  content: "";
  display: block;
  background: url("/common/img/icon/icon_faq_a.svg") center center no-repeat;
  background-size: 16px 25px;
  width: 16px;
  height: 25px;
  margin-right: 16px;
  flex-shrink: 0;
}
@media (min-width: 768px) {
  .faq__box .answer__box:before {
    background: url("/common/img/icon/icon_faq_a.svg") center center no-repeat;
    background-size: 20px 32px;
    width: 20px;
    height: 32px;
    margin-right: 32px;
  }
}
.faq__box .answer__box .right {
  text-align: right;
  padding-right: 1em;
}
@media (min-width: 768px) {
  .faq__box .answer__box .right {
    padding-right: 2em;
  }
}
.faq__box .answer__box-inner {
  word-break: break-all;
}
.faq__box .answer__box-inner ul {
  margin: 8px 0;
}
.faq__box .answer__box-inner ul li {
  position: relative;
  padding-left: 20px;
  padding-bottom: 2px;
}
@media (min-width: 768px) {
  .faq__box .answer__box-inner ul li {
    padding-left: 24px;
    padding-bottom: 4px;
  }
}
.faq__box .answer__box-inner ul li:last-child {
  padding-bottom: 0;
}
.faq__box .answer__box-inner ul li:before {
  content: '';
  position: absolute;
  left: 8px;
  top: 12px;
  width: 4px;
  height: 4px;
  background: #979ca1;
}
@media (min-width: 768px) {
  .faq__box .answer__box-inner ul li:before {
    top: 14px;
  }
}
.faq__box .answer__box-inner ol {
  margin: 8px 0;
}
.faq__box .answer__box-inner ol > li {
  position: relative;
  padding-left: 20px;
  padding-bottom: 2px;
}
@media (min-width: 768px) {
  .faq__box .answer__box-inner ol > li {
    padding-left: 24px;
    padding-bottom: 4px;
  }
}
.faq__box .answer__box-inner ol > li:before {
  position: absolute;
  top: 0;
  left: 0;
  width: auto;
  height: auto;
  background: none;
}
.faq__box .answer__box-inner ol > li:first-child:before {
  content: "①";
}
.faq__box .answer__box-inner ol > li:nth-child(2):before {
  content: "②";
}
.faq__box .answer__box-inner ol > li:nth-child(3):before {
  content: "③";
}
.faq__box .answer__box-inner ol > li:nth-child(4):before {
  content: "④";
}
.faq__box .answer__box-inner ol > li:nth-child(5):before {
  content: "⑤";
}
.faq__box .answer__box-inner ol > li:nth-child(6):before {
  content: "⑥";
}
.faq__box .answer__box-inner ol > li:nth-child(7):before {
  content: "⑦";
}
.faq__box .answer__box-inner ol > li:nth-child(8):before {
  content: "⑧";
}
.faq__box .answer__box-inner ol > li:nth-child(9):before {
  content: "⑨";
}
.faq__box .answer__box-inner ol > li:nth-child(10):before {
  content: "⑩";
}
.faq__box .answer__box-inner ol > li:nth-child(11):before {
  content: "⑪";
}
.faq__box .answer__box-inner ol > li:nth-child(12):before {
  content: "⑫";
}
.faq__box .answer__box-inner ol > li:nth-child(13):before {
  content: "⑬";
}
.faq__box .answer__box-inner ol > li:nth-child(14):before {
  content: "⑭";
}
.faq__box .answer__box-inner ol > li:nth-child(15):before {
  content: "⑮";
}
.faq__box .answer__box-inner ol > li:nth-child(16):before {
  content: "⑯";
}
.faq__box .answer__box-inner ol > li:nth-child(17):before {
  content: "⑰";
}
.faq__box .answer__box-inner ol > li:nth-child(18):before {
  content: "⑱";
}
.faq__box .answer__box-inner ol > li:nth-child(19):before {
  content: "⑲";
}
.faq__box .answer__box-inner ol > li:nth-child(20):before {
  content: "⑳";
}
.faq__box .answer__box-inner a:hover {
  text-decoration: underline;
}
.faq__box .answer__box-inner img {
  display: block;
  width: auto;
  max-width: 100%;
  margin: 8px 0;
}
.hero-area {
  color: #fff;
}
.hero-area__lead {
  font-size: 1.2rem;
  margin-top: 12px;
  letter-spacing: 0.2em;
  padding-bottom: 8px;
}
@media (min-width: 321px) {
  .hero-area__lead {
    font-size: 1.4rem;
    padding-bottom: 8px;
  }
}
@media (min-width: 768px) {
  .hero-area__lead {
    font-size: 1.8rem;
    padding-bottom: 0;
  }
}
.hero-news-area {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 8px;
}
@media (min-width: 768px) {
  .hero-news-area {
    gap: 32px;
    margin-bottom: 24px;
  }
}
@media (min-width: 768px) {
  .hero-news-area__date {
    font-size: 2rem;
  }
}
.hero-news-area__caption {
  font-size: 1.2rem;
  font-weight: bold;
}
@media (min-width: 768px) {
  .hero-news-area__caption {
    font-size: 1.8rem;
  }
}
.legal-documents .tab-anchor {
  margin: 16px auto 32px;
}
.legal-documents .link-box__title {
  margin: 0;
}
.legal-documents__intro {
  padding-bottom: 56px;
}
@media (min-width: 768px) {
  .legal-documents__intro {
    padding-top: 16px;
    padding-bottom: 56px;
  }
}
@media (min-width: 1080px) {
  .legal-documents__intro {
    text-align: center;
  }
}
.legal-documents__hr {
  border-top: 1px solid #dbdee3;
  padding-bottom: 80px;
}
@media (min-width: 768px) {
  .legal-documents__hr {
    padding-bottom: 120px;
  }
}
.legal-documents__category,
.legal-documents__list {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding-bottom: 80px;
  width: 100%;
}
@media (min-width: 768px) {
  .legal-documents__category,
  .legal-documents__list {
    gap: 24px;
    padding-bottom: 120px;
  }
}
.legal-documents__category:last-child,
.legal-documents__list:last-child {
  padding-bottom: 0;
}
.legal-documents__list {
  gap: 4px;
}
.legal-documents__list a {
  padding: 12px 0;
  border-bottom: 1px solid #dbdee3;
}
.legal-documents__list a:first-child {
  padding-top: 0;
}
.legal-documents__list a:last-child {
  border: none;
  padding-bottom: 0;
}
.legal-documents a.pdf {
  display: inline-block;
}
.legal-documents a.pdf:after {
  content: "";
  display: inline-block;
  width: 18px;
  height: 18px;
  background: url("/common/img/icon/icon_download_blue.svg") center right no-repeat;
  background-size: contain;
  margin: auto 3px;
  vertical-align: text-bottom;
}
.legal-documents a.pdf:hover {
  text-decoration: underline;
}
.legal-documents .link-box {
  border: 16px solid #f2f3f5;
}
.legal-documents .link-box__title {
  margin-bottom: 8px;
}
.legal-documents .link-box span {
  color: #6b7075;
}
.legal-documents .right {
  text-align: right;
}
.link-external {
  padding-right: 22px;
  background: url("/common/img/icon/icon_window_blue.svg") center right 4px no-repeat;
  background-size: 14px 14px;
}
@media (min-width: 768px) {
  .link-external {
    background-position: center right 6px;
    background-size: 16px 16px;
    padding-right: 26px;
  }
}
.link-pdf {
  padding-right: 28px;
  background: url("/common/img/icon/icon_download_blue.svg") center right 4px no-repeat;
  background-size: 18px 18px;
  display: inline-block !important;
}
@media (min-width: 768px) {
  .link-pdf {
    background-position: center right 6px;
    background-size: 20px 20px;
    padding-right: 28px;
  }
}
.link-box-wrap {
  display: grid;
  gap: 10px;
}
@media (min-width: 768px) {
  .link-box-wrap {
    gap: 20px;
  }
}
@media (min-width: 1080px) {
  .link-box-wrap {
    grid-template-columns: 1fr 1fr;
  }
}
.link-box-wrap--full {
  display: block;
}
@media (min-width: 768px) {
  .link-box-wrap--full .link-box {
    width: 100%;
  }
}
.link-box-wrap--faq {
  margin-top: 48px;
}
@media (min-width: 768px) {
  .link-box-wrap--faq {
    margin-top: 80px;
  }
}
@media (min-width: 1080px) {
  .link-box-wrap--group {
    grid-template-columns: 1fr;
  }
}
.link-box {
  width: 100%;
  display: block;
  padding: 24px;
  border: 1px solid #dbdee3;
  color: #1a1c21;
}
@media (min-width: 768px) {
  .link-box {
    padding: 40px;
  }
}
.link-box,
.link-box:link,
.link-box:visited {
  color: #1a1c21;
}
@media (min-width: 480px) {
  .link-box:hover,
  .link-box:link:hover,
  .link-box:visited:hover {
    color: #1a1c21;
    background: #f2f3f5;
  }
}
.link-box__title {
  font-size: 1.8rem;
  font-weight: bold;
  margin-bottom: 12px;
}
.link-box__title:after {
  content: '';
  display: inline-block;
  margin-left: 8px;
  background: url("/common/img/icon/icon_link_arrow.svg") center center no-repeat;
  background-size: 14px 15px;
  width: 14px;
  height: 15px;
}
@media (min-width: 768px) {
  .link-box__title {
    font-size: 2rem;
  }
}
.link-box__title--external:after {
  background: url("/common/img/icon/icon_window.svg") center center no-repeat;
  background-size: 16px 16px;
  width: 16px;
  height: 16px;
}
.news__list {
  border-top: 1px solid #dbdee3;
}
.news__item a {
  display: block;
  padding: 20px 40px 20px 20px;
  border-bottom: 1px solid #dbdee3;
  color: #1a1c21;
  position: relative;
}
@media (min-width: 768px) {
  .news__item a {
    padding: 32px 72px 32px 32px;
  }
}
@media (min-width: 1080px) {
  .news__item a {
    display: flex;
    align-items: center;
    padding: 32px 80px 32px 32px;
  }
}
.news__item a:after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 12px;
  margin: auto;
  width: 16px;
  height: 16px;
  background: url("/common/img/icon/icon_link_arrow.svg") center center no-repeat;
  background-size: cover;
}
@media (min-width: 768px) {
  .news__item a:after {
    right: 32px;
  }
}
.news__item a:hover,
.news__item a:link:hover,
.news__item a:visited:hover {
  color: #1a1c21;
  background: #f2f3f5;
  text-decoration: none;
}
.news__item a.link-external-news:after {
  content: '';
  background: url("/common/img/icon/icon_window.svg") center center no-repeat;
  width: 20px;
  height: 20px;
}
.news__item a.pdf:after {
  content: '';
  background: url("/common/img/icon/icon_download_black.svg") center center no-repeat;
  width: 20px;
  height: 20px;
}
.news__box {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media (min-width: 768px) {
  .news__box {
    flex-direction: row-reverse;
    width: 260px;
    flex-shrink: 0;
    justify-content: flex-end;
  }
}
.news__caption {
  font-size: 1.2rem;
  font-weight: bold;
}
@media (min-width: 768px) {
  .news__caption {
    font-size: 1.4rem;
  }
}
.news__date {
  font-size: 1.3rem;
  color: #979ca1;
}
@media (min-width: 768px) {
  .news__date {
    font-size: 1.5rem;
    width: 122px;
  }
}
.news__title {
  font-size: 1.4rem;
  margin-top: 8px;
}
@media (min-width: 1080px) {
  .news__title {
    font-size: 1.6rem;
    margin-top: 0;
    margin-left: 32px;
  }
}
.news__pagination {
  margin-top: 48px;
  display: flex;
  justify-content: center;
}
@media (min-width: 768px) {
  .news__pagination {
    margin-top: 80px;
  }
}
.news__pagination .pagination__list {
  display: flex;
}
.news__pagination .pagination__item {
  margin: 0 8px;
}
.news__pagination .pagination__item a,
.news__pagination .pagination__item span {
  font-size: 1.6rem;
  height: 48px;
  width: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.news__pagination .pagination__item span.current {
  color: #1a1c21;
  border-bottom: 4px solid #000;
}
.news__pagination .pagination__item a {
  color: #fff;
  background: #000;
}
.news__pagination .pagination__item a:hover {
  opacity: 0.8;
  text-decoration: none;
}
.news-content * {
  margin-bottom: 16px;
}
.news-content img {
  max-width: 100%;
  padding: 0 0 32px;
}
@media (min-width: 768px) {
  .news-content img {
    padding: 0 0 40px;
  }
}
@media (min-width: 1080px) {
  .news-content img {
    padding: 0 140px 40px;
  }
}
.news-content__section {
  padding-bottom: 80px;
}
@media (min-width: 768px) {
  .news-content__section {
    padding-bottom: 120px;
  }
}
.news-content__section:last-child {
  padding-bottom: 0;
}
.news-content__summary {
  padding-bottom: 32px;
}
@media (min-width: 768px) {
  .news-content__summary {
    padding-bottom: 40px;
  }
}
.news-content__summary:last-child {
  padding-bottom: 0;
}
.news-content__summary img {
  max-width: 100%;
  padding: 16px 0;
}
@media (min-width: 768px) {
  .news-content__summary img {
    padding: 24px 9.72vw;
  }
}
@media (min-width: 1080px) {
  .news-content__summary img {
    padding: 24px 140px;
  }
}
.news-content a {
  color: #009ce5;
  text-decoration: underline;
  cursor: pointer;
  display: inline;
}
@media (min-width: 1080px) {
  .news-content a {
    text-decoration: none;
  }
}
.news-content a:hover {
  text-decoration: underline;
}
.news-content a img {
  padding: 0;
  margin-left: 8px;
}
.news-content a.btn {
  text-decoration: none;
  margin: 0 0 32px;
}
@media (min-width: 768px) {
  .news-content a.btn {
    margin: 0 0 24px;
  }
}
.news-content .right {
  text-align: right;
  padding-bottom: 0;
  margin-top: 16px;
}
.news-content .supplement {
  color: #979ca1;
  font-size: 1.2rem;
}
@media (min-width: 768px) {
  .news-content .supplement {
    font-size: 1.4rem;
  }
}
.news-content h2 {
  font-weight: bold;
  font-size: 2.2rem;
}
@media (min-width: 768px) {
  .news-content h2 {
    font-size: 3.2rem;
  }
}
.news-content h3 {
  font-weight: bold;
  font-size: 2rem;
}
@media (min-width: 768px) {
  .news-content h3 {
    font-size: 2.4rem;
  }
}
.news-content h4 {
  font-weight: bold;
  font-size: 1.6rem;
}
@media (min-width: 768px) {
  .news-content h4 {
    font-size: 1.8rem;
  }
}
.news-content ul li {
  position: relative;
  padding-left: 20px;
  margin-bottom: 8px;
}
@media (min-width: 768px) {
  .news-content ul li {
    padding-left: 24px;
    margin-bottom: 12px;
  }
}
.news-content ul li:last-child {
  margin-bottom: 0;
}
.news-content ul li:before {
  content: '' !important;
  position: absolute;
  left: 8px;
  top: 12px;
  width: 4px;
  height: 4px;
  background: #979ca1;
}
@media (min-width: 768px) {
  .news-content ul li:before {
    top: 14px;
  }
}
.news-content ol > li {
  list-style-type: none;
  padding-left: 28px;
  margin-bottom: 8px;
  position: relative;
}
@media (min-width: 768px) {
  .news-content ol > li {
    padding-left: 32px;
  }
}
.news-content ol > li:nth-child(n + 10) {
  padding-left: 38px;
}
@media (min-width: 768px) {
  .news-content ol > li:nth-child(n + 10) {
    padding-left: 42px;
  }
}
.news-content ol > li p,
.news-content ol > li a {
  padding-top: 4px;
}
.news-content ol > li ul,
.news-content ol > li ol {
  padding: 8px 0 0;
}
@media (min-width: 768px) {
  .news-content ol > li ul,
  .news-content ol > li ol {
    padding: 12px 0 0;
  }
}
.news-content ol.brackets > li {
  counter-increment: section;
  padding-left: 20px;
}
@media (min-width: 768px) {
  .news-content ol.brackets > li {
    padding-left: 24px;
    margin-bottom: 16px;
  }
}
.news-content ol.brackets > li:before {
  content: "(" counter(section) ") ";
}
.news-content ol.dot-number > li {
  counter-increment: cnt;
  padding-left: 20px;
}
@media (min-width: 768px) {
  .news-content ol.dot-number > li {
    padding-left: 24px;
    margin-bottom: 16px;
  }
}
.news-content ol.dot-number > li:before {
  content: "" counter(cnt) ". ";
}
.news-content table {
  width: 100%;
}
.news-content table th,
.news-content table td {
  border-collapse: collapse;
  border: 1px solid #dbdee3;
  font-weight: normal;
}
.news-content table th {
  padding: 12px;
  width: 25%;
}
@media (min-width: 768px) {
  .news-content table th {
    padding: 16px 24px;
  }
}
.news-content table td {
  padding: 12px 16px;
  vertical-align: middle;
}
@media (min-width: 768px) {
  .news-content table td {
    padding: 16px 24px;
  }
}
.policy__section {
  padding-bottom: 80px;
}
@media (min-width: 768px) {
  .policy__section {
    padding-bottom: 120px;
  }
}
.policy__section:last-child {
  padding-bottom: 0;
}
.policy__summary {
  padding-bottom: 32px;
}
@media (min-width: 768px) {
  .policy__summary {
    padding-bottom: 40px;
  }
}
.policy a {
  color: #009ce5;
  text-decoration: underline;
  cursor: pointer;
}
@media (min-width: 1080px) {
  .policy a {
    text-decoration: none;
  }
}
.policy a:hover {
  text-decoration: underline;
}
.policy__intro {
  margin-bottom: 32px;
}
@media (min-width: 768px) {
  .policy__intro {
    margin-bottom: 40px;
  }
}
.policy a.btn {
  margin: 0 0 8px;
}
@media (min-width: 768px) {
  .policy a.btn {
    margin: 0 0 16px;
  }
}
.policy__text-space p {
  padding-bottom: 16px;
}
.policy .right {
  text-align: right;
}
.policy .supplement {
  color: #979ca1;
  font-size: 1.2rem;
}
@media (min-width: 768px) {
  .policy .supplement {
    font-size: 1.4rem;
  }
}
.policy dl dt {
  position: relative;
  z-index: 2;
  font-weight: bold;
  font-size: 2rem;
  padding-bottom: 16px;
}
@media (min-width: 768px) {
  .policy dl dt {
    font-size: 2.4rem;
  }
}
.policy dl dt span {
  font-weight: normal;
  font-size: 1.4rem;
}
@media (min-width: 768px) {
  .policy dl dt span {
    font-size: 1.6rem;
  }
}
.policy dl dd {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  padding-bottom: 32px;
}
@media (min-width: 768px) {
  .policy dl dd {
    padding-bottom: 40px;
  }
}
.policy dl.normal {
  display: flex;
  align-items: flex-start;
}
.policy dl.normal dt {
  position: relative;
  z-index: 2;
  font-weight: normal;
  font-size: 1.4rem;
  padding: 0;
  flex-shrink: 0;
}
@media (min-width: 768px) {
  .policy dl.normal dt {
    font-size: 1.6rem;
  }
}
.policy dl.normal dd {
  position: relative;
  z-index: 2;
  padding: 0;
}
.policy ul li {
  position: relative;
  z-index: 2;
  position: relative;
  padding-left: 20px;
  padding-bottom: 8px;
}
@media (min-width: 768px) {
  .policy ul li {
    padding-left: 24px;
    padding-bottom: 12px;
  }
}
.policy ul li:last-child {
  padding-bottom: 0;
}
.policy ul li:before {
  content: '';
  position: absolute;
  left: 8px;
  top: 12px;
  width: 4px;
  height: 4px;
  background: #979ca1;
}
@media (min-width: 768px) {
  .policy ul li:before {
    top: 14px;
  }
}
.policy ul.link li {
  position: relative;
  z-index: 2;
}
.policy ul.link li:before {
  background: #009ce5;
}
.policy ul.abc li {
  position: relative;
  z-index: 2;
  padding-left: 0;
  margin-left: 20px;
  list-style-type: lower-alpha;
}
@media (min-width: 768px) {
  .policy ul.abc li {
    margin-left: 24px;
  }
}
.policy ul.abc li:before {
  width: 0;
  height: 0;
  background: none;
}
.policy ol {
  display: block;
  position: relative;
  z-index: 2;
}
.policy ol > li {
  position: relative;
  list-style-type: none;
  counter-increment: cnt;
  padding-left: 28px;
  padding-bottom: 8px;
}
@media (min-width: 768px) {
  .policy ol > li {
    padding-left: 32px;
  }
}
.policy ol > li:before {
  position: absolute;
  left: 0;
  content: "(" counter(cnt) ") ";
}
.policy ol > li:last-child {
  padding-bottom: 0;
}
.policy ol > li:nth-child(n + 10) {
  padding-left: 38px;
}
@media (min-width: 768px) {
  .policy ol > li:nth-child(n + 10) {
    padding-left: 42px;
  }
}
.policy ol > li p,
.policy ol > li a {
  padding-top: 4px;
}
.policy ol > li ul {
  padding: 8px 0;
}
@media (min-width: 768px) {
  .policy ol > li ul {
    padding: 12px 0;
  }
}
.policy ol.dot-number {
  position: relative;
  z-index: 2;
}
.policy ol.dot-number li {
  padding-left: 20px;
}
@media (min-width: 768px) {
  .policy ol.dot-number li {
    padding-left: 24px;
    padding-bottom: 16px;
  }
}
.policy ol.dot-number li:last-child {
  padding-bottom: 0;
}
.policy ol.dot-number li:before {
  content: "" counter(cnt) ". ";
}
.policy ol.dot-number li:nth-child(n + 10) {
  padding-left: 30px;
}
@media (min-width: 768px) {
  .policy ol.dot-number li:nth-child(n + 10) {
    padding-left: 34px;
  }
}
.policy ol.dot-number li > ol.bracket-number {
  padding-top: 8px;
}
.policy ol.dot-number li > ol.bracket-number > li {
  list-style-type: none;
  padding-left: 28px;
  padding-bottom: 8px;
  position: relative;
  counter-reset: cnt;
  counter-increment: cnt_number;
}
@media (min-width: 768px) {
  .policy ol.dot-number li > ol.bracket-number > li {
    padding-left: 32px;
  }
}
.policy ol.dot-number li > ol.bracket-number > li:last-child {
  padding-bottom: 0;
}
.policy ol.dot-number li > ol.bracket-number > li:before {
  position: absolute;
  left: 0;
  content: "(" counter(cnt_number) ") ";
}
.policy ol.dot-number li > ol.bracket-number > li:nth-child(n + 10) {
  padding-left: 38px;
}
@media (min-width: 768px) {
  .policy ol.dot-number li > ol.bracket-number > li:nth-child(n + 10) {
    padding-left: 42px;
  }
}
.policy ol.dot-number li > ol.bracket-number > li > ol.circle-number {
  padding-top: 8px;
}
.policy ol.dot-number li > ol.bracket-number > li > ol.circle-number > li {
  counter-reset: cnt_number;
  padding-bottom: 8px;
}
.policy ol.dot-number li > ol.bracket-number > li > ol.circle-number > li:last-child {
  padding-bottom: 0;
}
.policy ol.dot-number li > ol.bracket-number > li > ol.circle-number > li:first-child:before {
  content: "①";
}
.policy ol.dot-number li > ol.bracket-number > li > ol.circle-number > li:nth-child(2):before {
  content: "②";
}
.policy ol.dot-number li > ol.bracket-number > li > ol.circle-number > li:nth-child(3):before {
  content: "③";
}
.policy ol.dot-number li > ol.bracket-number > li > ol.circle-number > li:nth-child(4):before {
  content: "④";
}
.policy ol.dot-number li > ol.bracket-number > li > ol.circle-number > li:nth-child(5):before {
  content: "⑤";
}
.policy ol.dot-number li > ol.bracket-number > li > ol.circle-number > li:nth-child(6):before {
  content: "⑥";
}
.policy ol.dot-number li > ol.bracket-number > li > ol.circle-number > li:nth-child(7):before {
  content: "⑦";
}
.policy ol.dot-number li > ol.bracket-number > li > ol.circle-number > li:nth-child(8):before {
  content: "⑧";
}
.policy ol.dot-number li > ol.bracket-number > li > ol.circle-number > li:nth-child(9):before {
  content: "⑨";
}
.policy ol.dot-number li > ol.bracket-number > li > ol.circle-number > li:nth-child(10):before {
  content: "⑩";
}
.policy ol.dot-number li > ol.bracket-number + p {
  margin-top: 8px;
}
.policy ol.dot-number li > ul.disc-list {
  padding-bottom: 0;
}
.policy ol.dot-number li > ul.disc-list > li {
  counter-reset: cnt;
}
.policy ol.dot-number li > ul.disc-list > li:last-child {
  padding-bottom: 0;
}
.policy ol.dot-number li > ul.disc-list > li:before {
  content: '';
}
.policy ol.roman-number > li {
  counter-increment: cnt1;
  padding-left: 36px;
}
.policy ol.roman-number > li:last-child {
  padding-bottom: 0;
}
@media (min-width: 768px) {
  .policy ol.roman-number > li {
    padding-left: 44px;
    padding-bottom: 16px;
  }
}
.policy ol.roman-number > li:before {
  content: "( " counter(cnt1, lower-roman) " ) ";
}
.policy__table-wrap {
  overflow-x: scroll;
  margin: 0 -4.27vw;
  padding: 0 4.27vw;
}
@media (min-width: 768px) {
  .policy__table-wrap {
    overflow-x: auto;
  }
}
.policy table,
.policy tr {
  width: 100%;
  font-size: 1.2rem;
}
@media (min-width: 768px) {
  .policy table,
  .policy tr {
    table-layout: fixed;
    font-size: 1.3rem;
  }
}
.policy table th,
.policy tr th,
.policy table td,
.policy tr td {
  border-collapse: collapse;
  border: 1px solid #dbdee3;
  font-weight: normal;
}
.policy table th.em,
.policy tr th.em,
.policy table td.em,
.policy tr td.em {
  background: #f2f3f5;
}
.policy table th,
.policy tr th {
  padding: 8px;
  min-width: 170px;
  width: 45%;
}
@media (min-width: 768px) {
  .policy table th,
  .policy tr th {
    width: 35%;
    min-width: 300px;
  }
}
@media (min-width: 1080px) {
  .policy table th,
  .policy tr th {
    padding: 16px;
  }
}
.policy table th:nth-child(2),
.policy tr th:nth-child(2),
.policy table th:nth-child(3),
.policy tr th:nth-child(3) {
  min-width: 72px;
}
@media (min-width: 768px) {
  .policy table th:nth-child(2),
  .policy tr th:nth-child(2),
  .policy table th:nth-child(3),
  .policy tr th:nth-child(3) {
    width: 84px;
  }
}
@media (min-width: 1080px) {
  .policy table th:nth-child(2),
  .policy tr th:nth-child(2),
  .policy table th:nth-child(3),
  .policy tr th:nth-child(3) {
    width: 114px;
  }
}
.policy table td,
.policy tr td {
  padding: 12px 8px;
  vertical-align: middle;
}
@media (min-width: 1080px) {
  .policy table td,
  .policy tr td {
    padding: 16px;
  }
}
.policy table a,
.policy tr a {
  word-wrap: break-word;
}
.policy .table-box table {
  margin-top: 32px;
}
.policy .table-box table:first-child {
  margin-top: 0;
}
@media (min-width: 768px) {
  .policy .table-box table {
    margin-top: 40px;
  }
}
.policy .contact-area {
  width: 100%;
  padding: 20px;
  border: 1px solid #dbdee3;
}
@media (min-width: 768px) {
  .policy .contact-area {
    padding: 24px;
  }
}
.policy .link-target {
  position: relative;
  z-index: -1;
  height: 1px;
  visibility: hidden;
}
.process__tab {
  border-bottom: 1px solid #000;
}
.process__tab-list {
  display: flex;
  align-items: flex-end;
  width: calc(100% - 4.27vw);
  margin: 0 auto;
}
.process__tab-list--current-first .process__tab-item:nth-child(2),
.process__tab-list--current-first .process__tab-item:nth-child(3),
.process__tab-list--current-first .process__tab-item:nth-child(4) {
  border-width: 1px 1px 0 0;
}
.process__tab-list--current-second .process__tab-item:first-child {
  border-width: 1px 0 0 1px;
}
.process__tab-list--current-second .process__tab-item:nth-child(3),
.process__tab-list--current-second .process__tab-item:nth-child(4) {
  border-width: 1px 1px 0 0;
}
.process__tab-list--current-third .process__tab-item:first-child,
.process__tab-list--current-third .process__tab-item:nth-child(2) {
  border-width: 1px 0 0 1px;
}
.process__tab-list--current-third .process__tab-item:nth-child(4) {
  border-width: 1px 1px 0 0;
}
.process__tab-list--current-fourth .process__tab-item:first-child,
.process__tab-list--current-fourth .process__tab-item:nth-child(2),
.process__tab-list--current-fourth .process__tab-item:nth-child(3) {
  border-width: 1px 0 0 1px;
}
@media (min-width: 1080px) {
  .process__tab-list {
    width: 924px;
  }
}
.process__tab-item {
  height: 64px;
  width: 25%;
  border-style: solid;
  border-color: #000;
}
@media (min-width: 768px) {
  .process__tab-item {
    height: 56px;
  }
}
.process__tab-item--current {
  height: 72px;
  position: relative;
  border-width: 4px 1px 0 1px;
}
@media (min-width: 768px) {
  .process__tab-item--current {
    height: 68px;
  }
}
.process__tab-item--current:after {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  z-index: 1;
  display: block;
  width: 100%;
  height: 2px;
  background-color: #fff;
}
.process__tab-item--current span {
  font-weight: bold;
  padding-top: 5px;
}
.process__tab-item span,
.process__tab-item a {
  font-size: 1.1rem;
  text-align: center;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1.7;
  letter-spacing: 0.08em;
}
@media (min-width: 321px) {
  .process__tab-item span,
  .process__tab-item a {
    font-size: 1.2rem;
  }
}
@media (min-width: 768px) {
  .process__tab-item span,
  .process__tab-item a {
    font-size: 1.6rem;
  }
}
.process__tab-item a {
  background-color: #f2f3f5;
  color: #1a1c21;
}
.process__tab-item a:hover,
.process__tab-item a:link:hover,
.process__tab-item a:visited:hover {
  color: #1a1c21;
  background: #dbdee3;
  text-decoration: none;
}
.process__content {
  padding-left: 4.27vw;
  padding-right: 4.27vw;
  padding-top: 32px;
}
@media (min-width: 768px) {
  .process__content {
    padding-top: 48px;
  }
}
@media (min-width: 1080px) {
  .process__content {
    padding-left: 0;
    padding-right: 0;
  }
}
.process__lead {
  margin-bottom: 32px;
}
@media (min-width: 768px) {
  .process__lead {
    margin-bottom: 48px;
  }
}
.process__lead p {
  text-align: center;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  margin-top: 24px;
}
.process__lead p:first-child {
  margin-top: 0;
}
@media (min-width: 321px) {
  .process__lead p {
    font-size: 1.4rem;
  }
}
@media (min-width: 768px) {
  .process__lead p {
    font-size: 1.6rem;
    margin-top: 16px;
  }
}
.process__step {
  margin-bottom: 24px;
}
.process .step-box {
  display: flex;
  margin-top: 56px;
}
@media (min-width: 768px) {
  .process .step-box {
    margin-top: 80px;
  }
}
.process .step-box:first-child {
  margin-top: 0;
}
.process .step-box__content {
  border: 1px solid #000;
  padding: 24px 4.27vw;
  margin-top: 56px;
  position: relative;
}
@media (min-width: 768px) {
  .process .step-box__content {
    display: flex;
    align-items: center;
    padding: 48px 4.27vw;
    margin-top: 80px;
  }
}
@media (min-width: 1080px) {
  .process .step-box__content {
    padding: 48px 72px;
  }
}
.process .step-box__content:first-child {
  margin-top: 0;
}
.process .step-box__content--01:after {
  content: "";
  display: block;
  width: 100%;
  height: 56px;
  clip-path: polygon(0 0, 100% 0, 88% 100%, 12% 100%);
  background: linear-gradient(110.8deg, #a8faff 2.55%, #65aeff 27.42%, #687cff 40.61%, #c464f1 52.29%, #ff6d64 64.47%, #ff9b52 76.65%, #eff0c4 100%);
  opacity: 0.24;
  position: absolute;
  bottom: -57px;
  left: 0;
}
@media (min-width: 768px) {
  .process .step-box__content--01:after {
    height: 80px;
    bottom: -81px;
  }
}
.process .step-box__content--02:after {
  content: "";
  display: block;
  width: 100%;
  height: 88px;
  clip-path: polygon(0 0, 100% 0, 88% 100%, 12% 100%);
  background: linear-gradient(110.8deg, #a8faff 2.55%, #65aeff 27.42%, #687cff 40.61%, #c464f1 52.29%, #ff6d64 64.47%, #ff9b52 76.65%, #eff0c4 100%);
  opacity: 0.24;
  position: absolute;
  bottom: -89px;
  left: 0;
}
@media (min-width: 768px) {
  .process .step-box__content--02:after {
    height: 80px;
    bottom: -81px;
  }
}
.process .step-box__content--03-04 {
  margin-top: 88px;
}
@media (min-width: 768px) {
  .process .step-box__content--03-04 {
    margin-top: 80px;
    align-items: flex-start;
  }
}
.process .step-box__content-inner {
  margin-top: 24px;
}
@media (min-width: 768px) {
  .process .step-box__content-inner {
    margin-top: 0;
  }
}
.process .step-box__content-inner:first-child {
  margin-top: 0;
}
@media (min-width: 768px) {
  .process .step-box__content-inner--03 {
    flex-shrink: 0;
    margin-right: 32px;
    width: calc((100% - 32px) / 2);
  }
}
@media (min-width: 1080px) {
  .process .step-box__content-inner--03 {
    width: 320px;
    margin-right: 80px;
  }
}
.process .step-box__number {
  margin: 0 auto 12px;
  display: flex;
  justify-content: center;
}
@media (min-width: 768px) {
  .process .step-box__number {
    flex-shrink: 0;
    margin: 0 48px 0 0;
    justify-content: flex-start;
  }
}
@media (min-width: 768px) {
  .process .step-box__number--03,
  .process .step-box__number--04 {
    margin-bottom: 24px;
  }
}
.process .step-box__number img {
  height: 48px;
}
@media (min-width: 768px) {
  .process .step-box__number img {
    height: 76px;
  }
}
.process .step-box__text {
  font-size: 1.3rem;
}
@media (min-width: 768px) {
  .process .step-box__text {
    font-size: 1.6rem;
  }
}
.process .step-box__arrow-text-wrap {
  text-align: center;
  position: absolute;
  bottom: -89px;
  left: 0;
  width: 100%;
  height: 88px;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
}
@media (min-width: 768px) {
  .process .step-box__arrow-text-wrap {
    bottom: -81px;
    height: 80px;
  }
}
.process .step-box__arrow-text {
  font-size: 1.2rem;
  line-height: 1.5;
}
@media (min-width: 768px) {
  .process .step-box__arrow-text {
    font-size: 1.8rem;
  }
}
.process .step-box__arrow-text span.step {
  padding: 0 4px;
}
@media (min-width: 768px) {
  .process .step-box__arrow-text span.step {
    font-size: 1.6rem;
    padding: 0 12px;
  }
}
.process .step-box__arrow-text span.number {
  font-size: 1.6rem;
  margin-left: 2px;
}
@media (min-width: 768px) {
  .process .step-box__arrow-text span.number {
    font-size: 2rem;
    margin-left: 8px;
  }
}
.process .step-box__sub-content {
  border-width: 4px 4px 4px 0;
  border-style: solid;
  border-color: #dbdee3;
  display: flex;
  justify-content: center;
  text-align: center;
  flex-direction: column;
  width: 70px;
  flex-shrink: 0;
  margin-left: 8px;
}
@media (min-width: 768px) {
  .process .step-box__sub-content {
    width: 120px;
    margin-left: 24px;
  }
}
@media (min-width: 1080px) {
  .process .step-box__sub-content {
    margin-left: 40px;
  }
}
.process .step-box__sub-content .caption {
  font-size: 1.1rem;
  line-height: 1.5;
}
@media (min-width: 768px) {
  .process .step-box__sub-content .caption {
    font-size: 1.6rem;
  }
}
.process .step-box__sub-content .period {
  margin-top: 8px;
  margin-left: -2px;
}
.process .step-box__sub-content .period span {
  font-size: 1.3rem;
}
@media (min-width: 768px) {
  .process .step-box__sub-content .period span {
    font-size: 2rem;
  }
}
.process .step-box__sub-content .period span.number {
  font-size: 1.5rem;
}
@media (min-width: 768px) {
  .process .step-box__sub-content .period span.number {
    font-size: 2.2rem;
  }
}
.process .step-box__sub-content .period span:last-child {
  font-size: 1rem;
}
@media (min-width: 768px) {
  .process .step-box__sub-content .period span:last-child {
    font-size: 1.6rem;
  }
}
.process__nav {
  margin-top: 48px;
  padding-left: 4.27vw;
  padding-right: 4.27vw;
}
@media (min-width: 768px) {
  .process__nav {
    display: none;
  }
}
.process__viewpoint {
  padding: 8px 0 0;
}
@media (min-width: 768px) {
  .process__viewpoint {
    padding: 16px 16px 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-row-gap: 64px;
    grid-column-gap: 56px;
  }
}
@media (min-width: 1080px) {
  .process__viewpoint {
    padding: 32px 80px 0;
    grid-row-gap: 80px;
    grid-column-gap: 140px;
  }
}
.process .viewpoint-box {
  margin-top: 40px;
}
.process .viewpoint-box:first-child {
  margin-top: 0;
}
@media (min-width: 768px) {
  .process .viewpoint-box {
    margin-top: 0;
  }
}
.process .viewpoint-box__text span.strong {
  font-weight: bold;
}
.process .framework-box {
  position: relative;
}
.process .framework-box__inner {
  background: linear-gradient(178.51deg, rgba(168,250,255,0.24) 0%, rgba(101,174,255,0.24) 25.52%, rgba(104,124,255,0.24) 39.06%, rgba(196,100,241,0.24) 51.04%, rgba(255,109,100,0.24) 63.54%, rgba(255,155,82,0.24) 76.04%, rgba(239,240,196,0.24) 100%);
}
@media (min-width: 768px) {
  .process .framework-box__inner {
    background: linear-gradient(101.88deg, rgba(168,250,255,0.24) 0.76%, rgba(101,174,255,0.24) 21.84%, rgba(104,124,255,0.24) 33.03%, rgba(196,100,241,0.24) 42.93%, rgba(255,109,100,0.24) 53.26%, rgba(255,155,82,0.24) 63.58%, rgba(239,240,196,0.24) 83.38%);
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
  }
}
.process .framework-box__box {
  border-left: 1px solid #fff;
}
.process .framework-box__box:first-child {
  border-left: none;
}
.process .framework-box__box--discover .framework-box__caption {
  color: #009ce5;
}
.process .framework-box__box--options .framework-box__caption {
  color: #c464f1;
}
.process .framework-box__box--deliver .framework-box__caption {
  color: #f2673c;
}
.process .framework-box__card-wrap {
  padding: 16px 4.27vw 32px;
}
@media (min-width: 768px) {
  .process .framework-box__card-wrap {
    padding: 24px 16px 356px;
  }
}
@media (min-width: 1080px) {
  .process .framework-box__card-wrap {
    padding: 24px 24px 493px;
  }
}
.process .framework-box__card {
  margin-top: 8px;
  text-align: center;
  background: #fff;
  padding: 16px 8px;
}
.process .framework-box__card:first-child {
  margin-top: 0;
}
.process .framework-box__caption {
  font-size: 1.6rem;
  font-weight: bold;
}
.process .framework-box__text {
  font-size: 1.4rem;
  margin-top: 2px;
}
.process .framework-box__image {
  margin-top: 48px;
}
@media (min-width: 768px) {
  .process .framework-box__image {
    width: 640px;
    position: absolute;
    bottom: 56px;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (min-width: 1080px) {
  .process .framework-box__image {
    width: 891px;
    bottom: 72px;
    left: 114px;
    transform: translateX(0);
  }
}
.process .framework-box__image img {
  width: 100%;
}
@media (min-width: 1080px) {
  .process__commercialization {
    padding: 0 80px;
  }
}
.process .commercialization-box {
  margin-top: 56px;
}
@media (min-width: 768px) {
  .process .commercialization-box {
    margin-top: 120px;
  }
}
.process .commercialization-box:first-child {
  margin-top: 0;
}
@media (min-width: 768px) {
  .process .commercialization-box__definition-list {
    display: flex;
    flex-wrap: wrap;
  }
}
.process .commercialization-box__definition-list dt {
  font-weight: bold;
  font-size: 1.6rem;
  margin-top: 32px;
}
@media (min-width: 768px) {
  .process .commercialization-box__definition-list dt {
    width: 130px;
    flex-shrink: 0;
    margin-right: 40px;
    margin-top: 48px;
  }
}
.process .commercialization-box__definition-list dd {
  margin-top: 8px;
}
@media (min-width: 768px) {
  .process .commercialization-box__definition-list dd {
    width: calc(100% - (130px + 40px));
    margin-top: 48px;
  }
}
.process .commercialization-box__definition-list dd p sup {
  font-size: 1.2rem;
  color: #979ca1;
  top: -0.4em;
  margin-right: 2px;
}
.process .commercialization-box__definition-list dd p.sub-text {
  font-size: 1.2rem;
  color: #979ca1;
  position: relative;
  padding-left: 22px;
  margin-top: 8px;
}
@media (min-width: 768px) {
  .process .commercialization-box__definition-list dd p.sub-text {
    font-size: 1.4rem;
  }
}
.process .commercialization-box__definition-list dd p.sub-text:before {
  content: "※";
  display: block;
  position: absolute;
  top: -1px;
  left: 0;
}
.process .commercialization-box__list {
  margin-top: 32px;
}
.process .commercialization-box__item {
  position: relative;
  padding-left: 20px;
  padding-bottom: 8px;
}
@media (min-width: 768px) {
  .process .commercialization-box__item {
    padding-left: 24px;
    padding-bottom: 12px;
  }
}
.process .commercialization-box__item:last-child {
  padding-bottom: 0;
}
.process .commercialization-box__item:before {
  content: '';
  position: absolute;
  left: 8px;
  top: 12px;
  width: 4px;
  height: 4px;
  background: #979ca1;
}
@media (min-width: 768px) {
  .process .commercialization-box__item:before {
    top: 14px;
  }
}
.process .commercialization-number-list {
  counter-reset: number;
  list-style: none;
  padding-left: 24px;
  margin-top: 16px;
}
.process .commercialization-number-list__item {
  position: relative;
  padding-left: 26px;
  margin-top: 8px;
}
.process .commercialization-number-list__item:first-child {
  margin-top: 0;
}
.process .commercialization-number-list__item:before {
  position: absolute;
  top: 0;
  left: 0;
}
.process .commercialization-number-list__item:first-child:before {
  content: "①";
}
.process .commercialization-number-list__item:nth-child(2):before {
  content: "②";
}
.process .commercialization-number-list__item:nth-child(3):before {
  content: "③";
}
.process .commercialization-number-list__item:nth-child(4):before {
  content: "④";
}
.process .commercialization-number-list__item:nth-child(5):before {
  content: "⑤";
}
.process .commercialization-number-list__item:nth-child(6):before {
  content: "⑥";
}
.process .commercialization-number-list__item:nth-child(7) {
  border-top: 1px solid #dbdee3;
  padding-top: 8px;
}
.process .commercialization-number-list__item:nth-child(7):before {
  content: "⑦";
  top: 8px;
}
.service {
  padding-left: 4.27vw;
  padding-right: 4.27vw;
}
@media (min-width: 1080px) {
  .service {
    padding-left: 0;
    padding-right: 0;
  }
}
.service a:hover,
.service a:link:hover,
.service a:visited:hover {
  opacity: 0.8;
  text-decoration: none;
}
.service__box {
  display: block;
  padding: 40px 0;
  border-bottom: 1px solid #dbdee3;
}
.service__box:first-child {
  margin-top: 0;
}
@media (min-width: 768px) {
  .service__box {
    display: flex;
  }
  .service__box:nth-of-type(odd) {
    flex-direction: row-reverse;
  }
  .service__box:nth-of-type(odd) .service__img {
    margin-left: 56px;
  }
  .service__box:nth-of-type(odd) .service__img:after {
    clip-path: polygon(56% 0, 100% 0%, 44% 100%, 0% 100%);
    right: -64px;
  }
  .service__box:nth-of-type(even) .service__img {
    margin-right: 56px;
  }
  .service__box:nth-of-type(even) .service__img:after {
    clip-path: polygon(0 0, 44% 0, 100% 100%, 56% 100%);
    left: -64px;
  }
}
@media (min-width: 1080px) {
  .service__box {
    padding: 80px 0 96px;
  }
  .service__box:nth-of-type(odd) {
    flex-direction: row-reverse;
  }
  .service__box:nth-of-type(odd) .service__img {
    margin-left: 80px;
  }
  .service__box:nth-of-type(odd) .service__img .service__img-box:after {
    clip-path: polygon(56% 0, 100% 0%, 44% 100%, 0% 100%);
    right: -64px;
  }
  .service__box:nth-of-type(even) .service__img {
    margin-right: 80px;
  }
  .service__box:nth-of-type(even) .service__img .service__img-box:after {
    clip-path: polygon(0 0, 44% 0, 100% 100%, 56% 100%);
    left: -64px;
  }
}
.service__img {
  margin-bottom: 24px;
}
@media (min-width: 768px) {
  .service__img {
    margin-bottom: 0;
    width: 50%;
    flex-shrink: 0;
  }
}
@media (min-width: 1080px) {
  .service__img {
    max-width: 520px;
  }
}
.service__img-box {
  position: relative;
  z-index: 0;
}
.service__img-box:after {
  content: "";
  display: block;
  background-color: #f2f3f5;
  clip-path: polygon(56% 0, 100% 0%, 44% 100%, 0% 100%);
  width: 180px;
  height: 152px;
  position: absolute;
  bottom: -38px;
  right: -48px;
  z-index: -1;
}
@media (min-width: 1080px) {
  .service__img-box:after {
    width: 437px;
    height: 368px;
    bottom: -48px;
  }
}
.service__img-box img {
  width: 100%;
}
.service__description {
  position: relative;
  z-index: 0;
}
.service__close,
.service__text {
  color: #1a1c21;
  font-size: 1.4rem;
}
@media (min-width: 768px) {
  .service__close,
  .service__text {
    font-size: 1.6rem;
  }
}
.service__close {
  display: inline-block;
  background: #f2f3f5;
  padding: 16px;
  margin-bottom: 16px;
  border-radius: 8px;
  border: 1px solid #dbdee3;
}
@media (min-width: 768px) {
  .service__close {
    padding: 16px 24px;
    margin-bottom: 28px;
  }
}
.service a.service__link,
.service__link {
  text-align: right;
  margin-top: 8px;
  font-weight: bold;
  font-size: 1.4rem;
  color: #1a1c21;
  display: inline-flex;
  align-items: center;
}
@media (min-width: 768px) {
  .service a.service__link,
  .service__link {
    text-align: left;
    margin-top: 16px;
    font-size: 1.6rem;
  }
}
.service a.service__link:after,
.service__link:after {
  content: "";
  background: url("/common/img/icon/icon_link_arrow.svg") center center no-repeat;
  width: 14px;
  height: 14px;
  background-size: 14px 14px;
  display: block;
  margin-left: 4px;
}
@media (min-width: 768px) {
  .service a.service__link:after,
  .service__link:after {
    width: 16px;
    height: 16px;
    background-size: 16px 16px;
    display: block;
    margin-left: 4px;
  }
}
.service a.service__link--external-link:after,
.service__link--external-link:after {
  background: url("/common/img/icon/icon_window.svg") center center no-repeat;
  background-size: 14px 14px;
}
@media (min-width: 768px) {
  .service a.service__link--external-link:after,
  .service__link--external-link:after {
    background-size: 16px 16px;
  }
}
.service a.service__link--external-link:hover,
.service__link--external-link:hover {
  text-decoration: underline;
}
.service__number {
  color: #6b7075;
  margin-top: 8px;
  text-align: right;
  font-size: 1.2rem;
}
@media (min-width: 768px) {
  .service__number {
    font-size: 1.4rem;
    margin-top: 20px;
  }
}
.service__other {
  background: #fff;
  width: 100%;
  padding: 0 16px 40px;
  margin-top: -1px;
  border-top: 1px solid #fff;
  border-bottom: 1px solid #dbdee3;
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
@media (min-width: 768px) {
  .service__other {
    margin-top: -32px;
    padding: 40px 16px 48px;
    text-align: center;
  }
}
@media (min-width: 1080px) {
  .service__other {
    margin: -48px auto 0;
    padding: 40px 16px 80px;
  }
}
.service__other-title {
  font-weight: bold;
  font-size: 1.2rem;
  text-align: center;
}
@media (min-width: 768px) {
  .service__other-title {
    font-size: 1.4rem;
  }
}
@media (min-width: 1080px) {
  .service__other-title {
    font-size: 1.6rem;
  }
}
@media (min-width: 768px) {
  .service__other-link-wrap {
    display: flex;
    justify-content: center;
    gap: 8px;
  }
}
.service__other-link {
  display: block;
  width: 100%;
  font-weight: bold;
  background: #fff;
  padding: 4px 16px 0;
  border: 1px solid #dbdee3;
  margin-bottom: 8px;
}
@media (min-width: 768px) {
  .service__other-link {
    padding: 4px 12px 0;
    margin-bottom: 0;
    width: auto;
    min-width: 33.3%;
  }
}
@media (min-width: 1080px) {
  .service__other-link {
    max-width: 350px;
  }
}
.service__other-link.no-link {
  height: auto;
}
@media (min-width: 1080px) {
  .service__other-link.no-link {
    max-width: 580px;
  }
}
.service__other-link.no-link:hover {
  background: #fff;
  opacity: 1;
  border-color: #dbdee3;
}
.service__other-link.no-link .service__other-description span:after {
  background: none;
  width: 0;
  height: 0;
  margin: 0;
}
.service__other-link:last-child {
  margin-bottom: 0;
}
.service__other-link,
.service__other-link:link,
.service__other-link:visited {
  color: #1a1c21;
}
@media (min-width: 480px) {
  .service__other-link:hover,
  .service__other-link:link:hover,
  .service__other-link:visited:hover {
    color: #1a1c21;
    background: #f2f3f5;
    border-color: #f2f3f5;
  }
  .service__other-link:hover .service__other-img-box,
  .service__other-link:link:hover .service__other-img-box,
  .service__other-link:visited:hover .service__other-img-box,
  .service__other-link:hover .service__other-description,
  .service__other-link:link:hover .service__other-description,
  .service__other-link:visited:hover .service__other-description {
    transition: all 0.3s ease;
    opacity: 0.8;
  }
}
.service__other-img-box {
  height: 32px;
  margin: 8px auto;
  text-align: center;
}
@media (min-width: 1080px) {
  .service__other-img-box {
    height: 40px;
  }
}
.service__other-img-box img {
  max-height: 100%;
}
.service__other-txt-box {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  margin: 8px auto;
}
@media (min-width: 1080px) {
  .service__other-txt-box {
    min-height: 40px;
  }
}
.service__other-description {
  padding: 16px 0;
  border-top: 1px solid #dbdee3;
  font-size: 1.2rem;
  text-align: center;
}
@media (min-width: 1080px) {
  .service__other-description {
    font-size: 1.4rem;
  }
}
.service__other-description span {
  display: inline-flex;
  align-items: center;
}
.service__other-description span:after {
  content: '';
  width: 17px;
  height: 14px;
  display: block;
  margin-left: 2px;
  background: url("/common/img/icon/icon_window.svg") center center no-repeat;
  background-size: 14px 14px;
}
@media (min-width: 768px) {
  .service__other-description span:after {
    width: 19px;
    height: 16px;
    background-size: 16px 16px;
    display: block;
    margin-left: 2px;
  }
}
.service__supplement {
  text-indent: -1em;
  padding-left: 1em;
  margin-top: 24px;
}
@media (min-width: 768px) {
  .service__supplement {
    margin-top: 48px;
  }
}
@media (min-width: 1080px) {
  .service__supplement {
    text-align: center;
  }
}
.service__supplement a {
  text-decoration: underline;
}
.service__process {
  margin-top: 48px;
}
@media (min-width: 768px) {
  .service__process {
    margin-top: 136px;
  }
}
.service__process-inner {
  border: 6px solid;
  border-image: linear-gradient(to right, #b2e9ff 0%, #9aa2fe 34%, #ffa090 66%, #f8e1bc 100%) 1;
  padding: 24px 5.33vw;
}
@media (min-width: 768px) {
  .service__process-inner {
    padding: 40px 48px;
  }
}
@media (min-width: 768px) {
  .service__process-box {
    display: flex;
    justify-content: space-between;
  }
}
@media (min-width: 1080px) {
  .service__process-box {
    align-items: center;
  }
}
.service__process-text {
  font-size: 1.4rem;
}
@media (min-width: 768px) {
  .service__process-text {
    font-size: 1.5rem;
  }
}
@media (min-width: 1080px) {
  .service__process-text {
    font-size: 1.6rem;
  }
}
@media (min-width: 768px) {
  .service__process-btn {
    width: 248px;
    flex-shrink: 0;
    margin-left: 24px;
  }
}
@media (min-width: 1080px) {
  .sub-nav {
    position: sticky;
    top: 128px;
  }
}
.sub-nav__item {
  margin-top: 8px;
}
@media (min-width: 768px) {
  .sub-nav__item {
    margin-top: 12px;
  }
}
.sub-nav__item:first-child {
  margin-top: 0;
}
.sub-nav__item--current span {
  font-weight: bold;
  display: block;
  font-size: 1.5rem;
  min-height: 48px;
  border-left: 5px solid #000;
  padding: 6px 0 6px 20px;
  display: flex;
  align-items: center;
}
@media (min-width: 768px) {
  .sub-nav__item--current span {
    font-size: 1.7rem;
    min-height: 56px;
  }
}
.sub-nav__item a {
  min-height: 48px;
  border-left: 5px solid #f2f3f5;
  padding: 6px 0 6px 20px;
  display: flex;
  align-items: center;
  color: #1a1c21;
}
@media (min-width: 768px) {
  .sub-nav__item a {
    min-height: 56px;
  }
}
.sub-nav__item a:hover,
.sub-nav__item a:link:hover,
.sub-nav__item a:visited:hover {
  color: #1a1c21;
  background: #f2f3f5;
  text-decoration: none;
}
.sub-nav__item a span {
  display: flex;
  align-items: center;
  font-size: 1.5rem;
}
@media (min-width: 768px) {
  .sub-nav__item a span {
    font-size: 1.7rem;
  }
}
.sub-nav__item a span:after {
  content: "";
  display: block;
  background: url("/common/img/icon/icon_link_arrow.svg") center center no-repeat;
  background-size: 16px 16px;
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  margin-left: 8px;
}
.tab-anchor {
  display: flex;
  margin: 16px auto 32px 0;
  width: 100%;
}
@media (min-width: 768px) {
  .tab-anchor {
    max-width: 840px;
  }
}
.tab-anchor--item {
  flex-grow: 1;
  width: 100%;
  padding: 16px 8px 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-weight: bold;
  color: #1a1c21;
  border: 1px solid #dbdee3;
  background: url("/common/img/icon/icon_tab_arrow.svg") center bottom 4px no-repeat;
  line-height: 1.4;
}
@media (min-width: 768px) {
  .tab-anchor--item {
    padding: 24px 32px 36px;
    background-position: center bottom 8px;
  }
}
.tab-anchor--item:last-child {
  border-left: 0;
}
.tab-anchor--item,
.tab-anchor--item:link,
.tab-anchor--item:visited {
  color: #1a1c21;
}
.tab-anchor--item:hover,
.tab-anchor--item:link:hover,
.tab-anchor--item:visited:hover {
  color: #1a1c21;
  opacity: 0.8;
  background-color: rgba(242,243,245,0.6);
  transition: all 0.3s ease;
}
h1,
h2,
h3,
h4,
h5 {
  line-height: 1.5;
}
@media (min-width: 768px) {
  h1,
  h2,
  h3,
  h4,
  h5 {
    line-height: 1.75;
  }
}
.title--top-main {
  width: 100%;
  max-width: 540px;
  margin: 0 auto;
}
@media (min-width: 768px) {
  .title--top-main {
    max-width: 612px;
  }
}
.title--top-main img {
  width: 100%;
}
.title--top-main-content {
  width: 100%;
  max-width: 235px;
}
@media (min-width: 768px) {
  .title--top-main-content {
    max-width: 640px;
  }
}
@media (min-width: 1080px) {
  .title--top-main-content {
    max-width: 755px;
    transform: translateY(-24px);
  }
}
.title--top-main-content img {
  width: 100%;
}
.title--top-strength {
  margin: 0 auto;
  width: 100%;
  max-width: 340px;
}
@media (min-width: 768px) {
  .title--top-strength {
    max-width: 704px;
    margin: 0;
  }
}
.title--top-strength img {
  width: 100%;
}
.title--top-strength-box {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.title--top-strength-box span {
  display: block;
}
.title--top-strength-box span.number img {
  height: 30px;
}
@media (min-width: 768px) {
  .title--top-strength-box span.number img {
    height: 36px;
  }
}
@media (min-width: 1080px) {
  .title--top-strength-box span.number img {
    height: 40px;
  }
}
.title--top-strength-box span.text {
  font-weight: bold;
  font-size: 2.8rem;
  letter-spacing: 0.4em;
  margin-top: 8px;
  text-align: center;
  padding-left: 12px;
}
@media (min-width: 768px) {
  .title--top-strength-box span.text {
    font-size: 3.2rem;
    padding-left: 16px;
  }
}
@media (min-width: 1080px) {
  .title--top-strength-box span.text {
    font-size: 4rem;
    padding-left: 20px;
  }
}
.title--top-pickup {
  width: 100%;
  max-width: 308px;
}
@media (min-width: 768px) {
  .title--top-pickup {
    max-width: 644px;
  }
}
.title--top-pickup img {
  width: 100%;
}
.title--top-pickup-box {
  font-weight: bold;
  font-size: 1.8rem;
  margin-bottom: 8px;
  color: #1a1c21;
}
@media (min-width: 768px) {
  .title--top-pickup-box {
    font-size: 3.2rem;
    margin-bottom: 24px;
  }
}
.title--top-news {
  width: 100%;
  max-width: 108px;
}
@media (min-width: 768px) {
  .title--top-news {
    max-width: 216px;
  }
}
.title--top-news img {
  width: 100%;
}
.title--hero {
  font-weight: bold;
  color: #fff;
  font-size: 2.4rem;
  letter-spacing: 0.2em;
  max-width: 880px;
}
@media (min-width: 768px) {
  .title--hero {
    font-size: 4.8rem;
  }
}
.title--hero-sub {
  font-weight: bold;
  color: #fff;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
  max-width: 914px;
  display: inline;
}
@media (min-width: 768px) {
  .title--hero-sub {
    display: block;
    font-size: 4rem;
  }
}
.title--hero-supplement {
  font-weight: bold;
  color: #fff;
  font-size: 1.4rem;
  letter-spacing: 0.2em;
  max-width: 880px;
}
@media (min-width: 768px) {
  .title--hero-supplement {
    font-size: 3.2rem;
  }
}
.title--service {
  color: #1a1c21;
  font-weight: bold;
  font-size: 1.8rem;
  margin-bottom: 8px;
}
@media (min-width: 768px) {
  .title--service {
    font-size: 3.2rem;
    margin-bottom: 24px;
  }
}
.title--service-process {
  font-weight: bold;
  font-size: 1.8rem;
  margin-bottom: 8px;
}
@media (min-width: 768px) {
  .title--service-process {
    font-size: 3.2rem;
    margin-bottom: 8px;
  }
}
.title--company-description {
  font-weight: bold;
  font-size: 1.4rem;
  text-align: center;
  line-height: 1.7;
}
@media (min-width: 321px) {
  .title--company-description {
    font-size: 1.6rem;
  }
}
@media (min-width: 768px) {
  .title--company-description {
    font-size: 2rem;
  }
}
.title--company-description span.company-x {
  font-size: 1.6rem;
}
@media (min-width: 321px) {
  .title--company-description span.company-x {
    font-size: 1.8rem;
  }
}
@media (min-width: 768px) {
  .title--company-description span.company-x {
    font-size: 2.2rem;
  }
}
.title--company-description span.text-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  margin-top: 6px;
}
.title--company-description span.x {
  display: block;
  font-size: 3.6rem;
  margin-top: 0;
  margin-right: 2px;
}
@media (min-width: 768px) {
  .title--company-description span.x {
    font-size: 4.2rem;
    margin-right: 4px;
  }
}
.title--company-description span.text {
  display: block;
  font-size: 2.2rem;
  margin-top: 0;
}
@media (min-width: 768px) {
  .title--company-description span.text {
    font-size: 2.4rem;
  }
}
.title--company-box span.text-wrap {
  display: flex;
  font-weight: bold;
  justify-content: center;
  line-height: 1;
}
.title--company-box span.text {
  font-size: 2.4rem;
  padding-top: 8px;
}
@media (min-width: 768px) {
  .title--company-box span.text {
    font-size: 4rem;
    padding-top: 13px;
  }
}
.title--company-box span.x {
  font-size: 3.4rem;
}
@media (min-width: 768px) {
  .title--company-box span.x {
    font-size: 5.6rem;
  }
}
.title--company-box span.caption {
  font-size: 1.4rem;
  display: block;
  line-height: 1;
  margin-top: 4px;
}
@media (min-width: 768px) {
  .title--company-box span.caption {
    font-size: 1.6rem;
  }
}
.title--company-box-sub {
  font-weight: bold;
  margin-bottom: 8px;
  font-size: 1.6rem;
}
@media (min-width: 768px) {
  .title--company-box-sub {
    font-size: 2rem;
  }
}
.title--faq {
  font-weight: bold;
  font-size: 1.8rem;
  margin-bottom: 16px;
}
@media (min-width: 768px) {
  .title--faq {
    font-size: 2.2rem;
  }
}
.title--faq-nav {
  font-weight: bold;
  font-size: 1.6rem;
  margin-bottom: 16px;
}
@media (min-width: 768px) {
  .title--faq-nav {
    font-size: 1.8rem;
  }
}
.title--faq-category {
  font-weight: bold;
  font-size: 1.8rem;
}
@media (min-width: 768px) {
  .title--faq-category {
    font-size: 2rem;
  }
}
.title--diagonal {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 76px;
  margin: 0 auto;
  font-weight: bold;
  margin-bottom: 16px;
}
@media (min-width: 768px) {
  .title--diagonal {
    min-height: 106px;
    width: 100%;
    justify-content: flex-start;
  }
}
.title--diagonal span {
  position: relative;
  z-index: 1;
  font-size: 2.2rem;
  text-align: center;
  line-height: 1.4;
}
@media (min-width: 768px) {
  .title--diagonal span {
    font-size: 2.4rem;
    text-align: left;
    line-height: 1.75;
  }
}
@media (min-width: 768px) {
  .title--diagonal span.big {
    font-size: 3rem;
  }
}
@media (min-width: 1080px) {
  .title--diagonal span.big {
    font-size: 3.2rem;
  }
}
.title--diagonal span:after {
  content: '';
  position: absolute;
  left: -56px;
  top: 0;
  bottom: 0;
  margin: auto;
  z-index: -1;
  width: 93px;
  height: 76px;
  background: #f2f3f5;
  clip-path: polygon(56% 0, 100% 0%, 44% 100%, 0% 100%);
}
@media (min-width: 768px) {
  .title--diagonal span:after {
    left: -80px;
    width: 128px;
    height: 106px;
  }
}
.title--content-error {
  font-weight: bold;
  font-size: 2rem;
  margin-bottom: 16px;
}
@media (min-width: 768px) {
  .title--content-error {
    font-size: 3.2rem;
    margin-bottom: 48px;
  }
}
.title--intro {
  text-align: center;
  padding-bottom: 40px;
}
@media (min-width: 768px) {
  .title--intro {
    text-align: left;
    padding-bottom: 48px;
  }
}
.title--intro a:hover {
  text-decoration: underline;
}
.title--intro-center {
  text-align: center;
  padding-bottom: 40px;
}
@media (min-width: 768px) {
  .title--intro-center {
    padding-bottom: 48px;
  }
}
.title--step-box {
  text-align: center;
  font-weight: bold;
  font-size: 1.6rem;
  margin-bottom: 12px;
}
@media (min-width: 768px) {
  .title--step-box {
    font-size: 2.3rem;
    text-align: left;
    margin-bottom: 8px;
  }
}
@media (min-width: 1080px) {
  .title--step-box {
    font-size: 2.4rem;
  }
}
.title--viewpoint-box {
  display: flex;
  justify-content: center;
  font-weight: bold;
  margin-bottom: 16px;
}
@media (min-width: 768px) {
  .title--viewpoint-box {
    justify-content: flex-start;
  }
}
.title--viewpoint-box span {
  position: relative;
  z-index: 1;
  font-size: 1.7rem;
}
@media (min-width: 321px) {
  .title--viewpoint-box span {
    font-size: 1.8rem;
  }
}
@media (min-width: 768px) {
  .title--viewpoint-box span {
    font-size: 2.4rem;
  }
}
.title--viewpoint-box span:after {
  content: '';
  width: 60px;
  height: 42px;
  position: absolute;
  left: -36px;
  top: 0;
  bottom: 0;
  margin: auto;
  z-index: -1;
  background: #f2f3f5;
  clip-path: polygon(56% 0, 100% 0%, 44% 100%, 0% 100%);
}
@media (min-width: 768px) {
  .title--viewpoint-box span:after {
    width: 68px;
    height: 48px;
    left: -44px;
  }
}
.title--framework {
  min-height: 96px;
  padding: 16px 0;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
}
.title--framework span {
  display: block;
}
.title--framework span.title {
  color: #fff;
  font-weight: bold;
  width: 100%;
  text-align: center;
  line-height: 1;
}
.title--framework span.title--jp {
  padding-left: 8px;
  letter-spacing: 0.4em;
  font-size: 2.2rem;
}
.title--framework span.title--en {
  font-size: 1.8rem;
  margin-top: 4px;
}
.title--framework-discover {
  background: #009ce5;
}
.title--framework-options {
  background: #c464f1;
}
.title--framework-deliver {
  background: #ff9b52;
}
.title--commercialization-box {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 76px;
  margin: 0 auto;
  font-weight: bold;
}
@media (min-width: 768px) {
  .title--commercialization-box {
    min-height: 106px;
    width: 100%;
    justify-content: flex-start;
  }
}
.title--commercialization-box span {
  position: relative;
  z-index: 1;
  font-size: 2.2rem;
  text-align: center;
  line-height: 1.4;
}
@media (min-width: 768px) {
  .title--commercialization-box span {
    font-size: 2.4rem;
    text-align: left;
    line-height: 1.75;
  }
}
.title--commercialization-box span:after {
  content: '';
  position: absolute;
  left: -56px;
  top: 0;
  bottom: 0;
  margin: auto;
  z-index: -1;
  width: 93px;
  height: 76px;
  background: #f2f3f5;
  clip-path: polygon(56% 0, 100% 0%, 44% 100%, 0% 100%);
}
@media (min-width: 768px) {
  .title--commercialization-box span:after {
    left: -80px;
    width: 128px;
    height: 106px;
  }
}
.top-main {
  color: #fff;
  padding-bottom: 140px;
  background: #000;
}
@media (min-width: 768px) {
  .top-main {
    background: #000;
    padding-bottom: 0;
  }
}
.top-main:before {
  content: "";
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: #000 url("/common/img/top/img_top_main_sp.png") left top no-repeat;
  background-size: cover;
}
@media (min-width: 768px) {
  .top-main:before {
    content: none;
  }
}
.top-main--bg-color:before {
  background: #fff;
}
.top-main__video {
  display: none;
}
@media (min-width: 768px) {
  .top-main__video {
    display: block;
    width: 100vw;
    height: calc(100vh - 159px);
    position: fixed;
    z-index: 0;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
  }
}
.top-main__video video {
  min-height: 100%;
  min-height: 100vh;
  min-width: 100%;
  min-width: 100vw;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
}
.top-main__box {
  padding: 164px 0 120px;
  max-width: 1080px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
@media (min-width: 768px) {
  .top-main__box {
    display: flex;
    align-items: center;
    justify-content: center;
    height: calc(100vh - 30vh);
    padding-top: 100px;
  }
}
.top-main__text {
  text-align: center;
}
.top-main__text img {
  width: 274px;
}
@media (min-width: 768px) {
  .top-main__content {
    max-width: 1440px;
    margin: 0 auto -800px;
    position: relative;
    z-index: 2;
  }
}
@media (min-width: 768px) {
  .top-main__content-back {
    background: #000 url("/common/img/top/img_top_main_pc.png") bottom 80px right -360px no-repeat;
    background-size: cover;
    clip-path: polygon(0 30%, 100% 0, 100% 100%, 0 100%);
    height: 920px;
    width: 100%;
    margin: 0 0 -320px;
    position: relative;
    z-index: 1;
  }
}
@media (min-width: 1080px) {
  .top-main__content-back {
    background: #000 url("/common/img/top/img_top_main_pc.png") bottom 80px right -240px no-repeat;
    background-size: auto 94%;
  }
}
@media (min-width: 1440px) {
  .top-main__content-back {
    background: #000 url("/common/img/top/img_top_main_pc.png") bottom 80px right -240px no-repeat;
    background-size: auto 104%;
  }
}
@media (min-width: 1680px) {
  .top-main__content-back {
    background: #000 url("/common/img/top/img_top_main_pc.png") bottom 20px right -280px no-repeat;
    background-size: auto 108%;
    height: 980px;
  }
}
.top-main__content-inner {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 6.4vw;
}
@media (min-width: 768px) {
  .top-main__content-inner {
    padding: 0 6.4vw 319px 6.4vw;
  }
}
@media (min-width: 1080px) {
  .top-main__content-inner {
    padding: 0 0 280px 0;
  }
}
@media (min-width: 1680px) {
  .top-main__content-inner {
    padding: 0 0 220px 0;
  }
}
.top-main__content-text {
  margin-top: 24px;
}
@media (min-width: 768px) {
  .top-main__content-text {
    margin-top: 38px;
  }
}
.top-main__content-text p {
  font-size: 1.4rem;
  margin-top: 16px;
}
@media (min-width: 768px) {
  .top-main__content-text p {
    font-size: 1.8rem;
    margin-top: 20px;
    letter-spacing: 0.2em;
  }
}
.top-main__content-text p:first-child {
  margin-top: 0;
}
.top-main__content-text .tablet {
  display: none !important;
}
@media (min-width: 480px) {
  .top-main__content-text .tablet {
    display: block !important;
  }
}
@media (min-width: 768px) {
  .top-main__content-text .tablet {
    display: none !important;
  }
}
.top-strength {
  margin-top: -8.4vh;
  z-index: 2;
  position: relative;
}
@media (min-width: 768px) {
  .top-strength {
    margin-top: -16vh;
  }
}
@media (min-width: 1080px) {
  .top-strength {
    margin-top: -26vh;
  }
}
.top-strength__top-img {
  height: calc(8.4vh + 8px);
  clip-path: polygon(0 0, 100% 8.4vh, 100% 100%, 0 100%);
  margin-bottom: -8.4vh;
  position: relative;
  z-index: -1;
  background: linear-gradient(106deg, #79c5ff 5%, #65aeff 15%, #687cff 35%, #c464f1 50%, #ff6d64 70%, #ff9b52 85%, #fab87a 95%);
}
@media (min-width: 768px) {
  .top-strength__top-img {
    height: calc(16vh + 20px);
    margin-bottom: -16vh;
    clip-path: polygon(0 0, 100% 16vh, 100% 100%, 0 100%);
  }
}
.top-strength__top-bg {
  border-style: solid;
  border-width: 8.4vh 0 0 100vw;
  border-color: transparent transparent transparent #fff;
}
@media (min-width: 768px) {
  .top-strength__top-bg {
    border-width: 16vh 0 0 100vw;
  }
}
.top-strength__content {
  background: #fff url("/common/img/top/img_bg_top_strength_back_sp.png") center center no-repeat;
  background-size: 100% 900px;
}
@media (min-width: 768px) {
  .top-strength__content {
    background: #fff url("/common/img/top/img_bg_top_strength_back_pc.png") top 170px center no-repeat;
    background-size: 100% 800px;
    padding-bottom: 68px;
  }
}
.top-strength__content-inner {
  max-width: 1080px;
  margin: 0 auto;
  padding: 48px 4.27vw 116px;
}
@media (min-width: 768px) {
  .top-strength__content-inner {
    padding: 20px 4.27vw 254px;
  }
}
@media (min-width: 1080px) {
  .top-strength__content-inner {
    padding: 20px 0 254px;
  }
}
.top-strength__box-wrap {
  padding: 0 4.27vw;
  margin: 40px auto 0;
}
@media (min-width: 768px) {
  .top-strength__box-wrap {
    display: flex;
    filter: drop-shadow(0px 0px 40px rgba(0,0,0,0.08));
    margin: 88px auto 0;
    padding: 0;
  }
}
@media (min-width: 1080px) {
  .top-strength__box-wrap {
    padding: 0;
  }
}
.top-strength__box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 40px 24px;
  background: #fff;
  box-shadow: 0px 8px 28px rgba(0,0,0,0.08);
  margin-top: 16px;
}
.top-strength__box:first-child {
  margin-top: 0;
}
@media (min-width: 768px) {
  .top-strength__box {
    box-shadow: none;
    width: calc(100% / 3);
    padding: 0 8px;
    height: 400px;
    margin-top: 0;
  }
  .top-strength__box:nth-child(2) {
    margin-top: 100px;
  }
  .top-strength__box:nth-child(3) {
    margin-top: 200px;
  }
}
@media (min-width: 1080px) {
  .top-strength__box {
    padding: 0 40px;
    height: 480px;
  }
  .top-strength__box:nth-child(2) {
    margin-top: 100px;
  }
  .top-strength__box:nth-child(3) {
    margin-top: 200px;
  }
}
.top-strength__text {
  text-align: center;
  font-size: 1.4rem;
  text-align: center;
  margin-top: 16px;
}
@media (min-width: 768px) {
  .top-strength__text {
    font-size: 1.3rem;
  }
}
@media (min-width: 1080px) {
  .top-strength__text {
    margin-top: 24px;
    font-size: 1.6rem;
  }
}
.top-pickup {
  position: relative;
  background: #f2f3f5;
  z-index: 2;
}
.top-pickup:before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 0 8.4vh 100vw;
  border-color: transparent transparent #f2f3f5 transparent;
  position: absolute;
  top: calc(-8.4vh + 1px);
}
@media (min-width: 768px) {
  .top-pickup:before {
    border-width: 0 0 16vh 100vw;
    top: calc(-16vh + 1px);
  }
}
@media (min-width: 1080px) {
  .top-pickup:before {
    border-width: 0 0 26vh 100vw;
    top: calc(-26vh + 1px);
  }
}
.top-pickup:after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 100vw 8.4vh 0;
  border-color: transparent #f2f3f5 transparent transparent;
  position: absolute;
  z-index: -1;
  bottom: -8.4vh;
}
@media (min-width: 768px) {
  .top-pickup:after {
    border-width: 0 100vw 16vh 0;
    bottom: -16vh;
  }
}
@media (min-width: 1080px) {
  .top-pickup:after {
    border-width: 0 100vw 26vh 0;
    bottom: calc(-26vh + 1px);
  }
}
.top-pickup__content {
  max-width: 1080px;
  margin: 0 auto;
  padding: 48px 4.27vw;
}
@media (min-width: 768px) {
  .top-pickup__content {
    padding: 64px 4.27vw 0;
  }
}
@media (min-width: 1080px) {
  .top-pickup__content {
    padding: 64px 0 0;
  }
}
.top-pickup__box-wrap {
  margin-top: 40px;
}
@media (min-width: 768px) {
  .top-pickup__box-wrap {
    margin-top: 104px;
  }
}
.top-pickup a:hover,
.top-pickup a:link:hover,
.top-pickup a:visited:hover {
  opacity: 0.8;
  text-decoration: none;
}
.top-pickup__box {
  display: block;
  margin-top: 40px;
}
.top-pickup__box:first-child {
  margin-top: 0;
}
@media (min-width: 768px) {
  .top-pickup__box {
    margin-top: 104px;
    display: flex;
  }
  .top-pickup__box:nth-child(odd) {
    flex-direction: row-reverse;
  }
  .top-pickup__box:nth-child(odd) .top-pickup__img {
    margin-left: 56px;
  }
  .top-pickup__box:nth-child(odd) .top-pickup__img:after {
    clip-path: polygon(56% 0, 100% 0%, 44% 100%, 0% 100%);
    right: -64px;
  }
  .top-pickup__box:nth-child(even) .top-pickup__img {
    margin-right: 56px;
  }
  .top-pickup__box:nth-child(even) .top-pickup__img:after {
    clip-path: polygon(0 0, 44% 0, 100% 100%, 56% 100%);
    left: -64px;
  }
}
.top-pickup__img {
  margin-bottom: 24px;
}
@media (min-width: 768px) {
  .top-pickup__img {
    margin-bottom: 0;
    width: 50%;
    flex-shrink: 0;
  }
}
@media (min-width: 1080px) {
  .top-pickup__img {
    width: 60%;
    max-width: 640px;
  }
}
.top-pickup__img-box {
  position: relative;
  z-index: 0;
}
.top-pickup__img-box:after {
  content: "";
  display: block;
  background-color: #fff;
  clip-path: polygon(56% 0, 100% 0%, 44% 100%, 0% 100%);
  width: 180px;
  height: 152px;
  position: absolute;
  bottom: -38px;
  right: -48px;
  z-index: -1;
}
@media (min-width: 1080px) {
  .top-pickup__img-box:after {
    width: 437px;
    height: 368px;
    bottom: -64px;
  }
}
.top-pickup__img-box-inner {
  filter: drop-shadow(0px 8px 30px rgba(0,0,0,0.08));
}
@media (min-width: 768px) {
  .top-pickup__img-box-inner {
    filter: drop-shadow(0px 10px 30px rgba(0,0,0,0.16));
  }
}
.top-pickup__img-box-inner img {
  width: 100%;
}
.top-pickup__description {
  position: relative;
  z-index: 0;
}
.top-pickup__text {
  color: #1a1c21;
  font-size: 1.4rem;
}
@media (min-width: 768px) {
  .top-pickup__text {
    font-size: 1.6rem;
  }
}
.top-pickup__link {
  text-align: right;
  margin-top: 8px;
  font-weight: bold;
  font-size: 1.4rem;
  color: #1a1c21;
  display: inline-flex;
  align-items: center;
}
@media (min-width: 768px) {
  .top-pickup__link {
    text-align: left;
    margin-top: 16px;
    font-size: 1.6rem;
  }
}
.top-pickup__link:after {
  content: "";
  background: url("/common/img/icon/icon_link_arrow.svg") center center no-repeat;
  width: 14px;
  height: 14px;
  background-size: 14px 14px;
  display: block;
  margin-left: 4px;
}
@media (min-width: 768px) {
  .top-pickup__link:after {
    width: 16px;
    height: 16px;
    background-size: 16px 16px;
    display: block;
    margin-left: 4px;
  }
}
.top-pickup__link--external-link:after {
  background: url("/common/img/icon/icon_window.svg") center center no-repeat;
  background-size: 14px 14px;
}
.top-pickup__number {
  color: #6b7075;
  margin-top: 8px;
  text-align: right;
  font-size: 1.2rem;
}
@media (min-width: 768px) {
  .top-pickup__number {
    font-size: 1.4rem;
    margin-top: 20px;
  }
}
.top-news {
  padding: 116px 0 200px;
  background: #fff;
  position: relative;
  z-index: 0;
}
.top-news:after {
  content: '';
  position: absolute;
  z-index: 0;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(106deg, #79c5ff 5%, #65aeff 15%, #687cff 35%, #c464f1 50%, #ff6d64 70%, #ff9b52 85%, #fab87a 95%);
  opacity: 0.4;
}
@media (min-width: 768px) {
  .top-news {
    padding: 254px 0 320px;
  }
}
@media (min-width: 1080px) {
  .top-news {
    padding: 254px 0 380px;
  }
}
@media (min-width: 1920px) {
  .top-news {
    padding: 254px 0 520px;
  }
}
.top-news__content {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 4.27vw;
  position: relative;
  z-index: 1;
}
@media (min-width: 1080px) {
  .top-news__content {
    padding: 0;
  }
}
.top-news__list {
  margin-top: 40px;
}
@media (min-width: 768px) {
  .top-news__list {
    margin-top: 60px;
  }
}
.top-news__item {
  margin-top: 1px;
}
.top-news__item:first-child {
  margin-top: 0;
}
.top-news__item a {
  display: block;
  padding: 20px 40px 20px 20px;
  background: #fff;
  color: #1a1c21;
  position: relative;
}
@media (min-width: 768px) {
  .top-news__item a {
    display: flex;
    align-items: center;
    padding: 32px 80px 32px 32px;
  }
}
.top-news__item a:after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 12px;
  margin: auto;
  width: 16px;
  height: 16px;
  background: url("/common/img/icon/icon_link_arrow.svg") center center no-repeat;
  background-size: cover;
}
@media (min-width: 768px) {
  .top-news__item a:after {
    right: 32px;
  }
}
.top-news__item a:hover,
.top-news__item a:link:hover,
.top-news__item a:visited:hover {
  color: #1a1c21;
  background: #f2f3f5;
  text-decoration: none;
}
.top-news__item a.link-external-news:after {
  content: '';
  background: url("/common/img/icon/icon_window.svg") center center no-repeat;
  width: 20px;
  height: 20px;
}
.top-news__item a.pdf:after {
  content: '';
  background: url("/common/img/icon/icon_download.svg") center center no-repeat;
}
.top-news__box {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media (min-width: 768px) {
  .top-news__box {
    flex-direction: row-reverse;
    width: 260px;
    flex-shrink: 0;
    justify-content: flex-end;
  }
}
.top-news__caption {
  font-size: 1.2rem;
  font-weight: bold;
}
@media (min-width: 768px) {
  .top-news__caption {
    font-size: 1.4rem;
  }
}
.top-news__date {
  font-size: 1.3rem;
  color: #979ca1;
}
@media (min-width: 768px) {
  .top-news__date {
    font-size: 1.5rem;
    width: 122px;
  }
}
.top-news__title {
  font-size: 1.4rem;
  margin-top: 8px;
}
@media (min-width: 768px) {
  .top-news__title {
    font-size: 1.6rem;
    margin-top: 0;
    margin-left: 32px;
  }
}
.top-btm {
  position: relative;
  z-index: 1;
  margin-top: -160px;
}
@media (min-width: 768px) {
  .top-btm {
    margin-top: -280px;
  }
}
@media (min-width: 1080px) {
  .top-btm {
    margin-top: -340px;
  }
}
@media (min-width: 1920px) {
  .top-btm {
    margin-top: -500px;
  }
}
.top-btm img {
  display: block;
  width: 100%;
}
.voice a,
.reexamination a {
  text-decoration: underline;
  cursor: pointer;
}
@media (min-width: 1080px) {
  .voice a,
  .reexamination a {
    text-decoration: none;
  }
}
.voice a:hover,
.reexamination a:hover {
  text-decoration: underline;
}
.voice .supplement,
.reexamination .supplement {
  position: relative;
  padding-left: 16px;
}
.voice .supplement:before,
.reexamination .supplement:before {
  content: '※';
  position: absolute;
  top: 0;
  left: 0;
}
.voice__section,
.reexamination__section {
  padding-bottom: 80px;
}
@media (min-width: 768px) {
  .voice__section,
  .reexamination__section {
    padding-bottom: 120px;
  }
}
.voice__section:last-child,
.reexamination__section:last-child {
  padding-bottom: 0;
}
.voice__box,
.reexamination__box {
  padding-bottom: 24px;
}
@media (min-width: 768px) {
  .voice__box,
  .reexamination__box {
    padding-bottom: 32px;
  }
}
.voice__box:last-child,
.reexamination__box:last-child {
  padding-bottom: 0;
}
.voice__box p,
.reexamination__box p {
  padding-bottom: 16px;
}
@media (min-width: 768px) {
  .voice__box p,
  .reexamination__box p {
    padding-bottom: 24px;
  }
}
.voice__title,
.reexamination__title {
  font-weight: bold;
  font-size: 1.8rem;
  padding-bottom: 12px;
}
@media (min-width: 768px) {
  .voice__title,
  .reexamination__title {
    font-size: 2rem;
    padding-bottom: 16px;
  }
}
.voice__contact,
.reexamination__contact {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 32px 8px;
  gap: 4px;
  border: 1px solid #dbdee3;
  font-weight: bold;
  margin: 0 auto 8px;
}
@media (min-width: 768px) {
  .voice__contact,
  .reexamination__contact {
    margin: 0 auto 16px;
  }
}
.voice__contact .tel,
.reexamination__contact .tel {
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: 0;
  font-size: 2.6rem;
}
@media (min-width: 768px) {
  .voice__contact .tel,
  .reexamination__contact .tel {
    flex-direction: row;
    gap: 24px;
    font-size: 2.8rem;
  }
}
.voice__contact .tel span,
.reexamination__contact .tel span {
  font-size: 1.6rem;
  line-height: 1;
}
@media (min-width: 768px) {
  .voice__contact .tel span,
  .reexamination__contact .tel span {
    font-size: 1.8rem;
  }
}
.voice__contact .tel img.number,
.reexamination__contact .tel img.number {
  display: block;
  width: 194px;
  margin-top: 12px;
}
@media (min-width: 768px) {
  .voice__contact .tel img.number,
  .reexamination__contact .tel img.number {
    width: 210px;
    margin-top: 0;
  }
}
.voice__contact .supplement,
.reexamination__contact .supplement {
  padding: 0;
  font-size: 1.4rem;
}
@media (min-width: 768px) {
  .voice__contact .supplement,
  .reexamination__contact .supplement {
    font-size: 1.6rem;
    display: inline;
  }
}
.voice__contact .supplement:before,
.reexamination__contact .supplement:before {
  content: '';
}
.voice__contact .right,
.reexamination__contact .right {
  padding-left: 88px;
}
@media (min-width: 768px) {
  .voice__contact .right,
  .reexamination__contact .right {
    padding-left: 0;
  }
}
.reexamination__text-space p {
  padding-bottom: 16px;
}
