/**
 * 통합 테마 시스템 + 반응형 UX
 * - 클래스 기반 테마 제어 (html.dark-theme, html.light-theme)
 * - 시스템 설정 감지는 초기값 설정에만 사용
 * - 반응형 브레이크포인트:
 *   - 모바일: 320px ~ 767px
 *   - 태블릿: 768px ~ 1023px
 *   - 데스크톱: 1024px 이상
 * - 터치 친화적 디자인 (최소 44x44px 터치 영역)
 */

/* ============================================
   기본 변수 정의 (CSS Custom Properties)
   ============================================ */
:root {
    /* 라이트 테마 색상 팔레트 - 광고 관리 시스템에 최적화 */
    
    /* 배경 색상 */
    --bg-primary: #ffffff;                    /* 메인 배경 (순수 흰색) */
    --bg-secondary: #f5f7fa;                  /* 보조 배경 (연한 회청색) */
    --bg-tertiary: #e8ecf1;                   /* 3차 배경 (더 연한 회청색) */
    --bg-accent: #f0f4f8;                     /* 강조 배경 (아주 연한 파란 회색) */
    
    /* 텍스트 색상 */
    --text-primary: #1a202c;                   /* 주요 텍스트 (거의 검정) */
    --text-secondary: #4a5568;                 /* 보조 텍스트 (중간 회색) */
    --text-muted: #718096;                    /* 비활성 텍스트 (연한 회색) */
    --text-inverse: #ffffff;                  /* 반전 텍스트 (흰색) */
    
    /* 경계선 색상 */
    --border-color: #e2e8f0;                  /* 기본 경계선 (연한 회청색) */
    --border-light: #f1f5f9;                  /* 가벼운 경계선 */
    --border-dark: #cbd5e0;                   /* 진한 경계선 */
    
    /* 네비게이션 바 */
    --navbar-bg: #2563eb;                     /* 네비게이션 배경 (프로페셔널 블루) */
    --navbar-text: #ffffff;                    /* 네비게이션 텍스트 */
    --navbar-hover: #1d4ed8;                  /* 네비게이션 호버 */
    
    /* 카드 */
    --card-bg: #ffffff;                       /* 카드 배경 */
    --card-border: #e2e8f0;                   /* 카드 경계선 */
    --card-shadow: rgba(0, 0, 0, 0.05);       /* 카드 그림자 */
    --card-shadow-hover: rgba(0, 0, 0, 0.1); /* 카드 호버 그림자 */
    
    /* 입력 필드 */
    --input-bg: #ffffff;                      /* 입력 배경 */
    --input-border: #cbd5e0;                  /* 입력 경계선 */
    --input-focus-border: #2563eb;            /* 입력 포커스 (프로페셔널 블루) */
    --input-focus-shadow: rgba(37, 99, 235, 0.1); /* 입력 포커스 그림자 */
    --input-placeholder: #a0aec0;            /* 플레이스홀더 텍스트 */
    
    /* 테이블 */
    --table-hover: #f7fafc;                    /* 테이블 호버 배경 */
    --table-stripe: #f9fafb;                  /* 테이블 줄무늬 */
    --table-border: #e5e7eb;                  /* 테이블 경계선 */
    
    /* 모달 */
    --modal-bg: #ffffff;                      /* 모달 배경 */
    --modal-border: #e2e8f0;                  /* 모달 경계선 */
    --modal-backdrop: rgba(0, 0, 0, 0.5);     /* 모달 백드롭 */
    
    /* 액센트 색상 (상태 표시용) */
    --accent-primary: #2563eb;                 /* 주요 액센트 (프로페셔널 블루) */
    --accent-success: #10b981;                 /* 성공 (에메랄드 그린) */
    --accent-warning: #f59e0b;                /* 경고 (앰버) */
    --accent-danger: #ef4444;                 /* 위험 (레드) */
    --accent-info: #3b82f6;                   /* 정보 (스카이 블루) */
    
    /* 버튼 색상 */
    --btn-primary: #2563eb;                   /* 주요 버튼 */
    --btn-primary-hover: #1d4ed8;              /* 주요 버튼 호버 */
    --btn-secondary: #64748b;                 /* 보조 버튼 */
    --btn-secondary-hover: #475569;            /* 보조 버튼 호버 */
    
    /* 링크 색상 */
    --link-color: #2563eb;                    /* 링크 색상 */
    --link-hover: #1d4ed8;                    /* 링크 호버 */
}

