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

/* ============================================
   작업 툴바 (플레이어 목록 탭 전용)
   ============================================ */
.export-toolbar {
    position: sticky;
    top: 195px;
    z-index: 100;
    padding: 0.75rem 0;
    background: var(--export-bg-primary);
    border-bottom: 1px solid var(--export-border);
    margin-bottom: 0.75rem;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.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;
    flex-wrap: wrap;
}


.export-btn {
    padding: 0.375rem 0.75rem;
    font-size: 0.8125rem;
    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;
}

.export-btn-small {
    padding: 0.375rem 0.75rem;
    font-size: 0.8125rem;
    font-weight: 500;
    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;
}

/* 저장하기, 불러오기, 다운로드 버튼 숨김 */
#btnSaveSelection,
#btnLoadSelection,
#btnDownload {
    display: none !important;
}

.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;
}

/* ============================================
   탭 전환
   ============================================ */
.export-tabs-wrapper {
    position: sticky;
    top: 145px;
    z-index: 101;
    max-width: 1080px;
    margin: 0 auto;
    padding: 0 1rem;
    margin-bottom: 1rem;
    background: var(--export-bg-primary);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.export-tabs {
    display: flex;
    gap: 0.5rem;
    border-bottom: 2px solid var(--export-border);
}

.export-tab {
    padding: 0.75rem 1.5rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--export-text-secondary);
    background: transparent;
    border: none;
    border-bottom: 2px solid transparent;
    cursor: pointer;
    transition: all 0.2s;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: -2px;
}

.export-tab:hover {
    color: var(--export-text-primary);
}

.export-tab.active {
    color: var(--export-accent);
    border-bottom-color: var(--export-accent);
}

.export-tab-content {
    display: none;
}

.export-tab-content.active {
    display: block;
}

/* ============================================
   팀 생성 결과
   ============================================ */
.team-build-wrapper {
    width: 100%;
    display: flex;
    flex-direction: column;
}

.team-build-controls {
    background: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%);
    border: 1px solid var(--export-border);
    border-radius: 10px;
    padding: 1rem;
    margin-bottom: 1.5rem;
    display: flex;
    gap: 1rem;
    align-items: center;
    flex-wrap: wrap;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.team-build-settings {
    display: flex;
    gap: 1rem;
    align-items: center;
    flex-wrap: wrap;
    flex: 1;
}

.team-build-setting-group {
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
    min-width: 120px;
}

.team-build-label {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--export-text-primary);
    white-space: nowrap;
    letter-spacing: 0.3px;
}

.team-build-select,
.team-build-input {
    padding: 0.5rem 0.75rem;
    font-size: 0.8125rem;
    border: 1.5px solid var(--export-border);
    border-radius: 6px;
    background: white;
    color: var(--export-text-primary);
    transition: all 0.2s;
    width: 100%;
    font-weight: 500;
}

.team-build-select:hover,
.team-build-input:hover {
    border-color: var(--export-accent);
    box-shadow: 0 2px 4px rgba(59, 130, 246, 0.1);
}

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

.team-build-input {
    -moz-appearance: textfield;
}

.team-build-input::-webkit-outer-spin-button,
.team-build-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.team-build-actions {
    display: flex;
    gap: 0.625rem;
    flex-wrap: wrap;
    align-items: flex-end;
}

.team-build-action-btn {
    padding: 0.5rem 1rem;
    font-size: 0.8125rem;
    font-weight: 600;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.2s;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    white-space: nowrap;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.08);
}

.team-build-action-btn-primary {
    background: linear-gradient(135deg, var(--export-accent) 0%, var(--export-accent-hover) 100%);
    color: white;
}

.team-build-action-btn-primary:hover {
    background: linear-gradient(135deg, var(--export-accent-hover) 0%, var(--export-accent) 100%);
    box-shadow: 0 4px 8px rgba(59, 130, 246, 0.25);
    transform: translateY(-1px);
}

.team-build-action-btn-primary:active {
    transform: translateY(0);
}

.team-build-action-btn-secondary {
    background: white;
    color: var(--export-text-primary);
    border: 1.5px solid var(--export-border);
}

.team-build-action-btn-secondary:hover {
    background: var(--export-bg-hover);
    border-color: var(--export-accent);
    color: var(--export-accent);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}

.team-build-action-btn i {
    font-size: 0.875rem;
}

