@charset "utf-8";
@import url('https://cdn.rawgit.com/moonspam/NanumSquare/master/nanumsquare.css');

/*****************/
/* 요소 */
/*****************/

/* 버튼 */
strong.pg_current.pg_page {
    background: var(--color-bg) !important;
}

strong.pg_current.pg_page:hover {
    background: var(--color-4);
    border-color: var(--color-2);
    color: var(--color-d);
}

.timethread_box {
    display: flex;
    gap: 10px;
    width: 100%;
}

.timethread_tag {
    display: none !important;
    position: fixed;
    top: 9%;
    right: 0;
    width: 300px;
    max-width: 300px;
    transform: translateX(100%) translateY(0%);
    transition: transform 0.3s ease-in-out;
    z-index: 1000;
    height: auto;
    /* 또는 fit-content; 사용 가능 */
    font-family: var(--content-font-family);
    display: flex;
    border: 1px solid var(--container-border-color);
    border-radius: 10px;
    padding: 20px;
    background-color: var(--color-2);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
    margin-bottom: 10px;
    box-sizing: border-box;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    align-content: center;
    gap: 3px;
}

.timethread_tag.active {
    display: flex !important;
    transform: translateX(0) translateY(0%);
}

.tagtoggle-btn {
    position: fixed;
    top: 9%;
    right: 0;
    transform: translateY(-50%);
    z-index: 1001;
    padding: 5px 10px;
    background: var(--btn-accent-bg);
    color: var(--btn-accent-text);
    border: none;
    border-radius: 4px 0px 0px 4px;
    box-shadow: 1px 3px 1px rgba(0, 0, 0, 0.2);
    cursor: pointer;
}

/* .pg_wrap {
    padding: 0;
    margin-bottom: 20px;
    display: inline-flex !important;
    gap: 2px;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
}

.pg_wrap .pg_page {
    display: inline-flex !important;
    height: 30px !important;
    width: 30px;
    box-sizing: border-box !important;
    font-size: 12px !important;
    border-radius: 8px !important;
    background: var(--gray-600);
    color: var(--color-e) !important;
    border: 0 !important;
    font-family: var(--content-font-family);
    align-items: center;
    justify-content: center;
}

.pg_wrap .pg_start,
.pg_wrap .pg_end {
    min-width: 0 !important;
}

.pg_wrap .pg_page.pg_control:before {
    font-size: 12px;
    display: inline-flex;
    font-family: var(--content-font-family);
    align-items: center;
    justify-content: center;
}

.searc-sub-box {
    padding: 0 !important;
    margin: 0 !important;
} */

.md-btn a {
    font-size: 0.9em;
}

/*****************/
/* 본문 */
/*****************/

#log_list .item {
    background-color: var(--color-bg) !important;
    color: var(--color-e) !important;
    border-radius: 20px;
}

#log_list {
    position: relative;
    background-color: transparent !important;
    border-color: transparent !important;
    width: 100%;
}