/* ============================================
   라이트 테마 클래스 (명시적)
   ============================================ */
html.light-theme {
    /* 라이트 테마는 기본값 사용 (변수 재정의 불필요) */
    /* 명시적으로 라이트 테마임을 표시 */
    color-scheme: light;
}

/* ============================================
   다크 테마 변수
   ============================================ */
html.dark-theme {
    --bg-primary: #0d1117;
    --bg-secondary: #161b22;
    --bg-tertiary: #21262d;
    --text-primary: #c9d1d9;
    --text-secondary: #8b949e;
    --text-muted: #6e7681;
    --border-color: #30363d;
    --navbar-bg: #161b22;
    --card-bg: #161b22;
    --card-border: #30363d;
    --input-bg: #0d1117;
    --input-border: #30363d;
    --input-focus-border: #58a6ff;
    --table-hover: #2d333b;
    --modal-bg: #161b22;
    --modal-border: #30363d;
}

/* ============================================
   기본 스타일 (라이트 테마)
   ============================================ */
body {
    background: linear-gradient(180deg, var(--bg-primary) 0%, var(--bg-secondary) 100%);
    background-attachment: fixed;
    color: var(--text-primary);
    transition: background-color 0.3s ease, color 0.3s ease;
    min-height: 100vh;
}

/* 링크 스타일 */
a {
    color: var(--link-color);
    text-decoration: none;
    transition: color 0.3s ease;
}

a:hover {
    color: var(--link-hover);
    text-decoration: underline;
}

/* 배지 스타일 개선 */
.badge {
    padding: 0.375rem 0.75rem;
    font-weight: 500;
    border-radius: 0.5rem;
    font-size: 0.8125rem;
    letter-spacing: 0.025em;
}

.bg-primary {
    background-color: var(--accent-primary) !important;
}

.bg-success {
    background-color: var(--accent-success) !important;
}

.bg-warning {
    background-color: var(--accent-warning) !important;
    color: #ffffff !important;
}

.bg-danger {
    background-color: var(--accent-danger) !important;
}

.bg-info {
    background-color: var(--accent-info) !important;
}

/* ============================================
   네비게이션 바
   ============================================ */
.navbar {
    background: linear-gradient(135deg, var(--navbar-bg) 0%, var(--navbar-hover) 100%) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease;
}

.navbar-brand {
    color: var(--navbar-text) !important;
    font-weight: 600;
    font-size: 1.25rem;
    transition: opacity 0.3s ease;
}

.navbar-brand:hover {
    opacity: 0.9;
}

.navbar-dark .navbar-nav .nav-link {
    color: rgba(255, 255, 255, 0.9) !important;
    font-weight: 500;
    transition: all 0.3s ease;
    border-radius: 0.375rem;
    margin: 0 0.25rem;
    padding: 0.5rem 0.75rem !important;
}

.navbar-dark .navbar-nav .nav-link:hover {
    color: var(--navbar-text) !important;
    background-color: rgba(255, 255, 255, 0.1);
}

.navbar-dark .navbar-nav .nav-link.active {
    background-color: rgba(255, 255, 255, 0.15);
    color: var(--navbar-text) !important;
}

.navbar-toggler {
    border-color: rgba(255, 255, 255, 0.3);
}

.navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.9%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