.team-result-container {
    position: relative;
    min-height: 400px;
    display: flex;
    flex-direction: column;
}

.team-result-loading-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999;
}

.team-result-loading-content {
    background: var(--export-bg-primary);
    padding: 2rem 3rem;
    border-radius: 8px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    text-align: center;
    color: var(--export-text-primary);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

.team-result-loading-content i {
    font-size: 2rem;
    color: var(--export-accent);
}

.team-result-loading-content p {
    margin: 0;
    font-size: 1rem;
    font-weight: 500;
}

.team-result-content {
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.team-result-empty {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--export-text-muted);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 300px;
}

.team-result-empty i {
    font-size: 2rem;
    margin-bottom: 0.75rem;
    color: var(--export-text-secondary);
    opacity: 0.5;
}

.team-result-empty p {
    margin: 0;
    font-size: 0.875rem;
}

/* game_card 구조 사용 */
.team-build-teams {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.75rem;
    border: 1px solid var(--export-border);
    border-radius: 6px;
    padding: 0.75rem;
    background: var(--export-bg-primary);
    flex: 1;
    min-height: 0;
    overflow-y: auto;
}

.team-build-teams .team-section {
    border-left: 3px solid;
    padding-left: var(--spacing-sm, 0.5rem);
    min-width: 0;
}

.team-build-teams .team-blue {
    border-left-color: #4299E1;
}

.team-build-teams .team-red {
    border-left-color: #F56565;
}

.team-build-teams .team-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-sm, 0.5rem);
    padding-bottom: var(--spacing-xs, 0.25rem);
    border-bottom: 1px solid var(--export-border);
}

.team-build-teams .team-label {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs, 0.25rem);
    flex: 1;
    min-width: 0;
}

.team-build-teams .team-name {
    font-size: 0.875rem;
    font-weight: 700;
    padding: 0.375rem 0.75rem;
    border-radius: 6px;
    display: inline-block;
    color: white;
}

.team-build-teams .team-blue .team-name {
    background-color: #4299E1;
    box-shadow: 0 2px 4px rgba(66, 153, 225, 0.2);
}

.team-build-teams .team-red .team-name {
    background-color: #F56565;
    box-shadow: 0 2px 4px rgba(245, 101, 101, 0.2);
}

.team-build-teams .team-score-compact {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    align-items: flex-end;
    text-align: right;
}

.team-build-teams .team-score-row {
    display: flex;
    align-items: baseline;
    gap: 0.25rem;
}

.team-build-teams .team-avg-score {
    font-size: 1rem;
    font-weight: 700;
    color: var(--export-text-primary);
    line-height: 1;
    font-variant-numeric: tabular-nums;
}

.team-build-teams .team-score-unit {
    font-size: 0.75rem;
    color: var(--export-text-secondary);
    font-weight: 500;
}

.team-build-teams .team-score-label-inline {
    font-size: 0.6875rem;
    color: var(--export-text-muted, #718096);
    margin-left: 0.25rem;
}

.balance-value-separator {
    margin: 0 0.125rem;
    color: var(--export-text-muted);
    font-size: 0.875rem;
}

.balance-value-label {
    font-size: 0.75rem;
    color: var(--export-text-muted);
    margin: 0 0.125rem;
}

.balance-value-inline {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--export-text-primary);
    margin: 0 0.125rem;
}

#scoreDiffAdjusted {
    display: inline;
    margin-left: 0.5rem;
    font-size: 0.875rem;
    color: var(--export-text-secondary);
    font-weight: 500;
}

.team-stats-inline {
    margin-bottom: var(--spacing-sm, 0.5rem);
    font-size: 0.8125rem;
    color: var(--export-text-secondary);
}

.team-stat-inline {
    display: inline-block;
}

.team-stat-inline strong {
    color: var(--export-text-primary);
    font-weight: 600;
}

.team-build-teams .players-list {
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
}

.team-build-teams .player-row {
    display: flex;
    text-decoration: none;
    color: inherit;
    border-radius: 2px;
    transition: all 0.2s;
    min-width: 0;
    padding: 0.375rem 0.5rem;
}

.team-build-teams .player-row:hover {
    background: var(--export-bg-hover);
    text-decoration: none;
    color: inherit;
}

.team-build-teams .player-champion-row {
    display: flex;
    gap: 0.5rem;
    width: 100%;
    align-items: flex-start;
}

