/**
 * Joyn Resources - Modals
 * Design System: Solapi v4.0
 * 
 * 게시글 보기 + 글쓰기 모달 솔라피 디자인
 * 
 * @location assets/css/modals.css
 */

/* ========================================
   Modal Base (Solapi)
   ======================================== */
.joyn-modal {
    position: fixed;
    inset: 0;
    z-index: 999998;
    display: none;
    align-items: center;
    justify-content: center;
    padding: var(--joyn-spacing-4);
}

body.joyn-modal-open .jmm-header {
    z-index: 999999 !important;
}

.joyn-modal.active {
    display: flex;
}

.joyn-modal__overlay {
    position: absolute;
    inset: 0;
    background-color: rgba(23, 23, 23, 0.5);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

.joyn-modal__container {
    position: relative;
    background: var(--joyn-bg-white);
    border-radius: var(--joyn-radius-lg);
    box-shadow: var(--joyn-shadow-xl);
    width: 100%;
    max-width: 600px;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    animation: joynModalSlideUp 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
    border: 1px solid var(--joyn-gray-200);
    overflow: hidden;
}

@keyframes joynModalSlideUp {
    from {
        opacity: 0;
        transform: translateY(16px) scale(0.98);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

/* ── 모달 헤더 (Solapi 그라데이션 액센트) ── */
.joyn-modal__header {
    padding: 20px 24px;
    border-bottom: 1px solid var(--joyn-gray-200);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--joyn-spacing-4);
    background: var(--joyn-bg-white);
    position: relative;
}

/* 솔라피 브랜드 액센트 라인 */
.joyn-modal__header::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--joyn-primary) 0%, var(--joyn-accent, #A788FF) 100%);
}

.joyn-modal__title {
    margin: 0;
    font-size: 17px;
    font-weight: 700;
    color: var(--joyn-gray-900);
    line-height: 1.4;
    display: flex;
    align-items: center;
    gap: 8px;
}

.joyn-modal__title i {
    color: var(--joyn-primary);
    font-size: 20px;
}

.joyn-modal__body {
    padding: 24px;
    overflow-y: auto;
    flex: 1;
}

.joyn-modal__footer {
    padding: 16px 24px;
    border-top: 1px solid var(--joyn-gray-200);
    display: flex;
    justify-content: flex-end;
    gap: var(--joyn-spacing-3);
    background-color: var(--joyn-gray-50);
}


/* ========================================
   Search Modal
   ======================================== */
.joyn-search-modal .joyn-modal__container {
    max-width: 560px;
    align-self: flex-start;
    margin-top: 12vh;
}

.joyn-search-form {
    display: flex;
    flex-direction: column;
    gap: var(--joyn-spacing-4);
}

.joyn-search-reset {
    text-align: center;
    margin-top: var(--joyn-spacing-2);
}


/* ========================================
   Notice Modal (등록 안내)
   ======================================== */
.joyn-notice-content {
    color: var(--joyn-gray-700);
}

.joyn-notice-intro {
    font-size: var(--joyn-font-size-base);
    line-height: 1.7;
    margin: 0 0 var(--joyn-spacing-5);
    color: var(--joyn-gray-700);
}

.joyn-notice-box {
    background-color: var(--joyn-primary-lighter, #F5F5FF);
    border-left: 4px solid var(--joyn-primary);
    padding: var(--joyn-spacing-5);
    border-radius: 0 var(--joyn-radius-sm) var(--joyn-radius-sm) 0;
    margin: var(--joyn-spacing-5) 0;
}

.joyn-notice-box__title {
    color: var(--joyn-primary);
    font-size: var(--joyn-font-size-base);
    font-weight: 600;
    margin: 0 0 var(--joyn-spacing-3);
    display: flex;
    align-items: center;
    gap: 6px;
}

.joyn-notice-box__title i {
    font-size: 18px;
}

.joyn-notice-list {
    margin: 0;
    padding-left: 1.25rem;
    color: var(--joyn-gray-600);
    line-height: 1.7;
    font-size: var(--joyn-font-size-sm);
}

.joyn-notice-list li {
    margin-bottom: var(--joyn-spacing-2);
}

.joyn-notice-list li:last-child {
    margin-bottom: 0;
}

.joyn-notice-agreement {
    margin-top: var(--joyn-spacing-5);
    padding-top: var(--joyn-spacing-5);
    border-top: 1px solid var(--joyn-gray-200);
}

.joyn-checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: var(--joyn-spacing-3);
    cursor: pointer;
}

.joyn-checkbox-label input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin-top: 2px;
    accent-color: var(--joyn-primary);
    cursor: pointer;
    flex-shrink: 0;
}