.profile-pic-img {
    width: 25px;
    height: 25px;
    border-radius: 50%;
    object-fit: cover;
    border: 1px solid var(--color-d);
    color: var(--color-d);
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

.profile-img img {
    width: 250px;
    height: 100%;
    object-fit: cover;
}

.main-container {
    transition: opacity 0.1s ease-in-out;
}

.main-container {
    font-family: var(--content-font-family);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-width: 550px;
    max-width: 50%;
    width: 100%;
    margin: 0 auto;
    border: 1px solid var(--container-border-color);
    border-radius: 10px;
    background: var(--container-bg-color);
    color: var(--content-font-color);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
    margin-bottom: 10px;
    box-sizing: border-box;
    overflow: hidden;
}

.main-container.notice {
    border: 2px solid rgb(from var(--accent-color) r g b / 50%);
}

.content-wrapper {
    display: flex;
    flex-direction: column;
    padding: 20px 20px 0px;
}


/******************/
/* 댓글			*/
/******************/

/* 📌 댓글창 토글 버튼 */
.comment-toggle {
    display: block;
    cursor: pointer;
    color: var(--color-b);
    font-weight: bold;
}

.linkcopyload_btn {
    color: var(--color-b);
}

.comment-wrapper {
    display: flex;
    flex-direction: column;
}

.comment-btn {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0px 15px 10px;
}

.comment.btn {
    display: flex;
    gap: 10px;
    height: 30px;
    align-items: center;
    padding: 0;
}

.comment.btn a {
    color: var(--secondary-color);
}

/* 좋아요 영역 */
.like_area {
    display: flex;
    align-items: center;
    gap: 5px;
}

.like_number {
    color: var(--secondary-color);
}

.like_btn {
    display: flex;
    align-items: center;
    font-size: 13px;
    border: 0;
    background: transparent;
    /* 하트 크기 조절 */
    color: var(--secondary-color);
    cursor: pointer;
    transition: transform 0.2s ease;
    /* 부드러운 애니메이션 효과 */
}

.like_btn:active,
.like_btn.active {
    transform: scale(1.1);
    color: var(--accent-color);
}

@keyframes pop {
    0% {
        transform: scale(1);
    }

    20% {
        transform: scale(1.3);
    }

    70% {
        transform: scale(1);
    }
}

.like_btn.active {
    animation: pop 0.3s;
}


.likers-modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    z-index: 10000;
    align-items: center;
    justify-content: center;
}
.likers-modal.show {
    display: flex;
}
.likers-modal-content {
    background: var(--card-bg-color, #fff);
    border-radius: 8px;
    width: 90%;
    max-width: 400px;
    max-height: 80vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
}
.likers-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px 20px 10px;
}
.likers-modal-header h3 {
    margin: 0;
    font-size: 16px;
    color: var(--text-color, #333);
}
.likers-modal-close {
    font-size: 24px;
    cursor: pointer;
    color: var(--secondary-color, #666);
    line-height: 1;
}
.likers-modal-close:hover {
    color: var(--primary-color, #007bff);
}
.likers-modal-body {
    padding: 0px 20px 15px;
    overflow-y: auto;
    flex: 1;
}
.likers-loading {
    text-align: center;
    color: var(--secondary-color, #666);
    padding: 20px;
}
.likers-list {
    list-style: none;
    margin: 0;
    padding: 0;
}
.likers-list li {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 0;
    border-bottom: 1px solid var(--line-color, #eee);
}
.likers-list li:last-child {
    border-bottom: none;
}
.liker-info {
    display: flex;
    flex-direction: column;
}
.liker-name {
    font-weight: 500;
    color: var(--text-color, #333);
}
.liker-id {
    font-size: 12px;
    color: var(--secondary-color, #999);
}
.liker-datetime {
    font-size: 11px;
    color: var(--secondary-color, #999);
}
.likers-list-empty {
    text-align: center;
    color: var(--secondary-color, #999);
    padding: 20px;
}
.like_number.clickable {
    cursor: pointer;
}
.like_number.clickable:hover {
    text-decoration: underline;
    color: var(--primary-color, #007bff);
}

.user-info-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;

}

/* 📌 작성자 정보 */
.user-info {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
}

.user-details {
    display: flex;
    flex-direction: row;
    gap: 3px;
    align-items: center;
}

.nick {
    font-weight: bold;
    font-size: 1em;
    color: var(--content-font-color);
}

.id {
    font-size: 0.85em;
    color: rgb(from var(--content-font-color) r g b / 70%);
}

.content-date {
    font-size: 0.85em;
    color: rgb(from var(--content-font-color) r g b / 70%);
}

/* 📌 본문 영역  */
.post-content {
    padding: 15px;
}

.post-edit,
.post-delete {
    color: var(--accent-color);
    font-weight: bold;
    cursor: pointer;
    text-decoration: none;
}

.post-edit:hover,
.post-delete:hover {
    text-decoration: underline;
}

/* 모달 기본 스타일 */
.modal {
    display: none;
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.8);
    align-items: center;
    justify-content: center;
}

/* 모달 내 이미지 스타일 */
.modal-content {
    max-width: 80%;
    max-height: 80%;
    border-radius: 10px;
}

/* 닫기 버튼 */
.close {
    position: absolute;
    top: 15px;
    right: 25px;
    color: var(--white);
    font-size: 30px;
    font-weight: bold;
    cursor: pointer;
}

/* 좌우 탐색 버튼 */
.prev,
.next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    font-size: 30px;
    color: var(--white);
    cursor: pointer;
    padding: 10px;
    background: rgba(0, 0, 0, 0.5);
    border-radius: 5px;
    user-select: none;
}

.prev {
    left: 20px;
}

.next {
    right: 20px;
}

.prev:hover,
.next:hover {
    background: rgba(0, 0, 0, 0.8);
}

/*****************/
/* 공지사항 추가 */
/*****************/

.load-option-btn {
    display: flex;
    align-items: center;
    gap: 2px;
}

.notice-option {
  padding: 0 6px;
  background: var(--card-bg-color);
  border: 2px solid var(--card-border-color);
  border-radius: var(--card-border-radius);
  color: var(--content-font-color);
  font-size: 0.9em;
  font-family: var(--content-font-family);
  font-weight: bold;
}

::-webkit-scrollbar {
    display: none;
}

/* 접힌 답글의 자식 답글 처리 */
.plip-comment.plip-collapsed>.comment-body .original_comment_area {
    display: none !important;
}

.comment-con a:link,
.comment-con a:visited {
    color: var(--accent-color);
}

/*****************/
/* 모바일 최적화 등 */
/*****************/

@media screen and (max-width: 768px) {
    .main-container {
        min-width: 100px;
        max-width: 96%;
    }

    .content-wrapper {
        padding: 10px 15px 0px;
    }

    .timethread_tag {
        width: 200px;
        max-width: 200px;
    }

    .timethread_tag.active {
        right: 0;
    }

    .user-info-container {
        flex-direction: column-reverse;
        align-items: flex-start;
    }
    .user-info {
        width: 100%;
    }
    .md-btn {
        flex: 1;
        display: flex;
        justify-content: flex-end;
        gap: 6px;
        font-size: 0.85em;
        opacity: 0.5;
    }
    .content-date {
        color: rgb(from var(--content-font-color) r g b / 30%);
        display: flex;
        justify-content: flex-end;
        width: 100%;
        font-size: 0.6em;
    }

}

hr.padding {
    display: none !important;
}

/* ========================================
   RA0 Edition - Timeline 답글 시스템 스타일
   ======================================== */

/* 답글 컨테이너 */
.reply-thread-container {
}

.reply-thread-container .ra0-content .tile-grid {
    display: flex;
    flex-wrap: nowrap;
    gap: 5px;
    margin: 15px 0;
    max-width: 100%;
    overflow-x: auto;
    max-height: 300px;
}

.reply-thread-container .ra0-content .tile-item {
    overflow: hidden;
    border-radius: 8px;
    flex: 1;
}

.reply-actions .ra0_ui_btn {
    background: var(--btn-accent-bg);
    color: var(--btn-accent-text);
    padding: 2px 5px;
    border-radius: 4px;
    font-size: 0.8em;
}

.reply-footer .ra0_ui_btn {
    background: transparent;
    color: var(--content-font-color);
}

/* 답글 아이템 - 트위터 스타일 */
.reply-item {
    padding: 0;
    background: var(--card-bg-color);
    color: var(--content-font-color);
    transition: all 0.3s ease;
}

.reply-item:hover {
    background: var(--container-bg-color);
    box-shadow: 0 2px 8px rgb(from var(--gray-600) r g b / 20%);
}

/* 답글 라인 래퍼 - 프로필과 콘텐츠를 가로로 배치 */
.reply-line-wrapper {
    display: flex;
    gap: 12px;
    padding: 10px 20px;
    align-items: stretch;
}

/* 답글 아바타 래퍼 - 프로필 이미지와 세로 라인 */
.reply-avatar-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex-shrink: 0;
    align-self: stretch;
}

/* 답글 프로필 사진 */
.reply-profile-pic {
    width: 30px;
    height: 30px;
    flex-shrink: 0;
}

.reply-profile-img {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    object-fit: cover;
    display: flex;
    justify-content: center;
    align-items: center;
    background: color-mix(in srgb, var(--secondary-color) 25%, transparent);
    border: 2px solid color-mix(in srgb, var(--primary-color) 70%, transparent);
}

/* 세로 연결 라인 - 트위터 스타일 */
.reply-thread-line {
    width: 2px;
    flex: 1;
    background: var(--secondary-color);
    margin-top: 8px;
    min-height: 30px;
    border-radius: 1px;
}

/* 답글 메인 콘텐츠 영역 */
.reply-main-content {
    flex: 1;
    min-width: 0;
}

/* 답글 헤더 */
.reply-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 4px 0 8px;
}

/* 답글 사용자 정보 */
.reply-user-info {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.reply-profile {
    display: flex;
    align-items: center;
    gap: 3px;
}

/* 답글 자식 컨테이너 */
.reply-children {
    /* 자식 답글은 같은 레벨에 표시 (margin-left 없음) */
}

.reply-actions {
    display: flex;
    gap: 5px;
}

/* 답글 내용 */
.reply-content {
    margin-top: 8px;
}

.reply-mention {
  background: var(--btn-accent-bg);
  color: var(--btn-accent-text);
  padding: 2px 5px;
  border-radius: 10px;
  font-size: 0.8em;
}

.reply-image {
    margin: 8px 0;
    border-radius: 5px;
    overflow: hidden;
}

.reply-image img {
    max-width: 100%;
    height: auto;
    display: block;
}

.reply-text, .reply-name, .reply-id, .reply-date {
    color: var(--content-font-color);
    line-height: 1.7;
    word-break: break-word;
}

.reply-text {
    font-size: var(--content-font-size);
    margin-top: 5px;
    padding: 0px 10px;
    white-space: pre-line;
}

.reply-name {
    font-weight: bold;
    font-size: 1em;
}

.reply-id {
    opacity: 0.7;
    font-size: 0.85em;
}

.reply-date {
    font-size: 0.7em;
    line-height: 1;
    opacity: 0.5;
}

/* .reply-item:hover .reply-text,
.reply-item:hover .reply-name,
.reply-item:hover .reply-id,
.reply-item:hover .reply-date,
.reply-item:hover .reply-actions .ra0_ui_btn,
.reply-item:hover .reply-footer .ra0_ui_btn {
    color: var(--content-bg-color);
} */

.reply-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 8px;
    height: 30px;
}

.reply-footer .ra0_ui_btn {
    background: transparent;
    color: var(--primary-color);
}

.reply-actions .ra0_ui_btn {
    background: transparent;
    color: var(--primary-color);
    padding: 0;
}

/* 답글 작성 폼 */
.reply-form-container {
    margin-top: 10px;
    padding: 15px;
    background: var(--secondary-color);
    border-radius: 8px;
    border: 1px solid var(--gray-600);
}

.reply-form textarea {
    width: 100%;
    min-height: 80px;
    padding: 10px;
    border: 1px solid var(--gray-600);
    border-radius: 5px;
    background: var(--color-2);
    color: var(--content-font-color);
    font-family: inherit;
    font-size: 13px;
    resize: vertical;
    margin-bottom: 10px;
}

.reply-guest {
    display: flex;
    gap: 10px;
    margin-bottom: 10px;
}

.reply-guest input {
    flex: 1;
    padding: 8px;
    border: 1px solid var(--gray-600);
    border-radius: 5px;
    background: var(--color-2);
    color: var(--content-font-color);
}

.reply-file-upload {
    margin-bottom: 10px;
}

.reply-file-upload label {
    display: block;
    margin-bottom: 5px;
    color: var(--color-9);
    font-size: 12px;
}

.reply-file-input {
    width: 100%;
    padding: 5px;
    margin-bottom: 5px;
    font-size: 12px;
}

.reply-buttons {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
}

/* 답글 중첩 스타일 */
.reply-nested {
    border-left-color: var(--color-s);
}

/* 모바일 최적화 */
@media (max-width: 768px) {
    .reply-line-wrapper {
        padding: 8px 12px;
        gap: 8px;
    }

    .reply-profile-pic {
        width: 30px;
        height: 30px;
    }

    .reply-profile-img {
        width: 30px;
        height: 30px;
    }

    .reply-name {
        font-size: 13px;
    }

    .reply-text {
        font-size: 12px;
    }

    .reply-form textarea {
        min-height: 60px;
        font-size: 12px;
    }

    .reply-guest {
        flex-direction: column;
    }
}

/* ========================================
   토글형 댓글 작성 폼
   ======================================== */

.comment-write-container {
    margin-top: 10px;
    padding: 0 10px;
}

.thread-write-form {
    background: var(--card-bg-color, #2a2a2a);
    border-radius: 10px;
    padding: 12px;
}

.thread-guest-name input {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid var(--border-color, #333);
    border-radius: 6px;
    background: var(--bg-color, #1a1a1a);
    color: var(--content-font-color, #fff);
    margin-bottom: 8px;
}

.thread-upload-toggle {
    margin-bottom: 8px;
}

.toggle-upload-btn {
    color: var(--text-muted-color, #888);
    font-size: 13px;
    display: inline-flex;
    align-items: center;
    gap: 5px;
}

.toggle-upload-btn:hover {
    color: var(--primary-color, #3b82f6);
}

.thread-upload-area {
    margin-bottom: 10px;
}

.thread-dropzone {
    border: 2px dashed var(--border-color, #444);
    border-radius: 8px;
    padding: 15px;
    text-align: center;
    cursor: pointer;
    color: var(--text-muted-color, #888);
    font-size: 12px;
    margin-bottom: 8px;
    transition: all 0.2s;
}

.thread-dropzone:hover,
.thread-dropzone.dragover {
    border-color: var(--primary-color, #3b82f6);
    background: rgba(59, 130, 246, 0.05);
}

.thread-dropzone i {
    font-size: 20px;
    display: block;
    margin-bottom: 5px;
}

.thread-url-input {
    display: flex;
    gap: 6px;
    margin-bottom: 8px;
}

.thread-url-input input {
    flex: 1;
    padding: 8px 10px;
    border: 1px solid var(--form-border-color);
    border-radius: 6px;
    background: var(--form-bg-color);
    color: var(--form-text-color);
    font-size: 0.9em;
}

.btn-add-url {
    padding: 8px 12px;
    border: none;
    border-radius: 6px;
    background: var(--btn-secondary-bg);
    color: var(--btn-secondary-text);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* 이미지 그리드 */
.thread-image-grid {
    display: grid;
    gap: 4px;
    margin-bottom: 8px;
}

.thread-image-grid.grid-1 {
    grid-template-columns: 1fr;
}

.thread-image-grid.grid-2 {
    grid-template-columns: 1fr 1fr;
}

.thread-image-grid.grid-3 {
    grid-template-columns: 1fr 1fr;
}

.thread-image-grid.grid-3 .thread-image-item:nth-child(3) {
    grid-column: span 2;
}

.thread-image-grid.grid-4 {
    grid-template-columns: 1fr 1fr;
}

.thread-image-item {
    position: relative;
    border-radius: 6px;
    overflow: hidden;
    aspect-ratio: 1;
}

.thread-image-grid.grid-1 .thread-image-item {
    aspect-ratio: 16/9;
}

.thread-image-grid.grid-3 .thread-image-item:nth-child(3) {
    aspect-ratio: 2/1;
}

.thread-image-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* 타래 이미지 그리드 (답글용) */
.reply-image-grid {
    display: grid;
    gap: 4px;
    margin: 10px 0;
    border-radius: 12px;
    overflow: hidden;
}
.reply-image-grid.grid-1 {
    grid-template-columns: 1fr;
}
.reply-image-grid.grid-2 {
    grid-template-columns: 1fr 1fr;
}
.reply-image-grid.grid-3 {
    grid-template-columns: 1fr 1fr;
}
.reply-image-grid.grid-3 .reply-image-item:nth-child(3) {
    grid-column: span 2;
}
.reply-image-grid.grid-4 {
    grid-template-columns: 1fr 1fr;
}
.reply-image-item {
    position: relative;
    height: 150px;
    overflow: hidden;
}

.reply-image-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    cursor: pointer;
    transition: transform 0.2s;
}
.reply-image-item img:hover {
    transform: scale(1.02);
}

.btn-remove-img {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    border: none;
    background: rgba(220, 38, 38, 0.9);
    color: #fff;
    cursor: pointer;
    opacity: 0;
    transition: opacity 0.2s;
}

.thread-image-item:hover .btn-remove-img {
    opacity: 1;
}

.thread-content-area {
    margin-bottom: 8px;
}

.thread-textarea {
    width: 100%;
    padding: 10px;
    border: 1px solid var(--form-border-color);
    border-radius: 6px;
    background: var(--form-bg-color);
    color: var(--form-text-color);
    resize: none;
    font-size: 1em;
    line-height: 1.5;
}

.thread-options {
    display: flex;
    gap: 12px;
    margin-bottom: 8px;
    font-size: 12px;
    color: var(--text-muted-color, #888);
}

.thread-options label {
    display: flex;
    align-items: center;
    gap: 4px;
    cursor: pointer;
}

.thread-submit {
    display: flex;
    justify-content: flex-end;
}

.btn-thread-submit {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 8px 16px;
    border: none;
    border-radius: 6px;
    background: var(--btn-accent-bg);
    color: var(--btn-accent-text);
    cursor: pointer;
    font-size: 1em;
}

.btn-thread-submit:hover {
    opacity: 0.9;
}

/* ========================================
   인라인 수정 폼
   ======================================== */

.reply-edit-form {
    padding: 10px 0;
}
.reply-edit-textarea {
    width: 100%;
    min-height: 60px;
    padding: 10px;
    border: 1px solid var(--form-border-color);
    border-radius: 8px;
    background: var(--form-bg-color);
    color: var(--form-text-color);
    font-size: 1em;
    resize: vertical;
    box-sizing: border-box;
}
.reply-edit-options {
    display: flex;
    gap: 10px;
    margin-top: 8px;
    font-size: 12px;
}
.reply-edit-options label {
    display: flex;
    align-items: center;
    gap: 3px;
    cursor: pointer;
}
.reply-edit-buttons {
    display: flex;
    gap: 5px;
    margin-top: 8px;
    justify-content: flex-end;
}
.reply-edit-buttons button {
    padding: 5px 12px;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    font-size: 12px;
}
.btn-reply-save {
    background: var(--primary-color);
    color: white;
}
.btn-reply-cancel {
    background: var(--color-5);
    color: var(--content-font-color);
}

/* 인라인 수정 이미지 업로드 */
.reply-edit-upload-toggle {
    margin-bottom: 5px;
}
.reply-edit-upload-toggle a {
    font-size: 12px;
    color: var(--content-font-color);
    opacity: 0.7;
}
.reply-edit-upload-toggle a:hover {
    opacity: 1;
}
.reply-edit-upload-area {
    border-radius: 8px;
}
.reply-edit-existing-files {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 10px;
}
.existing-file-item {
    position: relative;
    width: 60px;
    height: 60px;
    border-radius: 6px;
    overflow: hidden;
}
.existing-file-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.existing-file-item .file-del-check {
    position: absolute;
    top: 2px;
    right: 2px;
    width: 20px;
    height: 20px;
    background: rgba(0,0,0,0.6);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}
.existing-file-item .file-del-check input {
    display: none;
}
.existing-file-item .file-del-check i {
    font-size: 10px;
    color: #fff;
    opacity: 0.5;
}
.existing-file-item .file-del-check:has(input:checked) {
    background: var(--danger-color, #dc3545);
}
.existing-file-item .file-del-check:has(input:checked) i {
    opacity: 1;
}
.reply-edit-dropzone {
    padding: 15px;
    text-align: center;
    border: 2px dashed var(--accent-color);
    border-radius: 6px;
    cursor: pointer;
    font-size: 12px;
    color: var(--content-font-color);
    opacity: 0.6;
    transition: all 0.2s;
}
.reply-edit-dropzone:hover,
.reply-edit-dropzone.dragover {
    border-color: var(--primary-color);
    opacity: 1;
}
.reply-edit-dropzone i {
    display: block;
    font-size: 20px;
    margin-bottom: 5px;
}
.reply-edit-url-input {
    display: flex;
    gap: 5px;
    margin-top: 8px;
}
.reply-edit-url-input input {
    flex: 1;
    padding: 6px 10px;
    border: 1px solid var(--form-border-color);
    border-radius: 5px;
    font-size: 12px;
    background: var(--form-bg-color);
    color: var(--form-text-color);
}
.reply-edit-url-input button {
    padding: 6px 10px;
    border: none;
    border-radius: 5px;
    background: var(--primary-color);
    color: white;
    cursor: pointer;
}
.reply-edit-image-grid {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 10px;
}
.reply-edit-image-item {
    position: relative;
    width: 60px;
    height: 60px;
    border-radius: 6px;
    overflow: hidden;
}
.reply-edit-image-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.reply-edit-image-item .btn-remove-img {
    position: absolute;
    top: 2px;
    right: 2px;
    width: 18px;
    height: 18px;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: rgba(0,0,0,0.6);
    color: white;
    font-size: 10px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}
.reply-edit-image-item .btn-remove-img:hover {
    background: var(--danger-color, #dc3545);
}

/* 개별 답글 댓글 작성 컨테이너 */
.reply-comment-write-container {
    margin: 10px 0;
    padding: 0 10px;
}

/* Hallmark · timememo board skin
 * Reading this as: personal-home timeline/memo surface for repeat writing, with a quiet archive-tool language.
 * Palette source: RA0 default.css.php root variables.
 */
.timememo-shell,
.timememo-shell * {
    box-sizing: border-box;
}

.timememo-shell,
.timememo-dock,
#imageModal {
    --tmemo-surface: color-mix(in srgb, var(--card-bg-color) 92%, var(--bg-color));
    --tmemo-surface-soft: color-mix(in srgb, var(--container-bg-color) 88%, var(--card-bg-color));
    --tmemo-line: color-mix(in srgb, var(--card-border-color) 76%, transparent);
    --tmemo-muted: color-mix(in srgb, var(--content-font-color) 62%, transparent);
    --tmemo-accent: var(--primary-color);
}

.timememo-shell {
    width: min(100%, 1000px);
    margin: 0 auto;
    padding: var(--spacing-lg);
    display: grid;
    grid-template-columns: 260px minmax(0, 1fr);
    gap: var(--spacing-lg);
    color: var(--content-font-color);
    font-family: var(--content-font-family);
}

.timememo-shell.has-side {
    grid-template-columns: 260px minmax(0, 1fr);
}

.timememo-side {
    position: sticky;
    top: var(--spacing-lg);
    align-self: start;
    max-height: calc(100dvh - var(--spacing-lg) * 2);
    overflow: auto;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    min-width: 0;
}

.timememo-main {
    grid-column: 2;
    min-width: 0;
}

.timememo-card {
    position: relative;
    background: var(--tmemo-surface);
    border: 1px solid var(--tmemo-line);
    border-radius: min(var(--card-border-radius), 8px);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-sm);
}

.timememo-notice {
    padding-bottom: calc(var(--spacing-lg) + 8px);
}

.timememo-notice-version {
    position: absolute;
    right: var(--spacing-md);
    bottom: var(--spacing-sm);
    color: var(--title-font-color);
    font-size: 0.7em;
    letter-spacing: 0;
    line-height: 1;
    opacity: 0.2;
    pointer-events: none;
    user-select: none;
}

.timememo-card strong {
    display: block;
    margin-bottom: var(--spacing-sm);
    color: var(--title-font-color);
    font-family: var(--title-font-family);
    font-size: 12px;
    letter-spacing: 0;
}

.timememo-card p,
.timememo-card div,
.timememo-card li {
    font-size: 13px;
    line-height: 1.7;
}

.timememo-category-bar {
    margin: calc(var(--spacing-md) * -0.25) 0 var(--spacing-md);
}

.timememo-category-bar ul,
.timememo-archive ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.timememo-category-bar ul {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.timememo-category-bar li {
    display: inline-flex;
}

.timememo-category-bar .sound_only {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.timememo-category-bar li a,
.timememo-category-bar li span,
.timememo-category-bar li strong,
.timememo-archive a {
    min-height: 26px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    border: 1px solid var(--tmemo-line);
    border-radius: 999px;
    background: color-mix(in srgb, var(--tmemo-surface-soft) 72%, transparent);
    padding: 0 10px;
    color: var(--tmemo-muted);
    text-decoration: none;
    font-size: 12px;
    line-height: 1;
    backdrop-filter: blur(5px);
}

.timememo-category-bar li a:hover,
.timememo-category-bar li .on,
.timememo-category-bar li.active a,
.timememo-archive a:hover {
    border-color: color-mix(in srgb, var(--tmemo-accent) 42%, var(--tmemo-line));
    background: color-mix(in srgb, var(--tmemo-accent) 10%, var(--tmemo-surface));
    color: var(--content-font-color);
}

.timememo-category-bar #bo_cate_on {
  background: var(--btn-primary-bg);
  color: var(--btn-primary-text);
}

.timememo-archive a span {
    color: var(--tmemo-accent);
    font-weight: 700;
}

.timememo-archive a em {
    font-style: normal;
    color: var(--tmemo-muted);
}

.timememo-view-switch {
    flex: 0 0 auto;
    width: 86px;
    height: 34px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    overflow: hidden;
    background: var(--tmemo-surface);
    border: 1px solid var(--tmemo-line);
    border-radius: min(var(--card-border-radius), 8px);
}

.timememo-view-switch a,
.timememo-icon-btn,
.timememo-mobile-media,
.timememo-tool-btn,
.timememo-dock-toggle {
    appearance: none;
    border: 0;
    min-width: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    color: var(--content-font-color);
    background: var(--tmemo-surface);
    cursor: pointer;
    transition: background var(--motion-duration-fast) var(--motion-ease), color var(--motion-duration-fast) var(--motion-ease), transform var(--motion-duration-fast) var(--motion-ease);
}

.timememo-view-switch a + a {
    border-left: 1px solid var(--tmemo-line);
}

.timememo-icon-btn {
    height: 46px;
    border: 1px solid var(--tmemo-line);
    border-radius: min(var(--card-border-radius), 8px);
}

.timememo-view-switch a.active,
.timememo-icon-btn.active,
.timememo-mobile-media.active {
    background: var(--tmemo-accent);
    color: var(--btn-primary-text);
}

.timememo-topbar {
    margin-bottom: var(--spacing-md);
    padding: 0;
    background: transparent;
    border: 0;
    border-radius: 0;
    display: flex;
    gap: var(--spacing-md);
    align-items: center;
}

.timememo-search {
    flex: 1;
    min-width: 0;
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 34px 34px;
    gap: 6px;
    align-items: center;
    background: transparent;
    border: 0;
    border-radius: 0;
}

.timememo-search-field {
    min-width: 0;
    height: 34px;
    display: grid;
    grid-template-columns: 30px minmax(0, 1fr);
    align-items: center;
    background: var(--form-bg-color);
    border: 1px solid var(--form-border-color);
    border-radius: min(var(--form-border-radius), 7px);
    overflow: hidden;
}

.timememo-search label {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--tmemo-muted);
    background: transparent;
    border: 0;
}

.timememo-search button {
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--tmemo-muted);
    background: var(--tmemo-surface);
    border: 1px solid var(--tmemo-line);
    border-radius: min(var(--btn-secondary-radius), 7px);
}

.timememo-search input {
    width: 100%;
    min-width: 0;
    height: 100%;
    border: 0;
    background: transparent;
    color: var(--form-text-color);
    outline: none;
}

.timememo-date-toggle.active {
    color: var(--tmemo-accent);
}

.timememo-date-popover {
    display: none;
    position: absolute;
    z-index: 30;
    top: calc(100% + 8px);
    right: 40px;
    width: min(280px, 80vw);
    padding: var(--spacing-sm);
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-sm);
    border: 1px solid var(--tmemo-line);
    border-radius: min(var(--card-border-radius), 8px);
    background: var(--tmemo-surface);
    box-shadow: var(--shadow-md);
}

.timememo-date-popover.is-open {
    display: grid;
}

.timememo-date-popover input[type="date"] {
    min-width: 0;
    height: 34px;
    border: 1px solid var(--form-border-color);
    border-radius: min(var(--form-border-radius), 7px);
    background: var(--form-bg-color);
    color: var(--form-text-color);
    padding: 0 var(--spacing-sm);
    font-size: 12px;
}

.timememo-search-field:focus-within {
    border-color: var(--tmemo-accent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--tmemo-accent) 18%, transparent);
}

.timememo-mobile-media {
    display: none;
    gap: 6px;
    min-height: 44px;
    padding: 0 var(--spacing-md);
    border: 1px solid var(--tmemo-line);
    border-radius: min(var(--btn-secondary-radius), 7px);
}

.timememo-list-wrap {
    padding: 0;
    background: transparent;
}

.timememo-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.timememo-list.is-media-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(154px, 1fr));
    gap: var(--spacing-sm);
}

.timememo-media-item {
    min-width: 0;
    margin: 0;
    position: relative;
    overflow: hidden;
    border: 1px solid var(--tmemo-line);
    border-radius: min(var(--card-border-radius), 8px);
    background: var(--tmemo-surface);
}

.timememo-media-item button {
    display: block;
    width: 100%;
    aspect-ratio: 1;
    padding: 0;
    border: 0;
    background: transparent;
    cursor: pointer;
}

.timememo-media-item img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.timememo-media-item figcaption {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    padding: 18px 9px 8px;
    color: #fff;
    font-size: 12px;
    line-height: 1.3;
    background: linear-gradient(to top, rgba(0, 0, 0, .62), transparent);
    opacity: 0;
    transition: opacity var(--motion-duration-fast) var(--motion-ease);
}

.timememo-media-item:hover figcaption {
    opacity: 1;
}

.timememo-dayline {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    color: var(--tmemo-muted);
    font-size: 12px;
    justify-content: center;
}

.timememo-dayline::before,
.timememo-dayline::after {
    content: "";
    flex: 1;
    height: 1px;
    background: var(--tmemo-line);
}

.timememo-thread-card.main-container {
    width: 100% !important;
    max-width: none !important;
    margin: 0;
    background: var(--tmemo-surface);
    border: 1px solid var(--tmemo-line);
    border-radius: min(var(--card-border-radius), 8px);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
}

.timememo-thread-card.notice {
    border-color: color-mix(in srgb, var(--accent-color) 72%, var(--tmemo-line));
}

.timememo-thread-card .content-wrapper {
    padding: var(--spacing-lg);
}

.timememo-thread-card .user-info {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.timememo-thread-card .profile-pic, .timememo-thread-card .profile-pic-img, .timememo-thread-card .member-icon {
  width: 28px;
  height: 28px;
  display: flex;
  border-radius: 50%;
  align-items: center;
  justify-content: center;
}

.timememo-thread-card .profile-pic-img {
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: color-mix(in srgb, var(--secondary-color) 25%, transparent);
  border: 2px solid color-mix(in srgb, var(--primary-color) 70%, transparent);
}

.timememo-thread-card .profile-pic-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.timememo-thread-card .user-details {
    min-width: 0;
    display: flex;
    align-items: baseline;
    gap: var(--spacing-xs);
    flex-wrap: wrap;
}

.timememo-thread-card .nick {
    font-weight: 700;
}

.timememo-thread-card .id,
.timememo-thread-card .content-date {
    color: var(--tmemo-muted);
    font-size: 10px;
}

.timememo-thread-card .user-details .category {
    min-height: 18px;
    display: inline-flex;
    align-items: center;
    border: 1px solid color-mix(in srgb, var(--tmemo-accent) 28%, var(--tmemo-line));
    border-radius: 999px;
    background: color-mix(in srgb, var(--tmemo-accent) 8%, var(--tmemo-surface-soft));
    padding: 0 6px;
    color: color-mix(in srgb, var(--content-font-color) 78%, var(--tmemo-accent));
    font-size: 10px;
    line-height: 1;
    font-weight: 600;
}

.timememo-thread-card .timememo-entry-tools {
    margin-left: auto;
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.timememo-thread-card .md-btn {
    display: flex;
    gap: var(--spacing-xs);
}

.timememo-thread-card .md-btn a,
.timememo-thread-card .comment-btn a,
.timememo-thread-card .comment-btn button {
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--content-font-color);
    text-decoration: none;
}

.timememo-thread-card .notice-option label {
  display: inline-flex;
  min-height: 24px;
  align-items: center;
  font-weight: 500;
}

.timememo-thread-card .loadboard_content {
    font-size: var(--content-font-size);
    line-height: 1.85;
}

.timememo-thread-card .post-card {
    display: flex;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    overflow: hidden;
    white-space: normal;
}

.timememo-thread-card .post-card-body {
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
}

.timememo-thread-card .post-card-title,
.timememo-thread-card .post-card-excerpt,
.timememo-thread-card .post-card-meta {
    display: block;
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-word;
    white-space: normal;
}

.timememo-thread-card .loadboard_content .hashtag,
.timememo-thread-card .reply-content .hashtag {
    display: inline-flex;
    align-items: center;
    max-width: 100%;
    min-height: 22px;
    margin: 0 2px;
    padding: 0 7px;
    border: 1px solid color-mix(in srgb, var(--tmemo-accent) 34%, var(--tmemo-line));
    border-radius: 999px;
    background: color-mix(in srgb, var(--tmemo-accent) 8%, var(--tmemo-surface-soft));
    color: color-mix(in srgb, var(--content-font-color) 82%, var(--tmemo-accent));
    box-shadow: none;
    filter: none;
    font-size: .86em;
    line-height: 1;
    text-decoration: none;
    vertical-align: baseline;
    overflow-wrap: anywhere;
    white-space: normal;
    transition: border-color var(--motion-duration-fast) var(--motion-ease), background var(--motion-duration-fast) var(--motion-ease), color var(--motion-duration-fast) var(--motion-ease);
}

.timememo-thread-card .loadboard_content .hashtag:hover,
.timememo-thread-card .reply-content .hashtag:hover {
    border-color: color-mix(in srgb, var(--tmemo-accent) 62%, var(--tmemo-line));
    background: color-mix(in srgb, var(--tmemo-accent) 15%, var(--tmemo-surface));
    color: var(--content-font-color);
    filter: none;
}

.timememo-post-title {
    margin-bottom: var(--spacing-md);
    color: var(--title-font-color);
    font-family: var(--title-font-family);
    font-size: clamp(18px, 2vw, 22px);
    line-height: 1.45;
    letter-spacing: 0;
}

.timememo-thread-card .timememo-reply-extra {
    display: none;
}

.timememo-thread-card.reply-opened .timememo-reply-extra {
    display: block;
}

.timememo-thread-card.reply-opened .timememo-reply-preview {
    display: none;
}

.timememo-reply-preview[hidden],
.timememo-reply-full[hidden] {
    display: none !important;
}

.timememo-reply-more-bottom {
  padding: var(--spacing-xs);
}

.timememo-reply-more-bottom .reply-list-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgb(from var(--content-font-color) r g b / 0.6);
  font-size: 0.9em;
  text-decoration: none;
}

.timememo-thread-card.reply-opened .timememo-reply-more-bottom {
    display: none;
}

.timememo-auto-images {
    width: 100%;
    margin: 0 0 var(--spacing-md);
    overflow: hidden;
    border-radius: min(var(--card-border-radius), 8px);
}

.timememo-auto-images.grid-single {
    display: block;
}

.timememo-auto-images.grid-multi {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 4px;
}

.timememo-auto-image {
    width: 100%;
    display: block;
    padding: 0;
    border: 0;
    background: transparent;
    cursor: pointer;
}

.timememo-auto-images.grid-multi .timememo-auto-image {
    aspect-ratio: 2;
}

.timememo-auto-image img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

.timememo-auto-images.grid-multi .timememo-auto-image img {
    height: 100%;
}

.timememo-thread-card .loadboard_content img,
.timememo-thread-card .reply-content img,
.timememo-thread-card .content-image {
    border-radius: min(var(--card-border-radius), 7px);
    border: 1px solid var(--tmemo-line);
}

.timememo-thread-card .post-content.is-collapsed .actual-content {
    display: none;
}

.timememo-thread-card .post-content.is-collapsed::after {
    content: "접힌 본문입니다.";
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    color: var(--tmemo-muted);
    font-size: 12px;
}

.timememo-thread-card .post-content.is-expanded .actual-content {
    display: block;
}

.timememo-post-toggle {
    width: 24px;
    height: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-left: var(--spacing-xs);
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--tmemo-muted);
    padding: 0;
    font-size: 11px;
    cursor: pointer;
}

.timememo-post-toggle:hover,
.timememo-post-toggle:focus-visible {
    background: color-mix(in srgb, var(--tmemo-accent) 10%, transparent);
    color: var(--content-font-color);
}

.timememo-thread-card .reply-content.is-collapsed {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-xs) 0;
}

.timememo-thread-card .reply-content.is-collapsed .reply-actual-content {
    display: none;
}

.timememo-thread-card .reply-content.is-collapsed::before {
    content: "접힌 답글입니다.";
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    color: var(--tmemo-muted);
    font-size: 12px;
}

.timememo-thread-card .reply-content.is-expanded {
    max-height: none;
    overflow: visible;
    padding-bottom: 0;
}

.timememo-thread-card .reply-content.is-expanded .reply-actual-content {
    display: block;
}

.timememo-reply-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    width: 24px;
    height: 24px;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--tmemo-muted);
    padding: 0;
    font-size: 11px;
    cursor: pointer;
}

.timememo-reply-toggle:hover,
.timememo-reply-toggle:focus-visible {
    background: color-mix(in srgb, var(--tmemo-accent) 10%, transparent);
    color: var(--content-font-color);
}

.timememo-thread-card .reply-content.is-expanded .timememo-reply-toggle {
    margin-top: var(--spacing-xs);
    margin-left: 0;
}

.timememo-thread-card .comment-wrapper {
    border-top: 1px solid var(--tmemo-line);
    background: color-mix(in srgb, var(--tmemo-surface-soft) 80%, transparent);
}

.timememo-thread-card .comment-btn {
    padding: var(--spacing-xs) var(--spacing-lg);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-sm);
}

.timememo-thread-card .comment.btn,
.timememo-thread-card .comment.btn.r {
    display: flex;
    gap: var(--spacing-xs);
    align-items: center;
}

.timememo-thread-card .like_area {
    display: inline-flex;
    align-items: center;
    gap: 0;
    overflow: hidden;
}

.timememo-thread-card .like_area .like_btn {
    border: 0;
    background: transparent;
}

.timememo-thread-card .like_number,
.timememo-thread-card .comment-count {
    min-width: 12px;
    height: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    color: var(--tmemo-muted);
    font-size: 11px;
    line-height: 1;
}

.timememo-thread-card .like_number:empty {
    display: none;
}

.timememo-thread-card .timememo-reply-count {
    gap: 4px;
    width: auto;
    min-width: 38px;
    padding: 0 8px;
}

.secret-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-sm);
  color: var(--content-font-color);
  margin: 10px auto;
}

.secret-container h3 {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    margin: 0;
    color: var(--title-font-color);
    font-size: 16px;
    line-height: 1.35;
}

.secret-container p {
    margin: 0;
    color: var(--tmemo-muted);
    font-size: 13px;
    line-height: 1.6;
}

.secret-container form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: var(--spacing-sm);
    align-items: center;
    margin-top: var(--spacing-xs);
}

.secret-container input {
    width: 100%;
    min-width: 0;
    height: 38px;
    border: 1px solid var(--form-border-color);
    background: var(--form-bg-color);
    color: var(--form-text-color);
    border-radius: min(var(--form-border-radius), 7px);
    padding: 0 var(--spacing-md);
}

.secret-container button {
    min-width: 68px;
    height: 38px;
    border: 0;
    border-radius: min(var(--btn-primary-radius), 7px);
    background: var(--btn-primary-bg);
    color: var(--btn-primary-text);
    padding: 0 var(--spacing-lg);
    cursor: pointer;
}

.reply-secret-container {
    margin: var(--spacing-sm) 0;
    padding: var(--spacing-md);
    border: 1px solid var(--tmemo-line);
    border-radius: min(var(--card-border-radius), 8px);
    background: color-mix(in srgb, var(--tmemo-surface-soft) 80%, transparent);
    text-align: left;
}

.reply-secret-container form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: var(--spacing-sm);
    align-items: center;
}

.reply-secret-container input[type="password"] {
    width: 100%;
    min-width: 0;
    height: 34px;
    padding: 0 var(--spacing-sm);
    border: 1px solid var(--form-border-color);
    border-radius: min(var(--form-border-radius), 7px);
    background: var(--form-bg-color);
    color: var(--form-text-color);
}

.reply-secret-container button {
    height: 34px;
    padding: 0 var(--spacing-md);
    border: 0;
    border-radius: min(var(--btn-primary-radius), 7px);
    background: var(--btn-primary-bg);
    color: var(--btn-primary-text);
    cursor: pointer;
}

.timememo-accordion-toggle {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-sm);
    padding: 0;
    border: 0;
    background: transparent;
    color: inherit;
    cursor: pointer;
    text-align: left;
}