.team-build-teams .player-info {
    height: 100%;
    width: 100%;
    display: flex;
    align-items: flex-start;
    flex-direction: column;
    justify-content: center;
}

.team-build-teams .player-first-line,
.team-build-teams .player-second-line {
    flex: 1;
    min-width: 0;
    width: 100%;
}

.team-build-teams .player-first-line {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--spacing-xs, 0.25rem);
    line-height: 1.2;
    margin-bottom: 0.25rem;
}

.team-build-teams .player-champion-role {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    flex: 1;
    min-width: 0;
}

.team-build-teams .player-role {
    font-size: 0.6875rem;
    color: var(--export-text-secondary);
    padding: 0.125rem 0.375rem;
    background: var(--export-bg-hover);
    border-radius: 2px;
    white-space: nowrap;
    font-weight: 500;
    line-height: 1.2;
}

.team-build-teams .player-role-assigned {
    background: var(--export-accent);
    color: white;
    font-weight: 600;
}

/* 주포/부포/오프롤 색상 구분 */
.team-build-teams .player-role-assigned.player-role-main {
    background: #16A34A;  /* 초록색 - 주포 */
    color: white;
    font-weight: 700;
}

.team-build-teams .player-role-assigned.player-role-sub {
    background: #3B82F6;  /* 파란색 - 부포 */
    color: white;
    font-weight: 600;
}

.team-build-teams .player-role-assigned.player-role-offrole {
    background: #D97706;  /* 주황색 - 오프롤 */
    color: white;
    font-weight: 500;
}

/* 배정 타입 배지 */
.assignment-badge {
    display: inline-block;
    padding: 0.125rem 0.375rem;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: 600;
    margin-left: 0.5rem;
    vertical-align: middle;
}

.assignment-badge-main {
    background-color: rgba(22, 163, 74, 0.1);
    color: #16A34A;
    border: 1px solid rgba(22, 163, 74, 0.3);
}

.assignment-badge-sub {
    background-color: rgba(59, 130, 246, 0.1);
    color: #3B82F6;
    border: 1px solid rgba(59, 130, 246, 0.3);
}

.assignment-badge-offrole {
    background-color: rgba(217, 119, 6, 0.1);
    color: #D97706;
    border: 1px solid rgba(217, 119, 6, 0.3);
}

.team-build-teams .player-role-original {
    font-size: 0.625rem;
    color: var(--export-text-muted);
    background: transparent;
    padding: 0;
}

.team-build-teams .player-role-main-badge {
    font-size: 0.625rem;
    color: var(--export-text-primary);
    background: var(--export-bg-hover);
    border: 1px solid var(--export-border);
    border-radius: 3px;
    padding: 0.125rem 0.375rem;
    margin-left: 0.25rem;
    font-weight: 500;
    white-space: nowrap;
}

.team-build-teams .player-scores {
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.team-build-teams .player-score {
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.team-build-teams .player-score-adjusted {
    font-size: 0.625rem;
    color: var(--export-text-muted);
    font-weight: 500;
    margin-left: 0.125rem;
}

.team-build-teams .player-score {
    font-weight: 600;
    color: #0d47a1;
    background: #e8f0fe;
    border-radius: 12px;
    padding: 0.125rem 0.5rem;
    font-size: 0.75rem;
    line-height: 1.2;
    white-space: nowrap;
}

/* 배정 타입에 따른 점수 색상 */
.team-build-teams .player-score-main {
    background: #16A34A;  /* 초록색 - 주포 */
    color: white;
}

.team-build-teams .player-score-sub {
    background: #3B82F6;  /* 파란색 - 부포 */
    color: white;
}

.team-build-teams .player-score-offrole {
    background: #D97706;  /* 주황색 - 오프롤 */
    color: white;
}

.team-build-teams .score-unit {
    font-size: 0.625rem;
    margin-left: 0.125rem;
}

.team-build-teams .player-second-line {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--spacing-xs, 0.25rem);
    line-height: 1.2;
}

.team-build-teams .player-name {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--export-text-primary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
    min-width: 0;
}

.team-build-teams .player-name-link {
    color: var(--export-text-primary);
    text-decoration: none;
    transition: all 0.2s;
    cursor: pointer;
}

.team-build-teams .player-name-link:hover {
    color: var(--export-accent);
    text-decoration: underline;
}

.team-build-teams .player-wr {
    font-size: 0.75rem;
    color: var(--export-text-secondary);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}

.team-balance-info {
    background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%);
    border: 2px solid var(--export-border);
    border-radius: 12px;
    padding: 1rem 1.25rem;
    margin-bottom: 1rem;
    flex-shrink: 0;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.balance-stats-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    gap: 1rem;
}

