/**
 * 파일명: points.css
 * 위치: /wp-content/plugins/jmp-mypage/assets/css/
 * 설명: JSeeds 페이지 전용 스타일 — v4.0 Modern Redesign
 * 버전: 4.0.0
 */

/* ════════════════════════════════════════
   래퍼
   ════════════════════════════════════════ */
.joyn-points-wrapper {
    padding-top: var(--joyn-space-5);
    padding-bottom: 100px;
    display: flex;
    flex-direction: column;
    gap: var(--joyn-space-4);
}

/* ════════════════════════════════════════
   공지 노티스 (휴대폰 인증 안내)
   ════════════════════════════════════════ */
.joyn-points-wrapper .jmp-notice-points-after-verify {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin: 0;
    padding: var(--joyn-space-4);
    background: var(--bg-2);
    border-left: 3px solid var(--brand);
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
    font-size: var(--joyn-text-sm);
    color: var(--text-2);
}
.joyn-points-wrapper .jmp-notice-points-after-verify::before {
    content: '\EECE';
    font-family: 'remixicon';
    font-size: 15px;
    color: var(--brand);
    flex-shrink: 0;
    line-height: 1.5;
}

/* ════════════════════════════════════════
   HERO BALANCE CARD — 딥 그라데이션
   ════════════════════════════════════════ */
.joyn-points-wrapper .balance-card {
    background: linear-gradient(135deg, var(--brand) 0%, var(--brand-dark) 45%, #2a1f8f 100%);
    border-radius: var(--radius-xl, 20px) !important;
    border: none !important;
    padding: clamp(24px,5vw,36px) !important;
    position: relative;
    overflow: hidden;
    box-shadow: 0 12px 36px rgba(69,65,255,.28) !important;
    color: var(--brand-contrast);
}
.joyn-points-wrapper .balance-card::before {
    content: '';
    position: absolute;
    top: -60px; right: -40px;
    width: 220px; height: 220px;
    border-radius: 50%;
    background: rgba(255,255,255,.06);
    pointer-events: none;
}
.joyn-points-wrapper .balance-card::after {
    content: '';
    position: absolute;
    bottom: -30px; left: -20px;
    width: 150px; height: 150px;
    border-radius: 50%;
    background: rgba(255,255,255,.04);
    pointer-events: none;
}

/* 잔액 카드 내부 로고 행 */
.joyn-points-wrapper .balance-card .jseeds-logo {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: clamp(16px,3vw,22px);
    position: relative; z-index: 1;
}
.joyn-points-wrapper .balance-card .jseeds-logo-icon {
    width: 32px; height: 32px;
    background: rgba(255,255,255,.18);
    border-radius: var(--radius-sm);
    display: flex; align-items: center; justify-content: center;
    font-size: 17px; line-height: 1;
}
.joyn-points-wrapper .balance-card .jseeds-logo-text {
    font-size: 12px; font-weight: 800;
    color: rgba(255,255,255,.88);
    letter-spacing: 1px; text-transform: uppercase;
}

/* 잔액 레이블 */
.joyn-points-wrapper .balance-label {
    font-size: var(--joyn-text-sm);
    font-weight: 600;
    color: rgba(255,255,255,.75);
    position: relative; z-index: 1;
    margin-bottom: 6px;
}

/* 잔액 숫자 */
.joyn-points-wrapper .balance-value {
    font-size: clamp(34px,8vw,52px);
    font-weight: 900;
    color: var(--brand-contrast);
    letter-spacing: -1.5px;
    position: relative; z-index: 1;
    line-height: 1.1;
    margin-bottom: clamp(16px,3vw,24px);
}
.joyn-points-wrapper .balance-value .unit {
    font-size: .42em; font-weight: 700;
    opacity: .8; vertical-align: super;
    margin-left: 4px; letter-spacing: 0;
}

/* 레벨 행 */
.joyn-points-wrapper .level-info {
    display: flex;
    align-items: center;
    gap: 12px;
    position: relative; z-index: 1;
}
.joyn-points-wrapper .level-badge-pill {
    background: rgba(255,255,255,.18);
    border: 1px solid rgba(255,255,255,.25);
    border-radius: var(--radius-full);
    padding: 4px 12px;
    font-size: var(--joyn-text-sm); font-weight: 800;
    color: var(--brand-contrast);
    white-space: nowrap;
}
.joyn-points-wrapper .level-progress-wrap {
    flex: 1;
    display: flex; flex-direction: column; gap: 4px;
}
.joyn-points-wrapper .progress-bar {
    height: 6px;
    background: rgba(255,255,255,.22);
    border-radius: var(--radius-full);
    overflow: hidden;
    max-width: none;
}
.joyn-points-wrapper .progress-fill {
    height: 100%;
    background: rgba(255,255,255,.88);
    border-radius: var(--radius-full);
    transition: width .8s cubic-bezier(.4,0,.2,1);
}
.joyn-points-wrapper .level-next-text {
    font-size: var(--joyn-text-xs);
    color: rgba(255,255,255,.62);
    text-align: right;
}

/* ════════════════════════════════════════
   통계 카드 행 (총 획득 / 총 사용 — 각 50%)
   ════════════════════════════════════════ */
.joyn-points-wrapper .stats-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: var(--joyn-space-3);
}
.joyn-points-wrapper .stat-card {
    background: var(--bg-card);
    border-radius: var(--radius-lg) !important;
    border: 1px solid var(--border-1) !important;
    padding: clamp(14px,3vw,18px);
    display: flex; flex-direction: column;
    align-items: center; gap: 6px;
    text-align: center;
    box-shadow: var(--shadow-sm);
    transition: all var(--transition);
}
.joyn-points-wrapper .stat-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}
.joyn-points-wrapper .stat-icon-wrap {
    width: 36px; height: 36px;
    border-radius: var(--radius-sm);
    display: flex; align-items: center; justify-content: center;
    font-size: 18px;
}
.joyn-points-wrapper .stat-icon-wrap.earned { background: var(--success-bg); color: var(--success); }
.joyn-points-wrapper .stat-icon-wrap.spent  { background: var(--error-bg);   color: var(--error); }

