@charset "UTF-8";.async-hide {
    opacity: 0 !important;
  }
:root {
  --color-txt: #272727;
  --color-reversal: #fff;
  --color-prime: #f80;
  --color-second: #06f;
  --color-third: #f5b400;
  --color-body: #fff;
  --color-gray: #f9f7f6;
  --font-size-h1: min(10.6666666667vw, 5rem);
  --font-size-h2: min(7.4666666667vw, 3.5rem);
  --font-size-h3: min(7.4666666667vw, 3.5rem);
  --font-size-h4: min(6.4vw, 3rem);
  --font-size-h5: min(5.3333333333vw, 2.5rem);
  --font-size-xl: min(4vw, 1.875rem);
  --font-size-lg: min(4.2666666667vw, 2rem);
  --font-size-base: min(4vw, 1.875rem);
  --font-size-sm: min(3.7333333333vw, 1.75rem);
  --font-size-xs: min(3.2vw, 1.5rem);
}
@media (width >= 48em) {
  :root {
    --font-size-h1: 4rem;
    --font-size-h2: 2.5rem;
    --font-size-h3: 2rem;
    --font-size-h4: 1.75rem;
    --font-size-h5: 1.5rem;
    --font-size-xl: 1.25rem;
    --font-size-lg: 1.125rem;
    --font-size-base: 1rem;
    --font-size-sm: 0.875rem;
    --font-size-xs: 0.75rem;
  }
}

/* svgアイコン */
.l_footer#newFooter {
  padding-block: 3.5rem;
  color: #fff;
  background-color: #272727;
}
@media screen and (width >= 48em) {
  .l_footer#newFooter {
    padding-block: 5rem 3.5rem;
  }
}
.l_footer#newFooter .footBanners {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem 1.6875rem;
  margin-bottom: 3.5rem;
}
@media screen and (width >= 48em) {
  .l_footer#newFooter .footBanners {
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
    margin-bottom: 5rem;
  }
}
.l_footer#newFooter .footBanner::before, .l_footer#newFooter .footBanner::after {
  content: none;
}
.l_footer#newFooter .footBanner-img {
  background-color: #fff;
  transition: opacity 0.4s ease-out;
}
.l_footer#newFooter .footBanner-desc {
  display: block;
  margin-top: 0.625rem;
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.4;
  text-align: center;
  transition: color 0.4s ease-out;
  font-size: min(2.6666666667vw,1.25rem);
}
@media screen and (width >= 48em) {
  .l_footer#newFooter .footBanner-desc {
    font-size: 0.75rem;
  }
}
@media (any-hover: hover) {
  .l_footer#newFooter .footBanner:hover .footBanner-desc {
    color: #f80;
  }
  .l_footer#newFooter .footBanner:hover .footBanner-img {
    opacity: 0.7;
  }
}
.l_footer#newFooter .footBanner:focus-visible .footBanner-desc, .l_footer#newFooter .footBanner:active .footBanner-desc {
  color: #f80;
}
.l_footer#newFooter .footBanner:focus-visible .footBanner-img, .l_footer#newFooter .footBanner:active .footBanner-img {
  opacity: 0.7;
}
.l_footer#newFooter .footer_flex {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  justify-content: space-between;
}
@media screen and (width >= 48em) {
  .l_footer#newFooter .footer_flex {
    flex-direction: row;
    gap: min(5.8565153734vw,5rem);
  }
}
.l_footer#newFooter .footer_head {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
.l_footer#newFooter .footLogo {
  display: block;
}
@media screen and (width < 48em) {
  .l_footer#newFooter .footLogo {
    width: min(45.3333333333vw,21.25rem);
    margin-inline: auto;
  }
}
.l_footer#newFooter .footer_tel {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding: 1rem;
  background-color: rgba(255, 255, 255, 0.05);
  border-radius: 0.25rem;
}
.l_footer#newFooter .footer_tel_label {
  font-size: 0.75rem;
  line-height: 1;
}
.l_footer#newFooter .footer_tel_number {
  font-family: "Zalando Sans Expanded", sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
  text-align: center;
}
@media (any-hover: hover) {
  .l_footer#newFooter .footer_tel_number:hover {
    opacity: 0.7;
  }
}
.l_footer#newFooter .footer_tel_number:focus-visible, .l_footer#newFooter .footer_tel_number:active {
  opacity: 0.7;
}
.l_footer#newFooter .footer_divider {
  height: 0.0625rem;
  margin-block: 2rem;
  background-color: rgba(255, 255, 255, 0.05);
  border: none;
}
@media screen and (width >= 48em) {
  .l_footer#newFooter .footer_divider {
    margin-block: 3rem;
  }
}
.l_footer#newFooter .footer_nav {
  display: flex;
  grid-template-columns: 1fr;
  gap: 2.5rem;
}
@media screen and (width >= 48em) {
  .l_footer#newFooter .footer_nav {
    grid-template-columns: repeat(2, auto);
    gap: min(5.8565153734vw,5rem);
  }
}
@media screen and (width >= 60em) {
  .l_footer#newFooter .footer_nav {
    gap: min(11.7130307467vw,10rem);
  }
}
@media screen and (width < 48em) {
  .l_footer#newFooter .footer_nav {
    display: none;
  }
}
.l_footer#newFooter .footer_nav_main {
  display: grid;
  grid-template-columns: repeat(2, auto);
  gap: 1rem;
  width: 100%;
  height: fit-content;
}
@media screen and (width >= 48em) {
  .l_footer#newFooter .footer_nav_main {
    gap: 1.5rem min(5.8565153734vw,5rem);
    width: auto;
  }
}
@media screen and (width >= 60em) {
  .l_footer#newFooter .footer_nav_main {
    gap: 1.5rem min(11.7130307467vw,10rem);
  }
}
.l_footer#newFooter .footer_nav_link {
  display: inline-flex;
  gap: 0.25rem;
  align-items: center;
  font-weight: 700;
  transition: opacity 0.4s ease-out;
  font-size: min(4.2666666667vw,2rem);
}
@media screen and (width >= 48em) {
  .l_footer#newFooter .footer_nav_link {
    font-size: 1rem;
  }
}
@media (any-hover: hover) {
  .l_footer#newFooter .footer_nav_link:hover {
    opacity: 0.7;
  }
}
.l_footer#newFooter .footer_nav_link:focus-visible, .l_footer#newFooter .footer_nav_link:active {
  opacity: 0.7;
}
.l_footer#newFooter .footer_nav_child {
  display: grid;
  grid-template-columns: 1fr;
}
@media screen and (width >= 48em) {
  .l_footer#newFooter .footer_nav_child {
    gap: 0.75rem;
    margin-top: 1.5rem;
  }
}
.l_footer#newFooter .footer_nav_child li {
  line-height: 1;
}
.l_footer#newFooter .footer_external_link {
  display: inline-flex;
  gap: 0.25rem;
  align-items: center;
  color: #c0c6d0;
  transition: opacity 0.4s ease-out;
  font-size: min(3.4666666667vw,1.625rem);
}
@media screen and (width >= 48em) {
  .l_footer#newFooter .footer_external_link {
    font-size: 0.8125rem;
  }
}
@media (any-hover: hover) {
  .l_footer#newFooter .footer_external_link:hover {
    opacity: 0.7;
  }
}
.l_footer#newFooter .footer_external_link:focus-visible, .l_footer#newFooter .footer_external_link:active {
  opacity: 0.7;
}
.l_footer#newFooter .footer_bottom {
  display: flex;
  flex-direction: column-reverse;
  gap: 2rem;
}
@media screen and (width >= 48em) {
  .l_footer#newFooter .footer_bottom {
    flex-direction: row;
    gap: 1.5rem;
    align-items: center;
    justify-content: space-between;
  }
}
.l_footer#newFooter .footer_copyright {
  font-size: 0.625rem;
  font-weight: 500;
  line-height: 1.5;
  color: #c0c6d0;
}
.l_footer#newFooter .footer_sub_menu {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 2rem;
  justify-content: center;
}
@media screen and (width < 48em) {
  .l_footer#newFooter .footer_sub_menu {
    gap: min(4.2666666667vw,2rem);
    justify-content: flex-start;
  }
}
.l_footer#newFooter .footer_sub_menu a {
  font-size: 0.6875rem;
  font-weight: 400;
  line-height: 1.5;
  color: #c0c6d0;
}
@media (any-hover: hover) {
  .l_footer#newFooter .footer_sub_menu a:hover {
    opacity: 0.7;
  }
}
.l_footer#newFooter .footer_sub_menu a:focus-visible, .l_footer#newFooter .footer_sub_menu a:active {
  opacity: 0.7;
}
.l_footer#newFooter #toTop {
  position: fixed;
  right: 1.25rem;
  bottom: 4.375rem;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 3.5rem;
  aspect-ratio: 1;
  background: #272727;
  border-radius: 50%;
  box-shadow: 0 0 0.5rem rgba(255, 255, 255, 0.3);
  transition: all 0.4s ease-out;
}
.l_footer#newFooter #toTop::after {
  position: absolute;
  inset: 0;
  top: 0.1em;
  display: block;
  height: 0.5rem;
  aspect-ratio: 1;
  margin: auto;
  content: "";
  border: 0.125rem solid #fff;
  border-width: 0.125rem 0.125rem 0 0;
  rotate: -45deg;
}
@media (any-hover: hover) {
  .l_footer#newFooter #toTop:hover {
    box-shadow: 0 0 0.5rem rgba(255, 255, 255, 0.3), 0 0 1rem rgba(255, 255, 255, 0.3);
  }
}
.l_footer#newFooter #toTop:focus-visible, .l_footer#newFooter #toTop:active {
  box-shadow: 0 0 0.5rem rgba(255, 255, 255, 0.3), 0 0 1rem rgba(255, 255, 255, 0.3);
}
.l_footer#newFooter .ctaSp {
  position: fixed;
  bottom: -100%;
  z-index: 40;
  display: flex;
  gap: 1.5rem;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 1rem min(5.3333333333vw,2.5rem);
  background: rgba(255, 255, 255, 0.25);
  box-shadow: 0 -0.3125rem 0.625rem rgba(0, 0, 0, 0.05);
  opacity: 0;
  backdrop-filter: blur(0.625rem);
  transition: all 0.4s ease-out;
}
.l_footer#newFooter .ctaSp-item {
  width: 50%;
}
.l_footer#newFooter .ctaSp .c_btn {
  width: 100%;
  font-size: min(3.2vw,1.5rem);
  line-height: 0;
}
.l_footer#newFooter .ctaSp .c_btn-download::before {
  width: min(4.2666666667vw,2rem);
}
.l_footer#newFooter .ctaSp .c_btn-contact::before {
  width: min(5.3333333333vw,2.5rem);
}
.l_footer#newFooter .ctaSp.-visible {
  bottom: 0;
  opacity: 1;
}
@media screen and (width >= 48em) {
  .l_footer#newFooter .ctaSp {
    display: none;
  }
}
:root {
  --color-txt: #272727;
  --color-reversal: #fff;
  --color-prime: #f80;
  --color-second: #06f;
  --color-third: #f5b400;
  --color-body: #fff;
  --color-gray: #f9f7f6;
  --font-size-h1: min(10.6666666667vw, 5rem);
  --font-size-h2: min(7.4666666667vw, 3.5rem);
  --font-size-h3: min(7.4666666667vw, 3.5rem);
  --font-size-h4: min(6.4vw, 3rem);
  --font-size-h5: min(5.3333333333vw, 2.5rem);
  --font-size-xl: min(4vw, 1.875rem);
  --font-size-lg: min(4.2666666667vw, 2rem);
  --font-size-base: min(4vw, 1.875rem);
  --font-size-sm: min(3.7333333333vw, 1.75rem);
  --font-size-xs: min(3.2vw, 1.5rem);
}
@media (width >= 48em) {
  :root {
    --font-size-h1: 4rem;
    --font-size-h2: 2.5rem;
    --font-size-h3: 2rem;
    --font-size-h4: 1.75rem;
    --font-size-h5: 1.5rem;
    --font-size-xl: 1.25rem;
    --font-size-lg: 1.125rem;
    --font-size-base: 1rem;
    --font-size-sm: 0.875rem;
    --font-size-xs: 0.75rem;
  }
}

/* svgアイコン */
#newHeader a[target=_blank]::after,
#newFooter a[target=_blank]::after {
  mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2210%22%20height%3D%228%22%20viewBox%3D%220%200%2010%208%22%20fill%3D%22none%22%3E%20%3Cpath%20d%3D%22M8%202V8H0V2H8ZM1%207H7V3H1V7Z%22%20fill%3D%22%23C0C6D0%22%2F%3E%20%3Cpath%20d%3D%22M10%200V6.5H8.5V5.5H9V1H2.5V1.5H1.5V0H10Z%22%20fill%3D%22%23C0C6D0%22%2F%3E%3C%2Fsvg%3E");
}

#newHeader figure,
#newFooter figure {
  margin: 0;
}
@layer base {
  #newHeader,
  #newFooter {
    box-sizing: border-box;
  }
  #newHeader *,
  #newHeader *::before,
  #newHeader *::after,
  #newFooter *,
  #newFooter *::before,
  #newFooter *::after {
    box-sizing: border-box;
  }
  #newHeader :where([hidden]:not([hidden=until-found])),
  #newFooter :where([hidden]:not([hidden=until-found])) {
    display: none !important;
  }
  #newHeader :where(html),
  #newFooter :where(html) {
    scrollbar-gutter: stable;
    line-height: 1.5;
    tab-size: 2;
    color-scheme: dark light;
    -webkit-text-size-adjust: none;
    interpolate-size: allow-keywords;
  }
  #newHeader :where(html:has(dialog:modal[open])),
  #newFooter :where(html:has(dialog:modal[open])) {
    overflow: clip;
  }
  @media (prefers-reduced-motion: no-preference) {
    #newHeader :where(html:focus-within),
    #newFooter :where(html:focus-within) {
      scroll-behavior: smooth;
    }
  }
  #newHeader :where(body),
  #newFooter :where(body) {
    font-family: system-ui, sans-serif;
    line-height: inherit;
    -webkit-font-smoothing: antialiased;
  }
  #newHeader :where(button),
  #newFooter :where(button) {
    all: unset;
  }
  #newHeader :where(input, button, textarea, select),
  #newFooter :where(input, button, textarea, select) {
    font: inherit;
    font-variation-settings: inherit;
    font-feature-settings: inherit;
    color: inherit;
    word-spacing: inherit;
    letter-spacing: inherit;
  }
  #newHeader :where(textarea),
  #newFooter :where(textarea) {
    resize: vertical;
    resize: block;
  }
  #newHeader :where(button, label, select, summary, [role=button], [role=option]),
  #newFooter :where(button, label, select, summary, [role=button], [role=option]) {
    cursor: pointer;
  }
  #newHeader :where(:disabled, label:has(> :disabled, + disabled)),
  #newFooter :where(:disabled, label:has(> :disabled, + disabled)) {
    cursor: not-allowed;
  }
  #newHeader :where(a),
  #newFooter :where(a) {
    color: inherit;
    text-underline-offset: 0.2ex;
  }
  #newHeader :where(ul, ol),
  #newFooter :where(ul, ol) {
    list-style: none;
  }
  #newHeader :where(img, svg, video, canvas, audio, iframe, embed, object),
  #newFooter :where(img, svg, video, canvas, audio, iframe, embed, object) {
    display: block;
  }
  #newHeader :where(img, picture, svg, video),
  #newFooter :where(img, picture, svg, video) {
    max-inline-size: 100%;
    block-size: auto;
  }
  #newHeader :where(p, h1, h2, h3, h4, h5, h6),
  #newFooter :where(p, h1, h2, h3, h4, h5, h6) {
    overflow-wrap: break-word;
  }
  #newHeader :where(h1, h2, h3),
  #newFooter :where(h1, h2, h3) {
    line-height: calc(1em + 0.3125rem);
    text-wrap: balance;
  }
  #newHeader :where(hr),
  #newFooter :where(hr) {
    block-size: 0;
    overflow: visible;
    color: inherit;
    border: none;
    border-block-start: 1px solid;
  }
  #newHeader :where(dialog, [popover]),
  #newFooter :where(dialog, [popover]) {
    inset: unset;
    max-width: unset;
    max-height: unset;
    overflow: unset;
    color: inherit;
    background: none;
    border: none;
  }
  #newHeader :where(dialog:not([open], [popover]), [popover]:not(:popover-open)),
  #newFooter :where(dialog:not([open], [popover]), [popover]:not(:popover-open)) {
    display: none !important;
  }
  #newHeader :where(:focus-visible),
  #newFooter :where(:focus-visible) {
    outline: 3px solid CanvasText;
    outline-offset: 1px;
    box-shadow: 0 0 0 5px Canvas;
  }
  #newHeader :where(:focus-visible, :target),
  #newFooter :where(:focus-visible, :target) {
    scroll-margin-block: 8vh;
  }
  #newHeader :where(.visually-hidden:not(:focus-within, :active)),
  #newFooter :where(.visually-hidden:not(:focus-within, :active)) {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    user-select: none !important;
    border: 0 !important;
    clip-path: inset(50%) !important;
  }
}
#newHeader *,
#newFooter * {
  box-sizing: border-box;
}
#newHeader *::before, #newHeader *::after,
#newFooter *::before,
#newFooter *::after {
  box-sizing: inherit;
}
@media (prefers-reduced-motion: reduce) {
  #newHeader *,
  #newHeader ::before,
  #newHeader ::after,
  #newFooter *,
  #newFooter ::before,
  #newFooter ::after {
    transition-duration: 1ms !important;
    animation-duration: 1ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
  }
}
#newHeader input::-moz-focus-inner,
#newFooter input::-moz-focus-inner {
  padding: 0;
  margin: 0;
  border: 0;
}
#newHeader ul,
#newHeader ol,
#newHeader dd,
#newFooter ul,
#newFooter ol,
#newFooter dd {
  padding: 0;
  margin: 0;
  list-style: none;
}
#newHeader h1,
#newHeader h2,
#newHeader h3,
#newHeader h4,
#newHeader h5,
#newHeader h6,
#newFooter h1,
#newFooter h2,
#newFooter h3,
#newFooter h4,
#newFooter h5,
#newFooter h6 {
  margin: 0;
  font-size: inherit;
  font-weight: inherit;
  text-wrap: wrap;
}
#newHeader cite,
#newFooter cite {
  font-style: normal;
}
#newHeader fieldset,
#newFooter fieldset {
  padding: 0;
  margin: 0;
  border-width: 0;
}
#newHeader button,
#newFooter button {
  padding: 0;
  color: inherit;
  appearance: none;
  cursor: pointer;
  background-color: transparent;
  border: none;
}
#newHeader summary,
#newFooter summary {
  display: block;
  list-style: none;
}
#newHeader summary::-webkit-details-marker,
#newFooter summary::-webkit-details-marker {
  display: none;
}
#newHeader img,
#newFooter img {
  max-width: 100%;
  height: auto;
  max-height: 100%;
}
#newHeader figure,
#newHeader picture,
#newFooter figure,
#newFooter picture {
  padding: 0;
  margin: 0;
  line-height: 1;
  text-align: center;
}
#newHeader figure figcaption,
#newHeader picture figcaption,
#newFooter figure figcaption,
#newFooter picture figcaption {
  margin: auto;
  text-align: left;
}
#newHeader ::selection,
#newFooter ::selection {
  color: #fff;
  background-color: #f80;
}
#newHeader a,
#newHeader button,
#newFooter a,
#newFooter button {
  color: inherit;
  text-decoration: none;
}
#newHeader a:focus-visible,
#newHeader button:focus-visible,
#newFooter a:focus-visible,
#newFooter button:focus-visible {
  outline: solid 0.125rem #f80;
  outline-offset: 0.1875rem;
  box-shadow: none;
}
#newHeader a[target=_blank]::after,
#newFooter a[target=_blank]::after {
  display: inline-flex;
  height: 0.9em;
  aspect-ratio: 1;
  margin-left: 0.1em;
  content: "";
  background-color: currentColor;
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: 100%;
}
#newHeader [tabindex="-1"]:focus-visible,
#newFooter [tabindex="-1"]:focus-visible {
  outline: none !important;
  box-shadow: none;
}
@media screen and (width >= 48em) {
  #newHeader a[href^="tel:"],
  #newFooter a[href^="tel:"] {
    color: inherit !important;
    text-decoration: none !important;
    pointer-events: none;
  }
}

