/* ============================================
   AdX 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-accent {
    background-color: var(--color-accent);
    border-color: var(--color-accent);
    color: #fff;
}

.btn-accent:hover,
.btn-accent:focus {
    background-color: var(--color-accent-dark);
    border-color: var(--color-accent-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;
}

/* 테이블 반응형 */
@media (max-width: 768px) {
    .table-responsive-card thead { display: none; }
    .table-responsive-card tbody tr {
        display: block;
        background: var(--bg-card);
        border-radius: var(--radius-md);
        box-shadow: var(--shadow-sm);
        margin-bottom: var(--space-3);
        padding: var(--space-4);
        border: 1px solid var(--border-light);
    }
    .table-responsive-card tbody td {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: var(--space-2) 0 !important;
        border-bottom: 1px solid var(--border-light) !important;
        font-size: var(--font-size-sm);
    }
    .table-responsive-card tbody td:last-child { border-bottom: none !important; }
    .table-responsive-card tbody td::before {
        content: attr(data-label);
        font-weight: var(--font-weight-semibold);
        color: var(--text-secondary);
        font-size: var(--font-size-xs);
        text-transform: uppercase;
        min-width: 100px;
    }
}


/* -- 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; }
.bg-accent { background-color: var(--color-accent) !important; color: #fff; }

/* 상태 배지 (소프트 스타일) */
.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-soft-accent {
    background-color: rgba(124, 58, 237, 0.1);
    color: var(--color-accent);
}

