/* ============================================
   BlogMate Component Overrides
   Bootstrap 5 기본값을 design-tokens 변수로 재정의
   반드시 bootstrap.css 및 design-tokens.css 뒤에 로드
   ============================================ */

/* ── 1. 카드 ── */

.card {
    border: none;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
    background: var(--bg-card);
}

.card-header {
    background-color: var(--bg-card);
    border-bottom: 1px solid var(--border-color);
    border-radius: var(--radius-lg) var(--radius-lg) 0 0 !important;
    padding: var(--space-5);
    font-weight: var(--font-weight-semibold);
}

.card-body {
    padding: var(--space-5);
}

.card-footer {
    background-color: var(--color-gray-50);
    border-top: 1px solid var(--border-color);
    border-radius: 0 0 var(--radius-lg) var(--radius-lg) !important;
    padding: var(--space-4) var(--space-5);
}

/* 콘텐츠 래퍼 (공통 페이지 컨테이너) */
.content-wrapper {
    background-color: var(--bg-card);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
    padding: var(--space-6);
}


/* ── 2. 버튼 ── */

.btn {
    font-family: var(--font-family);
    font-weight: var(--font-weight-medium);
    border-radius: var(--radius-sm);
    transition: all var(--transition-fast);
    font-size: var(--font-size-sm);
}

.btn-primary {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
}

.btn-primary:hover,
.btn-primary:focus {
    background-color: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
}

.btn-primary:active,
.btn-primary.active {
    background-color: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
}

.btn-secondary {
    background-color: var(--color-gray-500);
    border-color: var(--color-gray-500);
}

.btn-secondary:hover,
.btn-secondary:focus {
    background-color: var(--color-gray-600);
    border-color: var(--color-gray-600);
}

.btn-success {
    background-color: var(--color-success);
    border-color: var(--color-success);
}

.btn-success:hover,
.btn-success:focus {
    background-color: var(--color-success-dark);
    border-color: var(--color-success-dark);
}

.btn-danger {
    background-color: var(--color-danger);
    border-color: var(--color-danger);
}

.btn-danger:hover,
.btn-danger:focus {
    background-color: var(--color-danger-dark);
    border-color: var(--color-danger-dark);
}

.btn-warning {
    background-color: var(--color-warning);
    border-color: var(--color-warning);
}

.btn-warning:hover,
.btn-warning:focus {
    background-color: var(--color-warning-dark);
    border-color: var(--color-warning-dark);
}

.btn-info {
    background-color: var(--color-info);
    border-color: var(--color-info);
    color: #fff;
}

.btn-info:hover,
.btn-info:focus {
    background-color: var(--color-info-dark);
    border-color: var(--color-info-dark);
    color: #fff;
}

/* 아웃라인 버튼 */
.btn-outline-primary {
    color: var(--color-primary);
    border-color: var(--color-primary);
}

.btn-outline-primary:hover,
.btn-outline-primary:active {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
    color: #fff;
}

.btn-outline-secondary {
    color: var(--color-gray-500);
    border-color: var(--color-gray-300);
}

.btn-outline-secondary:hover,
.btn-outline-secondary:active {
    background-color: var(--color-gray-100);
    border-color: var(--color-gray-400);
    color: var(--color-gray-700);
}

.btn-outline-danger {
    color: var(--color-danger);
    border-color: var(--color-danger);
}

.btn-outline-danger:hover,
.btn-outline-danger:active {
    background-color: var(--color-danger);
    border-color: var(--color-danger);
    color: #fff;
}


/* ── 3. 테이블 ── */

.table {
    font-size: var(--font-size-sm);
    color: var(--text-primary);
    margin-bottom: 0;
}

.table > thead > tr > th {
    background-color: var(--color-gray-50);
    font-weight: var(--font-weight-semibold);
    color: var(--text-secondary);
    font-size: var(--font-size-xs);
    text-transform: uppercase;
    letter-spacing: 0.3px;
    border-bottom: 2px solid var(--border-color);
    padding: var(--space-3) var(--space-4);
    white-space: nowrap;
}

.table > tbody > tr > td {
    padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid var(--border-light);
    vertical-align: middle;
}

.table > tbody > tr:hover {
    background-color: var(--color-gray-50);
}

.table > tbody > tr:last-child > td {
    border-bottom: none;
}


/* ── 4. 배지 / 상태 ── */

.badge {
    font-weight: var(--font-weight-medium);
    font-size: var(--font-size-xs);
    padding: 0.35em 0.65em;
    border-radius: var(--radius-sm);
}

.bg-primary {
    background-color: var(--color-primary) !important;
}

.bg-success {
    background-color: var(--color-success) !important;
}

.bg-danger {
    background-color: var(--color-danger) !important;
}

.bg-warning {
    background-color: var(--color-warning) !important;
}