.l_header#newHeader {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  width: 100%;
  padding: 0.875rem min(4.2666666667vw,2rem);
}
@media screen and (width >= 48em) {
  .l_header#newHeader {
    padding: 1.5rem min(1.6837481698vw,1.4375rem) 0.625rem;
  }
}
.l_header#newHeader .header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 3.5rem;
  padding-inline: 1.25rem 0.875rem;
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 4px 10px 0 rgba(0, 0, 0, 0.1);
}
@media screen and (width >= 48em) {
  .l_header#newHeader .header-inner {
    height: 4.375rem;
    padding-inline: min(2.3426061493vw,2rem) 0.8125rem;
  }
}
.l_header#newHeader .headerLogo svg {
  width: min(32vw,15rem);
}
@media screen and (width >= 48em) {
  .l_header#newHeader .headerLogo svg {
    width: min(12.298682284vw,10.5rem);
  }
}
.l_header#newHeader .headerNavi .ac_menu {
  position: relative;
  z-index: 102;
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  align-items: center;
  justify-content: center;
  width: 3.5rem;
  height: 3.5rem;
  cursor: pointer;
  background: none;
  border: none;
}
@media screen and (width >= 48em) {
  .l_header#newHeader .headerNavi .ac_menu {
    display: none;
  }
}
.l_header#newHeader .headerNavi .ac_menu span {
  font-size: 0.625rem;
  color: #f80;
}
.l_header#newHeader .headerNavi .ac_menu::before, .l_header#newHeader .headerNavi .ac_menu::after {
  width: 1.75rem;
  height: 0.1875rem;
  content: "";
  background: #f80;
  border-radius: 0.125rem;
  transition: all 0.3s ease;
}
.l_header#newHeader .headerNavi .ac_menu::before {
  transform: translateY(-0.25rem);
}
.l_header#newHeader .headerNavi .ac_menu::after {
  transform: translateY(0.25rem);
}

.wrapper .l_header#newHeader {
  padding: 0 0 0.625rem;
}
.wrapper .l_header#newHeader .header-inner {
  height: 4.375rem;
  border-radius: 0;
}
@media screen and (width >= 48em) {
  .wrapper .l_header#newHeader .header-inner {
    height: 5.625rem;
  }
}

.page-top .l_header {
  z-index: -2;
  pointer-events: none;
  opacity: 0;
}
.page-top .l_header.-visible {
  pointer-events: all;
  opacity: 1;
  transition: opacity 0.4s ease-out;
}
:root {
  --color-txt: #272727;
  --color-reversal: #fff;
  --color-prime: #f80;
  --color-second: #06f;
  --color-third: #f5b400;
  --color-body: #fff;
  --color-gray: #f9f7f6;
  --font-size-h1: min(10.6666666667vw, 5rem);
  --font-size-h2: min(7.4666666667vw, 3.5rem);
  --font-size-h3: min(7.4666666667vw, 3.5rem);
  --font-size-h4: min(6.4vw, 3rem);
  --font-size-h5: min(5.3333333333vw, 2.5rem);
  --font-size-xl: min(4vw, 1.875rem);
  --font-size-lg: min(4.2666666667vw, 2rem);
  --font-size-base: min(4vw, 1.875rem);
  --font-size-sm: min(3.7333333333vw, 1.75rem);
  --font-size-xs: min(3.2vw, 1.5rem);
}
@media (width >= 48em) {
  :root {
    --font-size-h1: 4rem;
    --font-size-h2: 2.5rem;
    --font-size-h3: 2rem;
    --font-size-h4: 1.75rem;
    --font-size-h5: 1.5rem;
    --font-size-xl: 1.25rem;
    --font-size-lg: 1.125rem;
    --font-size-base: 1rem;
    --font-size-sm: 0.875rem;
    --font-size-xs: 0.75rem;
  }
}

/* svgアイコン */
:root {
  --color-txt: #272727;
  --color-reversal: #fff;
  --color-prime: #f80;
  --color-second: #06f;
  --color-third: #f5b400;
  --color-body: #fff;
  --color-gray: #f9f7f6;
  --font-size-h1: min(10.6666666667vw, 5rem);
  --font-size-h2: min(7.4666666667vw, 3.5rem);
  --font-size-h3: min(7.4666666667vw, 3.5rem);
  --font-size-h4: min(6.4vw, 3rem);
  --font-size-h5: min(5.3333333333vw, 2.5rem);
  --font-size-xl: min(4vw, 1.875rem);
  --font-size-lg: min(4.2666666667vw, 2rem);
  --font-size-base: min(4vw, 1.875rem);
  --font-size-sm: min(3.7333333333vw, 1.75rem);
  --font-size-xs: min(3.2vw, 1.5rem);
}
@media (width >= 48em) {
  :root {
    --font-size-h1: 4rem;
    --font-size-h2: 2.5rem;
    --font-size-h3: 2rem;
    --font-size-h4: 1.75rem;
    --font-size-h5: 1.5rem;
    --font-size-xl: 1.25rem;
    --font-size-lg: 1.125rem;
    --font-size-base: 1rem;
    --font-size-sm: 0.875rem;
    --font-size-xs: 0.75rem;
  }
}

/* svgアイコン */
/* アコーディオン  */
.c_pull {
  height: var(--pullHeightClosed, auto);
  overflow: hidden;
  transition: height 0.4s ease-out;
}
.c_pull .c_pull_ttl {
  position: relative;
  padding-right: 3.125rem;
  cursor: pointer;
}
@media screen and (width >= 48em) {
  .c_pull .c_pull_ttl {
    padding-right: min(8vw,3.75rem);
  }
}
.c_pull .c_pull_ttl::before, .c_pull .c_pull_ttl::after {
  position: absolute;
  inset: 0 1em 0 auto;
  width: 1.5rem;
  height: 0.25rem;
  margin: auto;
  content: "";
  background-color: #f80;
  transform-origin: center;
  transition: rotate 0.4s ease-out;
}
.c_pull .c_pull_ttl::after {
  rotate: 90deg;
}
.c_pull .c_pull_ttl:focus-visible {
  outline: solid 0.1875rem #f80;
  outline-offset: -0.3125rem;
  box-shadow: none;
}
.c_pull.-open {
  height: var(--pullHeightOpen, auto);
}
.c_pull.-open .c_pull_ttl::after {
  rotate: none;
}
@media screen and (width >= 48em) {
  .c_pull.-spPull {
    border: 0;
  }
  .c_pull.-spPull .c_pull_ttl {
    padding: 0;
    pointer-events: none;
    cursor: none;
  }
  .c_pull.-spPull .c_pull_ttl::before, .c_pull.-spPull .c_pull_ttl::after {
    content: none;
  }
  .c_pull.-spPull .c_pull_content {
    padding: 0;
  }
}

/* /アコーディオン  */
:root {
  --color-txt: #272727;
  --color-reversal: #fff;
  --color-prime: #f80;
  --color-second: #06f;
  --color-third: #f5b400;
  --color-body: #fff;
  --color-gray: #f9f7f6;
  --font-size-h1: min(10.6666666667vw, 5rem);
  --font-size-h2: min(7.4666666667vw, 3.5rem);
  --font-size-h3: min(7.4666666667vw, 3.5rem);
  --font-size-h4: min(6.4vw, 3rem);
  --font-size-h5: min(5.3333333333vw, 2.5rem);
  --font-size-xl: min(4vw, 1.875rem);
  --font-size-lg: min(4.2666666667vw, 2rem);
  --font-size-base: min(4vw, 1.875rem);
  --font-size-sm: min(3.7333333333vw, 1.75rem);
  --font-size-xs: min(3.2vw, 1.5rem);
}
@media (width >= 48em) {
  :root {
    --font-size-h1: 4rem;
    --font-size-h2: 2.5rem;
    --font-size-h3: 2rem;
    --font-size-h4: 1.75rem;
    --font-size-h5: 1.5rem;
    --font-size-xl: 1.25rem;
    --font-size-lg: 1.125rem;
    --font-size-base: 1rem;
    --font-size-sm: 0.875rem;
    --font-size-xs: 0.75rem;
  }
}

/* svgアイコン */
.c_box {
  padding: 2rem min(6.4vw,3rem);
  background-color: #fff;
  border-radius: 0.5rem;
}
@media screen and (width >= 48em) {
  .c_box {
    padding: 2.5rem min(2.9282576867vw,2.5rem);
  }
}
:root {
  --color-txt: #272727;
  --color-reversal: #fff;
  --color-prime: #f80;
  --color-second: #06f;
  --color-third: #f5b400;
  --color-body: #fff;
  --color-gray: #f9f7f6;
  --font-size-h1: min(10.6666666667vw, 5rem);
  --font-size-h2: min(7.4666666667vw, 3.5rem);
  --font-size-h3: min(7.4666666667vw, 3.5rem);
  --font-size-h4: min(6.4vw, 3rem);
  --font-size-h5: min(5.3333333333vw, 2.5rem);
  --font-size-xl: min(4vw, 1.875rem);
  --font-size-lg: min(4.2666666667vw, 2rem);
  --font-size-base: min(4vw, 1.875rem);
  --font-size-sm: min(3.7333333333vw, 1.75rem);
  --font-size-xs: min(3.2vw, 1.5rem);
}
@media (width >= 48em) {
  :root {
    --font-size-h1: 4rem;
    --font-size-h2: 2.5rem;
    --font-size-h3: 2rem;
    --font-size-h4: 1.75rem;
    --font-size-h5: 1.5rem;
    --font-size-xl: 1.25rem;
    --font-size-lg: 1.125rem;
    --font-size-base: 1rem;
    --font-size-sm: 0.875rem;
    --font-size-xs: 0.75rem;
  }
}

/* svgアイコン */
/* パンくず  */
@layer components {
  .c_bread li:not(:last-child) {
    position: relative;
  }
  .c_bread li:not(:last-child)::after {
    position: absolute;
    inset: 0.1em -1.25rem 0 auto;
    height: 0.5em;
    aspect-ratio: 1;
    margin: auto;
    content: "";
    border: 0.0625rem solid #f80;
    border-width: 0.125rem 0.125rem 0 0;
    rotate: 45deg;
  }
  .c_bread li a {
    transition: opacity 0.4s ease-out;
  }
  @media (any-hover: hover) {
    .c_bread li a:hover {
      opacity: 0.7;
    }
  }
  .c_bread li a:focus-visible, .c_bread li a:active {
    opacity: 0.7;
  }
}
/* /パンくず  */
:root {
  --color-txt: #272727;
  --color-reversal: #fff;
  --color-prime: #f80;
  --color-second: #06f;
  --color-third: #f5b400;
  --color-body: #fff;
  --color-gray: #f9f7f6;
  --font-size-h1: min(10.6666666667vw, 5rem);
  --font-size-h2: min(7.4666666667vw, 3.5rem);
  --font-size-h3: min(7.4666666667vw, 3.5rem);
  --font-size-h4: min(6.4vw, 3rem);
  --font-size-h5: min(5.3333333333vw, 2.5rem);
  --font-size-xl: min(4vw, 1.875rem);
  --font-size-lg: min(4.2666666667vw, 2rem);
  --font-size-base: min(4vw, 1.875rem);
  --font-size-sm: min(3.7333333333vw, 1.75rem);
  --font-size-xs: min(3.2vw, 1.5rem);
}
@media (width >= 48em) {
  :root {
    --font-size-h1: 4rem;
    --font-size-h2: 2.5rem;
    --font-size-h3: 2rem;
    --font-size-h4: 1.75rem;
    --font-size-h5: 1.5rem;
    --font-size-xl: 1.25rem;
    --font-size-lg: 1.125rem;
    --font-size-base: 1rem;
    --font-size-sm: 0.875rem;
    --font-size-xs: 0.75rem;
  }
}

/* svgアイコン */
.c_btn_cta.-download::before {
  mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2226%22%20height%3D%2226%22%20viewBox%3D%220%200%2026%2026%22%20fill%3D%22none%22%3E%20%3Cpath%20d%3D%22M9.03916%2014.1193H16.9593V12.5456H9.03916V14.1193ZM9.03916%2017.1458H16.9593V15.5721H9.03916V17.1458ZM9.03916%2020.172H13.8393V18.5983H9.03916V20.172ZM7.07928%2023.4001C6.55391%2023.4001%206.10922%2023.2165%205.74522%2022.8493C5.38122%2022.4821%205.19922%2022.0336%205.19922%2021.5036V5.36335C5.19922%204.83337%205.38122%204.38478%205.74522%204.01759C6.10922%203.65039%206.55391%203.4668%207.07928%203.4668H15.3392L20.7992%208.97469V21.5036C20.7992%2022.0336%2020.6172%2022.4821%2020.2532%2022.8493C19.8892%2023.2165%2019.4445%2023.4001%2018.9192%2023.4001H7.07928ZM14.5592%209.76153V5.04048H7.07928C6.9992%205.04048%206.92588%205.07414%206.85932%205.14146C6.79259%205.2086%206.75922%205.28257%206.75922%205.36335V21.5036C6.75922%2021.5844%206.79259%2021.6583%206.85932%2021.7255C6.92588%2021.7928%206.9992%2021.8264%207.07928%2021.8264H18.9192C18.9992%2021.8264%2019.0726%2021.7928%2019.1391%2021.7255C19.2059%2021.6583%2019.2392%2021.5844%2019.2392%2021.5036V9.76153H14.5592Z%22%20fill%3D%22white%22%2F%3E%3C%2Fsvg%3E");
}

.c_btn_cta.-contact::before {
  mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2232%22%20height%3D%2232%22%20viewBox%3D%220%200%2032%2032%22%20fill%3D%22none%22%3E%20%3Cpath%20d%3D%22M5.74236%2026C5.06881%2026%204.4987%2025.7667%204.03203%2025.3C3.56536%2024.8333%203.33203%2024.2632%203.33203%2023.5897V8.41033C3.33203%207.73678%203.56536%207.16667%204.03203%206.7C4.4987%206.23333%205.06881%206%205.74236%206H26.255C26.9286%206%2027.4987%206.23333%2027.9654%206.7C28.432%207.16667%2028.6654%207.73678%2028.6654%208.41033V23.5897C28.6654%2024.2632%2028.432%2024.8333%2027.9654%2025.3C27.4987%2025.7667%2026.9286%2026%2026.255%2026H5.74236ZM15.9987%2016.7437L5.33203%209.923V23.5897C5.33203%2023.7094%205.37048%2023.8078%205.44736%2023.8847C5.52425%2023.9616%205.62259%2024%205.74236%2024H26.255C26.3748%2024%2026.4731%2023.9616%2026.55%2023.8847C26.6269%2023.8078%2026.6654%2023.7094%2026.6654%2023.5897V9.923L15.9987%2016.7437ZM15.9987%2014.6667L26.4604%208H5.53703L15.9987%2014.6667ZM5.33203%209.923V8V23.5897C5.33203%2023.7094%205.37048%2023.8078%205.44736%2023.8847C5.52425%2023.9616%205.62259%2024%205.74236%2024H5.33203V9.923Z%22%20fill%3D%22white%22%2F%3E%3C%2Fsvg%3E");
}