.joyn-points-wrapper .stat-card .stat-value {
    font-size: var(--joyn-text-lg);
    font-weight: 800;
    color: var(--text-1);
    display: block; line-height: 1;
}
.joyn-points-wrapper .stat-card .stat-label {
    font-size: var(--joyn-text-xs);
    font-weight: 600;
    color: var(--text-3);
}

/* ════════════════════════════════════════
   거래 내역 카드
   ════════════════════════════════════════ */
.joyn-points-wrapper .transactions-card {
    border-radius: var(--radius-lg) !important;
}

/* 헤더 */
.joyn-points-wrapper .section-header {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    margin-bottom: var(--joyn-space-4);
    flex-wrap: wrap;
}
.joyn-points-wrapper .section-title {
    font-size: var(--joyn-text-xs);
    font-weight: 800;
    color: var(--text-3);
    text-transform: uppercase;
    letter-spacing: .7px;
    margin: 0 !important;
    padding: 0 !important;
    background: none;
    border-radius: 0;
    width: auto !important;
}
.joyn-points-wrapper .section-title i { display: none; }

/* 필터 그룹 */
.joyn-points-wrapper .filter-group {
    display: flex;
    gap: 4px;
    background: var(--bg-2);
    padding: 4px;
    border-radius: var(--radius);
    border: 1px solid var(--border-2);
    margin: 0;
}
.joyn-points-wrapper .filter-btn {
    padding: 6px 14px;
    border-radius: var(--radius-sm);
    border: none;
    background: transparent;
    font-family: inherit;
    font-size: var(--joyn-text-sm);
    font-weight: 700;
    color: var(--text-3);
    cursor: pointer;
    transition: all var(--transition);
    min-height: 32px;
    display: inline-flex; align-items: center; justify-content: center;
}
.joyn-points-wrapper .filter-btn.active {
    background: var(--bg-1);
    color: var(--brand);
    box-shadow: var(--shadow-sm);
}
.joyn-points-wrapper .filter-btn:hover:not(.active) { color: var(--text-2); }
.joyn-points-wrapper .filter-btn:active { transform: scale(.97); }

/* ════════════════════════════════════════
   거래 아이템
   ════════════════════════════════════════ */
.joyn-points-wrapper .transaction-list {
    display: flex;
    flex-direction: column;
}
.joyn-points-wrapper .transaction-item {
    display: flex;
    align-items: center;
    gap: var(--joyn-space-4);
    padding: clamp(12px,2.5vw,15px) 0;
    border-bottom: 1px solid var(--border-2);
    transition: all var(--transition);
}
.joyn-points-wrapper .transaction-item:last-of-type { border-bottom: none; }
.joyn-points-wrapper .transaction-item:hover {
    background: var(--bg-2);
    margin-inline: calc(-1 * var(--joyn-space-5));
    padding-inline: var(--joyn-space-5);
    border-radius: var(--radius-sm);
}

