body.no-scroll {
    overflow: hidden;
    cursor: none;
    pointer-events: none;
}

.kyobunkwan_body .header-item-nav-right-fixed {
    z-index: 20;
}
.kyobunkwan_body .footer-bottom-area .footer-group-bottom {
    z-index: 21;
}
.kyobunkwan_body .footer-photo-wrap {
    z-index: 20;
}
.kyobunkwan_body .footer {
    z-index: 20;
}
.kyobunkwan_body .footer .footer-group-top {
    z-index: 21;
}

.kyobunkwan_body .content-wrapper {
    padding-bottom: 0 !important;
}

.top_content p,
.top_content a,
.top_content span,
.top_content h1,
.top_content h2,
.top_content h3,
.top_content h4,
.top_content h5 {
    letter-spacing: 0.05em;
    color: var(--color-text-entry);
}

.top_content p,
.top_content a,
.top_content span {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.875;
    letter-spacing: 0.05em;
    font-family: var(--font-notosan);
}

.top_content h2 {
    font-family: var(--font-shippori);
    font-size: 30px;
    font-weight: 700;
}

#adminBox {
    margin-top: 0 !important;
    margin-bottom: 170px;
}

.acms-form-group {
    position: absolute;
    top: 140px;
    z-index: 10;
    width: 100%;
    max-width: 1440px;
}

.admin_header .first_view_nav {
    top: 300px !important;
}

.fade_in {
    opacity: 0;
    transition: opacity 1.5s,
        transform 1.5s;
}

.fade_in.visible {
    opacity: 1;
}

.top_content.kyobunkwan {
    padding-top: 107px;
}

/* フェードインアニメーション */
.fade_in_animation {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 1s ease-in-out, transform 1s ease-in-out;
}

.fade_in_animation.show {
    opacity: 0;
    opacity: 1;
    transform: translateY(0);
}

.fade_in_animation_slow {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 1s ease-in-out, transform 1s ease-in-out;
}

.fade_in_animation_slow.show {
    opacity: 0;
    opacity: 1;
    transform: translateY(0);
}

/* フェードインアニメーション */

/* ヘッダー */
.kyobunkwan_body .nav-default {
    padding-bottom: 0;
}

.kyobunkwan_body .nav-default header.header {
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}

.kyobunkwan_body .nav-default header.header.is-visible {
    opacity: 1;
    pointer-events: auto;
}

#first_view_header {
    position: relative;
    max-width: 1440px;
    width: 100%;
    box-sizing: border-box;
    margin: 0 auto;
}

#first_view_header .first_view_nav {
    position: absolute;
    top: 30px;
    left: 40px;
    width: max-content;
}

#first_view_header .first_view_nav_list {
    display: grid;
    grid-template-columns: 1fr;
    flex-direction: column;
    row-gap: 8px;
    width: max-content;
}

#first_view_header .first_view_nav_list .first_view_nav_item {
    position: relative;
    padding-top: 4px;
    padding-bottom: 4px;
}

#first_view_header .first_view_nav_list .first_view_nav_link {
    font-family: var(--font-shippori);
    font-size: 18px;
    font-weight: 700;
    color: #202020;
}

#first_view_header .first_view_nav_list .first_view_nav_item .first_view_nav_list .first_view_nav_link {
    font-family: var(--font-notosan);
    font-size: 16px;
    font-weight: 500;
    color: #4C483A;
}

#first_view_header .first_view_nav_item:has(ul)::before {
    content: "";
    display: block;
    position: absolute;
    top: 17px;
    left: 125px;
    transform: translateY(-50%) rotate(135deg);
    width: 0.5rem;
    height: 0.5rem;
    border-top: 1px solid #202020;
    border-right: 1px solid #202020;
    transition: all 0.35s ease;
}
#first_view_header .first_view_nav_item.about-child:has(ul)::before {
    top: 1.1rem;
    left: 8.5rem;
}
#first_view_header .first_view_nav_item:has(ul) a {
    pointer-events: none;
}
#first_view_header .first_view_nav_item.about-child:has(ul) a {
    pointer-events: auto;
}

#first_view_header .first_view_nav_list .first_view_nav_item:hover {
    padding-right: 100px;
}

#first_view_header .first_view_nav_list.is-tablet .first_view_nav_item:hover {
    padding-right: 0;
}

#first_view_header .first_view_nav_list.is-tablet .first_view_nav_item.is-open {
    padding-right: 100px;
}

#first_view_header .first_view_nav_list .first_view_nav_item:hover::before {
    transform: translateY(-50%) rotate(315deg);
    top: 23px;
}

#first_view_header .first_view_nav_list.is-tablet .first_view_nav_item:hover::before {
    transform: translateY(-50%) rotate(135deg);
    top: 17px;
}

#first_view_header .first_view_nav_list.is-tablet .first_view_nav_item.is-open::before {
    transform: translateY(-50%) rotate(315deg);
    top: 23px;
}


#first_view_header .first_view_nav_item .first_view_nav_list {
    display: grid;
    opacity: 0;
    max-height: 0;
    height: auto;
    pointer-events: none;
    transition: max-height 0.35s ease, opacity 0.3s ease, margin 0.35s ease, padding 0.35s ease;
    flex-direction: column;
    row-gap: 2px;
    width: 232px;
    box-sizing: border-box;
    overflow: hidden;
    z-index: 5;
    padding-left: 32px;
    border-radius: var(--border-radius-lg);
    box-shadow: var(--box-shadow);
    background-color: var(--color-background-base);
}