.p_sample {
  padding: 2.5rem 0;
}

.c_btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 20rem;
  min-height: 3.5rem;
  margin: auto;
  font-weight: bold;
  color: #fff;
  background-color: #f80;
  border-radius: 0.25rem;
  transition: opacity 0.4s ease-out;
}
@media (any-hover: hover) {
  .c_btn:hover {
    opacity: 0.7;
  }
}
.c_btn:focus-visible, .c_btn:active {
  opacity: 0.7;
}
.c_btn_cta {
  position: relative;
  display: flex;
  gap: 0.25rem;
  align-items: center;
  justify-content: center;
  font-family: heisei-kaku-gothic-std, sans-serif;
  border-radius: 0.25rem;
  transition: color 0.4s ease-out, background-color 0.4s ease-out;
}
.c_btn_cta::before {
  display: block;
  height: 1.625rem;
  aspect-ratio: 1;
  content: "";
  background-color: currentcolor;
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
}
@media screen and (width >= 48em) {
  .c_btn_cta::before {
    height: min(1.9033674963vw,1.625rem);
  }
}
.c_btn_cta.-download {
  background-color: #f80;
  border: 0.0625rem solid #f80;
}
@media (any-hover: hover) {
  .c_btn_cta.-download:hover {
    color: #f80 !important;
    background-color: transparent;
  }
}
.c_btn_cta.-download:focus-visible, .c_btn_cta.-download:active {
  color: #f80 !important;
  background-color: transparent;
}
.c_btn_cta.-contact {
  background-color: #eb4000;
  border: 0.0625rem solid #eb4000;
}
@media (any-hover: hover) {
  .c_btn_cta.-contact:hover {
    color: #eb4000 !important;
    background-color: transparent;
  }
}
.c_btn_cta.-contact:focus-visible, .c_btn_cta.-contact:active {
  color: #eb4000 !important;
  background-color: transparent;
}
:root {
  --color-txt: #272727;
  --color-reversal: #fff;
  --color-prime: #f80;
  --color-second: #06f;
  --color-third: #f5b400;
  --color-body: #fff;
  --color-gray: #f9f7f6;
  --font-size-h1: min(10.6666666667vw, 5rem);
  --font-size-h2: min(7.4666666667vw, 3.5rem);
  --font-size-h3: min(7.4666666667vw, 3.5rem);
  --font-size-h4: min(6.4vw, 3rem);
  --font-size-h5: min(5.3333333333vw, 2.5rem);
  --font-size-xl: min(4vw, 1.875rem);
  --font-size-lg: min(4.2666666667vw, 2rem);
  --font-size-base: min(4vw, 1.875rem);
  --font-size-sm: min(3.7333333333vw, 1.75rem);
  --font-size-xs: min(3.2vw, 1.5rem);
}
@media (width >= 48em) {
  :root {
    --font-size-h1: 4rem;
    --font-size-h2: 2.5rem;
    --font-size-h3: 2rem;
    --font-size-h4: 1.75rem;
    --font-size-h5: 1.5rem;
    --font-size-xl: 1.25rem;
    --font-size-lg: 1.125rem;
    --font-size-base: 1rem;
    --font-size-sm: 0.875rem;
    --font-size-xs: 0.75rem;
  }
}

/* svgアイコン */
.c_card {
  overflow: hidden;
  background: #fff;
  border: 1px solid #e9e9e9;
  border-radius: 8px;
}
.c_card_img {
  overflow: hidden;
}
.c_card_img img {
  transition: scale 0.3s ease-in-out;
}
@media screen and (width < 48em) {
  .c_card_img img {
    width: 100%;
  }
}
.c_card_body {
  padding: 0 min(6.4vw,3rem) 1.5rem;
}
@media screen and (width >= 48em) {
  .c_card_body {
    padding: 0 min(2.3426061493vw,2rem) 2rem;
  }
}
.c_card_head {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}
.c_card_head time {
  font-family: "Red Hat Display", sans-serif;
  font-weight: 400;
  line-height: normal;
  font-size: min(3.7333333333vw,1.75rem);
}
@media screen and (width >= 48em) {
  .c_card_head time {
    font-size: 0.875rem;
  }
}
.c_card_cat {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  line-height: 1;
  font-size: min(3.2vw,1.5rem);
}
@media screen and (width >= 48em) {
  .c_card_cat {
    font-size: 0.75rem;
  }
}
.c_card_ttl {
  font-weight: 700;
  transition: color 0.4s ease-out;
}
@media (any-hover: hover) {
  .c_card:hover .c_card_ttl,
  .c_card:hover .c_link {
    color: #f80;
  }
  .c_card:hover .c_card_img img {
    scale: 1.08;
  }
}
.c_card:focus-visible .c_card_ttl,
.c_card:focus-visible .c_link, .c_card:active .c_card_ttl,
.c_card:active .c_link {
  color: #f80;
}
.c_card:focus-visible .c_card_img img, .c_card:active .c_card_img img {
  scale: 1.08;
}
.c_card.-horizon {
  display: grid;
  grid-template-columns: 1fr;
  background: none;
  border: 0;
}
@media screen and (width >= 48em) {
  .c_card.-horizon {
    grid-template-columns: auto 1fr;
    gap: min(1.756954612vw,1.5rem);
  }
  .c_card.-horizon .c_card_body {
    padding: 0;
  }
  .c_card.-horizon .c_card_head {
    gap: 1rem;
    margin-bottom: 0.5rem;
  }
}
.c_card.-horizon .c_card_img img {
  border-radius: 0.25rem;
}
:root {
  --color-txt: #272727;
  --color-reversal: #fff;
  --color-prime: #f80;
  --color-second: #06f;
  --color-third: #f5b400;
  --color-body: #fff;
  --color-gray: #f9f7f6;
  --font-size-h1: min(10.6666666667vw, 5rem);
  --font-size-h2: min(7.4666666667vw, 3.5rem);
  --font-size-h3: min(7.4666666667vw, 3.5rem);
  --font-size-h4: min(6.4vw, 3rem);
  --font-size-h5: min(5.3333333333vw, 2.5rem);
  --font-size-xl: min(4vw, 1.875rem);
  --font-size-lg: min(4.2666666667vw, 2rem);
  --font-size-base: min(4vw, 1.875rem);
  --font-size-sm: min(3.7333333333vw, 1.75rem);
  --font-size-xs: min(3.2vw, 1.5rem);
}
@media (width >= 48em) {
  :root {
    --font-size-h1: 4rem;
    --font-size-h2: 2.5rem;
    --font-size-h3: 2rem;
    --font-size-h4: 1.75rem;
    --font-size-h5: 1.5rem;
    --font-size-xl: 1.25rem;
    --font-size-lg: 1.125rem;
    --font-size-base: 1rem;
    --font-size-sm: 0.875rem;
    --font-size-xs: 0.75rem;
  }
}

/* svgアイコン */
.c_icon {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  align-items: center;
}
.c_icon_new {
  position: absolute;
  top: -0.5rem;
  left: 0.625rem;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.25rem 0.5rem 0.3125rem;
  margin: auto;
  font-family: "Red Hat Display", sans-serif;
  font-weight: 700;
  line-height: 1;
  color: #fff;
  background-color: #eb4000;
  border-radius: 1.5rem;
  transition: opacity 0.4s ease-out;
  font-size: min(2.6666666667vw,1.25rem);
}
@media screen and (width >= 48em) {
  .c_icon_new {
    font-size: 0.625rem;
  }
}
.c_icon_img {
  display: flex;
  align-items: center;
  justify-content: center;
  height: min(20vw,9.375rem);
  aspect-ratio: 1;
  padding: 1.25rem 1rem;
  background: #fff;
  border: 1px solid #dedfe5;
  border-radius: 1.5rem;
}
@media screen and (width >= 48em) {
  .c_icon_img {
    width: 5rem;
    height: 5rem;
  }
}
.c_icon_cap {
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.3;
  text-align: center;
  font-size: min(3.2vw,1.5rem);
}
@media screen and (width >= 48em) {
  .c_icon_cap {
    font-size: 0.875rem;
  }
}
.c_icon_link {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  margin: 0;
}
.c_icon:has(.top_function_item_link) .top_function_item_caption {
  text-decoration: underline;
  transition: color 0.4s ease-out;
}
@media (any-hover: hover) {
  .c_icon:has(.top_function_item_link):hover .top_function_item_icon {
    opacity: 0.5;
  }
  .c_icon:has(.top_function_item_link):hover .top_function_item_caption {
    color: #f80;
  }
}
.c_icon:has(.top_function_item_link):focus-visible .top_function_item_icon, .c_icon:has(.top_function_item_link):active .top_function_item_icon {
  opacity: 0.5;
}
.c_icon:has(.top_function_item_link):focus-visible .top_function_item_caption, .c_icon:has(.top_function_item_link):active .top_function_item_caption {
  color: #f80;
}
:root {
  --color-txt: #272727;
  --color-reversal: #fff;
  --color-prime: #f80;
  --color-second: #06f;
  --color-third: #f5b400;
  --color-body: #fff;
  --color-gray: #f9f7f6;
  --font-size-h1: min(10.6666666667vw, 5rem);
  --font-size-h2: min(7.4666666667vw, 3.5rem);
  --font-size-h3: min(7.4666666667vw, 3.5rem);
  --font-size-h4: min(6.4vw, 3rem);
  --font-size-h5: min(5.3333333333vw, 2.5rem);
  --font-size-xl: min(4vw, 1.875rem);
  --font-size-lg: min(4.2666666667vw, 2rem);
  --font-size-base: min(4vw, 1.875rem);
  --font-size-sm: min(3.7333333333vw, 1.75rem);
  --font-size-xs: min(3.2vw, 1.5rem);
}
@media (width >= 48em) {
  :root {
    --font-size-h1: 4rem;
    --font-size-h2: 2.5rem;
    --font-size-h3: 2rem;
    --font-size-h4: 1.75rem;
    --font-size-h5: 1.5rem;
    --font-size-xl: 1.25rem;
    --font-size-lg: 1.125rem;
    --font-size-base: 1rem;
    --font-size-sm: 0.875rem;
    --font-size-xs: 0.75rem;
  }
}

/* svgアイコン */
.c_link.-large .hasIcon::after {
  mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2213%22%20height%3D%2212%22%20viewBox%3D%220%200%2013%2012%22%20fill%3D%22none%22%3E%20%3Cpath%20d%3D%22M7%200.34375L12%205.60544L7%2010.8671%22%20stroke%3D%22%23272727%22%20stroke-miterlimit%3D%2210%22%2F%3E%20%3Crect%20y%3D%225.84375%22%20width%3D%220.999999%22%20height%3D%2212%22%20transform%3D%22rotate(-90%200%205.84375)%22%20fill%3D%22%23272727%22%2F%3E%3C%2Fsvg%3E");
}

.c_link {
  position: relative;
  display: flex;
  gap: min(4.2666666667vw,2rem);
  align-items: center;
  color: currentcolor;
  transition: color 0.4s ease-out;
}
@media screen and (width >= 48em) {
  .c_link {
    gap: 1rem;
  }
}
.c_link.-large .hasIcon {
  height: min(14.9333333333vw,7rem);
}
@media screen and (width >= 48em) {
  .c_link.-large .hasIcon {
    height: 3.5rem;
  }
}
.c_link.-large .hasIcon::after {
  mask-size: min(3.2vw,1.5rem);
}
@media screen and (width >= 48em) {
  .c_link.-large .hasIcon::after {
    mask-size: 0.75rem;
  }
}
@media (any-hover: hover) {
  .c_link.-large:hover {
    color: #f80;
  }
}
.c_link.-large:focus-visible, .c_link.-large:active {
  color: #f80;
}

.c_link_img[target=_blank]::after {
  content: none !important;
}
.c_link_img-cap {
  margin-top: 0.625rem;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  transition: color 0.4s ease-out;
}
.c_link_img-fig {
  overflow: hidden;
  border-radius: 0.25rem;
}
.c_link_img img {
  width: 100%;
  aspect-ratio: 8/5;
  transition: scale 0.4s ease-out;
}
.c_link_img .hasIcon {
  height: 1.5rem;
}
@media screen and (width >= 48em) {
  .c_link_img .hasIcon {
    height: min(1.756954612vw,1.5rem);
  }
}
@media screen and (width >= 48em) {
  .c_link_img .hasIcon::after {
    mask-size: min(0.5856515373vw,0.5rem);
  }
}
@media (any-hover: hover) {
  .c_link_img:hover .c_link_img-cap {
    color: #f80;
  }
  .c_link_img:hover .c_link_img-fig img {
    scale: 1.1;
  }
}
.c_link_img:focus-visible .c_link_img-cap, .c_link_img:active .c_link_img-cap {
  color: #f80;
}
.c_link_img:focus-visible .c_link_img-fig img, .c_link_img:active .c_link_img-fig img {
  scale: 1.1;
}
:root {
  --color-txt: #272727;
  --color-reversal: #fff;
  --color-prime: #f80;
  --color-second: #06f;
  --color-third: #f5b400;
  --color-body: #fff;
  --color-gray: #f9f7f6;
  --font-size-h1: min(10.6666666667vw, 5rem);
  --font-size-h2: min(7.4666666667vw, 3.5rem);
  --font-size-h3: min(7.4666666667vw, 3.5rem);
  --font-size-h4: min(6.4vw, 3rem);
  --font-size-h5: min(5.3333333333vw, 2.5rem);
  --font-size-xl: min(4vw, 1.875rem);
  --font-size-lg: min(4.2666666667vw, 2rem);
  --font-size-base: min(4vw, 1.875rem);
  --font-size-sm: min(3.7333333333vw, 1.75rem);
  --font-size-xs: min(3.2vw, 1.5rem);
}
@media (width >= 48em) {
  :root {
    --font-size-h1: 4rem;
    --font-size-h2: 2.5rem;
    --font-size-h3: 2rem;
    --font-size-h4: 1.75rem;
    --font-size-h5: 1.5rem;
    --font-size-xl: 1.25rem;
    --font-size-lg: 1.125rem;
    --font-size-base: 1rem;
    --font-size-sm: 0.875rem;
    --font-size-xs: 0.75rem;
  }
}

/* svgアイコン */
/* モーダル  */
.c_modal {
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100dvh;
  padding: 3vh 0;
  margin: auto;
  overflow-y: auto;
  overscroll-behavior-y: none;
  background: none;
  border: 0;
}
.c_modal::backdrop {
  inset: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  margin: auto;
  content: "";
  background-color: rgba(0, 0, 0, 0.75);
  opacity: 0;
  transition: opacity 0.4s ease-out;
}
.c_modal_close {
  position: relative;
  z-index: 999;
  display: block;
  width: 2.5rem;
  height: 2.5rem;
  margin-inline: auto 0;
  appearance: none;
}
.c_modal_close:focus-visible {
  outline-color: #fff;
}
.c_modal_close::before, .c_modal_close::after {
  position: absolute;
  inset: 0;
  z-index: 999;
  width: 0.125rem;
  height: 2.1875rem;
  margin: auto;
  content: "";
  background-color: #fff;
  rotate: -45deg;
}
.c_modal_close::after {
  rotate: 45deg;
}
.c_modal {
  /* stylelint-disable-next-line no-descending-specificity */
}
.c_modal_content {
  position: absolute;
  inset: 0;
  max-width: 78rem;
  height: fit-content;
  max-height: 90%;
  padding: 0 min(10.6666666667vw,5rem);
  margin: auto;
  opacity: 0;
  transition: opacity 0.4s ease-out;
}
@media screen and (width >= 48em) {
  .c_modal_content {
    padding: 0 1.5rem;
  }
}
.c_modal_content:has(iframe) {
  width: auto;
}
.c_modal_content figure {
  width: fit-content;
  margin: auto;
}
.c_modal_content iframe {
  aspect-ratio: 16/9;
}
.c_modal[open] .c_modal_content {
  animation: fade 1s ease 0s 1 forwards;
}
.c_modal[open]::backdrop {
  opacity: 1;
  transition: opacity 0.4s ease-out;
}

/* /モーダル  */
:root {
  --color-txt: #272727;
  --color-reversal: #fff;
  --color-prime: #f80;
  --color-second: #06f;
  --color-third: #f5b400;
  --color-body: #fff;
  --color-gray: #f9f7f6;
  --font-size-h1: min(10.6666666667vw, 5rem);
  --font-size-h2: min(7.4666666667vw, 3.5rem);
  --font-size-h3: min(7.4666666667vw, 3.5rem);
  --font-size-h4: min(6.4vw, 3rem);
  --font-size-h5: min(5.3333333333vw, 2.5rem);
  --font-size-xl: min(4vw, 1.875rem);
  --font-size-lg: min(4.2666666667vw, 2rem);
  --font-size-base: min(4vw, 1.875rem);
  --font-size-sm: min(3.7333333333vw, 1.75rem);
  --font-size-xs: min(3.2vw, 1.5rem);
}
@media (width >= 48em) {
  :root {
    --font-size-h1: 4rem;
    --font-size-h2: 2.5rem;
    --font-size-h3: 2rem;
    --font-size-h4: 1.75rem;
    --font-size-h5: 1.5rem;
    --font-size-xl: 1.25rem;
    --font-size-lg: 1.125rem;
    --font-size-base: 1rem;
    --font-size-sm: 0.875rem;
    --font-size-xs: 0.75rem;
  }
}

