@charset "UTF-8";
/*
Theme Name: yuso-web
Description: YUSO Web Theme
Author: YUSO
Version: 1.0.3
*/
:root { --text-body-lg: 20px; --text-body-md: 16px; --text-body-sm: 14px; --text-body-xs: 12px; --color-theme: #0F3C2C; --color-accent: #A7E9A9; --color-accent-light: rgba(167, 233, 169, 0.2); --color-accent-lighten: rgba(167, 233, 169, 0.1); --color-theme-light: rgba(15, 60, 44, 0.3); --color-theme-hovered: rgba(15, 60, 44, 0.06); --color-theme-border: rgba(15, 60, 44, 0.2); --color-theme-shadow: rgba(15, 60, 44, 0.08); --ff-neue: neue-haas-grotesk-display, sans-serif; --ease-out: cubic-bezier(0, 0.55, 0.45, 1); }

@keyframes popUp { 0% { opacity: 0; transform: translateY(24px) scale(0.92); }
  70% { transform: translateY(0) scale(1.02); }
  100% { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes fadeFromBottomLong { from { opacity: 0; transform: translateY(28px); }
  to { opacity: 1; transform: translateY(0); } }
@keyframes fadeFromBottom { from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); } }
@keyframes fadeFromBottomMin { from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); } }
@keyframes fadeFromLeft { from { opacity: 0; transform: translateX(-24px); }
  to { opacity: 1; transform: translateX(0); } }
@keyframes fadeFromRight { from { opacity: 0; transform: translateX(24px); }
  to { opacity: 1; transform: translateX(0); } }
* { margin: 0; padding: 0; border: 0; box-sizing: border-box; word-break: break-all; }
*:before, *:after { margin: 0; padding: 0; border: 0; box-sizing: border-box; word-break: break-all; }

img { vertical-align: bottom; height: auto; max-width: 100%; opacity: 1; pointer-events: none; -webkit-touch-callout: none; -webkit-user-select: none; user-select: none; }

svg { vertical-align: bottom; height: auto; }

img[data-src] { opacity: 0; }

ul, ol { list-style: none; }

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

html { font-size: 62.5%; vertical-align: baseline; margin: 0 !important; }