.timememo-accordion-toggle strong {
    margin-bottom: 0;
}

.timememo-accordion-toggle i {
    color: var(--tmemo-muted);
    font-size: 11px;
}

.timememo-accordion-panel {
    margin-top: var(--spacing-sm);
}

.timememo-accordion:not(.is-open) .timememo-accordion-panel,
.timememo-accordion-panel.is-hidden {
    display: none !important;
}

.timememo-tags .timememo-accordion-panel {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.timememo-tags .timememo-tag-extra {
    display: none;
}

.timememo-tags.is-expanded .timememo-tag-extra {
    display: inline-flex;
}

.timememo-tags-more {
    width: 100%;
    border: 1px solid var(--tmemo-line);
    border-radius: min(var(--btn-secondary-radius), 7px);
    background: var(--tmemo-surface-soft);
    color: var(--tmemo-muted);
    margin-top: 2px;
    min-height: 28px;
    font-size: 11px;
    cursor: pointer;
}

.timememo-tags a {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 0 8px;
    border: 1px solid transparent;
    border-radius: 999px;
    background: color-mix(in srgb, var(--tmemo-surface-soft) 76%, transparent);
    color: var(--tmemo-muted);
    text-decoration: none;
    font-size: 11px;
    line-height: 1;
    transition: border-color var(--motion-duration-fast) var(--motion-ease), color var(--motion-duration-fast) var(--motion-ease), background var(--motion-duration-fast) var(--motion-ease);
}

.timememo-tags a:hover,
.timememo-tags a.is-active {
    border-color: color-mix(in srgb, var(--tmemo-accent) 45%, var(--tmemo-line));
    background: color-mix(in srgb, var(--tmemo-accent) 10%, var(--tmemo-surface));
    color: var(--content-font-color);
}

.timememo-memo-item + .timememo-memo-item,
.timememo-memos p + p {
    margin-top: var(--spacing-xs);
}

.timememo-memo-item {
    position: relative;
    padding-right: 34px;
}

.timememo-memo-item p {
    margin: 0;
}

.timememo-memo-actions {
    position: absolute;
    top: var(--spacing-xs);
    right: 0;
    display: inline-flex;
    gap: 5px;
    opacity: 0;
    transition: opacity var(--motion-duration-fast) var(--motion-ease);
}

.timememo-memo-item:hover .timememo-memo-actions {
    opacity: .55;
}

.timememo-memo-actions a {
    width: 16px;
    height: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    background: transparent;
    color: var(--tmemo-muted);
    text-decoration: none;
    font-size: 10px;
}

.timememo-memo-actions a:hover {
    color: var(--content-font-color);
}

.timememo-empty {
    padding: var(--spacing-2xl);
    text-align: center;
    background: var(--tmemo-surface);
    border: 1px solid var(--tmemo-line);
    border-radius: min(var(--card-border-radius), 8px);
    color: var(--tmemo-muted);
}

.timememo-dock {
    position: fixed;
    z-index: 60;
    bottom: var(--spacing-md);
    right: max(var(--spacing-md), calc((100vw - 1000px) / 2 + var(--spacing-lg)));
    width: 48px;
    margin: 0;
    pointer-events: none;
}

.timememo-dock-toggle {
    position: relative;
    z-index: 2;
    pointer-events: auto;
    width: 48px;
    height: 48px;
    margin: 0;
    border-radius: 50%;
    background: var(--btn-primary-bg);
    color: var(--btn-primary-text);
    box-shadow: var(--shadow-md);
}

.timememo-write-panel {
    position: absolute;
    right: calc(100% + var(--spacing-sm));
    bottom: 0;
    pointer-events: auto;
    display: none;
    width: min(620px, calc(100vw - 96px));
    max-height: min(76dvh, 640px);
    overflow: auto;
    margin: 0;
    padding: var(--spacing-lg);
    background: var(--tmemo-surface);
    border: 1px solid var(--tmemo-line);
    border-radius: min(var(--card-border-radius), 8px);
    box-shadow: var(--shadow-lg);
    color: var(--content-font-color);
    font-family: var(--content-font-family);
}

.timememo-dock.is-open .timememo-write-panel {
    display: block;
}

.timememo-write-type {
    display: inline-flex;
    padding: 4px;
    border: 1px solid var(--tmemo-line);
    border-radius: min(var(--btn-secondary-radius), 7px);
    margin-bottom: var(--spacing-md);
}

.timememo-write-type label {
    cursor: pointer;
}

.timememo-write-type input {
    position: absolute;
    opacity: 0;
}

.timememo-write-type span {
    min-width: 54px;
    min-height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: min(var(--btn-secondary-radius), 6px);
    font-size: 13px;
}

.timememo-write-type input:checked + span {
    background: var(--tmemo-accent);
    color: var(--btn-primary-text);
}

.timememo-write-grid {
    display: block;
    margin-bottom: var(--spacing-sm);
}

.timememo-write-grid.has-category {
    display: grid;
    grid-template-columns: minmax(130px, 170px) minmax(0, 1fr);
    gap: var(--spacing-sm);
}

.timememo-write-grid select,
.timememo-write-grid input,
.timememo-write-panel textarea {
    width: 100%;
    min-width: 0;
    border: 1px solid var(--form-border-color);
    border-radius: min(var(--form-border-radius), 7px);
    background: var(--form-bg-color);
    color: var(--form-text-color);
    padding: 0 var(--spacing-md);
    font-family: var(--content-font-family);
}

.timememo-secret-password {
    display: none;
    flex: 0 1 200px;
    max-width: 200px;
    min-width: 150px;
}

.timememo-secret-password.is-open {
    display: block;
}

.timememo-secret-password input {
    width: 100%;
    min-height: 38px;
    border: 1px solid var(--form-border-color);
    border-radius: min(var(--form-border-radius), 7px);
    background: var(--form-bg-color);
    color: var(--form-text-color);
    padding: 0 var(--spacing-md);
}

.timememo-media-panel {
    display: none;
    margin-top: var(--spacing-sm);
    padding: var(--spacing-sm);
    border: 1px solid var(--tmemo-line);
    border-radius: min(var(--card-border-radius), 8px);
    background: color-mix(in srgb, var(--form-bg-color) 74%, transparent);
}

.timememo-media-panel.is-open,
.timememo-media-panel:focus-within {
    display: block;
}

.timememo-media-file-input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.timememo-media-dropzone {
    width: 100%;
    min-height: 86px;
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr);
    grid-template-rows: auto auto;
    column-gap: var(--spacing-sm);
    row-gap: 2px;
    align-items: center;
    margin: 0 0 var(--spacing-sm);
    padding: var(--spacing-md);
    border: 1px dashed color-mix(in srgb, var(--tmemo-accent) 45%, var(--tmemo-line));
    border-radius: min(var(--card-border-radius), 8px);
    background: color-mix(in srgb, var(--tmemo-accent) 7%, var(--tmemo-surface));
    color: var(--content-font-color);
    text-align: left;
    cursor: pointer;
}