/* svgアイコン */
#newHeader .c_nav_close::after, #newHeader .c_nav_mega_close::after {
  mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2240%22%20height%3D%2240%22%20viewBox%3D%220%200%2040%2040%22%20fill%3D%22none%22%3E%20%3Crect%20x%3D%2212%22%20y%3D%2212.8477%22%20width%3D%220.999999%22%20height%3D%2220%22%20transform%3D%22rotate(-45%2012%2012.8477)%22%20fill%3D%22%23272727%22%2F%3E%20%3Crect%20x%3D%2213%22%20y%3D%2226.8496%22%20width%3D%220.999999%22%20height%3D%2220%22%20transform%3D%22rotate(-135%2013%2026.8496)%22%20fill%3D%22%23272727%22%2F%3E%3C%2Fsvg%3E");
}

/* stylelint-disable no-descending-specificity */
/* Gナビ  */
#newHeader .c_nav {
  position: relative;
  color: #272727;
}
#newHeader .c_nav::before {
  position: fixed;
  inset: 0 0 auto auto;
  z-index: -1;
  height: 3.75rem;
  aspect-ratio: 1;
  margin: auto;
  content: "";
  background-color: #dedfe5;
  border-radius: 50%;
  opacity: 0;
  transform: translateZ(0) scale(0);
  transition: transform 0.6s cubic-bezier(0.6, -0.01, 0.1, 1), opacity 0.2s ease-out 0.3s;
}
@media screen and (width >= 48em) {
  #newHeader .c_nav::before {
    content: none;
  }
}
#newHeader .c_nav .c_nav_menu {
  display: flex;
  flex-direction: column;
}
@media screen and (width >= 48em) {
  #newHeader .c_nav .c_nav_menu {
    flex-direction: row;
    gap: min(2.9282576867vw,2.5rem);
    align-items: center;
    justify-content: flex-end;
  }
}
#newHeader .c_nav .c_nav_menu li {
  position: relative;
}
@media screen and (width >= 48em) {
  #newHeader .c_nav .c_nav_menu li {
    display: flex;
  }
}
@media screen and (width < 48em) {
  #newHeader .c_nav .c_nav_menu li.has-child {
    overflow: hidden;
  }
}
#newHeader .c_nav .c_nav_menu li.has-child .spAccordion {
  position: absolute;
  inset: 0 0 0 auto;
  aspect-ratio: 1/1;
  margin: auto;
}
@media screen and (width >= 48em) {
  #newHeader .c_nav .c_nav_menu li.has-child .spAccordion {
    display: none;
  }
}
#newHeader .c_nav .c_nav_menu li.has-child .spAccordion > span {
  display: block;
  width: 100%;
  height: 100%;
  color: transparent;
  text-indent: -999rem;
}
#newHeader .c_nav .c_nav_menu li.has-child .spAccordion > span::before, #newHeader .c_nav .c_nav_menu li.has-child .spAccordion > span::after {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  margin: auto;
  content: "";
  transition: rotate 0.4s ease-out;
}
#newHeader .c_nav .c_nav_menu li.has-child .spAccordion > span::before {
  rotate: 90deg;
}
#newHeader .c_nav .c_nav_menu li.has-child .spAccordion.-open > span::before {
  rotate: none;
}
@media screen and (width >= 48em) {
  #newHeader .c_nav .c_nav_menu li.has-child > ul.subMenu {
    position: absolute;
    inset: 0 0 auto -50%;
    display: grid;
    visibility: hidden;
    grid-template-columns: 1fr;
    gap: 0.5rem;
    width: 200%;
    padding: 0.5rem;
    overflow: visible;
    background-color: #f80;
    opacity: 0;
    transition: top 0.8s cubic-bezier(0.165, 0.84, 0.44, 1), opacity 0.4s ease-out;
  }
}
@media screen and (width < 48em) {
  #newHeader .c_nav .c_nav_menu li.has-child > ul.subMenu {
    position: relative;
    visibility: hidden;
    height: 0;
    max-height: none;
    transition: height 0.4s ease-out, opacity 0.4s ease-out;
  }
  #newHeader .c_nav .c_nav_menu li.has-child > ul.subMenu.-open {
    visibility: visible;
    height: var(--subHeaderHeight);
    opacity: 1;
  }
}
#newHeader .c_nav .c_nav_menu li.has-child > ul.subMenu > li > a {
  color: #fff;
}
@media screen and (width >= 48em) {
  #newHeader .c_nav .c_nav_menu li.has-child > ul.subMenu > li > a::before {
    right: auto;
  }
}
#newHeader .c_nav .c_nav_menu li.has-child > ul.subMenu.-open {
  height: var(--subHeightOpen, auto);
}
@media screen and (width >= 48em) and (any-hover: hover) {
  #newHeader .c_nav .c_nav_menu li.has-child:hover ul.subMenu {
    top: 100%;
    visibility: visible;
    opacity: 1;
  }
}
@media screen and (width >= 48em) {
  #newHeader .c_nav .c_nav_menu li.has-child:focus-visible ul.subMenu, #newHeader .c_nav .c_nav_menu li.has-child:active ul.subMenu {
    top: 100%;
    visibility: visible;
    opacity: 1;
  }
  #newHeader .c_nav .c_nav_menu li.has-child:focus-within > ul.subMenu {
    top: 100%;
    visibility: visible;
    opacity: 1;
  }
}
#newHeader .c_nav .c_nav_btn {
  position: relative;
  z-index: 999;
  display: block;
  height: min(8.5333333333vw,4rem);
  aspect-ratio: 1;
  margin: auto;
  color: #272727;
}
@media screen and (width >= 48em) {
  #newHeader .c_nav .c_nav_btn {
    display: none;
    pointer-events: none;
  }
}
#newHeader .c_nav .c_nav_btn > span {
  position: absolute;
  inset: 0;
  width: min(3.7333333333vw,1.75rem);
  height: 0.125rem;
  margin: auto;
  color: inherit;
  text-indent: -999rem;
  background-color: currentcolor;
  transition: background-color 0.4s ease-out;
}
#newHeader .c_nav .c_nav_btn > span::before, #newHeader .c_nav .c_nav_btn > span::after {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 0.125rem;
  margin: auto;
  content: "";
  background-color: currentcolor;
  transition: rotate 0.4s ease-out, background-color 0.4s ease-out;
}
#newHeader .c_nav .c_nav_btn > span::before {
  top: min(1.6vw,0.75rem);
  bottom: auto;
}
#newHeader .c_nav .c_nav_btn > span::after {
  top: auto;
  bottom: min(1.6vw,0.75rem);
}
#newHeader .c_nav_wrapper {
  position: fixed;
  inset: 0;
  z-index: 998;
  display: none;
  visibility: hidden;
  width: 100%;
  height: 100dvh;
  padding: var(--headerHeight) min(4.2666666667vw,2rem) 2.5rem;
  opacity: 0;
  transition: opacity 0.3s ease-out 0.4s;
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_wrapper {
    position: relative;
    display: block;
    visibility: visible;
    width: 100%;
    height: 100%;
    padding: 0;
    margin: auto;
    overflow-y: visible;
    background-color: transparent;
    opacity: 1;
  }
}
@media screen and (width < 48em) {
  #newHeader .c_nav #navi {
    position: relative;
    z-index: 500;
    visibility: visible;
    height: 100%;
    overflow-y: auto;
    opacity: 1;
  }
}
#newHeader .c_nav.-open::before {
  opacity: 1;
  transform: translateZ(0) scale(80);
  transition: transform 0.8s cubic-bezier(0.4, 0.1, 0.3, 1), oapcity 0.3s cubic-bezier(0.4, 0.1, 0.3, 1) 0.5s;
}
@media screen and (width < 48em) {
  #newHeader .c_nav.-open .c_nav_wrapper {
    display: block;
    visibility: visible;
    opacity: 1;
  }
  #newHeader .c_nav.-open .c_nav_wrapper #navi {
    visibility: visible;
    animation: fade 0.4s ease-out;
  }
}
#newHeader .c_nav.-open .c_nav_btn span {
  background-color: transparent;
}
#newHeader .c_nav.-open .c_nav_btn span::before, #newHeader .c_nav.-open .c_nav_btn span::after {
  inset: 0;
  rotate: 45deg;
}
#newHeader .c_nav.-open .c_nav_btn span::after {
  rotate: -45deg;
}
#newHeader .c_nav.-open .c_nav_inner {
  opacity: 1;
}
#newHeader .c_nav_close {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem 0 0;
  margin: auto;
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(4vw,1.875rem);
  line-height: 0;
  color: #444;
  cursor: pointer;
  transition: color 0.4s ease-out;
}
#newHeader .c_nav_close::after {
  display: block;
  height: min(10.6666666667vw,5rem);
  aspect-ratio: 1;
  content: "";
  transform: translateY(0.125rem);
  transition: background-color 0.4s ease-out;
  background-color: #272727;
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: 100%;
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_close {
    display: none;
  }
}
#newHeader .c_nav_inner {
  position: static;
  top: 0;
  right: 0;
  display: flex;
  flex-direction: column;
  width: 100%;
  height: auto;
  max-height: calc(95dvh - var(--headerHeight));
  padding: 1.5rem 0 1rem;
  overflow-y: auto;
  background-color: #fff;
  border-radius: 0.5rem;
  opacity: 0;
  transition: opacity 0.4s ease-out;
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_inner {
    position: static;
    display: flex;
    flex-direction: row;
    gap: min(2.9282576867vw,2.5rem);
    align-items: center;
    justify-content: flex-end;
    width: auto;
    max-width: none;
    height: auto;
    padding: 0;
    overflow: visible;
    background: transparent;
    border-radius: 0;
    opacity: 1;
    transform: none;
  }
}
#newHeader .c_nav_menu {
  display: flex;
  flex-direction: column;
  gap: 0;
}
@media screen and (width < 48em) {
  #newHeader .c_nav_menu {
    padding-inline: min(6.4vw,3rem);
  }
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_menu {
    flex-direction: row;
    gap: min(2.3426061493vw,2rem);
    align-items: center;
  }
}
#newHeader .c_nav_item {
  position: relative;
}
@media screen and (width < 48em) {
  #newHeader .c_nav_item {
    border-bottom: 0.0625rem solid #d9d9d9;
  }
}
#newHeader .c_nav_item > a {
  position: relative;
  z-index: 110;
  display: block;
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(3.2vw,1.5rem);
  color: currentcolor;
  text-decoration: none;
  transition: color 0.4s ease-out, background-color 0.4s ease-out;
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_item > a {
    font-size: min(1.0248901903vw,0.875rem);
    font-weight: 500;
  }
}
@media screen and (width < 48em) {
  #newHeader .c_nav_item > a {
    padding-block: 1rem;
  }
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_item > a::after {
    position: absolute;
    bottom: -0.3em;
    left: 0;
    width: 0;
    height: 0.0625rem;
    margin: auto;
    content: "";
    background-color: currentcolor;
    transition: width 0.4s ease-out;
  }
}
@media (any-hover: hover) {
  #newHeader .c_nav_item > a:hover {
    color: #f80;
  }
  #newHeader .c_nav_item > a:hover::after {
    width: 100%;
  }
}
#newHeader .c_nav_item > a:focus-visible, #newHeader .c_nav_item > a:active {
  color: #f80;
}
#newHeader .c_nav_item > a:focus-visible::after, #newHeader .c_nav_item > a:active::after {
  width: 100%;
}
#newHeader .c_nav_item.-hasChild > a {
  padding-right: 1.5rem;
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_item.-hasChild > a {
    padding-right: 1.25rem;
  }
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_item.-hasChild:hover > a, #newHeader .c_nav_item.-hasChild:focus-within > a {
    color: #f80;
  }
  #newHeader .c_nav_item.-hasChild:hover .c_nav_child, #newHeader .c_nav_item.-hasChild:focus-within .c_nav_child {
    top: 100%;
    visibility: visible;
    opacity: 1;
  }
  #newHeader .c_nav_item.-hasChild:hover .c_nav_trigger::before, #newHeader .c_nav_item.-hasChild:focus-within .c_nav_trigger::before {
    border-color: #f80;
    transform: rotate(-135deg) translateY(-0.125rem);
    transform-origin: center;
  }
}
#newHeader .c_nav_item.-open .c_nav_trigger::before {
  transform: rotate(225deg);
}
#newHeader .c_nav_item.-open .c_nav_child {
  height: var(--childHeight, auto);
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_item.-open .c_nav_child {
    visibility: visible;
    height: auto;
    opacity: 1;
  }
}
#newHeader .c_nav_trigger {
  position: absolute;
  top: 0.8125rem;
  right: 0;
  z-index: 120;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  color: currentcolor;
  cursor: pointer;
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_trigger {
    top: 0;
    height: 100%;
  }
}
#newHeader .c_nav_trigger::before {
  width: 0.5rem;
  height: 0.5rem;
  content: "";
  background: transparent;
  border: solid currentcolor;
  border-width: 0 0.0625rem 0.0625rem 0;
  transform: rotate(45deg) translateY(-0.125rem);
  transition: transform 0.2s;
}
#newHeader .c_nav_trigger::after {
  content: none;
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_trigger::before {
    width: 0.375rem;
    height: 0.375rem;
    background: transparent;
    border: solid currentcolor;
    border-width: 0 0.125rem 0.125rem 0;
    transform: rotate(45deg) translateY(-0.125rem);
  }
  #newHeader .c_nav_trigger::after {
    content: none;
  }
}
#newHeader .c_nav_child {
  height: 0;
  padding-left: 1rem;
  overflow: hidden;
  list-style: none;
  transition: height 0.3s ease;
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_child {
    position: absolute;
    top: calc(100% + 0.625rem);
    left: 50%;
    visibility: hidden;
    min-width: 12.5rem;
    height: auto;
    padding: 0.5rem 0;
    overflow: visible;
    background: #f80;
    border-radius: 0.25rem;
    box-shadow: 0 0.25rem 1rem rgba(0, 0, 0, 0.1);
    opacity: 0;
    transform: translateX(-50%);
    transition: top 0.3s ease, opacity 0.2s ease, visibility 0.2s;
  }
}
#newHeader .c_nav_child li a {
  display: block;
  padding: 0.75rem 0;
  font-size: 0.875rem;
  color: currentcolor;
  text-decoration: none;
  transition: color 0.4s ease-out, background-color 0.4s ease-out;
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_child li a {
    padding: 0.625rem 1rem;
    color: #fff;
  }
}
@media screen and (any-hover: hover) and (width >= 48em) {
  #newHeader .c_nav_child li a:hover {
    background: rgba(255, 255, 255, 0.1);
  }
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_child li a:focus-visible, #newHeader .c_nav_child li a:active {
    background: rgba(255, 255, 255, 0.1);
  }
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_child.-mega {
    left: 50%;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.5rem;
    width: max-content;
    min-width: 25rem;
    max-width: 37.5rem;
    padding: 1.5rem;
    transform: translateX(-50%);
  }
  #newHeader .c_nav_child.-mega li a {
    padding: 0.75rem 1rem;
    border-radius: 0.25rem;
  }
}
@media screen and (width >= 48em) and (any-hover: hover) {
  #newHeader .c_nav_child.-mega li a:hover {
    background: rgba(255, 255, 255, 0.1);
  }
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_child.-mega li a:focus-visible, #newHeader .c_nav_child.-mega li a:active {
    background: rgba(255, 255, 255, 0.1);
  }
}
#newHeader .c_nav_spOnly {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.375rem min(4.2666666667vw,2rem);
  padding: 1.5rem min(6.4vw,3rem) 1rem;
}
#newHeader .c_nav_spOnly_link {
  display: inline-flex;
  gap: 0.25rem;
  align-items: center;
  font-size: min(3.2vw,1.5rem);
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_spOnly_link {
    font-size: 0.75rem;
  }
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_spOnly {
    display: none;
  }
}
#newHeader .c_nav_cta {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-top: 1.5rem;
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_cta {
    flex-direction: row;
    gap: min(0.878477306vw,0.75rem);
    margin-top: 0;
  }
}
@media screen and (width < 48em) {
  #newHeader .c_nav_cta {
    padding-inline: min(6.4vw,3rem);
    padding-bottom: 1rem;
  }
}
#newHeader .c_nav_cta .c_btn_cta {
  height: min(13.3333333333vw,6.25rem);
  font-size: min(4vw,1.875rem);
  color: #fff;
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_cta .c_btn_cta {
    width: min(13.9092240117vw,11.875rem);
    height: min(3.6603221083vw,3.125rem);
    font-size: min(1.0248901903vw,0.875rem);
  }
}
#newHeader .c_nav_mega_wrapper {
  height: 0;
  overflow: hidden;
  transition: height 0.3s ease;
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_mega_wrapper {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 100;
    display: block;
    visibility: hidden;
    width: 100%;
    height: auto;
    padding: var(--headerHeight, 5rem) min(1.6837481698vw,1.4375rem) 0;
    overflow: visible;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.3s ease, visibility 0.3s;
  }
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_mega_box {
    width: 100%;
    height: auto;
    max-height: calc(100dvh - var(--headerHeight));
    margin: 0 auto;
    overflow-y: auto;
    overscroll-behavior: auto;
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 0.25rem 0.625rem 0 rgba(0, 0, 0, 0.1);
  }
}
#newHeader .c_nav_mega_inner {
  padding: 1rem 0.5rem 0;
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_mega_inner {
    width: 100%;
    max-width: 80rem;
    padding: min(2.9282576867vw,2.5rem);
    margin: 0 auto;
  }
}
@media screen and (width < 48em) {
  #newHeader .c_nav_mega_inner {
    border-top: 0.0625rem solid #d9d9d9;
  }
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_mega_head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.5rem;
  }
}
#newHeader .c_nav_mega_head > a {
  display: flex;
  gap: min(1.1713030747vw,1rem);
  align-items: center;
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(1.1713030747vw,1rem);
  line-height: 1.8;
  color: #272727;
  text-decoration: none;
  transition: color 0.4s ease-out;
}
@media screen and (width < 48em) {
  #newHeader .c_nav_mega_head > a {
    flex-direction: row-reverse;
    width: fit-content;
    font-size: min(4vw,1.875rem);
    font-weight: 700;
  }
}
#newHeader .c_nav_mega_head > a .hasIcon {
  height: min(6.4vw,3rem);
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_mega_head > a .hasIcon {
    height: min(2.635431918vw,2.25rem);
  }
}
#newHeader .c_nav_mega_head > a .hasIcon::after {
  mask-size: min(2.1333333333vw,1rem);
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_mega_head > a .hasIcon::after {
    mask-size: min(0.5856515373vw,0.5rem);
  }
}
@media (any-hover: hover) {
  #newHeader .c_nav_mega_head > a:hover {
    color: #f80;
  }
}
#newHeader .c_nav_mega_head > a:focus-visible, #newHeader .c_nav_mega_head > a:active {
  color: #f80;
}
#newHeader .c_nav_mega_ttl {
  font-family: ryo-gothic-plusn, sans-serif;
  font-size: min(1.4641288433vw,1.25rem);
  font-weight: 700;
  line-height: 1.3;
}
@media screen and (width < 48em) {
  #newHeader .c_nav_mega_ttl {
    display: none;
  }
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_mega_close {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem 0;
    margin: auto;
    font-family: "Noto Sans JP", sans-serif;
    font-size: min(1.1713030747vw,1rem);
    line-height: 0;
    color: #444;
    cursor: pointer;
    transition: color 0.4s ease-out;
  }
}
@media screen and (width < 48em) {
  #newHeader .c_nav_mega_close {
    display: none;
  }
}
#newHeader .c_nav_mega_close::after {
  display: block;
  height: min(2.9282576867vw,2.5rem);
  aspect-ratio: 1;
  content: "";
  transform: translateY(0.125rem);
  transition: background-color 0.4s ease-out;
  background-color: #272727;
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: 100%;
}
@media (any-hover: hover) {
  #newHeader .c_nav_mega_close:hover {
    color: #f80;
  }
  #newHeader .c_nav_mega_close:hover::after {
    background-color: #f80;
  }
}
#newHeader .c_nav_mega_close:focus-visible, #newHeader .c_nav_mega_close:active {
  color: #f80;
}
#newHeader .c_nav_mega_close:focus-visible::after, #newHeader .c_nav_mega_close:active::after {
  background-color: #f80;
}
#newHeader .c_nav_mega_hr {
  margin-block: 0;
  color: #e9e9e9;
}
#newHeader .megaDemo_list {
  display: grid;
  gap: 1rem;
}
@media screen and (width >= 48em) {
  #newHeader .megaDemo_list {
    grid-template-columns: repeat(5, minmax(auto, 1fr));
    gap: min(2.3426061493vw,2rem);
  }
}
@media screen and (width >= 48em) {
  #newHeader .megaDemo_list.-large {
    grid-template-columns: repeat(4, minmax(auto, 1fr));
  }
}
@media screen and (width < 48em) {
  #newHeader .megaDemo_list.-large {
    padding-top: 1rem;
  }
}
@media screen and (width < 48em) {
  #newHeader .megaDemo_list .c_link_img-fig {
    display: none;
  }
}
#newHeader .megaDemo_list .c_link_img-cap {
  font-size: min(1.1713030747vw,1rem);
}
@media screen and (width < 48em) {
  #newHeader .megaDemo_list .c_link_img-cap {
    gap: min(2.1333333333vw,1rem);
    margin-top: 0;
    font-size: min(4vw,1.875rem);
  }
}
#newHeader .megaScene {
  display: grid;
  grid-template-columns: 1fr;
}
@media screen and (width >= 48em) {
  #newHeader .megaScene {
    gap: 1.5rem;
  }
}
@media screen and (width < 48em) {
  #newHeader .megaScene {
    gap: 1rem;
    padding-bottom: 1rem;
  }
}
@media screen and (width < 48em) {
  #newHeader .megaDemo {
    padding-bottom: 1rem;
  }
}
#newHeader .megaFunction {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
}
@media screen and (width >= 48em) {
  #newHeader .megaFunction {
    grid-template-columns: repeat(4, minmax(auto, 1fr));
    gap: min(1.756954612vw,1.5rem);
  }
}
@media screen and (width < 48em) {
  #newHeader .megaFunction .megaFunction_menu {
    padding-block: 1rem;
  }
  #newHeader .megaFunction .megaFunction_menu:not(:last-child) {
    border-bottom: 0.0625rem solid #e9e9e9;
  }
}
#newHeader .megaFunction_ttl {
  flex-direction: row;
  gap: min(2.1333333333vw,1rem);
  margin-bottom: 1rem;
}
@media screen and (width >= 48em) {
  #newHeader .megaFunction_ttl {
    gap: min(0.5856515373vw,0.5rem);
  }
}
#newHeader .megaFunction .c_icon_cap {
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(4vw,1.875rem);
  font-feature-settings: "palt";
  line-height: 1.8;
}
@media screen and (width >= 48em) {
  #newHeader .megaFunction .c_icon_cap {
    font-size: min(1.1713030747vw,1rem);
  }
}
#newHeader .megaFunction .c_icon_img {
  width: min(9.6vw,4.5rem);
  height: min(9.6vw,4.5rem);
  padding: 0.3125rem;
  border-radius: 0.75rem;
}
@media screen and (width >= 48em) {
  #newHeader .megaFunction .c_icon_img {
    width: min(4.0995607613vw,3.5rem);
    height: min(4.0995607613vw,3.5rem);
    border-radius: 1.25rem;
  }
}
#newHeader .megaFunction .c_icon_img img {
  width: min(5.3333333333vw,2.5rem);
}
@media screen and (width >= 48em) {
  #newHeader .megaFunction .c_icon_img img {
    width: min(2.3426061493vw,2rem);
  }
}
#newHeader .megaFunction_list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}
@media screen and (width >= 48em) {
  #newHeader .megaFunction_list {
    gap: 0.625rem;
  }
}
#newHeader .megaFunction_link {
  position: relative;
  display: flex;
  align-items: center;
  font-family: "Noto Sans JP", sans-serif;
  font-size: min(3.7333333333vw,1.75rem);
  font-feature-settings: "palt";
  color: #272727;
  transition: color 0.4s ease-out;
}
@media screen and (width >= 48em) {
  #newHeader .megaFunction_link {
    font-size: min(1.0980966325vw,0.9375rem);
  }
}
#newHeader .megaFunction_link::before {
  display: block;
  height: 0.25rem;
  aspect-ratio: 1;
  margin-inline: 0.625rem;
  content: "";
  border: 0.0625rem solid currentcolor;
  border-width: 0.0625rem 0.0625rem 0 0;
  rotate: 45deg;
}
@media (any-hover: hover) {
  #newHeader .megaFunction_link:hover {
    color: #f80;
  }
}
#newHeader .megaFunction_link:focus-visible, #newHeader .megaFunction_link:active {
  color: #f80;
}

