﻿/* ===================================
   림버??컴퍼???�브 - 메인 ?��??�시??
   LimbusGiftPlanner ?�자?�과 ?��????��?
   =================================== */

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;500;600;700&display=swap');

:root {
    /* 주요 ?�상 (?�색 기반) */
    --primary-color: #5b8def;
    --primary-hover: #7aa3ff;
    --secondary-color: #4a6fa5;
    
    /* 배경 ?�상 */
    --bg-primary: #0d1117;
    --bg-secondary: #161b22;
    --bg-tertiary: #21262d;
    --bg-card: rgba(22, 27, 34, 0.9);
    --bg-hover: rgba(91, 141, 239, 0.1);
    
    /* ?�스???�상 */
    --text-primary: #e6edf3;
    --text-secondary: #8b949e;
    --text-muted: #6e7681;
    
    /* 강조 ?�상 */
    --accent-primary: #5b8def;
    --accent-secondary: #4a7ddd;
    --gold-accent: #5b8def;
    --bronze-accent: #4a6fa5;
    
    /* ?�태 ?�상 */
    --success: #3fb950;
    --error: #f85149;
    --warning: #d29922;
    --info: #58a6ff;
    
    /* ?�두�?*/
    --border-color: rgba(48, 54, 61, 0.8);
    --border-light: rgba(91, 141, 239, 0.3);
    
    /* 그라?�이??*/
    --gradient-gold: linear-gradient(135deg, #5b8def 0%, #4a7ddd 100%);
    --gradient-bg: linear-gradient(135deg, #0d1117 0%, #161b22 100%);
    
    /* 그림??*/
    --shadow-sm: 0 2px 4px rgba(0,0,0,0.4);
    --shadow-md: 0 4px 12px rgba(0,0,0,0.5);
    --shadow-lg: 0 8px 24px rgba(0,0,0,0.6);
    --shadow-gold: 0 0 1.25rem rgba(91, 141, 239, 0.2);
    
    /* 간격 (rem 기반 - ?�상?�에 ?�라 ?��??�링) */
    --spacing-xs: 0.25rem;
    --spacing-sm: 0.5rem;
    --spacing-md: 1rem;
    --spacing-lg: 1.5rem;
    --spacing-xl: 2rem;
    
    /* 반경 */
    --radius-sm: 0.25rem;
    --radius-md: 0.5rem;
    --radius-lg: 0.75rem;
    --radius-xl: 1rem;
    
    /* ?�랜지??*/
    --transition-fast: 0.15s ease;
    --transition-normal: 0.25s ease;
    
    /* 기�? ?�상??(2560x1440) */
    --base-width: 2560;
    --base-height: 1440;
}

/* ===================================
   리셋 & 기본 ?��???
   =================================== */

*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    font-size: 16px; /* 기본값 - JS에서 screen.height 기준으로 덮어씀 */
    scroll-behavior: smooth;
    overflow-x: auto;
    overflow-y: auto;
}

body {
    font-family: 'Noto Sans KR', sans-serif;
    background: var(--gradient-bg);
    color: var(--text-primary);
    line-height: 1.6;
    min-height: 100vh;
    min-width: 90rem;
    display: flex;
    flex-direction: column;
}

/* 해상도별 스케일링은 JS에서 screen.height로 처리 (창 크기 무관) */

/* ===================================
   컨테이너 (LimbusGiftPlanner 스타일)
   =================================== */

.container {
    display: flex;
    width: 100%;
    max-width: 100rem; /* 1600px at 16px base */
    min-width: 88rem;
    margin: 1.25rem auto;
    background: rgba(22, 27, 34, 0.8);
    box-shadow: 0 0 1.25rem rgba(91, 141, 239, 0.2);
    border-radius: 0.75rem;
    border: 2px solid rgba(48, 54, 61, 0.3);
    overflow: visible;
    flex: 1;
}

/* ===================================
   ?�이지 ?�더
   =================================== */

.page-header {
    margin-bottom: 1.875rem;
    padding: 1.25rem;
    padding-bottom: 1.25rem;
    border-bottom: 2px solid rgba(91, 141, 239, 0.5);
    background: rgba(22, 27, 34, 0.4);
    border-radius: 0.75rem;
}

.page-header h1 {
    margin: 0;
    font-size: 2rem;
    color: #e6edf3;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
}

a {
    color: inherit;
    text-decoration: none;
}

button {
    font-family: inherit;
    cursor: pointer;
    border: none;
    background: none;
    transition: all var(--transition-fast);
}

button:hover {
    transform: translateY(-1px);
}

button:active {
    transform: translateY(1px);
}

input, textarea, select {
    font-family: inherit;
    font-size: 1rem;
}

/* ?�크롤바 ?��???*/
::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

::-webkit-scrollbar-track {
    background: rgba(13, 17, 23, 0.5);
}

::-webkit-scrollbar-thumb {
    background: rgba(74, 111, 165, 0.6);
    border-radius: 5px;
    border: 2px solid rgba(13, 17, 23, 0.5);
}

::-webkit-scrollbar-thumb:hover {
    background: rgba(91, 141, 239, 0.8);
}

/* ===================================
   ?�더
   =================================== */

.header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(22, 27, 34, 0.95);
    border-bottom: 2px solid var(--border-color);
    backdrop-filter: blur(10px);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
    width: 100%;
}

.header-content {
    max-width: 100rem; /* 1600px */
    margin: 0 auto;
    padding: var(--spacing-md) var(--spacing-lg);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-lg);
}

.logo {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--gold-accent);
    text-shadow: 0 0 10px rgba(91, 141, 239, 0.3);
}

.logo i {
    font-size: 1.75rem;
}

.nav-links {
    display: flex;
    gap: var(--spacing-sm);
}

.nav-link {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-sm) var(--spacing-md);
    background: rgba(22, 27, 34, 0.8);
    border: 2px solid var(--border-color);
    border-radius: var(--radius-md);
    color: var(--text-secondary);
    font-weight: 500;
    transition: all var(--transition-fast);
}

.nav-link:hover {
    background: rgba(91, 141, 239, 0.2);
    border-color: var(--gold-accent);
    color: var(--text-primary);
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(91, 141, 239, 0.3);
}

.auth-area {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.user-info {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.user-avatar {
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--accent-primary);
}

/* ===================================
   버튼
   =================================== */

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--radius-md);
    font-weight: 500;
    transition: all var(--transition-fast);
    white-space: nowrap;
    border: 2px solid transparent;
}

.btn-sm {
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: 0.875rem;
}