.joyn-checkbox-text {
    font-size: var(--joyn-font-size-sm);
    line-height: 1.6;
    color: var(--joyn-gray-700);
}

.required {
    color: var(--joyn-error);
    font-weight: 500;
}


/* ========================================
   Upload Modal (글쓰기)
   ======================================== */
.joyn-modal--upload .joyn-modal__container {
    max-width: 720px;
    max-height: 95vh;
}


/* ========================================
   ★ Detail Modal (게시글 보기) - Solapi
   ======================================== */
.joyn-modal--detail .joyn-modal__container {
    max-width: 900px;
    max-height: 90vh;
    width: 100%;
}

/* 상세 모달 헤더: 닫기 버튼 왼쪽 */
.joyn-modal--detail .joyn-modal__header {
    padding: 20px 24px 16px;
    border-bottom: none;
    background: var(--joyn-bg-white);
    flex-direction: row;
}
.joyn-modal--detail .joyn-modal__header .joyn-detail-close-left {
    order: -1;
    flex-shrink: 0;
    background: var(--joyn-primary, #4541FF) !important;
    color: #fff !important;
    border: 1px solid rgba(255,255,255,.3);
    border-radius: 8px;
    width: 40px;
    height: 40px;
}
.joyn-modal--detail .joyn-modal__header .joyn-detail-close-left:hover {
    background: var(--joyn-primary-dark, #3730E3) !important;
    color: #fff !important;
}
.joyn-modal--detail .joyn-modal__header .joyn-detail-close-left i {
    color: #fff !important;
}

.joyn-modal--detail .joyn-modal__header::before {
    height: 3px;
    background: linear-gradient(90deg, var(--joyn-primary) 0%, var(--joyn-accent, #A788FF) 50%, var(--joyn-info, #518CFF) 100%);
}

/* 배치 업로드 콘텐츠 내부 모달 처리 · 글읽기 본문 상단 50px는 .joyn-detail-content에서 */
.joyn-modal--detail .joyn-modal__body,
.joyn-modal--detail #joyn-detail-body {
    position: static;
    transform: none;
    contain: layout style;
    padding: 0 24px 24px;
}
/* 글읽기 창: body 직속 첫 자식 상단 50px (JS로 삽입된 .joyn-detail-content) */
#joyn-detail-body > .joyn-detail-content {
    padding-top: 50px !important;
}

.joyn-detail-body-content .modal-overlay,
.joyn-detail-description .modal-overlay,
.joyn-modal__body .modal-overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    z-index: 999998 !important;
}

.joyn-detail-body-content .modal,
.joyn-detail-description .modal,
.joyn-modal__body .modal {
    position: relative !important;
    width: calc(100vw - 40px) !important;
    max-width: 900px !important;
    height: calc(100vh - 80px) !important;
    max-height: calc(100vh - 80px) !important;
}

.joyn-detail-body-content .modal-content iframe,
.joyn-detail-description .modal-content iframe,
.joyn-modal__body .modal-content iframe {
    width: 100% !important;
    height: 100% !important;
    border: none !important;
}

/* ── 상세 헤더 콘텐츠 ── */
.joyn-detail-header-content {
    flex: 1;
    min-width: 0;
}

/* 번역 버튼 비표시 */
.joyn-modal--detail .joyn-btn-translate-detail,
.joyn-modal--detail .joyn-btn-translate {
    display: none !important;
}

#joyn-detail-title {
    font-size: 20px !important;
    font-weight: 700 !important;
    color: var(--joyn-gray-900) !important;
    line-height: 1.4 !important;
    margin-bottom: 8px !important;
    word-break: keep-all;
    overflow-wrap: break-word;
}