@media screen and (width >= 48em) {
  #newHeader .c_nav_item.-hasChild.-open .c_nav_mega_wrapper,
  #newHeader .c_nav_item.-hasChild:focus-within .c_nav_mega_wrapper {
    visibility: visible;
    pointer-events: auto;
    opacity: 1;
  }
}

#newHeader .c_nav_item.-open .c_nav_mega_wrapper {
  height: var(--childHeight, auto);
}
@media screen and (width >= 48em) {
  #newHeader .c_nav_item.-open .c_nav_mega_wrapper {
    height: auto;
  }
}

/* /Gナビ  */
:root {
  --color-txt: #272727;
  --color-reversal: #fff;
  --color-prime: #f80;
  --color-second: #06f;
  --color-third: #f5b400;
  --color-body: #fff;
  --color-gray: #f9f7f6;
  --font-size-h1: min(10.6666666667vw, 5rem);
  --font-size-h2: min(7.4666666667vw, 3.5rem);
  --font-size-h3: min(7.4666666667vw, 3.5rem);
  --font-size-h4: min(6.4vw, 3rem);
  --font-size-h5: min(5.3333333333vw, 2.5rem);
  --font-size-xl: min(4vw, 1.875rem);
  --font-size-lg: min(4.2666666667vw, 2rem);
  --font-size-base: min(4vw, 1.875rem);
  --font-size-sm: min(3.7333333333vw, 1.75rem);
  --font-size-xs: min(3.2vw, 1.5rem);
}
@media (width >= 48em) {
  :root {
    --font-size-h1: 4rem;
    --font-size-h2: 2.5rem;
    --font-size-h3: 2rem;
    --font-size-h4: 1.75rem;
    --font-size-h5: 1.5rem;
    --font-size-xl: 1.25rem;
    --font-size-lg: 1.125rem;
    --font-size-base: 1rem;
    --font-size-sm: 0.875rem;
    --font-size-xs: 0.75rem;
  }
}

/* svgアイコン */
/* タブ  */
.c_tab_list button[tabindex="-1"] {
  color: #f80;
  pointer-events: none;
  background-color: #fff;
}
.c_tab_content {
  animation: fade 0.4s ease-out;
}
.c_tab_content[hidden] {
  opacity: 0;
}
:root {
  --color-txt: #272727;
  --color-reversal: #fff;
  --color-prime: #f80;
  --color-second: #06f;
  --color-third: #f5b400;
  --color-body: #fff;
  --color-gray: #f9f7f6;
  --font-size-h1: min(10.6666666667vw, 5rem);
  --font-size-h2: min(7.4666666667vw, 3.5rem);
  --font-size-h3: min(7.4666666667vw, 3.5rem);
  --font-size-h4: min(6.4vw, 3rem);
  --font-size-h5: min(5.3333333333vw, 2.5rem);
  --font-size-xl: min(4vw, 1.875rem);
  --font-size-lg: min(4.2666666667vw, 2rem);
  --font-size-base: min(4vw, 1.875rem);
  --font-size-sm: min(3.7333333333vw, 1.75rem);
  --font-size-xs: min(3.2vw, 1.5rem);
}
@media (width >= 48em) {
  :root {
    --font-size-h1: 4rem;
    --font-size-h2: 2.5rem;
    --font-size-h3: 2rem;
    --font-size-h4: 1.75rem;
    --font-size-h5: 1.5rem;
    --font-size-xl: 1.25rem;
    --font-size-lg: 1.125rem;
    --font-size-base: 1rem;
    --font-size-sm: 0.875rem;
    --font-size-xs: 0.75rem;
  }
}

/* svgアイコン */
.c_tag_list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem min(1.0666666667vw,0.5rem);
}
@media screen and (width >= 48em) {
  .c_tag_list {
    gap: min(0.5856515373vw,0.5rem);
  }
}
.c_tag {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.5rem 0.75rem;
  line-height: 1;
  color: #444;
  background-color: #fff;
  border: 1px solid #e9e9e9;
  border-radius: 999rem;
  font-size: min(2.6666666667vw,1.25rem);
}
@media screen and (width >= 48em) {
  .c_tag {
    font-size: 0.75rem;
  }
}
@media screen and (width >= 48em) {
  .c_tag {
    padding: 0.5rem 0.75rem;
  }
}
:root {
  --color-txt: #272727;
  --color-reversal: #fff;
  --color-prime: #f80;
  --color-second: #06f;
  --color-third: #f5b400;
  --color-body: #fff;
  --color-gray: #f9f7f6;
  --font-size-h1: min(10.6666666667vw, 5rem);
  --font-size-h2: min(7.4666666667vw, 3.5rem);
  --font-size-h3: min(7.4666666667vw, 3.5rem);
  --font-size-h4: min(6.4vw, 3rem);
  --font-size-h5: min(5.3333333333vw, 2.5rem);
  --font-size-xl: min(4vw, 1.875rem);
  --font-size-lg: min(4.2666666667vw, 2rem);
  --font-size-base: min(4vw, 1.875rem);
  --font-size-sm: min(3.7333333333vw, 1.75rem);
  --font-size-xs: min(3.2vw, 1.5rem);
}
@media (width >= 48em) {
  :root {
    --font-size-h1: 4rem;
    --font-size-h2: 2.5rem;
    --font-size-h3: 2rem;
    --font-size-h4: 1.75rem;
    --font-size-h5: 1.5rem;
    --font-size-xl: 1.25rem;
    --font-size-lg: 1.125rem;
    --font-size-base: 1rem;
    --font-size-sm: 0.875rem;
    --font-size-xs: 0.75rem;
  }
}

/* svgアイコン */
/* 見出し  */
@layer components {
  .c_ttl_top {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
    letter-spacing: 0;
  }
  .c_ttl_top-en {
    font-family: "Red Hat Display", sans-serif;
    font-weight: 600;
    line-height: 1;
    color: currentcolor;
    font-size: min(5.3333333333vw,2.5rem);
  }
  @media screen and (width >= 48em) {
    .c_ttl_top-en {
      font-size: 1.25rem;
    }
  }
  .c_ttl_top-jp {
    font-family: ryo-gothic-plusn, sans-serif;
    font-weight: 700;
    line-height: 1.3;
    font-size: min(8.5333333333vw,4rem);
  }
  @media screen and (width >= 48em) {
    .c_ttl_top-jp {
      font-size: 3rem;
    }
  }
  .c_ttl_top.-center {
    text-align: center;
  }
  .c_ttl_top svg {
    display: inline-block;
    vertical-align: bottom;
  }
}
/* /見出し  */
:root {
  --color-txt: #272727;
  --color-reversal: #fff;
  --color-prime: #f80;
  --color-second: #06f;
  --color-third: #f5b400;
  --color-body: #fff;
  --color-gray: #f9f7f6;
  --font-size-h1: min(10.6666666667vw, 5rem);
  --font-size-h2: min(7.4666666667vw, 3.5rem);
  --font-size-h3: min(7.4666666667vw, 3.5rem);
  --font-size-h4: min(6.4vw, 3rem);
  --font-size-h5: min(5.3333333333vw, 2.5rem);
  --font-size-xl: min(4vw, 1.875rem);
  --font-size-lg: min(4.2666666667vw, 2rem);
  --font-size-base: min(4vw, 1.875rem);
  --font-size-sm: min(3.7333333333vw, 1.75rem);
  --font-size-xs: min(3.2vw, 1.5rem);
}
@media (width >= 48em) {
  :root {
    --font-size-h1: 4rem;
    --font-size-h2: 2.5rem;
    --font-size-h3: 2rem;
    --font-size-h4: 1.75rem;
    --font-size-h5: 1.5rem;
    --font-size-xl: 1.25rem;
    --font-size-lg: 1.125rem;
    --font-size-base: 1rem;
    --font-size-sm: 0.875rem;
    --font-size-xs: 0.75rem;
  }
}

/* svgアイコン */
.hasIcon::after {
  mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%229%22%20height%3D%227%22%20viewBox%3D%220%200%209%207%22%20fill%3D%22none%22%3E%20%3Cpath%20d%3D%22M5%200.34375L8%203.50077L5%206.65778%22%20stroke%3D%22%23272727%22%20stroke-miterlimit%3D%2210%22%2F%3E%20%3Crect%20y%3D%223.84375%22%20width%3D%221%22%20height%3D%228%22%20transform%3D%22rotate(-90%200%203.84375)%22%20fill%3D%22%23272727%22%2F%3E%3C%2Fsvg%3E");
}

@layer base {
  .contentInner {
    width: 100%;
    max-width: 78rem;
    padding: 0 min(6.4vw,3rem);
    margin: auto;
  }
  @media screen and (width >= 48em) {
    .contentInner {
      padding: 0 1.5rem;
    }
  }
  @media screen and (width < 48em) {
    .pcOnly {
      display: none !important;
    }
  }
  @media screen and (width >= 48em) {
    .spOnly {
      display: none !important;
    }
  }
  .txtHidden {
    position: absolute;
    width: 0.0625rem;
    height: 0.0625rem;
    overflow: hidden;
    white-space: nowrap;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
  }
  .countReset {
    counter-reset: number 0;
  }
  .skipLink:focus-visible {
    z-index: 999;
    width: 100%;
    height: 1.5em;
    color: #fff;
    outline-offset: 0;
    background-color: #f80;
    clip: unset;
    clip-path: none;
  }
  .frameWrapper {
    position: relative;
    width: 100%;
    aspect-ratio: 16/9;
  }
  .frameWrapper iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    border: 0;
  }
  .hasIcon {
    position: relative;
    display: inline-flex;
    gap: 0.625rem;
    align-items: center;
    height: min(9.6vw,4.5rem);
    aspect-ratio: 1;
  }
  @media screen and (width >= 48em) {
    .hasIcon {
      height: 2.25rem;
    }
  }
  .hasIcon::before, .hasIcon::after {
    position: absolute;
    inset: 0;
    display: block;
    height: 100%;
    aspect-ratio: 1;
    margin: auto;
    content: "";
    border-radius: 50%;
  }
  .hasIcon::before {
    border: 0.0625rem solid #c8c8c8;
    transition: background-color 0.4s ease-out;
  }
  .hasIcon::after {
    background-color: currentColor;
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: 100%;
    mask-size: min(2.1333333333vw,1rem);
  }
  @media screen and (width >= 48em) {
    .hasIcon::after {
      mask-size: 0.5rem;
    }
  }
}
:root {
  --color-txt: #272727;
  --color-reversal: #fff;
  --color-prime: #f80;
  --color-second: #06f;
  --color-third: #f5b400;
  --color-body: #fff;
  --color-gray: #f9f7f6;
  --font-size-h1: min(10.6666666667vw, 5rem);
  --font-size-h2: min(7.4666666667vw, 3.5rem);
  --font-size-h3: min(7.4666666667vw, 3.5rem);
  --font-size-h4: min(6.4vw, 3rem);
  --font-size-h5: min(5.3333333333vw, 2.5rem);
  --font-size-xl: min(4vw, 1.875rem);
  --font-size-lg: min(4.2666666667vw, 2rem);
  --font-size-base: min(4vw, 1.875rem);
  --font-size-sm: min(3.7333333333vw, 1.75rem);
  --font-size-xs: min(3.2vw, 1.5rem);
}
@media (width >= 48em) {
  :root {
    --font-size-h1: 4rem;
    --font-size-h2: 2.5rem;
    --font-size-h3: 2rem;
    --font-size-h4: 1.75rem;
    --font-size-h5: 1.5rem;
    --font-size-xl: 1.25rem;
    --font-size-lg: 1.125rem;
    --font-size-base: 1rem;
    --font-size-sm: 0.875rem;
    --font-size-xs: 0.75rem;
  }
}