.btn-primary {
    background: linear-gradient(135deg, #5b8def 0%, #4a7cd8 100%);
    color: #ffffff;
    border: 2px solid rgba(91, 141, 239, 0.5);
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

.btn-primary:hover {
    background: linear-gradient(135deg, #6b9dff 0%, #5b8def 100%);
    box-shadow: 0 4px 12px rgba(91, 141, 239, 0.4);
    transform: translateY(-1px);
}

.btn-secondary {
    background: rgba(48, 72, 110, 0.5);
    color: var(--text-primary);
    border: 2px solid rgba(74, 111, 165, 0.5);
}

.btn-secondary:hover {
    background: rgba(48, 72, 110, 0.7);
    border-color: var(--bronze-accent);
}

.btn-login {
    width: 100%;
    padding: var(--spacing-md);
    font-size: 1rem;
    border-radius: var(--radius-lg);
    margin-bottom: var(--spacing-sm);
    font-weight: 600;
}

.btn-google {
    background: #fff;
    color: #333;
    border: 2px solid rgba(0, 0, 0, 0.1);
}

.btn-google:hover {
    background: #f5f5f5;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.btn-github {
    background: #333;
    color: #fff;
    border: 2px solid #444;
}

.btn-github:hover {
    background: #444;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.btn-anonymous {
    background: rgba(48, 72, 110, 0.3);
    color: var(--text-secondary);
    border: 2px solid rgba(74, 111, 165, 0.4);
}

.btn-anonymous:hover {
    background: rgba(48, 72, 110, 0.5);
    border-color: var(--bronze-accent);
}

/* ===================================
   메인 컨텐�?
   =================================== */

.main-content {
    flex: 1;
    padding: 1.25rem;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    min-width: 86rem;
}

/* ===================================
   ???�비게이??
   =================================== */

.tab-navigation {
    display: flex;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
    padding: var(--spacing-sm);
    background: rgba(22, 27, 34, 0.8);
    border-radius: var(--radius-lg);
    border: 2px solid rgba(48, 54, 61, 0.3);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3), inset 0 1px 0 rgba(91, 141, 239, 0.1);
    min-width: 26rem;
}

.tab-btn {
    flex: 1;
    min-width: 8rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-md);
    border-radius: var(--radius-md);
    color: var(--text-secondary);
    font-weight: 600;
    font-size: 1.1rem;
    transition: all var(--transition-fast);
    border: 2px solid transparent;
}

.tab-btn:hover {
    background: rgba(91, 141, 239, 0.15);
    color: var(--text-primary);
}

.tab-btn.active {
    background: linear-gradient(135deg, #5b8def 0%, #4a7cd8 100%);
    color: #ffffff;
    border-color: rgba(91, 141, 239, 0.5);
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
    box-shadow: 0 2px 8px rgba(91, 141, 239, 0.3);
}

.tab-content {
    display: none;
}

.tab-content.active {
    display: block;
    animation: fadeIn 0.3s ease;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ===================================
   ?�터 �?
   =================================== */

.filter-bar {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
    padding: var(--spacing-md);
    background: rgba(25, 35, 50, 0.8);
    border-radius: var(--radius-lg);
    border: 2px solid rgba(74, 111, 165, 0.3);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3);
}

.search-box {
    flex: 1;
    min-width: 15.625rem; /* 250px */
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    background: rgba(13, 17, 23, 0.6);
    border-radius: var(--radius-md);
    border: 2px solid rgba(74, 111, 165, 0.4);
    transition: all var(--transition-fast);
}

.search-box:focus-within {
    border-color: var(--gold-accent);
    box-shadow: 0 0 8px rgba(91, 141, 239, 0.2);
}

.search-box i {
    color: var(--text-muted);
}

.search-type-select {
    padding: var(--spacing-xs) var(--spacing-sm);
    background: rgba(25, 35, 50, 0.9);
    border: 1px solid rgba(74, 111, 165, 0.5);
    border-radius: var(--radius-sm);
    color: var(--text-primary);
    font-size: 0.85rem;
    cursor: pointer;
    outline: none;
    transition: all var(--transition-fast);
}

.search-type-select:hover {
    border-color: var(--gold-accent);
}

.search-type-select:focus {
    border-color: var(--gold-accent);
    box-shadow: 0 0 4px rgba(91, 141, 239, 0.3);
}

.search-box input {
    flex: 1;
    background: none;
    border: none;
    color: var(--text-primary);
    outline: none;
}

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

.filter-options {
    display: flex;
    gap: var(--spacing-sm);
}

.filter-options select {
    padding: var(--spacing-sm) var(--spacing-md);
    background: rgba(13, 17, 23, 0.6);
    border: 2px solid rgba(74, 111, 165, 0.4);
    border-radius: var(--radius-md);
    color: var(--text-primary);
    cursor: pointer;
    outline: none;
    transition: all var(--transition-fast);
}

.filter-options select:hover {
    border-color: var(--bronze-accent);
}

.filter-options select:focus {
    border-color: var(--gold-accent);
    box-shadow: 0 0 8px rgba(91, 141, 239, 0.2);
}

/* ===================================
   컨텐�??�더
   =================================== */

.content-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--spacing-lg);
}

.content-header h2 {
    font-size: 1.5rem;
    font-weight: 600;
}

/* 동기화 버튼 */
.btn-sync {
    background: var(--bg-tertiary);
    color: var(--text-primary);
    border: 1px solid var(--border-color);
    padding: 0.5rem 1rem;
    border-radius: var(--radius-sm);
    font-size: 0.875rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 0.4rem;
    transition: all 0.2s ease;
}

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

.btn-sync:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.btn-sync i {
    font-size: 0.875rem;
}

/* ===================================
   카드 그리??
   =================================== */

.cards-grid {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

/* ===================================
   카드 (???�이?�웃 - LimbusGiftPlanner ?��???
   =================================== */

.card {
    background: rgba(22, 27, 34, 0.8);
    border: 2px solid rgba(91, 141, 239, 0.2);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: all var(--transition-normal);
    display: flex;
    flex-direction: row;
    min-height: 15rem; /* 240px at 16px base */
    max-height: 15rem;
    min-width: 85rem;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3), inset 0 1px 0 rgba(91, 141, 239, 0.1);
}

.card:hover {
    border-color: #7aa3ff;
    box-shadow: 
        0 8px 24px rgba(0, 0, 0, 0.5),
        0 0 20px rgba(91, 141, 239, 0.3),
        inset 0 0 8px rgba(91, 141, 239, 0.1);
    transform: translateY(-2px);
}

/* 1. ?�쪽 ?�역: ?�보 */
.card-info {
    flex: 0 0 18.75rem; /* 300px at 16px base */
    min-width: 18.75rem;
    padding: var(--spacing-md);
    display: flex;
    flex-direction: column;
    justify-content: center;
    border-right: 2px solid rgba(48, 54, 61, 0.3);
    background: linear-gradient(135deg, rgba(22, 27, 34, 0.9) 0%, rgba(33, 38, 45, 0.9) 100%);
}

/* 2. ?�명 ?�역 (?��? 공간 채�?) */
.card-description-panel {
    flex: 1 1 auto;
    min-width: 22.5rem;
    padding: var(--spacing-md);
    display: flex;
    flex-direction: column;
    border-right: 2px solid rgba(48, 54, 61, 0.3);
    background: linear-gradient(135deg, rgba(13, 17, 23, 0.9) 0%, rgba(22, 27, 34, 0.9) 100%);
    overflow: visible;
}

.description-label {
    font-size: 0.7rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: var(--spacing-xs);
    padding-bottom: var(--spacing-xs);
    border-bottom: 1px solid rgba(48, 54, 61, 0.2);
    flex-shrink: 0;
}

.card-description {
    font-size: 0.85rem;
    color: #f0e8d8;
    line-height: 1.5;
    margin: 0;
    padding: 4px 0;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 7;
    -webkit-box-orient: vertical;
    word-break: break-word;
    cursor: pointer;
    transition: opacity 0.2s;
    max-height: calc(1.5em * 7 + 8px); /* 7줄 + padding */
}

.card-description:hover {
    opacity: 0.8;
}

.card-description.empty {
    color: #6e7681;
    font-style: italic;
    cursor: default;
}

.card-description.empty:hover {
    opacity: 1;
}

.description-more-link {
    display: block;
    color: var(--text-muted);
    font-size: 0.75rem;
    margin-top: 4px;
    font-style: italic;
}

.card-author {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin-bottom: var(--spacing-sm);
}

.card-author img {
    width: 24px;
    height: 24px;
    border-radius: 50%;
}

.card-title {
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: var(--spacing-xs);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.3;
    color: var(--gold-accent);
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
}

.card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
    align-items: center;
    margin-top: var(--spacing-sm);
}

/* 가??보기 버튼 */
.btn-blessing {
    padding: 0.1875rem 0.625rem;
    background: rgba(147, 112, 219, 0.25);
    border: 1px solid rgba(147, 112, 219, 0.5);
    border-radius: var(--radius-sm);
    font-size: 0.7rem;
    color: #b794f6;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.btn-blessing:hover {
    background: rgba(147, 112, 219, 0.4);
    border-color: rgba(147, 112, 219, 0.7);
}

.tag {
    padding: 0.1875rem 0.625rem;
    background: rgba(48, 54, 61, 0.3);
    border: 1px solid rgba(48, 54, 61, 0.4);
    border-radius: var(--radius-sm);
    font-size: 0.7rem;
    color: var(--text-secondary);
    font-weight: 500;
}