.bg-info {
    background-color: var(--color-info) !important;
}

.bg-secondary {
    background-color: var(--color-gray-500) !important;
}

/* 상태 배지 (소프트 스타일) */
.badge-soft-primary {
    background-color: var(--color-primary-bg);
    color: var(--color-primary);
}

.badge-soft-success {
    background-color: var(--color-success-light);
    color: var(--color-success-dark);
}

.badge-soft-danger {
    background-color: var(--color-danger-light);
    color: var(--color-danger-dark);
}

.badge-soft-warning {
    background-color: var(--color-warning-light);
    color: var(--color-warning-dark);
}

.badge-soft-info {
    background-color: var(--color-info-light);
    color: var(--color-info-dark);
}

/* 회원 역할 배지 */
.badge-admin {
    background-color: var(--color-danger);
    color: #fff;
}

.badge-vip {
    background-color: var(--color-success);
    color: #fff;
}

.badge-tester {
    background-color: var(--color-info);
    color: #fff;
}

.badge-reward {
    background-color: var(--color-warning);
    color: #fff;
}


/* ── 5. 폼 ── */

.form-control,
.form-select {
    font-family: var(--font-family);
    font-size: var(--font-size-sm);
    border-color: var(--border-color);
    border-radius: var(--radius-sm);
    color: var(--text-primary);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.form-control:focus,
.form-select:focus {
    border-color: var(--color-primary-light);
    box-shadow: 0 0 0 0.2rem rgba(79, 70, 229, 0.15);
}

.form-control::placeholder {
    color: var(--text-muted);
}

.form-label {
    font-weight: var(--font-weight-medium);
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    margin-bottom: var(--space-2);
}

.form-text {
    font-size: var(--font-size-xs);
    color: var(--text-muted);
}

.form-check-input:checked {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
}

.form-check-input:focus {
    box-shadow: 0 0 0 0.2rem rgba(79, 70, 229, 0.15);
    border-color: var(--color-primary-light);
}


/* ── 6. 모달 ── */

.modal-content {
    border: none;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
}

.modal-header {
    border-bottom: 1px solid var(--border-color);
    padding: var(--space-5);
}

.modal-header .modal-title {
    font-weight: var(--font-weight-semibold);
    font-size: var(--font-size-lg);
}

.modal-body {
    padding: var(--space-6);
}

.modal-footer {
    border-top: 1px solid var(--border-color);
    padding: var(--space-4) var(--space-5);
}

.btn-close:focus {
    box-shadow: 0 0 0 0.2rem rgba(79, 70, 229, 0.15);
}


/* ── 7. 알림 ── */

.alert {
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    border: none;
}

.alert-primary {
    background-color: var(--color-primary-bg);
    color: var(--color-primary-dark);
}

.alert-success {
    background-color: var(--color-success-light);
    color: var(--color-success-dark);
}

.alert-danger {
    background-color: var(--color-danger-light);
    color: var(--color-danger-dark);
}

.alert-warning {
    background-color: var(--color-warning-light);
    color: var(--color-warning-dark);
}

.alert-info {
    background-color: var(--color-info-light);
    color: var(--color-info-dark);
}


/* ── 8. 필터 / 검색 섹션 ── */

.filter-section {
    background-color: var(--bg-card);
    border-radius: var(--radius-md);
    padding: var(--space-5);
    margin-bottom: var(--space-6);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--border-light);
}

.filter-section .form-select {
    border-color: var(--border-color);
}

.search-box {
    position: relative;
}

.search-box .form-control {
    padding-right: 40px;
    border-radius: var(--radius-full);
    border: 1px solid var(--border-color);
}

.search-box .form-control:focus {
    border-color: var(--color-primary-light);
}

.search-box .btn {
    position: absolute;
    right: 5px;
    top: 50%;
    transform: translateY(-50%);
    border: none;
    background: none;
    color: var(--text-muted);
}


/* ── 9. 페이지네이션 ── */

.pagination {
    gap: var(--space-1);
}

.page-link {
    color: var(--text-secondary);
    border-color: var(--border-color);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-sm);
    padding: var(--space-2) var(--space-3);
    transition: all var(--transition-fast);
}

.page-link:hover {
    color: var(--color-primary);
    background-color: var(--color-primary-bg);
    border-color: var(--color-primary-light);
}

.page-item.active .page-link {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
    color: #fff;
}

.page-item.disabled .page-link {
    color: var(--text-muted);
    background-color: var(--color-gray-50);
    border-color: var(--border-light);
}


/* ── 10. 통계 카드 ── */

.stat-card {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    box-shadow: var(--shadow-md);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
    border: 1px solid var(--border-light);
}

.stat-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
}

.stat-number {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    line-height: var(--line-height-tight);
    margin-bottom: var(--space-2);
}

