/* ============================================================
 * 테더(USDT) 섹션 — 가이드/정보/거래소/지갑 공통 스타일
 * 톤: democoin 히어로와 통일 (다크 + 시안/보라 네온)
 * ============================================================ */
:root {
    --td-bg-0: #05080f;
    --td-bg-1: #0a1120;
    --td-bg-2: #0f1830;
    --td-bg-3: #162040;
    --td-line: #1c2744;
    --td-line-2: #2a3558;
    --td-ink-0: #ffffff;
    --td-ink-1: #c5d0e6;
    --td-ink-2: #8595b2;
    --td-ink-3: #5a6a8a;
    --td-cyan: #00f5ff;
    --td-violet: #a855f7;
    --td-emerald: #10b981;
    --td-gold: #ffcc33;
    --td-red: #ff4577;
    --td-tether: #26a17b;
}

.td-wrap {
    max-width: 1080px;
    margin: 16px auto 48px;
    padding: 0 16px;
    color: var(--td-ink-1);
    font-family: inherit;
    width:100%
}

/* ===== 헤더 + 탭 ===== */
.td-header {
    background: linear-gradient(180deg, rgba(38, 161, 123, .12) 0%, rgba(10, 17, 32, 0) 100%),
                linear-gradient(180deg, var(--td-bg-2) 0%, var(--td-bg-1) 100%);
    border: 1px solid var(--td-line);
    border-radius: 16px;
    overflow: hidden;
    margin-bottom: 20px;
}
.td-header-inner { padding: 24px 28px; }
.td-brand { display: flex; align-items: center; gap: 16px; }
.td-brand-logo {
    width: 56px; height: 56px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--td-tether), #1a7a5c);
    display: flex; align-items: center; justify-content: center;
    font-size: 32px; font-weight: 900; color: #fff;
    box-shadow: 0 6px 20px rgba(38, 161, 123, .4);
}
.td-brand-txt b { font-size: 22px; color: var(--td-ink-0); font-weight: 900; letter-spacing: -.01em; }
.td-brand-txt small { display: block; font-size: 12px; color: var(--td-ink-2); margin-top: 2px; }

.td-tabs {
    display: flex;
    gap: 2px;
    background: rgba(0, 0, 0, .2);
    padding: 4px;
    border-top: 1px solid var(--td-line);
}
.td-tab {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 12px;
    background: transparent;
    border-radius: 10px;
    color: var(--td-ink-2);
    text-decoration: none;
    font-weight: 700;
    font-size: 13px;
    transition: all .2s ease;
}
.td-tab:hover { color: var(--td-ink-0); background: rgba(255, 255, 255, .04); }
.td-tab.is-active {
    background: linear-gradient(135deg, rgba(0, 245, 255, .15), rgba(168, 85, 247, .15));
    color: var(--td-ink-0);
    box-shadow: 0 0 0 1px rgba(0, 245, 255, .3) inset, 0 8px 20px rgba(0, 245, 255, .1);
}
.td-tab-ic { font-size: 18px; }

.td-main { min-height: 400px; }

/* ===== 가이드: 진행 바 ===== */
.td-progress-bar {
    position: sticky;
    top: 0;
    z-index: 80;
    background: rgba(10, 17, 32, .95);
    backdrop-filter: blur(12px);
    border: 1px solid var(--td-line);
    border-radius: 12px;
    padding: 12px 18px;
    margin-bottom: 24px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, .4);
}
.td-progress-row {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 10px;
    font-size: 12px;
}
.td-progress-label b { color: var(--td-cyan); margin-left: 6px; font-size: 14px; font-weight: 900; }
.td-progress-chk { color: var(--td-ink-2); }
.td-progress-chk span { color: var(--td-ink-0); font-weight: 800; }
.td-progress-reward { margin-left: auto; color: var(--td-ink-2); }
.td-progress-reward b { color: var(--td-gold); font-weight: 900; }
.td-progress-track {
    height: 6px;
    background: rgba(255, 255, 255, .06);
    border-radius: 999px;
    overflow: hidden;
}
.td-progress-fill {
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg, var(--td-cyan), var(--td-violet), var(--td-gold));
    transition: width .4s ease;
    box-shadow: 0 0 10px rgba(0, 245, 255, .5);
}

/* ===== 가이드 히어로 ===== */
.td-hero {
    padding: 32px 32px 24px;
    margin-bottom: 24px;
    background: radial-gradient(900px 200px at 50% 0%, rgba(168, 85, 247, .14), transparent 70%),
                linear-gradient(180deg, var(--td-bg-2), var(--td-bg-1));
    border: 1px solid var(--td-line);
    border-radius: 16px;
}
.td-hero-tag {
    display: inline-block;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .15em;
    color: var(--td-cyan);
    background: rgba(0, 245, 255, .1);
    padding: 4px 10px;
    border-radius: 999px;
    border: 1px solid rgba(0, 245, 255, .3);
    margin-bottom: 14px;
}
.td-hero-title {
    font-size: 26px;
    font-weight: 900;
    color: var(--td-ink-0);
    line-height: 1.35;
    margin: 0 0 14px;
    letter-spacing: -.02em;
}
.td-hero-title em { font-style: normal; color: var(--td-cyan); }
.td-hero-desc {
    font-size: 14px;
    line-height: 1.8;
    color: var(--td-ink-1);
    margin: 0;
}
.td-hero-desc b { color: var(--td-ink-0); }

/* ===== 가이드 섹션 ===== */
.td-sec {
    position: relative;
    margin-bottom: 20px;
    padding: 28px 32px;
    background: linear-gradient(180deg, var(--td-bg-2), var(--td-bg-1));
    border: 1px solid var(--td-line);
    border-radius: 14px;
    transition: border-color .25s ease, box-shadow .25s ease;
}
.td-sec.is-checked {
    border-color: rgba(16, 185, 129, .5);
    box-shadow: 0 0 0 1px rgba(16, 185, 129, .2) inset, 0 10px 30px rgba(16, 185, 129, .08);
}
.td-sec-no {
    position: absolute;
    top: -10px;
    left: 24px;
    padding: 4px 12px;
    background: linear-gradient(135deg, var(--td-cyan), var(--td-violet));
    color: var(--td-bg-0);
    font-weight: 900;
    font-size: 11px;
    letter-spacing: .1em;
    border-radius: 999px;
}
.td-sec.is-checked .td-sec-no {
    background: linear-gradient(135deg, var(--td-emerald), #0a8a5c);
    color: #fff;
}
.td-sec-title {
    font-size: 20px;
    font-weight: 900;
    color: var(--td-ink-0);
    margin: 6px 0 18px;
    letter-spacing: -.01em;
}
.td-sec-body {
    font-size: 14px;
    line-height: 1.85;
    color: var(--td-ink-1);
}
.td-sec-body p { margin: 0 0 14px; }
.td-sec-body b { color: var(--td-ink-0); font-weight: 700; }
.td-sec-body code {
    font-family: 'Consolas', 'Menlo', monospace;
    font-size: 12px;
    padding: 2px 6px;
    background: rgba(0, 245, 255, .1);
    border-radius: 4px;
    color: var(--td-cyan);
}
.td-sec-body ul, .td-sec-body ol { margin: 8px 0 14px; padding-left: 20px; }
.td-sec-body ul li, .td-sec-body ol li { margin-bottom: 6px; }
.td-sub { font-size: 12px; color: var(--td-ink-2); margin-top: 10px !important; }

/* ===== 콜아웃 박스 ===== */
.td-callout {
    padding: 14px 18px;
    border-radius: 10px;
    margin: 16px 0;
    font-size: 13px;
    line-height: 1.75;
    border: 1px solid;
}
.td-callout b { color: var(--td-ink-0); font-weight: 800; }
.td-callout ul { margin: 6px 0 0; padding-left: 18px; }
.td-callout-info    { background: rgba(0, 245, 255, .08);  border-color: rgba(0, 245, 255, .3);  color: var(--td-ink-1); }
.td-callout-warn    { background: rgba(255, 204, 51, .08); border-color: rgba(255, 204, 51, .35); color: var(--td-ink-1); }
.td-callout-danger  { background: rgba(255, 69, 119, .1);  border-color: rgba(255, 69, 119, .4);  color: var(--td-ink-1); }
.td-callout-success { background: rgba(16, 185, 129, .1);  border-color: rgba(16, 185, 129, .45); color: var(--td-ink-1); }

/* ===== 2열 카드 ===== */
.td-grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin: 14px 0;
}
.td-card {
    padding: 16px 18px;
    background: rgba(255, 255, 255, .03);
    border: 1px solid var(--td-line);
    border-radius: 10px;
}
.td-card h4 { margin: 0 0 8px; font-size: 15px; color: var(--td-ink-0); font-weight: 800; }
.td-card p, .td-card ul { font-size: 13px; line-height: 1.7; margin: 0; color: var(--td-ink-2); }
.td-card ul { padding-left: 18px; }
.td-card ul li { margin-bottom: 4px; }
.td-card-primary { border-color: rgba(0, 245, 255, .4); background: rgba(0, 245, 255, .05); }

/* ===== 단계 목록 ===== */
.td-steps {
    counter-reset: td-step;
    list-style: none;
    padding: 0;
    margin: 14px 0;
}
.td-steps li {
    counter-increment: td-step;
    position: relative;
    padding: 14px 14px 14px 60px;
    margin-bottom: 10px;
    background: rgba(255, 255, 255, .03);
    border-radius: 10px;
    border-left: 3px solid var(--td-cyan);
}
.td-steps li::before {
    content: counter(td-step);
    position: absolute;
    left: 16px; top: 50%;
    transform: translateY(-50%);
    width: 32px; height: 32px;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, var(--td-cyan), var(--td-violet));
    color: var(--td-bg-0);
    font-weight: 900;
    border-radius: 50%;
    font-size: 13px;
}
.td-steps li b { display: block; font-size: 14px; color: var(--td-ink-0); margin-bottom: 2px; }
.td-steps li span { font-size: 12px; color: var(--td-ink-2); }

/* ===== 테이블 ===== */
.td-tbl {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
    margin: 14px 0;
    background: rgba(255, 255, 255, .02);
    border-radius: 10px;
    overflow: hidden;
}
.td-tbl th, .td-tbl td { padding: 10px 14px; text-align: left; border-bottom: 1px solid var(--td-line); }
.td-tbl th { background: rgba(168, 85, 247, .1); color: var(--td-ink-0); font-weight: 800; font-size: 12px; }
.td-tbl tr:last-child td { border-bottom: 0; }

/* ===== 보안 가드 리스트 ===== */
.td-guard { display: flex; flex-direction: column; gap: 10px; margin-top: 14px; }
.td-guard-item {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 14px;
    padding: 14px 16px;
    background: rgba(255, 69, 119, .06);
    border: 1px solid rgba(255, 69, 119, .2);
    border-radius: 10px;
}
.td-guard-no {
    width: 32px; height: 32px;
    display: flex; align-items: center; justify-content: center;
    background: var(--td-red);
    color: #fff;
    font-weight: 900;
    border-radius: 50%;
    font-size: 13px;
}
.td-guard-item b { font-size: 14px; color: var(--td-ink-0); }
.td-guard-item p { margin: 4px 0 0; font-size: 12px; color: var(--td-ink-2); line-height: 1.7; }