.balance-stats-left {
    display: flex;
    gap: 2rem;
    align-items: center;
    flex: 1;
}

.balance-stats-right {
    display: flex;
    gap: 2rem;
    align-items: center;
    justify-content: flex-end;
}

.feedback-buttons {
    display: flex;
    gap: 0.5rem;
    align-items: center;
}

.feedback-btn {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.375rem 0.625rem;
    border-radius: 4px;
    font-weight: 500;
    font-size: 0.75rem;
    cursor: pointer;
    border: 1px solid var(--export-border);
    background: rgba(100, 116, 139, 0.1);  /* 옅은 배경색 */
    color: var(--export-text-primary);
    transition: all 0.2s;
    user-select: none;
}

.feedback-btn:hover {
    background: rgba(100, 116, 139, 0.2);  /* 호버 시 조금 더 진한 배경 */
    border-color: var(--export-accent);
}

.feedback-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    background: rgba(100, 116, 139, 0.05);  /* 비활성화 시 더 옅은 배경 */
}

.feedback-btn i {
    font-size: 0.75rem;
}

.feedback-like {
    /* 단순한 스타일 - 색상 없이 */
}

.feedback-like:hover {
    /* 단순한 스타일 - 색상 없이 */
}

.feedback-dislike {
    /* 단순한 스타일 - 색상 없이 */
}

.feedback-dislike:hover {
    /* 단순한 스타일 - 색상 없이 */
}

.balance-stat {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

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

.balance-value {
    font-size: 1rem;
    font-weight: 700;
    color: var(--export-accent);
    font-variant-numeric: tabular-nums;
    padding: 0.25rem 0.5rem;
    background: rgba(59, 130, 246, 0.1);
    border-radius: 6px;
    display: inline-block;
    min-width: 50px;
    text-align: center;
}

.balance-value-warning {
    color: #D97706 !important;
}

.balance-warning {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1rem;
    background: rgba(217, 119, 6, 0.1);
    border: 1px solid #D97706;
    border-radius: 4px;
    color: #D97706;
    font-size: 0.875rem;
    font-weight: 600;
}

.balance-warning i {
    font-size: 1rem;
}

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

    /* 팀 생성 결과 반응형 */
    .team-build-teams {
        grid-template-columns: 1fr;
    }

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

    .team-build-settings {
        flex-direction: column;
        width: 100%;
    }

    .team-build-setting-group {
        width: 100%;
    }

    .team-build-actions {
        width: 100%;
        justify-content: stretch;
    }

    .team-build-action-btn {
        flex: 1;
    }

    .team-balance-info {
        flex-direction: column;
        gap: 1rem;
    }

    .export-save-load-group {
        width: 100%;
        justify-content: flex-start;
    }
}

/* ============================================
   저장된 선택 목록 모달
   ============================================ */
.saved-selections-modal {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2000;
}

.saved-selections-modal-content {
    background: var(--export-bg-primary);
    border-radius: 8px;
    width: 90%;
    max-width: 600px;
    max-height: 80vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
}

.saved-selections-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.5rem;
    border-bottom: 1px solid var(--export-border);
}

.saved-selections-modal-header h3 {
    margin: 0;
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--export-text-primary);
}

.saved-selections-modal-close {
    background: none;
    border: none;
    font-size: 1.5rem;
    color: var(--export-text-secondary);
    cursor: pointer;
    padding: 0;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 4px;
    transition: all 0.2s;
}

.saved-selections-modal-close:hover {
    background: var(--export-bg-hover);
    color: var(--export-text-primary);
}

.saved-selections-list {
    padding: 1rem;
    overflow-y: auto;
    flex: 1;
}

.saved-selection-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem;
    border: 1px solid var(--export-border);
    border-radius: 6px;
    margin-bottom: 0.75rem;
    transition: all 0.2s;
}

.saved-selection-item:hover {
    background: var(--export-bg-hover);
    border-color: var(--export-accent);
}

.saved-selection-info {
    flex: 1;
    min-width: 0;
}

.saved-selection-name {
    font-weight: 600;
    color: var(--export-text-primary);
    margin-bottom: 0.25rem;
    font-size: 0.9375rem;
}

