/*
Theme Name: AppBank
Theme URI: https://www.appbank.co.jp/
Description: for AppBank
Author: AppBank
Version: 1.0
*/

@font-face {
  font-family: 'LINESeedJPStd';
  src:
    url(./_assets/fonts/LINESeedJP_20241105/Web/WOFF/LINESeedJP_OTF_Rg.woff) format('woff'),
    url(./_assets/fonts/LINESeedJP_20241105/Web/WOFF2/LINESeedJP_OTF_Rg.woff2) format('woff2'),
    url(./_assets/fonts/LINESeedJP_20241105/Web/EOT/LINESeedJP_TTF_Rg.eot) format('eot')
  ;
  font-weight: 400;
}

@font-face {
  font-family: 'LINESeedJPStdBold';
  src:
    url(./_assets/fonts/LINESeedJP_20241105/Web/WOFF/LINESeedJP_OTF_Bd.woff) format('woff'),
    url(./_assets/fonts/LINESeedJP_20241105/Web/WOFF2/LINESeedJP_OTF_Bd.woff2) format('woff2'),
    url(./_assets/fonts/LINESeedJP_20241105/Web/EOT/LINESeedJP_TTF_Bd.eot) format('eot')
  ;
  font-weight: 700;
}

@font-face {
  font-family: 'LINESeedJPStdExtraBold';
  src:
    url(./_assets/fonts/LINESeedJP_20241105/Web/WOFF/LINESeedJP_OTF_Eb.woff) format('woff'),
    url(./_assets/fonts/LINESeedJP_20241105/Web/WOFF2/LINESeedJP_OTF_Eb.woff2) format('woff2'),
    url(./_assets/fonts/LINESeedJP_20241105/Web/EOT/LINESeedJP_TTF_Eb.eot) format('eot')
  ;
  font-weight: 800;
}

html {
  scroll-padding-top: 68px;
  font-size: 62.5%;
}

@media screen and (min-width: 769px) {
  html { scroll-padding-top: 100px; }
}

body {
  width: 100%;
  height: 100%;
  background-color: var(--body-bgcolor);
  -webkit-text-size-adjust: 100%;
  font-family: 'LINESeedJPStd', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', 'Meiryo', 'メイリオ', 'ＭＳ Ｐゴシック', 'MS P Gothic', Osaka, Arial, Helvetica, Verdana, sans-serif;
  font-size: 1rem;
  line-height: 1.6;
  font-weight: 400;
  color: #1A1C1D;
}

*,
*:before,
*:after { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box; }

img { width: auto; height: auto; max-width: 100%; border: none; vertical-align: top; }
picture { display: block; position: relative; width: 100%; }

