@charset "utf-8";
@import url('style.css');


.upskin-version {
    font-size: 0.8em;
    font-family: var(--f-pre);
    color: var(--content-font-color);
    opacity: 0.2;
    margin-right: 5px;
}

/* 요소 */
input[type="text"] {
    width: 200px;
}

.pg_wrap .pg_end:before {
    font-family: var(--f-pre);
    font-size: 12px !important;
}

.cha-ui-btn {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 6px;
}

.cha-ui-btn .ui-btn {
    font-size: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.cha-view-tools {
    position: relative;
    display: flex;
    align-items: center;
    gap: 5px;
}

/* 카테고리 */
nav.cha-board-category {
    display: flex;
    gap: 5px;
    margin-bottom: 20px;
    justify-content: center;
}

nav.cha-board-category a {
    display: inline-flex;
    border-radius: 10px;
    background: var(--btn-primary-bg);
    color: var(--btn-primary-text);
    border: 1px inset var(--btn-primary-bg);
    min-width: 30px;
    max-width: 80px;
    padding: 5px 8px;
    text-align: center;
    font-size: 0.9em;
    font-family: var(--content-font-family);
    align-items: center;
    justify-content: center;
    line-height: 1;
}

nav.cha-board-category a:hover {
    background: var(--btn-accent-bg);
    color: var(--btn-accent-text);
}

nav.cha-board-category #bo_cate_on {
    background: var(--btn-accent-bg);
    color: var(--btn-accent-text);
}

.cha-board-category li::marker {
    content: none;
}

/* 리스트 시작 */
.cha-guide {
    display: flex;
    justify-content: space-between;
    margin-top: 20px;
    gap: 10px;
}

.cha-board-skin {
    padding: 30px 0px;
}

.cha-view-switch {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 32px;
    gap: 0;
    padding: 3px;
    border: 1px solid var(--container-border-color, rgb(from var(--content-font-color) r g b / 16%));
    border-radius: 999px;
    background: var(--card-bg-color, rgb(from var(--content-font-color) r g b / 6%));
    font-family: var(--content-font-family);
    overflow: hidden;
}

.cha-view-switch a {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 34px;
    height: 24px;
    padding: 0 8px;
    border-radius: 999px;
    background: transparent;
    color: rgb(from var(--content-font-color) r g b / 64%);
    text-align: center;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;
    white-space: nowrap;
    transition: background 180ms ease, color 180ms ease;
}

.cha-view-switch a i {
    display: block;
    line-height: 1;
}

.cha-view-switch a + a::before {
    content: "";
    position: absolute;
    left: -2px;
    top: 6px;
    bottom: 6px;
    width: 1px;
    background: rgb(from var(--content-font-color) r g b / 14%);
}

.cha-view-switch a.active + a::before,
.cha-view-switch a.active::before,
.cha-view-switch a:hover + a::before,
.cha-view-switch a:hover::before {
    opacity: 0;
}

.cha-view-switch a.active,
.cha-view-switch a:hover {
    background: var(--btn-accent-bg);
    color: var(--btn-accent-text);
}

.cha-view-config-wrap {
    position: relative;
}

.cha-view-config-btn {
    width: 32px;
    height: 32px;
    min-width: 32px;
}