html.dark-theme .navbar {
    background: linear-gradient(135deg, #161b22 0%, #0d1117 100%) !important;
    border-bottom: 1px solid #30363d;
}

html.dark-theme .navbar-dark .navbar-nav .nav-link {
    color: #c9d1d9 !important;
}

html.dark-theme .navbar-dark .navbar-nav .nav-link:hover {
    color: #f0f6fc !important;
    background-color: rgba(255, 255, 255, 0.05);
}

/* ============================================
   카드
   ============================================ */
.card {
    background-color: var(--card-bg);
    border: 1px solid var(--card-border);
    color: var(--text-primary);
    border-radius: 0.75rem;
    box-shadow: 0 1px 3px var(--card-shadow);
    transition: all 0.3s ease;
}

.card:hover {
    box-shadow: 0 4px 12px var(--card-shadow-hover);
    transform: translateY(-2px);
}

.card-header {
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-accent) 100%);
    border-bottom: 1px solid var(--border-color);
    color: var(--text-primary);
    font-weight: 600;
    padding: 1rem 1.5rem;
    border-radius: 0.75rem 0.75rem 0 0;
}

.card-body {
    padding: 1.5rem;
}

.card-footer {
    background-color: var(--bg-secondary);
    border-top: 1px solid var(--border-color);
    border-radius: 0 0 0.75rem 0.75rem;
}

/* ============================================
   타이포그래피
   ============================================ */
h1, h2, h3, h4, h5, h6 {
    color: var(--text-primary);
}

.text-dark {
    color: var(--text-primary) !important;
}

.text-muted {
    color: var(--text-secondary) !important;
}

/* ============================================
   테이블
   ============================================ */
.table {
    color: var(--text-primary);
    border-color: var(--table-border);
    background-color: var(--card-bg);
}

.table thead th {
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-accent) 100%);
    color: var(--text-primary);
    font-weight: 600;
    text-transform: uppercase;
    font-size: 0.8125rem;
    letter-spacing: 0.05em;
    border-bottom: 2px solid var(--table-border);
    padding: 1rem 0.75rem;
}

.table > tbody > tr > td {
    color: var(--text-primary) !important;
    border-color: var(--table-border);
    padding: 1rem 0.75rem;
    vertical-align: middle;
}

.table > tbody > tr:nth-child(even) {
    background-color: var(--table-stripe);
}

.table-hover > tbody > tr {
    transition: all 0.2s ease;
}