#first_view_header .first_view_nav_item:hover .first_view_nav_list {
    max-height: 260px;
    opacity: 1;
    padding: 20px 0 20px 32px;
    pointer-events: auto;
    transition: max-height 0.35s ease, opacity 0.3s ease, margin 0.35s ease, padding 0.35s ease;
    margin-top: 16px;
}
#first_view_header .first_view_nav_item.about-child:hover .first_view_nav_list {
    width: 18.5rem;
}
#first_view_header .first_view_nav_list.is-tablet .first_view_nav_item:hover .first_view_nav_list {
    max-height: 0;
    opacity: 0;
    padding: 0 0 0 32px;
    pointer-events: none;
    margin-top: 0;
}

#first_view_header .first_view_nav_list.is-tablet .first_view_nav_item.is-open .first_view_nav_list {
    max-height: 260px;
    opacity: 1;
    padding: 20px 0 20px 32px;
    pointer-events: auto;
    margin-top: 16px;
}

#first_view_header .first_view_nav_item .first_view_nav_list .first_view_nav_item {
    width: 100%;
}

#first_view_header .first_view_nav_item .first_view_nav_list .first_view_nav_item .first_view_nav_link {
    position: relative;
    width: 100%;
    height: auto;
    padding: 1rem 1.5rem;
    margin: 0;
    color: var(--color-text-2nd);
    font-family: var(--font-base);
    font-weight: 500;
    padding: 0;
    pointer-events: auto;
}

/* ヘッダー */

/* タイトル */
.section_title {
    font-size: 30px;
    font-weight: 700;
    font-family: var(--font-shippori);
}

.section_title.white {
    color: #fff;
    text-shadow: 0px 0px 15px rgba(255, 255, 255, 0.5);
}

.section_title.black {
    color: var(--color-text-entry);
    text-shadow: 0px 0px 15px rgba(61, 56, 38, 0.45);
}

.top_container {
    position: relative;
}

p.section_title_copy {
    position: absolute;
    top: -20px;
    left: -24px;
    font-size: 160px;
    letter-spacing: 0;
    font-weight: 700;
    font-style: italic;
    font-family: var(--font-cormorant);
    color: rgba(255, 255, 255, 0.25);
    max-width: 100%;
    line-height: 0.0875;
}

.section_sub_title {
    font-size: 30px;
    font-weight: 600;
    font-family: var(--font-shippori);
}

/* タイトル */
/* リンクスタイル */
.top_text_link {
    margin-top: 40px;
    text-align: center;
}

.top_text_link a {
    font-size: 14px;
    position: relative;
    font-weight: 700;
    font-family: var(--font-shippori);
}