/* ===== 실수 리스트 ===== */
.td-mistakes { padding-left: 20px; }
.td-mistakes li { margin-bottom: 12px; }
.td-mistakes li b { display: block; font-size: 14px; color: var(--td-red); margin-bottom: 2px; }
.td-mistakes li span { font-size: 12px; color: var(--td-ink-2); }

/* ===== 활용 그리드 ===== */
.td-usage {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 10px;
    margin: 14px 0;
}
.td-usage-item {
    padding: 16px 14px;
    background: rgba(255, 255, 255, .03);
    border: 1px solid var(--td-line);
    border-radius: 10px;
    text-align: center;
}
.td-usage-ic { font-size: 28px; margin-bottom: 6px; }
.td-usage-item b { display: block; font-size: 13px; color: var(--td-ink-0); font-weight: 800; margin-bottom: 4px; }
.td-usage-item span { font-size: 11px; color: var(--td-ink-2); line-height: 1.6; }

/* ===== 체크포인트 박스 ===== */
.td-checkpoint {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 20px;
    padding: 14px 18px;
    background: rgba(168, 85, 247, .06);
    border: 1px dashed rgba(168, 85, 247, .4);
    border-radius: 10px;
    cursor: pointer;
    user-select: none;
    transition: all .25s ease;
}
.td-checkpoint:hover { background: rgba(168, 85, 247, .1); border-color: rgba(168, 85, 247, .6); }
.td-checkpoint-box { position: absolute; opacity: 0; pointer-events: none; }
.td-checkpoint-visual {
    width: 26px; height: 26px;
    border: 2px solid rgba(168, 85, 247, .5);
    border-radius: 7px;
    display: flex; align-items: center; justify-content: center;
    color: transparent;
    flex-shrink: 0;
    transition: all .2s ease;
}
.td-checkpoint-label {
    font-size: 13px;
    font-weight: 700;
    color: var(--td-ink-1);
    letter-spacing: -.01em;
}
.td-checkpoint-box:checked ~ .td-checkpoint-visual {
    background: linear-gradient(135deg, var(--td-cyan), var(--td-violet));
    border-color: transparent;
    color: #fff;
    box-shadow: 0 4px 12px rgba(168, 85, 247, .4);
}
.td-checkpoint-box:checked ~ .td-checkpoint-label {
    color: var(--td-emerald);
}
.td-sec.is-checked .td-checkpoint {
    border-style: solid;
    border-color: rgba(16, 185, 129, .4);
    background: rgba(16, 185, 129, .08);
}

/* ===== 최종 CTA (finale) ===== */
.td-finale {
    margin-top: 32px;
    padding: 32px;
    background: radial-gradient(800px 200px at 50% 50%, rgba(255, 204, 51, .14), transparent 70%),
                linear-gradient(135deg, var(--td-bg-3), var(--td-bg-1));
    border: 2px solid rgba(255, 204, 51, .3);
    border-radius: 16px;
    text-align: center;
}
.td-finale-claim { display: flex; flex-direction: column; align-items: center; gap: 16px; }
.td-finale-status {
    display: flex; align-items: center; gap: 10px;
    padding: 12px 22px;
    background: rgba(0, 0, 0, .3);
    border-radius: 999px;
    font-size: 14px;
    color: var(--td-ink-1);
}
.td-finale-icon { font-size: 18px; }
.td-finale-claim.is-ready .td-finale-status {
    background: rgba(16, 185, 129, .15);
    color: var(--td-emerald);
}
.td-finale-btn {
    padding: 16px 32px;
    border-radius: 12px;
    background: rgba(255, 255, 255, .06);
    border: 1px solid var(--td-line);
    color: var(--td-ink-2);
    font-size: 16px;
    font-weight: 900;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    cursor: pointer;
    transition: all .2s ease;
    font-family: inherit;
}
.td-finale-btn:disabled { cursor: not-allowed; }
.td-finale-btn-primary {
    background: linear-gradient(135deg, var(--td-gold), #ff9933);
    color: #2a1a04;
    border: 0;
    box-shadow: 0 10px 30px rgba(255, 204, 51, .35);
}
.td-finale-btn-primary:disabled {
    background: rgba(255, 255, 255, .06);
    color: var(--td-ink-3);
    box-shadow: none;
}
.td-finale-btn-primary:not(:disabled):hover { transform: translateY(-2px); filter: brightness(1.1); }
.td-finale-done {
    display: flex; align-items: center; gap: 16px; justify-content: center; flex-wrap: wrap;
}
.td-finale-done .td-finale-ic {
    width: 48px; height: 48px;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, var(--td-emerald), #0a8a5c);
    color: #fff;
    border-radius: 50%;
    font-size: 24px;
    font-weight: 900;
}
.td-finale-done b { font-size: 16px; color: var(--td-ink-0); display: block; }
.td-finale-done p { margin: 4px 0 0; font-size: 12px; color: var(--td-ink-2); }
.td-finale-login { display: flex; gap: 14px; align-items: center; justify-content: center; }
.td-finale-login b { font-size: 15px; color: var(--td-ink-0); }

/* ===== 빠른 스크롤 경고 토스트 ===== */
.td-fast-alert {
    position: fixed;
    top: 72px;
    left: 50%;
    transform: translateX(-50%) translateY(-20px);
    z-index: 999;
    padding: 12px 24px;
    background: linear-gradient(135deg, rgba(255, 69, 119, .95), rgba(255, 69, 119, .85));
    border-radius: 999px;
    box-shadow: 0 10px 30px rgba(255, 69, 119, .35);
    display: flex;
    align-items: center;
    gap: 12px;
    color: #fff;
    font-weight: 700;
    font-size: 13px;
    opacity: 0;
    transition: all .3s ease;
    backdrop-filter: blur(10px);
}
.td-fast-alert.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.td-fast-alert span { font-size: 18px; }
.td-fast-alert small { opacity: .8; font-weight: 500; }

/* ===== Placeholder (info/exchange/wallet) ===== */
.td-placeholder {
    padding: 60px 40px;
    text-align: center;
    background: linear-gradient(180deg, var(--td-bg-2), var(--td-bg-1));
    border: 1px solid var(--td-line);
    border-radius: 16px;
    color: var(--td-ink-1);
}
.td-ph-ic { font-size: 56px; margin-bottom: 14px; }
.td-placeholder h2 { font-size: 22px; margin: 0 0 10px; color: var(--td-ink-0); font-weight: 900; }
.td-placeholder p { font-size: 14px; color: var(--td-ink-2); line-height: 1.7; margin: 8px 0; }
.td-ph-list { display: inline-block; text-align: left; margin: 14px 0; padding-left: 20px; font-size: 13px; color: var(--td-ink-1); }
.td-ph-list li { margin-bottom: 6px; }
.td-ph-note { margin-top: 20px; font-size: 12px; color: var(--td-ink-3); }
.td-ph-btn {
    display: inline-block;
    margin-top: 16px;
    padding: 12px 24px;
    background: linear-gradient(135deg, var(--td-cyan), var(--td-violet));
    color: var(--td-bg-0);
    border-radius: 10px;
    text-decoration: none;
    font-weight: 900;
}

/* ===== (구) placeholder 카드 — 미사용, 호환 유지 ===== */
.td-exchanges { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin: 20px 0; text-align: left; }

/* ============================================================
 * 거래소 목록 + 상세 페이지
 * ============================================================ */

/* ── 목록 히어로 (가이드 페이지와 동일한 폭·정렬) ── */
.td-ex-hero {
    padding: 32px;
    margin-bottom: 24px;
    background: radial-gradient(900px 220px at 20% 0%, rgba(38, 161, 123, .18), transparent 70%),
                linear-gradient(180deg, var(--td-bg-2), var(--td-bg-1));
    border: 1px solid var(--td-line);
    border-radius: 16px;
}
.td-ex-hero-tag {
    display: inline-block;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .2em;
    color: var(--td-tether);
    background: rgba(38, 161, 123, .14);
    padding: 5px 12px;
    border-radius: 999px;
    border: 1px solid rgba(38, 161, 123, .4);
    margin-bottom: 14px;
}
.td-ex-hero-title {
    font-size: 28px;
    font-weight: 900;
    color: var(--td-ink-0);
    margin: 0 0 12px;
    letter-spacing: -.02em;
}
.td-ex-hero-desc {
    font-size: 14px;
    line-height: 1.8;
    color: var(--td-ink-1);
    margin: 0 0 18px;
}
.td-ex-hero-desc b { color: var(--td-cyan); }
.td-ex-hero-meta {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    font-size: 12px;
    color: var(--td-ink-2);
}
.td-ex-hero-meta span {
    padding: 5px 12px;
    background: rgba(255, 255, 255, .04);
    border: 1px solid var(--td-line);
    border-radius: 999px;
}

/* ── 목록 그리드 (3열) ── */
.td-ex-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
    margin-bottom: 24px;
}
.td-ex-card {
    display: flex;
    flex-direction: column;
    padding: 20px;
    background: linear-gradient(180deg, var(--td-bg-2), var(--td-bg-1));
    border: 1px solid var(--td-line);
    border-radius: 14px;
    text-decoration: none;
    color: var(--td-ink-1);
    transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
    position: relative;
    overflow: hidden;
}
.td-ex-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: var(--ex-color, var(--td-cyan));
    opacity: .6;
}
.td-ex-card:hover {
    transform: translateY(-3px);
    border-color: rgba(255, 255, 255, .2);
    box-shadow: 0 14px 34px rgba(0, 0, 0, .5);
}
.td-ex-card-logo {
    width: 56px; height: 56px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 14px;
    box-shadow: 0 6px 14px rgba(0, 0, 0, .25);
    overflow: hidden;
    flex-shrink: 0;
}
.td-ex-card-logo svg { width: 100%; height: 100%; display: block; }
.td-ex-card-body { flex: 1; }
.td-ex-card-titles b { display: block; font-size: 17px; color: var(--td-ink-0); font-weight: 900; }
.td-ex-card-titles small { font-size: 11px; color: var(--td-ink-3); font-weight: 600; text-transform: uppercase; letter-spacing: .05em; }
.td-ex-card-tag {
    margin: 10px 0 12px;
    font-size: 13px;
    color: var(--td-ink-1);
    line-height: 1.5;
}
.td-ex-card-stats {
    display: flex;
    gap: 10px;
    font-size: 11px;
    color: var(--td-ink-2);
    padding-top: 10px;
    border-top: 1px dashed var(--td-line);
}
.td-ex-card-arrow {
    margin-top: 14px;
    padding: 8px 12px;
    background: rgba(0, 245, 255, .08);
    border-radius: 8px;
    color: var(--td-cyan);
    font-size: 12px;
    font-weight: 800;
    text-align: center;
    transition: background .2s ease;
}
.td-ex-card:hover .td-ex-card-arrow { background: rgba(0, 245, 255, .18); }