.stat-label {
    color: var(--text-muted);
    font-size: var(--font-size-sm);
    margin-bottom: var(--space-4);
}

/* 통계 카드 색상 변형 */
.stat-card.stat-primary .stat-number { color: var(--color-primary); }
.stat-card.stat-success .stat-number { color: var(--color-success); }
.stat-card.stat-warning .stat-number { color: var(--color-warning); }
.stat-card.stat-danger .stat-number { color: var(--color-danger); }
.stat-card.stat-info .stat-number { color: var(--color-info); }

/* 통계 카드 아이콘 배경 */
.stat-icon {
    width: 48px;
    height: 48px;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-xl);
}

.stat-icon.icon-primary {
    background: var(--color-primary-bg);
    color: var(--color-primary);
}

.stat-icon.icon-success {
    background: var(--color-success-light);
    color: var(--color-success);
}

.stat-icon.icon-warning {
    background: var(--color-warning-light);
    color: var(--color-warning);
}

.stat-icon.icon-danger {
    background: var(--color-danger-light);
    color: var(--color-danger);
}

.stat-icon.icon-info {
    background: var(--color-info-light);
    color: var(--color-info);
}


/* ── 프로그레스 바 ── */

.progress {
    height: 6px;
    border-radius: var(--radius-full);
    background-color: var(--color-gray-100);
}

.progress-bar {
    border-radius: var(--radius-full);
}


/* ── 텍스트 컬러 유틸리티 ── */

.text-primary { color: var(--color-primary) !important; }
.text-success { color: var(--color-success) !important; }
.text-danger { color: var(--color-danger) !important; }
.text-warning { color: var(--color-warning) !important; }
.text-info { color: var(--color-info) !important; }
.text-muted { color: var(--text-muted) !important; }


/* ── 드롭다운 ── */

.dropdown-menu {
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    font-size: var(--font-size-sm);
}

.dropdown-item {
    padding: var(--space-2) var(--space-4);
    transition: background-color var(--transition-fast);
}

.dropdown-item:hover,
.dropdown-item:focus {
    background-color: var(--color-primary-bg);
    color: var(--color-primary);
}

.dropdown-item.active,
.dropdown-item:active {
    background-color: var(--color-primary);
    color: #fff;
}


/* ── 툴팁, 팝오버 ── */

.tooltip-inner {
    font-size: var(--font-size-xs);
    border-radius: var(--radius-sm);
}


/* ── 11. 페이지 헤더 ── */

.page-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-6);
    flex-wrap: wrap;
    gap: var(--space-3);
}
.page-header h2 { margin: 0; font-size: var(--font-size-2xl); font-weight: var(--font-weight-bold); }
.page-header p { margin: var(--space-1) 0 0; color: var(--text-muted); font-size: var(--font-size-sm); }
.page-header-actions { display: flex; gap: var(--space-3); align-items: center; flex-wrap: wrap; }

@media (max-width: 576px) {
    .page-header {
        flex-direction: column;
        align-items: flex-start;
    }
    .page-header-actions {
        width: 100%;
    }
    .page-header-actions .btn {
        flex: 1;
        font-size: 0.8rem;
        padding: 0.4rem 0.6rem;
    }
}


/* ── 12. 안내 섹션 ── */

.info-section {
    background-color: var(--bg-page);
    border-left: 4px solid var(--color-primary);
    padding: var(--space-5);
    margin-bottom: var(--space-6);
    border-radius: var(--radius-sm);
}

.info-section .card-title {
    font-size: var(--font-size-lg);
    color: var(--color-primary);
    margin-bottom: var(--space-4);
    font-weight: var(--font-weight-semibold);
}

.info-item {
    margin-bottom: var(--space-2);
    display: flex;
    align-items: flex-start;
    font-size: var(--font-size-sm);
}

.info-item:last-child {
    margin-bottom: 0;
}

.info-item i {
    color: var(--color-success);
    margin-right: var(--space-3);
    margin-top: var(--space-1);
    min-width: 1rem;
}


/* ── 13. 빈 상태 ── */

.empty-state {
    text-align: center;
    padding: var(--space-10) var(--space-6);
    color: var(--text-muted);
}
.empty-state i { font-size: 2.5rem; color: var(--color-gray-300); margin-bottom: var(--space-4); display: block; }
.empty-state p { margin: 0; font-size: var(--font-size-sm); }
.empty-state a { color: var(--color-primary); text-decoration: none; margin-top: var(--space-3); display: inline-block; }


/* ── 13. 필터 바 ── */

.filter-bar {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    padding: var(--space-5);
    margin-bottom: var(--space-6);
    border: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--space-3);
}


/* ── 14. 토스트 알림 ── */