.timememo-media-dropzone i {
    grid-row: 1 / span 2;
    width: 34px;
    height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: var(--tmemo-accent);
    color: var(--btn-primary-text);
}

.timememo-media-dropzone span {
    font-weight: 700;
}

.timememo-media-dropzone em {
    color: var(--tmemo-muted);
    font-size: 12px;
    font-style: normal;
    line-height: 1.45;
}

.timememo-media-dropzone:hover,
.timememo-media-dropzone:focus-visible,
.timememo-media-dropzone.is-dragover {
    border-color: var(--tmemo-accent);
    background: color-mix(in srgb, var(--tmemo-accent) 12%, var(--tmemo-surface));
}

.timememo-url-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 38px;
    gap: var(--spacing-sm);
}

.timememo-url-row input {
    width: 100%;
    min-width: 0;
    height: 38px;
    border: 1px solid var(--form-border-color);
    border-radius: min(var(--form-border-radius), 7px);
    background: var(--form-bg-color);
    color: var(--form-text-color);
    padding: 0 var(--spacing-md);
}

.timememo-url-row button {
    border: 1px solid var(--tmemo-line);
    border-radius: min(var(--btn-secondary-radius), 7px);
    background: var(--tmemo-surface);
    color: var(--content-font-color);
}

.timememo-media-note {
    margin: 7px 0 0;
    color: var(--tmemo-muted);
    font-size: 12px;
    line-height: 1.45;
}