body { font-size: var(--text-body-lg); color: var(--color-theme); font-family: "Hiragino Kaku Gothic Pro", "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, sans-serif; line-height: 1.6; -webkit-font-smoothing: antialiased; }
@media all and (max-width: 767px) { body { font-size: 14px; } }

h1, h2, h3, h4 { line-height: 1.5; font-weight: normal; }

body, pre, input, textarea { font-family: "Hiragino Kaku Gothic Pro", "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, sans-serif; }

#wpadminbar { display: none !important; }

.serif { font-family: "Shippori Mincho", serif; font-weight: 400; font-style: normal; }

@font-face { font-family: neue-haas-grotesk-display; src: url("./assets/fonts/NHaasGroteskDSPro-45Lt.otf") format("truetype"); font-weight: normal; font-style: normal; }
@font-face { font-family: neue-haas-grotesk-display; src: url("./assets/fonts/NHaasGroteskDSPro-46LtIt.otf") format("truetype"); font-weight: normal; font-style: italic; }
@font-face { font-family: neue-haas-grotesk-display; src: url("./assets/fonts/NHaasGroteskDSPro-55Rg.otf") format("truetype"); font-weight: 500; font-style: normal; }
@font-face { font-family: neue-haas-grotesk-display; src: url("./assets/fonts/NHaasGroteskDSPro-56It.otf") format("truetype"); font-weight: 500; font-style: italic; }
@font-face { font-family: neue-haas-grotesk-display; src: url("./assets/fonts/NHaasGroteskDSPro-65Md.otf") format("truetype"); font-weight: 600; font-style: normal; }
.neue, .kv-title, .kv-bar-item, .button.primary > i, .topics-item-time, .home-about-copy span, .home-talent-slider-current, .about-desc, .single-talent-topic-item-time, .single-talent-history-def > dt, .single-talent-history-def > dd time, .archive-topic-nav-item, .single-topic-breadcrumbs > a, .single-topic-info > time, .single-topic-back-button, .single-topic-related-title { font-family: neue-haas-grotesk-display, sans-serif; font-weight: 400; font-style: normal; }

@keyframes inKvBar { from { transform: translateY(100%); }
  to { transform: translateY(0); } }
.kv { position: relative; padding-left: 40px; padding-right: 40px; overflow: hidden; height: 464px; }
@media all and (max-width: 767px) { .kv { height: 200px; padding-left: 16px; padding-right: 16px; } }

.kv-inner { position: relative; max-width: 1360px; margin-left: auto; margin-right: auto; height: 100%; }

.kv-title { font-size: 64px; font-weight: 500; display: flex; align-items: flex-end; justify-content: center; text-align: center; flex-grow: 1; height: calc(100% - 54px); line-height: 1.2; padding-bottom: 36px; }
@media all and (max-width: 767px) { .kv-title { font-size: 32px; height: calc(100% - 44px); padding-bottom: 20px; } }

.kv-bar { position: absolute; bottom: 0; left: 0; width: 100%; display: flex; align-items: center; justify-content: space-between; padding-top: 20px; padding-bottom: 20px; transform: translateY(100%); animation: 0.8s homeInKvBar 0.04s var(--ease-out) both; }
@media all and (max-width: 767px) { .kv-bar { padding-bottom: 16px; padding-top: 16px; } }

.kv-bar-item { display: flex; align-items: center; width: 33.33333%; font-size: var(--text-body-sm); line-height: 1; }
@media all and (max-width: 767px) { .kv-bar-item { font-size: var(--text-body-xs); } }
.kv-bar-item:nth-of-type(2) { justify-content: center; }
.kv-bar-item:nth-of-type(3) { justify-content: flex-end; }
.kv-bar-item a { cursor: pointer; }
.kv-bar-item a:hover { text-decoration: underline; }

.header { position: fixed; top: 0; left: 0; z-index: 11; width: 100%; }

.header-inner { display: flex; justify-content: space-between; align-items: center; height: 128px; width: 100%; margin-left: auto; margin-right: auto; padding-left: 40px; padding-right: 40px; }
@media all and (max-width: 767px) { .header-inner { padding-left: 16px; padding-right: 16px; height: 72px; } }

.header-brand { display: flex; }

.header-brand-link { display: flex; transition: 0.4s var(--ease-out); }
.header-brand-link:hover { opacity: 0.8; }
.header-brand-link img { height: 36px; width: auto; vertical-align: bottom; }
@media all and (max-width: 767px) { .header-brand-link img { height: 28px; } }

.header-nav-trigger { position: relative; background: none; display: flex; flex-direction: column; align-items: center; gap: 8px; padding-top: 4px; height: 51px; width: 44px; cursor: pointer; transition: 0.2s; }
.header-nav-trigger:hover { opacity: 0.8; }
.header-nav-trigger .header-nav-trigger-object { position: absolute; top: 4px; left: 0; height: 29px; width: 100%; }
.header-nav-trigger .header-nav-trigger-object img { position: absolute; height: 100%; width: 100%; left: 0; top: 0; object-fit: contain; transition: 0.4s var(--ease-out); }
.header-nav-trigger .header-nav-trigger-label { position: absolute; bottom: 0; left: 0; height: 10px; width: 100%; }
.header-nav-trigger .header-nav-trigger-label img { position: absolute; height: 100%; width: 100%; left: 0; top: 0; object-fit: contain; transition: 0.4s var(--ease-out); }
.header-nav-trigger .opened { opacity: 0; }
.header-nav-trigger .closed { opacity: 1; }
.header-nav-trigger.is-active .opened { opacity: 1; }
.header-nav-trigger.is-active .closed { opacity: 0; }

.header-nav-trigger-object, .header-nav-trigger-label { display: flex; }

.header-nav-trigger-object { position: relative; }

body { min-height: 100vh; }

.wrapper { min-height: 100vh; overflow: hidden; }

.container { position: relative; max-width: 1360px; margin-left: auto; margin-right: auto; padding-left: 80px; padding-right: 80px; }
@media all and (max-width: 767px) { .container { padding-left: 16px; padding-right: 16px; } }

.button { position: relative; appearance: none; display: inline-flex; align-items: center; }
.button:not([disabled]) { cursor: pointer; }
.button.primary { font-size: 16px; height: 56px; padding-left: 40px; padding-right: 28px; border: 1px solid var(--color-theme); background: none; color: var(--color-theme); transition: 0.32s var(--ease-out); }
@media all and (max-width: 767px) { .button.primary { font-size: 14px; } }
@keyframes spin { from { transform: translate(-50%, -50%) rotate(0deg); }
  to { transform: translate(-50%, -50%) rotate(360deg); } }
.button.primary:hover { cursor: pointer; background: var(--color-theme); color: #ffffff; }
.button.primary.loading { cursor: not-allowed; pointer-events: none; border-color: rgba(255, 255, 255, 0.5); color: rgba(255, 255, 255, 0.5); background: var(--color-theme); }
.button.primary.loading:before { opacity: 1; animation: 1s spin linear infinite; }
.button.primary:before { content: ''; display: block; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 24px; height: 24px; border-radius: 100%; border-width: 2px; border-style: solid; border-color: #ffffff #ffffff rgba(255, 255, 255, 0) rgba(255, 255, 255, 0); opacity: 0; pointer-events: none; }
.button.primary > i { display: flex; align-items: center; gap: 2px; font-size: 16px; }
@media all and (max-width: 767px) { .button.primary > i { font-size: 14px; } }
.button.primary > i:before { content: '（'; }
.button.primary > i:after { content: '）'; }
.button.secondary { gap: 20px; }
@media all and (max-width: 767px) { .button.secondary img { height: 30px; width: auto; } }
.button.secondary:after { content: ''; display: block; width: 34px; height: 34px; background: url("./assets/images/button_secondary_arrow.svg") no-repeat center; background-size: cover; transition: 0.32s var(--ease-out); }
@media all and (max-width: 767px) { .button.secondary:after { width: 26px; height: 26px; } }
.button.secondary:hover:after { transform: translate(25%, -25%); }

.footer { position: relative; display: flex; flex-direction: column; justify-content: flex-end; background-size: cover; aspect-ratio: 1440 / 733; max-height: 800px; width: 100%; }
@media all and (max-width: 767px) { .footer { aspect-ratio: 375 / 400; } }

@keyframes footerBgTrack { 0% { transform: translateX(0); }
  100% { transform: translateX(-50%); } }
.footer-bg { display: flex; position: absolute; z-index: 0; top: 0; left: 0; width: 100%; height: 100%; white-space: nowrap; }
.footer-bg .footer-bg-track { display: flex; animation: footerBgTrack 80s linear infinite; }
.footer-bg img { height: 100%; width: auto; max-width: none; }

.footer-inner { position: relative; padding-left: 40px; padding-right: 40px; background: linear-gradient(rgba(255, 255, 255, 0), #444444); }
@media all and (max-width: 767px) { .footer-inner { padding-left: 16px; padding-right: 16px; } }

.footer-content { max-width: 1360px; margin-left: auto; margin-right: auto; padding-top: 24px; padding-bottom: 24px; }
@media all and (max-width: 767px) { .footer-content { padding-top: 26px; padding-bottom: 16px; } }

.footer-logo { display: block; }
.footer-logo img { height: 152px; width: auto; }
@media all and (max-width: 767px) { .footer-logo img { height: 66px; width: 188px; object-fit: contain; } }

.footer-nav { margin-top: 40px; color: #ffffff; }
@media all and (max-width: 767px) { .footer-nav { margin-top: 24px; } }
.footer-nav a, .footer-nav span { transition: 0.24s var(--ease-out); }
.footer-nav a.inactive, .footer-nav span.inactive { color: rgba(255, 255, 255, 0.3); filter: blur(2px); transition: 0.24s var(--ease-out); }

.footer-nav-main { display: flex; }
@media all and (max-width: 767px) { .footer-nav-main { display: none; } }
.footer-nav-main > li + li { margin-left: 24px; }

.footer-nav-main-item { font-size: 32px; font-weight: 300; line-height: 1.2; }
.footer-nav-main-item:before { content: '/'; padding-right: 8px; display: inline-flex; }

.footer-nav-sub { margin-top: 16px; display: flex; }
.footer-nav-sub > li + li { margin-left: 24px; }

.footer-nav-sub-item { font-size: 16px; font-weight: 300; line-height: 1.2; }
@media all and (max-width: 767px) { .footer-nav-sub-item { font-size: 12px; } }

.gnav { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 10; opacity: 0; pointer-events: none; transition: 0.4s var(--ease-out); }
.gnav.is-active { opacity: 1; pointer-events: auto; }
.gnav.is-active .gnav-container { filter: blur(0); }

.gnav-container { width: 654px; height: 100%; position: absolute; top: 0; right: 0; display: flex; align-items: center; justify-content: center; overflow: hidden; background: url("./assets/images/modal_bg.jpg") top; background-size: auto 100%; filter: blur(12px); box-shadow: -10px 0 20px 0px rgba(0, 0, 0, 0.05); transition: 0.4s var(--ease-out); }
@media all and (max-width: 767px) { .gnav-container { width: 100%; height: auto; box-shadow: 0px 10px 20px 0px rgba(0, 0, 0, 0.05); } }
.gnav-container a { transition: 0.32s var(--ease-out); }
.gnav-container a.inactive { color: var(--color-theme-light); filter: blur(3px); }
.gnav-container a.inactive.gnav-sub-link { filter: blur(2px); }

.gnav-inner { display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 64px; }
@media all and (max-width: 767px) { .gnav-inner { gap: 40px; padding-top: 148px; padding-bottom: 80px; } }

.gnav-list { display: flex; flex-direction: column; align-items: center; gap: 12px; }

.gnav-link { font-size: 48px; line-height: 1.2; font-weight: 500; }
@media all and (max-width: 767px) { .gnav-link { font-size: 32px; } }

.gnav-sub-list { display: flex; justify-content: center; gap: 24px; }

.gnav-sub-link { font-size: 16px; line-height: 1.2; }
@media all and (max-width: 767px) { .gnav-sub-link { font-size: 12px; } }

.topics-list > li { border-bottom: 1px solid var(--color-theme); }
.topics-list.jsc-anim > li { opacity: 0; transform: translateX(24px); filter: blur(4px); transition: 0.64s var(--ease-out); }
.topics-list.jsc-anim > li:nth-of-type(1) { transition-delay: 0.1s; }
.topics-list.jsc-anim > li:nth-of-type(2) { transition-delay: 0.2s; }
.topics-list.jsc-anim > li:nth-of-type(3) { transition-delay: 0.3s; }
.topics-list.jsc-anim > li:nth-of-type(4) { transition-delay: 0.4s; }
.topics-list.jsc-anim > li:nth-of-type(5) { transition-delay: 0.5s; }
.topics-list.jsc-anim > li:nth-of-type(6) { transition-delay: 0.6s; }
.topics-list.jsc-anim > li:nth-of-type(7) { transition-delay: 0.7s; }
.topics-list.jsc-anim > li:nth-of-type(8) { transition-delay: 0.8s; }
.topics-list.jsc-anim > li:nth-of-type(9) { transition-delay: 0.9s; }
.topics-list.jsc-anim > li:nth-of-type(10) { transition-delay: 1s; }
.topics-list.jsc-anim > li:nth-of-type(11) { transition-delay: 1.1s; }
.topics-list.jsc-anim > li:nth-of-type(12) { transition-delay: 1.2s; }
.topics-list.jsc-anim > li:nth-of-type(13) { transition-delay: 1.3s; }
.topics-list.jsc-anim > li:nth-of-type(14) { transition-delay: 1.4s; }
.topics-list.jsc-anim > li:nth-of-type(15) { transition-delay: 1.5s; }
.topics-list.jsc-anim > li:nth-of-type(16) { transition-delay: 1.6s; }
.topics-list.jsc-anim > li:nth-of-type(17) { transition-delay: 1.7s; }
.topics-list.jsc-anim > li:nth-of-type(18) { transition-delay: 1.8s; }
.topics-list.jsc-anim > li:nth-of-type(19) { transition-delay: 1.9s; }
.topics-list.jsc-anim > li:nth-of-type(20) { transition-delay: 2s; }
.topics-list.jsc-anim.in-view > li { opacity: 1; transform: translateX(0); filter: blur(0); }

.topics-item { position: relative; display: block; padding: 24px 16px 32px; }
@media all and (max-width: 767px) { .topics-item { padding: 16px; } }
.topics-item:after { content: ''; display: block; position: absolute; bottom: 0; left: 0; height: 1.5px; background-color: var(--color-theme); width: 100%; transform: scaleX(0); transform-origin: left; transition: 1s cubic-bezier(0.33, 1, 0.68, 1); }
@media all and (max-width: 767px) { .topics-item:after { height: 1px; } }
.topics-item:hover:after { transform: scaleX(1); }
.topics-item:hover .topics-item-main:after { transform: translate(16px, -50%); }

.topics-item-lead { display: flex; align-items: center; }

.topics-item-time { line-height: 1.2; }
@media all and (max-width: 767px) { .topics-item-time { font-size: var(--text-body-sm); } }

.topics-item-category { font-size: var(--text-body-md); line-height: 1.3; padding-left: 16px; }
@media all and (max-width: 767px) { .topics-item-category { font-size: 12px; padding-left: 12px; } }
.topics-item-category:before { content: '/'; padding-right: 16px; }
@media all and (max-width: 767px) { .topics-item-category:before { padding-right: 12px; } }

.topics-item-tag { height: 18px; padding-left: 12px; padding-right: 12px; background-color: #A7E9A9; font-size: var(--text-body-xs); margin-left: 12px; display: inline-flex; }

.topics-item-main { position: relative; padding-right: 80px; margin-top: 18px; }
@media all and (max-width: 767px) { .topics-item-main { padding-right: 48px; margin-top: 8px; } }
.topics-item-main:after { content: ''; display: block; position: absolute; top: 50%; right: 8px; transform: translateY(-50%); width: 27px; height: 16px; background: url("./assets/images/topics_arrow.svg") no-repeat center; background-size: cover; transition: 0.48s var(--ease-out); }
@media all and (max-width: 767px) { .topics-item-main:after { right: 0; } }

.topics-item-title { font-size: var(--text-body-lg); line-height: 1.3; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2; overflow: hidden; }
@media all and (max-width: 767px) { .topics-item-title { font-size: var(--text-body-sm); -webkit-line-clamp: 3; } }

.form { background-color: #f5f6f3; padding-top: 80px; padding-bottom: 80px; line-height: 1.3; }
@media all and (max-width: 767px) { .form { padding-top: 40px; padding-bottom: 40px; } }

.form-inner { max-width: 832px; margin-left: auto; margin-right: auto; padding-left: 16px; padding-right: 16px; }

.form-lead { font-size: 12px; margin-bottom: 40px; }
@media all and (max-width: 767px) { .form-lead { margin-bottom: 24px; } }

.form-lead-main { font-size: 16px; line-height: 1.7; padding-bottom: 40px; }
@media all and (max-width: 767px) { .form-lead-main { font-size: 12px; padding-bottom: 24px; } }

.form-field { font-size: var(--text-body-md); line-height: 1.7; display: flex; align-items: flex-start; gap: 14px; }
@media all and (max-width: 767px) { .form-field { gap: 6px; flex-direction: column; align-items: stretch; } }
.form-field > dt { display: flex; gap: 4px; width: 190px; flex-shrink: 0; padding-top: 6px; padding-bottom: 5px; min-height: 40px; border-bottom: 0.5px solid; }
@media all and (max-width: 767px) { .form-field > dt { width: auto; font-size: 14px; line-height: 1.4; padding-top: 0; padding-bottom: 4px; min-height: 0; } }
.form-field > dd { display: flex; gap: 4px; flex-grow: 1; }
.form-field.required > dt:after { content: '*'; color: var(--color-accent); margin-top: -4px; }
.form-field + .form-field { margin-top: 32px; }

input, textarea, .multiselect-trigger-body { font-size: var(--text-body-sm); padding: 11px 12px; line-height: 1.3; border: 0.5px solid var(--color-theme); width: 100%; background-color: #FFFFFF; -webkit-appearance: none; text-align: left; outline: 1px solid rgba(255, 255, 255, 0); transition: 0.32s var(--ease-out); border-radius: 0; color: var(--color-theme); }
input::placeholder, textarea::placeholder, .multiselect-trigger-body::placeholder { color: #cfd4d6; }
input:focus, textarea:focus, .multiselect-trigger-body:focus { outline-color: var(--color-accent); border-color: var(--color-accent); }

.radio-list { display: flex; gap: 8px 24px; padding-top: 8px; flex-wrap: wrap; }

.radio { position: relative; display: flex; cursor: pointer; font-size: var(--text-body-sm); }
.radio input { opacity: 0; width: 100%; position: absolute; top: 0; left: 0; height: 100%; }
.radio input:checked ~ span:after { opacity: 1; }
.radio span { position: relative; display: block; padding-left: 24px; }
.radio span:before, .radio span:after { content: ''; display: block; position: absolute; transition: 0.32s var(--ease-out); }
.radio span:before { top: 50%; left: 0; transform: translateY(-50%); width: 16px; height: 16px; border-radius: 100%; border: 1px solid var(--color-theme); }
.radio span:after { top: 50%; left: 4px; transform: translateY(-50%); width: 8px; height: 8px; border-radius: 100%; background: var(--color-theme); opacity: 0; }

.field-number-group { margin-left: -8px; margin-right: -8px; margin-top: -4px; }
.field-number-group .field-number { padding-left: 8px; padding-right: 8px; padding-top: 4px; }
.field-number-group .field-number + .field-number { margin-left: 0; }

.field-number { display: inline-flex; gap: 4px; align-items: flex-end; white-space: nowrap; }
.field-number input { width: 100px; }
.field-number + .field-number { margin-left: 16px; }

.sns-field-group { width: 100%; display: flex; flex-direction: column; gap: 4px; }

.sns-field { display: flex; width: 100%; }
.sns-field > dt { width: 104px; padding-right: 16px; font-size: 16px; flex-shrink: 0; padding-top: 6px; text-align: right; }
@media all and (max-width: 767px) { .sns-field > dt { font-size: 12px; width: 80px; } }
.sns-field > dd { flex-grow: 1; }

.uploader { border: 0.5px solid var(--color-theme); width: 100%; background-color: #FFFFFF; padding: 16px; }
.uploader label { position: relative; display: inline-flex; align-items: center; justify-content: center; font-size: 14px; height: 44px; width: 210px; border: 1px solid var(--color-theme); margin-right: 24px; }
.uploader label input { position: absolute; top: 0; left: 0; width: 100%; height: 100%; opacity: 0; }
.uploader .uploader-name { display: inline-flex; font-size: 12px; }
@media all and (max-width: 767px) { .uploader .uploader-name { display: block; margin-top: 8px; } }
.uploader .uploader-desc { font-size: 12px; line-height: 1.3; margin-top: 12px; }

.select { position: relative; display: inline-flex; border: 0.5px solid var(--color-theme); width: 100%; background-color: #FFFFFF; text-align: left; outline: 1px solid rgba(255, 255, 255, 0); transition: 0.32s var(--ease-out); }
.select.year { width: 160px; }
.select.month, .select.day { width: 100px; }
.select select { font-size: var(--text-body-sm); line-height: 1.3; -webkit-appearance: none; padding: 11px 12px; width: 100%; background-color: #FFFFFF; color: var(--color-theme); }
.select select:focus { outline-color: var(--color-accent); border-color: var(--color-accent); }
.select:after { content: ''; position: absolute; width: 8px; height: 8px; top: 14px; right: 20px; border-bottom: 1px solid var(--color-theme); border-left: 1px solid var(--color-theme); transform: rotate(-45deg); }

.multiselect { position: relative; width: 100%; }

.multiselect-trigger { position: relative; }
.multiselect-trigger:after { content: ''; position: absolute; width: 8px; height: 8px; top: 14px; right: 20px; border-bottom: 1px solid var(--color-theme); border-left: 1px solid var(--color-theme); transform: rotate(-45deg); }

.multiselect-trigger-body { position: relative; cursor: pointer; padding-right: 48px; }
.multiselect-trigger-body:hover { background-color: rgba(255, 255, 255, 0.8); }
.multiselect-trigger-body:not(.is-filled) { color: #cfd4d6; }
.multiselect-trigger-body.is-active { outline: 1px solid var(--color-accent); border-color: var(--color-accent); }

.multiselect-popover { position: absolute; top: calc(100% + 8px); left: 0; width: 320px; height: 240px; overflow: auto; padding: 4px 0; border: 1px solid var(--color-theme-border); background-color: #fff; box-shadow: 0 1px 8px 3px var(--color-theme-shadow); border-radius: 4px; opacity: 0; transform: translateY(16px); pointer-events: none; }
.multiselect-popover.is-active { opacity: 1; transform: translateY(0); pointer-events: auto; }

.multiselect-item { position: relative; display: flex; padding: 8px 16px; cursor: pointer; font-size: var(--text-body-sm); }
.multiselect-item input { display: block; width: 100%; position: absolute; top: 0; left: 0; height: 100%; border: 1px solid rgba(255, 255, 255, 0); outline: none; cursor: pointer; }
.multiselect-item input:hover { background-color: var(--color-accent-lighten); }
.multiselect-item input:focus { background-color: var(--color-accent-light); }
.multiselect-item input:checked ~ span:after { opacity: 1; }
.multiselect-item span { position: relative; display: block; padding-left: 28px; }
.multiselect-item span:before, .multiselect-item span:after { content: ''; display: block; position: absolute; transition: 0.32s var(--ease-out); }
.multiselect-item span:before { top: 50%; left: 0; transform: translateY(-50%); width: 16px; height: 16px; border: 1px solid var(--color-theme); background-color: #fff; border-radius: 4px; }
.multiselect-item span:after { top: 50%; left: 5px; margin-top: -1px; transform: translateY(-50%) rotate(40deg); width: 6px; height: 9px; border-bottom: 1px solid var(--color-theme); border-right: 1px solid var(--color-theme); opacity: 0; }

.form-action { display: flex; flex-direction: column; justify-content: center; align-items: center; margin-top: 40px; font-size: 14px; gap: 16px; }
@media all and (max-width: 767px) { .form-action { margin-top: 24px; } }

.form-action-desc { line-height: 1.6; }
@media all and (max-width: 767px) { .form-action-desc { font-size: 12px; text-align: center; } }
.form-action-desc a { text-decoration: underline; }
.form-action-desc a:hover { opacity: 0.8; }

.image-modal { position: fixed; top: 0; left: 0; width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; background-color: rgba(0, 0, 0, 0.4); backdrop-filter: blur(8px); z-index: 1000; transition: 0.24s ease-in-out; }
.image-modal:not([data-active]) { opacity: 0; visibility: hidden; transition: 0.04s ease-in-out; }
.image-modal:not([data-active]) .image-modal-container { opacity: 0; transform: scale(0.95); transition: 0.04s ease-in-out; }

.image-modal-image { width: 100%; height: 100%; max-width: 1200px; max-height: 1200px; padding: 80px 40px; object-fit: contain; }
@media all and (max-width: 767px) { .image-modal-image { padding: 48px 12px; } }

.image-modal-close { position: absolute; top: 16px; right: 16px; width: 40px; height: 40px; display: block; background: none; border: 0; }
@media all and (max-width: 767px) { .image-modal-close { top: 20px; right: 20px; width: 32px; height: 32px; } }
.image-modal-close:before, .image-modal-close:after { content: ''; display: block; width: 90%; height: 2px; position: absolute; top: 50%; left: 50%; background-color: rgba(255, 255, 255, 0.7); }
@media all and (max-width: 767px) { .image-modal-close:before, .image-modal-close:after { height: 1.4px; background-color: #fff; } }
.image-modal-close:before { transform: translate(-50%, -50%) rotate(45deg); }
.image-modal-close:after { transform: translate(-50%, -50%) rotate(-45deg); }

.u-font-accent { font-family: "Jost"; line-height: 1; }

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

@media all and (max-width: 767px) { .sp-dn { display: none !important; } }

.separator { background: url("./assets/images/separator.svg") no-repeat center; background-size: auto 100%; width: 100%; height: 5px; margin-top: 60px; margin-bottom: 60px; }

@keyframes homeInHeader { 0% { opacity: 0; transform: translateY(-100%); }
  80% { opacity: 1; }
  100% { opacity: 1; transform: translateY(0); } }
@keyframes homeInKvBar { 0% { opacity: 0; transform: translateY(100%); }
  80% { opacity: 1; }
  100% { opacity: 1; transform: translateY(0); } }
.is-home .header { opacity: 0; transform: translateY(-100%); animation: 0.8s homeInHeader 1.8s var(--ease-out) both; }
.is-home .kv-bar { opacity: 0; transform: translateY(100%); animation: 0.8s homeInKvBar 1.8s var(--ease-out) both; }

.no-anim .home-kv-logo { animation: none; }
.no-anim .header { transform: translateY(0); opacity: 1; animation: none; }
.no-anim .kv-bar { transform: translateY(0); opacity: 1; animation: none; }

@keyframes inKv { from { opacity: 0; }
  to { opacity: 1; } }
.home-kv { position: relative; height: calc(100vh - 40px); height: calc(100dvh - 40px); height: calc(100svh - 40px); }
.home-kv.no-anim .home-kv-logo { animation: none; }

@keyframes inKvBg { from { opacity: 0; }
  to { opacity: 1; } }
.home-kv-bg { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: url("./assets/images/top/kv_bg_v2.jpg") no-repeat center; background-size: cover; animation: 1s inKvBg ease-in both; }
@media all and (max-width: 767px) { .home-kv-bg { background: url("./assets/images/top/kv_bg_sp_v2.jpg") no-repeat center; } }

@keyframes outKvBgBlur { from { backdrop-filter: blur(40px); background-color: rgba(242, 242, 242, 0.5); }
  to { backdrop-filter: blur(0); background-color: rgba(255, 255, 255, 0); } }
@keyframes inKvLogoTop { from { filter: blur(12px); transform: scale(0.9); opacity: 0; }
  to { filter: blur(0); transform: scale(0.8); opacity: 1; } }
@keyframes adjustKvLogoUnder { from { opacity: 0; transform: translate(-50%, -50%) scale(0.8); }
  to { opacity: 1; transform: translate(-50%, -40%) scale(1); } }
@keyframes adjustKvLogoTop { from { filter: blur(0); transform: translate(-50%, -50%) scale(1); opacity: 1; }
  to { filter: blur(4px); transform: translate(-50%, 0%) scale(1.25); opacity: 0; } }
.home-kv-logo { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }
@media all and (max-width: 767px) { .home-kv-logo { bottom: 16px; top: auto; transform: translate(-50%, 0); } }
.home-kv-logo.under { opacity: 0; animation: 0.8s adjustKvLogoUnder 1.2s cubic-bezier(0.5, 1, 0.89, 1) both; }
.home-kv-logo.top { animation: 0.8s adjustKvLogoTop 1.6s cubic-bezier(0.5, 1, 0.89, 1) both; }
.home-kv-logo.top img { filter: blur(4px); transform: scale(0.8); opacity: 0; animation: 0.8s inKvLogoTop 0.2s ease-in-out both; }
.home-kv-logo img { max-width: 80vw; width: 680px; height: auto; }

@keyframes inKvLogo { from { transform: translate(-50%, -50%); }
  to { transform: translate(-50%, -50%); } }
.home-section { overflow: hidden; }

.home-section-header { display: flex; flex-direction: column; align-items: flex-start; }
.home-section-header .home-section-body { margin-top: 80px; }
.home-section-header.jsc-anim .home-section-caption, .home-section-header.jsc-anim .home-section-title { opacity: 0; filter: blur(12px); transition: 0.8s cubic-bezier(0, 0.55, 0.45, 1) 0.24s; }
.home-section-header.jsc-anim .home-section-caption { transform: translateX(48px) skew(-5deg); }
.home-section-header.jsc-anim .home-section-title { transform: translateX(-48px) skew(5deg); }
.home-section-header.jsc-anim.in-view .home-section-caption, .home-section-header.jsc-anim.in-view .home-section-title { filter: blur(0); opacity: 1; transform: translateX(0) skew(0deg); }

.home-section-caption { line-height: 1.5; font-size: var(--text-body-sm); }
@media all and (max-width: 767px) { .home-section-caption { font-size: var(--text-body-xs); line-height: 1.3; } }

.home-section-action { display: flex; justify-content: flex-end; }
@media all and (max-width: 767px) { .home-section-action { justify-content: center; } }

.home-section.about { padding-top: 140px; padding-bottom: 160px; background-color: #F2F2F2; }
@media all and (max-width: 767px) { .home-section.about { padding-top: 98px; padding-bottom: 120px; } }
.home-section.about .home-section-body { margin-top: 160px; }
@media all and (max-width: 767px) { .home-section.about .home-section-body { margin-top: 124px; } }
.home-section.about .home-section-action { margin-top: 80px; }
@media all and (max-width: 767px) { .home-section.about .home-section-action { justify-content: flex-end; } }

.home-about-copy { position: absolute; top: -112px; right: 40px; }
@media all and (max-width: 767px) { .home-about-copy { top: -72px; } }
@media all and (max-width: 767px) { .home-about-copy img { height: 42px; width: auto; } }
.home-about-copy span { display: block; font-weight: 500; line-height: 1.1; font-size: 20px; }
@media all and (max-width: 767px) { .home-about-copy span { font-size: 14px; font-weight: 400; } }
.home-about-copy span:nth-of-type(2) { padding-left: 0.9em; }
.home-about-copy span:nth-of-type(3) { padding-left: 2.4em; }

.home-about-def { max-width: 700px; width: 100%; margin-left: auto; }
.home-about-def > dt { font-size: 40px; font-weight: 600; opacity: 0; transform: scale(1.1); filter: blur(8px); transition: 1s var(--ease-out) 0.2s; }
@media all and (max-width: 767px) { .home-about-def > dt { font-size: 32px; line-height: 1.3; } }
.home-about-def > dt.in-view { opacity: 1; transform: scale(1); filter: blur(0); }
.home-about-def > dd { margin-top: 32px; font-size: 20px; line-height: 2; opacity: 0; transform: scale(1.1); filter: blur(8px); transition: 1s var(--ease-out) 0.2s; }
@media all and (max-width: 767px) { .home-about-def > dd { font-size: var(--text-body-sm); } }
.home-about-def > dd.in-view { opacity: 1; transform: scale(1); filter: blur(0); }
.home-about-def > dd span { transition: 0.32s var(--ease-out); color: var(--color-theme-light); }
.home-about-def > dd span.filled { color: var(--color-theme); }

.home-section.talent { padding-top: 80px; padding-bottom: 120px; border-top: 1px solid var(--color-theme); }
@media all and (max-width: 767px) { .home-section.talent { padding-top: 40px; } }
.home-section.talent .home-section-header { align-items: center; }
@media all and (max-width: 767px) { .home-section.talent .home-section-title img { height: 58px; width: auto; } }
.home-section.talent .home-section-body { margin-top: 80px; }
@media all and (max-width: 767px) { .home-section.talent .home-section-body { margin-top: 40px; } }
.home-section.talent .home-section-action { margin-top: 40px; }

.home-talent-slider-wrapper { overflow: hidden; overscroll-behavior: contain; width: 100%; }

.home-talent-slider { position: relative; z-index: 1; opacity: 0; transform: translateY(24px) scale(0.92); filter: blur(12px); transition: 1s cubic-bezier(0, 0.55, 0.45, 1) 0.2s; overscroll-behavior: contain; }
@media all and (max-width: 767px) { .home-talent-slider { margin-left: -16px; margin-right: -16px; padding-top: 16px; overflow: hidden; } }
.home-talent-slider.in-view { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
.home-talent-slider .home-talent-slider-track { white-space: nowrap; overscroll-behavior: contain; }
@media all and (max-width: 767px) { .home-talent-slider .home-talent-slider-track { overflow: hidden; } }
.home-talent-slider .home-talent-slider-list { display: flex; justify-content: center; align-items: flex-end; min-height: 632px; transition: transform 0.64s var(--ease-out); overscroll-behavior: contain; touch-action: pan-x; will-change: transform; }
@media all and (max-width: 767px) { .home-talent-slider .home-talent-slider-list { min-height: 400px; align-items: center; transition: transform 0.24s ease; } }
.home-talent-slider .home-talent-slider-list.disabled-anim { transition: none; }
.home-talent-slider .home-talent-slider-list.disabled-anim > li { transition: none; }
.home-talent-slider .home-talent-slider-list.disabled-anim .home-talent-slider-item-detail, .home-talent-slider .home-talent-slider-list.disabled-anim .home-talent-slider-item-box { transition: none !important; }
.home-talent-slider .home-talent-slider-list > li { flex-shrink: 0; width: 274px; padding-left: 12px; padding-right: 12px; user-select: none; padding-bottom: 80px; transition: width 0.64s var(--ease-out), padding-bottom 0.64s var(--ease-out); will-change: width, height, padding-bottom; }
@media all and (max-width: 767px) { .home-talent-slider .home-talent-slider-list > li { width: 230px; padding-left: 8px; padding-right: 8px; transition: width 0.24s ease; will-change: width, height; padding-bottom: 0; } }
.home-talent-slider .home-talent-slider-list > li.is-active { width: 524px; padding-bottom: 0; }
@media all and (max-width: 767px) { .home-talent-slider .home-talent-slider-list > li.is-active { width: 316px; } }
.home-talent-slider .home-talent-slider-list > li.is-active .home-talent-slider-item-box { opacity: 1; filter: none; transform: scale(1); transition: 0.64s var(--ease-out) 0.08s; }
@media all and (max-width: 767px) { .home-talent-slider .home-talent-slider-list > li.is-active .home-talent-slider-item-box { transition: 0.24s var(--ease-out) 0.08s; } }
.home-talent-slider .home-talent-slider-list > li.is-active .home-talent-slider-item-detail { opacity: 1; filter: none; transform: translateX(100%); }
.home-talent-slider .home-talent-slider-list > li.is-active .home-talent-slider-item-thumbnail { filter: saturate(1); cursor: pointer; }
.home-talent-slider .home-talent-slider-list > li .home-talent-slider-item-detail { opacity: 0; transition: none; }
.home-talent-slider .home-talent-slider-list > li .home-talent-slider-item-thumbnail { filter: saturate(0); }

.home-talent-slider-item { position: relative; user-select: none; -webkit-user-drag: none; }

.home-talent-slider-item-thumbnail { position: relative; aspect-ratio: 580 / 733; overflow: hidden; width: 100%; cursor: pointer; }
.home-talent-slider-item-thumbnail:after { content: ''; display: block; position: absolute; top: 0; right: 0; width: 100%; height: 100%; background: url("./assets/images/top/talent_light.png") no-repeat right top; background-size: cover; pointer-events: none; transform-origin: top right; opacity: 0; transform: scale(1.2); transition: 0.32s ease-out; }
.home-talent-slider-item-thumbnail:hover:after { opacity: 1; transform: scale(1); }
.home-talent-slider-item-thumbnail img { width: 100%; height: 100%; object-fit: cover; }

.home-talent-slider-item-box { position: absolute; bottom: 0; left: 0; padding: 24px; opacity: 0; filter: blur(8px); will-change: filter, opacity; transition: none; z-index: 10; }
@media all and (max-width: 767px) { .home-talent-slider-item-box { padding: 12px; filter: none; will-change: opacity; } }

.home-talent-slider-item-label { font-family: var(--ff-neue); font-size: var(--text-body-md); line-height: 1; height: 22px; display: inline-flex; align-items: center; gap: 4px; background-color: #A7E9A9; padding-left: 12px; padding-right: 12px; }
@media all and (max-width: 767px) { .home-talent-slider-item-label { font-size: 12px; line-height: 1; padding-left: 8px; padding-right: 8px; height: 16px; } }
.home-talent-slider-item-label b { font-weight: 600; }

.home-talent-slider-item-title { font-size: 65px; line-height: 1; color: #F5F6F3; margin-top: 8px; }
@media all and (max-width: 767px) { .home-talent-slider-item-title { font-size: 32px; } }

.home-talent-slider-item-tag-list { margin-top: 16px; display: flex; align-items: flex-start; font-size: var(--text-body-sm); color: #F5F6F3; font-weight: 300; }
@media all and (max-width: 767px) { .home-talent-slider-item-tag-list { font-size: 12px; } }
.home-talent-slider-item-tag-list > li + li { display: inline-flex; align-items: center; }
.home-talent-slider-item-tag-list > li + li:before { content: '|'; padding-left: 6px; padding-right: 6px; font-size: 12px; display: inline-flex; }

.home-talent-slider-item-tag { font-family: var(--ff-neue); color: #F5F6F3; font-style: italic; display: inline-flex; }

.home-talent-slider-item-detail { position: absolute; top: 0; right: -24px; padding-top: 16px; transform: translateX(100%) scale(1.2); filter: blur(8px); display: none; will-change: transform, opacity, filter; transition: 0.52s var(--ease-out) 0.32s; }
@media all and (max-width: 767px) { .home-talent-slider-item-detail { filter: none; will-change: transform, opacity; } }

.home-talent-slider-item-detail-def > dt { font-size: 0; }
.home-talent-slider-item-detail-def > dd { margin-top: 48px; display: flex; flex-direction: column; padding-left: 96px; }
.home-talent-slider-item-detail-def > dd > span:nth-of-type(1) { align-self: flex-start; padding-right: 26px; }
.home-talent-slider-item-detail-def > dd > span:nth-of-type(2) { align-self: flex-end; padding-left: 26px; }

.home-talent-slider-arrows { display: flex; position: absolute; left: calc(50% + (524px / 2) + 24px); bottom: 0; gap: 10px; }
@media all and (max-width: 767px) { .home-talent-slider-arrows { position: static; left: auto; right: 16px; margin-top: 24px; justify-content: flex-end; padding-right: 16px; gap: 4px; } }

.home-talent-slider-arrow { height: 24px; width: 32px; display: block; background: url("./assets/images/slider_arrows.svg") no-repeat; background-size: auto 19px; cursor: pointer; transition: 0.4s var(--ease-out); }
@media all and (max-width: 767px) { .home-talent-slider-arrow { height: 20px; width: 27px; background-size: auto 17px; } }
.home-talent-slider-arrow.prev { background-position: left; transform-origin: right; }
.home-talent-slider-arrow.next { background-position: right; transform-origin: left; }
.home-talent-slider-arrow:hover.prev { transform: scale(1.12); }
@media all and (max-width: 767px) { .home-talent-slider-arrow:hover.prev { transform: scale(1); } }
.home-talent-slider-arrow:hover.next { transform: scale(1.12); }
@media all and (max-width: 767px) { .home-talent-slider-arrow:hover.next { transform: scale(1); } }
.home-talent-slider-arrow:active { transition: 0.12s var(--ease-out); opacity: 0.7; }

.home-talent-slider-current { position: absolute; top: 16px; left: calc(50% + 524px / 2 + 12px); z-index: 1; }
@media all and (max-width: 767px) { .home-talent-slider-current { top: 0; left: 50%; transform: translateX(-50%); display: flex; gap: 32px; white-space: nowrap; justify-content: space-between; width: 300px; } }
.home-talent-slider-current:hover { opacity: 0.8; }
.home-talent-slider-current > dt { letter-spacing: 0.1px; font-weight: 500; line-height: 1.2; }
@media all and (max-width: 767px) { .home-talent-slider-current > dt { padding-left: 2px; } }
.home-talent-slider-current > dd { position: relative; margin-top: 52px; margin-left: 96px; }
@media all and (max-width: 767px) { .home-talent-slider-current > dd { margin-top: 0; margin-left: 0; } }

.home-talent-slider-current-name { display: flex; flex-direction: column; line-height: 1.1; letter-spacing: 0.2px; position: absolute; top: 0; left: 0; opacity: 0; filter: blur(4px); transform: scale(1.32); transition: 0.64s ease-in-out 0.08s; white-space: nowrap; }
@media all and (max-width: 767px) { .home-talent-slider-current-name { flex-direction: row; right: 0; transform-origin: right; left: auto; text-align: right; transform: scale(1); padding-right: 2px; } }
.home-talent-slider-current-name.is-active { opacity: 1; filter: blur(0); transform: scale(1); z-index: 1; }
.home-talent-slider-current-name > span { white-space: nowrap; }
.home-talent-slider-current-name > span:nth-of-type(1) { align-self: flex-start; padding-right: 26px; }
@media all and (max-width: 767px) { .home-talent-slider-current-name > span:nth-of-type(1) { padding-right: 8px; } }
.home-talent-slider-current-name > span:nth-of-type(2) { align-self: flex-end; padding-left: 26px; }
@media all and (max-width: 767px) { .home-talent-slider-current-name > span:nth-of-type(2) { padding-left: 0; } }

.home-talent-action { margin-top: 40px; }

.home-section.topics { padding-top: 120px; padding-bottom: 120px; background-color: #F2F2F2; }
@media all and (max-width: 767px) { .home-section.topics { padding-top: 80px; padding-bottom: 120px; } }
@media all and (max-width: 767px) { .home-section.topics .home-section-title { margin-top: 4px; } }
@media all and (max-width: 767px) { .home-section.topics .home-section-title img { height: 38px; } }
.home-section.topics .home-section-body { margin-top: 16px; }
.home-section.topics .home-section-action { margin-top: 40px; }

.about-kv { background: url("./assets/images/about/kv_bg.jpg") no-repeat center; background-size: cover; height: 464px; }
@media all and (max-width: 767px) { .about-kv { height: 200px; } }

.about-kv-logo { position: absolute; top: 0; left: 0; width: 100%; height: calc(100% - 54px); display: flex; justify-content: center; align-items: flex-end; padding-bottom: 56px; }
@media all and (max-width: 767px) { .about-kv-logo { padding-bottom: 20px; height: calc(100% - 44px); } }
.about-kv-logo img { height: 48px; width: auto; }
@media all and (max-width: 767px) { .about-kv-logo img { height: 24px; } }

.about-main { padding-top: 160px; padding-bottom: 240px; }
@media all and (max-width: 767px) { .about-main { padding-top: 80px; padding-bottom: 120px; } }

.about-def { width: 100%; display: flex; flex-direction: column; gap: 124px; max-width: 928px; margin-left: auto; margin-right: auto; }
@media all and (max-width: 767px) { .about-def { gap: 80px; } }
.about-def > dt { align-self: flex-end; width: 240px; opacity: 0; transform: scale(1.4); filter: blur(8px); transition: 1s var(--ease-out) 0.72s; }
@media all and (max-width: 767px) { .about-def > dt { width: auto; padding-right: 36px; } }
.about-def > dt.in-view { opacity: 1; transform: scale(1); filter: blur(0); }
.about-def > dt img { height: 440px; width: auto; }
@media all and (max-width: 767px) { .about-def > dt img { height: 350px; } }
.about-def > dd { margin-top: 32px; font-size: 20px; line-height: 1.7; opacity: 0; transform: scale(1.1); filter: blur(8px); transition: 1s var(--ease-out) 0.2s; }
@media all and (max-width: 767px) { .about-def > dd { margin-top: 0; font-size: 14px; line-height: 2; } }
.about-def > dd.in-view { opacity: 1; transform: scale(1); filter: blur(0); }
.about-def > dd span { transition: 0.32s var(--ease-out); color: var(--color-theme-light); }
.about-def > dd span.filled { color: var(--color-theme); }

@media all and (max-width: 767px) { .about-desc { padding-left: 16px; } }
.about-desc + .about-desc { margin-top: 88px; }
@media all and (max-width: 767px) { .about-desc + .about-desc { margin-top: 40px; } }

.about-catch { font-size: 54px; line-height: 1.15; font-weight: 600; margin-top: 160px; }
@media all and (max-width: 767px) { .about-catch { font-size: 32px; line-height: 1.7; margin-top: 80px; } }

.archive-talent-main { padding-top: 80px; padding-bottom: 240px; }

.talent-list { max-width: 1200px; margin-left: auto; margin-right: auto; }
.talent-list > li + li { margin-top: 80px; }

.talent-card { position: relative; display: block; }
.talent-card .talent-card-box { opacity: 0; filter: blur(8px); }
.talent-card .talent-card-thumbnail-main-link, .talent-card .talent-card-thumbnail-sub { opacity: 0; filter: blur(8px); transform: translateX(24px) scale(1.1); }
@media all and (max-width: 767px) { .talent-card .talent-card-thumbnail-main-link, .talent-card .talent-card-thumbnail-sub { transform: translateX(0) scale(1.1); } }
.talent-card .talent-card-detail { opacity: 0; transform: translateY(-24px); transition: 0.64s 0.7s var(--ease-out); }
@media all and (max-width: 767px) { .talent-card .talent-card-detail { transition-delay: 0s; } }
.talent-card .talent-card-more { opacity: 0; transform: translateY(12px); transition: 0.56s var(--ease-out); }
.talent-card .talent-card-more.in-view { opacity: 1; transform: translateY(0); }
.talent-card .talent-card-thumbnail-main-link { transition: 0.92s var(--ease-out) 0.1s; }
.talent-card .talent-card-thumbnail-main .talent-card-box { transition: 0.92s var(--ease-out) 0.1s; }
.talent-card .talent-card-thumbnail-sub:nth-of-type(1) { transition: 0.92s var(--ease-out) 0.4s; }
.talent-card .talent-card-thumbnail-sub:nth-of-type(2) { transition: 0.92s var(--ease-out) 0.6s; }
.talent-card.in-view .talent-card-box, .talent-card.in-view .talent-card-thumbnail-main-link, .talent-card.in-view .talent-card-thumbnail-sub { opacity: 1; filter: blur(0); transform: none; }
.talent-card.in-view .talent-card-detail { transform: translateY(0); opacity: 1; }

.talent-card-thumbnail-list { display: flex; align-items: flex-end; }
@media all and (max-width: 767px) { .talent-card-thumbnail-list { flex-direction: column; align-items: flex-start; gap: 8px; margin-bottom: 16px; } }
.talent-card-thumbnail-list img { aspect-ratio: 580 / 733; object-fit: cover; }

.talent-card-thumbnail-main { position: relative; width: 580px; flex-shrink: 0; }
@media all and (max-width: 767px) { .talent-card-thumbnail-main { width: 100%; } }

.talent-card-thumbnail-main-link { display: block; }

.talent-card-thumbnail-sub-list { flex-grow: 1; margin-left: 24px; display: flex; gap: 16px; padding-bottom: 60px; }
@media all and (max-width: 767px) { .talent-card-thumbnail-sub-list { gap: 8px; padding-bottom: 0; margin-left: 0; } }

.talent-card-thumbnail-sub { width: 50%; }

.talent-card-box { position: absolute; bottom: 0; left: 0; padding: 24px; font-size: 0; z-index: 10; }
@media all and (max-width: 767px) { .talent-card-box { padding: 12px; } }

.talent-card-label { display: inline-flex; align-items: center; font-family: var(--ff-neue); font-size: var(--text-body-md); line-height: 1.2; height: 21px; display: inline-flex; gap: 4px; background-color: #A7E9A9; padding-top: 2px; padding-left: 12px; padding-right: 12px; }
@media all and (max-width: 767px) { .talent-card-label { font-size: 18px; line-height: 1; padding-left: 14px; padding-right: 14px; height: 24px; } }
.talent-card-label b { font-weight: 600; }

.talent-card-tag-list { margin-top: 8px; display: flex; align-items: center; font-size: var(--text-body-sm); color: #F5F6F3; font-weight: 300; line-height: 1; padding-top: 2px; padding-bottom: 2px; }
@media all and (max-width: 767px) { .talent-card-tag-list { font-size: 16px; } }
.talent-card-tag-list > li { display: flex; }
.talent-card-tag-list > li + li:before { content: '|'; display: inline-flex; padding-left: 6px; padding-right: 6px; font-size: 12px; transform: translateY(-5%); }
@media all and (max-width: 767px) { .talent-card-tag-list > li + li:before { font-size: 14px; } }

.talent-card-tag { font-family: var(--ff-neue); color: #F5F6F3; font-style: italic; }

.talent-card-detail { position: absolute; top: 80px; left: 580px; padding-left: 24px; display: flex; flex-direction: column; gap: 6px; }
@media all and (max-width: 767px) { .talent-card-detail { position: static; padding-left: 0; padding-bottom: 8px; } }
.talent-card-detail > dt { font-size: var(--text-body-sm); line-height: 1.2; }
.talent-card-detail > dd { display: flex; gap: 24px; align-items: baseline; }
.talent-card-detail > dd span { font-size: var(--text-body-lg); line-height: 1.2; }
.talent-card-detail > dd strong { font-size: var(--text-body-lg); line-height: 1.7; font-weight: normal; }

.talent-card-more { position: absolute; bottom: 0; left: 580px; margin-left: 24px; cursor: pointer; transition: 0.32s ease-out; }
@media all and (max-width: 767px) { .talent-card-more { position: static; margin-left: 0; margin-top: 16px; } }
.talent-card-more:hover { padding-left: 16px; }

.single-talent-kv { height: 252px; }
@media all and (max-width: 767px) { .single-talent-kv { height: 200px; } }

.single-talent-main { padding-top: 80px; padding-bottom: 240px; }
@media all and (max-width: 767px) { .single-talent-main { padding-top: 40px; padding-bottom: 120px; } }

.single-talent-profile-inner { display: flex; }
@media all and (max-width: 767px) { .single-talent-profile-inner { flex-direction: column; } }

.single-talent-profile-thumbnail { position: relative; width: 580px; flex-shrink: 0; cursor: pointer; overflow: hidden; }
@media all and (max-width: 767px) { .single-talent-profile-thumbnail { width: 100%; } }
.single-talent-profile-thumbnail:hover img { transform: scale(1.05); }
.single-talent-profile-thumbnail img { transition: 0.5s var(--ease-out); }

.single-talent-profile-detail { padding-left: 24px; flex-grow: 1; padding-top: 80px; display: flex; flex-direction: column; }
@media all and (max-width: 767px) { .single-talent-profile-detail { padding-left: 16px; padding-right: 16px; padding-top: 24px; } }

.single-talent-profile-detail-main { flex-grow: 1; padding-left: 8px; }
@media all and (max-width: 767px) { .single-talent-profile-detail-main { padding-left: 0; } }

.single-talent-profile-caption { font-size: 20px; }
@media all and (max-width: 767px) { .single-talent-profile-caption { font-size: 14px; } }

.single-talent-profile-name { font-size: 40px; line-height: 1.6; }
@media all and (max-width: 767px) { .single-talent-profile-name { line-height: 1.2; } }

.single-talent-profile-action { margin-top: 40px; }
@media all and (max-width: 767px) { .single-talent-profile-action { margin-top: 24px; } }
@media all and (max-width: 767px) { .single-talent-profile-action .button { width: 100%; justify-content: center; } }

.single-talent-profile-defs { margin-top: 40px; }
@media all and (max-width: 767px) { .single-talent-profile-defs { margin-top: 24px; } }
.single-talent-profile-defs > li + li { margin-top: 8px; }

.single-talent-profile-def { display: flex; font-size: var(--text-body-md); line-height: 1.3; }
@media all and (max-width: 767px) { .single-talent-profile-def { font-size: 14px; } }
.single-talent-profile-def > dt { width: 104px; padding-right: 20px; }
@media all and (max-width: 767px) { .single-talent-profile-def > dt { width: 80px; } }

.single-talent-profile-detail-sns { flex-shrink: 0; padding-top: 40px; }
@media all and (max-width: 767px) { .single-talent-profile-detail-sns { padding-top: 24px; } }

.single-talent-profile-sns-list { display: flex; gap: 8px; }

.single-talent-profile-sns-item { display: block; width: 40px; height: 40px; transition: 0.32s var(--ease-out); }
@media all and (max-width: 767px) { .single-talent-profile-sns-item { width: 32px; height: 32px; } }
.single-talent-profile-sns-item.inactive { opacity: 0.3; filter: blur(2px); }
.single-talent-profile-sns-item img { width: 100%; }

.single-talent-gallery { margin-top: 120px; padding-bottom: 120px; }
@media all and (max-width: 767px) { .single-talent-gallery { margin-top: 40px; padding-bottom: 80px; } }

.single-talent-gallery-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
@media all and (max-width: 767px) { .single-talent-gallery-list { grid-template-columns: repeat(2, 1fr); gap: 16px 20px; } }

.single-talent-gallery-item { cursor: pointer; overflow: hidden; aspect-ratio: 382 / 458; }
.single-talent-gallery-item:hover img { transform: scale(1.05); }
.single-talent-gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: 0.5s var(--ease-out); }

.single-talent-topic { padding-top: 40px; padding-bottom: 64px; border-top: 1px solid var(--color-theme-border); letter-spacing: -6%; }
.single-talent-topic.is-empty { padding-top: 32px; padding-bottom: 32px; }
@media all and (max-width: 767px) { .single-talent-topic { padding-top: 32px; padding-bottom: 32px; } }

.single-talent-topic-title { font-weight: 500; font-size: 48px; letter-spacing: -0.01em; line-height: 1.2; }
@media all and (max-width: 767px) { .single-talent-topic-title { font-size: 32px; } }

.single-talent-topic-list { padding-left: 40px; padding-right: 40px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px 100px; }
@media all and (max-width: 767px) { .single-talent-topic-list { padding-left: 0; padding-right: 0; grid-template-columns: repeat(2, 1fr); gap: 16px; } }

.single-talent-topic-list { margin-top: 32px; }

.single-talent-topic-item:hover .single-talent-topic-item-thumbnail:after { opacity: 1; transform: scale(1); }

.single-talent-topic-item-thumbnail { position: relative; aspect-ratio: 300 / 192; }
.single-talent-topic-item-thumbnail:after { content: ''; display: block; position: absolute; top: 0; right: 0; width: 100%; height: 100%; background: url("./assets/images/top/talent_light.png") no-repeat right top; background-size: cover; pointer-events: none; transform-origin: top right; opacity: 0; transform: scale(1.2); transition: 0.32s ease-out; }
.single-talent-topic-item-thumbnail img { width: 100%; height: 100%; object-fit: cover; }

.single-talent-topic-item-time { display: block; font-size: var(--text-body-md); line-height: 1; margin-top: 12px; letter-spacing: 0.02em; }
@media all and (max-width: 767px) { .single-talent-topic-item-time { font-size: 12px; } }

.single-talent-topic-item-title { font-size: var(--text-body-md); margin-top: 8px; line-height: 1.4; display: -webkit-box; -webkit-box-orient: vertical; overflow: hidden; -webkit-line-clamp: 2; }
@media all and (max-width: 767px) { .single-talent-topic-item-title { font-size: 12px; } }

.single-talent-history { padding-top: 112px; padding-bottom: 48px; border-top: 1px solid var(--color-theme-border); border-bottom: 1px solid var(--color-theme-border); }
.single-talent-history.is-empty { padding-top: 32px; padding-bottom: 32px; }
@media all and (max-width: 767px) { .single-talent-history { padding-top: 64px; } }

.single-talent-history-title { font-weight: 500; font-size: 48px; line-height: 1.2; letter-spacing: -0.01em; }
@media all and (max-width: 767px) { .single-talent-history-title { font-size: 32px; } }

.single-talent-history-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 32px 12px; margin-top: 32px; }
@media all and (max-width: 767px) { .single-talent-history-list { grid-template-columns: repeat(1, 1fr); gap: 28px; margin-top: 24px; } }

.single-talent-history-def > dt { font-size: 20px; font-weight: 500; line-height: 1.2; padding-bottom: 8px; border-bottom: 1px solid var(--color-theme); margin-bottom: 24px; }
@media all and (max-width: 767px) { .single-talent-history-def > dt { font-size: 16px; margin-bottom: 16px; } }
.single-talent-history-def > dd { font-size: 14px; line-height: 1.3; display: flex; }
@media all and (max-width: 767px) { .single-talent-history-def > dd { font-size: 12px; } }
.single-talent-history-def > dd + dd { margin-top: 16px; }
@media all and (max-width: 767px) { .single-talent-history-def > dd + dd { margin-top: 8px; } }
.single-talent-history-def > dd time { display: block; flex-shrink: 0; width: 60px; }
@media all and (max-width: 767px) { .single-talent-history-def > dd time { width: 48px; } }
.single-talent-history-def > dd span { display: block; flex-grow: 1; }

.single-talent-empty { margin-top: 16px; font-size: var(--text-body-lg); line-height: 1.3; }
@media all and (max-width: 767px) { .single-talent-empty { font-size: var(--text-body-sm); margin-top: 8px; } }

.archive-empty { padding-top: 80px; padding-bottom: 80px; text-align: center; }

.archive-topic-main { padding-top: 80px; padding-bottom: 240px; }
@media all and (max-width: 767px) { .archive-topic-main { padding-top: 40px; padding-bottom: 120px; } }

.archive-topic-nav-list { display: flex; justify-content: center; gap: 16px; }

.archive-topic-nav-item { font-size: 20px; transition: 0.32s var(--ease-out); }
@media all and (max-width: 767px) { .archive-topic-nav-item { font-size: 14px; } }
.archive-topic-nav-item.is-active, .archive-topic-nav-item:hover { color: rgba(15, 60, 44, 0.5); }
.archive-topic-nav-item:not(.is-active):before { content: '（'; }
.archive-topic-nav-item:not(.is-active):after { content: '）'; }

.archive-topic-list { margin-top: 80px; }
@media all and (max-width: 767px) { .archive-topic-list { margin-top: 40px; } }

.single-topic-kv { height: 252px; }
@media all and (max-width: 767px) { .single-topic-kv { height: 108px; } }

.single-topic-main { margin-top: 80px; padding-bottom: 240px; margin-left: auto; margin-right: auto; }
@media all and (max-width: 767px) { .single-topic-main { margin-top: 0; padding-bottom: 120px; } }

.single-topic-content { max-width: 760px; margin-left: auto; margin-right: auto; }

.single-topic-breadcrumbs { display: flex; gap: 4px; font-size: var(--text-body-md); }
@media all and (max-width: 767px) { .single-topic-breadcrumbs { font-size: 12px; } }
.single-topic-breadcrumbs > a { flex-shrink: 0; transition: 0.32s var(--ease-out); }
.single-topic-breadcrumbs > a:hover { color: rgba(15, 60, 44, 0.5); }
.single-topic-breadcrumbs > a:after { content: ' /'; }
.single-topic-breadcrumbs > span { flex-grow: 1; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 1; overflow: hidden; }

.single-topic-info { margin-top: 80px; display: flex; gap: 12px; align-items: center; }
@media all and (max-width: 767px) { .single-topic-info { margin-top: 12px; } }
.single-topic-info > time { font-size: 20px; }
@media all and (max-width: 767px) { .single-topic-info > time { font-size: 14px; } }

.single-topic-talent-info { font-size: var(--text-body-md); display: flex; align-items: center; gap: 12px; }
@media all and (max-width: 767px) { .single-topic-talent-info { font-size: 12px; gap: 8px; } }
.single-topic-talent-info a { text-decoration: underline; }
.single-topic-talent-info a:hover { text-decoration: none; }
@media all and (max-width: 767px) { .single-topic-talent-info .topics-item-tag { margin-left: 0; } }
.single-topic-talent-info:before { content: '/ '; }

.single-topic-header { margin-top: 32px; margin-bottom: 40px; }
@media all and (max-width: 767px) { .single-topic-header { margin-top: 24px; margin-bottom: 40px; } }

.single-topic-title { line-height: 1.3; font-weight: bold; font-size: 24px; }
@media all and (max-width: 767px) { .single-topic-title { font-size: 20px; } }

.single-topic-body { font-size: 16px; line-height: 1.7; max-width: 760px; margin-left: auto; margin-right: auto; }
@media all and (max-width: 767px) { .single-topic-body { font-size: 14px; } }
.single-topic-body * { margin: 0; font-family: "Noto Sans JP", sans-serif; }
.single-topic-body p { font-size: 16px; line-height: 1.6; }
@media all and (max-width: 767px) { .single-topic-body p { font-size: 14px; } }
.single-topic-body p + h3 { margin-top: 40px; }
.single-topic-body p + * { margin-top: 16px; }
.single-topic-body h2 { margin: 0 0 24px; font-size: 20px; font-weight: normal; line-height: 1.3; }
@media all and (max-width: 767px) { .single-topic-body h2 { font-size: 16px; margin-bottom: 16px; } }
.single-topic-body h2:not(:first-child) { margin-top: 48px; }
@media all and (max-width: 767px) { .single-topic-body h2:not(:first-child) { margin-top: 24px; } }
.single-topic-body h3 { margin: 0 0 20px; font-size: 18px; line-height: 1.3; }
.single-topic-body h3:not(:first-child) { margin-top: 32px; }
.single-topic-body a { color: #8CAABE; }
.single-topic-body .img-block { margin-top: 40px; margin-bottom: 40px; }
.single-topic-body img { vertical-align: middle; height: auto; max-width: 100%; width: 100%; }
.single-topic-body hr { margin-top: 50px; margin-bottom: 50px; height: 1px; background-color: #CCCCCC; }
.single-topic-body .wp-block-image { text-align: center; }
.single-topic-body .wp-block-image .alignleft { text-align: left; }
.single-topic-body .wp-block-image .alignright { text-align: right; }
.single-topic-body .wp-block-image .aligncenter { text-align: center; }
.single-topic-body .wp-block-image + * { margin-top: 32px; }
.single-topic-body .wp-block-image + .wp-block-image { margin-top: 32px; }
.single-topic-body ul, .single-topic-body ol { list-style: none; padding-left: 0; }
.single-topic-body ul:not(:first-child), .single-topic-body ol:not(:first-child) { margin-top: 1.5em; margin-bottom: 1.5em; }
.single-topic-body ul > li, .single-topic-body ol > li { position: relative; }
.single-topic-body ul > li + li, .single-topic-body ol > li + li { margin-top: 0.5em; }
.single-topic-body ul > li:before, .single-topic-body ol > li:before { position: absolute; top: 0; left: 0; }
.single-topic-body ul > li { padding-left: 1.2em; }
.single-topic-body ul > li:before { content: '・'; }
.single-topic-body ol { counter-reset: ol-list; }
.single-topic-body ol > li { padding-left: 1.4em; counter-increment: ol-list; }
.single-topic-body ol > li:before { content: counter(ol-list) "."; padding-left: 0.25em; font-family: "Hiragino Kaku Gothic Pro", "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, sans-serif; }
.single-topic-body iframe { max-width: 100%; }

.single-topic-foot { display: flex; justify-content: center; margin-top: 56px; }

.single-topic-back-button { display: inline-flex; line-height: 1.2; letter-spacing: 0.02em; transition: 0.32s var(--ease-out); }
.single-topic-back-button:hover { color: rgba(15, 60, 44, 0.5); }

.single-topic-related { margin-top: 40px; padding-top: 80px; border-top: 1px solid var(--color-theme); }

.single-topic-related-caption { font-size: var(--text-body-sm); line-height: 1.3; }
@media all and (max-width: 767px) { .single-topic-related-caption { font-size: 12px; } }

.single-topic-related-title { font-size: 48px; line-height: 1.2; font-weight: 500; }
@media all and (max-width: 767px) { .single-topic-related-title { margin-top: 4px; font-size: 24px; } }

.single-topic-related-body { margin-top: 16px; }

.contact-main { margin-top: 80px; margin-bottom: 240px; }
@media all and (max-width: 767px) { .contact-main { margin-top: 40px; margin-bottom: 120px; } }

.thanks-kv { height: 252px; }
@media all and (max-width: 767px) { .thanks-kv { height: 200px; } }

.thanks-main { padding-top: 80px; padding-bottom: 320px; }
@media all and (max-width: 767px) { .thanks-main { padding-top: 40px; padding-bottom: 200px; } }

.thanks-header { display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 12px; }
.thanks-header p { font-size: 14px; line-height: 1.3; text-align: center; }

.thanks-title img { height: 105px; width: auto; }
@media all and (max-width: 767px) { .thanks-title img { height: 54px; } }

.thanks-action { display: flex; justify-content: center; margin-top: 40px; }
.thanks-action .single-topic-back-button { font-size: 16px; }