.toast-notification {
    position: fixed;
    top: 20px;
    right: 20px;
    padding: 12px 20px;
    border-radius: var(--radius-md, 8px);
    color: #fff;
    font-size: 14px;
    z-index: 9999;
    opacity: 0;
    transform: translateX(100%);
    transition: all 0.3s ease;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    max-width: 400px;
}
.toast-notification.show { opacity: 1; transform: translateX(0); }
.toast-success { background-color: var(--color-success, #198754); }
.toast-error { background-color: var(--color-danger, #dc3545); }
.toast-warning { background-color: var(--color-warning, #ffc107); color: #333; }
.toast-info { background-color: var(--color-primary, #0d6efd); }


/* ── 15. 로딩 오버레이 ── */

#globalLoadingOverlay {
    position: fixed; inset: 0; z-index: 10001;
    display: flex; align-items: center; justify-content: center;
    opacity: 0; transition: opacity 0.2s ease;
    pointer-events: none;
}
#globalLoadingOverlay.show { opacity: 1; pointer-events: auto; }
.loading-backdrop {
    position: absolute; inset: 0;
    background: rgba(255,255,255,0.7);
}
.loading-content {
    position: relative; text-align: center;
}
.loading-spinner {
    width: 40px; height: 40px; margin: 0 auto 12px;
    border: 4px solid var(--border-color, #dee2e6);
    border-top-color: var(--color-primary, #0d6efd);
    border-radius: 50%;
    animation: globalSpin 0.8s linear infinite;
}
@keyframes globalSpin {
    to { transform: rotate(360deg); }
}
.loading-message {
    font-size: 14px;
    color: var(--text-secondary, #666);
}


/* ── 16. 확인 모달 ── */

#globalConfirmModal {
    position: fixed; inset: 0; z-index: 10000;
    display: flex; align-items: center; justify-content: center;
    opacity: 0; transition: opacity 0.2s ease;
}
#globalConfirmModal.show { opacity: 1; }
.confirm-backdrop {
    position: absolute; inset: 0;
    background: rgba(0,0,0,0.4);
}
.confirm-dialog {
    position: relative; background: #fff;
    border-radius: var(--radius-lg, 12px);
    box-shadow: 0 8px 32px rgba(0,0,0,0.2);
    min-width: 320px; max-width: 440px; width: 90%;
    transform: scale(0.95); transition: transform 0.2s ease;
}
#globalConfirmModal.show .confirm-dialog { transform: scale(1); }
.confirm-header {
    padding: 16px 20px;
    border-bottom: 1px solid var(--border-color, #dee2e6);
    font-size: 15px;
}
.confirm-body {
    padding: 20px;
    font-size: 14px;
    color: var(--text-secondary, #555);
    line-height: 1.6;
}
.confirm-footer {
    padding: 12px 20px;
    display: flex; justify-content: flex-end; gap: 8px;
    border-top: 1px solid var(--border-color, #dee2e6);
}

/* -- 17. 회원 검색 자동완성 -- */
.member-search-wrapper { position: relative; }
.member-search-dropdown {
    display: none; position: absolute; top: 100%; left: 0; right: 0; z-index: 1050;
    background: var(--bg-card, #fff); border: 1px solid var(--border-color, #dee2e6);
    border-radius: var(--radius-md, 6px); box-shadow: var(--shadow-lg, 0 10px 25px rgba(0,0,0,0.15));
    max-height: 250px; overflow-y: auto; margin-top: 4px;
}
.member-search-dropdown.show { display: block; }
.member-search-item {
    padding: 10px 14px; cursor: pointer; border-bottom: 1px solid var(--border-light, #f0f0f0);
    transition: background 0.15s;
}
.member-search-item:last-child { border-bottom: none; }
.member-search-item:hover, .member-search-item.active { background: var(--color-primary-bg, #e8f0fe); }
.member-search-name { font-size: 0.875rem; font-weight: 500; color: var(--text-primary, #333); }
.member-search-id { font-weight: 400; color: var(--text-secondary, #666); font-size: 0.8rem; }
.member-search-sub { font-size: 0.75rem; color: var(--text-muted, #999); margin-top: 2px; }
.member-search-empty { padding: 12px 14px; color: var(--text-muted, #999); font-size: 0.85rem; text-align: center; }
.member-search-badge {
    display: inline-flex; align-items: center; gap: 6px;
    background: var(--color-primary-bg, #e8f0fe); color: var(--color-primary, #4e73df);
    padding: 4px 10px; border-radius: 20px; font-size: 0.8rem; margin-top: 6px;
}
.member-search-remove { cursor: pointer; opacity: 0.7; font-size: 0.7rem; }
.member-search-remove:hover { opacity: 1; color: var(--color-danger, #dc3545); }
[data-theme="dark"] .member-search-dropdown { background: var(--bg-card); border-color: var(--border-color); }
[data-theme="dark"] .member-search-item:hover, [data-theme="dark"] .member-search-item.active { background: rgba(78,115,223,0.15); }