.top_text_link a::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    display: block;
    width: 238px;
    height: 58px;
    background-image: url("../images/top/top_module_rhombus_outside.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.top_text_link a::before {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    display: block;
    width: 222px;
    height: 54px;
    background-image: url("../images/top/top_module_rhombus_inside.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

/* リンクスタイル */
/* container */
.top_container {
    padding: 0 80px;
    max-width: 1440px;
    box-sizing: border-box;
    margin: 0 auto;
    width: 100%;
}

.top_container_left {
    padding: 0 0 0 80px;
    max-width: 1440px;
    box-sizing: border-box;
    margin: 0 auto;
    width: 100%;
}

/* container */

/* メインビジュアル */
.top_main_visual {
    padding: 0 48px;
    max-width: 1440px;
    box-sizing: border-box;
    margin: 0 auto;
    width: 100%;
    height: 700px;
}

.top_main_visual_decoration {
    position: relative;
    z-index: 0;
}

.top_main_visual_decoration::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #DFD9C6;
    z-index: 0;
    clip-path: polygon(237px 0,
            /* 左上切り取り後の開始点 */
            237px 35px,
            /* 左上の縦 */
            0 35px,
            /* 左上の横 */
            0 100%,
            /* 左下 */
            100% 100%,
            /* 右下 */
            100% 35px,
            /* 右下から右上切り取りへ */
            calc(100% - 237px) 35px,
            /* 右上の横 */
            calc(100% - 237px) 0,
            /* 右上の縦 */
            237px 0
            /* 左上に戻る */
        );
}

.top_main_visual_decoration .site_logo {
    position: absolute;
    /* top: -78px; */
    top: -4.4rem;
    left: 50%;
    transform: translateX(-50%);
    width: 246px;
    z-index: 3;
}

.top_main_visual_decoration .top_main_visual_catchphrase {
    position: absolute;
    z-index: 3;
    bottom: -10px;
    right: 28px;
    letter-spacing: 0.23em;
    line-height: 1.35;
    writing-mode: vertical-rl;
    font-size: 40px;
    font-weight: 700;
    font-family: var(--font-shippori);
}

.top_main_visual_decoration .top_main_visual_decoration_left {
    position: absolute;
    top: -60px;
    left: 0;
    width: 482px;
    z-index: 1;
}

.top_main_visual_decoration .top_main_visual_decoration_right {
    position: absolute;
    top: -60px;
    right: 0;
    width: 482px;
    z-index: 1;
}

.top_main_visual_decoration .top_main_visual_image {
    width: 100%;
    padding: 0 52px;
    box-sizing: border-box;
    z-index: 2;
    position: relative;
}

.top_main_visual_decoration .top_main_visual_image img {
    width: 100%;
}

.top_main_visual img {
    width: 100%;
}

/* メインビジュアル */

/* キャッチコピー */
.top_kyobunkwan_about {
    margin-top: 96px;
}

.top_kyobunkwan_about_block h3 {
    font-size: 14px;
    font-family: var(--font-shippori);
    font-weight: 700;
}

.top_kyobunkwan_about_block p {
    font-size: 16px;
    font-weight: 600;
    box-sizing: border-box;
    font-family: var(--font-shippori);
    max-width: 562px;
}

.top_kyobunkwan_about_block img {
    max-width: 100%;
    width: 100%;
    box-sizing: border-box;
}

.top_kyobunkwan_about>div:nth-child(1) {
    display: flex;
    position: relative;
    gap: 140px;
    justify-content: center;
    align-items: end;
}

.top_kyobunkwan_about>div:nth-child(1) p.about_us_text {
    position: absolute;
    top: 120px;
    left: -100px;
    font-size: 160px;
    letter-spacing: 0;
    font-weight: 700;
    font-style: italic;
    font-family: var(--font-cormorant);
    color: rgba(255, 255, 255, 0.25);
    max-width: 100%;
}

.top_kyobunkwan_about>div:nth-child(1) .top_kyobunkwan_about_content {
    max-width: 357px;
    width: 100%;
}

.top_kyobunkwan_about>div:nth-child(1) .top_kyobunkwan_about_content p {
    margin-bottom: 72px;
}

.top_kyobunkwan_about>div:nth-child(1) .top_kyobunkwan_about_image {
    flex: 0 0 320px;
}

.top_kyobunkwan_about>div:nth-child(2) {
    display: flex;
    position: relative;
    gap: 80px;
    justify-content: center;
    align-items: center;
    margin-top: 152px;
}

.top_kyobunkwan_about>div:nth-child(2) .top_kyobunkwan_about_image {
    flex: 0 0 480px;
}

.top_kyobunkwan_about>div:nth-child(2) .top_kyobunkwan_about_content p {
    margin-left: 40px;
    margin-bottom: 40px;
}

.top_kyobunkwan_about>div:nth-child(2) .top_kyobunkwan_about_content h4 {
    margin-left: 40px;
}

.top_kyobunkwan_about>div:nth-child(2) .top_kyobunkwan_about_content a {
    font-weight: 700;
    font-family: var(--font-shippori);
    font-size: 14px;
    padding-left: 0px;
    position: relative;
}

.top_kyobunkwan_about>div:nth-child(2) .top_kyobunkwan_about_content a::before {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    display: block;
    width: 210px;
    height: 60px;
    background-image: url("../images/top/rhombus_outside.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.top_kyobunkwan_about>div:nth-child(2) .top_kyobunkwan_about_content a::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    display: block;
    width: 194px;
    height: 56px;
    background-image: url("../images/top/rhombus_inside.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

/* キャッチコピー */


/* ===== 画像スライダー ===== */
.top_image_slider {
    box-sizing: border-box;
    margin: 0 auto;
    width: 100%;
    position: relative;
    max-width: 100%;
}

.top_image_slider_content {
    width: 100%;
    max-width: 100%;
    aspect-ratio: 15 / 7;
    overflow: hidden;
    position: relative;
    z-index: 21;
}

.top_image_slider_content h2 {
    position: absolute;
    top: 49.5%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 30px;
    font-weight: 700;
    font-family: var(--font-shippori);
    writing-mode: vertical-rl;
    line-height: 1.4;
    color: #fff;
    z-index: 10;
    text-shadow: 0px 0px 15px rgba(255, 255, 255, 0.5);
    pointer-events: none;
    margin: 0;
    height: max-content;
    letter-spacing: 0.23em;
}

.top_image_slider .scroll-image {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    will-change: clip-path;
}


/* 売り場のご案内 */
.top_store_guide {
    box-sizing: border-box;
    padding: 176px 80px 0;
    max-width: 100%;
    width: 100%;
    background-image: url('../images/background/top_backgraound_green.png');
    background-repeat: repeat;
    position: relative;
}

.top_store_guide p.section_title_copy {
    top: 160px;
    left: auto;
    right: 80px;
    font-size: 160px;
    letter-spacing: 0;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.05);
    line-height: 0.0875;
    margin-top: 0;
    height: 100px;
}

.top_store_guide .top_store_guide_title p {
    box-sizing: border-box;
    max-width: 840px;
    width: 100%;
    margin-top: 24px;
}

.top_store_guide h3 a {
    color: #fff;
    font-size: 30px;
    font-weight: 700;
    line-height: 1.46;
    font-family: var(--font-shippori);
}

.top_store_guide p {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.875;
    color: #fff;
    margin-top: 40px;
    letter-spacing: 0.05em;
}

.top_store_guide_link {
    margin-top: 24px;
    margin-left: 20px;
}

.top_store_guide a {
    font-size: 14px;
    font-weight: 400;
    color: #fff;
    position: relative;
    display: inline-block;
}

.top_store_guide a svg:nth-child(1) {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    display: block;
    width: 182px;
    height: 58px;
}

.top_store_guide a svg:nth-child(2) {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    display: block;
    width: 166px;
    height: 53px;
}

.top_store_guide span {
    font-size: 14px;
    font-weight: 400;
    color: #fff;
    display: inline-block;
    position: relative;
    padding-left: 28px;
}

.top_store_guide span::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    display: block;
    width: 20px;
    height: 20px;
    background-color: #fff;
    mask-image: url("../images/top/xbook_floor_icon.svg");
    -webkit-mask-image: url("../images/top/xbook_floor_icon.svg");
    mask-repeat: no-repeat;
    -webkit-mask-repeat: no-repeat;
    mask-size: 20px 20px;
    -webkit-mask-size: 20px 20px;
    mask-position: center;
}

.top_store_guide_block {
    margin-top: 96px;
}

.top_store_guide_content {
    display: grid;
    column-gap: 64px;
}

.top_store_guide_content:not(:first-child) {
    margin-top: 96px;
}

.top_store_guide_content_texts {
    box-sizing: border-box;
    margin-top: min(4.45vw, 64px);
}

.top_store_guide_content_image {
    box-sizing: border-box;
    width: 100%;
}

.top_store_guide_content_image img {
    width: 100%;
    display: block;
}

.top_store_guide_content_grid_texts img {
    filter: blur(2px);
}

.top_store_guide_content:nth-child(even) {
    grid-template-columns: minmax(500px, 630px) minmax(300px, 480px);
    justify-content: left;
}

.top_store_guide_content:nth-child(odd) {
    grid-template-columns: minmax(300px, 480px) minmax(500px, 630px);
    justify-content: right;
}

.top_store_guide_content:nth-child(even) .top_store_guide_content_texts {
    order: 2;
}

.top_store_guide_content:nth-child(even) .top_store_guide_content_texts .top_store_guide_name {
    text-align: right;
}

.top_store_guide_content_fbook {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

/* 売り場のご案内 */

/* 出版部と洋書部 */
.top_entry_link {
    margin: -1px auto 0;
    box-sizing: border-box;
    padding: 0 80px 104px;
    max-width: 100%;
    width: 100%;
    background-image: url('../images/background/top_backgraound_green.png');
    background-repeat: repeat;
    z-index: -2;
}

.top_store_guide_content_grid {
    display: inline-block;
    box-sizing: border-box;
    max-width: calc(50% - 10px);
    width: 100%;
    position: relative;
    margin-top: 96px;
    aspect-ratio: 3/2;
    height: 100%;
    vertical-align: top;
}

.top_store_guide_content_grid svg {
    display: none;
}

.top_store_guide_content_grid:nth-child(1) {
    margin-right: 16px;
}

a.top_store_guide_content_grid_texts {
    display: flex;
    align-items: center;
    margin: 0;
    box-sizing: border-box;
    padding: 0 min(5.3vw, 75px);
    height: 100%;
}

.top_store_guide_content_grid_texts .top_store_guide_name {
    position: relative;
    z-index: 2;
    height: 100%;
    width: 100%;
}

.top_store_guide_content_grid_texts .top_store_guide_name h3 {
    text-align: center;
    font-size: 24px;
    font-weight: 600;
    color: #fff;
    width: 100%;
    position: absolute;
    top: min(8.473vw, 122px);
    left: 0;
}

.top_store_guide_content_grid_texts .top_store_guide_name p {
    color: #fff;
    width: 100%;
    position: absolute;
    top: min(15vw, 215px);
    left: 0;
}

.top_store_guide_content_grid_texts .top_store_guide_content_image {
    max-width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: auto;
    z-index: 1;
}
/* 出版部と洋書部 */

/* 教文館からのお知らせ */
.top_container.news {
    margin-top: 170px;
}

.news .entry_block {
    display: flex;
    gap: 80px;
    justify-content: space-between;
}

.news .top_text_link {
    text-align: right;
    margin-right: 56px;
}

.news .entry_block .section_title {
    flex: 0 0 auto;
}

.news .entry_link_block {
    max-width: 840px;
    flex: 0 1 100%;
    min-width: 0;
}

.news .entry_link {
    padding: 1.5rem 0;
    border-top: 1px solid var(--color-border-line);
    transition: all 0.3s;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
}

.news .entry_link:last-child {
    border-bottom: 1px solid var(--color-border-line);
}

.news .entry_link:hover {
    opacity: 1;
    background-color: unset;
}

.news .entry_link .entry_blog_name {
    flex-basis: 100%;
    font-size: 14px;
    color: var(--color-light-brown);
    font-weight: 500;
}

.news .entry-header-time {
    font-family: var(--font-notosan);
    font-size: 1rem;
    font-weight: 500;
    flex: 0 0 104px;
}

.news .entry_link .entry_list_title {
    font-family: var(--font-notosan);
    font-size: 1rem;
    font-weight: 500;
    margin: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
    flex: 1 1 0;
}

.news .entry_link::after {
    content: "";
    background: url("../../kyobunkwan@site/images/news/link-arrow.svg") no-repeat center center;
    background-size: cover;
    background-position: top center;
    display: inline-block;
    position: relative;
    top: 0;
    left: 0;
    right: 0;
    width: 1.5rem;
    height: .5rem;
    z-index: 1;
}

/* 教文館からのお知らせ */

/* 催事情報 */
.top_container.event_news {
    margin-top: 152px;
}

.event_news .entry_blog_name {
    flex-basis: 100%;
    font-size: 14px;
    color: var(--color-light-brown);
    font-weight: 500;
    margin-bottom: 4px;
}

.top_event_news_entry_block {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 296px));
    gap: 32px;
    margin-top: 56px;
}

.top_event_news_entry_link {
    display: block;
    transition: all 0.3s;
}

.top_event_news_entry_link .entry_image {
    width: 100%;
    box-sizing: border-box;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background-color: #eee;
}

.top_event_news_entry_link .entry_image img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.top_event_news_entry_link:hover {
    opacity: 0.75;
}

.top_event_news_entry_link .entry_list_title {
    white-space: normal;
    text-overflow: ellipsis;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    display: -webkit-box;
    box-orient: vertical;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-size: 16px;
    font-weight: 500;
    font-family: var(--font-notosan);
    line-height: 1.625;

}

.top_event_news_entry_link .category-tag-list {
    width: 100%;
    row-gap: 8px;
    display: flex !important;
    flex-wrap: wrap;
    align-items: center;
    column-gap: 8px;
}
.top_event_news_entry_link .category-tag-list > div {
    line-height: 1;
}

.top_event_news_entry_link .date-title {
    margin-top: 6px;
}

.top_event_news_entry_link .entry_list_title {
    margin-top: 8px;
}

.top_event_news_entry_link .category-tag-list .tag-label {
    display: inline-block;
    font-size: 12px;
    margin-bottom: 0;
    font-family: var(--font-notosan);
    border-radius: 20px;
    width: 100%;
    max-width: 4rem;
    text-align: center;
    padding: 0;
    font-weight: 500;
    height: 22px;
    line-height: 22px;
}

.top_event_news_entry_link .category-tag-list .category_label {
    margin-right: 4px;
    display: inline-block;
    font-size: 12px;
    background-color: var(--color-beige-accent);
    line-height: 24px;
    padding: 0 8px;
}

.top_event_news_entry_link .category-tag-list .tag-label.tag-yokoku {
    color: var(--color-green-base);
    background: color-mix(in srgb, var(--color-white), transparent 50%);
    border: 1px solid var(--color-green-base);
}

.top_event_news_entry_link .category-tag-list .tag-label.tag-kaisai {
    color: var(--color-white);
    background: var(--color-green-base);
    border: 1px solid var(--color-green-base);
}

.top_event_news_entry_link .category-tag-list .tag-label.tag-shuryo {
    color: var(--color-text-entry);
    background: var(--color-background-beige);
}

.top_event_news_entry_link .category-tag-list .tag-label.tag-moushikomi,
.top_event_news_entry_link .category-tag-list .tag-label.tag-uketsuke-shuryo {
    color: var(--color-text-entry);
    border: 1px solid var(--color-text-entry);
}

.top_event_news_entry_info {
    margin-top: 8px;
}

/* 催事情報 */

/* おすすめ商品 */
#bg_noise_d8d4c5 {
    background-image: url('../images/background/background_d8d4c5.png');
    background-repeat: repeat;
    padding-bottom: 104px;
    position: relative;
    z-index: 1;
}