.saved-selection-meta {
    font-size: 0.8125rem;
    color: var(--export-text-muted);
}

.saved-selection-actions {
    display: flex;
    gap: 0.5rem;
    flex-shrink: 0;
}

.btn-load-saved,
.btn-delete-saved {
    padding: 0.375rem 0.75rem;
    font-size: 0.8125rem;
    font-weight: 600;
    border: 1px solid var(--export-border);
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.2s;
}

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

.btn-load-saved:hover {
    background: var(--export-accent-hover);
    border-color: var(--export-accent-hover);
}

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

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

/* ============================================
   플레이어 가공 탭
   ============================================ */
/* ============================================
   플레이어 정보 수정 사이드 패널
   ============================================ */
.player-edit-sidepanel {
    position: fixed;
    top: 0;
    right: -100%;
    width: 100%;
    max-width: 600px;
    height: 100vh;
    z-index: 1000;
    transition: right 0.3s ease-in-out;
    pointer-events: none;
}

.player-edit-sidepanel.active {
    right: 0;
    pointer-events: auto;
}

.player-edit-sidepanel-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background: rgba(0, 0, 0, 0.5);
    opacity: 0;
    transition: opacity 0.3s ease-in-out;
    pointer-events: none;
}

.player-edit-sidepanel.active .player-edit-sidepanel-overlay {
    opacity: 1;
    pointer-events: auto;
}

.player-edit-sidepanel-content {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    max-width: 600px;
    height: 100vh;
    background: var(--export-bg-primary);
    box-shadow: -2px 0 8px rgba(0, 0, 0, 0.15);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.player-edit-sidepanel-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid var(--export-border);
    flex-shrink: 0;
    background: var(--export-bg-hover);
}

.player-edit-sidepanel-header h2 {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--export-text-primary);
    margin: 0;
}

.player-edit-sidepanel-close {
    background: none;
    border: none;
    color: var(--export-text-secondary);
    cursor: pointer;
    padding: 0.5rem;
    border-radius: 4px;
    transition: all 0.2s;
    font-size: 1.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
}

.player-edit-sidepanel-close:hover {
    background: var(--export-bg-hover);
    color: var(--export-text-primary);
}

.player-edit-sidepanel-body {
    flex: 1;
    overflow-y: auto;
    padding: 1rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.player-edit-sidepanel-body .player-edit-actions {
    flex-shrink: 0;
    margin-bottom: 0;
}

.player-edit-table-wrapper {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
}

.player-edit-table-card {
    background: var(--export-bg-primary);
    border: 1px solid var(--export-border);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.player-edit-table {
    width: 100%;
    border-collapse: collapse;
}

.player-edit-table thead {
    background: linear-gradient(135deg, var(--export-accent) 0%, var(--export-accent-hover) 100%);
    position: sticky;
    top: 0;
    z-index: 10;
}

.player-edit-table th {
    padding: 0.75rem 1rem;
    text-align: left;
    font-weight: 600;
    font-size: 0.8125rem;
    color: white;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-bottom: 2px solid rgba(255, 255, 255, 0.2);
}

.player-edit-table tbody tr {
    border-bottom: 1px solid var(--export-border);
    transition: all 0.2s;
}

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

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

.player-edit-row {
    cursor: pointer;
}

.player-edit-col-name {
    font-weight: 600;
    color: var(--export-text-primary);
    min-width: 120px;
}

.player-edit-name-cell {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-weight: 600;
    color: var(--export-text-primary);
}

.player-edit-col-mainline,
.player-edit-col-subline {
    min-width: 100px;
}

.player-edit-col-mainscore,
.player-edit-col-subscore {
    min-width: 100px;
}

.player-edit-select,
.player-edit-input {
    width: 100%;
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--export-border);
    border-radius: 6px;
    font-size: 0.875rem;
    color: var(--export-text-primary);
    background: var(--export-bg-primary);
    transition: all 0.2s;
}

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

.player-edit-select:hover {
    border-color: var(--export-accent-hover);
}

.player-edit-table td {
    padding: 0.75rem 1rem;
    vertical-align: middle;
}

.player-edit-wrapper {
    width: 100%;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.player-edit-header {
    margin-bottom: 0.5rem;
    flex-shrink: 0;
}

.player-edit-header h2 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--export-text-primary);
    margin: 0 0 0.25rem 0;
}