.tag.type-deck {
    background: rgba(91, 141, 239, 0.2);
    border-color: rgba(91, 141, 239, 0.4);
    color: var(--gold-accent);
}

.tag.type-plan {
    background: rgba(74, 111, 165, 0.25);
    border-color: rgba(74, 111, 165, 0.5);
    color: var(--bronze-accent);
}

.tag.difficulty-normal {
    background: rgba(64, 192, 128, 0.2);
    color: var(--success);
}

.tag.difficulty-hard {
    background: rgba(224, 160, 48, 0.2);
    color: var(--warning);
}

.tag.difficulty-extreme {
    background: rgba(224, 80, 80, 0.2);
    color: var(--error);
}

.tag.local-badge {
    background: rgba(64, 144, 224, 0.2);
    color: var(--info);
}

.tag.no-plan {
    background: rgba(100, 100, 100, 0.2);
    border-color: rgba(100, 100, 100, 0.4);
    color: var(--text-muted);
    font-style: italic;
}

/* 중앙 ?�역: 미리보기 */
.card-preview {
    flex: 0 0 auto;
    min-width: 40rem;
    padding: 0.625rem;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    box-sizing: border-box;
}

/* ??미리보기: 12�?그리??(6x2) */
.deck-preview-grid {
    display: grid;
    grid-template-columns: repeat(6, 6.5625rem); /* 105px at 16px base */
    grid-template-rows: repeat(2, 6.5625rem);
    gap: 0.375rem;
    min-width: 40rem;
}

.deck-preview-slot {
    width: 6.5625rem;
    height: 6.5625rem;
    background: rgba(22, 27, 34, 0.6);
    border: 2px solid rgba(48, 54, 61, 0.4);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    position: relative;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3), inset 0 1px 0 rgba(91, 141, 239, 0.05);
}

.deck-preview-slot img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
}

.deck-preview-slot.empty {
    color: var(--text-muted);
    font-size: 0.7rem;
}

.deck-preview-slot.empty::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, transparent 40%, rgba(255,255,255,0.03) 50%, transparent 60%);
}

/* ?�성 ?�서가 ?�는 ?�롯 */
.deck-preview-slot.has-formation {
    border-color: var(--primary-color);
    box-shadow: 0 0 8px rgba(91, 141, 239, 0.5), inset 0 0 4px rgba(91, 141, 239, 0.2);
}

.formation-order {
    position: absolute;
    top: 0.125rem;
    left: 0.125rem;
    width: 1.125rem;
    height: 1.125rem;
    background: var(--primary-color);
    color: #0d1117;
    font-size: 0.6875rem;
    font-weight: 700;
    border-radius: 0.1875rem;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);
}

/* ?�랜 미리보기: 기프??목록 */
.plan-preview-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 0.375rem;
    justify-content: center;
    align-items: center;
}

.plan-preview-gift {
    width: 2.5rem;
    height: 2.5rem;
    background: rgba(22, 27, 34, 0.6);
    border: 2px solid rgba(48, 54, 61, 0.4);
    border-radius: var(--radius-sm);
    overflow: hidden;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

.plan-preview-gift img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* ?�른�??�역: ?�션 버튼 */
.card-actions-panel {
    flex: 0 0 13.25rem;
    min-width: 13.25rem;
    min-height: 15rem;
    padding: 0.75rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.375rem;
    border-left: 2px solid rgba(48, 54, 61, 0.3);
    background: linear-gradient(135deg, rgba(22, 27, 34, 0.9) 0%, rgba(33, 38, 45, 0.9) 100%);
    justify-content: center;
}

.card-action-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.375rem;
    padding: 0.5rem 0.875rem;
    background: rgba(48, 54, 61, 0.4);
    border: 2px solid rgba(48, 54, 61, 0.5);
    border-radius: var(--radius-md);
    color: var(--text-secondary);
    font-size: 0.8rem;
    font-weight: 500;
    transition: all var(--transition-fast);
    white-space: nowrap;
    cursor: pointer;
    box-sizing: border-box;
    width: 11.5rem;
}

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

.card-action-btn:hover {
    background: rgba(48, 54, 61, 0.6);
    color: var(--text-primary);
    border-color: var(--bronze-accent);
    transform: translateY(-1px);
}

.card-action-btn.primary {
    background: linear-gradient(135deg, #5b8def 0%, #4a7cd8 100%);
    color: #ffffff;
    border: 2px solid rgba(91, 141, 239, 0.5);
    font-weight: 600;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

.card-action-btn.primary:hover {
    background: linear-gradient(135deg, #6b9dff 0%, #5b8def 100%);
    box-shadow: 0 4px 12px rgba(91, 141, 239, 0.4);
}

.card-action-btn.success {
    background: rgba(74, 124, 74, 0.3);
    color: #6aaf6a;
    border-color: rgba(74, 124, 74, 0.5);
}

.card-action-btn.success:hover {
    background: rgba(74, 124, 74, 0.5);
    border-color: #6aaf6a;
}

.card-action-btn.danger:hover {
    background: rgba(156, 74, 74, 0.3);
    color: #cf7a7a;
    border-color: #cf7a7a;
}

.card-action-btn.secondary {
    background: rgba(74, 106, 156, 0.3);
    color: #7a9fcf;
    border-color: rgba(74, 106, 156, 0.5);
}

.card-action-btn.secondary:hover {
    background: rgba(74, 106, 156, 0.5);
    border-color: #7a9fcf;
}

.card-action-btn.disabled {
    background: rgba(100, 100, 100, 0.3);
    border-color: rgba(100, 100, 100, 0.5);
    color: var(--text-muted);
    cursor: not-allowed;
    opacity: 0.7;
}

.card-action-btn.disabled:hover {
    background: rgba(100, 100, 100, 0.3);
    border-color: rgba(100, 100, 100, 0.5);
}

.card-action-btn i {
    font-size: 0.8rem;
}

/* 다운로드 완료 카드 음영 처리 */
.card.downloaded-card {
    opacity: 0.6;
    background: rgba(22, 27, 34, 0.5);
}

.card.downloaded-card:hover {
    opacity: 0.75;
}

/* 카드 ?�계 (?�단 ?��? ?�보) */
.card-stats {
    display: flex;
    gap: var(--spacing-md);
    font-size: 0.75rem;
    color: var(--text-muted);
    margin-top: var(--spacing-sm);
    padding-top: var(--spacing-sm);
    border-top: 1px solid var(--border-color);
}

.card-stats span {
    display: flex;
    align-items: center;
    gap: 4px;
}

/* 기존 ?�환??*/
.card-header, .card-body, .card-footer {
    display: none;
}

.card-tags, .card-date {
    display: none;
}

/* ===================================
   로딩 & �??�태
   =================================== */

.loading-state,
.empty-state {
    grid-column: 1 / -1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-xl) * 2;
    color: var(--text-muted);
    text-align: center;
}

.loading-state i,
.empty-state i {
    font-size: 3rem;
    margin-bottom: var(--spacing-md);
}

.empty-state .sub {
    font-size: 0.875rem;
    margin-top: var(--spacing-xs);
}

/* ===================================
   모달
   =================================== */

.modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.85);
    display: none;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-lg);
    z-index: 1000;
    opacity: 0;
    transition: opacity var(--transition-normal);
    backdrop-filter: blur(4px);
}

.modal-overlay.active {
    display: flex;
    opacity: 1;
}

.modal-content {
    background: linear-gradient(135deg, #0d1117 0%, #161b22 100%);
    border: 2px solid rgba(91, 141, 239, 0.3);
    border-radius: var(--radius-xl);
    width: 100%;
    max-width: 31.25rem; /* 500px at 16px */
    max-height: 90vh;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    animation: modalSlideIn 0.3s ease;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.6), 0 0 40px rgba(91, 141, 239, 0.1);
}