.timememo-media-preview {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(64px, 1fr));
    gap: var(--spacing-sm);
    margin-top: var(--spacing-sm);
}

.timememo-preview-item {
    position: relative;
    aspect-ratio: 1;
    min-width: 0;
    padding: 0;
    overflow: hidden;
    border: 1px solid var(--tmemo-line);
    border-radius: min(var(--card-border-radius), 7px);
    background: var(--tmemo-surface-soft);
    cursor: pointer;
}

.timememo-preview-item img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.timememo-preview-item span,
.timememo-preview-item em {
    position: absolute;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
}

.timememo-preview-item span {
    top: 4px;
    right: 4px;
    width: 20px;
    height: 20px;
    background: rgba(0, 0, 0, .58);
    color: #fff;
    font-size: 11px;
}

.timememo-preview-item em {
    left: 4px;
    bottom: 4px;
    width: 20px;
    height: 20px;
    background: var(--tmemo-accent);
    color: var(--btn-primary-text);
    font-size: 10px;
    font-style: normal;
}

.timememo-preview-item.is-broken img {
    display: none;
}

.timememo-preview-item.is-broken::before {
    content: "URL";
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--tmemo-muted);
    font-size: 12px;
    font-weight: 700;
}


#imageModal {
    display: none;
    position: fixed;
    inset: 0;
    width: 100vw;
    height: 100vh;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, .84);
    z-index: 9999;
}