#bg_noise_d8d4c5 .column-media {
    margin-bottom: 0;
    padding-bottom: 144px;
}

#bg_noise_d8d4c5 .column-module {
    margin-bottom: 0;
}

.recommended_product {
    margin-top: 136px;
    max-width: 100%;
}

.recommended_product .entry_block {
    padding: 136px 80px 0;
    box-sizing: border-box;
    max-width: 1440px;
    margin: 0 auto;
}

.recommended_product .entry_link_grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(auto, 296px));
    gap: 40px 32px;
    margin-top: 56px;
}

.recommended_product .entry_link_grid .entry_link {
    display: block;
    width: 100%;
    min-width: 0;
}

.recommended_product .entry_link_grid .entry_info {
    margin-top: 4px;
}

.recommended_product .entry_image.auto_padding_img {
    position: relative;
    width: 100%;
    background-color: rgba(255, 255, 255, 0.4);
    --auto-padding-inset: 32px;
}

.recommended_product .entry_image.auto_padding_img::before {
    content: '';
    display: block;
    padding-top: 100%;
}

.recommended_product .entry_image.auto_padding_img img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: block;
    width: auto;
    height: auto;
}

.recommended_product .auto_padding_img.horizontal img {
    width: calc(100% - 2 * var(--auto-padding-inset));
    height: auto;
}