.modal-large {
    max-width: 43.75rem; /* 700px at 16px */
    min-width: 40rem;
}

.modal-small {
    max-width: 25rem; /* 400px at 16px */
}

@keyframes modalSlideIn {
    from { transform: translateY(20px); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}

.modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-md) var(--spacing-lg);
    border-bottom: 2px solid rgba(74, 111, 165, 0.3);
    background: rgba(25, 35, 50, 0.5);
}

.modal-header h3 {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--gold-accent);
    text-shadow: 0 0 10px rgba(91, 141, 239, 0.3);
}

.modal-close-btn {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-md);
    color: var(--text-secondary);
    transition: all var(--transition-fast);
    border: 2px solid transparent;
}

.modal-close-btn:hover {
    background: rgba(156, 74, 74, 0.3);
    color: #cf7a7a;
    border-color: rgba(156, 74, 74, 0.5);
}

.modal-body {
    padding: var(--spacing-lg);
    overflow-y: auto;
    flex: 1;
}

.modal-footer {
    display: flex;
    justify-content: flex-end;
    gap: var(--spacing-sm);
    padding: var(--spacing-md) var(--spacing-lg);
    border-top: 2px solid rgba(74, 111, 165, 0.3);
    background: rgba(25, 35, 50, 0.5);
}

/* ===================================
   ?�로??모달 ?��???
   =================================== */

.upload-type-selector {
    display: flex;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
}

.upload-type-btn {
    flex: 1;
    padding: var(--spacing-md);
    background: var(--bg-tertiary);
    border: 2px solid var(--border-color);
    border-radius: var(--radius-md);
    color: var(--text-secondary);
    font-size: 1rem;
    font-weight: 500;
    transition: all var(--transition-fast);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
}

.upload-type-btn:hover {
    border-color: var(--border-light);
    color: var(--text-primary);
}

.upload-type-btn.active {
    background: var(--gradient-gold);
    border-color: var(--accent-primary);
    color: #000;
}

/* 미리보기 카드 */
.upload-preview-card {
    display: flex;
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    margin-bottom: var(--spacing-lg);
    overflow: hidden;
    height: 140px;
}

.upload-preview-card .card-info {
    flex: 0 0 160px;
    padding: var(--spacing-md);
    border-right: 1px solid var(--border-color);
    background: var(--bg-secondary);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.upload-preview-card .card-preview {
    flex: 1;
    padding: var(--spacing-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
}

.upload-preview-card .deck-preview-grid {
    height: 100%;
    max-height: 120px;
}

/* ???��???*/
.upload-form {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.form-row {
    display: flex;
    gap: var(--spacing-md);
}

.form-group.flex-1 {
    flex: 1;
}

.form-group label {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-xs);
    font-weight: 500;
    color: var(--text-secondary);
}

.form-group label i {
    color: var(--accent-primary);
}

.label-hint {
    font-size: 0.75rem;
    color: var(--text-muted);
    font-weight: 400;
}

#parse-code-btn {
    margin-top: var(--spacing-xs);
}

/* ?�그 ?�력 */
.tags-input-container {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
    padding: var(--spacing-sm);
    background: rgba(13, 17, 23, 0.6);
    border: 2px solid rgba(74, 111, 165, 0.4);
    border-radius: var(--radius-md);
    min-height: 42px;
    align-items: center;
    transition: all var(--transition-fast);
}

.tags-input-container:focus-within {
    border-color: var(--gold-accent);
    box-shadow: 0 0 12px rgba(91, 141, 239, 0.2);
}

.tags-input-container input {
    flex: 1;
    min-width: 6.25rem; /* 100px */
    background: none;
    border: none;
    color: var(--text-primary);
    outline: none;
    padding: 4px;
}

.tags-list {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
}

.tag-item {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    background: linear-gradient(135deg, #5b8def 0%, #4a7cd8 100%);
    color: #ffffff;
    border-radius: var(--radius-sm);
    font-size: 0.8rem;
    font-weight: 600;
    border: 1px solid rgba(91, 141, 239, 0.5);
}

.tag-item .remove-tag {
    cursor: pointer;
    opacity: 0.7;
}

.tag-item .remove-tag:hover {
    opacity: 1;
}

.suggested-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
    margin-top: var(--spacing-sm);
    align-items: center;
}

.suggested-label {
    font-size: 0.75rem;
    color: var(--text-muted);
}

.suggested-tag {
    padding: 0.1875rem 0.625rem;
    background: rgba(48, 54, 61, 0.3);
    border: 2px solid rgba(48, 54, 61, 0.4);
    border-radius: var(--radius-sm);
    color: var(--text-secondary);
    font-size: 0.75rem;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.suggested-tag:hover {
    background: rgba(91, 141, 239, 0.2);
    border-color: var(--gold-accent);
    color: var(--gold-accent);
}

/* ===================================
   ???�소
   =================================== */

.form-group {
    margin-bottom: var(--spacing-md);
}

.form-group label {
    display: block;
    margin-bottom: var(--spacing-xs);
    font-weight: 500;
    color: var(--text-secondary);
}

.form-group input,
.form-group textarea,
.form-group select {
    width: 100%;
    padding: var(--spacing-sm) var(--spacing-md);
    background: rgba(13, 17, 23, 0.6);
    border: 2px solid rgba(74, 111, 165, 0.4);
    border-radius: var(--radius-md);
    color: var(--text-primary);
    outline: none;
    transition: all var(--transition-fast);
}

.form-group input:focus,
.form-group textarea:focus {
    border-color: var(--gold-accent);
    box-shadow: 0 0 12px rgba(91, 141, 239, 0.2);
}

.form-group textarea {
    resize: vertical;
    min-height: 80px;
}

/* ===================================
   ?�세보기 모달
   =================================== */

.detail-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-md);
    border-bottom: 1px solid var(--border-color);
}

.detail-author {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.author-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
}