.table-hover > tbody > tr:hover {
    background-color: var(--table-hover) !important;
    color: var(--text-primary) !important;
    transform: scale(1.01);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.table-hover > tbody > tr:hover > td,
.table-hover > tbody > tr:hover > td * {
    color: var(--text-primary) !important;
}

.table-light {
    --bs-table-bg: var(--bg-secondary);
    --bs-table-border-color: var(--table-border);
    color: var(--text-primary);
}

.table > :not(caption) > * > * {
    background-color: transparent !important;
}

.table > tbody > tr > td strong {
    color: var(--text-primary) !important;
    font-weight: 600;
}

.table > tbody > tr > td .text-muted {
    color: var(--text-secondary) !important;
}

/* ============================================
   폼 요소
   ============================================ */
.form-control,
.form-select {
    background-color: var(--input-bg);
    border: 1.5px solid var(--input-border);
    color: var(--text-primary);
    border-radius: 0.5rem;
    padding: 0.625rem 0.875rem;
    transition: all 0.3s ease;
    font-size: 0.9375rem;
}

.form-control::placeholder {
    color: var(--input-placeholder);
    opacity: 0.7;
}

.form-control:focus,
.form-select:focus {
    background-color: var(--input-bg);
    border-color: var(--input-focus-border);
    color: var(--text-primary);
    box-shadow: 0 0 0 3px var(--input-focus-shadow);
    outline: none;
}

.form-control:disabled,
.form-select:disabled {
    background-color: var(--bg-tertiary);
    border-color: var(--border-light);
    color: var(--text-muted);
    cursor: not-allowed;
}

.form-label {
    color: var(--text-primary);
    font-weight: 500;
    margin-bottom: 0.5rem;
    font-size: 0.9375rem;
}

.input-group-text {
    background-color: var(--bg-secondary);
    border: 1.5px solid var(--input-border);
    color: var(--text-secondary);
    border-radius: 0.5rem;
    font-weight: 500;
}

html.dark-theme .form-control:focus,
html.dark-theme .form-select:focus {
    box-shadow: 0 0 0 3px rgba(88, 166, 255, 0.25);
}

/* ============================================
   버튼
   ============================================ */
.btn {
    border-radius: 0.5rem;
    font-weight: 500;
    padding: 0.625rem 1.25rem;
    transition: all 0.3s ease;
    border-width: 1.5px;
}

.btn-primary {
    background: linear-gradient(135deg, var(--btn-primary) 0%, var(--btn-primary-hover) 100%);
    border-color: var(--btn-primary);
    color: var(--text-inverse);
}

.btn-primary:hover {
    background: linear-gradient(135deg, var(--btn-primary-hover) 0%, var(--btn-primary) 100%);
    border-color: var(--btn-primary-hover);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(37, 99, 235, 0.3);
}

.btn-secondary {
    background-color: var(--btn-secondary);
    border-color: var(--btn-secondary);
    color: var(--text-inverse);
}

.btn-secondary:hover {
    background-color: var(--btn-secondary-hover);
    border-color: var(--btn-secondary-hover);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(100, 116, 139, 0.3);
}

.btn-outline-primary {
    color: var(--btn-primary);
    border-color: var(--btn-primary);
    background-color: transparent;
}

.btn-outline-primary:hover {
    background-color: var(--btn-primary);
    border-color: var(--btn-primary);
    color: var(--text-inverse);
}

.btn-outline-info,
.btn-outline-warning,
.btn-outline-danger {
    color: var(--text-primary);
    border-width: 1.5px;
}

.btn-outline-info:hover {
    background-color: var(--accent-info);
    border-color: var(--accent-info);
    color: var(--text-inverse);
}

.btn-outline-warning:hover {
    background-color: var(--accent-warning);
    border-color: var(--accent-warning);
    color: var(--text-inverse);
}

.btn-outline-danger:hover {
    background-color: var(--accent-danger);
    border-color: var(--accent-danger);
    color: var(--text-inverse);
}

html.dark-theme .btn-outline-info,
html.dark-theme .btn-outline-warning,
html.dark-theme .btn-outline-danger {
    color: #c9d1d9;
}

/* ============================================
   모달
   ============================================ */
.modal-backdrop {
    background-color: var(--modal-backdrop);
    backdrop-filter: blur(2px);
}

.modal-content {
    background-color: var(--modal-bg);
    border: 1px solid var(--modal-border);
    border-radius: 1rem;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    color: var(--text-primary);
}

.modal-header {
    border-bottom: 1px solid var(--border-color);
    background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-accent) 100%);
    border-radius: 1rem 1rem 0 0;
    padding: 1.5rem;
}

.modal-title {
    color: var(--text-primary);
    font-weight: 600;
    font-size: 1.25rem;
}

.modal-body {
    padding: 1.5rem;
}

.modal-footer {
    border-top: 1px solid var(--border-color);
    background-color: var(--bg-secondary);
    border-radius: 0 0 1rem 1rem;
    padding: 1rem 1.5rem;
}

.btn-close {
    filter: none;
    opacity: 0.7;
    transition: opacity 0.3s ease;
}

.btn-close:hover {
    opacity: 1;
}

html.dark-theme .btn-close {
    filter: invert(1) grayscale(100%) brightness(200%);
}

/* ============================================
   푸터
   ============================================ */
footer {
    background: linear-gradient(135deg, var(--navbar-bg) 0%, var(--navbar-hover) 100%) !important;
    color: var(--text-inverse);
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    padding: 1.5rem 0;
    margin-top: auto;
}

footer a {
    color: rgba(255, 255, 255, 0.9);
    text-decoration: none;
    transition: color 0.3s ease;
}

footer a:hover {
    color: var(--text-inverse);
}