/* 역할 배지 */
.badge-super-admin { background-color: var(--color-danger); color: #fff; }
.badge-admin { background-color: var(--color-accent); color: #fff; }
.badge-staff { background-color: var(--color-info); color: #fff; }
.badge-customer { background-color: var(--color-gray-400); 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(37, 99, 235, 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(37, 99, 235, 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(37, 99, 235, 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. (예비) -- */


/* -- 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);
}

.pagination-wrapper {
    display: flex;
    justify-content: center;
    margin-top: var(--space-5);
}

/* -- 10.5 섹션 카드 (주문폼 등) -- */

.section-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-5);
    overflow: hidden;
}

.section-card-header {
    background: var(--color-gray-50);
    padding: var(--space-4) var(--space-5);
    border-bottom: 1px solid var(--border-color);
    font-weight: var(--font-weight-semibold);
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.section-card-body {
    padding: var(--space-5);
    color: var(--text-primary);
}


/* -- 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-card.stat-accent .stat-number { color: var(--color-accent); }

/* 통계 카드 아이콘 배경 */
.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); }
.stat-icon.icon-accent { background: rgba(124, 58, 237, 0.1); color: var(--color-accent); }


/* -- 프로그레스 바 -- */

.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-accent { color: var(--color-accent) !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, .empty-state .empty-icon { font-size: 2.5rem; color: var(--color-gray-300); margin-bottom: var(--space-4); display: block; }
.empty-state p { margin: 0 0 var(--space-4); font-size: var(--font-size-sm); }
.empty-state .btn { display: inline-flex; align-items: center; gap: var(--space-2); }
.empty-state .btn i { font-size: inherit; color: inherit; margin: 0; display: inline; }


/* -- 14. 필터 바 -- */

.filter-bar {
    margin-bottom: var(--space-5);
}

/* 상태 필터 탭 */
.filter-tabs {
    display: flex;
    gap: var(--space-2);
    flex-wrap: wrap;
    margin-bottom: var(--space-4);
}

.filter-tab {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    padding: var(--space-2) var(--space-4);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    text-decoration: none;
    color: var(--text-secondary);
    background: var(--bg-card);
    border: 1px solid var(--border-light);
    transition: all var(--transition-fast);
    white-space: nowrap;
}

.filter-tab:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
    background: var(--color-primary-bg);
}

.filter-tab.active {
    background: var(--color-primary);
    color: #fff;
    border-color: var(--color-primary);
}

.filter-count {
    display: inline-block;
    padding: 1px 8px;
    border-radius: var(--radius-full);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
    background: rgba(255, 255, 255, 0.2);
    line-height: 1.4;
}

.filter-tab:not(.active) .filter-count {
    background: var(--color-gray-100);
    color: var(--text-muted);
}

/* 검색/필터 컨트롤 영역 */
.filter-controls {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    flex-wrap: wrap;
}

.filter-controls-start,
.filter-controls-end {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    flex-wrap: wrap;
}

.filter-select {
    font-size: var(--font-size-sm);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    padding: var(--space-2) var(--space-8) var(--space-2) var(--space-3);
    background-color: var(--bg-card);
    color: var(--text-primary);
    min-width: 140px;
    max-width: 180px;
    transition: border-color var(--transition-fast);
    appearance: auto;
}

.filter-select:focus {
    border-color: var(--color-primary-light);
    outline: none;
    box-shadow: 0 0 0 0.2rem rgba(37, 99, 235, 0.15);
}

/* 검색 인풋 그룹 */
.filter-search {
    display: flex;
    align-items: stretch;
}

.filter-search .filter-input {
    font-size: var(--font-size-sm);
    border: 1px solid var(--border-color);
    border-right: none;
    border-radius: var(--radius-full) 0 0 var(--radius-full);
    padding: var(--space-2) var(--space-4);
    min-width: 200px;
    max-width: 300px;
    background-color: var(--bg-card);
    color: var(--text-primary);
    transition: border-color var(--transition-fast);
}

.filter-search .filter-input::placeholder {
    color: var(--text-muted);
}

.filter-search .filter-input:focus {
    border-color: var(--color-primary-light);
    outline: none;
    box-shadow: 0 0 0 0.2rem rgba(37, 99, 235, 0.15);
}

.filter-search-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-2) var(--space-3);
    border: 1px solid var(--border-color);
    border-left: none;
    border-radius: 0 var(--radius-full) var(--radius-full) 0;
    background: var(--bg-card);
    color: var(--text-muted);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.filter-search-btn:hover {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: #fff;
}

.filter-search .filter-input:focus ~ .filter-search-btn,
.filter-search .filter-input:focus + .filter-search-btn {
    border-color: var(--color-primary-light);
}

.filter-reset {
    font-size: var(--font-size-sm);
    padding: var(--space-2) var(--space-3);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-sm);
    background: transparent;
    color: var(--text-muted);
    cursor: pointer;
    text-decoration: none;
    transition: all var(--transition-fast);
    white-space: nowrap;
}

.filter-reset:hover {
    border-color: var(--color-danger);
    color: var(--color-danger);
}

/* 모바일 대응 */
@media (max-width: 768px) {
    .filter-tabs {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        padding-bottom: var(--space-2);
    }
    .filter-tabs::-webkit-scrollbar { display: none; }

    .filter-tab {
        flex-shrink: 0;
        font-size: var(--font-size-xs);
        padding: var(--space-1) var(--space-3);
    }

    .filter-controls {
        flex-direction: column;
        align-items: stretch;
    }

    .filter-controls-start,
    .filter-controls-end {
        width: 100%;
    }

    .filter-select {
        max-width: 100%;
        width: 100%;
    }

    .filter-search {
        width: 100%;
    }

    .filter-search .filter-input {
        min-width: 0;
        max-width: none;
        flex: 1;
    }
}

/* 다크모드 */
[data-theme="dark"] .filter-tab {
    background: var(--bg-card);
    border-color: var(--border-color);
    color: var(--text-secondary);
}

[data-theme="dark"] .filter-tab:hover {
    border-color: var(--color-primary-light);
    color: var(--color-primary-light);
    background: rgba(37, 99, 235, 0.1);
}

[data-theme="dark"] .filter-tab.active {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: #fff;
}

[data-theme="dark"] .filter-tab:not(.active) .filter-count {
    background: var(--bg-page);
    color: var(--text-muted);
}

[data-theme="dark"] .filter-select {
    background-color: var(--bg-card);
    color: var(--text-primary);
    border-color: var(--border-color);
}

[data-theme="dark"] .filter-search .filter-input {
    background-color: var(--bg-card);
    color: var(--text-primary);
    border-color: var(--border-color);
}

[data-theme="dark"] .filter-search .filter-input::placeholder {
    color: var(--text-muted);
}

[data-theme="dark"] .filter-search-btn {
    background-color: var(--bg-card);
    border-color: var(--border-color);
    color: var(--text-muted);
}

[data-theme="dark"] .filter-search-btn:hover {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: #fff;
}

[data-theme="dark"] .filter-reset {
    border-color: var(--border-color);
    color: var(--text-muted);
}


/* -- 15. 토스트 알림 -- */

.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, #2563eb); }


/* -- 16. 로딩 오버레이 -- */

#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, #2563eb);
    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);
}