.detail-stats {
    display: flex;
    gap: var(--spacing-md);
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.detail-stats span {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.detail-description {
    margin-bottom: var(--spacing-lg);
    line-height: 1.7;
}

.detail-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
}

.detail-code-section {
    margin-top: var(--spacing-lg);
}

.detail-code-section label {
    display: block;
    margin-bottom: var(--spacing-sm);
    font-weight: 500;
    color: var(--text-secondary);
}

.code-box {
    position: relative;
}

.code-box textarea {
    width: 100%;
    height: 120px;
    padding: var(--spacing-md);
    padding-right: 80px;
    background: rgba(13, 17, 23, 0.6);
    border: 2px solid rgba(74, 111, 165, 0.4);
    border-radius: var(--radius-md);
    color: var(--text-primary);
    font-family: 'Consolas', 'Monaco', monospace;
    font-size: 0.875rem;
    resize: none;
}

.code-box textarea:focus {
    border-color: var(--gold-accent);
    box-shadow: 0 0 12px rgba(91, 141, 239, 0.2);
    outline: none;
}

.code-box .btn {
    position: absolute;
    right: var(--spacing-sm);
    top: var(--spacing-sm);
}

/* ===================================
   로그??모달
   =================================== */

.login-options {
    text-align: center;
}

.login-description {
    margin-bottom: var(--spacing-lg);
    color: var(--text-secondary);
}

.login-note {
    margin-top: var(--spacing-lg);
    padding: var(--spacing-md);
    background: rgba(25, 35, 50, 0.8);
    border: 2px solid rgba(74, 111, 165, 0.3);
    border-radius: var(--radius-md);
    font-size: 0.85rem;
    color: var(--text-muted);
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.login-note i {
    color: var(--gold-accent);
}

/* ===================================
   ?�네???�정 모달
   =================================== */

.nickname-description {
    margin-bottom: var(--spacing-lg);
    color: var(--text-secondary);
    text-align: center;
}

.nickname-status {
    margin-top: var(--spacing-sm);
    font-size: 0.85rem;
    min-height: 1.2em;
}

.nickname-status.error {
    color: var(--error);
}

.nickname-status.success {
    color: var(--success);
}

.nickname-status.checking {
    color: var(--text-muted);
}

/* ===================================
   ?�스???�림
   =================================== */

#toast-container {
    position: fixed;
    bottom: var(--spacing-lg);
    right: var(--spacing-lg);
    z-index: 2000;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.toast {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-md) var(--spacing-lg);
    background: linear-gradient(135deg, #0d1117 0%, #161b22 100%);
    border: 2px solid rgba(74, 111, 165, 0.5);
    border-radius: var(--radius-md);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5);
    animation: toastSlideIn 0.3s ease;
}

.toast.success { border-color: #6aaf6a; box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5), 0 0 15px rgba(106, 175, 106, 0.3); }
.toast.error { border-color: #cf7a7a; box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5), 0 0 15px rgba(207, 122, 122, 0.3); }
.toast.warning { border-color: #e6a23c; box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5), 0 0 15px rgba(230, 162, 60, 0.3); }
.toast.info { border-color: #7a9fcf; box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5), 0 0 15px rgba(122, 159, 207, 0.3); }

@keyframes toastSlideIn {
    from { transform: translateX(100%); opacity: 0; }
    to { transform: translateX(0); opacity: 1; }
}

@keyframes toastSlideOut {
    from { transform: translateX(0); opacity: 1; }
    to { transform: translateX(100%); opacity: 0; }
}

.toast.removing {
    animation: toastSlideOut 0.3s ease forwards;
}

/* ===================================
   ???�로???�션
   =================================== */

.my-uploads-section {
    margin-bottom: var(--spacing-xl);
}

.my-uploads-section h3 {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
    padding-bottom: var(--spacing-sm);
    border-bottom: 1px solid var(--border-color);
    color: var(--text-secondary);
}

/* ===================================
   로컬 카드 ?��???
   =================================== */

.local-card {
    border-color: rgba(122, 159, 207, 0.5);
    background: linear-gradient(135deg, rgba(25, 35, 50, 0.8), rgba(74, 106, 156, 0.1));
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3), 0 0 15px rgba(122, 159, 207, 0.1);
}

.local-badge {
    background: linear-gradient(135deg, #7a9fcf 0%, #5a7faf 100%) !important;
    color: #fff !important;
    font-size: 0.7rem !important;
    border: 1px solid rgba(122, 159, 207, 0.5) !important;
}

/* 삭제된 카드 스타일 */
.deleted-card {
    border-color: rgba(200, 80, 80, 0.5);
    background: linear-gradient(135deg, rgba(50, 25, 25, 0.8), rgba(156, 74, 74, 0.1));
    opacity: 0.7;
}

.deleted-badge {
    background: linear-gradient(135deg, #c85050 0%, #a03030 100%) !important;
    color: #fff !important;
    font-size: 0.7rem !important;
    border: 1px solid rgba(200, 80, 80, 0.5) !important;
}

/* ===================================
   ?�로??모달 ?��???
   =================================== */

.upload-type-selector {
    display: flex;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
}

.upload-type-btn {
    flex: 1;
    padding: var(--spacing-md);
    background: rgba(48, 54, 61, 0.3);
    border: 2px solid rgba(48, 54, 61, 0.4);
    border-radius: var(--radius-md);
    color: var(--text-secondary);
    font-weight: 500;
    cursor: pointer;
    transition: all var(--transition-fast);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
}

.upload-type-btn:hover {
    border-color: var(--gold-accent);
    color: var(--text-primary);
    background: rgba(91, 141, 239, 0.15);
}

.upload-type-btn.active {
    background: linear-gradient(135deg, #5b8def 0%, #4a7cd8 100%);
    border-color: rgba(91, 141, 239, 0.5);
    color: #ffffff;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

.upload-preview-card {
    background: rgba(25, 35, 50, 0.8);
    border: 2px solid rgba(91, 141, 239, 0.2);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
    display: flex;
    gap: var(--spacing-lg);
    align-items: center;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3);
}

.upload-preview-card .card-info {
    flex: 1;
    min-width: 0;
}

.upload-preview-card .card-author {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
}

.upload-preview-card .card-author img {
    width: 24px;
    height: 24px;
    border-radius: 50%;
}

.upload-preview-card .card-author span {
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.upload-preview-card .card-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: var(--spacing-sm);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.upload-preview-card .card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
}

.upload-preview-card .card-preview {
    flex-shrink: 0;
}

.upload-preview-card .deck-preview-grid {
    display: grid;
    grid-template-columns: repeat(6, 24px);
    grid-template-rows: repeat(2, 24px);
    gap: 3px;
}

.upload-preview-card .deck-preview-slot {
    width: 24px;
    height: 24px;
    background: rgba(13, 17, 23, 0.6);
    border: 1px solid rgba(74, 111, 165, 0.4);
    border-radius: 4px;
}

.upload-preview-card .deck-preview-slot.empty {
    background: repeating-linear-gradient(
        45deg,
        rgba(13, 17, 23, 0.6),
        rgba(13, 17, 23, 0.6) 3px,
        rgba(74, 111, 165, 0.2) 3px,
        rgba(74, 111, 165, 0.2) 4px
    );
}

.upload-preview-card .plan-preview-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    width: 100px;
}

.upload-preview-card .plan-preview-gift {
    width: 20px;
    height: 20px;
    background: rgba(13, 17, 23, 0.6);
    border: 1px solid rgba(74, 111, 165, 0.4);
    border-radius: 4px;
}

.upload-form {
    padding-top: var(--spacing-md);
    border-top: 2px solid rgba(74, 111, 165, 0.3);
}

.form-row {
    display: flex;
    gap: var(--spacing-md);
}

.form-row .flex-1 {
    flex: 1;
}

.label-hint {
    font-size: 0.75rem;
    color: var(--text-muted);
    font-weight: 400;
}

#parse-code-btn {
    margin-top: var(--spacing-sm);
}

/* ====================================
   별점 ?�스???��???
   ==================================== */

.card-stats {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-top: var(--spacing-sm);
    padding-top: var(--spacing-sm);
    border-top: 1px solid rgba(48, 54, 61, 0.2);
}

.card-rating-section {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-top: var(--spacing-xs);
    font-size: 0.8rem;
}

.rating-row {
    display: flex;
    align-items: center;
    gap: 6px;
}

.rating-row .rating-label {
    min-width: 45px;
    color: var(--text-muted);
    font-size: 0.75rem;
}

.rating-stars {
    display: flex;
    gap: 2px;
}

.rating-star {
    font-size: 0.85rem;
    color: #444;
    transition: all 0.15s ease;
}

.rating-star.filled {
    color: var(--gold-accent);
    text-shadow: 0 0 4px rgba(91, 141, 239, 0.5);
}

/* ??별점 ?��???*/
.rating-star.my-star {
    color: #444;
}

.rating-star.my-star.my-filled {
    color: #ff9500;
    text-shadow: 0 0 6px rgba(255, 149, 0, 0.6);
}

.rating-row.can-rate .rating-star.my-star {
    cursor: pointer;
}

.rating-row.can-rate .rating-star.my-star:hover,
.rating-row.can-rate .rating-star.my-star.hover {
    transform: scale(1.2);
    color: #ff9500;
}

.rating-row.locked .rating-stars {
    opacity: 0.5;
}

.rating-locked {
    font-size: 0.7rem;
    color: var(--text-muted);
    display: flex;
    align-items: center;
    gap: 4px;
}

.rating-locked i {
    font-size: 0.65rem;
}

.rating-value {
    font-weight: 600;
    color: var(--gold-accent);
    font-size: 0.8rem;
}

.rating-value.my-value {
    color: #ff9500;
}

.rating-count {
    font-size: 0.7rem;
    color: var(--text-muted);
}

.download-count {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 0.8rem;
    color: var(--text-secondary);
}

.download-count::before {
    content: "�?;
    font-size: 0.9rem;
}

/* 별점 ?�력 모달 */
.rating-modal {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: var(--surface-color);
    border: 2px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    z-index: 1100;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
    text-align: center;
}

.rating-modal h3 {
    margin-bottom: var(--spacing-md);
    color: var(--gold-accent);
}

.rating-input-stars {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-bottom: var(--spacing-md);
}

.rating-input-stars .rating-star {
    font-size: 2rem;
    cursor: pointer;
    transition: all 0.15s ease;
}

.rating-input-stars .rating-star:hover,
.rating-input-stars .rating-star.preview {
    transform: scale(1.1);
    color: var(--gold-accent);
    text-shadow: 0 0 8px rgba(91, 141, 239, 0.6);
}

.rating-modal-buttons {
    display: flex;
    gap: var(--spacing-sm);
    justify-content: center;
    margin-top: var(--spacing-md);
}

.rating-modal-buttons button {
    padding: 8px 20px;
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-weight: 500;
    transition: all 0.2s ease;
}

.rating-modal-buttons .btn-confirm {
    background: var(--gold-accent);
    border: none;
    color: var(--bg-primary);
}

.rating-modal-buttons .btn-confirm:hover {
    background: #e5c347;
}

.rating-modal-buttons .btn-cancel {
    background: transparent;
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
}

.rating-modal-buttons .btn-cancel:hover {
    border-color: var(--gold-accent);
    color: var(--gold-accent);
}

/* ====================================
   ?�이지?�이???��???
   ==================================== */

.pagination-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-md);
    margin-top: var(--spacing-md);
    background: rgba(25, 35, 50, 0.8);
    border: 2px solid rgba(74, 111, 165, 0.3);
    border-radius: var(--radius-lg);
}

.pagination-info {
    font-size: 0.85rem;
    color: var(--text-muted);
}

.pagination-buttons {
    display: flex;
    gap: var(--spacing-xs);
}

.pagination-btn {
    padding: 8px 14px;
    background: rgba(48, 72, 110, 0.3);
    border: 2px solid rgba(74, 111, 165, 0.4);
    border-radius: var(--radius-md);
    color: var(--text-secondary);
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.pagination-btn:hover {
    background: rgba(91, 141, 239, 0.2);
    border-color: var(--gold-accent);
    color: var(--text-primary);
}

.pagination-btn.active {
    background: linear-gradient(135deg, #5b8def 0%, #4a7cd8 100%);
    border-color: rgba(91, 141, 239, 0.5);
    color: #ffffff;
    font-weight: 600;
}

/* ====================================
   모달 ?��???
   ==================================== */

.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.8);
    display: none;
    justify-content: center;
    align-items: center;
    z-index: 1000;
    padding: var(--spacing-md);
    backdrop-filter: blur(4px);
}

.modal-overlay.active {
    display: flex;
}

.modal-content {
    background: var(--bg-secondary);
    border: 2px solid var(--border-color);
    border-radius: var(--radius-xl);
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: var(--shadow-lg), 0 0 40px rgba(91, 141, 239, 0.1);
}

.modal-small {
    width: 100%;
    max-width: 25rem; /* 400px at 16px */
}

.modal-large {
    width: 100%;
    max-width: 56.25rem; /* 900px at 16px */
    min-width: 50rem;
}

.modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-lg);
    border-bottom: 2px solid var(--border-color);
    background: rgba(25, 35, 50, 0.5);
}

.modal-header h3 {
    color: var(--gold-accent);
    font-size: 1.2rem;
    font-weight: 600;
}

.modal-close-btn {
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 1.5rem;
    cursor: pointer;
    padding: 4px 8px;
    line-height: 1;
    transition: color var(--transition-fast);
}

.modal-close-btn:hover {
    color: var(--text-primary);
}

.modal-body {
    padding: var(--spacing-lg);
}

.modal-footer {
    display: flex;
    justify-content: flex-end;
    gap: var(--spacing-md);
    padding: var(--spacing-lg);
    border-top: 2px solid var(--border-color);
    background: rgba(25, 35, 50, 0.5);
}

/* 로그??모달 */
.login-options {
    text-align: center;
}

.login-description {
    color: var(--text-secondary);
    margin-bottom: var(--spacing-lg);
}

.btn-login {
    width: 100%;
    padding: 14px;
    font-size: 1rem;
    margin-bottom: var(--spacing-md);
}

.btn-google {
    background: #fff;
    color: #333;
    border: 2px solid #ddd;
}

.btn-google:hover {
    background: #f5f5f5;
    border-color: #ccc;
}

.login-note {
    font-size: 0.85rem;
    color: var(--text-muted);
    padding-top: var(--spacing-md);
    border-top: 1px solid var(--border-color);
}

/* ?�네??모달 */
.nickname-description {
    color: var(--text-secondary);
    margin-bottom: var(--spacing-lg);
    text-align: center;
}

.nickname-status {
    font-size: 0.85rem;
    margin-top: var(--spacing-sm);
    min-height: 20px;
}

.nickname-status.error {
    color: var(--error);
}

.nickname-status.success {
    color: var(--success);
}

.nickname-status.checking {
    color: var(--text-muted);
}

/* ???�소 */
.form-group {
    margin-bottom: var(--spacing-md);
}

.form-group label {
    display: block;
    margin-bottom: var(--spacing-sm);
    color: var(--text-secondary);
    font-weight: 500;
    font-size: 0.9rem;
}

.form-group input,
.form-group textarea,
.form-group select {
    width: 100%;
    padding: 12px;
    background: var(--bg-tertiary);
    border: 2px solid var(--border-color);
    border-radius: var(--radius-md);
    color: var(--text-primary);
    font-size: 1rem;
    transition: border-color var(--transition-fast);
}

.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
    outline: none;
    border-color: var(--gold-accent);
}