/* svgアイコン */
.top_contact_button .hasIcon::after {
  mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2213%22%20height%3D%2212%22%20viewBox%3D%220%200%2013%2012%22%20fill%3D%22none%22%3E%20%3Cpath%20d%3D%22M7%200.34375L12%205.60544L7%2010.8671%22%20stroke%3D%22%23272727%22%20stroke-miterlimit%3D%2210%22%2F%3E%20%3Crect%20y%3D%225.84375%22%20width%3D%220.999999%22%20height%3D%2212%22%20transform%3D%22rotate(-90%200%205.84375)%22%20fill%3D%22%23272727%22%2F%3E%3C%2Fsvg%3E");
}

.top_function_item:has(.top_function_item_link) .top_function_item_caption::after {
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2216%22%20height%3D%2216%22%20viewBox%3D%220%200%2016%2016%22%20fill%3D%22none%22%3E%20%3Ccircle%20cx%3D%228%22%20cy%3D%228%22%20r%3D%228%22%20fill%3D%22%23FF8800%22%2F%3E%20%3Cpath%20d%3D%22M7%205L10%208L7%2011%22%20stroke%3D%22white%22%20stroke-miterlimit%3D%2210%22%2F%3E%3C%2Fsvg%3E");
}

.top_contact_button.-contact .top_contact_button_ttl::before {
  mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2232%22%20height%3D%2232%22%20viewBox%3D%220%200%2032%2032%22%20fill%3D%22none%22%3E%20%3Cg%20clip-path%3D%22url(%23clip0_31330_2672)%22%3E%20%3Cpath%20d%3D%22M27.665%200H4.33505C1.94457%200%200%201.94457%200%204.33505V27.6655C0%2030.056%201.94457%2032.0006%204.33505%2032.0006H27.6655C30.056%2032.0006%2032.0006%2030.056%2032.0006%2027.6655V4.33505C32.0006%201.94457%2030.056%200%2027.6655%200H27.665ZM15.2645%2030.451H4.33505C2.79875%2030.451%201.54902%2029.2013%201.54902%2027.665V16.7742H15.2645V30.4504V30.451ZM15.2645%2015.2252H1.54902V4.33505C1.54902%202.79875%202.79875%201.54902%204.33505%201.54902H15.265V15.2252H15.2645ZM30.451%2027.665C30.451%2029.2013%2029.2013%2030.451%2027.665%2030.451H16.8135V16.7748H30.451V27.6655V27.665ZM30.451%2015.2252H16.8135V1.54902H27.665C29.2013%201.54902%2030.451%202.79875%2030.451%204.33505V15.2258V15.2252Z%22%20fill%3D%22white%22%2F%3E%20%3Cpath%20d%3D%22M3.75391%208.64735C3.75391%209.07499%204.10078%209.42186%204.52842%209.42186H7.52909V12.4225C7.52909%2012.8502%207.87596%2013.197%208.3036%2013.197C8.73124%2013.197%209.07811%2012.8502%209.07811%2012.4225V9.42186H12.0788C12.5064%209.42186%2012.8533%209.07499%2012.8533%208.64735C12.8533%208.21971%2012.5064%207.87284%2012.0788%207.87284H9.07811V4.87217C9.07811%204.44453%208.73124%204.09766%208.3036%204.09766C7.87596%204.09766%207.52909%204.44453%207.52909%204.87217V7.87284H4.52842C4.10078%207.87284%203.75391%208.21971%203.75391%208.64735Z%22%20fill%3D%22white%22%2F%3E%20%3Cpath%20d%3D%22M7.20595%2023.3576L5.09485%2025.4903C4.7939%2025.7946%204.79667%2026.2847%205.10039%2026.5857C5.25142%2026.7351%205.44836%2026.8097%205.64531%2026.8097C5.84226%2026.8097%206.04418%2026.7328%206.19577%2026.5802L8.30686%2024.4475L10.4395%2026.5586C10.5906%2026.708%2010.7875%2026.7826%2010.9845%2026.7826C11.1814%2026.7826%2011.3833%2026.7057%2011.5349%2026.553C11.8359%2026.2488%2011.8331%2025.7586%2011.5294%2025.4577L9.39671%2023.3466L11.5078%2021.2139C11.8088%2020.9096%2011.806%2020.4195%2011.5023%2020.1185C11.198%2019.8176%2010.7078%2019.8203%2010.4069%2020.1241L8.29579%2022.2567L6.16313%2020.1456C5.85885%2019.8447%205.3687%2019.8474%205.06775%2020.1512C4.76679%2020.4554%204.76956%2020.9456%205.07328%2021.2465L7.20595%2023.3576Z%22%20fill%3D%22white%22%2F%3E%20%3Cpath%20d%3D%22M27.5671%207.87305H20.0167C19.5891%207.87305%2019.2422%208.21992%2019.2422%208.64756C19.2422%209.0752%2019.5891%209.42207%2020.0167%209.42207H27.5671C27.9947%209.42207%2028.3416%209.0752%2028.3416%208.64756C28.3416%208.21992%2027.9947%207.87305%2027.5671%207.87305Z%22%20fill%3D%22white%22%2F%3E%20%3Cpath%20d%3D%22M20.0167%2024.1271H27.5671C27.9947%2024.1271%2028.3416%2023.7803%2028.3416%2023.3526C28.3416%2022.925%2027.9947%2022.5781%2027.5671%2022.5781H20.0167C19.5891%2022.5781%2019.2422%2022.925%2019.2422%2023.3526C19.2422%2023.7803%2019.5891%2024.1271%2020.0167%2024.1271Z%22%20fill%3D%22white%22%2F%3E%20%3Cpath%20d%3D%22M23.7919%2021.8474C24.4264%2021.8474%2024.9431%2021.3307%2024.9431%2020.6962C24.9431%2020.0616%2024.4264%2019.5449%2023.7919%2019.5449C23.1573%2019.5449%2022.6406%2020.0611%2022.6406%2020.6962C22.6406%2021.3313%2023.1568%2021.8474%2023.7919%2021.8474Z%22%20fill%3D%22white%22%2F%3E%20%3Cpath%20d%3D%22M23.7919%2024.8574C23.1573%2024.8574%2022.6406%2025.3736%2022.6406%2026.0087C22.6406%2026.6438%2023.1568%2027.1599%2023.7919%2027.1599C24.427%2027.1599%2024.9431%2026.6432%2024.9431%2026.0087C24.9431%2025.3741%2024.4264%2024.8574%2023.7919%2024.8574Z%22%20fill%3D%22white%22%2F%3E%20%3C%2Fg%3E%20%3Cdefs%3E%20%3CclipPath%20id%3D%22clip0_31330_2672%22%3E%20%3Crect%20width%3D%2232%22%20height%3D%2232%22%20fill%3D%22white%22%2F%3E%20%3C%2FclipPath%3E%20%3C%2Fdefs%3E%3C%2Fsvg%3E");
}

.top_contact_button.-download .top_contact_button_ttl::before {
  mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2232%22%20height%3D%2232%22%20viewBox%3D%220%200%2032%2032%22%20fill%3D%22none%22%3E%20%3Cpath%20d%3D%22M5.74236%2026C5.06881%2026%204.4987%2025.7667%204.03203%2025.3C3.56536%2024.8333%203.33203%2024.2632%203.33203%2023.5897V8.41033C3.33203%207.73678%203.56536%207.16667%204.03203%206.7C4.4987%206.23333%205.06881%206%205.74236%206H26.255C26.9286%206%2027.4987%206.23333%2027.9654%206.7C28.432%207.16667%2028.6654%207.73678%2028.6654%208.41033V23.5897C28.6654%2024.2632%2028.432%2024.8333%2027.9654%2025.3C27.4987%2025.7667%2026.9286%2026%2026.255%2026H5.74236ZM15.9987%2016.7437L5.33203%209.923V23.5897C5.33203%2023.7094%205.37048%2023.8078%205.44736%2023.8847C5.52425%2023.9616%205.62259%2024%205.74236%2024H26.255C26.3748%2024%2026.4731%2023.9616%2026.55%2023.8847C26.6269%2023.8078%2026.6654%2023.7094%2026.6654%2023.5897V9.923L15.9987%2016.7437ZM15.9987%2014.6667L26.4604%208H5.53703L15.9987%2014.6667ZM5.33203%209.923V8V23.5897C5.33203%2023.7094%205.37048%2023.8078%205.44736%2023.8847C5.52425%2023.9616%205.62259%2024%205.74236%2024H5.33203V9.923Z%22%20fill%3D%22white%22%2F%3E%3C%2Fsvg%3E");
}

.top_about::before, .top_contact::before, .top_contact_button.-contact::before {
  mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22281%22%20height%3D%22281%22%20viewBox%3D%220%200%20281%20281%22%20fill%3D%22none%22%3E%20%3Cpath%20d%3D%22M140.489%20141.195V139.702C140.489%20138.649%20141.341%20137.788%20142.403%20137.788H278.977C280.058%20137.788%20280.928%20136.9%20280.891%20135.819C278.455%2060.7816%20217.139%200.608942%20141.634%200.00446787C63.1874%20-0.618324%20-1.0318%2063.9505%200.0125604%20142.358C1.05692%20220.766%2063.5355%20280.893%20140.479%20280.893C217.423%20280.893%20278.436%20220.5%20280.873%20145.069C280.91%20143.988%20280.03%20143.1%20278.958%20143.1H142.394C141.341%20143.1%20140.479%20142.248%20140.479%20141.186L140.489%20141.195Z%22%20fill%3D%22white%22%2F%3E%3C%2Fsvg%3E");
}

.top_bgContainer::before, .top_contact::after, .top_contact_button.-download::before {
  mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22281%22%20height%3D%22281%22%20viewBox%3D%220%200%20281%20281%22%20fill%3D%22none%22%3E%20%3Cpath%20d%3D%22M257.064%200H145.786C144.313%200%20143.116%201.20231%20143.116%202.68208V139.394C143.116%20140.874%20141.919%20142.076%20140.446%20142.076C138.973%20142.076%20137.776%20140.874%20137.776%20139.394V2.68208C137.776%201.20231%20136.579%200%20135.106%200H23.8284C6.05863%200%20-5.44111%2018.8485%202.62436%2034.7561L121.627%20269.309C129.462%20284.754%20151.43%20284.754%20159.275%20269.309L278.268%2034.7561C286.334%2018.8578%20274.834%200%20257.064%200Z%22%20fill%3D%22%23EF6926%22%2F%3E%3C%2Fsvg%3E");
}

.top_information::before {
  mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22244%22%20height%3D%22244%22%20viewBox%3D%220%200%20244%20244%22%20fill%3D%22none%22%3E%20%3Cpath%20d%3D%22M122%200C54.6189%200%200%2054.6189%200%20122V224.479C0%20235.261%208.7387%20244%2019.5209%20244H119.694V122H124.306V244H224.479C235.261%20244%20244%20235.261%20244%20224.479V122C244%2054.6189%20189.381%200%20122%200Z%22%20fill%3D%22url(%23paint0_linear_29726_5502)%22%2F%3E%20%3Cdefs%3E%20%3ClinearGradient%20id%3D%22paint0_linear_29726_5502%22%20x1%3D%22122%22%20y1%3D%220%22%20x2%3D%22122%22%20y2%3D%22244%22%20gradientUnits%3D%22userSpaceOnUse%22%3E%20%3Cstop%20stop-color%3D%22%2300BBFF%22%2F%3E%20%3Cstop%20offset%3D%221%22%20stop-color%3D%22%2300BBFF%22%20stop-opacity%3D%220.2%22%2F%3E%20%3C%2FlinearGradient%3E%20%3C%2Fdefs%3E%3C%2Fsvg%3E");
}

.p_top {
  overflow: hidden;
}

.top_hero {
  position: relative;
  width: 100%;
  height: 100vh;
  height: 100svh;
  overflow: hidden;
  background-color: #f80;
}
.top_hero.-collapsed {
  height: 0;
  min-height: 0;
  overflow: hidden;
}
.top_hero_bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.top_hero_bg picture,
.top_hero_bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.opening_grid {
  position: absolute;
  left: 50%;
  z-index: 20;
  pointer-events: none;
  transform: translateX(-50%);
}
body.-opening-complete .opening_grid {
  display: none !important;
}
.opening_grid_svg {
  grid-row: 1/-1;
  grid-column: 1/-1;
  width: 100%;
  height: 100%;
}
.opening_grid.-pc {
  bottom: calc(13.125vw + 1.3889vw + 8%);
  display: none;
  grid-template-rows: repeat(3, 13.125vw);
  grid-template-columns: repeat(7, 13.125vw);
  gap: 1.3889vw 0.33056vw;
}
@media screen and (width >= 48em) {
  .opening_grid.-pc {
    display: grid;
  }
}
.opening_grid.-sp {
  bottom: calc(21.333vw * 2 + 2.133vw + 3rem);
  display: grid;
  grid-template-rows: repeat(5, 21.333vw);
  grid-template-columns: repeat(4, 21.333vw);
  gap: 2.133vw 1.067vw;
}
@media screen and (width >= 48em) {
  .opening_grid.-sp {
    display: none;
  }
}

.opening_letter {
  will-change: opacity;
}

.hero_content {
  position: absolute;
  top: 50%;
  right: 0;
  left: 0;
  z-index: 15;
  width: 100%;
  max-width: 78rem;
  padding: 0 min(6.4vw,3rem);
  margin: auto;
  text-align: center;
  pointer-events: none;
  opacity: 0;
}
@media screen and (width >= 48em) {
  .hero_content {
    top: 35%;
    padding: 0 1.5rem;
  }
}
@media screen and (width < 48em) {
  .hero_content {
    top: auto;
    bottom: max(21.333vw * 3, 50%);
  }
}
.hero_content_ttl {
  width: fit-content;
  margin-inline: auto;
}

.eventos_container {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  z-index: 10;
  display: grid;
  grid-template-columns: repeat(4, 21.333vw);
  gap: 2.133vw 1.067vw;
  justify-content: center;
  transform: translateX(-50%);
}
@media screen and (width >= 48em) {
  .eventos_container {
    bottom: 8%;
    grid-template-columns: repeat(7, 13.125vw);
    gap: 0 0.33056vw;
  }
}

.letter_mask {
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  width: 21.333vw;
  height: 21.333vw;
  will-change: transform, opacity;
}
@media screen and (width >= 48em) {
  .letter_mask {
    width: 13.125vw;
    height: 13.125vw;
  }
}
.letter_mask picture,
.letter_mask img {
  width: 100%;
  height: 100%;
  aspect-ratio: 1;
  object-fit: contain;
}
.letter_mask:nth-child(1) {
  z-index: 7;
}
.letter_mask:nth-child(2) {
  z-index: 6;
}
.letter_mask:nth-child(3) {
  z-index: 5;
}
.letter_mask:nth-child(4) {
  z-index: 4;
}
.letter_mask:nth-child(5) {
  z-index: 3;
  grid-column: 2;
}
@media screen and (width >= 48em) {
  .letter_mask:nth-child(5) {
    grid-column: auto;
  }
}
.letter_mask:nth-child(6) {
  z-index: 2;
}
.letter_mask:nth-child(7) {
  z-index: 1;
}

.letter_svg {
  display: block;
  width: 100%;
  height: 100%;
}
.letter_svg image {
  transition: filter 0.3s ease;
}

.mv_logo {
  display: block;
  margin: auto;
  margin-top: 2.5rem;
}
@media screen and (width < 48em) {
  .mv_logo {
    width: min(20.5333333333vw,9.625rem);
    margin-top: 1.5rem;
  }
}

.hero_scroll_content {
  position: relative;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 100vh;
  min-height: 100svh;
  text-align: center;
  background-color: #f9f9f9;
}
.hero_scroll_content.-animating {
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0;
}

.top_about {
  position: relative;
  z-index: 1;
}
.top_about::before {
  position: absolute;
  right: -14.125rem;
  bottom: -18.8125rem;
  z-index: -1;
  display: block;
  height: 30rem;
  aspect-ratio: 1;
  margin: auto;
  content: "";
  background-image: linear-gradient(180deg, #ddecf9 0%, rgba(221, 236, 249, 0.2) 100%);
  background-blend-mode: multiply;
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
}
@media screen and (width >= 48em) {
  .top_about::before {
    right: -3.875rem;
    bottom: -35.75rem;
    height: 50.75rem;
  }
}
@media screen and (width >= 48em) {
  .top_about .c_ttl_top-jp {
    font-size: 2rem;
  }
}
.top_about_stats {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem min(2.1333333333vw,1rem);
  justify-content: center;
  margin: 2rem auto 0;
}
@media screen and (width >= 48em) {
  .top_about_stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
    max-width: 53.875rem;
  }
}
@media screen and (width < 48em) {
  .top_about_stats img {
    width: min(42.4vw,19.875rem);
  }
}
.top_about_stat {
  padding: 1.5rem;
  text-align: center;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 0.75rem;
  backdrop-filter: blur(10px);
}