/* -- 17. 확인 모달 -- */

#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);
}


/* -- 18. 모바일 카드뷰 -- */

.mobile-card {
    display: none;
}

@media (max-width: 768px) {
    .mobile-card {
        display: block;
    }
    .mobile-card-item {
        background: var(--bg-card);
        border-radius: var(--radius-md);
        box-shadow: var(--shadow-sm);
        padding: var(--space-4);
        margin-bottom: var(--space-3);
        border: 1px solid var(--border-light);
    }
    .mobile-card-row {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: var(--space-2) 0;
        border-bottom: 1px solid var(--border-light);
        font-size: var(--font-size-sm);
    }
    .mobile-card-row:last-child { border-bottom: none; }
    .mobile-card-label {
        color: var(--text-muted);
        font-size: var(--font-size-xs);
        font-weight: var(--font-weight-medium);
    }
    .mobile-card-value {
        font-weight: var(--font-weight-medium);
        color: var(--text-primary);
    }
    .desktop-table { display: none !important; }
}


/* -- 19. 회원 검색 자동완성 -- */

.user-search-wrapper {
    position: relative;
}

.user-search-dropdown {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    z-index: 1050;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-top: none;
    border-radius: 0 0 var(--radius-md) var(--radius-md);
    box-shadow: var(--shadow-lg);
    max-height: 280px;
    overflow-y: auto;
}

.user-search-dropdown.show {
    display: block;
}

.user-search-item {
    padding: var(--space-3) var(--space-4);
    cursor: pointer;
    border-bottom: 1px solid var(--border-light);
    transition: background-color var(--transition-fast);
}

.user-search-item:last-child {
    border-bottom: none;
}

.user-search-item:hover,
.user-search-item.active {
    background-color: var(--color-primary-bg);
}

.user-search-item-main {
    font-size: var(--font-size-sm);
    color: var(--text-primary);
    line-height: 1.4;
}

.user-search-name {
    font-weight: var(--font-weight-semibold);
}

.user-search-id {
    color: var(--text-muted);
    font-size: var(--font-size-xs);
}

.user-search-item-sub {
    font-size: var(--font-size-xs);
    color: var(--text-muted);
    margin-top: 2px;
}

.user-search-empty {
    padding: var(--space-4);
    text-align: center;
    color: var(--text-muted);
    font-size: var(--font-size-sm);
}

/* 선택된 회원 배지 */
.selected-user-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    background: var(--color-primary-bg);
    color: var(--color-primary);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    margin-top: var(--space-2);
}

.selected-user-badge .selected-user-remove {
    cursor: pointer;
    opacity: 0.6;
    font-size: var(--font-size-xs);
    transition: opacity var(--transition-fast);
}

.selected-user-badge .selected-user-remove:hover {
    opacity: 1;
}

/* 다크모드 */
[data-theme="dark"] .user-search-dropdown {
    background: var(--bg-card);
    border-color: var(--border-color);
}

[data-theme="dark"] .user-search-item:hover,
[data-theme="dark"] .user-search-item.active {
    background-color: rgba(37, 99, 235, 0.1);
}

[data-theme="dark"] .selected-user-badge {
    background: rgba(37, 99, 235, 0.15);
    color: var(--color-primary-light);
}