.player-edit-header p {
    color: var(--export-text-secondary);
    margin: 0;
    font-size: 0.75rem;
}

.player-edit-actions {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
    justify-content: flex-end;
    flex-shrink: 0;
}

.player-edit-table-wrapper {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
}

.player-edit-table-card {
    background: var(--export-bg-primary);
    border: 1px solid var(--export-border);
    border-radius: 6px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    max-height: 100%;
}

.player-edit-table {
    width: 100%;
    border-collapse: collapse;
}

.player-edit-table thead {
    background: var(--export-bg-hover);
}

.player-edit-table th {
    padding: 0.5rem 0.625rem;
    text-align: left;
    font-weight: 600;
    font-size: 0.75rem;
    color: var(--export-text-secondary);
    border-bottom: 2px solid var(--export-border);
    position: sticky;
    top: 0;
    background: var(--export-bg-hover);
    z-index: 1;
}

.player-edit-table td {
    padding: 0.5rem 0.625rem;
    border-bottom: 1px solid var(--export-border);
    font-size: 0.8125rem;
}

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

.player-edit-table tbody tr:last-child td {
    border-bottom: none;
}

.player-edit-col-name {
    font-weight: 600;
    color: var(--export-text-primary);
    min-width: 150px;
}

.player-edit-col-mainline,
.player-edit-col-subline {
    min-width: 120px;
}

.player-edit-col-mainscore,
.player-edit-col-subscore {
    min-width: 100px;
}

.player-edit-select,
.player-edit-input {
    width: 100%;
    padding: 0.5rem 0.75rem;
    border: 1px solid var(--export-border);
    border-radius: 4px;
    font-size: 0.9375rem;
    color: var(--export-text-primary);
    background: var(--export-bg-primary);
    transition: all 0.2s;
}

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

.player-edit-select:hover {
    border-color: var(--export-accent-hover);
}

.player-edit-input {
    font-family: inherit;
}

/* ============================================
   팀 생성 전체 컨테이너
   ============================================ */
.team-build-full-container {
    max-width: 1080px;
    margin: 0 auto;
    padding: 1rem;
    position: relative;
}

.team-build-header-actions {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 1rem;
}

/* ============================================
   선택된 플레이어 목록 패널
   ============================================ */
.selected-players-panel {
    position: sticky;
    top: 255px;
    z-index: 99;
    background: var(--export-bg-primary);
    border-bottom: 1px solid var(--export-border);
    margin-bottom: 0.75rem;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.selected-players-content {
    max-width: 1080px;
    margin: 0 auto;
    padding: 0 1rem;
}

.selected-players-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.625rem 0;
    border-bottom: 1px solid var(--export-border);
    flex-wrap: wrap;
    gap: 0.5rem;
}

.selected-players-header-actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.selected-players-title {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--export-text-primary);
    margin: 0;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}


.selected-players-title i {
    color: var(--export-accent);
}

.selected-players-toggle {
    background: none;
    border: none;
    color: var(--export-text-secondary);
    cursor: pointer;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    transition: all 0.2s;
    font-size: 0.875rem;
}

.selected-players-toggle:hover {
    background: var(--export-bg-hover);
    color: var(--export-text-primary);
}

.selected-players-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.375rem;
    padding: 0.625rem 0;
    max-height: 300px;
    overflow-y: auto;
}

.selected-player-item {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.375rem 0.5rem;
    background: var(--export-bg-hover);
    border: 1px solid var(--export-border);
    border-radius: 4px;
    font-size: 0.8125rem;
    transition: all 0.2s;
}

.selected-player-item:hover {
    border-color: var(--export-accent);
    background: #EBF4FF;
}

.selected-player-info {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.selected-player-name {
    font-weight: 600;
    color: var(--export-text-primary);
}

.selected-player-meta {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    color: var(--export-text-secondary);
    font-size: 0.75rem;
}

.selected-player-score {
    color: var(--export-accent);
    font-weight: 500;
}

.selected-player-roles {
    color: var(--export-text-muted);
}

.selected-player-remove {
    background: none;
    border: none;
    color: var(--export-text-muted);
    cursor: pointer;
    padding: 0.125rem;
    border-radius: 3px;
    transition: all 0.2s;
    font-size: 0.6875rem;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

.selected-player-remove:hover {
    background: #FEE2E2;
    color: #DC2626;
}