a { color: #1A1C1D; }

strong { font-family: 'LINESeedJPStdBold', sans-serif; font-weight: 700; }

/* utility
------------------------------------------------ */
.u-r-lists { margin: 0; padding: 0; list-style: none; }
.u-r-btn { -webkit-appearance: none; -moz-appearance: none; -ms-appearance: none; appearance: none; position: relative; padding: 0; background: none; border: none; border-radius: 0; box-shadow: none; text-align: left; font-family: inherit; font-weight: inherit; line-height: inherit; color: inherit; cursor: pointer; }
.u-r-input { -webkit-appearance: none; -moz-appearance: none; -ms-appearance: none; appearance: none; position: relative; padding: 0; background: none; border: none; border-radius: 0; box-shadow: none; text-align: left; font-family: inherit; font-weight: inherit; line-height: inherit; color: inherit; }
.u-r-select { -webkit-appearance: none; -moz-appearance: none; -ms-appearance: none; appearance: none; position: relative; padding: 0; background: none; border: none; border-radius: 0; box-shadow: none; text-align: left; font-family: inherit; font-weight: inherit; line-height: inherit; color: inherit; }
.u-object-fit { width: 100%; height: 100%; max-width: inherit; object-fit: cover; font-family: 'object-fit: cover;'; }
.u-categories { display: flex; flex-wrap: wrap; }
.u-categories > span { padding: 4px 10px 2px; background-color: #DE1E40; border-radius: 8px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 1.2rem; font-weight: 700; line-height: 1.5; color: #fff; }
.u-categories > .is-cat-pr { background-color: #FF7F11; color: #fff; }
.u-categories > .is-cat-yuho { background-color: #913900; color: #fff; }
.u-categories > .is-cat-tekiji { background-color: #007CD6; color: #fff; }
.u-categories > .is-cat-kessai { background-color: #DE1D3F; color: #fff; }
.u-companies { display: flex; flex-wrap: wrap; }
.u-companies > span { padding: 7px 10px 6px; border-radius: 8px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 1.4rem; font-weight: 700; line-height: 1.5; }
.u-companies > .is-company-appbank { background-color: #DE1E40; color: #fff; }
.u-companies > .is-company-pwan { background-color: #FF7F11; color: #fff; }
.u-companies > .is-company-musicalab { background-color: #3F8FCF; color: #fff; }

@media screen and (max-width: 768px) {
  .u-d-mobile { display: inherit !important; }
  .u-d-desktop { display: none !important; }
}

@media screen and (min-width: 769px) {
  .u-d-mobile { display: none !important; }
  .u-d-desktop { display: inherit !important; }
  .u-categories > span { padding: 4px 11px 3px; font-size: 1.2rem; line-height: 1.5; }
  .u-companies > span { padding: 5px 8px 3px; font-size: 1.2rem; line-height: 1.5; }
}

/* container
------------------------------------------------ */
.l-container { position: relative; }
.l-wrap { position: relative; }
.l-main { position: relative; }

@media screen and (min-width: 769px) {
  .l-wrap { margin: 0 auto; padding: 0 20px; max-width: 1140px; }
}

/* component
------------------------------------------------ */
/* button */
.btn-1 { margin: 0; font-size: 1.4rem; line-height: 1.5; }
.btn-1 > a { display: inline-block; padding: 7px 8px 6px; min-width: 110px; border: 1px solid #DE1E40; border-radius: 26px; text-align: center; text-decoration: none; color: #DE1E40; }
.btn-2 { margin: 0; font-size: 1.6rem; line-height: 1.5; }
.btn-2 > a { display: block; padding: 15px 10px 13px; width: 100%; border: 1px solid #DE1E40; border-radius: 28px; text-align: center; text-decoration: none; color: #DE1E40; }
.btn-2.is-center > a { margin: 0 auto; }
.btn-3 { margin: 0; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 1.6rem; font-weight: 700; letter-spacing: 0.01em; line-height: 1.625; }
.btn-3 > a { display: inline-block; position: relative; padding: 12px 8px; min-width: 220px; background-color: #DE1E40; border: 1px solid #DE1E40; border-radius: 28px; text-align: center; text-decoration: none; vertical-align: top; color: #fff; }
.btn-3 > a::after { content: ''; position: absolute; top: 50%; right: 18px; transform: translateY(-50%); width: 9px; height: 15px; background: url(./_assets/img/icon/arrow1-white.svg) no-repeat center center; background-size: 100%; }

@media screen and (max-width: 768px) {
}

@media screen and (min-width: 769px) {
  .btn-1 { font-size: 1.4rem; }
  .btn-1 > a { padding: 7px 8px 6px; min-width: 130px; }
  .btn-2 { font-size: 1.6rem; }
  .btn-2 > a { padding: 15px 10px 13px; max-width: 246px; }
  .btn-3 { font-size: 1.6rem; line-height: 1.625; }
  .btn-3 > a { padding: 12px 8px; min-width: 220px; }
}

/* title */
.title-page { position: relative; height: 108px; background: url(./_assets/img/share/title_page_bg.png) no-repeat right center #F6F7F9; background-size: auto 100%; }
.title-page > .l-wrap { display: flex; flex-flow: column; justify-content: center; height: 100%; }
.title-page-en { margin: 0; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 1.4rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.6428571428; color: #DE1E40; }
.title-page-ja { margin: -5px 0 0; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 3rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.6; color: #54585B; }
.title-page-parent { margin: 0; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 1.6rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.625; color: #54585B; }
.title-page.is-s-min { height: 70px; background: #F6F7F9; }
.title-page.is-s-min .title-page-ja { margin: 0; font-size: 2.6rem; line-height: 1.6153846153; }
.title-page.is-bg-no { background: #F6F7F9; }
.title-1 { display: flex; align-items: baseline; gap: 11px; position: relative; margin-bottom: 22px; }
.title-1-en { margin: 0; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 2.8rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.6071428571; }
.title-1-ja { margin: 0; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 1.8rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.6111111111; }
.title-2 { position: relative; margin: 0 0 20px; padding-left: 30px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 2rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.6; }
.title-2::before { content: ''; position: absolute; top: 8px; left: 0; width: 16px; height: 16px; background-color: #DE1E40; border-radius: 50%; }

@media screen and (max-width: 768px) {
  .title-page > .l-wrap { padding: 0 26px; }
  .title-2 { margin-left: -12px; }
}

@media screen and (min-width: 769px) {
  .title-page { height: 250px; }
  .title-page-en { font-size: 2.2rem; letter-spacing: 0.04em; line-height: 1.5909090909; }
  .title-page-ja { margin-top: -4px; font-size: 5.4rem; letter-spacing: 0.01em; line-height: 1.6111111111; }
  .title-page-parent { font-size: 2.4rem; line-height: 1.625; }
  .title-page.is-s-min { height: 77px; }
  .title-page.is-s-min .title-page-ja { font-size: 2.6rem; letter-spacing: 0.02em; line-height: 1.6153846153; }
  .title-1 { gap: 12px; margin-bottom: 13px; }
  .title-1-en { font-size: 3.2rem; line-height: 1.625; }
  .title-1-ja { font-size: 2rem; line-height: 1.6; }
  .title-2 { margin-bottom: 30px; font-size: 2rem; line-height: 1.6; }
}

/* topicpath */
.topicpath { padding: 12px 0 24px; }
.topicpath-lists { display: flex; }
.topicpath-lists-item { white-space: nowrap; font-size: 1.4rem; letter-spacing: 0.02em; line-height: 1.6428571428; }
.topicpath-lists-item:not(:last-child)::after { content: '>'; padding: 0 0.6em; }
.topicpath-lists-item:last-child { text-overflow: ellipsis; overflow: hidden; }
.topicpath-lists-item > a { display: inline-block; text-decoration: none; vertical-align: top; }

@media screen and (max-width: 768px) {
  .topicpath > .l-wrap { padding: 0 12px; }
}

@media screen and (min-width: 769px) {
  .topicpath { padding: 14px 0 34px; }
  .topicpath-lists-item { font-size: 1.2rem; line-height: 1.5833333333; }
}

/* lists */
.lists-news-item { position: relative; }
.lists-news-item .post-edit-link { position: absolute; top: 0; left: 0; z-index: 2; }
.lists-news-item > a:not(.post-edit-link) { display: block; text-decoration: none; }
.lists-news-photo { position: relative; aspect-ratio: 1 / 0.5771339527; margin-bottom: 9px; border-radius: 18px; overflow: hidden; }
.lists-news-categories { display: flex; flex-wrap: wrap; position: absolute; bottom: 10px; left: 10px; margin: 0; }
.lists-news-categories > span { padding: 7px 18px 5px; background-color: rgba(0,0,0,0.6); border-radius: 24px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 1.8rem; font-weight: 700; line-height: 1.5; color: #fff; }
.lists-news-info { display: flex; flex-wrap: wrap; align-items: center; column-gap: 12px; }
.lists-news-companies { display: flex; flex-wrap: wrap; margin: 0; }
.lists-news-date { margin: 0; text-align: right; font-size: 1.4rem; line-height: 1.6428571428; }
.lists-news-title { margin: 12px 0 0; width: 100%; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 1.6rem; font-weight: 700; line-height: 1.48; }
.lists-ir-item { display: flex; align-items: center; padding: 18px 0 10px; }
.lists-ir-item:not(:last-child) { border-bottom: 1px solid #C3C3C3; }
.lists-ir-date { margin: 0; font-size: 1.4rem; line-height: 1.64285714286; }
.lists-ir-categories { display: flex; flex-wrap: wrap; margin: 0; }
.lists-ir-categories > span { padding: 4px 10px 2px; min-width: 100px; text-align: center; }
.lists-ir-title { margin: 0; font-size: 1.4rem; line-height: 1.71428571429; }
.lists-ir-title > a { display: inline-block; vertical-align: top; }
.lists-ir-title > a[href*='.pdf']::after { content: ''; display: inline-block; margin: 2px 0 0 8px; width: 16px; height: 17px; background: url(./_assets/img/icon/pdf1.png) no-repeat center center; background-size: 100%; vertical-align: top; }

@media screen and (max-width: 768px) {
  .lists-news[data-column-mobile] { display: grid; }
  .lists-news[data-column-mobile='1'] { gap: 32px; }
  .lists-news[data-column-mobile='2'] { row-gap: 20px; column-gap: 14px; grid-template-columns: repeat(2,calc(50% - (14px / 2))); }
  .lists-news[data-column-mobile='2'] .lists-news-categories { bottom: 5px; left: 5px; }
  .lists-news[data-column-mobile='2'] .lists-news-categories > span { padding: 7px 15px 5px; font-size: 1.5rem; }
  .lists-news[data-column-mobile='2'] .lists-news-companies { order: 2; }
  .lists-news[data-column-mobile='2'] .lists-news-date { order: 1; margin-bottom: 3px; }
  .lists-news[data-column-mobile='2'] .lists-news-title { order: 3; }
  .lists-ir-item { flex-wrap: wrap; }
  .lists-ir-categories { margin-left: 8px; }
  .lists-ir-title { margin-top: 10px; width: 100%; }
}

@media screen and (min-width: 769px) {
  .lists-news-photo { margin-bottom: 14px; }
  .lists-news-categories { bottom: 8px; left: 8px; }
  .lists-news-categories > span { padding: 5px 10px 3px; font-size: 1.2rem; line-height: 1.5; }
  .lists-news-info { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; }
  .lists-news-date { margin-left: auto; font-size: 1.4rem; }
  .lists-news-title { margin-top: 11px; font-size: 1.6rem; line-height: 1.48; }
  .lists-news[data-column-desktop] { display: grid; }
  .lists-news[data-column-desktop='4'] { row-gap: 64px; column-gap: 35px; grid-template-columns: repeat(4,calc((100% / 4) - (35px / (4 / 3)))); }
  .lists-ir-item { padding: 11px 20px 13px; }
  .lists-ir-date { width: 130px; font-size: 1.4rem; line-height: 1.64285714286; }
  .lists-ir-categories { width: 134px; }
  .lists-ir-categories > span { padding: 5px 10px 6px; min-width: 108px; }
  .lists-ir-title { width: calc(100% - (130px + 134px)); font-size: 1.4rem; line-height: 1.71428571429; }
}

/* banner */
.banner-1 { padding: 50px 0; background-color: #F6F7F9; }
.banner-1-lists { display: grid; gap: 24px; }
.banner-1-lists__item { height: 105px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 2rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.6; }
.banner-1-lists__item > a { display: flex; align-items: center; position: relative; padding: 10px 28px; height: 100%; background-color: #fff; border-radius: 16px; box-shadow: 0 6px 16px rgba(53,57,60,0.07); text-decoration: none; }
.banner-1-lists__item > a::after { content: ''; position: absolute; top: 50%; right: 18px; transform: translateY(-50%); width: 30px; height: 30px; background: url(./_assets/img/icon/arrow2.svg) no-repeat center center; background-size: 100%; }
.banner-ir { display: grid; gap: 20px; }
.banner-ir-item { height: 120px; }
.banner-ir-item > a { display: grid; grid-template-columns: 120px calc(100% - 120px); position: relative; height: 100%; background-color: #FAFBFC; border: 1px solid rgba(152,162,171,0.3); border-radius: 14px; text-decoration: none; overflow: hidden; }
.banner-ir-item > a::after { content: ''; position: absolute; top: 50%; right: 18px; transform: translateY(-50%); width: 30px; height: 30px; background: url(./_assets/img/icon/arrow2.svg) no-repeat center center; background-size: 100%; }
.banner-ir-item i { display: block; position: relative; width: 100%; height: 100%; }
.banner-ir-item i img { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); }
.banner-ir-title { display: flex; align-items: center; margin: 0; padding: 0 32px 0 16px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 1.8rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.6111111111; }

.banner-ir-item i.is-i-finance img { width: 71px; }
.banner-ir-item i.is-i-library img { width: 67px; }
.banner-ir-item i.is-i-stock img { width: 67px; }
.banner-ir-item i.is-i-event img { width: 67px; }

@media screen and (max-width: 768px) {
  .banner-1 > .l-wrap { padding: 0 25px; }
}

@media screen and (min-width: 769px) {
  .banner-1 { padding: 70px 0; }
  .banner-1 > .l-wrap { max-width: 1040px; }
  .banner-1-lists { gap: 46px; grid-template-columns: repeat(2,calc(50% - (46px / 2))); }
  .banner-1-lists__item { height: 156px; font-size: 2.4rem; line-height: 1.625; }
  .banner-1-lists__item > a { padding: 10px 46px; }
  .banner-1-lists__item > a::after { right: 36px; width: 32px; height: 32px; }
  .banner-ir { gap: 50px; grid-template-columns: repeat(2,calc(50% - (50px / 2))); }
  .banner-ir-item { aspect-ratio: 1 / 0.326996197718; height: auto; }
  .banner-ir-item > a { grid-template-columns: 32.6996197719% calc(100% - 32.6996197719%); }
  .banner-ir-item > a::after { right: 36px; width: 32px; height: 32px; }
  .banner-ir-title { padding: 0 70px 0 30px; font-size: 2.4rem; line-height: 1.625; }

  .banner-ir-item i.is-i-finance img { width: 57.5581395349%; }
  .banner-ir-item i.is-i-library img { width: 54.6511627907%; }
  .banner-ir-item i.is-i-stock img { width: 54.6511627907%; }
  .banner-ir-item i.is-i-event img { width: 54.6511627907%; }
}

/* pagination */
.pagination { display: flex; justify-content: center; margin-top: 38px; }
.pagination-link,
.pagination-current,
.pagination-ellipses { padding: 4px 15px; border-radius: 6px; font-size: 1.4rem; line-height: 3.1428571428; }
.pagination-link { text-decoration: none; color: #333; }
.pagination-current { background-color: #DE1E40; color: #fff; }
.pagination-ellipses { margin-top: -4px; padding: 0; font-size: 2.4rem; line-height: 1.8333333333; opacity: 0.5; }
.pagination-prev,
.pagination-next { display: flex; align-items: center; position: relative; }
.pagination-prev svg,
.pagination-next svg { width: 12px; height: 22px; }
.pagination-prev { margin-right: auto; }
.pagination-prev svg { transform: rotate(180deg); }
.pagination-next { margin-left: auto; }
.pagination-prev.is-disabled,
.pagination-next.is-disabled { pointer-events: none; }
.pagination-prev.is-disabled svg,
.pagination-next.is-disabled svg { opacity: 0.2; }

@media screen and (max-width: 768px) {
}

@media screen and (min-width: 769px) {
  .pagination { margin-top: 50px; }
  .pagination-link,
  .pagination-current,
  .pagination-ellipses { padding: 4px 17px; }
  .pagination-prev { margin-right: 58px; }
  .pagination-next { margin-left: 58px; }
}

/* pager */
.pager { display: flex; flex-wrap: wrap; row-gap: 36px; position: relative; margin-top: 34px; padding-top: 28px; border-top: 2px solid rgba(217,217,217,0.5); }
.pager-link { width: calc(50% - 18px); }
.pager-link-name { margin: 0 0 30px; font-size: 1.6rem; line-height: 1.5; }
.pager-link-name > a { display: inline-flex; align-items: center; gap: 20px; text-decoration: none; vertical-align: top; color: #DE1E40; }
.pager-link-name svg { width: 12px; height: 22px; }
.pager-link-name path { fill: #DE1E40; }
.pager-link-post > a { display: block; text-decoration: none; width: 100%; }
.pager-link-post__photo { position: relative; aspect-ratio: 1 / 0.5771339527; border-radius: 18px; overflow: hidden; }
.pager-link-post__date { margin: 0 0 7px; font-size: 1.2rem; line-height: 1.5833333333; }
.pager-link-post__categories { margin: 0 0 9px; }
.pager-link-post__title { margin: 0; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 1.6rem; font-weight: 700; line-height: 1.48; }
.pager-back { margin: 48px 0 0; width: 100%; text-align: center; font-size: 1.6rem; line-height: 1.5; }
.pager-back > a { display: inline-block; margin: 0 auto; padding: 14px 10px; min-width: 280px; border: 1px solid #DE1E40; border-radius: 28px; text-decoration: none; vertical-align: top; color: #DE1E40; }

.pager-link.is-prev .pager-link-name svg { transform: rotate(180deg); }
.pager-link.is-next { margin-left: auto; }
.pager-link.is-next .pager-link-name { text-align: right; }

@media screen and (max-width: 768px) {
  .pager-link-post__photo { margin-bottom: 9px; }
}

@media screen and (min-width: 769px) {
  .pager { margin-top: 64px; padding-top: 36px; }
  .pager-link-name { margin-bottom: 25px; font-size: 1.6rem; line-height: 1.5; }
  .pager-link-post { max-width: 415px; }
  .pager-link-post > a { display: grid; gap: 16px; grid-template-columns: 148px calc(100% - (148px + 16px)); }
  .pager-link-post__date { margin-bottom: 5px; font-size: 1.2rem; line-height: 1.5833333333; }
  .pager-link-post__categories { margin-bottom: 7px; }
  .pager-link-post__title { font-size: 1.6rem; line-height: 1.48; }
  .pager-back { margin-top: 44px; font-size: 1.6rem; line-height: 1.5; }
  .pager-back > a { padding: 14px 10px; min-width: 246px; }

  .pager-link.is-next .pager-link-post { margin-left: auto; }
}

/* header
------------------------------------------------ */
.l-hd { position: sticky; top: 0; width: 100%; height: var(--header-height-mobile); background-color: #fff; box-shadow: 0 0 10px rgba(0,0,0,0.05); z-index: 10; }
.l-hd > .l-wrap { height: 100%; }
.l-hd-content { position: relative; width: 100%; height: 100%; z-index: 2; }
.l-hd-logo { position: relative; top: 24px; left: 19px; margin: 0; width: 159px; font-size: 1rem; line-height: 1.2; }
.l-hd-logo > a { display: block; width: 100%; }
.l-hd-menu { position: absolute; margin: 0; top: 50%; right: 27px; transform: translateY(-50%); width: 27px; height: 27px; }
.l-hd-menu > button,
.l-hd-menu span { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.l-hd-menu span { text-indent: -9999px; white-space: nowrap; overflow: hidden; }
.l-hd-menu > button::after,
.l-hd-menu span::before,
.l-hd-menu span::after { content: ''; position: absolute; left: 0; transition: transform 0.4s ease; width: 27px; height: 3px; background-color: #54585B; border-radius: 10px; }
.l-hd-menu > button::after { top: 3px; }
.l-hd-menu span::before { top: 12px; }
.l-hd-menu span::after { top: 21px; }
.l-hd-menu > button[aria-expanded=true]::after { opacity: 0; }
.l-hd-menu > button[aria-expanded=true] span::before,
.l-hd-menu > button[aria-expanded=true] span::after { top: 50%; }
.l-hd-menu > button[aria-expanded=true] span::before { transform: rotate(45deg); }
.l-hd-menu > button[aria-expanded=true] span::after { transform: rotate(-45deg); }

@media screen and (max-width: 768px) {
}

@media screen and (min-width: 769px) {
  .l-hd { height: var(--header-height-desktop); background-color: rgba(255,255,255,0.94); box-shadow: 0 0 6px rgba(0,0,0,0.1); backdrop-filter: blur(40px); }
  .l-hd-content { z-index: 1; }
  .l-hd-logo { top: 36px; left: 20px; width: 209px; }
  .l-hd-menu { display: none; }
}

/* global navigation
------------------------------------------------ */
.l-gnav-search { position: relative; width: 100%; }
.l-gnav-search > form { display: block; position: relative; width: 100%; }
.l-gnav-search__keyword { padding: 8px 46px 8px 20px; width: 100%; height: 48px; border: 2px solid #A7ABAF; border-radius: 26px; font-size: 1.8rem; line-height: 1.6111111111; }
.l-gnav-search__submit { position: absolute; top: 50%; right: 17px; transform: translateY(-50%); width: 22px; height: 22px; }
.l-gnav-sns__item { width: 32px; height: 32px; }
.l-gnav-sns__item > a { display: flex; justify-content: center; align-items: center; width: 100%; height: 100%; }
.l-gnav-sns__item.is-x img { width: 23px; }

@media screen and (max-width: 768px) {
  .l-gnav { pointer-events: none; position: absolute; top: 0; left: 0; transition: opacity 0.4s ease; width: 100%; height: 100dvh; background-color: #fff; overflow-y: auto; overscroll-behavior: contain; opacity: 0; z-index: 1; }
  .l-gnav[aria-hidden=false] { pointer-events: inherit; opacity: 1; }
  .l-gnav-content { position: relative; padding: 78px 13px 22px; min-height: 100%; }
  .l-gnav-content::after { content: ''; position: absolute; bottom: 0; left: 0; width: 100%; height: 7px; background: url(./_assets/img/share/bg1.svg) repeat left top; background-size: 100%; }
  .l-gnav-search { margin-bottom: 20px; }
  .l-gnav-links__item { font-size: 1.6rem; line-height: 1.625; }
  .l-gnav-links__item:not(:last-child) { border-bottom: 1px solid #C3C3C3; }
  .l-gnav-links__item > a,
  .l-gnav-links__trigger { display: block; position: relative; padding: 10px 40px 10px 11px; width: 100%; }
  .l-gnav-links__trigger::after { content: ''; position: absolute; top: 50%; right: 12px; transition: transform 0.4s ease; transform: translateY(-50%) rotate(90deg); width: 7px; height: 14px; background: url(./_assets/img/icon/arrow1.svg) no-repeat center center; background-size: 100%; }
  .l-gnav-links__trigger[aria-expanded=true]::after { transform: translateY(-50%) rotate(-90deg); }
  .l-gnav-links__target { display: none; }
  .l-gnav-links__item > a { text-decoration: none; }
  .l-gnav-links__sub { padding: 10px 20px 20px; }
  .l-gnav-links__sub__item { font-size: 1.6rem; line-height: 1.625; }
  .l-gnav-links__sub__item:not(:first-child) { margin-top: 10px; }
  .l-gnav-links__sub__item > a { display: block; text-decoration: none; }
  .l-gnav-sns { display: flex; justify-content: flex-end; gap: 26px; margin-top: 12px; }

  .body-gnav-open { overflow: hidden; }
}

@media screen and (min-width: 769px) {
  .l-gnav { position: absolute; top: 0; right: 38px; height: 100%; z-index: 2; }
  .l-gnav-content { position: absolute; height: 100%; }
  .l-gnav-search { position: absolute; top: 17px; right: 0; width: 189px; }
  .l-gnav-search__keyword { padding: 4px 30px 4px 12px; height: 32px; border-width: 1px; font-size: 1.4rem; line-height: 1.6428571428; }
  .l-gnav-search__submit { right: 12px; width: 15px; }
  .l-gnav-links { display: flex; gap: 39px; position: absolute; bottom: 0; right: 0; }
  .l-gnav-links__item { position: relative; white-space: nowrap; font-size: 1.4rem; line-height: 1.6428571428; }
  .l-gnav-links__item > a,
  .l-gnav-links__trigger { display: inline-block; position: relative; padding-bottom: 12px; vertical-align: top; }
  .l-gnav-links__item > a { text-decoration: none; }
  .l-gnav-links__trigger { padding-right: 18px; }
  .l-gnav-links__trigger::after { content: ''; position: absolute; top: 6px; right: 0; transition: transform 0.4s ease; transform: rotate(90deg); width: 5px; height: 10px; background: url(./_assets/img/icon/arrow1.svg) no-repeat center center; background-size: 100%; }
  .l-gnav-links__trigger[aria-expanded=true] { color: #DE1E40; }
  .l-gnav-links__trigger[aria-expanded=true]::after { transform: rotate(-90deg); background-image: url(./_assets/img/icon/arrow1-red.svg); }
  .l-gnav-links__target { display: none; pointer-events: none; position: absolute; top: 35px; left: -10px; transition: opacity 0.4s ease; padding: 18px 8px; min-width: 164px; background-color: #fff; border-radius: 0 0 8px 8px; box-shadow: 0 15px 28px rgba(0,0,0,0.12); opacity: 0; }
  .l-gnav-links__target[aria-hidden=false] { pointer-events: inherit; opacity: 1; }
  .l-gnav-links__sub__item { font-size: 1.4rem; line-height: 1.6428571428; }
  .l-gnav-links__sub__item:not(:first-child) { margin-top: 5px; }
  .l-gnav-links__sub__item > a { display: block; padding: 9px 20px 6px; width: 100%; border-radius: 8px; text-decoration: none; }
  .u-device-click .l-gnav-links__sub__item > a { transition: background-color 0.4s ease; }
  .l-gnav-links__sub__item > a.is-active,
  .u-device-click .l-gnav-links__sub__item > a:hover { background-color: #F6F7F9; }
  .l-gnav-sns { display: flex; gap: 12px; position: absolute; top: 21px; right: 208px; }
  .l-gnav-sns__item { width: 22px; height: 22px; }
  .l-gnav-sns__item.is-x img { width: 16px; }
}

/* top
------------------------------------------------ */
/* common */
.body-home .l-ft { margin-top: 0; }

/* visual */
.top-visual { position: relative; margin-top: calc(var(--header-height-mobile) * -1); height: 515px; overflow: hidden; z-index: 1; }
.top-visual > .l-wrap { height: 100%; }
.top-visual-copy { position: absolute; top: 257px; left: 0; margin: 0; width: 100%; text-shadow: 0 1px 50px #1A1C1D; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 3.4rem; font-weight: 700; letter-spacing: 0.07em; line-height: 1.5; color: #fff; z-index: 2; }
.top-visual-photo { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 1; }
.top-visual-photo picture { height: 100%; }

@media screen and (max-width: 768px) {
  .top-visual-copy { padding: 0 10px; text-align: center; }
}

@media screen and (min-width: 769px) {
  .top-visual { margin-top: calc(var(--header-height-desktop) * -1); height: 800px; }
  .top-visual::before { content: ''; position: absolute; top: var(--header-height-desktop); left: 0; width: 100%; height: 4px; background: url(./_assets/img/share/bg1.svg) no-repeat center center; background-size: 100%; z-index: 2; }
  .top-visual-copy { top: 308px; left: 20px; width: calc(100% - 40px); font-size: 6rem; }
}

/* content */
.top-content { position: relative; z-index: 2; }
.top-content::before { content: ''; pointer-events: none; position: absolute; top: -18px; left: 0; width: 100%; height: 117px; background-color: rgba(255,255,255,0.88); backdrop-filter: blur(12px); z-index: -1; }

@media screen and (min-width: 769px) {
  .top-content::before { top: -21px; height: 49px; }
}

/* news */
.top-news { position: relative; padding: 7px 0 44px; }
.top-news-above { position: relative; }
.top-news-above .btn-1 { position: absolute; top: 0; right: 0; }

@media screen and (max-width: 768px) {
  .top-news > .l-wrap { padding: 0 17px; }
}

@media screen and (min-width: 769px) {
  .top-news { padding: 17px 0 62px; }
}

/* about */
.top-about { position: relative; padding: 58px 0 56px; background-color: #FAFBFC; }
.top-about-title { margin: 0; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 7.4rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.1621621621; color: #DE1E40; }
.top-about-copy { margin: 0 0 20px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 2.8rem; font-weight: 700; line-height: 1.2; color: #676B6F; }
.top-about-text { margin: 0; font-size: 1.6rem; line-height: 1.72; }
.top-about-info .btn-2 { margin: 38px 22px 0; }

@media screen and (max-width: 768px) {
  .top-about > .l-wrap { padding: 0 31px; }
  .top-about-title { margin-bottom: 32px; padding-bottom: 27px; border-bottom: 2px solid #D9D9D9; }
}

@media screen and (min-width: 769px) {
  .top-about { padding: 218px 0; }
  .top-about > .l-wrap { display: flex; justify-content: center; align-items: center; }
  .top-about-title { margin-right: 72px; padding-right: 76px; border-right: 2px solid #D9D9D9; font-size: 10rem; line-height: 1.2; }
  .top-about-copy { margin-bottom: 18px; font-size: 3.2rem; }
  .top-about-text { font-size: 1.6rem; }
  .top-about-info { max-width: 462px; }
  .top-about-info .btn-2 { margin: 30px 0 0; }
}

/* ir */
.top-ir { position: relative; padding: 40px 0 62px; }
.top-ir-title { margin: 0 0 26px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 3.2rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.625; }
.top-ir-title > a { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; }
.top-ir-title > a::after { content: ''; width: 32px; height: 32px; background: url(./_assets/img/icon/arrow2.svg) no-repeat center center; background-size: 100%; }
.top-ir-news { margin-bottom: 32px; }
.top-ir-news__title { margin: 0 0 4px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 2rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.6; }

@media screen and (max-width: 768px) {
  .top-ir > .l-wrap { padding: 0 17px; }
}

@media screen and (min-width: 769px) {
  .top-ir { padding: 50px 0 82px; }
  .top-ir-title { margin-bottom: 35px; font-size: 3.2rem; }
  .top-ir-title > a { gap: 14px; }
  .top-ir-title > a::after { width: 32px; height: 32px; }
  .top-ir-news { margin: 0 auto 50px; max-width: 1000px; }
  .top-ir-news__title { margin-bottom: 20px; font-size: 2rem; letter-spacing: 0.02em; line-height: 1.6; }
}

/* news
------------------------------------------------ */
/* archive */

@media screen and (max-width: 768px) {
  .news-archive > .l-wrap { padding: 0 25px; }
}

/* detail */
.news-detail-above { display: flex; flex-wrap: wrap; align-items: center; margin-bottom: 18px; }
.news-detail-companies { margin: 0 10px 0 0; }
.news-detail-categories { display: flex; flex-wrap: wrap; margin: 0 13px 0 0; }
.news-detail-categories > span { padding: 6px 10px 5px; background-color: rgba(0,0,0,0.5); border-radius: 24px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 1.5rem; font-weight: 700; line-height: 1.5; color: #fff; }
.news-detail-date { margin: 0; font-size: 1.4rem; line-height: 1.6428571428; }
.news-detail-sns { display: flex; justify-content: flex-end; gap: 8px; width: 100%; }
.news-detail-sns__item { width: 38px; height: 38px; }
.news-detail-sns__item > a { display: block; width: 100%; height: 100%; }
.news-detail-title { margin: 16px 0 0; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 2.8rem; font-weight: 700; line-height: 1.48; }
.news-detail-content { font-size: 1.6rem; line-height: 2.02; }
.news-detail-content p { margin: 0; }
.news-detail-content p + p { margin-top: 2.02em; }
.news-detail-eyecatch { margin-bottom: 30px; border-radius: 18px; overflow: hidden; }

@media screen and (max-width: 768px) {
  .news-detail > .l-wrap { padding: 0 13px; }
  .news-detail-sns { margin-top: 18px; }
}

@media screen and (min-width: 769px) {
  .news-detail > .l-wrap { max-width: 1040px; }
  .news-detail-above { margin-bottom: 24px; }
  .news-detail-companies { margin-right: 8px; }
  .news-detail-categories { margin-right: 12px; }
  .news-detail-categories > span { padding: 5px 10px 3px; font-size: 1.2rem; line-height: 1.5; }
  .news-detail-date { font-size: 1.4rem; line-height: 1.6428571428; }
  .news-detail-sns { gap: 6px; margin-left: auto; width: auto; }
  .news-detail-sns__item { width: 30px; height: 30px; }
  .news-detail-title { margin-top: 38px; font-size: 2.8rem; line-height: 1.48; }
  .news-detail-content { font-size: 1.6rem; line-height: 2.02; }
  .news-detail-content p + p { margin-top: 2.02em; }
  .news-detail-eyecatch { margin-bottom: 36px; }
}

/* servide
------------------------------------------------ */
/* common */
.service-below { margin-top: 60px; }

@media screen and (max-width: 768px) {
  .service-below > .l-wrap { padding: 0 12px; }
  .service-below .btn-2 > a { max-width: 246px; }
}

@media screen and (min-width: 769px) {
  .service-below { margin-top: 60px; }
}

/* index */
.service-index { position: relative; overflow: hidden; }
.service-index-block { position: relative; }
.service-index-block:not(:first-child) { margin-top: 24px; }
.service-index-block__title { margin: 0; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 2.6rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.6153846153; }
.service-index-block__subtitle { margin: 0 0 10px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 2.2rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.5909090909; }
.service-index-block__text { margin: 0; font-size: 1.6rem; letter-spacing: 0.02em; line-height: 1.875; }
.service-index-block__award { margin: 22px 0 0; }
.service-index-block__award__title { margin-bottom: 10px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 2rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.6; }
.service-index-block__award__text { margin: 0 10px; font-size: 1.4rem; letter-spacing: 0.02em; line-height: 1.7142857142; }
.service-index-block__btn { margin-top: 30px; }

@media screen and (max-width: 768px) {
  .service-index > .l-wrap { padding: 0 12px; }
  .service-index-block { padding: 30px 24px 42px; background-color: #F6F7F9; border-radius: 32px; }
  .service-index-block__title { text-align: center; }
  .service-index-block__btn { text-align: center; }
  .service-index-block.is-net .service-index-block__title { margin-bottom: 36px; }
  .service-index-block.is-net .service-index-block__image { transform: translateX(-24px); margin-bottom: 13px; width: calc(100% + 24px); }
  .service-index-block.is-media .service-index-block__title { margin-bottom: 32px; }
  .service-index-block.is-media .service-index-block__image { margin: 0 22px 26px; }
  .service-index-block.is-video .service-index-block__title { margin-bottom: 36px; }
  .service-index-block.is-video .service-index-block__image { margin: 0 2px 32px; }
}

@media screen and (min-width: 769px) {
  .service-index-block { display: grid; justify-content: space-between; align-items: center; padding: 68px 40px 60px; }
  .service-index-block:not(:first-child) { margin-top: 84px; }
  .service-index-block::after { content: ''; position: absolute; top: 0; width: calc((100vw - 80px) - 24.625vw); height: 100%; background-color: #F6F7F9; border-radius: 38px; z-index: -1; }
  .service-index-block__title { font-size: 3.8rem; line-height: 1.6052631578; }
  .service-index-block__image { position: absolute; top: 50%; transform: translateY(-50%); }
  .service-index-block__subtitle { margin: 28px 0 14px; font-size: 2rem; line-height: 1.6; }
  .service-index-block__text { font-size: 1.4rem; line-height: 2; }
  .service-index-block__award { margin-top: 18px; }
  .service-index-block__award__title { margin-bottom: 8px; font-size: 1.6rem; line-height: 1.625; }
  .service-index-block__award__text { margin: 0 10px; font-size: 1.2rem; line-height: 1.8333333333; }
  .service-index-block__btn { margin-top: 28px; }

  .service-index-block:nth-of-type(odd) { grid-template-columns: calc(100% - 56.3636363636%) 56.3636363636%; }
  .service-index-block:nth-of-type(odd)::after { right: calc(((1100px - 100vw) / 2) + 40px); }
  .service-index-block:nth-of-type(odd) .service-index-block__image { left: 0; }
  .service-index-block:nth-of-type(even) { grid-template-columns: 56.3636363636% calc(100% - 56.3636363636%); }
  .service-index-block:nth-of-type(even) .service-index-block__image { right: 0; }
  .service-index-block:nth-of-type(even)::after { left: calc(((1100px - 100vw) / 2) + 40px); }

  .service-index-block.is-net .service-index-block__image { left: -40px; width: 45.9227272727%; }
  .service-index-block.is-net .service-index-block__title { grid-row: 1; grid-column: 2; }
  .service-index-block.is-net .service-index-block__text { grid-row: 2; grid-column: 2; }
  .service-index-block.is-net .service-index-block__award { grid-row: 3; grid-column: 2; }
  .service-index-block.is-net .service-index-block__btn { grid-row: 4; grid-column: 2; }

  .service-index-block.is-media .service-index-block__image { width: 36.9090909090%; }
  .service-index-block.is-media .service-index-block__title { grid-row: 1; grid-column: 1; }
  .service-index-block.is-media .service-index-block__subtitle { grid-row: 2; grid-column: 1; }
  .service-index-block.is-media .service-index-block__text { grid-row: 3; grid-column: 1; }

  .service-index-block.is-video .service-index-block__image { width: 38.2727272727%; }
  .service-index-block.is-video .service-index-block__title { grid-row: 1; grid-column: 2; }
  .service-index-block.is-video .service-index-block__subtitle { grid-row: 2; grid-column: 2; }
  .service-index-block.is-video .service-index-block__text { grid-row: 3; grid-column: 2; }
}

@media screen and (min-width: 769px) and (max-width: 1140px) {
  .service-index-block:nth-of-type(odd)::after { right: 0; }
  .service-index-block:nth-of-type(even)::after { left: 0; }
}

/* subsidiary */
.service-subsidiary { margin-top: 40px; }
.service-subsidiary::before { content: ''; display: block; margin: 0 auto 40px; width: calc(100% - 24px); height: 4px; background: url(./_assets/img/share/bg1.svg) no-repeat center center; background-size: 100%; }
.service-subsidiary-title { margin: 0 0 28px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 3.8rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.6052631578; }
.service-subsidiary-block + .service-subsidiary-block { margin-top: 46px; }
.service-subsidiary-block__title { position: relative; margin: 0 0 34px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 1.8rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.6111111111; color: #54585B; }
.service-subsidiary-block__title::before { content: ''; position: absolute; top: 50%; right: 0; transform: translateY(-50%); width: 100%; height: 4px; background-color: #D9D9D9; z-index: 1; }
.service-subsidiary-block__title > span { display: inline-block; position: relative; padding-right: 10px; background-color: #fff; z-index: 2; }
.service-subsidiary-corporate__logo { margin: 0 0 40px; }
.service-subsidiary-corporate__logo > a { display: inline-block; vertical-align: top; }
.service-subsidiary-corporate__box { margin: 0; }
.service-subsidiary-corporate__box__title { position: relative; margin-bottom: 15px; padding-left: 78px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 2.2rem; font-weight: 700; line-height: 1.3636363636; color: #54585B; }
.service-subsidiary-corporate__box__title > i { position: absolute; top: 50%; transform: translateY(-50%); }
.service-subsidiary-corporate__box__text { margin: 0; font-size: 1.6rem; letter-spacing: 0.02em; line-height: 1.625; color: #54585B; }

.service-subsidiary-corporate.is-pwan .service-subsidiary-corporate__logo > a { width: 184px; }
.service-subsidiary-corporate.is-pwan .service-subsidiary-corporate__box__title > i.is-i-network { left: 5px; width: 63px; }
.service-subsidiary-corporate.is-pwan .service-subsidiary-corporate__box__title > i.is-i-store { left: 15px; width: 49px; }
.service-subsidiary-corporate.is-pwan .service-subsidiary-corporate__box__title > i.is-i-web { left: 5px; width: 55px; }
.service-subsidiary-corporate.is-musicalab .service-subsidiary-corporate__logo > a { width: 266px; }
.service-subsidiary-corporate.is-musicalab .service-subsidiary-corporate__box__title > i.is-i-product { left: 14px; width: 46px; }
.service-subsidiary-corporate.is-musicalab .service-subsidiary-corporate__box__title > i.is-i-content { left: 10px; width: 51px; }
.service-subsidiary-corporate.is-musicalab .service-subsidiary-corporate__box__title > i.is-i-ec { left: 8px; width: 56px; }

@media screen and (max-width: 768px) {
  .service-subsidiary > .l-wrap { padding: 0 12px; }
  .service-subsidiary-title { text-align: center; }
  .service-subsidiary-block__title::before { right: -12px; width: calc(100% + 12px); }
  .service-subsidiary-corporate__logo { text-align: center; }
  .service-subsidiary-corporate__box:not(:first-child) { margin-top: 40px; }
}

@media screen and (min-width: 769px) {
  .service-subsidiary { margin-top: 70px; }
  .service-subsidiary::before { margin-bottom: 55px; width: 100%; max-width: 1000px; }
  .service-subsidiary > .l-wrap { max-width: 1040px; }
  .service-subsidiary-title { margin-bottom: 42px; font-size: 4.8rem; line-height: 1.6041666666; }
  .service-subsidiary-block + .service-subsidiary-block { margin-top: 68px; }
  .service-subsidiary-block__title { margin-bottom: 30px; font-size: 2.4rem; line-height: 1.625; }
  .service-subsidiary-block__title > span { padding-right: 44px; }
  .service-subsidiary-corporate__logo { margin-bottom: 66px; }
  .service-subsidiary-corporate__info { display: grid; row-gap: 44px; column-gap: 60px; grid-template-columns: repeat(2,calc(50% - (60px / 2))); }
  .service-subsidiary-corporate__box { margin: 0; }
  .service-subsidiary-corporate__box__title { margin-bottom: 20px; padding-left: 76px; font-size: 2.2rem; line-height: 1.5909090909; }
  .service-subsidiary-corporate__box__text { font-size: 2rem; line-height: 1.6; }

  .service-subsidiary-corporate.is-pwan .service-subsidiary-corporate__logo > a { width: 184px; }
  .service-subsidiary-corporate.is-pwan .service-subsidiary-corporate__box__title > i.is-i-network { left: 0; width: 63px; }
  .service-subsidiary-corporate.is-pwan .service-subsidiary-corporate__box__title > i.is-i-store { left: 0; width: 49px; }
  .service-subsidiary-corporate.is-pwan .service-subsidiary-corporate__box__title > i.is-i-web { left: 0; width: 49px; }
  .service-subsidiary-corporate.is-musicalab .service-subsidiary-corporate__logo > a { width: 266px; }
  .service-subsidiary-corporate.is-musicalab .service-subsidiary-corporate__box__title > i.is-i-product { left: 0; width: 52px; }
  .service-subsidiary-corporate.is-musicalab .service-subsidiary-corporate__box__title > i.is-i-content { left: 0; width: 56px; }
  .service-subsidiary-corporate.is-musicalab .service-subsidiary-corporate__box__title > i.is-i-ec { left: 0; width: 59px; }
}

/* company
------------------------------------------------ */
/* common */
.body-company .l-ft { margin-top: 0; }
.body-company-history .company { background-color: #FAFBFC; }
.company-below { padding: 32px 0; }

@media screen and (max-width: 768px) {
  .company-below > .l-wrap { padding: 0 12px; }
}

@media screen and (min-width: 769px) {
  .company-below { padding: 54px 0; }
}

/* outline */
.company-outline-box { display: grid; grid-template-columns: 108px calc(100% - 108px); margin: 0; }
.company-outline-box__title,
.company-outline-box__text { padding: 18px 0 15px; border-top: 1px solid #D9D9D9; font-size: 1.6rem; line-height: 1.625; }
.company-outline-box__title:first-child,
.company-outline-box__title:first-child + .company-outline-box__text { padding-top: 0; border-top: none; }
.company-outline-box__title { font-family: 'LINESeedJPStdBold', sans-serif; font-weight: 700; }
.company-outline-box__text { margin: 0; }

@media screen and (max-width: 768px) {
  .company-outline { padding-bottom: 10px; }
  .company-outline > .l-wrap { padding: 0 25px; }
}

@media screen and (min-width: 769px) {
  .company-outline { padding-bottom: 30px; }
  .company-outline > .l-wrap { max-width: 1040px; }
  .company-outline-box { grid-template-columns: 140px calc(100% - 140px); }
  .company-outline-box__title,
  .company-outline-box__text { padding: 20px 0 18px; font-size: 1.6rem; line-height: 1.625; }
  .company-outline-box__title { padding-left: 4px; }
}

/* history */
.company-history-content { padding: 28px 15px; background-color: #fff; border-radius: 25px; }
.company-history-years__item { position: relative; }
.company-history-years__item::before { content: ''; position: absolute; top: 0; left: 4px; width: 3px; height: 100%; background-color: #BFC1C5; }
.company-history-years__item:first-child::before { top: 8px; height: calc(100% - 8px); }
.company-history-years__num { position: relative; margin: 0; padding-left: 28px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 3rem; font-weight: 700; line-height: 1.2; color: #54585B; }
.company-history-years__num::before { content: ''; position: absolute; top: 2px; left: -10px; width: 32px; height: 32px; background-color: #DE1E40; border: 8px solid #ffff; border-radius: 50%; }
.company-history-months { padding: 25px 0; }
.company-history-years__item:last-child .company-history-months { padding-bottom: 10px; }
.company-history-months__item:not(:first-child) { margin-top: 25px; }
.company-history-months__num { position: relative; margin: 0; padding-left: 28px; font-size: 2rem; line-height: 1.3; color: #575C63; }
.company-history-months__num::before { content: ''; position: absolute; top: 8px; left: -1px; width: 14px; height: 14px; background-color: #D9D9D9; border: 2px solid #fff; border-radius: 50%; }
.company-history-months__text { margin: 0; padding-left: 38px; font-size: 1.6rem; line-height: 1.6; }

@media screen and (max-width: 768px) {
  .company-history > .l-wrap { padding: 0 12px; }
  .company-history-months__num { font-family: 'LINESeedJPStdBold', sans-serif; font-weight: 700; }
  .company-history-months__text { margin-top: 10px; }
}

@media screen and (min-width: 769px) {
  .company-history > .l-wrap { max-width: 1040px; }
  .company-history-content { padding: 70px 80px; }
  .company-history-years__num { padding-left: 54px; font-size: 4rem; }
  .company-history-months { padding: 36px 0 48px; }
  .company-history-months__item { display: grid; align-items: center; grid-template-columns: 165px calc(100% - 165px); }
  .company-history-months__item:not(:first-child) { margin-top: 40px; }
  .company-history-months__num { padding-left: 70px; font-size: 3.2rem; line-height: 1.3; }
  .company-history-months__text { padding-left: 24px; border-left: 2px solid #D9D9D9; font-size: 1.6rem; line-height: 1.5; }
}

/* vision */
.company-vision { padding-top: 42px; }
.company-vision-copy { margin: 0 0 36px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 5rem; font-weight: 700; line-height: 1.62; }
.company-vision-copy span { display: inline-block; position: relative; -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; text-fill-color: transparent; vertical-align: baseline; font-size: 10rem; line-height: 1.3; }
.company-vision-copy span.is-red { background-image: linear-gradient(46.41deg, #F7012C 18.2%, #FF7300 87.64%); }
.company-vision-copy span.is-blue { background-image: linear-gradient(52.7deg, #007CD6 20.16%, #00AEFF 90.78%); }
.company-vision-lead { margin: 0; font-family: 'LINESeedJPStdExtraBold', sans-serif; font-size: 1.6rem; font-weight: 800; letter-spacing: 0.04em; line-height: 2; }
.company-vision-lead span { color: #DE1E40; }
.company-vision-content { position: relative; margin-top: 36px; padding: 34px 10px; }
.company-vision-content::before,
.company-vision-content::after { content: ''; position: absolute; left: 0; width: 100%; height: 4px; background: url(./_assets/img/share/bg1.svg) no-repeat center center; background-size: 100%; }
.company-vision-content::before { top: 0; }
.company-vision-content::after { bottom: 0; }
.company-vision-text { font-size: 1.6rem; letter-spacing: 0.04em; line-height: 2; }
.company-vision-text p { margin: 0; }
.company-vision-text p + p { margin-top: 2em; }
.company-vision-lists { margin: 20px 0; padding: 16px; background-color: #F6F7F9; border-radius: 20px; }
.company-vision-lists:first-child { margin-top: 0; }
.company-vision-lists:last-child { margin-bottom: 0; }
.company-vision-lists__item { position: relative; padding-left: 25px; font-size: 1.6rem; line-height: 1.75; }
.company-vision-lists__item:not(:first-child) { margin-top: 14px; }
.company-vision-lists__item::before { content: ''; position: absolute; top: 0.5em; left: 0; width: 12px; height: 12px; background-color: #DE1E40; border-radius: 50%; }
.company-vision-link { margin: 20px 0 0; font-size: 1.6rem; letter-spacing: 0.04em; line-height: 2; }
.company-vision-link > a { display: inline-flex; align-items: center; gap: 11px; text-decoration: none; }
.company-vision-link > a::before { content: ''; width: 18px; height: 18px; background: url(./_assets/img/icon/arrow2.svg) no-repeat center center; background-size: 100%; }

@media screen and (max-width: 768px) {
  .company-vision > .l-wrap { padding: 0 15px; }
  .company-vision-copy span { margin-right: 12px; }
}

@media screen and (min-width: 769px) {
  .company-vision { padding-top: 54px; }
  .company-vision > .l-wrap { max-width: 1040px; }
  .company-vision-copy { margin-bottom: 54px; text-align: center; font-size: 9.7rem; line-height: 1.3; }
  .company-vision-copy span { padding: 0 0.1em; font-size: 9.7rem; line-height: 1.3; }
  .company-vision-lead { text-align: center; font-size: 1.8rem; line-height: 1.7777777777; }
  .company-vision-content { margin-top: 43px; padding: 48px 30px 50px; }
  .company-vision-text { font-size: 1.6rem; line-height: 2; }
  .company-vision-lists { margin: 14px 0 26px; padding: 15px 30px; }
  .company-vision-lists__item { padding-left: 32px; font-size: 1.6rem; line-height: 2; }
  .company-vision-link { margin-top: 28px; font-size: 1.6rem; line-height: 2; }
}

@media screen and (min-width: 769px) and (max-width: 1040px) {
  .company-vision-copy,
  .company-vision-copy span { font-size: 9.03846153846vw; }
}

/* executive */
.company-executive-president { padding-bottom: 55px; border-bottom: 1px solid #C3C3C3; }
.company-executive-president__photo { border-radius: 20px; overflow: hidden; }
.company-executive-president__post { margin: 0 0 2px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 2rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.6; color: #DE1E40; }
.company-executive-president__name { margin: 0 0 8px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 3.4rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.6176470588; }
.company-executive-president__text { margin: 0; font-size: 1.4rem; letter-spacing: 0.02em; line-height: 1.7142857142; }
.company-executive-lists__item { padding-top: 24px; }
.company-executive-lists__item:not(:last-child) { padding-bottom: 26px; border-bottom: 1px solid #C3C3C3; }
.company-executive-lists__post { margin: 0; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 2rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.6; color: #DE1E40; }
.company-executive-lists__name { margin: 0; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 2.4rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.625; }
.company-executive-lists__text { margin: 0; font-size: 1.4rem; letter-spacing: 0.02em; line-height: 1.6428571428; }

@media screen and (max-width: 768px) {
  .company-executive > .l-wrap { padding: 0 25px; }
  .company-executive-president__photo { margin-bottom: 10px; }
}

@media screen and (min-width: 769px) {
  .company-executive > .l-wrap { max-width: 840px; }
  .company-executive-president { display: grid; align-items: center; gap: 40px; grid-template-columns: 168px calc(100% - (168px + 40px)); padding-bottom: 55px; }
  .company-executive-president__post { margin-bottom: 2px; font-size: 2rem; line-height: 1.6; }
  .company-executive-president__name { margin-bottom: 8px; font-size: 3.4rem; line-height: 1.6176470588; }
  .company-executive-president__text { font-size: 1.4rem; line-height: 1.7142857142; }
  .company-executive-lists__item { display: grid; align-items: center; column-gap: 48px; grid-template-columns: 162px calc(100% - (162px + 48px)); }
  .company-executive-lists__post { grid-row: 1 / 3; grid-column: 1; text-align: right; font-size: 2rem; line-height: 1.6; }
  .company-executive-lists__name { grid-row: 1; grid-column: 2; margin-bottom: 9px; font-size: 2.4rem; line-height: 1.625; }
  .company-executive-lists__text { grid-row: 2; grid-column: 2; font-size: 1.4rem; line-height: 1.6428571428; }
}

/* message */
.company-message-president { position: relative; background-repeat: no-repeat; background-position: right bottom; background-color: #E4E7EC; background-size: 100%; border-radius: 30px; }
.company-message-president > .l-wrap { height: 100%; }
.company-message-president__copy { margin: 0; padding: 7.0351758793% 0 0 7.9365079365%; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 7.7114427860vw; font-weight: 700; letter-spacing: 0.02em; line-height: 1.6129032258; }
.company-message-president__author { margin: 0; padding: 32.1608040201% 0 0 7.9365079365%; font-size: 3.9800995024vw; letter-spacing: 0.04em; line-height: 2.4375; color: #54585B; }
.company-message-president__photo { position: absolute; bottom: 0; right: 7.9365079365%; width: 46.0317460317%; }
.company-message-text { font-size: 1.6rem; letter-spacing: 0.04em; line-height: 2; }
.company-message-text p { margin: 0; text-indent: 1em; }
.company-message-text p + p { margin-top: 2em; }

@media screen and (max-width: 768px) {
  .company-message-president { aspect-ratio: 1 / 1.0529100529; margin: 0 12px 30px; background-image: url(./_assets/img/company/message_bg.png); }
  .company-message > .l-wrap { padding: 0 25px; }
}

@media screen and (min-width: 769px) {
  .company-message-president { margin: 0 auto 64px; max-width: 1400px; height: 464px; background-image: url(./_assets/img/company/message_bg-desktop.png); }
  .company-message-president > .l-wrap { max-width: 1040px; }
  .company-message-president__copy { padding: 148px 0 0 100px; font-size: 5rem; line-height: 1.4; }
  .company-message-president__author { padding: 11px 0 0 100px; font-size: 1.4rem; line-height: 2.7857142857; }
  .company-message-president__photo { right: 50px; width: 270px; }
  .company-message > .l-wrap { max-width: 840px; }
  .company-message-text { font-size: 1.8rem; line-height: 2.1666666666; }
  .company-message-text p + p { margin-top: 2.1666666666em; }
}

@media screen and (min-width: 769px) and (max-width: 1000px) {
  .company-message-president { height: 46.4vw; }
  .company-message-president__copy { padding: 14.8vw 0 0 10vw; font-size: 5vw; }
  .company-message-president__author { padding: 1.1vw 0 0 10vw; font-size: 1.4vw; }
  .company-message-president__photo { right: 5vw; width: 27vw; }
}

@media screen and (min-width: 769px) and (max-width: 1440px) {
  .company-message-president { margin-right: 20px; margin-left: 20px; }
}

/* recruit
------------------------------------------------ */
.body-recruit .l-ft { margin-top: 0; }
.recruit { padding-bottom: 60px; background-color: rgba(246,247,249,0.5); }
.recruit-archive-frame { padding: 24px 20px 30px; background-color: #fff; border-radius: 34px; }
.recruit-archive-title { position: relative; margin: 0 0 38px; padding-left: 30px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 2.4rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.625; }
.recruit-archive-title::before,
.recruit-archive-title::after { content: ''; position: absolute; left: 0; width: 9px; }
.recruit-archive-title::before { top: 3.8461538461%; height: 30.7692307692%; background-color: #007CD6; border-radius: 5px 5px 0 0; }
.recruit-archive-title::after { top: 34.6153846153%; height: calc(100% - (3.8461538461% + 34.6153846153%)); background-color: #DE1D3F; border-radius: 0 0 5px 5px; }
.recruit-archive-lists { display: grid; gap: 24px; }
.recruit-archive-lists__item { border: 1px solid rgba(123,136,149,0.2); border-radius: 18px; }
.recruit-archive-lists__trigger { display: block; position: relative; padding: 18px 30px; width: 100%; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 1.6rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.6; }
.recruit-archive-lists__trigger::before { content: ''; position: absolute; top: 24px; left: 10px; width: 12px; height: 12px; background-color: #DE1E40; border: 1px solid rgba(123,136,149,0.2); border-radius: 50%; }
.recruit-archive-lists__trigger::after { content: ''; position: absolute; top: 50%; right: 10px; transition: transform 0.4s ease; transform: translateY(-50%); width: 17px; height: 10px; background: url(./_assets/img/icon/select1.svg) no-repeat center center; background-size: 100%; }
.recruit-archive-lists__trigger[aria-expanded=true]::after { transform: translateY(-50%) rotate(180deg); }
.recruit-archive-lists__target { display: none; padding: 8px 20px 30px; }
.recruit-archive-lists__block + .recruit-archive-lists__block { margin-top: 25px; }
.recruit-archive-lists__title { margin: 0 0 10px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 1.6rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.6; }
.recruit-archive-lists__text { padding: 22px 26px; background-color: #F2F4F5; border-radius: 14px; font-size: 1.2rem; line-height: 1.75; }
.recruit-archive-lists__box { margin: 0; border-top: 1px solid #C3C3C3; border-left: 1px solid #C3C3C3; }
.recruit-archive-lists__box__title,
.recruit-archive-lists__box__text { padding: 12px 18px; border-right: 1px solid #C3C3C3; border-bottom: 1px solid #C3C3C3; }
.recruit-archive-lists__box__title { display: flex; justify-content: center; align-items: center; background-color: #F8F8F8; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 1.4rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.625; }
.recruit-archive-lists__box__text { margin: 0; font-size: 1.4rem; line-height: 1.75; }
.recruit-archive-none { padding-bottom: 18px; }
.recruit-archive-none::before { content: ''; display: block; margin: 0 auto 22px; width: 124px; height: 124px; background: url(./_assets/img/icon/bag1.svg) no-repeat center center #F6F7F9; background-size: 58px 58px; border-radius: 50%; }
.recruit-archive-none__title { margin: 0 0 4px; text-align: center; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 1.6rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.6; }
.recruit-archive-none__text { margin: 0; text-align: center; font-size: 1.2rem; letter-spacing: 0.02em; line-height: 1.6428571428; }

@media screen and (max-width: 768px) {
  .recruit-archive > .l-wrap { padding: 0 12px; }
}

@media screen and (min-width: 769px) {
  .recruit { padding-bottom: 100px; }
  .recruit-archive-frame { padding: 32px 48px 48px; }
  .recruit-archive-title { margin-bottom: 38px; padding-left: 30px; font-size: 3.2rem; line-height: 1.625; }
  .recruit-archive-title::before,
  .recruit-archive-title::after { width: 9px; }
  .recruit-archive-title::before { top: 3.8461538461%; height: 30.7692307692%; }
  .recruit-archive-title::after { top: 34.6153846153%; height: calc(100% - (3.8461538461% + 34.6153846153%)); }
  .recruit-archive-lists { gap: 24px; }
  .recruit-archive-lists__trigger { padding: 22px 28px 22px 56px; font-size: 2rem; line-height: 1.6; }
  .recruit-archive-lists__trigger::before { top: 30px; left: 28px; width: 16px; height: 16px; }
  .recruit-archive-lists__trigger::after { top: 50%; right: 25px; width: 17px; height: 10px; }
  .recruit-archive-lists__target { padding: 8px 46px 46px; }
  .recruit-archive-lists__block + .recruit-archive-lists__block { margin-top: 25px; }
  .recruit-archive-lists__title { margin-bottom: 10px; font-size: 2rem; line-height: 1.6; }
  .recruit-archive-lists__text { padding: 22px 26px; font-size: 1.6rem; line-height: 1.75; }
  .recruit-archive-lists__box { display: grid; grid-template-columns: 192px calc(100% - 192px); }
  .recruit-archive-lists__box__title,
  .recruit-archive-lists__box__text { padding: 22px 28px; }
  .recruit-archive-lists__box__title { font-size: 1.6rem; line-height: 1.625; }
  .recruit-archive-lists__box__text { font-size: 1.6rem; line-height: 1.75; }
  .recruit-archive-none { padding-bottom: 18px; }
  .recruit-archive-none::before { margin-bottom: 22px; width: 124px; height: 124px; background-size: 58px 58px; }
  .recruit-archive-none__title { margin-bottom: 4px; font-size: 2rem; line-height: 1.6; }
  .recruit-archive-none__text { font-size: 1.4rem; line-height: 1.6428571428; }
}

/* contact
------------------------------------------------ */
.body-contact .l-ft { margin-top: 0; }
.contact { padding-bottom: 60px; background-color: rgba(246,247,249,0.5); }
.contact-frame { padding: 30px 20px 40px; background-color: #fff; border-radius: 34px; }
.contact-form-lead { margin: 0 0 22px; font-size: 1.4rem; line-height: 1.6428571428; }
.contact-form-text { margin: 0; font-size: 1.4rem; line-height: 1.6428571428; }
.contact-form-label { display: flex; align-items: center; gap: 7px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 1.4rem; font-weight: 700; line-height: 1.6428571428; }
.contact-form-required { padding: 2px 5px; border: 1px solid #DE1E40; border-radius: 13px; font-family: 'LINESeedJPStd', sans-serif; font-size: 1rem; line-height: 1.5; color: #DE1E40; }
.contact-form-parts input[type=text],
.contact-form-parts input[type=tel],
.contact-form-parts input[type=email],
.contact-form-parts textarea,
.contact-form-parts select { width: 100%; padding: 11px 14px 9px; background-color: #fff; border: 1px solid #848994; border-radius: 2px; font-size: 1.4rem; line-height: 1.6428571428; }
.contact-form-parts input.is-reemail { margin-top: 18px; }
.contact-form-parts textarea { height: 193px; }
.contact-form-parts select { background: url(./_assets/img/icon/select1.svg) no-repeat right 16px center; background-size: 12px 7px; }
.contact-form-parts__note { margin: 10px 0 0; font-size: 1rem; line-height: 1.5; color: #54585B; }
.contact-form-agree { margin-top: 34px; text-align: center; }
.contact-form-agree > label { display: inline-flex; align-items: center; vertical-align: top; gap: 12px; font-size: 1.4rem; line-height: 1.6428571428; }
.contact-form-agree a[target=_blank] { display: inline-flex; align-items: center; gap: 6px; margin-right: 6px; }
.contact-form-agree a[target=_blank]::after { content: ''; width: 10px; height: 10px; background: url(./_assets/img/icon/external1.png) no-repeat center center; background-size: 100%; }
.contact-form-btns { display: flex; flex-wrap: wrap; justify-content: center; gap: 20px; margin-top: 34px; }
.contact-form-btns__item > button,
.contact-form-btns__item > a { display: flex; justify-content: center; align-items: center; margin: 0 auto; width: 280px; height: 52px; background: url(./_assets/img/icon/arrow1-white.svg) no-repeat right 20px center #DE1E40; background-size: 9px 14px; border-radius: 26px; text-align: center; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 1.6rem; font-weight: 700; letter-spacing: 0.01em; line-height: 1.625; color: #fff; cursor: pointer; }
.contact-form-btns__item > a { background-color: #666; text-decoration: none; }
.contact-form-error { margin: 10px 0 0; font-size: 1.2rem; line-height: 1.6; color: #DE1E40; }
.contact-form-detail__block { padding: 14px 0; border-bottom: 1px solid #E2E6EA; }
.contact-thanks-title { margin: 0 0 40px; text-align: center; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 2rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.2; }
.contact-thanks-text { margin: 0 0 20px; text-align: center; font-size: 1.4rem; line-height: 1.6; }
.contact-thanks-back { margin: 0; text-align: center; }

@media screen and (max-width: 768px) {
  .contact > .l-wrap { padding: 0 12px; }
  .contact-form-label { margin-bottom: 12px; }
}

@media screen and (min-width: 769px) {
  .contact { padding-bottom: 100px; }
  .contact-frame { padding: 44px 0 55px; }
  .contact-form { margin: 0 auto; max-width: 665px; }
  .contact-form-lead { margin-bottom: 22px; font-size: 1.4rem; line-height: 1.6428571428; }
  .contact-form-text { padding-top: 10px; font-size: 1.4rem; line-height: 1.6428571428; }
  .contact-form-label { gap: 7px; font-size: 1.4rem; line-height: 1.6428571428; }
  .contact-form-required { padding: 2px 5px; font-size: 1rem; line-height: 1.5; }
  .contact-form-parts input[type=text],
  .contact-form-parts input[type=tel],
  .contact-form-parts input[type=email],
  .contact-form-parts textarea,
  .contact-form-parts select { padding: 11px 14px 9px; font-size: 1.4rem; line-height: 1.6428571428; }
  .contact-form-parts input.is-name { width: 47.9166666666%; }
  .contact-form-parts input.is-tel { width: 31.6666666666%; }
  .contact-form-parts input.is-reemail { margin-top: 18px; }
  .contact-form-parts textarea { height: 193px; }
  .contact-form-parts select { background-position: right 16px center; background-size: 12px 7px; }
  .contact-form-parts__note { margin-top: 10px; font-size: 1rem; line-height: 1.5; }
  .contact-form-agree { margin-top: 34px; }
  .contact-form-agree > label { gap: 12px; font-size: 1.4rem; line-height: 1.6428571428; }
  .contact-form-agree a[target=_blank] { gap: 6px; margin-right: 6px; }
  .contact-form-agree a[target=_blank]::after { width: 10px; height: 10px; }
  .contact-form-submit { flex-flow: row; gap: 20px; margin-top: 34px; }
  .contact-form-submit > button,
  .contact-form-submit > a { width: 280px; height: 52px; background-position: right 20px center; background-size: 9px 14px; font-size: 1.6rem; line-height: 1.625; }
  .contact-form-error { margin-top: 10px; font-size: 1.2em; line-height: 1.6; }
  .contact-form-detail__block { display: flex; align-items: flex-start; }
  .contact-form-detail__block .contact-form-label { padding-top: 10px; width: 185px; }
  .contact-form-detail__block .contact-form-parts { width: calc(100% - 185px); }
  .contact-thanks-title { margin-bottom: 40px; font-size: 2rem; line-height: 1.2; }
  .contact-thanks-text { margin-bottom: 20px; font-size: 1.4rem; line-height: 1.6; }
}

/* terms
------------------------------------------------ */
.terms-detail-block:not(:first-child) { margin-top: 46px; }
.terms-detail-block__title { position: relative; margin: 0 0 16px; padding-left: 22px; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 2.4rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.6153846153; }
.terms-detail-block__title::before,
.terms-detail-block__title::after { content: ''; position: absolute; left: -5px; width: 9px; }
.terms-detail-block__title::before { top: 0; height: 34.5238095238%; background-color: #007CD6; border-radius: 5px 5px 0 0; }
.terms-detail-block__title::after { top: 34.5238095238%; height: calc(100% - 34.5238095238%); background-color: #DE1D3F; border-radius: 0 0 5px 5px; }
.terms-detail-block__text { font-size: 1.4rem; letter-spacing: 0.02em; line-height: 2; }
.terms-detail-block__text p { margin: 0; }
.terms-detail-block__text p + p { margin-top: 2em; }

@media screen and (max-width: 768px) {
  .terms-detail > .l-wrap { padding: 0 12px; }
}

@media screen and (min-width: 769px) {
  .terms-detail > .l-wrap { max-width: 830px; }
  .terms-detail-block:not(:first-child) { margin-top: 46px; }
  .terms-detail-block__title { margin-bottom: 16px; padding-left: 22px; font-size: 2.6rem; line-height: 1.6153846153; }
  .terms-detail-block__title::before,
  .terms-detail-block__title::after { left: -5px; width: 9px; }
  .terms-detail-block__title::before { height: 34.5238095238%; }
  .terms-detail-block__title::after { top: 34.5238095238%; height: calc(100% - 34.5238095238%); }
  .terms-detail-block__text { font-size: 1.6rem; line-height: 2; }
  .terms-detail-block__text p + p { margin-top: 2em; }
}

/* guidelines
------------------------------------------------ */
.guidelines-detail-text { font-size: 1.4rem; letter-spacing: 0.02em; line-height: 2; }
.guidelines-detail-text p { margin: 0; }
.guidelines-detail-text p + p { margin-top: 2em; }
.guidelines-detail-date { margin: 45px 0 0; text-align: right; font-size: 1.4rem; letter-spacing: 0.02em; line-height: 2; }

@media screen and (max-width: 768px) {
  .guidelines-detail > .l-wrap { padding: 0 12px; }
}

@media screen and (min-width: 769px) {
  .guidelines-detail > .l-wrap { max-width: 830px; }
  .guidelines-detail-text { font-size: 1.6rem; line-height: 2; }
  .guidelines-detail-text p + p { margin-top: 2em; }
  .guidelines-detail-date { margin-top: 45px; font-size: 1.6rem; line-height: 2; }
}

/* privacy
------------------------------------------------ */
.privacy-detail-content { font-size: 1.4rem; letter-spacing: 0.02em; line-height: 2; }
.privacy-detail-content p { margin: 0; }
.privacy-detail-content ol { margin: 0; padding-left: 1.6em; }
.privacy-detail-date { margin: 45px 0 0; text-align: right; font-size: 1.4rem; letter-spacing: 0.02em; line-height: 2; }

@media screen and (max-width: 768px) {
  .privacy-detail > .l-wrap { padding: 0 12px; }
}

@media screen and (min-width: 769px) {
  .privacy-detail > .l-wrap { max-width: 830px; }
  .privacy-detail-text { font-size: 1.6rem; line-height: 2; }
  .privacy-detail-text p + p { margin-top: 2em; }
  .privacy-detail-date { margin-top: 45px; font-size: 1.6rem; line-height: 2; }
}

/* sitemap
------------------------------------------------ */
.body-sitemap .l-ft { margin-top: 0; }
.sitemap { padding-bottom: 60px; background-color: rgba(246,247,249,0.5); }
.sitemap-links-frame { padding: 24px 20px; background-color: #fff; border-radius: 25px; }
.sitemap-links-lists__item:not(:first-child) { margin-top: 14px; }
.sitemap-links-lists__item > a { display: inline-block; position: relative; padding-left: 23px; text-decoration: none; vertical-align: top; font-family: 'LINESeedJPStdBold', sans-serif; font-size: 1.6rem; font-weight: 700; letter-spacing: 0.02em; line-height: 1.625; }
.sitemap-links-lists__item > a::before { content: ''; position: absolute; top: 0.4em; left: 0; width: 12px; height: 12px; background-color: #DE1E40; border-radius: 50%; }
.sitemap-links-child { padding: 10px 0 0 33px; }
.sitemap-links-child__item:not(:first-child) { margin-top: 6px; }
.sitemap-links-child__item > a { display: inline-block; position: relative; padding-left: 22px; text-decoration: none; vertical-align: top; font-size: 1.6rem; letter-spacing: 0.02em; line-height: 1.625; }
.sitemap-links-child__item > a::before { content: ''; position: absolute; top: 0.4em; left: 0; width: 10px; height: 10px; background-color: #98A2AB; border-radius: 50%; }
.sitemap-links-gchild { position: relative; padding: 10px 0 0 4px; }
.sitemap-links-child__item:not(:last-child) .sitemap-links-gchild { margin-bottom: 20px; }
.sitemap-links-gchild::before { content: ''; position: absolute; top: -7px; left: 4px; width: 2px; height: calc(100% - 6px); background-color: #D9D9D9; }
.sitemap-links-gchild__item { position: relative; padding-left: 40px; }
.sitemap-links-gchild__item:not(:first-child) { margin-top: 3px; }
.sitemap-links-gchild__item::before { content: ''; position: absolute; top: 1.1em; left: 0; width: 25px; height: 2px; background-color: #D9D9D9; }
.sitemap-links-gchild__item > a { display: inline-block; text-decoration: none; vertical-align: top; font-size: 1.6rem; letter-spacing: 0.02em; line-height: 1.625; }

.u-device-click .sitemap-links-lists__item > a:hover { text-decoration: underline; color: #DE1E40; }

@media screen and (max-width: 768px) {
  .sitemap-links > .l-wrap { padding: 0 16px; }
}

@media screen and (min-width: 769px) {
  .sitemap { padding-bottom: 100px; }
  .sitemap-links > .l-wrap { max-width: 1040px; }
  .sitemap-links-frame { padding: 28px 42px; }
  .sitemap-links-lists__item:not(:first-child) { margin-top: 14px; }
  .sitemap-links-lists__item > a { padding-left: 23px; font-size: 1.6rem; line-height: 1.625; }
  .sitemap-links-lists__item > a::before { top: 0.4em; width: 12px; height: 12px; }
  .sitemap-links-child { padding: 10px 0 0 33px; }
  .sitemap-links-child__item:not(:first-child) { margin-top: 6px; }
  .sitemap-links-child__item > a { padding-left: 22px; font-size: 1.6rem; line-height: 1.625; }
  .sitemap-links-child__item > a::before { top: 0.4em; width: 10px; height: 10px; }
  .sitemap-links-gchild { padding: 10px 0 0 4px; }
  .sitemap-links-child__item:not(:last-child) .sitemap-links-gchild { margin-bottom: 20px; }
  .sitemap-links-gchild::before { top: -7px; left: 4px; width: 2px; height: calc(100% - 6px); }
  .sitemap-links-gchild__item { padding-left: 40px; }
  .sitemap-links-gchild__item:not(:first-child) { margin-top: 3px; }
  .sitemap-links-gchild__item::before { top: 1.1em; width: 25px; height: 2px; }
  .sitemap-links-gchild__item > a { font-size: 1.6rem; line-height: 1.625; }
}

/* footer
------------------------------------------------ */
.l-ft { position: relative; margin-top: 60px; background-color: #FBFBFB; border-bottom: 14px solid #E1E5E5; }
.l-ft-above { padding: 42px 0 68px; }
.l-ft-links__box { margin: 0; }
.l-ft-links__box__title { margin-bottom: 21px; padding-bottom: 9px; border-bottom: 1px solid rgba(195,195,195,0.8); font-family: 'LINESeedJPStdBold', sans-serif; font-size: 1.4rem; font-weight: 700; letter-spacing: 0.04em; line-height: 1.5; }
.l-ft-links__box__title > a { display: inline-block; text-decoration: none; vertical-align: top; }
.l-ft-links__box__content { margin: 0; }
.l-ft-links__lists__item { font-size: 1.4rem; letter-spacing: 0.02em; line-height: 1.6428571428; }
.l-ft-links__lists__item:not(:first-child) { margin-top: 14px; }
.l-ft-links__lists__item > a { display: inline-block; text-decoration: none; vertical-align: top; }
.l-ft-below { padding: 23px 0 25px; border-top: 1px solid rgba(195,195,195,0.8); }
.l-ft-others__item { font-size: 1.2rem; letter-spacing: 0.03em; line-height: 2.5; }
.l-ft-others__item > a { display: inline-block; text-decoration: none; vertical-align: top; }
.l-ft-copyright { margin: 0; font-size: 1rem; letter-spacing: 0.04em; line-height: 3.9; }
.l-ft-copyright > small { font-family: inherit; }

@media screen and (max-width: 768px) {
  .l-ft-links { display: grid; row-gap: 39px; column-gap: 25px; grid-template-columns: repeat(2,calc(50% - (25px / 2))); padding: 0 17px; }
  .l-ft-others,
  .l-ft-copyright { padding: 0 27px; }
  .l-ft-copyright { margin-top: 6px; }
}

@media screen and (min-width: 769px) {
  .l-ft { margin-top: 100px; border-bottom-width: 12px; }
  .l-ft-above { padding: 78px 0 56px; }
  .l-ft-links { display: flex; gap: 30px; }
  .l-ft-links__box { min-width: 130px; }
  .l-ft-links__box__title { margin-bottom: 21px; padding-bottom: 9px; font-size: 1.4rem; }
  .l-ft-links__box__content { padding-right: 18px; }
  .l-ft-links__lists__item { font-size: 1.4rem; }
  .l-ft-links__lists__item:not(:first-child) { margin-top: 14px; }
  .l-ft-below { display: flex; flex-flow: row-reverse; justify-content: space-between; align-items: center; gap: 30px; padding: 7px 0 10px; }
  .l-ft-others { display: flex; flex-wrap: wrap; justify-content: flex-end; }
  .l-ft-others__item { font-size: 1.2rem; line-height: 3.25; }
  .l-ft-others__item:not(:first-child)::before { content: '|'; padding: 0 0.8em; }
  .l-ft-copyright { font-size: 1.2rem; line-height: 3.25; }
}