/* 아이콘 (숨김 → 표시로 변경) */
.joyn-points-wrapper .transaction-icon {
    display: flex !important;
    width: 38px; height: 38px;
    border-radius: var(--radius);
    align-items: center; justify-content: center;
    font-size: 18px; flex-shrink: 0;
}
.joyn-points-wrapper .transaction-icon.earned { background: var(--success-bg); color: var(--success); }
.joyn-points-wrapper .transaction-icon.spent  { background: var(--error-bg);   color: var(--error); }
.joyn-points-wrapper .transaction-icon.bonus  { background: var(--warning-bg); color: var(--warning); }
.joyn-points-wrapper .transaction-icon.login  { background: var(--brand-glow); color: var(--brand); }

.joyn-points-wrapper .transaction-details { flex: 1; min-width: 0; }
.joyn-points-wrapper .transaction-title {
    font-size: var(--joyn-text-md, var(--joyn-text-base));
    font-weight: 700;
    color: var(--text-1);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    margin-bottom: 3px;
}
.joyn-points-wrapper .transaction-date {
    font-size: var(--joyn-text-xs);
    color: var(--text-3); font-weight: 500;
}
.joyn-points-wrapper .transaction-amount {
    font-size: var(--joyn-text-lg);
    font-weight: 800;
    flex-shrink: 0;
    letter-spacing: -0.3px;
}
.joyn-points-wrapper .amount-earned { color: var(--success); }
.joyn-points-wrapper .amount-spent  { color: var(--error); }

/* ════════════════════════════════════════
   더보기 버튼
   ════════════════════════════════════════ */
.joyn-points-wrapper .load-more {
    width: 100%; margin-top: var(--joyn-space-4);
    padding: 12px;
    background: var(--bg-2);
    border: 1.5px solid var(--border-1);
    border-radius: var(--radius);
    cursor: pointer;
    font-family: inherit;
    font-size: var(--joyn-text-sm); font-weight: 700;
    color: var(--text-2);
    display: flex; align-items: center; justify-content: center; gap: 8px;
    transition: all var(--transition);
    min-height: 44px;
}
.joyn-points-wrapper .load-more:hover {
    background: var(--bg-3);
    border-color: var(--text-3);
    color: var(--text-1);
}
.joyn-points-wrapper .load-more:active { transform: scale(.98); }

/* ════════════════════════════════════════
   빈 상태
   ════════════════════════════════════════ */
.joyn-points-wrapper .empty-state {
    text-align: center;
    padding: var(--joyn-space-10);
    color: var(--text-2);
}
.joyn-points-wrapper .empty-icon {
    font-size: clamp(44px,10vw,52px);
    margin-bottom: var(--joyn-space-4);
    color: var(--brand); opacity: .2;
    display: block;
}
.joyn-points-wrapper .empty-message {
    font-size: var(--joyn-text-base); margin: 0;
}

/* ════════════════════════════════════════
   JSeeds 획득 방법 가이드
   ════════════════════════════════════════ */
.joyn-points-wrapper .earn-guide-card {
    border-radius: var(--radius-lg) !important;
}
.joyn-points-wrapper .earn-item-list {
    display: flex; flex-direction: column; gap: var(--joyn-space-3);
}
.joyn-points-wrapper .earn-item {
    display: flex; align-items: center;
    gap: var(--joyn-space-4);
    padding: clamp(12px,2.5vw,15px);
    background: var(--bg-2);
    border-radius: var(--radius);
    border: 1px solid var(--border-2);
    transition: all var(--transition);
}
.joyn-points-wrapper .earn-item:hover {
    background: var(--bg-3);
    transform: translateX(3px);
    border-color: var(--brand-glow);
}
.joyn-points-wrapper .earn-item-icon {
    width: 40px; height: 40px;
    border-radius: var(--radius);
    display: flex; align-items: center; justify-content: center;
    font-size: 20px; flex-shrink: 0;
}
.joyn-points-wrapper .earn-item-info { flex: 1; min-width: 0; }
.joyn-points-wrapper .earn-item-title {
    font-size: var(--joyn-text-base); font-weight: 700; color: var(--text-1);
}
.joyn-points-wrapper .earn-item-desc {
    font-size: var(--joyn-text-xs); color: var(--text-3); margin-top: 2px;
}
.joyn-points-wrapper .earn-item-pts {
    font-size: var(--joyn-text-base); font-weight: 800; color: var(--brand);
    flex-shrink: 0; white-space: nowrap;
}

/* ════════════════════════════════════════
   반응형
   ════════════════════════════════════════ */
@media (max-width: 500px) {
    .joyn-points-wrapper .stats-row { gap: var(--joyn-space-2); }
    .joyn-points-wrapper .stat-card { padding: 12px 8px; }
    .joyn-points-wrapper .section-header { flex-direction: column !important; align-items: flex-start !important; }
    .joyn-points-wrapper .filter-group { width: 100%; }
    .joyn-points-wrapper .filter-btn { flex: 1; }
}