html.dark-theme footer {
    background: linear-gradient(135deg, #161b22 0%, #0d1117 100%) !important;
    color: #c9d1d9;
    border-top: 1px solid #30363d;
}

/* ============================================
   특수 컴포넌트
   ============================================ */
.user-stats-card {
    background-color: var(--bg-secondary);
}

.user-filter-pills {
    background-color: var(--bg-secondary);
    border-radius: 30px;
    padding: 5px;
}

.user-filter-pills .nav-link {
    color: var(--text-secondary);
    border-radius: 30px;
    transition: all 0.3s ease;
}

.user-filter-pills .nav-link.active {
    background-color: var(--text-primary);
    color: var(--bg-primary);
    font-weight: bold;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
}

html.dark-theme .user-filter-pills .nav-link.active {
    background-color: #f0f6fc;
    color: #161b22;
}

.action-btn-group {
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 4px;
    display: inline-flex;
}

.action-btn-group .btn {
    border: none !important;
}

/* ============================================
   테마 토글 버튼
   ============================================ */
.theme-toggle-btn {
    background: transparent;
    border: 1px solid var(--border-color);
    color: var(--text-primary);
    padding: 0.5rem 0.75rem;
    border-radius: 0.5rem;
    cursor: pointer;
    transition: all 0.3s ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    min-width: 44px; /* 터치 친화적 최소 크기 */
    min-height: 44px;
    font-size: 1rem;
    line-height: 1;
    position: relative;
}

.theme-toggle-btn:hover,
.theme-toggle-btn:focus {
    background-color: var(--bg-secondary);
    border-color: var(--input-focus-border);
    outline: none;
    box-shadow: 0 0 0 2px rgba(88, 166, 255, 0.2);
}

.theme-toggle-btn:active {
    transform: scale(0.95);
}

.theme-icon {
    font-size: 1.25rem;
    line-height: 1;
    display: inline-block;
}

.theme-text {
    font-size: 0.875rem;
    font-weight: 500;
}

html.dark-theme .theme-toggle-btn {
    color: #c9d1d9;
    border-color: #30363d;
}

html.dark-theme .theme-toggle-btn:hover,
html.dark-theme .theme-toggle-btn:focus {
    background-color: #21262d;
    border-color: #58a6ff;
    box-shadow: 0 0 0 2px rgba(88, 166, 255, 0.2);
}

/* ============================================
   반응형 개선
   ============================================ */

/* 모바일 (320px ~ 767px) */
@media screen and (max-width: 767px) {
    /* 테마 토글 버튼 모바일 최적화 */
    .theme-toggle-btn {
        padding: 0.5rem;
        min-width: 44px;
        min-height: 44px;
        border-radius: 50%;
    }
    
    .theme-text {
        display: none !important; /* 모바일에서 텍스트 숨김 */
    }
    
    .theme-icon {
        font-size: 1.5rem;
    }
    
    /* 네비게이션 바 모바일 개선 */
    .navbar {
        padding: 0.5rem 0;
    }
    
    .navbar-brand {
        font-size: 1rem;
        padding: 0.5rem 0;
    }
    
    .navbar-toggler {
        padding: 0.375rem 0.5rem;
        min-width: 44px;
        min-height: 44px;
        border: 1px solid rgba(255, 255, 255, 0.3);
    }
    
    .navbar-nav {
        padding-top: 1rem;
    }
    
    .navbar-nav .nav-item {
        margin-bottom: 0.5rem;
    }
    
    .navbar-nav .nav-link {
        padding: 0.75rem 1rem;
        font-size: 1rem;
        min-height: 44px;
        display: flex;
        align-items: center;
    }
    
    /* 테이블 모바일 카드 뷰 */
    .table-responsive {
        overflow-x: visible;
    }
    
    .table {
        border: none;
    }
    
    .table thead {
        display: none;
    }
    
    .table tbody tr {
        display: block;
        margin-bottom: 1rem;
        border: 1px solid var(--border-color);
        border-radius: 0.5rem;
        background-color: var(--card-bg);
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    }
    
    .table tbody tr:hover {
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
    }
    
    .table tbody td {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 0.75rem 1rem;
        border: none;
        border-bottom: 1px solid var(--border-color);
    }
    
    .table tbody td:last-child {
        border-bottom: none;
    }
    
    .table tbody td::before {
        content: attr(data-label);
        font-weight: 600;
        color: var(--text-secondary);
        margin-right: 1rem;
        flex-shrink: 0;
    }
    
    /* 버튼 그룹 모바일 최적화 */
    .btn-group {
        flex-wrap: wrap;
        gap: 0.25rem;
    }
    
    .btn-group .btn {
        min-width: 44px;
        min-height: 44px;
        padding: 0.5rem;
        font-size: 1rem;
    }
    
    /* 카드 모바일 최적화 */
    .card {
        margin-bottom: 1rem;
        border-radius: 0.75rem;
    }
    
    .card-body {
        padding: 1rem;
    }
    
    /* 폼 요소 모바일 최적화 */
    .form-control,
    .form-select {
        min-height: 44px;
        font-size: 16px; /* iOS 줌 방지 */
        padding: 0.75rem;
    }
    
    /* 모달 모바일 최적화 */
    .modal-dialog {
        margin: 0.5rem;
        max-width: calc(100% - 1rem);
    }
    
    .modal-content {
        border-radius: 0.75rem;
    }
    
    /* 페이지네이션 모바일 최적화 */
    .pagination {
        flex-wrap: wrap;
        justify-content: center;
    }
    
    .page-link {
        min-width: 44px;
        min-height: 44px;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0.5rem;
    }
    
    /* 통계 카드 모바일 */
    .row .col-md-3,
    .row .col-md-4,
    .row .col-md-6 {
        margin-bottom: 1rem;
    }
    
    /* 액션 버튼 모바일 */
    .btn-group-sm .btn {
        min-width: 44px;
        min-height: 44px;
        padding: 0.5rem;
    }
    
    /* 배지 모바일 */
    .badge {
        font-size: 0.875rem;
        padding: 0.375rem 0.5rem;
    }
    
    /* 다크 테마 모바일 특화 */
    html.dark-theme .table tbody tr {
        background-color: var(--card-bg);
        border-color: var(--border-color);
    }
    
    html.dark-theme .table tbody td::before {
        color: var(--text-secondary);
    }
    
    html.dark-theme .card {
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
    }
}

/* 태블릿 다크 테마 최적화 */
@media screen and (min-width: 768px) and (max-width: 1023px) {
    html.dark-theme .table {
        border-color: var(--border-color);
    }
    
    html.dark-theme .card {
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
    }
}

/* 태블릿 (768px ~ 1023px) */
@media screen and (min-width: 768px) and (max-width: 1023px) {
    /* 테마 토글 버튼 태블릿 */
    .theme-toggle-btn {
        padding: 0.5rem 0.75rem;
    }
    
    .theme-text {
        display: inline;
        font-size: 0.875rem;
    }
    
    /* 네비게이션 바 태블릿 */
    .navbar-nav .nav-link {
        padding: 0.5rem 0.75rem;
        font-size: 0.95rem;
    }
    
    /* 테이블 태블릿 최적화 */
    .table-responsive {
        overflow-x: auto;
    }
    
    .table {
        font-size: 0.9rem;
    }
    
    .table th,
    .table td {
        padding: 0.75rem 0.5rem;
    }
    
    /* 카드 태블릿 그리드 */
    .row .col-md-6 {
        flex: 0 0 50%;
        max-width: 50%;
    }
}

/* 데스크톱 (1024px 이상) */
@media screen and (min-width: 1024px) {
    /* 테마 토글 버튼 데스크톱 */
    .theme-toggle-btn {
        padding: 0.5rem 1rem;
    }
    
    .theme-text {
        display: inline;
    }
    
    /* 호버 효과 강화 */
    .theme-toggle-btn:hover {
        transform: translateY(-1px);
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    }
}

/* ============================================
   추가 컴포넌트 스타일
   ============================================ */
.badge {
    transition: background-color 0.3s ease, color 0.3s ease;
}

html.dark-theme .badge.bg-warning {
    background-color: #d97706 !important;
    color: #ffffff !important;
}

html.dark-theme .badge.bg-dark {
    background-color: #374151 !important;
    color: #ffffff !important;
}

/* 드롭다운 메뉴 */
.dropdown-menu {
    background-color: var(--card-bg);
    border-color: var(--border-color);
    color: var(--text-primary);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

html.dark-theme .dropdown-menu {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
}

.dropdown-item {
    color: var(--text-primary);
    transition: background-color 0.2s ease, color 0.2s ease;
}

.dropdown-item:hover,
.dropdown-item:focus {
    background-color: var(--bg-secondary);
    color: var(--text-primary);
}

.dropdown-item.active {
    background-color: var(--input-focus-border);
    color: #ffffff;
}

.dropdown-divider {
    border-color: var(--border-color);
    margin: 0.5rem 0;
}

/* 알림/경고 메시지 */
.alert {
    background-color: var(--card-bg);
    border-color: var(--border-color);
    color: var(--text-primary);
}

/* 컨테이너 반응형 개선 */
.container {
    padding-left: 1rem;
    padding-right: 1rem;
}

@media (min-width: 576px) {
    .container {
        padding-left: 1.5rem;
        padding-right: 1.5rem;
    }
}

/* 메인 콘텐츠 영역 */
main {
    padding-bottom: 2rem;
}

@media (max-width: 767px) {
    main {
        padding-bottom: 1rem;
    }
}

/* 버튼 그룹 반응형 */
.btn-group {
    display: inline-flex;
    flex-wrap: wrap;
}

@media (max-width: 767px) {
    .btn-group {
        width: 100%;
        justify-content: center;
    }
    
    .btn-group .btn {
        flex: 1 1 auto;
        min-width: 44px;
    }
}

/* 입력 그룹 반응형 */
.input-group {
    flex-wrap: wrap;
}

@media (max-width: 767px) {
    .input-group > .form-control,
    .input-group > .form-select {
        width: 100%;
        margin-bottom: 0.5rem;
    }
    
    .input-group > .btn {
        width: 100%;
        margin-top: 0.5rem;
    }
}

/* 페이지네이션 반응형 */
.pagination {
    display: flex;
    flex-wrap: wrap;
    gap: 0.25rem;
}

@media (max-width: 767px) {
    .pagination {
        justify-content: center;
    }
    
    .pagination .page-item {
        margin: 0.125rem;
    }
    
    .pagination .page-link {
        min-width: 44px;
        min-height: 44px;
        padding: 0.5rem;
        display: flex;
        align-items: center;
        justify-content: center;
    }
}

/* 드롭다운 메뉴 반응형 */
.dropdown-menu {
    max-width: 100%;
}

@media (max-width: 767px) {
    .dropdown-menu {
        width: 100%;
        max-width: calc(100vw - 2rem);
        margin-top: 0.5rem;
    }
    
    .dropdown-item {
        padding: 0.75rem 1rem;
        min-height: 44px;
        display: flex;
        align-items: center;
    }
}

/* 시스템 설정 기반 초기 감지 (선택적) - JavaScript에서 처리하므로 주석 처리 */
/*
@media (prefers-color-scheme: dark) {
    html:not([data-theme]) {
        --bg-primary: #0d1117;
        --bg-secondary: #161b22;
        --bg-tertiary: #21262d;
        --text-primary: #c9d1d9;
        --text-secondary: #8b949e;
        --text-muted: #6e7681;
        --border-color: #30363d;
        --navbar-bg: #161b22;
        --card-bg: #161b22;
        --card-border: #30363d;
        --input-bg: #0d1117;
        --input-border: #30363d;
        --input-focus-border: #58a6ff;
        --table-hover: #2d333b;
        --modal-bg: #161b22;
        --modal-border: #30363d;
    }
}
*/