.recommended_product .auto_padding_img.vertical img {
    height: calc(100% - 2 * var(--auto-padding-inset));
    width: auto;
}

.recommended_product .auto_padding_img.square img {
    width: calc(100% - 2 * var(--auto-padding-inset));
    height: calc(100% - 2 * var(--auto-padding-inset));
    object-fit: contain;
}

.global_book_entry_list_container .entry_list_block .entry_link .entry_block .entry_image {
    width: 152px;
    height: 152px;
}

.recommended_product .entry_link_grid .entry_info .entry_list_title {
    font-size: 16px;
    font-weight: 500;
    margin-bottom: 0px;
    color: var(--color-text-entry);
    font-family: var(--font-notosan);
    letter-spacing: 0.05em;
    line-height: 1.625em;
}

.recommended_product .entry_link_grid .entry_info #book_price_tax {
    font-size: 18px;
    font-weight: 500;
    margin-bottom: 0px;
    color: var(--color-text-entry);
    line-height: 1.2em;
    margin-top: 4px;
}

.recommended_product .entry_link_grid .entry_info #book_bace_price {
    font-size: 14px;
    font-weight: 400;
}

.recommended_product .entry_link_grid .entry_info .tag_label {
    font-size: 12px;
    font-weight: 400;
    color: var(--color-text-entry);
}

/* おすすめ商品 */

/* 採用情報 */
.top_recruit {
    aspect-ratio: 3/1;
    overflow: hidden;
    position: relative;
}

.top_recruit_content {
    position: relative;
    z-index: 2;
    margin-top: min(8.4vw, 120px);
    margin-left: min(11.2vw, 160px);
}

.top_recruit_content h2 {
    line-height: 1;
    color: #fff !important;
}

.top_recruit_content p {
    margin-top: 48px;
    margin-bottom: 56px;
    color: #fff !important;
}

.top_recruit_content a {
    font-size: 16px;
    font-weight: 500;
    font-family: var(--font-shippori);
    display: inline-block;
    padding-left: 76px;
    position: relative;
    line-height: 1.625;
    color: #fff !important;
}

.top_recruit_content a::before {
    content: "";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 0;
    height: 1px;
    width: 60px;
    background-color: #fff;
    transform-origin: right center;
    transition: transform 0.5s ease, opacity 0.5s ease;
}

.top_recruit_content a:hover::before {
    transform: translateY(-50%) scaleX(0);
    opacity: 0;
}

.top_recruit_image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
}

.top_recruit_image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.top_recruit img {
    box-sizing: border-box;
    max-width: 100%;
    width: 100%;
    object-fit: cover;
}

/* 採用情報 */

/* バナー */
.top_banner {
    margin-top: 104px;
}

.top_banner a {
    display: block;
    width: 100%;
}