/* ── 메타 정보 (카테고리, 날짜, 조회수 등) ── */
.joyn-detail-meta {
    font-size: var(--joyn-font-size-sm);
    color: var(--joyn-gray-500);
    margin-top: var(--joyn-spacing-2);
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.joyn-detail-meta .joyn-category-badge {
    display: inline-flex;
    padding: 3px 10px;
    background-color: var(--joyn-primary-light);
    color: var(--joyn-primary);
    font-size: 12px;
    font-weight: 600;
    border-radius: var(--joyn-radius-full);
}

.joyn-detail-meta .joyn-meta-separator {
    color: var(--joyn-gray-300);
    font-size: 10px;
}

.joyn-detail-meta .joyn-meta-item {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 13px;
    color: var(--joyn-gray-500);
}

.joyn-detail-meta .joyn-meta-item i {
    font-size: 14px;
    color: var(--joyn-gray-400);
}

/* ── 로딩 ── */
.joyn-detail-loading {
    text-align: center;
    padding: var(--joyn-spacing-12);
    color: var(--joyn-gray-500);
}

.joyn-detail-loading i {
    font-size: 32px;
    color: var(--joyn-primary);
    margin-bottom: var(--joyn-spacing-4);
    display: block;
}

.joyn-detail-loading p {
    margin: 0;
    font-size: var(--joyn-font-size-sm);
}

/* ── 본문 콘텐츠 (글읽기 창 상단 50px 띄운 뒤 구성) ── */
.joyn-detail-content {
    word-wrap: break-word;
    overflow-wrap: break-word;
    padding-top: 50px !important;
}

.joyn-detail-body-content {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    word-wrap: break-word;
    overflow-wrap: break-word;
}

.joyn-detail-body-content table,
.joyn-detail-body-content img,
.joyn-detail-body-content video,
.joyn-detail-body-content embed,
.joyn-detail-body-content object {
    max-width: 100% !important;
    height: auto !important;
}

.joyn-detail-body-content iframe {
    max-width: 100% !important;
    width: 100% !important;
}

.joyn-detail-body-content pre,
.joyn-detail-body-content code {
    max-width: 100%;
    overflow-x: auto;
    word-wrap: break-word;
}

.joyn-detail-body-content body,
.joyn-detail-body-content > body {
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    min-height: auto !important;
    max-width: 100% !important;
    width: 100% !important;
}

.joyn-detail-body-content .container {
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    max-width: 100% !important;
    width: 100% !important;
    background: transparent !important;
}

/* ── 본문 설명 영역 ── */
.joyn-detail-description {
    margin-bottom: var(--joyn-spacing-6);
    line-height: 1.8;
    color: var(--joyn-gray-700);
    font-size: var(--joyn-font-size-base);
    padding: 20px 0;
    border-bottom: 1px solid var(--joyn-gray-100);
}

.joyn-detail-description img {
    max-width: 100%;
    height: auto;
    display: block;
    margin: var(--joyn-spacing-4) auto;
    border-radius: var(--joyn-radius-sm);
}

/* ── 섹션 구분 ── */
.joyn-detail-section {
    margin-bottom: var(--joyn-spacing-6);
    padding-top: var(--joyn-spacing-5);
    border-top: 1px solid var(--joyn-gray-100);
}

.joyn-detail-section:first-of-type {
    border-top: none;
    padding-top: 0;
}

.joyn-detail-section h4 {
    margin: 0 0 var(--joyn-spacing-4) 0;
    font-size: var(--joyn-font-size-md);
    font-weight: 700;
    color: var(--joyn-gray-900);
    display: flex;
    align-items: center;
    gap: 8px;
}

.joyn-detail-section h4 i {
    font-size: 18px;
    color: var(--joyn-primary);
}

.joyn-detail-files,
.joyn-detail-links {
    display: flex;
    flex-direction: column;
    gap: var(--joyn-spacing-3);
}

.joyn-detail-file-item,
.joyn-detail-link-item {
    display: flex;
    align-items: center;
    gap: var(--joyn-spacing-4);
    padding: var(--joyn-spacing-4);
    background-color: var(--joyn-gray-50);
    border-radius: var(--joyn-radius-sm);
    border: 1px solid var(--joyn-gray-100);
    transition: var(--joyn-transition);
}

.joyn-detail-file-item:hover,
.joyn-detail-link-item:hover {
    background-color: var(--joyn-bg-white);
    border-color: var(--joyn-primary);
    box-shadow: var(--joyn-shadow-sm);
}

.joyn-detail-file-item .file-icon,
.joyn-detail-link-item .file-icon {
    width: 42px;
    height: 42px;
    background: var(--joyn-primary-light);
    border-radius: var(--joyn-radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.joyn-detail-file-item .file-icon i,
.joyn-detail-link-item .file-icon i {
    font-size: 20px;
    color: var(--joyn-primary);
}

.joyn-detail-file-item .file-info,
.joyn-detail-link-item .file-info {
    flex: 1;
    min-width: 0;
}

.joyn-detail-file-item .file-name,
.joyn-detail-link-item .file-name {
    display: block;
    font-weight: 500;
    color: var(--joyn-gray-900);
    word-break: break-word;
    line-height: 1.4;
    font-size: var(--joyn-font-size-sm);
}

.joyn-detail-file-item .file-size {
    display: block;
    font-size: var(--joyn-font-size-xs);
    color: var(--joyn-gray-500);
    margin-top: 2px;
}

/* ── Permalink & Meta ── */
.joyn-detail-permalink-section {
    margin-bottom: var(--joyn-spacing-4);
    padding: 12px 16px;
    background-color: var(--joyn-gray-50);
    border-radius: var(--joyn-radius-sm);
    display: flex;
    align-items: center;
    gap: var(--joyn-spacing-3);
    flex-wrap: wrap;
    border: 1px solid var(--joyn-gray-100);
}

.joyn-copy-permalink-btn:hover {
    background: var(--joyn-gray-100) !important;
    color: var(--joyn-gray-600) !important;
}

.joyn-copy-permalink-btn.copied {
    color: var(--joyn-success) !important;
}

.joyn-detail-admin-actions a:hover,
.joyn-detail-admin-actions button:hover {
    background: var(--joyn-gray-200) !important;
    color: var(--joyn-gray-700) !important;
}

.joyn-detail-admin-actions button.joyn-btn-delete-resource:hover {
    background: var(--joyn-error-light) !important;
    color: var(--joyn-error) !important;
    border-color: var(--joyn-error) !important;
}

.joyn-youtube-embed {
    margin: var(--joyn-spacing-5) 0;
    border-radius: var(--joyn-radius-md);
    overflow: hidden;
    box-shadow: var(--joyn-shadow-md);
}


/* ========================================
   ★ File Card (첨부파일 카드) - Solapi
   ======================================== */
.joyn-files-section h4 {
    display: flex;
    align-items: center;
    gap: var(--joyn-spacing-2);
}

.joyn-files-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 22px;
    padding: 0 6px;
    background: var(--joyn-primary-light);
    color: var(--joyn-primary);
    font-size: 11px;
    font-weight: 700;
    border-radius: var(--joyn-radius-full);
}

.joyn-file-card {
    display: flex;
    align-items: center;
    gap: var(--joyn-spacing-4);
    padding: 14px 16px;
    background: var(--joyn-bg-white);
    border: 1px solid var(--joyn-gray-200);
    border-radius: var(--joyn-radius-sm);
    transition: var(--joyn-transition);
    margin-bottom: var(--joyn-spacing-2);
}

.joyn-file-card:last-child {
    margin-bottom: 0;
}

.joyn-file-card:hover {
    border-color: var(--joyn-primary);
    box-shadow: var(--joyn-shadow-md);
    transform: translateY(-1px);
}

.joyn-file-card__icon {
    width: 44px;
    height: 44px;
    background: var(--joyn-primary-light);
    border-radius: var(--joyn-radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.joyn-file-card__icon i {
    font-size: 22px;
    color: var(--joyn-primary);
}

/* 파일 타입별 컬러 */
.joyn-file-card[data-type="image"] .joyn-file-card__icon { background: #FFF8E1; }
.joyn-file-card[data-type="image"] .joyn-file-card__icon i { color: #F2994A; }

.joyn-file-card[data-type="document"] .joyn-file-card__icon { background: var(--joyn-info-light, #EFF4FF); }
.joyn-file-card[data-type="document"] .joyn-file-card__icon i { color: var(--joyn-info, #518CFF); }

.joyn-file-card[data-type="spreadsheet"] .joyn-file-card__icon { background: #ECFDF5; }
.joyn-file-card[data-type="spreadsheet"] .joyn-file-card__icon i { color: #10b981; }

.joyn-file-card[data-type="presentation"] .joyn-file-card__icon { background: #FDF2F8; }
.joyn-file-card[data-type="presentation"] .joyn-file-card__icon i { color: #ec4899; }

.joyn-file-card[data-type="audio"] .joyn-file-card__icon { background: var(--joyn-accent-light, #F0EBFF); }
.joyn-file-card[data-type="audio"] .joyn-file-card__icon i { color: var(--joyn-accent, #A788FF); }

.joyn-file-card[data-type="archive"] .joyn-file-card__icon { background: var(--joyn-warning-light, #FFF8F0); }
.joyn-file-card[data-type="archive"] .joyn-file-card__icon i { color: var(--joyn-warning, #F2994A); }

.joyn-file-card[data-type="pdf"] .joyn-file-card__icon { background: #FEF2F2; }
.joyn-file-card[data-type="pdf"] .joyn-file-card__icon i { color: #ef4444; }

.joyn-file-card__info {
    flex: 1;
    min-width: 0;
}

.joyn-file-card__name {
    display: block;
    font-weight: 600;
    color: var(--joyn-gray-900);
    font-size: var(--joyn-font-size-sm);
    line-height: 1.4;
    word-break: break-word;
}

.joyn-file-card__size {
    display: block;
    font-size: var(--joyn-font-size-xs);
    color: var(--joyn-gray-500);
    margin-top: 3px;
}

.joyn-file-card__path {
    margin-top: 4px;
    font-size: 10px;
    font-family: 'SF Mono', Monaco, 'Courier New', monospace;
    color: var(--joyn-gray-400);
    word-break: break-all;
    line-height: 1.4;
}

.joyn-file-card__actions {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
}

/* ── 파일 버튼 (Solapi) ── */
.joyn-file-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 8px 14px;
    border: none;
    border-radius: var(--joyn-radius-sm);
    font-size: var(--joyn-font-size-sm);
    font-weight: 500;
    cursor: pointer;
    transition: var(--joyn-transition);
    white-space: nowrap;
    font-family: var(--joyn-font-sans);
}

.joyn-file-btn i {
    font-size: 16px;
}

.joyn-file-btn--preview {
    background: var(--joyn-gray-100);
    color: var(--joyn-gray-700);
    padding: 8px;
}

.joyn-file-btn--preview span {
    display: none;
}

.joyn-file-btn--preview:hover {
    background: var(--joyn-gray-200);
    color: var(--joyn-gray-900);
}

.joyn-file-btn--download {
    background: var(--joyn-primary);
    color: white;
}

.joyn-file-btn--download:hover {
    background: var(--joyn-primary-hover);
    transform: translateY(-1px);
    box-shadow: var(--joyn-shadow-primary);
}

.joyn-file-btn--download:active {
    transform: translateY(0);
}


/* ========================================
   Comments Section (Solapi)
   ======================================== */
.joyn-comments-section {
    margin-top: var(--joyn-spacing-6);
    padding-top: var(--joyn-spacing-5);
    border-top: 2px solid var(--joyn-gray-100);
}

.joyn-comments-section h4 {
    margin-bottom: var(--joyn-spacing-4);
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: var(--joyn-font-size-md);
    font-weight: 700;
    color: var(--joyn-gray-900);
}

.joyn-comments-section h4 i {
    font-size: 20px;
    color: var(--joyn-primary);
}

.joyn-comments-count {
    font-size: var(--joyn-font-size-xs);
    font-weight: 600;
    color: var(--joyn-primary);
    background: var(--joyn-primary-light);
    padding: 2px 8px;
    border-radius: var(--joyn-radius-full);
    margin-left: 4px;
}

.joyn-comments-list {
    margin-bottom: var(--joyn-spacing-5);
}

.joyn-comment-item {
    padding: 16px;
    background-color: var(--joyn-gray-50);
    border-radius: var(--joyn-radius-sm);
    margin-bottom: var(--joyn-spacing-2);
    border-left: 3px solid var(--joyn-primary);
}

.joyn-comment-item:last-child {
    margin-bottom: 0;
}

.joyn-comment-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--joyn-spacing-2);
    flex-wrap: wrap;
    gap: var(--joyn-spacing-2);
}

.joyn-comment-author {
    font-weight: 600;
    color: var(--joyn-gray-900);
    font-size: var(--joyn-font-size-sm);
}

.joyn-comment-date {
    font-size: var(--joyn-font-size-xs);
    color: var(--joyn-gray-500);
}

.joyn-comment-content {
    color: var(--joyn-gray-700);
    line-height: 1.7;
    font-size: var(--joyn-font-size-sm);
}

.joyn-comment-content p {
    margin: 0 0 var(--joyn-spacing-2) 0;
}

.joyn-comment-content p:last-child {
    margin-bottom: 0;
}

.joyn-comments-empty {
    text-align: center;
    padding: var(--joyn-spacing-8);
    color: var(--joyn-gray-500);
    font-size: var(--joyn-font-size-sm);
    background: var(--joyn-gray-50);
    border-radius: var(--joyn-radius-sm);
}

.joyn-comment-form-wrapper {
    margin-top: var(--joyn-spacing-5);
    padding-top: var(--joyn-spacing-5);
    border-top: 1px solid var(--joyn-gray-100);
}

.joyn-comment-form {
    background-color: var(--joyn-gray-50);
    padding: var(--joyn-spacing-4);
    border-radius: var(--joyn-radius-sm);
}

.joyn-comment-form-group {
    margin-bottom: var(--joyn-spacing-3);
}

.joyn-comment-textarea {
    width: 100%;
    padding: 12px 14px;
    border: 1px solid var(--joyn-gray-200);
    border-radius: var(--joyn-radius-sm);
    font-family: var(--joyn-font-sans);
    font-size: var(--joyn-font-size-sm);
    line-height: 1.6;
    resize: vertical;
    min-height: 90px;
    box-sizing: border-box;
    background: var(--joyn-bg-white);
    transition: var(--joyn-transition);
}

.joyn-comment-textarea:focus {
    outline: none;
    border-color: var(--joyn-primary);
    box-shadow: var(--joyn-focus-ring);
}

.joyn-comment-form-actions {
    display: flex;
    justify-content: flex-end;
}

.joyn-comment-login-required {
    text-align: center;
    padding: var(--joyn-spacing-8);
    background-color: var(--joyn-gray-50);
    border-radius: var(--joyn-radius-sm);
    margin-top: var(--joyn-spacing-5);
}

.joyn-comment-login-required p {
    margin: 0 0 var(--joyn-spacing-4) 0;
    color: var(--joyn-gray-600);
}


/* ========================================
   Mobile Responsive
   ======================================== */
@media (max-width: 639px) {
    .joyn-modal {
        padding: 0;
        align-items: flex-start;
        top: 60px !important;
        right: 0 !important;
        bottom: 0 !important;
        left: 0 !important;
        inset: unset;
    }

    .joyn-modal .joyn-modal__container {
        max-width: 100%;
        width: 100%;
        border-radius: 0;
        margin: 0;
        max-height: calc(100vh - 60px);
        border: none;
    }

    .joyn-modal--detail {
        padding-top: 0;
        top: 60px !important;
        right: 0 !important;
        bottom: 0 !important;
        left: 0 !important;
        inset: unset;
    }

    .joyn-modal--detail .joyn-modal__container {
        height: calc(100vh - 60px);
        max-height: calc(100vh - 60px);
    }

    .joyn-modal__header {
        padding: 16px;
    }

    #joyn-detail-title {
        font-size: 18px !important;
    }

    .joyn-modal__body {
        padding: 16px;
    }

    .joyn-modal--detail .joyn-modal__body,
    .joyn-modal--detail #joyn-detail-body {
        padding: 0 16px 16px;
    }

    .joyn-modal__footer {
        padding: 12px 16px;
        border-radius: 0;
    }

    .joyn-search-modal .joyn-modal__container {
        margin-top: 0;
    }

    /* 모바일 파일 카드 */
    .joyn-file-card {
        flex-wrap: wrap;
        padding: 12px;
        gap: 10px;
    }

    .joyn-file-card__icon {
        width: 40px;
        height: 40px;
    }

    .joyn-file-card__icon i {
        font-size: 18px;
    }

    .joyn-file-card__info {
        flex: 1;
        min-width: calc(100% - 56px);
    }

    .joyn-file-card__actions {
        width: 100%;
        justify-content: flex-end;
    }

    .joyn-file-btn--download {
        flex: 1;
        justify-content: center;
    }
}