#imageModal .modal-content {
    max-width: 92vw;
    max-height: 92vh;
    border: 0;
    border-radius: min(var(--card-border-radius), 8px);
}

#imageModal .close,
#imageModal .prev,
#imageModal .next {
    position: absolute;
    color: #fff;
    font-size: 30px;
    line-height: 1;
    cursor: pointer;
    user-select: none;
}

#imageModal .close {
    top: 20px;
    right: 28px;
}

#imageModal .prev {
    left: 20px;
    top: 50%;
    transform: translateY(-50%);
}

#imageModal .next {
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
}

.timememo-write-grid select,
.timememo-write-grid input {
    height: 40px;
}

.timememo-write-panel textarea {
    min-height: 112px;
    padding-top: var(--spacing-md);
    padding-bottom: var(--spacing-md);
    resize: vertical;
}

.timememo-write-actions {
    margin-top: var(--spacing-sm);
    display: flex;
    gap: var(--spacing-sm);
    align-items: center;
    flex-wrap: wrap;
}

.timememo-dock:not(.is-comment-mode) .timememo-comment-only,
.timememo-dock.is-comment-mode .timememo-root-only,
.timememo-dock.is-comment-mode .timememo-root-only-control {
    display: none;
}

.timememo-tool-btn {
    width: 38px;
    height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--tmemo-line);
    border-radius: min(var(--btn-secondary-radius), 7px);
    background: var(--tmemo-surface);
    color: var(--content-font-color);
    cursor: pointer;
    padding: 0;
    transition: border-color var(--motion-duration-fast) var(--motion-ease), background var(--motion-duration-fast) var(--motion-ease), color var(--motion-duration-fast) var(--motion-ease);
}