.form-group input::placeholder,
.form-group textarea::placeholder {
    color: var(--text-muted);
}

.form-row {
    display: flex;
    gap: var(--spacing-md);
}

.form-row .form-group.flex-1 {
    flex: 1;
}

.label-hint {
    font-weight: 400;
    color: var(--text-muted);
    font-size: 0.8rem;
}

/* 버튼 ?��???*/
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    padding: 10px 20px;
    border-radius: var(--radius-md);
    font-weight: 500;
    cursor: pointer;
    transition: all var(--transition-fast);
    border: 2px solid transparent;
    font-size: 0.9rem;
}

.btn-primary {
    background: linear-gradient(135deg, #5b8def 0%, #4a7cd8 100%);
    color: #ffffff;
    border-color: rgba(91, 141, 239, 0.5);
}

.btn-primary:hover {
    background: linear-gradient(135deg, #6b9dff 0%, #5b8def 100%);
    box-shadow: 0 4px 12px rgba(91, 141, 239, 0.3);
}

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

.btn-secondary {
    background: rgba(48, 72, 110, 0.3);
    color: var(--text-secondary);
    border-color: rgba(74, 111, 165, 0.5);
}

.btn-secondary:hover {
    background: rgba(48, 72, 110, 0.5);
    color: var(--text-primary);
}

.btn-sm {
    padding: 6px 12px;
    font-size: 0.8rem;
}

/* ?�로??모달 */
.upload-preview-card {
    background: var(--bg-tertiary);
    border: 2px solid var(--border-color);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
}

.upload-form {
    margin-top: var(--spacing-lg);
}

.blessing-selection-area {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.selected-blessings-preview {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
    padding: var(--spacing-md);
    background: var(--bg-tertiary);
    border: 2px solid var(--border-color);
    border-radius: var(--radius-md);
    min-height: 50px;
}

.no-blessing-text {
    color: var(--text-muted);
    font-size: 0.9rem;
}

.btn-blessing-select {
    background: rgba(74, 106, 156, 0.3);
    color: #7a9fcf;
    border: 2px solid rgba(74, 106, 156, 0.5);
    padding: 10px 20px;
    cursor: pointer;
}

.btn-blessing-select:hover {
    background: rgba(74, 106, 156, 0.5);
}

.selected-blessing-tag {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    background: rgba(91, 141, 239, 0.2);
    border: 1px solid var(--gold-accent);
    border-radius: var(--radius-sm);
    font-size: 0.85rem;
    color: var(--gold-accent);
}

.remove-blessing {
    cursor: pointer;
    font-size: 1.1rem;
    line-height: 1;
}

.remove-blessing:hover {
    color: var(--error);
}

.blessing-total-tag {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    background: rgba(74, 124, 74, 0.2);
    border: 1px solid var(--success);
    border-radius: var(--radius-sm);
    font-size: 0.85rem;
    color: var(--success);
}

.code-inputs-section {
    margin-top: var(--spacing-md);
}

/* ====================================
   관리자???��???
   ==================================== */

.author-email {
    font-size: 0.75rem;
    color: var(--text-muted);
    margin-left: 4px;
}

.btn-ban {
    padding: 2px 8px;
    font-size: 0.7rem;
    background: rgba(156, 74, 74, 0.3);
    color: #cf7a7a;
    border: 1px solid rgba(156, 74, 74, 0.5);
    border-radius: var(--radius-sm);
    cursor: pointer;
    margin-left: 8px;
    transition: all var(--transition-fast);
}

.btn-ban:hover {
    background: rgba(156, 74, 74, 0.5);
    border-color: #cf7a7a;
}

.card-author {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 4px;
}

/* ====================================
   관리자 버튼 ?��???
   ==================================== */

.btn-admin {
    padding: 8px 16px;
    background: linear-gradient(135deg, rgba(156, 74, 74, 0.8) 0%, rgba(120, 50, 50, 0.8) 100%);
    color: #ffcccc;
    border: 2px solid rgba(156, 74, 74, 0.6);
    border-radius: var(--radius-md);
    font-weight: 600;
    font-size: 0.85rem;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.btn-admin:hover {
    background: linear-gradient(135deg, rgba(180, 90, 90, 0.9) 0%, rgba(140, 60, 60, 0.9) 100%);
    border-color: #cf7a7a;
    box-shadow: 0 0 10px rgba(156, 74, 74, 0.4);
}

/* ====================================
   관리자 ?�널 ?��???(??기반)
   ==================================== */

.admin-panel-content {
    padding: var(--spacing-md);
    background: var(--bg-secondary);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border-color);
}

.admin-tabs {
    display: flex;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
    border-bottom: 2px solid var(--border-color);
    padding-bottom: var(--spacing-sm);
}

.admin-tab-btn {
    padding: 10px 20px;
    background: transparent;
    color: var(--text-secondary);
    border: none;
    border-radius: var(--radius-md) var(--radius-md) 0 0;
    cursor: pointer;
    font-weight: 500;
    transition: all var(--transition-fast);
}

.admin-tab-btn:hover {
    color: var(--text-primary);
    background: rgba(91, 141, 239, 0.1);
}

.admin-tab-btn.active {
    color: var(--gold-accent);
    background: rgba(91, 141, 239, 0.2);
    border-bottom: 2px solid var(--gold-accent);
    margin-bottom: -2px;
}

.admin-tab-content {
    display: none;
    flex: 1;
    overflow: hidden;
    flex-direction: column;
}

.admin-tab-content.active {
    display: flex;
}

.admin-search {
    margin-bottom: var(--spacing-md);
    display: flex;
    gap: 8px;
    align-items: center;
}

.admin-search input {
    flex: 1;
    padding: 12px;
    background: var(--bg-tertiary);
    border: 2px solid var(--border-color);
    border-radius: var(--radius-md);
    color: var(--text-primary);
    font-size: 0.95rem;
}

.admin-search input:focus {
    outline: none;
    border-color: var(--gold-accent);
}

.admin-refresh-btn {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-tertiary);
    border: 2px solid var(--border-color);
    border-radius: var(--radius-md);
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.2s;
    flex-shrink: 0;
}

.admin-refresh-btn:hover {
    background: var(--bg-secondary);
    border-color: var(--gold-accent);
    color: var(--gold-accent);
}

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

.admin-refresh-btn.spinning i {
    animation: spin 1s linear infinite;
}

@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.admin-list {
    flex: 1;
    overflow-y: auto;
    max-height: 60vh;
}

.admin-user-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-md);
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-sm);
    transition: all var(--transition-fast);
}