.top_banner a img {
    display: block;
    width: 100%;
}

/* バナー */


@media (max-width: 1280px) {
    .top_kyobunkwan_about>div:nth-child(1) p.about_us_text {
        top: 100px;
    }

    /* 売り場のご案内 */
    .top_store_guide {
        padding: 176px 40px 0;
    }

    p.section_title_copy {
        font-size: 120px;
        top: -8px;
    }

    .top_store_guide_content_grid_texts .top_store_guide_name h3 {
        top: 6.473vw;
    }

    .top_store_guide_content_grid_texts .top_store_guide_name p {
        top: 12vw;
    }

    /* 売り場のご案内 */
    .top_store_guide p.section_title_copy {
        font-size: 120px;
    }
}


@media (max-width: 1099px) {

    /* container */
    .top_container {
        padding: 0 40px;
    }

    .top_container_left {
        padding: 0 0 0 40px;
    }

    /* container */

    .top_image_slider_content h2 {
        font-size: 28px;
        top: 58%;
    }

    /* キャッチコピー */
    .top_kyobunkwan_about>div:nth-child(1) {
        display: flex;
        position: relative;
        gap: 40px;
        display: grid;
        grid-template-columns: 357px 320px;
        justify-content: center;
        align-items: end;
    }

    .top_kyobunkwan_about>div:nth-child(1) p.about_us_text {
        top: 0px;
        left: -40px;
        font-size: 120px;
        line-height: 0.75;
    }

    .top_kyobunkwan_about>div:nth-child(1) .top_kyobunkwan_about_content {
        max-width: 357px;
        width: 100%;
    }

    .top_kyobunkwan_about>div:nth-child(1) .top_kyobunkwan_about_content p {
        margin-bottom: 72px;
    }

    .top_kyobunkwan_about>div:nth-child(1) .top_kyobunkwan_about_image {}

    .top_kyobunkwan_about>div:nth-child(2) {
        gap: 40px;
        display: grid;
        grid-template-columns: minmax(300px, 480px) minmax(330px, 562px);
    }

    .top_kyobunkwan_about>div:nth-child(2) .top_kyobunkwan_about_content p {
        margin-left: 0px;
    }

    /* キャッチコピー */

    /* 売り場のご案内 */
    .top_store_guide_content {
        display: grid;
        grid-template-columns: 1fr;
    }

    .top_store_guide_content_texts {
        order: 2;
    }

    .top_store_guide_content:nth-child(odd) {
        grid-template-columns: 1fr;
    }

    .top_store_guide_content:nth-child(even) {
        grid-template-columns: 1fr;
    }

    .top_store_guide p {
        margin-top: 16px;
    }

    .top_store_guide_content_texts {
        margin-top: 24px;
    }

    .top_store_guide_link {
        text-align: center;
        margin-left: 0;
        margin-top: 32px;
    }

    /* 売り場のご案内 */

    /* 出版部と洋書部 */
    .top_entry_link {
        padding: 0 40px 104px;
    }

    a.top_store_guide_content_grid_texts {
        padding: 0 75px;
    }

    .top_store_guide_content_grid {
        display: block;
        max-width: 626px;
        margin-top: 0;
        padding-top: 96px;
        margin: 0 auto;
        box-sizing: content-box;
    }

    .top_store_guide_content_grid:nth-child(1) {
        margin-right: auto;
        max-width: 100%;
    }

    .top_store_guide_content_grid:nth-child(2) {
        padding-top: 40px;
        max-width: 100%;
    }

    .top_store_guide_content_grid_texts .top_store_guide_name h3 {
        top: 122px;
    }

    .top_store_guide_content_grid_texts .top_store_guide_name p {
        top: 215px;
    }

    /* 出版部と洋書部 */

    /* お知らせ */
    .news .entry_block {
        display: block;
    }

    .news .entry_link_block {
        max-width: 100%;
    }

    .news .entry_block .section_title {
        margin-bottom: 56px;
    }

    .news .top_text_link {
        text-align: center;
        margin-right: 0;
    }

    /* お知らせ */

    /* おすすめ商品 */
    .recommended_product .entry_block {
        padding: 136px 40px 0;
    }
    .entry_image.auto_padding_img {
        width: 100%;
    }
    /* おすすめ商品 */

    /* 採用情報 */
    .top_recruit_content {
        margin-top: 40px;
        margin-left: 80px;
    }

    .top_recruit_content p {
        margin-top: 24px;
        margin-bottom: 32px;
    }

    /* 採用情報 */
}
@media (max-width: 1099px) and (min-width: 768px) {
    .top_main_visual_image {
        position: relative;
        top: 0rem;
    }
    .top_main_visual_decoration_sp.ap_pc_hidden{
        position: relative;
        top: -2rem;
    }
    .top_store_guide_content_image .ap_pc_hidden{
        display: none !important;
    }
    .top_store_guide_content_image .ap_sp_hidden{
        display: block !important;
    }
    .top_store_guide p.section_title_copy.ap_pc_hidden {
        display: block !important;
        font-size: 80px;
        line-height: 0.75;
        right: 0;
        top: 0;
        z-index: 5;
        top: 52px;
    }
    .top_store_guide p.section_title_copy.ap_sp_hidden {
        display: none !important;
    }
    /* .top_image_slider .scroll-image.ap_sp_hidden {
        display: none !important;
    }
    .top_image_slider .scroll-image.ap_pc_hidden {
        display: block !important;
    } */
}
@media (max-width: 767.98px) {
    .top_main_visual {
        height: 480px;
    }

    .kyobunkwan_body .nav-default {
        opacity: 0;
        pointer-events: none;
        transition: opacity 0.3s ease;
    }

    .kyobunkwan_body .nav-default.is-visible {
        opacity: 1;
        pointer-events: auto;
    }

    p.section_title_copy {
        font-size: 80px;
        top: 2px;
        left: -4px;
    }

    .top_content h2 {
        font-size: 24px;
    }

    .top_content.kyobunkwan {
        padding-top: 170px;
    }

    #first_view_header {
        display: none;
    }

    .page_title {
        font-size: 28px;
    }

    /* container */
    .top_container {
        padding: 0 22px;
    }

    .top_container_left {
        padding: 0 22px;
    }

    /* container */

    /* メインビジュアル */
    .top_main_visual {
        margin-top: 0;
    }

    .top_main_visual_decoration .site_logo {
        width: 200px;
        top: -130px;
    }

    .kyobunkwan .top_main_visual {
        padding: 0;
    }

    .top_main_visual_decoration .top_main_visual_image {
        padding: 0;
    }

    .top_main_visual_decoration .top_main_visual_catchphrase {
        right: 51%;
        bottom: 20px;
        transform: translateX(50%);
        font-size: 24px;
        z-index: 4;
        line-height: 1.6;
        letter-spacing: 0.25em;
    }

    .top_main_visual_decoration .top_main_visual_catchphrase::before {
        content: "";
        position: absolute;
        top: 35%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 126px;
        height: 289px;
        border-radius: 50%;
        background-color: rgba(255, 255, 255, 0.9);
        filter: blur(40px);
        z-index: -1;
    }

    .top_main_visual_decoration .top_main_visual_decoration_sp {
        position: absolute;
        width: 100%;
        display: block;
        z-index: 1;
        top: -96px;
        left: 0;
    }

    .top_main_visual_decoration::before {
        top: -6px;
        clip-path: polygon(22px 0,
                /* 左上切り取り後の開始点 */
                22px 22px,
                /* 左上の縦 */
                0 22px,
                /* 左上の横 */
                0 100%,
                /* 左下 */
                100% 100%,
                /* 右下 */
                100% 22px,
                /* 右下から右上切り取りへ */
                calc(100% - 22px) 22px,
                /* 右上の横 */
                calc(100% - 22px) 0,
                /* 右上の縦 */
                22px 0
                /* 左上に戻る */
            );
    }

    /* メインビジュアル */

    /* キャッチコピー */
    .top_kyobunkwan_about_block h3 {
        font-size: 24px;
    }

    .top_kyobunkwan_about_block p {
        max-width: 100%;
    }

    .top_kyobunkwan_about>div:nth-child(1) p.about_us_text {
        top: -33px;
        left: -22px;
        font-size: 80px;
        line-height: 0.75;
        z-index: 0;
    }

    .top_kyobunkwan_about>div:nth-child(1) {
        grid-template-columns: 1fr;
    }

    .top_kyobunkwan_about>div:nth-child(1) .top_kyobunkwan_about_image {
        text-align: right;
    }

    .top_kyobunkwan_about>div:nth-child(1) .top_kyobunkwan_about_image img {
        max-width: 200px;
        position: relative;
        z-index: 1;
    }

    .top_kyobunkwan_about>div:nth-child(1) .top_kyobunkwan_about_content {
        max-width: 100%;
        order: 2;
    }

    .top_kyobunkwan_about>div:nth-child(1) .top_kyobunkwan_about_content p {
        margin-bottom: 0;
    }

    .top_kyobunkwan_about>div:nth-child(2) {
        display: block;
        padding: 0;
        margin-top: 56px;
    }

    .top_kyobunkwan_about>div:nth-child(2) p {
        margin-top: 32px;
        margin-bottom: 32px;
        margin-left: 0;
    }

    .top_kyobunkwan_about>div:nth-child(2) .top_kyobunkwan_about_image {
        text-align: left;
        margin-left: -22px;
    }

    .top_kyobunkwan_about>div:nth-child(2) .top_kyobunkwan_about_image img {
        width: 300px;
    }

    .top_kyobunkwan_about>div:nth-child(2) .top_kyobunkwan_about_content h4 {
        margin-left: 0;
        text-align: center;
    }

    /* キャッチコピー */

    /* 画像スライドショー */
    .top_image_slider_content {
        aspect-ratio: 125 / 216;
    }

    .top_image_slider_content h2 {
        font-size: 24px;
        top: 50.3%;
        line-height: 1.3;
    }

    /* 画像スライドショー */

    /* 売り場のご案内 */
    .top_store_guide {
        padding: 120px 22px 0;
    }

    .top_store_guide p.section_title_copy {
        font-size: 80px;
        line-height: 0.75;
        right: 0;
        top: 0;
        z-index: 5;
        top: 52px;
    }

    .top_store_guide .top_store_guide_title p {
        margin-top: 16px;
    }

    .top_store_guide_block {
        margin-top: 64px;
    }

    .top_store_guide h3 a {
        font-size: 24px;
        line-height: 1.3;
    }

    .top_store_guide span {
        margin-top: 4px;
    }

    .top_store_guide_content_texts {
        margin-top: 16px;
    }

    .top_store_guide_content_image {
        width: calc(100% + 22px);
    }

    .top_store_guide_content:nth-child(even) .top_store_guide_content_image {
        margin-left: -22px;
    }

    /* 売り場のご案内 */

    /* 出版部と洋書部 */
    .top_entry_link {
        padding: 0 0 56px;
    }

    .top_store_guide_content_grid {
        aspect-ratio: 375 / 512;
    }

    .top_store_guide_content_grid:nth-child(1) {
        max-width: 100%;
    }

    a.top_store_guide_content_grid_texts {
        padding: 0 22px;
    }

    .top_store_guide_content_grid_texts .top_store_guide_name h3 {
        position: static;
        text-align: left;
        margin-top: 80px;
    }

    .top_store_guide_content_grid_texts .top_store_guide_name p {
        position: static;
        margin-top: 32px;
    }

    /* 出版部と洋書部 */
    .recommended_product .entry_block {
        padding: 136px 22px 0;
    }

    /* 教文館からのお知らせ */
    .top_container.news {
        margin-top: 88px;
    }

    .news .entry_block .section_title {
        margin-bottom: 28px;
    }

    .news .entry_link {
        padding: 16px 0;
        align-items: baseline;
        min-width: 0;
        display: grid;
        grid-template-columns: 1fr 20px;
        gap: 0px;
    }

    .news .entry-header-time {
        font-size: 1rem;
        grid-column: 1 / -1;
    }

    .news .entry_link .entry_list_title {
        white-space: normal;
        text-overflow: ellipsis;
        -webkit-line-clamp: 2;
        line-clamp: 2;
        display: -webkit-box;
        box-orient: vertical;
        -webkit-box-orient: vertical;
    }

    .news .entry_link::after {
        top: -3px;
        width: 24px;
        height: 8px;
    }

    /* 教文館からのお知らせ */

    /* 催事情報 */
    .top_container.event_news {
        margin-top: 96px;
    }

    .top_event_news_entry_block {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 24px 27px;
        margin-top: 32px;
    }

    .top_event_news_entry_link {
        display: block;
    }

    .top_event_news_entry_link .entry_image {
        width: 100%;
        box-sizing: border-box;
    }

    .top_event_news_entry_link .entry_image img {
        width: 100%;
        display: block;
    }

    .top_event_news_entry_link:hover {
        opacity: 0.75;
    }

    .top_event_news_entry_link .entry_list_title {
        -webkit-line-clamp: 3;
        line-clamp: 3;
        font-size: 14px;
        line-height: 1.4285;
    }


    .top_event_news_entry_link .date-title {
        margin-top: 0;
    }

    .top_event_news_entry_link .entry_list_title {
        margin-top: 0px;
    }

    .top_event_news_entry_link .category-tag-list .tag-label {
        font-size: 11px;
        max-width: 100%;
        width: auto;
        padding: 0 8px;
        line-height: 20px;
        height: 20px;
    }

    .top_event_news_entry_link .category-tag-list .category_label {
        margin-right: 4px;
        font-size: 11px;
        line-height: 22px;
        padding: 0 4px;
    }

    .top_event_news_entry_link .category-tag-list {
        column-gap: 4px;
        margin-top: -4px;
        row-gap: 6px;
    }

    .top_event_news_entry_info {
        margin-top: 4px;
    }

    .card-date-layout {
        font-size: 12px;
        font-weight: 500;
        color: #3D3826;
        letter-spacing: 0.03em;
        margin-right: 0;
    }

    .top_event_news_entry_link .category-tag-list>div {
        flex: 0 0 100%;
    }

    .date-title .card-date-layout {
        font-size: 12px;
        letter-spacing: 0.03em;
        margin-right: 0;
    }

    .event_news .entry_blog_name {
        font-size: 11px;
    }

    /* 催事情報 */

    .top_banner {
        margin-top: 80px;
    }

    /* おすすめ商品 */
    #bg_noise_d8d4c5 {
        padding-bottom: 56px;
    }

    #bg_noise_d8d4c5 .column-media {
        margin-bottom: 0;
        padding-bottom: 144px;
    }

    .recommended_product {
        margin-top: 56px;
        max-width: 100%;
    }

    .recommended_product .entry_block {
        padding: 72px 22px 0;
    }

    .recommended_product .entry_link_grid {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        gap: 40px 27px;
        margin-top: 32px;
    }

    .recommended_product .entry_link_grid .entry_link {
        display: block;
    }

    .recommended_product .entry_link_grid .entry_info {
        margin-top: 4px;
    }

    .recommended_product .entry_link_grid .entry_info .entry_list_title {
        -webkit-line-clamp: 3;
        line-clamp: 3;
        font-size: 14px;
        line-height: 1.4285;
    }

    .recommended_product .entry_link_grid .entry_info #book_price_tax {
        margin-top: 4px;
        margin-bottom: 0;
        font-size: 15px;
        line-height: 1.3rem;
    }

    .recommended_product .entry_link_grid .entry_info #book_bace_price {
        font-size: 12px;
        line-height: 1.7;
    }

    .recommended_product .entry_link_grid .entry_info .tag_label {
        font-size: 11px;
    }

    .recommended_product .entry_link_grid .tag_list {
        line-height: 1;
        font-size: 11px;
    }
    .entry_image.auto_padding_img {
        width: 100%;
    }
    /* おすすめ商品 */

    /* 採用情報 */
    .top_recruit {
        aspect-ratio: 375 / 512;
    }

    .top_recruit_content {
        margin-left: 22px;
        margin-top: 80px;
        margin-right: 22px;
    }

    .top_recruit_content p {
        margin-top: 32px;
        margin-bottom: 16px;
        line-height: 1.75;
    }

    /* 採用情報 */

    #adminBox {
        margin-bottom: 96px;
    }

    .acms-form-group {
        position: absolute;
        top: 230px;
    }

    .top_store_guide_content_grid svg {
        position: absolute;
        right: 22px;
        bottom: 40px;
        z-index: 1;
        display: block;
    }

    .recommended_product .entry_image.auto_padding_img {
        --auto-padding-inset: 16px;
    }

    .top_store_guide_content_grid_texts .top_store_guide_content_image{
        height: 100%;
    }
    .top_store_guide_content_grid_texts .top_store_guide_content_image img{
        aspect-ratio: 375 / 512;
    }
}