/* ============================================
   Player Export Page - 다운로드 도구 중심 디자인
   ============================================ */

:root {
    --export-text-primary: #1A1A1A;
    --export-text-secondary: #4A5568;
    --export-text-muted: #718096;
    --export-border: #E2E8F0;
    --export-bg-primary: #FFFFFF;
    --export-bg-hover: #F7FAFC;
    --export-accent: #3B82F6;
    --export-accent-hover: #2563EB;
}

/* ============================================
   히어로 섹션 (sticky)
   ============================================ */
.export-hero {
    position: sticky;
    top: 56px; /* 헤더 높이 */
    z-index: 102;
    padding: 1.25rem 0;
    border-bottom: 1px solid var(--export-border);
    background: var(--export-bg-primary);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
    margin-bottom: 0.75rem;
}

.export-hero-content {
    max-width: 1080px;
    margin: 0 auto;
    padding: 0 1rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1.5rem;
}

.export-hero-text {
    flex: 1;
}

.export-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--export-text-primary);
    margin: 0 0 0.5rem 0;
    line-height: 1.2;
}

.export-description {
    font-size: 0.875rem;
    color: var(--export-text-secondary);
    margin: 0;
    line-height: 1.5;
}

.export-status {
    flex-shrink: 0;
}

.export-status-text {
    font-size: 0.875rem;
    color: var(--export-text-secondary);
}

.export-status-text strong {
    font-weight: 700;
    color: var(--export-accent);
}

/* ============================================
   작업 툴바 (sticky)
   ============================================ */
.export-toolbar {
    position: sticky;
    top: 145px; /* 헤더(56px) + 히어로(약 89px) = 약 145px */
    z-index: 101;
    padding: 1rem 0;
    background: var(--export-bg-primary);
    border-bottom: 1px solid var(--export-border);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
    margin-bottom: 0.75rem;
}

.export-toolbar-content {
    max-width: 1080px;
    margin: 0 auto;
    padding: 0 1rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
}

.export-search {
    position: relative;
    flex: 1;
    max-width: 400px;
}

.export-search-icon {
    position: absolute;
    left: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--export-text-muted);
    font-size: 0.875rem;
    z-index: 1;
}

.export-search-input {
    width: 100%;
    padding: 0.625rem 0.75rem 0.625rem 2.25rem;
    font-size: 0.875rem;
    border: 1px solid var(--export-border);
    border-radius: 4px;
    background: var(--export-bg-primary);
    color: var(--export-text-primary);
    transition: all 0.2s;
}

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

.export-search-input:focus {
    outline: none;
    border-color: var(--export-accent);
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.export-actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    position: relative;
}

.export-btn {
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
    font-weight: 600;
    border: 1px solid var(--export-border);
    border-radius: 4px;
    background: var(--export-bg-primary);
    color: var(--export-text-primary);
    cursor: pointer;
    transition: all 0.2s;
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    white-space: nowrap;
}

.export-btn:hover:not(:disabled) {
    background: var(--export-bg-hover);
    border-color: var(--export-text-secondary);
}

.export-btn:active:not(:disabled) {
    background: #EDF2F7;
}

.export-btn-secondary {
    border-color: var(--export-border);
    background: var(--export-bg-primary);
}

.export-btn-primary {
    background: var(--export-accent);
    border-color: var(--export-accent);
    color: white;
}

.export-btn-primary:hover:not(:disabled) {
    background: var(--export-accent-hover);
    border-color: var(--export-accent-hover);
    color: white;
}

.export-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.export-btn-hint {
    position: absolute;
    top: calc(100% + 0.25rem);
    right: 0;
    font-size: 0.75rem;
    color: var(--export-text-muted);
    white-space: nowrap;
}

/* ============================================
   포지션 필터 (sticky)
   ============================================ */
.export-position-filters {
    position: sticky;
    top: 120px; /* 헤더 + 툴바 높이 */
    z-index: 99;
    padding: 0.75rem 0;
    background: var(--export-bg-hover);
    border-bottom: 1px solid var(--export-border);
}

.export-position-filters-content {
    max-width: 1080px;
    margin: 0 auto;
    padding: 0 1rem;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.export-filter-label {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--export-text-secondary);
    white-space: nowrap;
}