.timememo-tool-btn input[type="file"],
.timememo-tool-btn input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.timememo-tool-btn:has(input:checked) {
    background: var(--tmemo-accent);
    color: var(--btn-primary-text);
}

.timememo-tool-btn[aria-expanded="true"],
.timememo-tool-btn:hover,
.timememo-tool-btn:focus-visible {
    border-color: color-mix(in srgb, var(--tmemo-accent) 45%, var(--tmemo-line));
    background: color-mix(in srgb, var(--tmemo-accent) 10%, var(--tmemo-surface));
}

.timememo-submit {
    margin-left: auto;
    min-height: 38px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border: 0;
    border-radius: 999px;
    background: var(--btn-primary-bg);
    color: var(--btn-primary-text);
    padding: 0 16px;
    font-weight: 700;
    box-shadow: none;
}

.timememo-toast {
    position: fixed;
    left: 50%;
    bottom: calc(var(--spacing-lg) + 10px);
    z-index: 9999;
    max-width: min(380px, calc(100vw - var(--spacing-lg) * 2));
    min-height: 46px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    transform: translate(-50%, 14px) scale(0.98);
    opacity: 0;
    pointer-events: none;
    padding: 12px 16px;
    border: 2px solid color-mix(in srgb, var(--tmemo-accent) 72%, #fff);
    border-radius: min(var(--card-border-radius), 8px);
    background: color-mix(in srgb, var(--tmemo-accent) 18%, var(--tmemo-surface));
    color: var(--title-font-color);
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.22), 0 0 0 4px color-mix(in srgb, var(--tmemo-accent) 14%, transparent);
    font-size: 14px;
    font-weight: 800;
    line-height: 1.4;
    text-align: center;
    transition: opacity var(--motion-duration-fast) var(--motion-ease), transform var(--motion-duration-fast) var(--motion-ease);
}