.admin-user-item:hover {
    border-color: var(--gold-accent);
    background: rgba(91, 141, 239, 0.05);
}

.admin-user-item.banned {
    background: rgba(156, 74, 74, 0.1);
    border-color: rgba(156, 74, 74, 0.3);
}

.admin-user-info {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    flex: 1;
}

.admin-user-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--border-color);
}

.admin-user-details {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.admin-user-name {
    font-weight: 600;
    color: var(--text-primary);
}

.admin-user-email {
    font-size: 0.85rem;
    color: var(--text-muted);
}

.admin-user-meta {
    display: flex;
    gap: 1rem;
    align-items: center;
    flex-wrap: wrap;
}

.admin-user-id {
    font-size: 0.75rem;
    color: var(--text-muted);
    font-family: monospace;
}

.admin-user-last-login {
    font-size: 0.75rem;
    color: var(--primary-light);
}

.admin-user-actions {
    display: flex;
    gap: var(--spacing-sm);
}

.admin-action-btn {
    padding: 6px 12px;
    border-radius: var(--radius-sm);
    font-size: 0.8rem;
    font-weight: 500;
    cursor: pointer;
    transition: all var(--transition-fast);
    border: 1px solid;
}

.admin-action-btn.ban {
    background: rgba(156, 74, 74, 0.3);
    color: #cf7a7a;
    border-color: rgba(156, 74, 74, 0.5);
}

.admin-action-btn.ban:hover {
    background: rgba(156, 74, 74, 0.5);
}

.admin-action-btn.unban {
    background: rgba(74, 124, 74, 0.3);
    color: #7acf7a;
    border-color: rgba(74, 124, 74, 0.5);
}

.admin-action-btn.unban:hover {
    background: rgba(74, 124, 74, 0.5);
}

.admin-action-btn.delete {
    background: rgba(180, 50, 50, 0.3);
    color: #ff8080;
    border-color: rgba(180, 50, 50, 0.5);
}

.admin-action-btn.delete:hover {
    background: rgba(180, 50, 50, 0.5);
}

.admin-empty-state {
    text-align: center;
    padding: var(--spacing-xl);
    color: var(--text-muted);
}

.admin-user-badge {
    padding: 2px 8px;
    border-radius: var(--radius-sm);
    font-size: 0.7rem;
    font-weight: 600;
    margin-left: 8px;
}

.admin-user-badge.banned {
    background: rgba(156, 74, 74, 0.3);
    color: #cf7a7a;
}

.admin-user-badge.admin {
    background: rgba(91, 141, 239, 0.3);
    color: var(--gold-accent);
}

/* ===================================
   설명 상세 모달
   =================================== */
#description-modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.8);
    z-index: 10000;
    align-items: center;
    justify-content: center;
}

#description-modal.show {
    display: flex;
}

#description-modal .modal-content {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-lg);
    max-width: 600px;
    width: 90%;
    max-height: 80vh;
    display: flex;
    flex-direction: column;
}

#description-modal .modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-md) var(--spacing-lg);
    border-bottom: 1px solid var(--border-color);
}

#description-modal .modal-header h3 {
    margin: 0;
    font-size: 1.1rem;
    color: var(--text-primary);
}

#description-modal .modal-header .close-btn {
    background: none;
    border: none;
    font-size: 1.5rem;
    color: var(--text-muted);
    cursor: pointer;
    padding: 0;
    line-height: 1;
}

#description-modal .modal-header .close-btn:hover {
    color: var(--text-primary);
}

#description-modal .modal-body {
    padding: var(--spacing-lg);
    overflow-y: auto;
    flex: 1;
}

#description-modal .description-content {
    font-size: 0.95rem;
    color: var(--text-primary);
    line-height: 1.7;
    white-space: pre-wrap;
    word-break: break-word;
}