.export-filter-checkboxes {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.export-filter-checkbox {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.8125rem;
    color: var(--export-text-primary);
    cursor: pointer;
    user-select: none;
}

.export-filter-checkbox input[type="checkbox"] {
    width: 16px;
    height: 16px;
    cursor: pointer;
    margin: 0;
}

.export-filter-checkbox:hover {
    color: var(--export-accent);
}

/* ============================================
   테이블 카드
   ============================================ */
.export-table-wrapper {
    padding: 1.5rem 0;
    max-width: 1080px;
    margin: 0 auto;
}

.export-table-card {
    background: var(--export-bg-primary);
    border: 1px solid var(--export-border);
    border-radius: 6px;
    position: relative;
    overflow-x: auto;
}

.export-table-container {
    position: relative;
}

.export-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    font-size: 0.875rem;
}

.export-table thead.export-table-header {
    background: var(--export-bg-hover);
    border-bottom: 1px solid var(--export-border);
}

.export-table thead.export-table-header tr {
    background: var(--export-bg-hover);
}

.export-table th {
    padding: 0.75rem 1rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--export-text-secondary);
    text-align: left;
    white-space: nowrap;
    vertical-align: middle;
    background: var(--export-bg-hover);
}

.export-table th.sortable {
    cursor: pointer;
    user-select: none;
    transition: background-color 0.2s;
}

.export-table th.sortable:hover {
    background: rgba(0, 0, 0, 0.02);
}

.export-table th.export-col-score,
.export-table th.export-col-games,
.export-table th.export-col-wins,
.export-table th.export-col-losses {
    text-align: right;
}

.sort-indicator {
    font-size: 0.75rem;
    color: var(--export-text-muted);
    opacity: 0.5;
    transition: opacity 0.2s;
}

.export-table tbody tr {
    border-bottom: 1px solid var(--export-border);
    transition: background-color 0.2s;
    cursor: pointer;
}

.export-table tbody tr:last-child {
    border-bottom: none;
}

.export-table tbody tr:hover {
    background: var(--export-bg-hover);
}

.export-table tbody tr.hidden {
    display: none;
}

.export-table td {
    padding: 0.75rem 1rem;
    color: var(--export-text-primary);
    vertical-align: middle;
}

.export-table td.export-col-score,
.export-table td.export-col-games,
.export-table td.export-col-wins,
.export-table td.export-col-losses {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

/* 체크박스 컬럼 */
.export-col-checkbox {
    width: 50px;
    text-align: center;
}

.export-col-checkbox input[type="checkbox"] {
    cursor: pointer;
    width: 18px;
    height: 18px;
}

/* 이름 컬럼 */
.export-col-name {
    min-width: 200px;
}

.player-name-text {
    word-break: break-word;
    white-space: normal;
    display: block;
    font-weight: 600;
    color: var(--export-text-primary);
}

/* 점수/게임수/승/패 컬럼 */
.export-col-score,
.export-col-games {
    width: 100px;
    font-weight: 600;
}

.export-col-wins,
.export-col-losses {
    width: 80px;
}

/* 주/부 컬럼 */
.export-col-mainline,
.export-col-subline {
    width: 100px;
    text-align: left;
}

.role-tag {
    display: inline-block;
    padding: 0.125rem 0.5rem;
    border-radius: 3px;
    font-size: 0.75rem;
    background: var(--export-bg-hover);
    color: var(--export-text-secondary);
    font-weight: 500;
    white-space: nowrap;
}

/* 빈 상태 */
.export-empty {
    padding: 3rem 1rem;
    text-align: center;
    color: var(--export-text-muted);
    font-size: 0.875rem;
}

.export-empty-search {
    padding: 2rem 1rem;
    text-align: center;
    color: var(--export-text-muted);
    font-size: 0.875rem;
}

.export-empty-search p {
    margin: 0;
}

/* ============================================
   Responsive
   ============================================ */
@media (max-width: 992px) {
    .export-hero-content {
        flex-direction: column;
        align-items: flex-start;
        gap: 1rem;
    }
    
    .export-toolbar-content {
        flex-direction: column;
        align-items: stretch;
        gap: 1rem;
    }
    
    .export-search {
        max-width: 100%;
    }
    
    .export-actions {
        flex-wrap: wrap;
        width: 100%;
    }
    
    .export-btn {
        flex: 1;
        min-width: 0;
    }
}

@media (max-width: 768px) {
    .export-hero {
        padding: 1.25rem 0;
    }
    
    .export-title {
        font-size: 1.25rem;
    }
    
    .export-table-wrapper {
        padding: 1rem 0;
    }
    
    .export-table-card {
        border-left: none;
        border-right: none;
        border-radius: 0;
    }
    
    /* 모바일에서 일부 컬럼 숨김 */
    .export-col-mainline,
    .export-col-subline {
        display: none;
    }
    
    .export-table th,
    .export-table td {
        padding: 0.625rem 0.75rem;
        font-size: 0.8125rem;
    }
}