.top_solutions {
  position: relative;
  z-index: 1;
  padding-block: 5.25rem 7.5rem;
  overflow: clip;
  background-color: rgba(238, 245, 250, 0.9);
}
@media screen and (width >= 48em) {
  .top_solutions {
    padding-block: 10rem;
  }
}
.top_solutions_grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 5.125rem;
}
@media screen and (width >= 48em) {
  .top_solutions_grid {
    grid-template-columns: 42% 1fr;
    gap: 1rem;
  }
  .top_solutions_grid .top_solutions_grid-right {
    padding-top: 2.5rem;
  }
}
.top_solutions_desc {
  margin-top: 2rem;
  font-family: "Noto Sans JP", sans-serif;
  line-height: 2;
  font-size: min(4.5333333333vw,2.125rem);
}
@media screen and (width >= 48em) {
  .top_solutions_desc {
    font-size: 1.125rem;
  }
}
.top_solutions_targets {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  padding: 2.5rem;
  padding-right: 0;
}
@media screen and (width >= 75em) {
  .top_solutions_targets {
    grid-template-columns: auto 1fr;
    padding: 3rem;
    padding-bottom: 5.5rem;
  }
}
.top_solutions_targets::before {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100vw;
  height: 100%;
  margin: auto;
  content: "";
  background-color: #fff;
  border-radius: 0.5rem 0 0 0.5rem;
}
.top_solutions_target {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
  color: #000;
}
@media screen and (width >= 75em) {
  .top_solutions_target {
    grid-template-columns: subgrid;
    grid-column: span 2;
    gap: 5rem;
  }
}
@media screen and (width < 75em) {
  .top_solutions_target_header {
    display: flex;
    justify-content: space-between;
  }
}
.top_solutions_target:not(:first-child) {
  padding-top: 2.5rem;
  margin-top: 2.5rem;
  border-top: 0.0625rem dashed #272727;
}
.top_solutions_target:nth-child(2) .top_solutions_target_ttl-en {
  color: #f80;
}
.top_solutions_target_ttl {
  font-family: "Red Hat Display", sans-serif;
  font-weight: 600;
}
.top_solutions_target_ttl-en {
  display: block;
  margin-bottom: 0.5rem;
  color: #06f;
}
.top_solutions_target_ttl-jp {
  font-weight: 700;
  line-height: 1.3;
  color: #000;
  font-size: min(4.8vw,2.25rem);
}
@media screen and (width >= 48em) {
  .top_solutions_target_ttl-jp {
    font-size: 1.25rem;
  }
}
.top_solutions_target_problem {
  margin-top: 0.5rem;
  line-height: 1.8;
  font-size: min(4vw,1.875rem);
}
@media screen and (width >= 48em) {
  .top_solutions_target_problem {
    font-size: 1rem;
  }
}
.top_solutions_target_img {
  height: fit-content;
}
@media screen and (width >= 48em) {
  .top_solutions_target_img {
    margin-top: 1.375rem;
  }
}
@media screen and (width < 48em) {
  .top_solutions_target_img {
    width: min(21.3333333333vw,10rem);
  }
}
.top_solutions_target_features {
  display: flex;
  gap: min(4.2666666667vw,2rem);
  justify-content: space-between;
}
@media screen and (width >= 48em) {
  .top_solutions_target_features {
    flex-wrap: wrap;
    gap: 1rem;
  }
}
.top_solutions_feature {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.top_solutions_feature_img {
  margin-bottom: 0.5rem;
}
@media screen and (width < 48em) {
  .top_solutions_feature_img {
    width: min(36.2666666667vw,17rem);
  }
}
.top_solutions_feature_desc {
  line-height: 1.3;
  text-align: center;
  font-size: min(3.2vw,1.5rem);
}
@media screen and (width >= 48em) {
  .top_solutions_feature_desc {
    font-size: 0.875rem;
  }
}
.top_solutions_figure {
  margin-top: 8.5rem;
}
@media screen and (width >= 48em) {
  .top_solutions_figure {
    margin-top: 11.875rem;
  }
}
.top_solutions_figure_ttl {
  margin-bottom: 3rem;
  font-family: ryo-gothic-plusn, sans-serif;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
  font-size: min(6.4vw,3rem);
}
@media screen and (width >= 48em) {
  .top_solutions_figure_ttl {
    font-size: 2rem;
  }
}
@media screen and (width < 48em) {
  .top_solutions_figure_img {
    position: relative;
    z-index: 3;
    width: 100%;
  }
}
.top_solutions .top_solutions_txt {
  font-family: "Red Hat Display", sans-serif;
  font-weight: 400;
  line-height: 0;
  color: #fff;
  opacity: 0.5;
  translate: 0 0.625rem;
  font-size: min(32vw,15rem);
}
@media screen and (width >= 48em) {
  .top_solutions .top_solutions_txt {
    font-size: 11.25rem;
  }
}
@media screen and (width >= 48em) {
  .top_solutions .top_solutions_txt {
    translate: 0 1.25rem;
  }
}

.section_scene-wrapper {
  position: relative;
  z-index: 1;
}

.top_scene {
  position: relative;
  width: 100%;
  height: 100dvh;
  overflow: hidden;
}

.scene_bg-layer {
  position: absolute;
  inset: 0;
  opacity: 0;
}
.scene_bg-layer.-active {
  opacity: 1;
}
.scene_bg-layer picture {
  width: 100%;
  height: 100%;
}
.scene_bg-layer img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.scene_content-layer {
  position: absolute;
  inset: 0;
  z-index: 10;
}
.scene_content-layer .contentInner {
  display: grid;
  grid-template-columns: 1fr;
}
@media screen and (width < 48em) {
  .scene_content-layer .contentInner {
    padding-inline: 0;
  }
  .scene_content-layer .contentInner > * {
    grid-row: 1;
    grid-column: 1;
  }
}
@media screen and (width >= 48em) {
  .scene_content-layer .contentInner {
    grid-template-columns: 50% 1fr;
    gap: min(2.9282576867vw,2.5rem);
  }
}

.scene_ttl-container {
  position: sticky;
  top: 0;
  height: 100dvh;
  padding-top: 10rem;
  color: #fff;
}
@media screen and (width < 48em) {
  .scene_ttl-container {
    padding-inline: min(6.4vw,3rem);
    padding-top: 7.5rem;
  }
}
.scene_ttl-container .c_link {
  width: fit-content;
  margin-top: 3rem;
}

.scene_content-wrapper {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  pointer-events: none;
}
@media screen and (width < 48em) {
  .scene_content-wrapper {
    padding-top: 100dvh;
  }
}
@media screen and (width >= 48em) {
  .scene_content-wrapper {
    grid-column: 2;
  }
}

.scene_item {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-items: flex-start;
  justify-content: center;
  min-height: 100dvh;
  padding-block: 2.5rem;
}
@media screen and (width >= 48em) {
  .scene_item {
    padding-block: 5rem;
  }
}
.scene_item .c_box {
  position: relative;
  z-index: 2;
  width: 100%;
  pointer-events: auto;
}
.scene_item_ttl {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  margin-bottom: 1.5rem;
}
.scene_item_ttl-cat {
  display: flex;
  gap: 1rem;
  align-items: center;
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.5;
  font-size: min(4.8vw,2.25rem);
}
@media screen and (width >= 48em) {
  .scene_item_ttl-cat {
    font-size: 1.25rem;
  }
}
.scene_item_ttl-cat::before {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: min(9.6vw,4.5rem);
  padding: 0.1875rem min(4.8vw,2.25rem);
  font-family: "Red Hat Display", sans-serif;
  font-weight: 700;
  line-height: 1;
  color: #fff;
  content: counter(number, decimal-leading-zero) ".";
  counter-increment: number;
  background-color: #f80;
  border-radius: 999rem;
  font-size: min(4.2666666667vw,2rem);
}
@media screen and (width >= 48em) {
  .scene_item_ttl-cat::before {
    font-size: 1rem;
  }
}
@media screen and (width >= 48em) {
  .scene_item_ttl-cat::before {
    min-height: 2.5rem;
    padding: 0.1875rem 1.25rem;
  }
}
.scene_item_ttl-jp {
  font-family: ryo-gothic-plusn, sans-serif;
  font-weight: 700;
  line-height: 1.3;
  font-size: min(5.3333333333vw,2.5rem);
}
@media screen and (width >= 48em) {
  .scene_item_ttl-jp {
    font-size: 1.75rem;
  }
}
.scene_item_txt {
  font-family: "Noto Sans JP", sans-serif;
  line-height: 2;
  font-size: min(4.8vw,2.25rem);
}
@media screen and (width >= 48em) {
  .scene_item_txt {
    font-size: 1.125rem;
  }
}
.scene_item_tags {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 0.5rem;
  justify-content: center;
}
@media screen and (width >= 48em) {
  .scene_item_tags {
    gap: 1rem 0;
  }
}
.scene_item_tag {
  width: min(19.2vw,9rem);
}
@media screen and (width >= 48em) {
  .scene_item_tag {
    width: 7.2rem;
  }
}
.scene_item .c_link {
  width: fit-content;
  margin: auto;
  margin-top: 2.625rem;
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.8;
}
@media screen and (width >= 48em) {
  .scene_item .c_link {
    margin-inline: auto 0;
    margin-top: 2.5rem;
  }
}
.scene_item_list {
  margin-top: 1.5rem;
}
.scene_item_list-item:not(:last-child) {
  border-bottom: 0.0625rem solid #c0c6d0;
}
.scene_item_list-item a {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  justify-content: center;
  padding: 1.5rem;
  padding-right: min(16vw,7.5rem);
  transition: color 0.4s ease-out;
}
@media screen and (width >= 48em) {
  .scene_item_list-item a {
    gap: 0.5rem;
    padding-right: 3.75rem;
  }
}
.scene_item_list-item a h4 {
  font-family: ryo-gothic-plusn, sans-serif;
  font-weight: 700;
  line-height: 1.3;
  font-size: min(5.3333333333vw,2.5rem);
}
@media screen and (width >= 48em) {
  .scene_item_list-item a h4 {
    font-size: 1.25rem;
  }
}
.scene_item_list-item a .hasIcon {
  position: absolute;
  inset: 0;
  left: auto;
  margin: auto;
  overflow: hidden;
}
@media (any-hover: hover) {
  .scene_item_list-item a:hover {
    color: #f80;
  }
}
.scene_item_list-item a:focus-visible, .scene_item_list-item a:active {
  color: #f80;
}

.top_bgContainer {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr;
  gap: 7.5rem;
  padding-top: 7.5rem;
  background-color: #f9f7f6;
}
@media screen and (width >= 48em) {
  .top_bgContainer {
    gap: 10rem;
    padding-top: 10rem;
  }
}
.top_bgContainer::before {
  position: absolute;
  inset: 10rem -13.1875rem auto auto;
  z-index: -1;
  display: block;
  height: 30rem;
  aspect-ratio: 1;
  margin: auto;
  content: "";
  background-image: linear-gradient(180deg, rgba(255, 219, 178, 0.5) 0%, rgba(255, 219, 178, 0.2) 100%);
  mix-blend-mode: multiply;
  mask-repeat: no-repeat;
  mask-position: right;
  mask-size: contain;
}
@media screen and (width >= 48em) {
  .top_bgContainer::before {
    top: 10rem;
    right: -16.5rem;
    height: 50.75rem;
    background-image: linear-gradient(180deg, rgba(255, 219, 178, 0.8) 0%, rgba(255, 219, 178, 0.2) 100%);
  }
}

.topGrid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}
@media screen and (width >= 48em) {
  .topGrid {
    grid-template-rows: auto;
    grid-template-columns: 1fr auto;
    gap: 3rem min(3.513909224vw,3rem);
    align-items: flex-start;
    align-items: flex-end;
  }
  .topGrid .-order1 {
    grid-row: 1;
    grid-column: 1;
  }
  .topGrid .-order3 {
    grid-row: 1;
    grid-column: 2;
  }
  .topGrid .-order2 {
    grid-row: 2;
    grid-column: 1/-1;
  }
}
.topGrid .-order3 {
  order: 3;
}
.topGrid .c_link {
  width: fit-content;
}
@media screen and (width >= 48em) {
  .topGrid .c_link {
    margin-inline: auto 0;
  }
}
@media screen and (width < 48em) {
  .topGrid .c_link {
    margin-top: 2rem;
  }
}

.top_function_list {
  display: grid;
  grid-template-columns: repeat(4, minmax(auto, 1fr));
  gap: 0.75rem min(3.4666666667vw,1.625rem);
}
@media screen and (width >= 48em) {
  .top_function_list {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem min(1.0980966325vw,0.9375rem);
    justify-content: center;
  }
}
.top_function_item {
  position: absolute;
  display: flex;
  visibility: hidden;
  flex-direction: column;
  gap: 0.5rem;
  align-items: center;
  width: 0;
  height: 0;
  overflow: hidden;
  opacity: 0;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
@media screen and (width >= 48em) {
  .top_function_item {
    margin: 0;
  }
}
.top_function_item.-visible {
  position: relative;
  visibility: visible;
  width: min(18.6666666667vw,8.75rem);
  height: auto;
  overflow: visible;
  opacity: 1;
}
@media screen and (width >= 48em) {
  .top_function_item.-visible {
    width: 7.5rem;
  }
}
.top_function_item_new {
  position: absolute;
  top: -0.5rem;
  left: 0.625rem;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.25rem 0.5rem 0.3125rem;
  margin: auto;
  font-family: "Red Hat Display", sans-serif;
  font-weight: 700;
  line-height: 1;
  color: #fff;
  background-color: #eb4000;
  border-radius: 1.5rem;
  transition: opacity 0.4s ease-out;
  font-size: min(2.6666666667vw,1.25rem);
}
@media screen and (width >= 48em) {
  .top_function_item_new {
    font-size: 0.625rem;
  }
}
.top_function_item_icon {
  display: flex;
  align-items: center;
  justify-content: center;
  height: min(20vw,9.375rem);
  aspect-ratio: 1;
  padding: 1.25rem 1rem;
  background: #fff;
  border: 1px solid #dedfe5;
  border-radius: 1.5rem;
  transition: opacity 0.4s ease-out;
}
@media screen and (width >= 48em) {
  .top_function_item_icon {
    height: 5rem;
  }
}
.top_function_item_caption {
  line-height: 1.3;
  text-align: center;
  font-size: min(3.2vw,1.5rem);
}
@media screen and (width >= 48em) {
  .top_function_item_caption {
    font-size: 0.875rem;
  }
}
.top_function_item_link {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  margin: 0;
}
.top_function_item:has(.top_function_item_link) .top_function_item_caption {
  transition: color 0.4s ease-out;
}
.top_function_item:has(.top_function_item_link) .top_function_item_caption::after {
  display: inline-block;
  height: min(4.2666666667vw,2rem);
  aspect-ratio: 1;
  margin-left: 0.3em;
  line-height: 1;
  content: "";
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100%;
  transform: translateY(0.2em);
}
@media screen and (width >= 48em) {
  .top_function_item:has(.top_function_item_link) .top_function_item_caption::after {
    height: min(1.1713030747vw,1rem);
  }
}
@media (any-hover: hover) {
  .top_function_item:has(.top_function_item_link):hover .top_function_item_icon {
    opacity: 0.5;
  }
  .top_function_item:has(.top_function_item_link):hover .top_function_item_caption {
    color: #f80;
  }
}
.top_function_item:has(.top_function_item_link):focus-visible .top_function_item_icon, .top_function_item:has(.top_function_item_link):active .top_function_item_icon {
  opacity: 0.5;
}
.top_function_item:has(.top_function_item_link):focus-visible .top_function_item_caption, .top_function_item:has(.top_function_item_link):active .top_function_item_caption {
  color: #f80;
}
.top_function_more {
  display: none;
  width: fit-content;
  margin: auto;
  line-height: 1.8;
}
@media screen and (width >= 48em) {
  .top_function_more {
    margin-top: 1rem;
  }
}
.top_function_more.-visible {
  display: flex;
}

.top_clients_ttl {
  margin-bottom: 2rem;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
  font-size: min(5.8666666667vw,2.75rem);
}
@media screen and (width >= 48em) {
  .top_clients_ttl {
    font-size: 2rem;
  }
}
@media screen and (width >= 48em) {
  .top_clients_ttl {
    margin-bottom: 3rem;
  }
}
.top_clients_list {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
}
@media screen and (width < 48em) {
  .top_clients_list {
    display: grid;
    grid-template-columns: repeat(3, minmax(auto, 1fr));
    gap: 0.375rem min(1.0666666667vw,0.5rem);
  }
  .top_clients_list img {
    width: 100%;
  }
}

.top_case {
  position: relative;
  z-index: 1;
  padding-block: 7.5rem;
}
@media screen and (width >= 48em) {
  .top_case {
    padding-block: 10rem;
  }
  .top_case .topGrid {
    row-gap: 3.5rem;
  }
}
.top_case::before {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 75%;
  height: 100%;
  margin: auto;
  content: "";
  background-color: #fff;
  border-radius: 0 1rem 0 0;
}
.top_case .top_case_grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(24rem, 1fr));
  gap: 1.5rem;
}
@media screen and (width < 48em) {
  .top_case .top_case_grid {
    grid-template-columns: 1fr;
    margin-top: 3.5rem;
  }
}
.top_case .top_case_grid .c_card {
  display: grid;
  gap: 1rem;
}
@media screen and (width >= 48em) {
  .top_case .top_case_grid .c_card {
    grid-template-rows: subgrid;
    grid-row: span 4;
  }
}
.top_case .top_case_grid .c_card_body {
  display: grid;
  gap: 0.5rem;
}
@media screen and (width >= 48em) {
  .top_case .top_case_grid .c_card_body {
    grid-template-rows: subgrid;
    grid-row: span 3;
    gap: 1rem;
  }
}
.top_case .top_case_grid .c_card_ttl {
  display: -webkit-box;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 3;
  font-family: ryo-gothic-plusn, sans-serif;
  font-weight: 700;
  line-height: 1.3;
  -webkit-box-orient: vertical;
  font-size: min(4.8vw,2.25rem);
}
@media screen and (width >= 48em) {
  .top_case .top_case_grid .c_card_ttl {
    font-size: 1.25rem;
  }
}
@media screen and (width < 48em) {
  .top_case .top_case_grid .c_card_ttl {
    margin-top: 0.5rem;
  }
}
.top_case .top_case_grid .hasIcon {
  display: flex;
  margin-inline: auto 0;
  color: #272727;
}
.top_case_list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  margin-bottom: 2.5rem;
}
@media screen and (width >= 48em) {
  .top_case_list {
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem;
    margin-bottom: 3.75rem;
  }
}
.top_case_item {
  overflow: hidden;
  background: #fff;
  border-radius: 0.75rem;
  transition: 0.4s ease-out;
}
@media (any-hover: hover) {
  .top_case_item:hover {
    box-shadow: 0 0.5rem 1.5rem rgba(0, 0, 0, 0.1);
  }
}
.top_case_item:focus-visible, .top_case_item:active {
  box-shadow: 0 0.5rem 1.5rem rgba(0, 0, 0, 0.1);
}
.top_case_item_img {
  aspect-ratio: 16/9;
  overflow: hidden;
}
.top_case_item_img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: 0.4s ease-out;
}
@media (any-hover: hover) {
  .top_case_item:hover .top_case_item_img img {
    transform: scale(1.05);
  }
}
.top_case_item:focus-visible .top_case_item_img img, .top_case_item:active .top_case_item_img img {
  transform: scale(1.05);
}
.top_case_item_body {
  padding: 1.25rem;
}
@media screen and (width >= 48em) {
  .top_case_item_body {
    padding: 1.5rem;
  }
}
.top_case_item_tag {
  display: inline-block;
  padding: 0.25rem 0.75rem;
  margin-bottom: 0.75rem;
  font-size: var(--font-size-xs);
  color: #f80;
  background: rgba(255, 136, 0, 0.1);
  border-radius: 1.25rem;
}
.top_case_item_ttl {
  margin-bottom: 0.5rem;
  font-size: var(--font-size-lg);
  font-weight: 700;
  color: #272727;
}
.top_case_item_desc {
  font-size: var(--font-size-sm);
  line-height: 1.6;
  color: #272727;
  opacity: 0.8;
}
.top_case_more {
  text-align: center;
}