.cha-view-config-panel {
    display: none;
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    z-index: 20;
    width: 180px;
    padding: 12px;
    border: 1px solid var(--container-border-color, rgb(from var(--content-font-color) r g b / 16%));
    border-radius: 8px;
    background: var(--card-bg-color, var(--body-bg, var(--white, #fff)));
    box-shadow: 0 8px 24px rgb(from var(--black) r g b / 18%);
    color: var(--content-font-color);
    font-family: var(--content-font-family);
}

.cha-view-config-panel.is-open {
    display: block;
}

.cha-view-config-panel strong {
    display: block;
    margin-bottom: 9px;
    font-size: 12px;
    line-height: 1;
}

.cha-view-config-segment {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4px;
    margin-bottom: 10px;
}

.cha-view-config-segment label {
    display: block;
    cursor: pointer;
}

.cha-view-config-segment input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.cha-view-config-segment span {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 28px;
    border-radius: 6px;
    background: rgb(from var(--content-font-color) r g b / 7%);
    color: rgb(from var(--content-font-color) r g b / 70%);
    font-size: 11px;
    font-weight: 700;
    line-height: 1;
}

.cha-view-config-segment span i {
    display: block;
    font-size: 12px;
    line-height: 1;
}

.cha-view-config-segment input:checked + span {
    background: var(--btn-accent-bg);
    color: var(--btn-accent-text);
}

.cha-view-config-save {
    width: 100%;
    min-height: 30px;
    border: 0;
    border-radius: 6px;
    background: var(--btn-primary-bg);
    color: var(--btn-primary-text);
    font-family: var(--content-font-family);
    font-size: 11px;
    font-weight: 700;
    cursor: pointer;
}

.cha-view-config-save:hover {
    background: var(--btn-accent-bg);
    color: var(--btn-accent-text);
}

/* 기존 flex 코드를 주석처리하고 grid로 변경 */
.list_row {
    display: grid;
    grid-template-columns: repeat(var(--desktop-cols), 1fr);
    gap: 8px;
    list-style: none;
    padding: 0;
    margin: 0;
}

.cha_card {
    position: relative;
    overflow: hidden;
    border: 2px groove var(--black);
    border-radius: 15px;
    filter: brightness(0.7) drop-shadow(1px 3px 2px rgb(from var(--black) r g b / 30%));
}

.cha_card:hover {
	filter: brightness(1) drop-shadow(1px 3px 3px rgb(from var(--black) r g b / 50%));
}

@keyframes chaPairCardIn {
    from {
        opacity: 0;
        transform: translateY(12px) scale(0.985);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

@keyframes chaPairLeftIn {
    from {
        opacity: 0;
        transform: translateX(-12px) rotate(-1deg) scale(0.985);
    }
    to {
        opacity: 1;
        transform: translateX(0) rotate(0) scale(1);
    }
}

@keyframes chaPairRightIn {
    from {
        opacity: 0;
        transform: translateX(12px) rotate(1deg) scale(0.985);
    }
    to {
        opacity: 1;
        transform: translateX(0) rotate(0) scale(1);
    }
}

@keyframes chaPairMetaIn {
    from {
        opacity: 0;
        transform: translateY(6px) scale(0.96);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.pair_row {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: flex-start;
    gap: 28px 34px;
}

.cha_pair_card {
    position: relative;
    width: min(100%, 600px);
    padding: 0;
    --pair-delay: 0ms;
    animation: chaPairCardIn 520ms cubic-bezier(0.2, 0.72, 0.22, 1) both;
    animation-delay: var(--pair-delay);
}

.pair_row .cha_pair_card:nth-child(2) {
    --pair-delay: 70ms;
}

.pair_row .cha_pair_card:nth-child(3) {
    --pair-delay: 140ms;
}

.pair_row .cha_pair_card:nth-child(4) {
    --pair-delay: 210ms;
}

.pair_row .cha_pair_card:nth-child(n+5) {
    --pair-delay: 280ms;
}

.cha_pair_members {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 200px minmax(0, 1fr);
    gap: 12px;
    align-items: center;
}

.cha_pair_member_card {
    display: block;
    min-width: 0;
    text-decoration: none;
    height: clamp(180px, 22vw, 260px) !important;
    filter: brightness(0.78) drop-shadow(1px 3px 2px rgb(from var(--black) r g b / 25%));
    transition: filter 240ms ease, outline-color 240ms ease, transform 260ms cubic-bezier(0.2, 0.72, 0.22, 1);
}

.cha_pair_members > .cha_pair_member_card:first-child {
    animation: chaPairLeftIn 560ms cubic-bezier(0.2, 0.72, 0.22, 1) both;
    animation-delay: calc(var(--pair-delay) + 90ms);
}

.cha_pair_members > .cha_pair_member_card:last-child {
    animation: chaPairRightIn 560ms cubic-bezier(0.2, 0.72, 0.22, 1) both;
    animation-delay: calc(var(--pair-delay) + 150ms);
}

.cha_pair_member_card .list_box {
    height: 100% !important;
}

.cha_pair_member_card:hover,
.cha_pair_member_card:focus-visible {
    filter: brightness(1) drop-shadow(1px 3px 3px rgb(from var(--black) r g b / 50%));
    transform: translateY(-4px) scale(1.015);
}

.cha_pair_member_card:focus-visible {
    outline: 2px solid var(--btn-accent-bg);
    outline-offset: 4px;
}

.cha_pair_member_card img {
    transition: transform 320ms ease, filter 320ms ease;
}

.cha_pair_member_card:hover img,
.cha_pair_member_card:focus-visible img {
    transform: scale(1.04);
}

.cha_pair_member_card .ov-one-liner {
    font-size: 34px;
}

.cha_pair_member_card .ov-cname {
    font-size: 20px;
}

.cha_pair_bridge {
    display: flex;
    min-width: 0;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    color: var(--content-font-color);
    font-family: var(--content-font-family);
    text-align: center;
    animation: chaPairMetaIn 440ms cubic-bezier(0.2, 0.72, 0.22, 1) both;
    animation-delay: calc(var(--pair-delay) + 220ms);
}

.cha_pair_mark {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 28px;
    border-radius: 50%;
    color: var(--content-font-color);
    font-family: var(--content-font-family);
    font-size: 22px;
    font-weight: 500;
    letter-spacing: 0;
    line-height: 1;
    animation: chaPairMetaIn 360ms cubic-bezier(0.2, 0.72, 0.22, 1) both;
    animation-delay: calc(var(--pair-delay) + 360ms);
    transition: color 220ms ease, transform 220ms ease;
}

.cha_pair_mark span {
    display: flex;
    align-items: center;
    justify-content: center;
    transform: translateY(-1px);
    transition: transform 300ms cubic-bezier(0.2, 0.72, 0.22, 1);
}

.cha_pair_card:hover .cha_pair_mark {
    color: var(--btn-accent-bg);
}

.cha_pair_card:hover .cha_pair_mark span {
    transform: translateY(-1px) rotate(90deg) scale(1.05);
}

.cha_pair_day {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    min-width: 0;
    font-style: normal;
    animation: chaPairMetaIn 360ms cubic-bezier(0.2, 0.72, 0.22, 1) both;
    animation-delay: calc(var(--pair-delay) + 300ms);
}

.cha_pair_day strong {
    display: block;
    font-family: var(--f-pre);
    font-size: 13px;
    font-weight: 800;
    line-height: 1;
    color: var(--btn-accent-bg);
    transition: transform 220ms ease;
}

.cha_pair_day span {
    font-size: 10px;
    line-height: 1.2;
    opacity: 0.62;
}

.cha_pair_card:hover .cha_pair_day strong {
    transform: translateY(-1px);
}

.cha_pair_text {
    width: 150px;
    overflow: hidden;
    color: var(--content-font-color);
    font-size: 11px;
    line-height: 1.45;
    opacity: 0.78;
    word-break: keep-all;
    overflow-wrap: anywhere;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    animation: chaPairMetaIn 400ms cubic-bezier(0.2, 0.72, 0.22, 1) both;
    animation-delay: calc(var(--pair-delay) + 420ms);
    transition: opacity 220ms ease, transform 220ms ease;
}

.cha_pair_card:hover .cha_pair_text {
    opacity: 0.9;
    transform: translateY(-1px);
}

/* 편집 모드일 때 카드에 점선 테두리와 배경색 변경 */
.cha_list.editing .cha_card {
    border: 2px dotted var(--warning-color);
    filter: contrast(0.7) drop-shadow(1px 3px 0px rgb(from var(--black) r g b / 70%));
    transition: background-color 0.3s, border 0.3s;
}

.cha_list_controls {
    display: flex;
    flex: 1;
    justify-content: flex-end;
    gap: 3px;
}

#edit-order-btn {
    border-radius: 5px;
    background: var(--btn-secondary-bg);
    color: var(--btn-secondary-text);
    font-size: 12px;
    font-family: var(--f-pre);
    border: 2px groove var(--btn-secondary-bg);
    padding: 0;
    width: 32px;
    height: 32px;
    min-width: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    cursor: pointer;
}

#edit-order-btn:hover {
    transform: scale(1.02);
}

/* 편집 모드일 때 편집 버튼 강조 */
#edit-order-btn.editing {
    background-color: var(--warning-color);
    color: var(--white);
}

a.card_link {
    cursor: pointer;
}

.list_box img {
    height: 100%;
    width: 100%;
    object-fit: cover;
    position: relative;
    bottom: 0;
}

.ov-one-liner {
    position: absolute;
    white-space: nowrap;
    text-overflow: ellipsis;
    top: 15%;
    left: 70%;
    transform: translate(-50%, -50%) rotate(-15deg);
    font-size: 70px;
    font-weight: bold;
    color: var(--gray-800);
    z-index: -10;
    pointer-events: none;
    font-family: 'HakgyoansimByeolbichhaneulTTF-B';
}

.info_overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 10px;
    box-sizing: border-box;
    background: linear-gradient(0deg, var(--black) 25%, rgb(from var(--white) r g b / 0%) 100%);
    color: var(--white);
    height: 70px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
}

.ov-cname {
    font-family: "Playfair Display", serif;
    font-size: 25px;
    text-align: center;
    line-height: 80%;
	  text-shadow: 0 0 5px var(--black), 0 0 15px var(--gray-700), 0 0 35px var(--gray-500), 0 0 40px var(--gray-500);
}

/* 한자, 일본어 */
.ov-cname.cjk-ja {
    font-family: "Zen Antique", serif;
}

/* 중국어 */
.ov-cname.cjk-zh {
    font-family: "Noto Serif SC", serif;
}

.ov-kname {
    margin: 5px 0px;
    font-weight: 400;
    letter-spacing: 2px;
    text-align: center;
    font-size: 11px;
    font-family: var(--f-pre);
}

@media (max-width: 768px) {
    .list_row {
        grid-template-columns: repeat(var(--mobile-cols), 1fr);
        gap: 6px;
    }

    .pair_row {
        gap: 22px;
    }

    .cha_pair_members {
        grid-template-columns: minmax(0, 1fr) 150px minmax(0, 1fr);
        gap: 8px;
    }

    .cha_pair_member_card {
        height: clamp(160px, 42vw, 230px) !important;
    }

    .cha_pair_mark {
        width: 28px;
        height: 26px;
        font-size: 20px;
    }

    .cha_pair_day strong {
        font-size: 11px;
    }

    .cha_pair_day span,
    .cha_pair_text {
        font-size: 9px;
    }

    .cha_list_controls {
        display: none;
    }
}

@media (prefers-reduced-motion: reduce) {
    .cha_pair_card,
    .cha_pair_members > .cha_pair_member_card:first-child,
    .cha_pair_members > .cha_pair_member_card:last-child,
    .cha_pair_bridge,
    .cha_pair_mark,
    .cha_pair_day,
    .cha_pair_text {
        animation: none !important;
    }

    .cha_pair_member_card,
    .cha_pair_member_card img,
    .cha_pair_mark,
    .cha_pair_mark span,
    .cha_pair_day strong,
    .cha_pair_text {
        transition: none !important;
    }

    .cha_pair_member_card:hover,
    .cha_pair_member_card:focus-visible,
    .cha_pair_member_card:hover img,
    .cha_pair_member_card:focus-visible img,
    .cha_pair_card:hover .cha_pair_day strong,
    .cha_pair_card:hover .cha_pair_text {
        transform: none;
    }

    .cha_pair_card:hover .cha_pair_mark span {
        transform: translateY(-1px);
    }
}