#description-modal .description-content a {
    color: var(--accent-color);
    text-decoration: underline;
}

#description-modal .description-content a:hover {
    color: var(--gold-accent);
}

/* ===================================
   푸터 스타일
   =================================== */
.site-footer {
    background: var(--bg-secondary);
    border-top: 1px solid var(--border-color);
    padding: var(--spacing-lg) var(--spacing-xl);
    margin-top: auto;
    text-align: center;
}

.footer-content {
    max-width: 800px;
    margin: 0 auto;
}

.footer-content p {
    margin: 0.3rem 0;
    font-size: 0.8rem;
    color: var(--text-muted);
}

.footer-content p:first-child {
    font-weight: 600;
    color: var(--text-secondary);
    margin-bottom: 0.5rem;
}

.footer-content a {
    color: var(--accent-primary);
    text-decoration: none;
}

.footer-content a:hover {
    text-decoration: underline;
}

/* ===================================
   사이드 광고 영역
   =================================== */
/* 광고 미승인 상태 - 승인 후 아래 display: none 제거 */
/* 요청 시 광고칸 다시 보이게 변경 */
.side-ad {
    display: none;
}

.bottom-ad {
    display: none;
}

/* 요청 시 광고칸 다시 보이게 변경
   광고 승인 후 위의 display: none 삭제하고 아래 주석 해제

.side-ad {
    position: fixed;
    top: 50%;
    transform: translateY(-50%);
    width: 160px;
    min-height: 600px;
    z-index: 100;
    display: flex;
    align-items: center;
    justify-content: center;
}

.side-ad.left-ad {
    left: 10px;
}

.side-ad.right-ad {
    right: 10px;
}

.ad-placeholder {
    width: 160px;
    height: 600px;
    background: rgba(22, 27, 34, 0.8);
    border: 1px dashed var(--border-color);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-muted);
    font-size: 0.75rem;
}

@media (min-width: 1700px) {
    .side-ad {
        display: flex;
    }
}

@media (max-width: 1699px) {
    .side-ad {
        display: none;
    }
}

.bottom-ad {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: var(--spacing-lg) 0;
    margin-top: var(--spacing-xl);
}

.ad-placeholder-horizontal {
    width: 728px;
    height: 90px;
    max-width: 100%;
    background: rgba(22, 27, 34, 0.8);
    border: 1px dashed var(--border-color);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-muted);
    font-size: 0.75rem;
}

/* 요청 시 광고칸 다시 보이게 변경 */

/* 후원하기 버튼 */
.donate-btn {
    background: linear-gradient(135deg, #ff6b6b, #ee5a5a);
    color: white;
    border: none;
    padding: 0.5rem 1rem;
    border-radius: 0.5rem;
    font-size: 0.875rem;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 0.4rem;
    transition: all 0.2s ease;
    margin-left: 1rem;
}

.donate-btn:hover {
    background: linear-gradient(135deg, #ff5252, #e04848);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(238, 90, 90, 0.4);
}

.donate-btn i {
    font-size: 1rem;
}

/* 후원 모달 */
.donate-modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.7);
    display: none;
    justify-content: center;
    align-items: center;
    z-index: 10000;
}

.donate-modal-overlay.active {
    display: flex;
}

.donate-modal-content {
    background: #2a2a2a;
    border-radius: 1rem;
    padding: 2rem;
    max-width: 400px;
    width: 90%;
    text-align: center;
    position: relative;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
}

.donate-modal-content h3 {
    color: #fff;
    margin: 0 0 0.5rem 0;
    font-size: 1.5rem;
}

.donate-modal-content > p {
    color: #aaa;
    margin: 0 0 1.5rem 0;
    font-size: 0.9rem;
}

.donate-modal-close {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    background: none;
    border: none;
    color: #888;
    font-size: 1.5rem;
    cursor: pointer;
    line-height: 1;
    padding: 0.25rem;
}

.donate-modal-close:hover {
    color: #fff;
}

.donate-options {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.donate-option.coffee-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    background: linear-gradient(135deg, #ffdd00, #ffc800);
    color: #333;
    padding: 1rem 1.5rem;
    border-radius: 0.75rem;
    font-size: 1.1rem;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.2s ease;
}

.donate-option.coffee-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(255, 200, 0, 0.4);
}

.donate-option.coffee-btn i {
    font-size: 1.3rem;
}

.donate-option.qr-option {
    background: #333;
    border-radius: 0.75rem;
    padding: 1rem;
}

.donate-option.qr-option p {
    color: #aaa;
    margin: 0 0 0.75rem 0;
    font-size: 0.9rem;
}

.donate-qr {
    width: 180px;
    height: 180px;
    border-radius: 0.5rem;
    background: white;
    padding: 0.5rem;
}

/* ===================================
   신고 시스템 스타일
   =================================== */

/* 신고 버튼 */
.card-action-btn.warning {
    background: linear-gradient(135deg, #f5a623, #e09500);
    color: white;
}

.card-action-btn.warning:hover {
    background: linear-gradient(135deg, #e09500, #c68000);
}

/* 신고 모달 */
.report-target-info {
    background: var(--bg-tertiary);
    padding: 0.75rem 1rem;
    border-radius: var(--radius-sm);
    margin-bottom: 1rem;
    font-size: 0.9rem;
}

#report-reason {
    width: 100%;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
    border-radius: var(--radius-sm);
    padding: 0.75rem;
    font-size: 0.9rem;
    resize: vertical;
}

#report-reason:focus {
    outline: none;
    border-color: var(--primary-color);
}

.char-count {
    text-align: right;
    font-size: 0.75rem;
    color: var(--text-muted);
    margin-top: 0.25rem;
}

/* 신고 내역 보기 모달 */
.reports-list {
    max-height: 400px;
    overflow-y: auto;
}

.report-item {
    background: var(--bg-tertiary);
    border-radius: var(--radius-sm);
    padding: 1rem;
    margin-bottom: 0.75rem;
}

.report-header {
    display: flex;
    justify-content: space-between;
    margin-bottom: 0.5rem;
    font-size: 0.85rem;
}

.report-user {
    font-weight: 600;
    color: var(--primary-color);
}

.report-date {
    color: var(--text-muted);
}

.report-reason {
    color: var(--text-secondary);
    font-size: 0.9rem;
    line-height: 1.5;
}

.empty-reports {
    text-align: center;
    color: var(--text-muted);
    padding: 2rem;
}

/* 관리자 패널 - 신고된 카드 */
.admin-report-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: 1rem;
    margin-bottom: 0.75rem;
}

.admin-report-info {
    flex: 1;
}

.admin-report-title {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.25rem;
}

.admin-report-count {
    background: #f5a623;
    color: white;
    padding: 0.15rem 0.5rem;
    border-radius: 0.25rem;
    font-size: 0.75rem;
    font-weight: 600;
}

.admin-report-author {
    font-size: 0.85rem;
    color: var(--text-muted);
    margin-bottom: 0.5rem;
}

.admin-report-latest {
    font-size: 0.8rem;
    color: var(--text-secondary);
}

.admin-report-latest .report-label {
    color: var(--text-muted);
    margin-right: 0.5rem;
}

.admin-report-latest .report-user {
    margin-right: 0.5rem;
}

.admin-report-latest .report-reason {
    font-style: italic;
}

.admin-report-actions {
    display: flex;
    gap: 0.5rem;
}

.admin-action-btn.view {
    background: var(--primary-color);
}

.admin-action-btn.view:hover {
    background: var(--primary-hover);
}

/* 모달 footer 버튼 스타일 */
.btn-warning {
    background: linear-gradient(135deg, #f5a623, #e09500);
    color: white;
    border: none;
}

.btn-warning:hover {
    background: linear-gradient(135deg, #e09500, #c68000);
}

.btn-danger {
    background: linear-gradient(135deg, #dc3545, #c82333);
    color: white;
    border: none;
}

.btn-danger:hover {
    background: linear-gradient(135deg, #c82333, #bd2130);
}