.top_information {
  position: relative;
  z-index: 1;
  padding-block: 7.5rem;
  background-color: #fff9f2;
}
@media screen and (width >= 48em) {
  .top_information {
    padding-block: 10rem;
  }
}
.top_information .contentInner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 5rem;
}
@media screen and (width >= 48em) {
  .top_information .contentInner {
    gap: 10rem;
  }
}
.top_information::before {
  position: absolute;
  inset: 0 auto 0 -11.8125rem;
  z-index: -1;
  display: block;
  height: 30rem;
  aspect-ratio: 1;
  margin: auto;
  content: "";
  background-image: linear-gradient(180deg, rgba(255, 219, 178, 0.8) 0%, rgba(255, 219, 178, 0.2) 100%);
  mask-repeat: no-repeat;
  mask-position: left;
  mask-size: contain;
}
@media screen and (width >= 48em) {
  .top_information::before {
    left: -18.9375rem;
    height: 50.75rem;
  }
}
.top_information_grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}
@media screen and (width >= 48em) {
  .top_information_grid {
    grid-template-rows: auto 1fr;
    grid-template-columns: 29.4% 1fr;
    gap: 3rem min(3.513909224vw,3rem);
    align-items: flex-start;
  }
  .top_information_grid .-order1 {
    grid-row: 1;
    grid-column: 1;
  }
  .top_information_grid .-order3 {
    grid-row: 2;
    grid-column: 1;
  }
  .top_information_grid .-order2 {
    grid-row: 1/-1;
    grid-column: 2;
  }
}
.top_information_grid .-order3 {
  order: 3;
}
.top_information_link {
  line-height: 1.8;
  color: #444;
}
.top_information_body {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}
@media screen and (width < 48em) {
  .top_information_body {
    margin-top: 3rem;
  }
}
.top_information_sub {
  margin-bottom: 1rem;
  font-family: "Red Hat Display", sans-serif;
  font-weight: 600;
  line-height: 1;
  color: #000;
  font-size: min(4.2666666667vw,2rem);
}
@media screen and (width >= 48em) {
  .top_information_sub {
    font-size: 1rem;
  }
}
@media screen and (width >= 48em) {
  .top_information .top_information_topics {
    padding-right: 1.5rem;
  }
}
@media screen and (width < 48em) {
  .top_information .top_information_topics .c_card {
    gap: 1rem;
  }
}
@media screen and (width < 48em) {
  .top_information .top_information_topics .c_card_body {
    display: grid;
    gap: 0.5rem;
    padding: 0 0 1rem;
  }
}
.top_information .top_information_topics .c_card_ttl {
  display: -webkit-box;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 3;
  font-family: ryo-gothic-plusn, sans-serif;
  font-weight: 700;
  line-height: 1.3;
  -webkit-box-orient: vertical;
  font-size: min(4.8vw,2.25rem);
}
@media screen and (width >= 48em) {
  .top_information .top_information_topics .c_card_ttl {
    font-size: 1.25rem;
  }
}
.top_information .top_information_topics .top_information_topics_txt {
  font-size: min(4vw,1.875rem);
}
@media screen and (width >= 48em) {
  .top_information .top_information_topics .top_information_topics_txt {
    font-size: 0.9375rem;
  }
}
@media screen and (width >= 48em) {
  .top_information .top_information_topics .top_information_topics_txt {
    margin-top: 1rem;
  }
}
.top_information .top_information_topics .c_card_img img {
  aspect-ratio: 8/5;
}
@media screen and (width < 48em) {
  .top_information .top_information_topics .c_card_img {
    overflow: clip;
    border-radius: 0.5rem;
  }
}
.top_information .informationList {
  border-top: 0.0625rem solid #c0c6d0;
}
.top_information .informationLink {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.5rem;
  align-items: center;
  padding: 1.5rem 0;
  background-color: transparent;
  border-bottom: 0.0625rem solid #c0c6d0;
}
@media screen and (width >= 48em) {
  .top_information .informationLink {
    padding: 1.5rem min(1.1713030747vw,1rem);
  }
}
.top_information .informationLink_head {
  display: flex;
  gap: 1rem;
  align-items: center;
}
.top_information .informationLink_head time {
  font-weight: 400;
}
.top_information .informationLink_ttl {
  display: -webkit-box;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 2;
  font-family: ryo-gothic-plusn, sans-serif;
  font-weight: 700;
  line-height: 1.3;
  transition: color 0.4s ease-out;
  -webkit-box-orient: vertical;
  font-size: min(4.2666666667vw,2rem);
}
@media screen and (width >= 48em) {
  .top_information .informationLink_ttl {
    font-size: 1.25rem;
  }
}
@media screen and (width >= 48em) {
  .top_information .informationLink_ttl {
    -webkit-line-clamp: 1;
  }
}
@media (any-hover: hover) {
  .top_information .informationLink:hover .informationLink_ttl {
    color: #f80;
  }
}
.top_information .informationLink:focus-visible .informationLink_ttl, .top_information .informationLink:active .informationLink_ttl {
  color: #f80;
}

.top_download_ttl {
  margin-bottom: 1.5rem;
  font-family: ryo-gothic-plusn, sans-serif;
  font-weight: 700;
  line-height: 1.3;
  text-align: center;
  font-size: min(4.8vw,2.25rem);
}
@media screen and (width >= 48em) {
  .top_download_ttl {
    font-size: 1.5rem;
  }
}
@media screen and (width >= 48em) {
  .top_download_ttl {
    margin-bottom: 3rem;
  }
}
.top_download .c_link {
  margin-inline: auto 0;
  color: #444;
}
.top_download .c_link.bulkDownload {
  width: fit-content;
  margin: auto;
  margin-top: 3rem;
  line-height: 1.5;
  color: #444;
  font-size: min(4.2666666667vw,2rem);
}
@media screen and (width >= 48em) {
  .top_download .c_link.bulkDownload {
    font-size: 1.25rem;
  }
}
@media (any-hover: hover) {
  .top_download .c_link.bulkDownload:hover {
    color: #f80;
  }
}
.top_download .c_link.bulkDownload:focus-visible, .top_download .c_link.bulkDownload:active {
  color: #f80;
}
.top_download .c_link.bulkDownload .hasIcon::before {
  background-color: #f80;
  border-color: #f80;
}
.top_download .c_link.bulkDownload .hasIcon::after {
  background-color: #fff;
}
.top_download .downloadGrid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}
.top_download .downloadGrid .c_card_body {
  display: grid;
  gap: 1rem;
}
@media screen and (width >= 48em) {
  .top_download .downloadGrid {
    grid-template-columns: repeat(3, minmax(auto, 24.3125rem));
  }
  .top_download .downloadGrid .c_card_body {
    grid-template-rows: subgrid;
    grid-row: span 2;
  }
}
.top_download .downloadGrid .c_card {
  display: grid;
}
@media screen and (width >= 48em) {
  .top_download .downloadGrid .c_card {
    grid-template-rows: subgrid;
    grid-row: span 3;
    gap: 1rem;
  }
  .top_download .downloadGrid .c_card .c_card_body {
    gap: 2.7rem;
  }
}
@media screen and (width < 48em) {
  .top_download .downloadGrid .c_card {
    grid-template-columns: 35% 1fr;
    gap: min(4.2666666667vw,2rem);
    padding: min(4.2666666667vw,2rem);
  }
  .top_download .downloadGrid .c_card .c_card_body {
    gap: 0.5rem;
    padding: 0;
  }
}
.top_download .downloadGrid .c_card_ttl {
  display: -webkit-box;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 3;
  font-family: ryo-gothic-plusn, sans-serif;
  font-weight: 700;
  line-height: 1.3;
  -webkit-box-orient: vertical;
  font-size: min(3.7333333333vw,1.75rem);
}
@media screen and (width >= 48em) {
  .top_download .downloadGrid .c_card_ttl {
    font-size: 1.125rem;
  }
}
.top_download .downloadGrid .c_link {
  margin-inline: auto 0;
}
@media screen and (width < 48em) {
  .top_download .downloadGrid .c_link .hasIcon {
    height: min(6.4vw,3rem);
  }
  .top_download .downloadGrid .c_link .hasIcon::after {
    mask-size: min(2.1333333333vw,1rem);
  }
}

.top_contact {
  position: relative;
  z-index: 1;
  padding-block: 7.5rem 3.5rem;
  overflow: clip;
  background-color: #eef5fa;
}
@media screen and (width >= 48em) {
  .top_contact {
    padding-block: 7.5rem 3.5rem;
  }
}
.top_contact::before, .top_contact::after {
  position: absolute;
  z-index: -1;
  display: block;
  aspect-ratio: 1;
  margin: auto;
  content: "";
  background-image: linear-gradient(180deg, rgba(221, 236, 249, 0.2) 0%, #ddecf9 100%);
  mask-repeat: no-repeat;
  mask-size: contain;
}
@media screen and (width >= 48em) {
  .top_contact::before, .top_contact::after {
    background-image: linear-gradient(180deg, #ddecf9 0%, rgba(221, 236, 249, 0.2) 100%);
  }
}
.top_contact::before {
  top: -7.9375rem;
  left: -18.8125rem;
  height: 30rem;
  mask-position: left;
}
@media screen and (width >= 48em) {
  .top_contact::before {
    top: -7.9375rem;
    left: -20.375rem;
    height: min(59.4436310395vw,50.75rem);
  }
}
.top_contact::after {
  top: 19.5625rem;
  right: -20.75rem;
  height: 30rem;
  background-image: linear-gradient(180deg, #ddecf9 0%, rgba(221, 236, 249, 0.2) 100%);
  mask-position: right;
}
@media screen and (width >= 48em) {
  .top_contact::after {
    top: 6.875rem;
    right: -21.5rem;
    height: min(59.7364568082vw,51rem);
  }
}
.top_contact .top_contact_head {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
  margin-bottom: 3.5rem;
}
@media screen and (width >= 48em) {
  .top_contact .top_contact_head {
    flex-direction: row;
    gap: min(2.9282576867vw,2.5rem);
    align-items: flex-end;
    margin-bottom: 3.5rem;
  }
  .top_contact .top_contact_head .c_ttl_top {
    width: min(36.6764275256vw,31.3125rem);
    min-width: fit-content;
  }
}
.top_contact_desc {
  font-family: "Noto Sans JP", sans-serif;
  line-height: 2;
  font-size: min(4.5333333333vw,2.125rem);
}
@media screen and (width >= 48em) {
  .top_contact_desc {
    font-size: 1.125rem;
  }
}
.top_contact_buttons {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}
@media screen and (width >= 75em) {
  .top_contact_buttons {
    grid-template-columns: repeat(2, 1fr);
    min-height: 16.25rem;
  }
}
.top_contact_button {
  position: relative;
  z-index: 1;
  padding: 2rem 2.5rem;
  overflow: hidden;
  color: #fff;
  background-repeat: no-repeat;
  background-position: right;
  background-size: contain;
  border-radius: 0.5rem;
  transition: opacity 0.4s ease-out;
}
.top_contact_button::before {
  position: absolute;
  z-index: -1;
  display: block;
  height: 18.75rem;
  aspect-ratio: 1;
  margin: auto;
  content: "";
  mask-repeat: no-repeat;
  mask-position: right;
  mask-size: cover;
}
@media screen and (width >= 48em) {
  .top_contact_button::before {
    height: 23.5625rem;
  }
}
@media screen and (width >= 48em) {
  .top_contact_button {
    min-height: 16.25rem;
    padding: 2.5rem min(3.513909224vw,3rem);
    padding-right: 3.5rem;
  }
}
.top_contact_button {
  /* stylelint-disable-next-line no-descending-specificity */
}
.top_contact_button .hasIcon {
  display: block;
  height: min(14.9333333333vw,7rem);
  margin: 1rem 0 auto auto;
}
@media screen and (width >= 48em) {
  .top_contact_button .hasIcon {
    position: absolute;
    inset: 0;
    right: min(3.513909224vw,3rem);
    left: auto;
    height: 5rem;
    margin: auto;
  }
}
.top_contact_button .hasIcon::before {
  border-color: #fff;
}
.top_contact_button .hasIcon::after {
  mask-size: min(3.2vw,1.5rem);
}
@media screen and (width >= 48em) {
  .top_contact_button .hasIcon::after {
    mask-size: 1rem;
  }
}
.top_contact_button_ttl {
  display: block;
  display: flex;
  gap: 1rem;
  align-items: center;
  margin-bottom: 1rem;
  font-family: heisei-kaku-gothic-std, sans-serif;
  font-weight: 700;
  line-height: 1.3;
  font-size: min(4.8vw,2.25rem);
}
@media screen and (width >= 48em) {
  .top_contact_button_ttl {
    font-size: 1.5rem;
  }
}
@media screen and (width >= 48em) {
  .top_contact_button_ttl {
    margin-bottom: 1.4375rem;
  }
}
.top_contact_button_ttl::before {
  display: block;
  height: min(8.5333333333vw,4rem);
  aspect-ratio: 1;
  content: "";
  background-color: currentcolor;
  mask-position: center;
  mask-size: contain;
}
@media screen and (width >= 48em) {
  .top_contact_button_ttl::before {
    height: 2rem;
  }
}
.top_contact_button_desc {
  line-height: 1.6;
  font-size: min(3.7333333333vw,1.75rem);
}
@media screen and (width >= 48em) {
  .top_contact_button_desc {
    font-size: 0.9375rem;
  }
}
.top_contact_button.-contact {
  background-color: #06f;
}
.top_contact_button.-contact::before {
  top: -1.25rem;
  right: -8rem;
  background-image: linear-gradient(180deg, #004fc5 0%, rgba(0, 79, 197, 0.2) 100%);
}
@media screen and (width >= 48em) {
  .top_contact_button.-contact::before {
    top: 0;
    bottom: 0;
  }
}
.top_contact_button.-download {
  background-color: #eb4000;
}
.top_contact_button.-download::before {
  top: -1.25rem;
  right: -10.9375rem;
  background-image: linear-gradient(180deg, #ef6926 0%, rgba(239, 105, 38, 0.2) 100%);
}
@media screen and (width >= 48em) {
  .top_contact_button.-download::before {
    top: -2.8125rem;
    right: -7.5rem;
  }
}
@media (any-hover: hover) {
  .top_contact_button:hover {
    opacity: 0.5;
  }
}
.top_contact_button:focus-visible, .top_contact_button:active {
  opacity: 0.5;
}