/* ── 목록 "Pick Guide" — 유저 타입별 거래소 추천 ── */
.td-ex-pick {
    padding: 28px 32px;
    background:
        radial-gradient(800px 200px at 100% 0%, rgba(168, 85, 247, .12), transparent 70%),
        radial-gradient(600px 180px at 0% 100%, rgba(0, 245, 255, .1), transparent 70%),
        linear-gradient(180deg, var(--td-bg-2), var(--td-bg-1));
    border: 1px solid var(--td-line);
    border-radius: 16px;
    margin-top: 8px;
}
.td-ex-pick-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 20px;
    padding-bottom: 18px;
    margin-bottom: 20px;
    border-bottom: 1px solid var(--td-line);
}
.td-ex-pick-head small {
    display: block;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .2em;
    color: var(--td-cyan);
    margin-bottom: 6px;
}
.td-ex-pick-head h2 {
    margin: 0;
    font-size: 22px;
    font-weight: 900;
    color: var(--td-ink-0);
    letter-spacing: -.02em;
}
.td-ex-pick-head p {
    margin: 0;
    font-size: 13px;
    color: var(--td-ink-2);
    max-width: 300px;
    text-align: right;
}

.td-ex-pick-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
}
.td-ex-pick-card {
    position: relative;
    padding: 20px 18px 18px;
    background: rgba(255, 255, 255, .03);
    border: 1px solid var(--td-line);
    border-radius: 14px;
    overflow: hidden;
    transition: transform .25s ease, border-color .25s ease;
}
.td-ex-pick-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--pick-accent);
    opacity: .06;
    pointer-events: none;
}
.td-ex-pick-card:hover {
    transform: translateY(-3px);
    border-color: color-mix(in srgb, var(--pick-accent-strong) 40%, var(--td-line));
}
.td-ex-pick-card.tone-kr    { --pick-accent: radial-gradient(200px 100px at 50% 0%, #1FC7D4, transparent 70%); --pick-accent-strong: #1FC7D4; }
.td-ex-pick-card.tone-safe  { --pick-accent: radial-gradient(200px 100px at 50% 0%, #F0B90B, transparent 70%); --pick-accent-strong: #F0B90B; }
.td-ex-pick-card.tone-alt   { --pick-accent: radial-gradient(200px 100px at 50% 0%, #a855f7, transparent 70%); --pick-accent-strong: #a855f7; }
.td-ex-pick-card.tone-copy  { --pick-accent: radial-gradient(200px 100px at 50% 0%, #00CEFF, transparent 70%); --pick-accent-strong: #00CEFF; }

.td-ex-pick-top {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 14px;
}
.td-ex-pick-ic {
    font-size: 28px;
    line-height: 1;
    filter: drop-shadow(0 4px 8px rgba(0, 0, 0, .3));
}
.td-ex-pick-tag {
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .05em;
    padding: 4px 10px;
    border-radius: 999px;
    background: rgba(255, 255, 255, .06);
    border: 1px solid var(--td-line);
    color: var(--td-ink-2);
}
.td-ex-pick-title {
    position: relative;
    z-index: 1;
    margin: 0 0 8px;
    font-size: 15px;
    font-weight: 900;
    color: var(--td-ink-0);
    letter-spacing: -.01em;
    line-height: 1.35;
}
.td-ex-pick-desc {
    position: relative;
    z-index: 1;
    margin: 0 0 16px;
    font-size: 12px;
    color: var(--td-ink-2);
    line-height: 1.65;
    min-height: 40px;
}
.td-ex-pick-chips {
    position: relative;
    z-index: 1;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding-top: 12px;
    border-top: 1px dashed var(--td-line);
}
.td-ex-pick-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 10px 5px 5px;
    background: rgba(0, 0, 0, .3);
    border: 1px solid var(--td-line);
    border-radius: 999px;
    text-decoration: none;
    transition: all .2s ease;
}
.td-ex-pick-chip:hover {
    background: rgba(0, 0, 0, .5);
    border-color: rgba(255, 255, 255, .25);
    transform: translateY(-1px);
}
.td-ex-pick-chip-logo {
    width: 20px; height: 20px;
    border-radius: 6px;
    overflow: hidden;
    flex-shrink: 0;
}
.td-ex-pick-chip-logo svg { width: 100%; height: 100%; display: block; }
.td-ex-pick-chip-name {
    font-size: 12px;
    font-weight: 700;
    color: var(--td-ink-1);
    letter-spacing: -.01em;
}
.td-ex-pick-chip:hover .td-ex-pick-chip-name { color: var(--td-ink-0); }

/* ============================================================
 * 거래소 상세 페이지
 * ============================================================ */
.td-ex-detail { color: var(--td-ink-1); }

.td-ex-back {
    display: inline-block;
    font-size: 12px;
    color: var(--td-ink-2);
    text-decoration: none;
    margin-bottom: 14px;
    padding: 6px 12px;
    background: rgba(255, 255, 255, .04);
    border-radius: 6px;
    transition: background .2s ease;
}
.td-ex-back:hover { background: rgba(255, 255, 255, .08); color: var(--td-ink-0); }

/* ── 브랜드 히어로 ── */
.td-ex-hero-brand {
    position: relative;
    padding: 32px;
    border-radius: 16px;
    overflow: hidden;
    margin-bottom: 20px;
    background: linear-gradient(180deg, var(--td-bg-2), var(--td-bg-1));
    border: 1px solid var(--td-line);
}
.td-ex-brand-bg {
    position: absolute;
    inset: 0;
    background: radial-gradient(600px 220px at 0% 0%, color-mix(in srgb, var(--ex-color) 25%, transparent), transparent 70%);
    pointer-events: none;
    z-index: 0;
}
.td-ex-brand-inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 24px;
    align-items: center;
}
.td-ex-brand-logo {
    width: 88px; height: 88px;
    border-radius: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 10px 30px color-mix(in srgb, var(--ex-color) 50%, transparent), 0 0 0 1px rgba(255, 255, 255, .06) inset;
    overflow: hidden;
    flex-shrink: 0;
}
.td-ex-brand-logo svg { width: 100%; height: 100%; display: block; }
.td-ex-brand-chips { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 10px; }
.td-ex-chip {
    font-size: 10px;
    font-weight: 700;
    padding: 3px 10px;
    background: rgba(255, 255, 255, .06);
    border: 1px solid var(--td-line);
    border-radius: 999px;
    color: var(--td-ink-2);
}
.td-ex-brand-name {
    margin: 0 0 8px;
    font-size: 28px;
    font-weight: 900;
    color: var(--td-ink-0);
    letter-spacing: -.02em;
}
.td-ex-brand-name em { font-style: normal; color: var(--td-ink-3); font-size: 18px; font-weight: 600; margin-left: 4px; }
.td-ex-brand-head { margin: 0 0 8px; font-size: 15px; color: var(--td-ink-0); font-weight: 700; }
.td-ex-brand-desc { margin: 0 0 16px; font-size: 13px; color: var(--td-ink-2); line-height: 1.75; }

.td-ex-brand-cta { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.td-ex-cta-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 22px;
    border-radius: 10px;
    font-weight: 900;
    text-decoration: none;
    font-size: 14px;
    transition: transform .15s ease, filter .15s ease;
    cursor: pointer;
    border: 0;
    font-family: inherit;
}
.td-ex-cta-primary {
    background: var(--ex-color, var(--td-gold));
    color: #e7e7f0;
    box-shadow: 0 8px 22px color-mix(in srgb, var(--ex-color) 40%, transparent);
}
.td-ex-cta-primary:hover { transform: translateY(-2px); filter: brightness(1.08); }
.td-ex-cta-note { font-size: 11px; color: var(--td-ink-3); }

/* ── 섹션 공통 ── */
.td-ex-sec {
    padding: 24px 28px;
    background: linear-gradient(180deg, var(--td-bg-2), var(--td-bg-1));
    border: 1px solid var(--td-line);
    border-radius: 14px;
    margin-bottom: 18px;
}
.td-ex-sec-title {
    margin: 0 0 18px;
    font-size: 18px;
    font-weight: 900;
    color: var(--td-ink-0);
    letter-spacing: -.01em;
}

/* ── 특징 카드 ── */
.td-ex-features {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 10px;
}
.td-ex-feature {
    padding: 16px 14px;
    background: rgba(255, 255, 255, .03);
    border: 1px solid var(--td-line);
    border-radius: 10px;
}
.td-ex-feature-ic { font-size: 24px; margin-bottom: 8px; }
.td-ex-feature b { display: block; font-size: 13px; color: var(--td-ink-0); margin-bottom: 4px; }
.td-ex-feature p { margin: 0; font-size: 12px; color: var(--td-ink-2); line-height: 1.55; }

/* ── 장단점 ── */
.td-ex-pros-cons { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.td-ex-pros, .td-ex-cons { padding: 16px; border-radius: 10px; }
.td-ex-pros { background: rgba(16, 185, 129, .08); border: 1px solid rgba(16, 185, 129, .3); }
.td-ex-cons { background: rgba(255, 69, 119, .08); border: 1px solid rgba(255, 69, 119, .3); }
.td-ex-pros h3, .td-ex-cons h3 { margin: 0 0 10px; font-size: 13px; color: var(--td-ink-0); }
.td-ex-pros ul, .td-ex-cons ul { margin: 0; padding-left: 20px; }
.td-ex-pros li, .td-ex-cons li { font-size: 13px; line-height: 1.75; color: var(--td-ink-1); }

/* ── 모바일 mockup ── */
.td-ex-app-row { display: grid; grid-template-columns: 260px 1fr; gap: 28px; align-items: center; }
.td-phone-mock {
    position: relative;
    width: 240px;
    height: 480px;
    background: #0a0a0a;
    border-radius: 36px;
    padding: 12px;
    box-shadow: 0 30px 60px rgba(0, 0, 0, .6), 0 0 0 1px rgba(255, 255, 255, .06) inset;
    margin: 0 auto;
}
.td-phone-notch {
    position: absolute;
    top: 14px; left: 50%; transform: translateX(-50%);
    width: 60px; height: 18px;
    background: #000;
    border-radius: 999px;
    z-index: 2;
}
.td-phone-home {
    position: absolute;
    bottom: 8px; left: 50%; transform: translateX(-50%);
    width: 80px; height: 4px;
    background: #333;
    border-radius: 999px;
}
.td-phone-screen {
    width: 100%; height: 100%;
    background: linear-gradient(180deg, var(--ex-color, #333), #0a0a0a);
    border-radius: 28px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    position: relative;
}
.td-phone-screen img { width: 100%; height: 100%; object-fit: cover; }
.td-phone-placeholder {
    padding: 40px 20px 20px;
    text-align: center;
    width: 100%;
}
.td-phone-logo-ch {
    width: 60px; height: 60px;
    margin: 0 auto 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, .9);
    color: var(--ex-color, #333);
    border-radius: 16px;
    font-size: 28px;
    font-weight: 900;
}
.td-phone-ph-title { font-size: 18px; font-weight: 900; color: #fff; margin-bottom: 4px; }
.td-phone-ph-sub { font-size: 11px; color: rgba(255, 255, 255, .7); margin-bottom: 24px; }
.td-phone-skeleton {
    height: 40px;
    background: rgba(255, 255, 255, .12);
    border-radius: 8px;
    margin: 8px 12px;
}
.td-phone-skeleton.sm { height: 24px; width: 60%; margin-left: auto; margin-right: auto; }

.td-ex-app-info h3 { margin: 0 0 10px; color: var(--td-ink-0); font-size: 16px; }
.td-ex-app-info p { font-size: 13px; color: var(--td-ink-2); margin: 0 0 14px; line-height: 1.7; }
.td-store-btns { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 14px; }
.td-store-btn {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    background: #000;
    border: 1px solid #333;
    border-radius: 10px;
    color: #fff;
    text-decoration: none;
    min-width: 140px;
}
.td-store-btn:hover { background: #1a1a1a; }
.td-store-btn span { font-size: 20px; }
.td-store-btn small { display: block; font-size: 9px; opacity: .6; line-height: 1; }
.td-store-btn b { font-size: 14px; font-weight: 700; line-height: 1.2; }
.td-ex-app-warn { margin: 0 !important; font-size: 11px !important; color: var(--td-red) !important; }

/* ── 단계 목록 (가입/이용/지갑) ── */
.td-ex-steps {
    counter-reset: exstep;
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.td-ex-steps li {
    counter-increment: exstep;
    position: relative;
    padding: 12px 14px 12px 48px;
    background: rgba(255, 255, 255, .03);
    border-radius: 8px;
    border-left: 3px solid var(--ex-color, var(--td-cyan));
    font-size: 13px;
    color: var(--td-ink-1);
    line-height: 1.6;
}
.td-ex-steps li::before {
    content: counter(exstep);
    position: absolute;
    left: 12px; top: 50%;
    transform: translateY(-50%);
    width: 26px; height: 26px;
    display: flex; align-items: center; justify-content: center;
    background: var(--ex-color, var(--td-cyan));
    color: #0a1120;
    font-weight: 900;
    border-radius: 50%;
    font-size: 12px;
}

/* ── 최종 CTA ── */
.td-ex-final {
    padding: 24px 28px;
    background: linear-gradient(135deg, color-mix(in srgb, var(--ex-color) 18%, var(--td-bg-2)), var(--td-bg-1));
    border: 2px solid color-mix(in srgb, var(--ex-color) 40%, var(--td-line));
    border-radius: 14px;
    margin-bottom: 18px;
}
.td-ex-final-inner {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 18px;
    align-items: center;
}
.td-ex-final-ic {
    width: 56px; height: 56px;
    display: flex; align-items: center; justify-content: center;
    background: var(--ex-color);
    color: #0a1120;
    border-radius: 50%;
    font-size: 26px;
    box-shadow: 0 8px 20px color-mix(in srgb, var(--ex-color) 40%, transparent);
}
.td-ex-final-inner b { font-size: 15px; color: var(--td-ink-0); display: block; margin-bottom: 4px; font-weight: 800; }
.td-ex-final-inner p { margin: 0; font-size: 12px; color: var(--td-ink-2); }

/* ── 다른 거래소 추천 — 리뉴얼 ── */
.td-ex-more {
    padding: 26px 28px;
    background:
        radial-gradient(600px 160px at 100% 0%, rgba(0, 245, 255, .08), transparent 70%),
        linear-gradient(180deg, var(--td-bg-2), var(--td-bg-1));
    border: 1px solid var(--td-line);
    border-radius: 16px;
    margin-top: 4px;
}
.td-ex-more-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--td-line);
}
.td-ex-more-head small {
    display: block;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .2em;
    color: var(--td-cyan);
    margin-bottom: 4px;
}
.td-ex-more-head h3 {
    margin: 0;
    font-size: 18px;
    font-weight: 900;
    color: var(--td-ink-0);
    letter-spacing: -.01em;
}
.td-ex-more-all {
    font-size: 12px;
    font-weight: 800;
    color: var(--td-ink-2);
    text-decoration: none;
    padding: 8px 14px;
    background: rgba(255, 255, 255, .04);
    border: 1px solid var(--td-line);
    border-radius: 8px;
    transition: all .2s ease;
    white-space: nowrap;
}
.td-ex-more-all:hover {
    color: var(--td-cyan);
    border-color: rgba(0, 245, 255, .4);
    background: rgba(0, 245, 255, .08);
}

.td-ex-more-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
}
.td-ex-more-item {
    position: relative;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    background: rgba(255, 255, 255, .03);
    border: 1px solid var(--td-line);
    border-radius: 12px;
    text-decoration: none;
    overflow: hidden;
    transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.td-ex-more-item::before {
    content: '';
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 3px;
    background: var(--ex-color, var(--td-cyan));
    opacity: .8;
}
.td-ex-more-item:hover {
    transform: translateY(-2px);
    border-color: color-mix(in srgb, var(--ex-color) 50%, var(--td-line));
    box-shadow: 0 10px 24px rgba(0, 0, 0, .35),
                0 0 0 1px color-mix(in srgb, var(--ex-color) 25%, transparent);
    background: rgba(255, 255, 255, .05);
}
.td-ex-more-logo {
    width: 40px; height: 40px;
    border-radius: 10px;
    overflow: hidden;
    flex-shrink: 0;
    box-shadow: 0 4px 10px rgba(0, 0, 0, .3);
}
.td-ex-more-logo svg { width: 100%; height: 100%; display: block; }
.td-ex-more-body { min-width: 0; }
.td-ex-more-body b {
    display: block;
    font-size: 14px;
    font-weight: 800;
    color: var(--td-ink-0);
    margin-bottom: 2px;
    letter-spacing: -.01em;
}
.td-ex-more-body small {
    display: block;
    font-size: 11px;
    color: var(--td-ink-2);
    line-height: 1.4;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.td-ex-more-arrow {
    font-size: 16px;
    font-weight: 800;
    color: var(--td-ink-3);
    transition: transform .2s ease, color .2s ease;
}
.td-ex-more-item:hover .td-ex-more-arrow {
    color: var(--ex-color, var(--td-cyan));
    transform: translateX(3px);
}

/* ============================================================
 * 가이드 완료 → 거래소 유도 모달
 * ============================================================ */
.td-grant-modal {
    position: fixed;
    inset: 0;
    z-index: 2147483000;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity .3s ease;
}
.td-grant-modal.show { opacity: 1; }
.td-grant-bd {
    position: absolute;
    inset: 0;
    background: rgba(5, 8, 15, .85);
    backdrop-filter: blur(10px);
}
.td-grant-box {
    position: relative;
    width: min(480px, 92vw);
    background: linear-gradient(180deg, var(--td-bg-2), var(--td-bg-1));
    border: 1px solid var(--td-line);
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 40px 80px rgba(0, 0, 0, .7);
    transform: translateY(20px);
    transition: transform .35s cubic-bezier(.2, 1.2, .3, 1);
}
.td-grant-modal.show .td-grant-box { transform: translateY(0); }

.td-grant-head {
    padding: 32px 32px 24px;
    text-align: center;
    background: radial-gradient(400px 200px at 50% 0%, rgba(255, 204, 51, .22), transparent 70%);
    border-bottom: 1px solid var(--td-line);
}
.td-grant-coin {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 10px 20px;
    background: linear-gradient(135deg, var(--td-gold), #ff9933);
    color: #2a1a04;
    border-radius: 999px;
    font-weight: 900;
    box-shadow: 0 10px 24px rgba(255, 204, 51, .35);
    margin-bottom: 16px;
    animation: tgGrantPop .6s cubic-bezier(.2, 1.3, .3, 1);
}
@keyframes tgGrantPop {
    0%   { transform: scale(.3); opacity: 0; }
    60%  { transform: scale(1.12); }
    100% { transform: scale(1); opacity: 1; }
}
.td-grant-coin-sym { font-size: 18px; }
.td-grant-plus { font-size: 20px; }
.td-grant-amount { font-size: 28px; font-variant-numeric: tabular-nums; }
.td-grant-head h3 { margin: 0 0 8px; font-size: 22px; color: var(--td-ink-0); font-weight: 900; }
.td-grant-head p { margin: 0; font-size: 14px; color: var(--td-ink-1); }
.td-grant-head p b { color: var(--td-gold); }

.td-grant-body { padding: 22px 28px; }
.td-grant-next {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 14px;
    align-items: center;
    padding: 16px;
    background: linear-gradient(135deg, rgba(0, 245, 255, .1), rgba(168, 85, 247, .1));
    border: 1px solid rgba(0, 245, 255, .3);
    border-radius: 12px;
    margin-bottom: 14px;
}
.td-grant-next-ic {
    width: 44px; height: 44px;
    display: flex; align-items: center; justify-content: center;
    background: rgba(0, 245, 255, .15);
    border-radius: 12px;
    font-size: 22px;
}
.td-grant-next-txt b { display: block; font-size: 13px; color: var(--td-ink-0); font-weight: 800; margin-bottom: 2px; }
.td-grant-next-txt p { margin: 0; font-size: 13px; color: var(--td-ink-2); }
.td-grant-next-amt { color: var(--td-cyan); font-size: 16px; font-weight: 900; }

.td-grant-benefit {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 14px 16px;
    background: rgba(255, 255, 255, .03);
    border-radius: 10px;
    font-size: 12px;
    color: var(--td-ink-1);
}
.td-grant-benefit > div {
    display: flex;
    align-items: center;
    gap: 10px;
}
.td-grant-benefit span { font-size: 16px; }

.td-grant-foot {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 10px;
    padding: 16px 24px 24px;
}
.td-grant-btn {
    padding: 14px 20px;
    border: 0;
    border-radius: 10px;
    font-weight: 900;
    font-size: 14px;
    cursor: pointer;
    transition: all .2s ease;
    font-family: inherit;
}
.td-grant-btn-ghost {
    background: rgba(255, 255, 255, .06);
    color: var(--td-ink-2);
    border: 1px solid var(--td-line);
}
.td-grant-btn-ghost:hover { background: rgba(255, 255, 255, .1); color: var(--td-ink-0); }
.td-grant-btn-primary {
    background: linear-gradient(135deg, var(--td-cyan), var(--td-violet));
    color: var(--td-bg-0);
    box-shadow: 0 8px 22px rgba(0, 245, 255, .3);
}
.td-grant-btn-primary:hover { transform: translateY(-1px); filter: brightness(1.1); }

/* ── 반응형 ── */
@media (max-width: 768px) {
    .td-ex-hero { padding: 22px 18px; }
    .td-ex-hero-title { font-size: 22px; }
    .td-ex-grid { grid-template-columns: 1fr; }
    .td-ex-pick { padding: 22px 18px; }
    .td-ex-pick-head { flex-direction: column; align-items: flex-start; gap: 8px; }
    .td-ex-pick-head p { text-align: left; max-width: none; }
    .td-ex-pick-grid { grid-template-columns: 1fr 1fr; }
    .td-ex-pick-desc { min-height: auto; }
    .td-ex-brand-inner { grid-template-columns: 1fr; text-align: center; }
    .td-ex-brand-logo { margin: 0 auto; }
    .td-ex-brand-chips { justify-content: center; }
    .td-ex-brand-cta { justify-content: center; }
    .td-ex-features { grid-template-columns: 1fr 1fr; }
    .td-ex-pros-cons { grid-template-columns: 1fr; }
    .td-ex-app-row { grid-template-columns: 1fr; }
    .td-phone-mock { width: 200px; height: 400px; }
    .td-ex-final-inner { grid-template-columns: 1fr; text-align: center; }
    .td-ex-final-ic { margin: 0 auto; }
    .td-ex-more-grid { grid-template-columns: 1fr; }
    .td-ex-more-head { flex-direction: column; align-items: flex-start; }
    .td-grant-foot { grid-template-columns: 1fr; }
    .td-grant-head { padding: 22px 20px 18px; }
    .td-grant-body { padding: 18px 20px; }
    .td-grant-foot { padding: 14px 20px 20px; }
}

/* ===== Wallet ===== */
.td-wallet-card {
    padding: 28px;
    background: linear-gradient(135deg, rgba(38, 161, 123, .2), rgba(10, 17, 32, .9)), var(--td-bg-2);
    border: 1px solid rgba(38, 161, 123, .4);
    border-radius: 16px;
    margin-bottom: 18px;
}
.td-wallet-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
.td-wallet-brand { display: flex; align-items: center; gap: 14px; }
.td-wallet-logo {
    width: 48px; height: 48px; border-radius: 50%;
    background: linear-gradient(135deg, var(--td-tether), #1a7a5c);
    display: flex; align-items: center; justify-content: center;
    font-size: 26px; color: #fff; font-weight: 900;
}
.td-wallet-brand b { font-size: 16px; color: var(--td-ink-0); display: block; }
.td-wallet-brand small { font-size: 12px; color: var(--td-ink-2); }
.td-wallet-net { padding: 4px 10px; background: rgba(38, 161, 123, .2); border: 1px solid rgba(38, 161, 123, .4); border-radius: 999px; font-size: 11px; color: var(--td-tether); font-weight: 800; }
.td-wallet-balance { display: flex; align-items: baseline; gap: 8px; padding: 20px 0; border-top: 1px solid var(--td-line); }
.td-wb-sym { font-size: 20px; color: var(--td-tether); font-weight: 900; }
.td-wb-val { font-size: 48px; font-weight: 900; color: #fff; font-variant-numeric: tabular-nums; }
.td-wb-unit { font-size: 14px; color: var(--td-ink-2); font-weight: 700; }
.td-wallet-meta { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; padding-top: 16px; border-top: 1px solid var(--td-line); }
.td-wallet-meta > div { text-align: center; }
.td-wallet-meta span { display: block; font-size: 11px; color: var(--td-ink-2); margin-bottom: 4px; }
.td-wallet-meta b { font-size: 14px; color: var(--td-ink-0); font-weight: 800; }
.td-wallet-notice { padding: 24px; background: rgba(0, 245, 255, .05); border: 1px solid rgba(0, 245, 255, .2); border-radius: 12px; margin-top: 18px; }
.td-wallet-notice h3 { margin: 0 0 10px; font-size: 15px; color: var(--td-ink-0); }
.td-wallet-notice p { margin: 0; font-size: 13px; color: var(--td-ink-2); line-height: 1.7; }
.td-wallet-notice p b { color: var(--td-ink-0); }

/* ============================================================
 * 회원 지갑 주소 관리 (My Wallets)
 * ============================================================ */
.td-wl-section {
    margin-top: 18px;
    padding: 26px 28px;
    background: linear-gradient(180deg, var(--td-bg-2), var(--td-bg-1));
    border: 1px solid var(--td-line);
    border-radius: 16px;
}
.td-wl-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 20px;
    padding-bottom: 18px;
    margin-bottom: 18px;
    border-bottom: 1px solid var(--td-line);
}
.td-wl-head small {
    display: block;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .2em;
    color: var(--td-cyan);
    margin-bottom: 6px;
}
.td-wl-head h3 {
    margin: 0 0 6px;
    font-size: 18px;
    font-weight: 900;
    color: var(--td-ink-0);
    letter-spacing: -.01em;
}
.td-wl-head p {
    margin: 0;
    font-size: 12px;
    color: var(--td-ink-2);
    line-height: 1.7;
    max-width: 560px;
}

.td-wl-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 10px 18px;
    border-radius: 10px;
    border: 0;
    font-family: inherit;
    font-weight: 800;
    font-size: 13px;
    cursor: pointer;
    transition: all .2s ease;
    white-space: nowrap;
}
.td-wl-btn-primary {
    background: linear-gradient(135deg, var(--td-cyan), var(--td-violet));
    color: var(--td-bg-0);
    box-shadow: 0 6px 18px rgba(0, 245, 255, .25);
}
.td-wl-btn-primary:hover { transform: translateY(-1px); filter: brightness(1.08); }
.td-wl-btn-primary span { font-size: 16px; font-weight: 900; }
.td-wl-btn-ghost {
    background: rgba(255, 255, 255, .05);
    color: var(--td-ink-2);
    border: 1px solid var(--td-line);
}
.td-wl-btn-ghost:hover { color: var(--td-ink-0); background: rgba(255, 255, 255, .1); }
.td-wl-btn-danger {
    background: linear-gradient(135deg, var(--td-red), #c73060);
    color: #fff;
    box-shadow: 0 6px 18px rgba(255, 69, 119, .3);
}
.td-wl-btn-danger:hover { transform: translateY(-1px); filter: brightness(1.08); }

/* ── 테이블 ── */
.td-wl-table-wrap { overflow-x: auto; border-radius: 10px; border: 1px solid var(--td-line); }
.td-wl-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.td-wl-table thead th {
    padding: 12px 14px;
    background: rgba(255, 255, 255, .04);
    color: var(--td-ink-2);
    font-size: 11px;
    font-weight: 800;
    text-align: left;
    letter-spacing: .03em;
    border-bottom: 1px solid var(--td-line);
    white-space: nowrap;
}
.td-wl-table tbody td {
    padding: 14px;
    border-bottom: 1px solid var(--td-line);
    color: var(--td-ink-1);
    vertical-align: middle;
}
.td-wl-table tbody tr:last-child td { border-bottom: 0; }
.td-wl-table tbody tr:hover { background: rgba(0, 245, 255, .03); }

.td-wl-col-date { color: var(--td-ink-2); font-size: 12px; white-space: nowrap; font-variant-numeric: tabular-nums; }
.td-wl-ex-tag, .td-wl-nw-tag {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: -.01em;
}
.td-wl-ex-tag { background: rgba(168, 85, 247, .12); color: #c78bff; border: 1px solid rgba(168, 85, 247, .3); }
.td-wl-nw-tag { background: rgba(0, 245, 255, .08); color: var(--td-cyan); border: 1px solid rgba(0, 245, 255, .25); }
.td-wl-addr {
    font-family: 'Consolas', 'Menlo', monospace;
    font-size: 13px;
    background: rgba(0, 0, 0, .3);
    padding: 5px 10px;
    border-radius: 6px;
    color: var(--td-ink-0);
    letter-spacing: .02em;
}
.td-wl-label { margin-left: 8px; font-size: 11px; color: var(--td-ink-3); }
.td-wl-col-actions { text-align: right; white-space: nowrap; }
.td-wl-mini-btn {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    background: rgba(255, 255, 255, .04);
    border: 1px solid var(--td-line);
    border-radius: 8px;
    color: var(--td-ink-2);
    font-size: 11px;
    font-weight: 800;
    font-family: inherit;
    cursor: pointer;
    margin-left: 4px;
    transition: all .2s ease;
}
.td-wl-mini-btn:hover { background: rgba(0, 245, 255, .1); border-color: rgba(0, 245, 255, .3); color: var(--td-cyan); }
.td-wl-mini-btn-danger:hover { background: rgba(255, 69, 119, .12); border-color: rgba(255, 69, 119, .35); color: var(--td-red); }

/* ── 빈 상태 ── */
.td-wl-empty {
    padding: 48px 24px;
    text-align: center;
    color: var(--td-ink-2);
}
.td-wl-empty-ic { font-size: 44px; margin-bottom: 14px; opacity: .7; }
.td-wl-empty b { display: block; font-size: 15px; color: var(--td-ink-0); margin-bottom: 6px; }
.td-wl-empty p { margin: 0; font-size: 12px; color: var(--td-ink-2); }

/* ── 모달 ── */
.td-wl-modal {
    position: fixed;
    inset: 0;
    z-index: 2147483000;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity .25s ease;
}
.td-wl-modal.show { opacity: 1; }
.td-wl-modal-bd {
    position: absolute;
    inset: 0;
    background: rgba(5, 8, 15, .85);
    backdrop-filter: blur(8px);
}
.td-wl-modal-box {
    position: relative;
    width: min(520px, 92vw);
    background: linear-gradient(180deg, var(--td-bg-2), var(--td-bg-1));
    border: 1px solid var(--td-line);
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 40px 80px rgba(0, 0, 0, .7);
    transform: translateY(16px);
    transition: transform .3s cubic-bezier(.2, 1.2, .3, 1);
}
.td-wl-modal.show .td-wl-modal-box { transform: translateY(0); }
.td-wl-modal-sm { width: min(420px, 92vw); }
.td-wl-modal-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 22px;
    border-bottom: 1px solid var(--td-line);
}
.td-wl-modal-head h3 { margin: 0; font-size: 16px; font-weight: 900; color: var(--td-ink-0); }
.td-wl-modal-x {
    background: transparent;
    border: 0;
    color: var(--td-ink-2);
    font-size: 18px;
    cursor: pointer;
    font-family: inherit;
    padding: 4px 8px;
}
.td-wl-modal-x:hover { color: var(--td-ink-0); }

.td-wl-form { padding: 18px 22px 20px; display: flex; flex-direction: column; gap: 14px; }
.td-wl-field { display: flex; flex-direction: column; gap: 6px; }
.td-wl-field > span {
    font-size: 12px;
    font-weight: 700;
    color: var(--td-ink-1);
    letter-spacing: -.01em;
}
.td-wl-field > span em {
    font-style: normal;
    margin-left: 6px;
    font-size: 10px;
    font-weight: 600;
    color: var(--td-red);
    letter-spacing: 0;
}
.td-wl-field > span small { font-size: 10px; color: var(--td-ink-3); font-weight: 500; margin-left: 4px; }
.td-wl-field input,
.td-wl-field select {
    width: 100%;
    height: 40px;
    padding: 0 12px;
    background: rgba(0, 0, 0, .3);
    border: 1px solid var(--td-line);
    border-radius: 8px;
    color: var(--td-ink-0);
    font-size: 13px;
    font-family: inherit;
    transition: border-color .2s ease, background .2s ease;
}
.td-wl-field input:focus,
.td-wl-field select:focus {
    outline: none;
    border-color: var(--td-cyan);
    background: rgba(0, 0, 0, .5);
    box-shadow: 0 0 0 3px rgba(0, 245, 255, .12);
}
.td-wl-field input::placeholder { color: var(--td-ink-3); }
.td-wl-field select { cursor: pointer; }
.td-wl-field select option { background: var(--td-bg-2); color: var(--td-ink-0); }

.td-wl-form-foot {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    padding-top: 4px;
}
.td-wl-form-err {
    padding: 10px 14px;
    background: rgba(255, 69, 119, .1);
    border: 1px solid rgba(255, 69, 119, .35);
    border-radius: 8px;
    color: var(--td-red);
    font-size: 12px;
    font-weight: 700;
}

.td-wl-del-body { padding: 22px 24px; text-align: center; }
.td-wl-del-ic { font-size: 40px; margin-bottom: 10px; }
.td-wl-del-body p { margin: 0 0 12px; font-size: 13px; color: var(--td-ink-1); line-height: 1.7; }
.td-wl-del-preview {
    padding: 10px 14px;
    background: rgba(0, 0, 0, .3);
    border: 1px solid var(--td-line);
    border-radius: 8px;
    font-family: 'Consolas', 'Menlo', monospace;
    font-size: 12px;
    color: var(--td-ink-2);
    margin-top: 10px;
}
.td-wl-modal-sm .td-wl-form-foot { padding: 0 22px 20px; }

/* ── 지갑 보너스 힌트 (헤더 내) ── */
.td-wl-bonus-hint {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-top: 12px;
    padding: 10px 14px;
    background: linear-gradient(135deg, rgba(255, 204, 51, .12), rgba(255, 153, 51, .08));
    border: 1px solid rgba(255, 204, 51, .35);
    border-radius: 10px;
}
.td-wl-bonus-hint > span { font-size: 22px; }
.td-wl-bonus-hint b {
    display: block;
    font-size: 12px;
    font-weight: 800;
    color: var(--td-gold);
    margin-bottom: 2px;
}
.td-wl-bonus-hint em {
    font-style: normal;
    font-size: 11px;
    color: var(--td-ink-2);
}
.td-wl-bonus-hint strong {
    color: var(--td-gold);
    font-weight: 900;
}

/* ── 등록 모달 보너스 배너 ── */
.td-wl-bonus-banner {
    padding: 12px 14px;
    background: linear-gradient(135deg, rgba(255, 204, 51, .12), rgba(168, 85, 247, .1));
    border: 1px solid rgba(255, 204, 51, .3);
    border-radius: 10px;
    font-size: 12px;
    color: var(--td-ink-1);
    text-align: center;
}
.td-wl-bonus-banner strong {
    color: var(--td-gold);
    font-weight: 900;
}

/* ── 삭제 모달 페널티 경고 ── */
.td-wl-del-penalty {
    margin-top: 12px;
    padding: 10px 14px;
    background: rgba(255, 69, 119, .1);
    border: 1px solid rgba(255, 69, 119, .35);
    border-radius: 8px;
    font-size: 12px;
    color: var(--td-red);
    font-weight: 700;
}
.td-wl-del-penalty strong { font-weight: 900; }

/* ── 토스트 ── */
.td-wl-toast {
    position: fixed;
    bottom: 40px;
    left: 50%;
    transform: translateX(-50%) translateY(20px);
    z-index: 2147483001;
    padding: 12px 22px;
    border-radius: 999px;
    color: #fff;
    font-weight: 800;
    font-size: 13px;
    display: flex;
    align-items: center;
    gap: 10px;
    backdrop-filter: blur(8px);
    opacity: 0;
    transition: opacity .25s ease, transform .25s ease;
    box-shadow: 0 12px 30px rgba(0, 0, 0, .4);
}
.td-wl-toast.show {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}
.td-wl-toast.tone-success {
    background: linear-gradient(135deg, rgba(16, 185, 129, .95), rgba(16, 185, 129, .8));
    border: 1px solid rgba(16, 185, 129, .5);
}
.td-wl-toast.tone-warn {
    background: linear-gradient(135deg, rgba(255, 69, 119, .95), rgba(255, 69, 119, .8));
    border: 1px solid rgba(255, 69, 119, .5);
}

/* ============================================================
 * 입금 / 출금 섹션 (눈에 잘 띄게 강조)
 * ============================================================ */
.td-wallet-ops {
    margin-top: 18px;
    padding: 28px 30px;
    background:
        radial-gradient(800px 200px at 0% 0%, rgba(38, 161, 123, .18), transparent 70%),
        radial-gradient(800px 200px at 100% 100%, rgba(0, 245, 255, .12), transparent 70%),
        linear-gradient(180deg, var(--td-bg-3), var(--td-bg-1));
    border: 1px solid rgba(38, 161, 123, .3);
    border-radius: 16px;
}
.td-wallet-ops-head {
    margin-bottom: 18px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--td-line);
}
.td-wallet-ops-head small {
    display: block;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .22em;
    color: var(--td-tether);
    margin-bottom: 8px;
}
.td-wallet-ops-head h3 {
    margin: 0 0 6px;
    font-size: 22px;
    font-weight: 900;
    color: var(--td-ink-0);
    letter-spacing: -.02em;
}
.td-wallet-ops-head p {
    margin: 0;
    font-size: 13px;
    color: var(--td-ink-2);
    line-height: 1.7;
}

.td-wallet-ops-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}
.td-wallet-op {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 16px;
    padding: 22px 24px;
    border: 1px solid var(--td-line);
    border-radius: 14px;
    background: rgba(255, 255, 255, .03);
    color: var(--td-ink-1);
    cursor: not-allowed;
    font-family: inherit;
    text-align: left;
    position: relative;
    overflow: hidden;
    transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.td-wallet-op:not(:disabled) { cursor: pointer; }
.td-wallet-op:not(:disabled):hover {
    transform: translateY(-3px);
    border-color: var(--td-tether);
    box-shadow: 0 14px 34px rgba(38, 161, 123, .2);
}
.td-wallet-op-deposit {
    background: linear-gradient(135deg, rgba(38, 161, 123, .22), rgba(16, 185, 129, .08)), rgba(255, 255, 255, .03);
    border-color: rgba(38, 161, 123, .45);
}
.td-wallet-op-withdraw {
    background: linear-gradient(135deg, rgba(0, 245, 255, .18), rgba(168, 85, 247, .08)), rgba(255, 255, 255, .03);
    border-color: rgba(0, 245, 255, .4);
}
.td-wallet-op-ic {
    width: 56px; height: 56px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: #fff;
}
.td-wallet-op-deposit .td-wallet-op-ic {
    background: linear-gradient(135deg, var(--td-tether), #1a7a5c);
    box-shadow: 0 8px 20px rgba(38, 161, 123, .4);
}
.td-wallet-op-withdraw .td-wallet-op-ic {
    background: linear-gradient(135deg, var(--td-cyan), var(--td-violet));
    color: var(--td-bg-0);
    box-shadow: 0 8px 20px rgba(0, 245, 255, .3);
}
.td-wallet-op-body { display: flex; flex-direction: column; gap: 2px; }
.td-wallet-op-tag {
    display: inline-block;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .15em;
    color: var(--td-ink-3);
    margin-bottom: 2px;
}
.td-wallet-op-body b {
    font-size: 18px;
    font-weight: 900;
    color: var(--td-ink-0);
    letter-spacing: -.01em;
}
.td-wallet-op-body small {
    font-size: 12px;
    color: var(--td-ink-2);
}
.td-wallet-op-status {
    padding: 6px 14px;
    background: rgba(255, 204, 51, .14);
    border: 1px solid rgba(255, 204, 51, .4);
    border-radius: 999px;
    font-size: 11px;
    font-weight: 900;
    color: var(--td-gold);
    white-space: nowrap;
}

.td-wallet-ops-note {
    margin-top: 14px;
    padding: 12px 16px;
    background: rgba(0, 0, 0, .25);
    border: 1px dashed var(--td-line);
    border-radius: 10px;
    font-size: 12px;
    color: var(--td-ink-2);
    text-align: center;
}
.td-wallet-ops-note b { color: var(--td-gold); font-weight: 800; }

/* ============================================================
 * 획득 내역 (체험 지갑 카드 내)
 * ============================================================ */
.td-earn-wrap {
    margin-top: 18px;
    padding-top: 18px;
    border-top: 1px solid var(--td-line);
}
.td-earn-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 12px;
}
.td-earn-head small {
    display: block;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .18em;
    color: var(--td-cyan);
    margin-bottom: 4px;
}
.td-earn-head h4 {
    margin: 0;
    font-size: 15px;
    font-weight: 900;
    color: var(--td-ink-0);
}
.td-earn-count {
    padding: 3px 10px;
    background: rgba(16, 185, 129, .12);
    border: 1px solid rgba(16, 185, 129, .35);
    border-radius: 999px;
    font-size: 11px;
    font-weight: 800;
    color: var(--td-emerald);
}

.td-earn-empty {
    padding: 28px 16px;
    text-align: center;
    background: rgba(255, 255, 255, .03);
    border: 1px dashed var(--td-line);
    border-radius: 10px;
}
.td-earn-empty span { font-size: 34px; display: block; margin-bottom: 8px; }
.td-earn-empty b { display: block; font-size: 13px; color: var(--td-ink-1); margin-bottom: 4px; }
.td-earn-empty small { font-size: 11px; color: var(--td-ink-2); }
.td-earn-empty strong { color: var(--td-gold); font-weight: 900; }

.td-earn-list {
    list-style: none;
    padding: 0;
    margin: 0;
    max-height: 360px;
    overflow-y: auto;
    border: 1px solid var(--td-line);
    border-radius: 10px;
}
.td-earn-list::-webkit-scrollbar { width: 6px; }
.td-earn-list::-webkit-scrollbar-thumb { background: var(--td-line-2); border-radius: 3px; }
.td-earn-item {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 12px;
    align-items: center;
    padding: 12px 16px;
    border-bottom: 1px solid var(--td-line);
    background: rgba(255, 255, 255, .02);
    transition: background .2s ease;
}
.td-earn-item:last-child { border-bottom: 0; }
.td-earn-item:hover { background: rgba(0, 245, 255, .04); }
.td-earn-ic {
    width: 36px; height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, .05);
    border-radius: 10px;
    font-size: 18px;
    flex-shrink: 0;
}
.td-earn-info { min-width: 0; }
.td-earn-info b {
    display: block;
    font-size: 13px;
    font-weight: 800;
    color: var(--td-ink-0);
    margin-bottom: 2px;
    letter-spacing: -.01em;
}
.td-earn-info small {
    display: block;
    font-size: 11px;
    color: var(--td-ink-2);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.td-earn-right { text-align: right; white-space: nowrap; }
.td-earn-amt {
    display: block;
    font-size: 15px;
    font-weight: 900;
    color: var(--td-emerald);
    font-variant-numeric: tabular-nums;
    margin-bottom: 2px;
}
.td-earn-time {
    font-size: 10px;
    color: var(--td-ink-3);
    font-variant-numeric: tabular-nums;
}

/* ============================================================
 * 가이드 완료 모달 — 화려한 지갑 등록 유도
 * ============================================================ */
.td-sparkle {
    position: absolute;
    width: 8px; height: 8px;
    background: linear-gradient(135deg, #fff, var(--td-gold));
    border-radius: 50%;
    pointer-events: none;
    opacity: 0;
    animation: tdSparkle 2.4s ease-in-out infinite;
    box-shadow: 0 0 12px rgba(255, 204, 51, .8);
}
.td-sparkle.sp1 { top: 14%; left: 12%; animation-delay: 0s; }
.td-sparkle.sp2 { top: 22%; right: 10%; animation-delay: .4s; }
.td-sparkle.sp3 { top: 48%; left: 8%;  animation-delay: .8s; width: 6px; height: 6px; }
.td-sparkle.sp4 { top: 60%; right: 14%; animation-delay: 1.2s; }
.td-sparkle.sp5 { top: 80%; left: 18%;  animation-delay: 1.6s; width: 5px; height: 5px; }
.td-sparkle.sp6 { top: 30%; left: 48%;  animation-delay: 2s;   width: 6px; height: 6px; }
@keyframes tdSparkle {
    0%, 100% { opacity: 0; transform: scale(.5) rotate(0deg); }
    50%      { opacity: 1; transform: scale(1.2) rotate(180deg); }
}

.td-grant-hype {
    position: relative;
    padding: 24px 24px 20px;
    background:
        radial-gradient(400px 160px at 50% 0%, rgba(255, 204, 51, .3), transparent 70%),
        linear-gradient(135deg, rgba(255, 153, 51, .22), rgba(168, 85, 247, .18));
    border: 2px solid rgba(255, 204, 51, .45);
    border-radius: 14px;
    overflow: hidden;
    text-align: center;
    box-shadow: 0 0 0 1px rgba(255, 204, 51, .15) inset,
                0 16px 40px rgba(255, 153, 51, .25);
}
.td-grant-hype-shine {
    position: absolute;
    top: 0;
    left: -100%;
    width: 60%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, .22), transparent);
    animation: tdShine 3s ease-in-out infinite;
    pointer-events: none;
}
@keyframes tdShine {
    0%   { left: -60%; }
    100% { left: 140%; }
}

.td-grant-hype-badge {
    display: inline-block;
    padding: 4px 12px;
    background: linear-gradient(135deg, var(--td-red), var(--td-gold));
    color: #fff;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .1em;
    margin-bottom: 12px;
    box-shadow: 0 4px 14px rgba(255, 69, 119, .4);
    animation: tdBadgePulse 1.5s ease-in-out infinite;
}
@keyframes tdBadgePulse {
    0%, 100% { transform: scale(1); }
    50%      { transform: scale(1.06); }
}

.td-grant-hype-title {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    margin-bottom: 12px;
}
.td-grant-hype-line1,
.td-grant-hype-line2 {
    font-size: 16px;
    font-weight: 900;
    color: var(--td-ink-0);
    letter-spacing: -.01em;
}
.td-grant-hype-big {
    display: inline-flex;
    align-items: baseline;
    gap: 2px;
    font-weight: 900;
    line-height: 1;
    color: #fff;
    text-shadow: 0 0 30px rgba(255, 204, 51, .8),
                 0 4px 12px rgba(255, 153, 51, .6);
    animation: tdBigBounce 1.4s ease-in-out infinite;
}
.td-grant-hype-big em {
    font-style: normal;
    font-size: 72px;
    background: linear-gradient(135deg, #FFE878 0%, var(--td-gold) 50%, #FF8C42 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    -webkit-text-stroke: 1px rgba(255, 255, 255, .2);
    filter: drop-shadow(0 6px 10px rgba(255, 153, 51, .5));
}
.td-grant-hype-big sup {
    font-size: 32px;
    color: var(--td-gold);
    font-weight: 900;
    margin-left: 2px;
}
@keyframes tdBigBounce {
    0%, 100% { transform: translateY(0); }
    50%      { transform: translateY(-4px); }
}

.td-grant-hype-sub {
    font-size: 14px;
    color: var(--td-ink-0);
    font-weight: 700;
    line-height: 1.6;
}
.td-grant-hype-sub b { color: var(--td-cyan); font-weight: 900; }
.td-grant-hype-sub strong {
    color: var(--td-gold);
    font-weight: 900;
    font-size: 16px;
}
.td-grant-hype-ex {
    color: var(--td-red);
    font-weight: 900;
    animation: tdExclaim 0.9s ease-in-out infinite;
    display: inline-block;
}
@keyframes tdExclaim {
    0%, 100% { transform: rotate(-3deg) scale(1); }
    50%      { transform: rotate(3deg) scale(1.15); }
}

.td-grant-hype-chips {
    display: flex;
    justify-content: center;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 14px;
}
.td-grant-hype-chips span {
    font-size: 11px;
    font-weight: 800;
    padding: 5px 11px;
    background: rgba(0, 0, 0, .35);
    border: 1px solid rgba(255, 204, 51, .35);
    border-radius: 999px;
    color: var(--td-ink-0);
}

/* pulse 버튼 (계속 진행 강조) */
.td-grant-btn-pulse {
    position: relative;
    animation: tdBtnPulse 1.6s ease-in-out infinite;
}
.td-grant-btn-pulse b {
    background: rgba(0, 0, 0, .25);
    padding: 2px 8px;
    border-radius: 6px;
    margin: 0 4px;
}
@keyframes tdBtnPulse {
    0%, 100% { box-shadow: 0 8px 22px rgba(0, 245, 255, .3); }
    50%      { box-shadow: 0 10px 30px rgba(0, 245, 255, .55),
                           0 0 0 4px rgba(0, 245, 255, .1); }
}

/* ── 반응형 ── */
@media (max-width: 768px) {
    .td-wallet-ops-grid { grid-template-columns: 1fr; }
    .td-wallet-ops { padding: 20px 16px; }
    .td-wallet-ops-head h3 { font-size: 18px; }
    .td-wallet-op { padding: 18px; gap: 12px; }
    .td-wallet-op-ic { width: 44px; height: 44px; }
    .td-wallet-op-body b { font-size: 15px; }
    .td-grant-hype-big em { font-size: 56px; }
    .td-earn-item { padding: 10px 12px; gap: 10px; }
    .td-earn-info b { font-size: 12px; }
    .td-earn-amt { font-size: 13px; }
}

/* ===== 반응형 ===== */
@media (max-width: 768px) {
    .td-header-inner { padding: 18px 20px; }
    .td-brand-logo { width: 48px; height: 48px; font-size: 26px; }
    .td-brand-txt b { font-size: 18px; }
    .td-tab { padding: 10px 8px; font-size: 11px; }
    .td-tab-lbl { display: none; }
    .td-tab.is-active .td-tab-lbl { display: inline; }
    .td-hero, .td-sec { padding: 22px 20px; }
    .td-hero-title { font-size: 20px; }
    .td-sec-title { font-size: 17px; }
    .td-grid-2, .td-exchanges { grid-template-columns: 1fr; }
    .td-usage { grid-template-columns: 1fr 1fr; }
    .td-progress-row { font-size: 11px; }
    .td-progress-reward { margin-left: 0; width: 100%; }
    .td-wb-val { font-size: 36px; }
    .td-finale { padding: 22px; }
    .td-finale-btn { padding: 14px 22px; font-size: 14px; }
    .td-wallet-meta { grid-template-columns: 1fr 1fr; }
    .td-wl-section { padding: 20px 16px; }
    .td-wl-head { flex-direction: column; align-items: flex-start; }
    .td-wl-table thead { display: none; }
    .td-wl-table tbody td { display: block; padding: 6px 14px; border: 0; }
    .td-wl-table tbody tr {
        display: block;
        padding: 14px 0;
        border-bottom: 1px solid var(--td-line);
    }
    .td-wl-table tbody tr:last-child { border-bottom: 0; }
    .td-wl-col-date::before { content: '등록 '; color: var(--td-ink-3); font-size: 11px; }
    .td-wl-col-actions { text-align: left; padding-top: 8px !important; }
    .td-wl-mini-btn { margin: 0 4px 0 0; }
}

/* ============================================================
 * 암호화폐 정보 페이지
 * ============================================================ */
.cr-wrap { color: var(--td-ink-1); }

.cr-hero {
    padding: 32px;
    margin-bottom: 20px;
    background: radial-gradient(900px 220px at 20% 0%, rgba(247, 166, 0, .14), transparent 70%),
                linear-gradient(180deg, var(--td-bg-2), var(--td-bg-1));
    border: 1px solid var(--td-line);
    border-radius: 16px;
}
.cr-hero-tag {
    display: inline-block;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .22em;
    color: var(--td-gold);
    background: rgba(255, 204, 51, .12);
    padding: 5px 12px;
    border-radius: 999px;
    border: 1px solid rgba(255, 204, 51, .35);
    margin-bottom: 14px;
}
.cr-hero-title { margin: 0 0 12px; font-size: 28px; font-weight: 900; color: var(--td-ink-0); letter-spacing: -.02em; }
.cr-hero-desc { margin: 0 0 18px; font-size: 14px; line-height: 1.8; color: var(--td-ink-1); }
.cr-hero-desc b { color: var(--td-gold); }
.cr-hero-meta { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; font-size: 11px; color: var(--td-ink-3); }

.cr-badge {
    padding: 5px 12px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 800;
    background: rgba(255, 255, 255, .04);
    border: 1px solid var(--td-line);
    color: var(--td-ink-2);
}
.cr-badge.cr-ok   { background: rgba(16, 185, 129, .12);  border-color: rgba(16, 185, 129, .3);  color: var(--td-emerald); }
.cr-badge.cr-warn { background: rgba(255, 204, 51, .12);  border-color: rgba(255, 204, 51, .35); color: var(--td-gold); }
.cr-badge.cr-bad  { background: rgba(255, 69, 119, .12);  border-color: rgba(255, 69, 119, .35); color: var(--td-red); }
.cr-updated { font-size: 11px; color: var(--td-ink-3); }
.cr-refresh {
    margin-left: auto;
    padding: 6px 14px;
    background: rgba(0, 245, 255, .1);
    border: 1px solid rgba(0, 245, 255, .3);
    border-radius: 8px;
    color: var(--td-cyan);
    font-family: inherit;
    font-weight: 800;
    font-size: 12px;
    cursor: pointer;
    transition: all .18s ease;
}
.cr-refresh:hover { background: rgba(0, 245, 255, .2); transform: translateY(-1px); }

/* ── 글로벌 지표 ── */
.cr-global {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin-bottom: 18px;
}
.cr-global-card {
    padding: 18px 20px;
    background: linear-gradient(180deg, var(--td-bg-2), var(--td-bg-1));
    border: 1px solid var(--td-line);
    border-radius: 12px;
}
.cr-global-card small { display: block; font-size: 11px; color: var(--td-ink-3); margin-bottom: 8px; letter-spacing: .03em; }
.cr-global-card b { display: block; font-size: 20px; font-weight: 900; color: var(--td-ink-0); font-variant-numeric: tabular-nums; letter-spacing: -.01em; }
.cr-global-card em {
    display: inline-block;
    margin-top: 6px;
    font-style: normal;
    font-size: 11px;
    color: var(--td-ink-2);
    font-variant-numeric: tabular-nums;
}
.cr-delta.cr-up   { color: var(--td-emerald); font-weight: 800; }
.cr-delta.cr-down { color: var(--td-red);     font-weight: 800; }
.cr-sub { font-size: 11px; color: var(--td-ink-3); }
.cr-sub span { color: var(--td-cyan); font-weight: 700; }

/* ── 상위 상승/하락 ── */
.cr-top-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-bottom: 18px;
}
.cr-top-card {
    padding: 18px 20px;
    background: linear-gradient(180deg, var(--td-bg-2), var(--td-bg-1));
    border: 1px solid var(--td-line);
    border-radius: 14px;
}
.cr-top-gainers { border-color: rgba(16, 185, 129, .3); }
.cr-top-losers  { border-color: rgba(255, 69, 119, .3); }
.cr-top-card > header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 12px; padding-bottom: 10px; border-bottom: 1px dashed var(--td-line); }
.cr-top-card > header small { font-size: 12px; color: var(--td-ink-2); font-weight: 700; }
.cr-top-card > header b { font-size: 10px; font-weight: 900; letter-spacing: .15em; color: var(--td-ink-3); }
.cr-top-list { list-style: none; margin: 0; padding: 0; }
.cr-top-list li {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 10px;
    align-items: center;
    padding: 10px 0;
    border-bottom: 1px solid var(--td-line);
}
.cr-top-list li:last-child { border-bottom: 0; }
.cr-top-empty { color: var(--td-ink-3); font-size: 12px; text-align: center; padding: 20px 0 !important; border: 0 !important; }
.cr-mover-img { width: 28px; height: 28px; border-radius: 50%; }
.cr-mover-info b { display: block; font-size: 13px; font-weight: 800; color: var(--td-ink-0); }
.cr-mover-info small { font-size: 11px; color: var(--td-ink-3); }
.cr-mover-right { text-align: right; font-variant-numeric: tabular-nums; }
.cr-mover-price { display: block; font-size: 12px; color: var(--td-ink-1); font-weight: 700; }
.cr-mover-pct { font-size: 11px; font-weight: 900; }
.cr-mover-pct.cr-up   { color: var(--td-emerald); }
.cr-mover-pct.cr-down { color: var(--td-red); }

/* ── 시세 테이블 ── */
.cr-table-section {
    margin-bottom: 18px;
    padding: 24px 26px 20px;
    background: linear-gradient(180deg, var(--td-bg-2), var(--td-bg-1));
    border: 1px solid var(--td-line);
    border-radius: 14px;
}
.cr-table-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 16px; margin-bottom: 16px; flex-wrap: wrap; }
.cr-table-head small { display: block; font-size: 10px; font-weight: 900; letter-spacing: .18em; color: var(--td-cyan); margin-bottom: 4px; }
.cr-table-head h2 { margin: 0; font-size: 18px; font-weight: 900; color: var(--td-ink-0); letter-spacing: -.01em; }
.cr-table-tools { display: flex; gap: 8px; }
.cr-search {
    width: 260px;
    height: 36px;
    padding: 0 12px;
    background: rgba(0, 0, 0, .3);
    border: 1px solid var(--td-line);
    border-radius: 8px;
    color: var(--td-ink-0);
    font-size: 13px;
    font-family: inherit;
    transition: border-color .2s ease, background .2s ease;
}
.cr-search:focus { outline: none; border-color: var(--td-cyan); background: rgba(0, 0, 0, .5); box-shadow: 0 0 0 3px rgba(0, 245, 255, .12); }
.cr-search::placeholder { color: var(--td-ink-3); }

.cr-table-wrap { overflow-x: auto; border-radius: 10px; border: 1px solid var(--td-line); }
.cr-table { width: 100%; border-collapse: collapse; font-size: 13px; min-width: 760px; }
.cr-table thead th {
    padding: 12px 14px;
    background: rgba(255, 255, 255, .04);
    color: var(--td-ink-2);
    font-size: 11px;
    font-weight: 800;
    text-align: left;
    letter-spacing: .03em;
    border-bottom: 1px solid var(--td-line);
    white-space: nowrap;
    cursor: pointer;
    user-select: none;
    transition: background .15s ease, color .15s ease;
}
.cr-table thead th:hover { background: rgba(0, 245, 255, .08); color: var(--td-cyan); }
.cr-table thead th.cr-num { text-align: right; }
.cr-table thead th.cr-sorted-asc::after  { content: ' ▲'; color: var(--td-cyan); }
.cr-table thead th.cr-sorted-desc::after { content: ' ▼'; color: var(--td-cyan); }
.cr-table tbody td {
    padding: 12px 14px;
    border-bottom: 1px solid var(--td-line);
    color: var(--td-ink-1);
    vertical-align: middle;
    font-variant-numeric: tabular-nums;
}
.cr-table tbody tr:last-child td { border-bottom: 0; }
.cr-table tbody tr:hover { background: rgba(0, 245, 255, .03); }
.cr-col-rank { width: 40px; color: var(--td-ink-3); text-align: center !important; }
.cr-col-name { display: flex; align-items: center; gap: 10px; min-width: 180px; }
.cr-coin-img { width: 24px; height: 24px; border-radius: 50%; flex-shrink: 0; }
.cr-coin-name { font-weight: 800; color: var(--td-ink-0); }
.cr-coin-sym { font-size: 11px; color: var(--td-ink-3); font-weight: 700; padding: 2px 6px; background: rgba(255, 255, 255, .05); border-radius: 4px; }
.cr-num { text-align: right; white-space: nowrap; }
.cr-price { color: var(--td-ink-0); font-weight: 700; }
.cr-dim { color: var(--td-ink-2); }
.cr-up   { color: var(--td-emerald); font-weight: 700; }
.cr-down { color: var(--td-red);     font-weight: 700; }
.cr-empty { padding: 40px 20px !important; text-align: center; color: var(--td-ink-3); }

/* ── 용어 사전 ── */
.cr-glossary {
    padding: 26px 28px;
    background: linear-gradient(180deg, var(--td-bg-2), var(--td-bg-1));
    border: 1px solid var(--td-line);
    border-radius: 14px;
}
.cr-glossary-head small { display: block; font-size: 10px; font-weight: 900; letter-spacing: .18em; color: var(--td-violet); margin-bottom: 4px; }
.cr-glossary-head h2 { margin: 0 0 6px; font-size: 20px; font-weight: 900; color: var(--td-ink-0); letter-spacing: -.01em; }
.cr-glossary-head p { margin: 0 0 16px; font-size: 13px; color: var(--td-ink-2); line-height: 1.7; }

.cr-gl-tools { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; padding-bottom: 16px; margin-bottom: 16px; border-bottom: 1px solid var(--td-line); }
.cr-gl-tools .cr-search { flex: 1 1 240px; max-width: 340px; }
.cr-gl-cats { display: flex; gap: 6px; flex-wrap: wrap; }
.cr-gl-cat {
    padding: 6px 12px;
    background: rgba(255, 255, 255, .04);
    border: 1px solid var(--td-line);
    border-radius: 999px;
    color: var(--td-ink-2);
    font-size: 12px;
    font-weight: 700;
    font-family: inherit;
    cursor: pointer;
    transition: all .15s ease;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.cr-gl-cat span { font-size: 14px; }
.cr-gl-cat:hover { background: rgba(255, 255, 255, .08); color: var(--td-ink-0); }
.cr-gl-cat.is-active { background: linear-gradient(135deg, rgba(168, 85, 247, .2), rgba(0, 245, 255, .2)); color: var(--td-ink-0); border-color: rgba(168, 85, 247, .4); }

.cr-gl-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.cr-gl-card {
    padding: 0;
    background: rgba(255, 255, 255, .03);
    border: 1px solid var(--td-line);
    border-radius: 10px;
    transition: border-color .2s ease;
}
.cr-gl-card[open] { border-color: rgba(168, 85, 247, .4); background: rgba(168, 85, 247, .06); }
.cr-gl-card summary {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 16px;
    cursor: pointer;
    list-style: none;
    font-size: 14px;
}
.cr-gl-card summary::-webkit-details-marker { display: none; }
.cr-gl-icon { font-size: 18px; }
.cr-gl-q { flex: 1; color: var(--td-ink-0); font-weight: 800; letter-spacing: -.01em; }
.cr-gl-toggle { font-size: 18px; color: var(--td-ink-3); font-weight: 400; transition: transform .2s ease; }
.cr-gl-card[open] .cr-gl-toggle { transform: rotate(45deg); color: var(--td-violet); }
.cr-gl-card p { margin: 0; padding: 0 16px 16px; font-size: 13px; color: var(--td-ink-1); line-height: 1.75; border-top: 1px dashed var(--td-line); padding-top: 12px; }
.cr-gl-empty { grid-column: 1 / -1; padding: 40px; text-align: center; color: var(--td-ink-3); font-size: 13px; }

.cr-disclaimer {
    margin-top: 16px;
    padding: 14px 18px;
    background: rgba(0, 0, 0, .25);
    border: 1px dashed var(--td-line);
    border-radius: 10px;
    font-size: 11px;
    color: var(--td-ink-3);
    text-align: center;
    line-height: 1.7;
}
.cr-disclaimer b { color: var(--td-gold); }
.cr-disclaimer a { color: var(--td-cyan); text-decoration: none; }
.cr-disclaimer a:hover { text-decoration: underline; }

@media (max-width: 768px) {
    .cr-hero { padding: 22px 18px; }
    .cr-hero-title { font-size: 22px; }
    .cr-global { grid-template-columns: 1fr 1fr; }
    .cr-top-row { grid-template-columns: 1fr; }
    .cr-table-section { padding: 18px 14px; }
    .cr-table-head { flex-direction: column; align-items: flex-start; }
    .cr-search { width: 100%; }
    .cr-glossary { padding: 20px 16px; }
    .cr-gl-grid { grid-template-columns: 1fr; }
    .cr-refresh { margin-left: 0; }
}