.timememo-toast i {
    width: 24px;
    height: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    border-radius: 999px;
    background: var(--tmemo-accent);
    color: var(--btn-primary-text);
    font-size: 12px;
}

.timememo-toast.is-error {
    border-color: #dc2626;
    background: color-mix(in srgb, #dc2626 14%, var(--tmemo-surface));
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.22), 0 0 0 4px rgba(220, 38, 38, 0.14);
}

.timememo-toast.is-error i {
    background: #dc2626;
}

.timememo-toast.is-open {
    opacity: 1;
    transform: translate(-50%, 0) scale(1);
}

.tagtoggle-btn {
    display: none;
}

@media (max-width: 860px) {
    .timememo-shell {
        grid-template-columns: minmax(0, 1fr);
    }

    .timememo-shell.has-side {
        grid-template-columns: minmax(0, 1fr);
    }

    .timememo-shell.has-side .timememo-side,
    .timememo-shell.has-side .timememo-main {
        grid-column: 1;
    }

    .timememo-side {
        position: static;
        max-height: none;
        overflow: visible;
    }
}

@media (max-width: 760px) {
    .timememo-shell {
        width: 100%;
        display: block;
        padding: var(--spacing-sm);
    }

    .timememo-side {
        display: none;
    }

    .timememo-topbar {
        position: sticky;
        top: 0;
        z-index: 20;
        margin-bottom: var(--spacing-md);
    }

    .timememo-search {
        grid-template-columns: 32px minmax(0, 1fr) 36px 36px;
        height: 38px;
    }

    .timememo-date-popover {
        right: 0;
    }

    .timememo-list.is-media-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 3px;
    }

    .timememo-media-item {
        border-radius: 0;
    }

    .timememo-media-item figcaption {
        display: none;
    }

    .timememo-mobile-media {
        display: inline-flex;
    }

    .timememo-thread-card .content-wrapper {
        padding: var(--spacing-md);
    }

    .timememo-thread-card .user-info {
        align-items: flex-start;
    }

    .timememo-thread-card .user-details {
        flex-wrap: wrap;
    }

    .timememo-thread-card .md-btn {
        gap: 4px;
    }

    .timememo-dock {
        left: auto;
        right: var(--spacing-sm);
        bottom: var(--spacing-sm);
        width: 48px;
    }

    .timememo-write-panel {
        position: absolute;
        right: 0;
        bottom: calc(100% + var(--spacing-sm));
        width: calc(100vw - var(--spacing-sm) * 2);
        max-height: min(74dvh, 560px);
        overflow: auto;
    }

    .timememo-write-grid.has-category {
        grid-template-columns: minmax(0, 1fr);
    }

    .timememo-secret-password {
        flex-basis: min(200px, calc(100% - 46px));
    }

    .secret-container form,
    .reply-secret-container form {
        grid-template-columns: minmax(0, 1fr);
    }

    .secret-container button,
    .reply-secret-container button {
        width: 100%;
    }

    .timememo-submit span {
        display: none;
    }
}

@media (max-width: 360px) {
    .timememo-shell {
        padding-left: var(--spacing-xs);
        padding-right: var(--spacing-xs);
    }

    .timememo-topbar {
        padding: 6px;
    }

    .timememo-mobile-media span {
        display: none;
    }
}
