:root {
  --bg: #f0f4fa;
  --surface: #fff;
  --border: #e2e8f0;
  --text: #0f172a;
  --muted: #64748b;
  --primary: #2563eb;
  --primary-hover: #1d4ed8;
  --success: #10b981;
  --danger: #ef4444;
  --sidebar: #fff;
  --shadow: 0 1px 3px rgba(15,23,42,.06);
  --radius: 10px;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: "DM Sans", system-ui, sans-serif; background: var(--bg); color: var(--text); min-height: 100vh; }
.hidden { display: none !important; }
.green { color: var(--success); }
.muted { color: var(--muted); font-size: .85rem; }

.login-wrap { min-height: 100vh; display: grid; place-items: center; background: var(--bg); }
.login-card { width: min(420px,92vw); background: var(--surface); border-radius: 16px; padding: 2.5rem; box-shadow: var(--shadow); border: 1px solid var(--border); }
.login-logo { width: 52px; height: 52px; border-radius: 14px; background: linear-gradient(135deg,#6366f1,#2563eb); display: grid; place-items: center; font-size: 1.5rem; margin: 0 auto 1rem; }
.login-card h1 { text-align: center; font-size: 1.2rem; margin-bottom: .25rem; }
.login-card .sub { text-align: center; color: var(--muted); font-size: .85rem; margin-bottom: 1.5rem; }
.demo-hints { margin-top: 1rem; padding: .75rem; background: #f8fafc; border-radius: 8px; font-size: .78rem; color: var(--muted); line-height: 1.6; }
.demo-hints code { color: var(--primary); font-weight: 600; }

.shell { display: flex; min-height: 100vh; }
.sidebar { width: 220px; background: var(--sidebar); border-right: 1px solid var(--border); padding: 1rem 0; flex-shrink: 0; display: flex; flex-direction: column; }
.sidebar-brand { padding: 0 1rem 1rem; display: flex; gap: .6rem; align-items: center; border-bottom: 1px solid var(--border); margin-bottom: .5rem; }
.sidebar-brand .logo { width: 34px; height: 34px; border-radius: 8px; background: linear-gradient(135deg,#6366f1,#2563eb); display: grid; place-items: center; }
.sidebar-brand strong { font-size: .82rem; display: block; line-height: 1.3; }
.sidebar-brand span { font-size: .68rem; color: var(--muted); }
.nav { flex: 1; padding: .5rem .75rem; overflow-y: auto; }
.nav-section { font-size: .72rem; color: var(--muted); font-weight: 600; padding: .75rem .5rem .25rem; text-transform: uppercase; letter-spacing: .04em; }
.nav-group + .nav-group { margin-top: .25rem; }
.nav a { display: block; padding: .5rem .65rem; border-radius: 8px; color: var(--text); text-decoration: none; font-size: .875rem; margin-bottom: 1px; }
.nav a:hover { background: #f1f5f9; }
.nav a.active { background: #eff6ff; color: var(--primary); font-weight: 600; }
.sidebar-footer { padding: .75rem 1rem; border-top: 1px solid var(--border); }

.main { flex: 1; display: flex; flex-direction: column; min-width: 0; }
.topbar { background: var(--surface); border-bottom: 1px solid var(--border); padding: .85rem 1.25rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; min-height: 64px; }
.topbar-right { display: flex; align-items: center; gap: .75rem; margin-left: auto; }
.topbar h2 { font-size: 1.05rem; font-weight: 600; }
.topbar .meta { font-size: .78rem; color: var(--muted); margin-top: .15rem; }
.notif-wrap { position: relative; }
.notif-btn { position: relative; font-size: 1.1rem; line-height: 1; padding: .35rem .5rem; }
.notif-badge { position: absolute; top: -2px; right: -2px; min-width: 16px; height: 16px; padding: 0 4px; border-radius: 999px; background: var(--danger); color: #fff; font-size: 10px; font-weight: 700; line-height: 16px; text-align: center; }
.notif-panel { position: absolute; right: 0; top: calc(100% + 6px); width: min(360px, 90vw); max-height: 420px; overflow: auto; background: var(--surface); border: 1px solid var(--border); border-radius: 10px; box-shadow: var(--shadow); z-index: 200; }
.notif-head { display: flex; align-items: center; justify-content: space-between; padding: .65rem .85rem; border-bottom: 1px solid var(--border); }
.notif-list { padding: .35rem 0; }
.notif-item { padding: .65rem .85rem; cursor: pointer; border-bottom: 1px solid var(--border); }
.notif-item:last-child { border-bottom: none; }
.notif-item:hover { background: var(--surface-2); }
.notif-item.unread { background: #eff6ff; }
.notif-item p { font-size: .78rem; margin: .25rem 0; }
.notif-time { font-size: .72rem; }
.balance-pill { display: flex; align-items: center; gap: .65rem; background: #f8fafc; border: 1px solid var(--border); border-radius: 10px; padding: .4rem .65rem; }
.balance-pill .lbl { font-size: .72rem; color: var(--muted); }
.balance-pill strong { color: var(--primary); font-size: .95rem; }
.content { padding: 1.25rem; flex: 1; overflow: auto; }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: .35rem; padding: .5rem .9rem; border-radius: 8px; border: none; font-family: inherit; font-size: .84rem; font-weight: 600; cursor: pointer; }
.btn-primary { background: var(--primary); color: #fff; }
.btn-primary:hover { background: var(--primary-hover); }
.btn-primary:disabled { opacity: .5; cursor: not-allowed; }
.btn-ghost { background: #fff; color: var(--muted); border: 1px solid var(--border); }
.btn-danger { background: var(--danger); color: #fff; }
.btn-sm { padding: .35rem .7rem; font-size: .78rem; }
.btn-block { width: 100%; }

.field { margin-bottom: .85rem; }
.field label { display: block; font-size: .75rem; font-weight: 600; color: var(--muted); margin-bottom: .3rem; }
.field input, .field select { width: 100%; padding: .55rem .75rem; border: 1px solid var(--border); border-radius: 8px; font-family: inherit; font-size: .875rem; }
.field input:focus, .field select:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(37,99,235,.12); }

.stats-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(170px,1fr)); gap: .85rem; margin-bottom: 1rem; }
.stats-grid.five { grid-template-columns: repeat(5,1fr); }
.stats-grid.four { grid-template-columns: repeat(4,1fr); }
.stats-grid.three { grid-template-columns: repeat(3,1fr); }
@media (max-width:1100px) { .stats-grid.five { grid-template-columns: repeat(2,1fr); } }
.stat-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 1rem; box-shadow: var(--shadow); }
.stat-card .label { font-size: .75rem; color: var(--muted); margin-bottom: .25rem; }
.stat-card .value { font-size: 1.45rem; font-weight: 700; }
.stat-card .value.sm { font-size: 1rem; }
.stat-card .delta { font-size: .72rem; margin-top: .2rem; }
.stat-card .delta.green { color: var(--success); }
.stat-card .delta.muted { color: var(--muted); }
.value-xl { font-size: 2rem; font-weight: 700; color: var(--primary); }

.panel { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow); margin-bottom: 1rem; overflow: hidden; }
.panel-head { padding: .85rem 1rem; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: .5rem; }
.panel-head h3 { font-size: .9rem; font-weight: 600; }
.panel-body { padding: 1rem; }
.charts-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 1rem; }
@media (max-width:900px) { .charts-row { grid-template-columns: 1fr; } .sidebar { display: none; } }

table { width: 100%; border-collapse: collapse; font-size: .82rem; }
th, td { padding: .65rem .85rem; text-align: left; border-bottom: 1px solid var(--border); }
th { font-size: .72rem; color: var(--muted); font-weight: 600; background: #f8fafc; white-space: nowrap; }
tr:hover td { background: #fafbfc; }
.badge { display: inline-block; padding: .15rem .5rem; border-radius: 999px; font-size: .68rem; font-weight: 600; }
.badge-gold { background: #fef3c7; color: #b45309; }
.link { color: var(--primary); text-decoration: none; font-size: .82rem; }

.filters { display: flex; flex-wrap: wrap; gap: .5rem; align-items: flex-end; }
.filters .field { margin: 0; min-width: 130px; }
.order-period-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .35rem;
  width: 100%;
  margin-top: .35rem;
  padding-top: .55rem;
  border-top: 1px solid var(--border);
}
.order-period-row .period-label { margin-right: .25rem; font-size: .8125rem; }
.period-btn.active { background: #dbeafe; color: #1d4ed8; border-color: #93c5fd; }
.crypto-period-btn.active { background: #dbeafe; color: #1d4ed8; border-color: #93c5fd; }
.crypto-pager { display: flex; align-items: center; justify-content: center; gap: .75rem; padding: .75rem 1rem; font-size: .8125rem; color: var(--muted); }
.admin-form textarea { width: 100%; padding: .55rem .75rem; border: 1px solid var(--border); border-radius: 8px; font-family: inherit; font-size: .875rem; line-height: 1.5; }
.field textarea { width: 100%; padding: .55rem .75rem; border: 1px solid var(--border); border-radius: 8px; font-family: inherit; font-size: .875rem; line-height: 1.5; }
.thumb { width: 38px; height: 38px; object-fit: cover; border-radius: 6px; border: 1px solid var(--border); }
.ratio-note { background: #f8fafc; border: 1px solid var(--border); border-radius: 8px; padding: .75rem; font-size: .85rem; }
.tabs { display: flex; gap: .5rem; margin-bottom: .85rem; }
.tab { padding: .45rem .85rem; border: 1px solid var(--border); border-radius: 8px; background: #fff; cursor: pointer; font-family: inherit; font-size: .82rem; }
.tab.active { background: var(--primary); color: #fff; border-color: var(--primary); }
.pager { padding: .75rem 1rem; font-size: .78rem; color: var(--muted); }
.agent-overview-panels { display: grid; grid-template-columns: 2fr 1fr; gap: 1rem; margin-bottom: 1rem; }
@media (max-width:980px) { .agent-overview-panels { grid-template-columns: 1fr; } }
.map-mode-select { border: 1px solid var(--border); border-radius: 8px; padding: .35rem .55rem; font-size: .8rem; background: #fff; color: var(--text); }
.world-map-wrap { position: relative; width: 100%; aspect-ratio: 3507 / 2480; min-height: 380px; border: 1px solid var(--border); border-radius: 12px; overflow: hidden; background: #f4f6fb; }
.world-map-canvas { position: absolute; inset: 0; transform-origin: center center; transition: transform .3s ease; }
.world-map-jvm { width: 100%; height: 100%; }
.world-map-jvm .jvm-container { background: transparent !important; }
.world-map-jvm .jvm-zoom-btn { display: none; }
.world-map-jvm .jvm-tooltip { z-index: 20; }
.world-map-svg { display: none; }
.map-ocean { fill: #f4f6fb; }
.map-land { fill: #d4d8e0; stroke: #f4f6fb; stroke-width: 0.6; transition: fill .25s ease; }
.map-land-group:hover .map-land { fill: #c9cdd6; }
.map-markers { position: absolute; inset: 0; pointer-events: none; }
.map-marker { position: absolute; transform: translate(-50%,-100%); border: none; background: transparent; padding: 0; cursor: pointer; pointer-events: auto; display: flex; flex-direction: column; align-items: center; gap: 2px; line-height: 1; }
.map-marker .flag { font-size: 22px; line-height: 1; filter: drop-shadow(0 1px 2px rgba(0,0,0,.25)); }
.map-marker .tag { display: inline-flex; align-items: center; gap: 4px; font-size: .68rem; color: #111; background: rgba(255,255,255,.96); border: 1px solid var(--border); border-radius: 6px; padding: 2px 6px; box-shadow: 0 1px 2px rgba(0,0,0,.08); white-space: nowrap; }
.map-marker .tag .dot { width: 7px; height: 7px; border-radius: 50%; display: inline-block; background: #ef4444; }
.map-marker .pulse { position: absolute; left: 50%; bottom: -4px; width: 12px; height: 12px; border-radius: 50%; transform: translate(-50%,0); background: rgba(239,68,68,.35); animation: mapPulse 1.8s infinite ease-out; pointer-events: none; }
.map-marker:hover .tag { background: #fff; box-shadow: 0 2px 6px rgba(0,0,0,.12); }
.map-marker.active .tag { background: #fff7ed; border-color: #fdba74; color: #c2410c; }
.map-marker.lv-1 .tag .dot, .map-marker.lv-1 .pulse { background: #ff1f1f; }
.map-marker.lv-2 .tag .dot, .map-marker.lv-2 .pulse { background: #7c3aed; }
.map-marker.lv-3 .tag .dot, .map-marker.lv-3 .pulse { background: #2563eb; }
.map-marker.lv-4 .tag .dot, .map-marker.lv-4 .pulse { background: #22c55e; }
.map-marker.lv-5 .tag .dot, .map-marker.lv-5 .pulse { background: #6b7280; }
.world-map-legend { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); background: rgba(255,255,255,.95); border: 1px solid var(--border); border-radius: 10px; padding: .65rem .8rem; font-size: .78rem; color: var(--muted); display: grid; gap: .35rem; box-shadow: 0 2px 6px rgba(0,0,0,.06); z-index: 5; }
.world-map-legend strong { color: var(--text); font-size: .82rem; margin-bottom: .2rem; }
.world-map-legend > div { display: flex; align-items: center; gap: .4rem; }
.world-map-legend .lv { width: 12px; height: 12px; border-radius: 50%; display: inline-block; }
.world-map-legend .lv-1 { background: #ff1f1f; }
.world-map-legend .lv-2 { background: #7c3aed; }
.world-map-legend .lv-3 { background: #2563eb; }
.world-map-legend .lv-4 { background: #22c55e; }
.world-map-legend .lv-5 { background: #6b7280; }
.world-map-legend .lv-none { background: #e8edf4; border: 1px solid #d8dee8; }
.map-zoom { position: absolute; right: 14px; bottom: 14px; display: flex; flex-direction: column; gap: 6px; z-index: 5; }
.map-zoom-btn { width: 30px; height: 30px; border-radius: 6px; border: 1px solid var(--border); background: #fff; font-size: 16px; color: var(--text); cursor: pointer; box-shadow: 0 1px 3px rgba(0,0,0,.08); display: inline-flex; align-items: center; justify-content: center; }
.map-zoom-btn:hover { background: #f8fafc; border-color: #94a3b8; }
.map-hint { margin: .6rem 0 0; font-size: .8rem; color: #2563eb; }
@keyframes mapPulse {
  0% { transform: translate(-50%,0) scale(1); opacity: .6; }
  100% { transform: translate(-50%,0) scale(3); opacity: 0; }
}
.agent-overview-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(220px,1fr)); gap: .75rem; }
.agent-overview-card { border: 1px solid var(--border); border-radius: 10px; background: #fff; padding: .85rem; box-shadow: var(--shadow); display: flex; flex-direction: column; gap: .35rem; }
.agent-overview-head { display: flex; flex-direction: column; gap: .1rem; margin-bottom: .2rem; }
.agent-overview-kv { display: flex; align-items: center; justify-content: space-between; font-size: .8rem; color: var(--muted); }
.agent-overview-kv strong { color: var(--text); }

.steps { display: flex; gap: 1.5rem; margin-bottom: 1rem; font-size: .85rem; color: var(--muted); }
.steps span.on { color: var(--primary); font-weight: 600; }
.recharge-flow { display: grid; grid-template-columns: 1fr 300px; gap: 1rem; }
@media (max-width:960px) { .recharge-flow { grid-template-columns: 1fr; } }
.flow-row { display: flex; flex-wrap: wrap; gap: .75rem; align-items: center; }
.flow-row input { flex: 1; min-width: 180px; padding: .55rem .75rem; border: 1px solid var(--border); border-radius: 8px; }
.user-card { display: flex; gap: .65rem; align-items: center; padding: .65rem .85rem; background: #f8fafc; border-radius: 10px; border: 1px solid var(--border); }
.user-card .avatar { font-size: 1.75rem; }
.user-card p { font-size: .78rem; color: var(--muted); }
.online { color: var(--success); }

.category-tabs { display: flex; gap: .4rem; flex-wrap: wrap; margin-bottom: .85rem; }
.category-tabs button { padding: .35rem .75rem; border-radius: 999px; border: 1px solid var(--border); background: #fff; cursor: pointer; font-family: inherit; font-size: .78rem; }
.category-tabs button.active { background: var(--primary); color: #fff; border-color: var(--primary); }
.product-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(130px,1fr)); gap: .65rem; }
.product-grid.lg { grid-template-columns: repeat(auto-fill,minmax(110px,1fr)); }
.product-card { border: 2px solid var(--border); border-radius: 10px; padding: .85rem .5rem; text-align: center; cursor: pointer; background: #fff; position: relative; }
.product-card.selected { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(37,99,235,.15); }
.product-card.selected::after { content: '✓'; position: absolute; top: 6px; right: 8px; color: var(--primary); font-weight: 700; }
.product-card .icon { font-size: 1.5rem; }
.product-card .name { font-size: .75rem; font-weight: 600; margin: .25rem 0; }
.product-card .qty { font-size: .68rem; color: var(--muted); }
.product-card .price { color: var(--primary); font-weight: 700; font-size: .82rem; }

.settle-panel { position: sticky; top: 1rem; align-self: start; }
.settle-block { margin-bottom: .85rem; padding-bottom: .85rem; border-bottom: 1px solid var(--border); }
.settle-block .st { font-size: .72rem; color: var(--muted); font-weight: 600; margin-bottom: .35rem; }
.settle-lines div { display: flex; justify-content: space-between; font-size: .82rem; padding: .2rem 0; }
.settle-lines .total { font-weight: 700; margin-top: .35rem; padding-top: .35rem; border-top: 1px dashed var(--border); }
.settle-lines .pay-total strong { color: var(--danger); font-size: 1.05rem; }
.settle-lines .cny-approx { font-size: .82rem; color: var(--danger); font-weight: 600; justify-content: flex-end; margin-top: .15rem; }
.settle-lines .fx-rate-row { font-size: .75rem; color: var(--muted); margin-top: .35rem; padding-top: .35rem; border-top: 1px solid var(--border); }
.settle-lines .fx-updated { font-size: .72rem; color: var(--muted); justify-content: flex-end; }
.fx-refresh { border: none; background: none; color: var(--primary); cursor: pointer; font-size: .9rem; padding: 0 .25rem; font-family: inherit; }
.settle-warning { font-size: .75rem; color: var(--muted); margin: 0 0 .75rem; line-height: 1.5; }
.settle-product .price-red { color: var(--danger); font-weight: 700; }
.search-field-wrap { flex: 1; min-width: 200px; }
.search-field-wrap input { width: 100%; padding: .55rem .75rem; border: 1px solid var(--border); border-radius: 8px; }
.search-caption { display: block; font-size: .72rem; color: var(--muted); margin-top: .25rem; }
.user-card { position: relative; flex: 1 1 100%; }
.user-card-close { position: absolute; top: .5rem; right: .5rem; border: none; background: none; color: var(--muted); cursor: pointer; font-size: .9rem; padding: .2rem .35rem; }
.user-card-close:hover { color: var(--text); }
.empty-cat { padding: 1.5rem; text-align: center; }

.allocate-layout { display: grid; grid-template-columns: 280px 1fr; gap: 1rem; }
@media (max-width:800px) { .allocate-layout { grid-template-columns: 1fr; } }
.agent-pick-list { max-height: 420px; overflow-y: auto; }
.agent-pick { display: flex; gap: .65rem; padding: .75rem 1rem; cursor: pointer; border-bottom: 1px solid var(--border); align-items: center; }
.agent-pick:hover, .agent-pick.active { background: #eff6ff; }
.agent-pick .avatar { width: 36px; height: 36px; border-radius: 50%; background: #e2e8f0; display: grid; place-items: center; font-weight: 700; }
.agent-pick p { font-size: .75rem; color: var(--muted); }
.ratio-ref { font-size: .78rem; color: var(--muted); background: #f8fafc; padding: .65rem; border-radius: 8px; margin-bottom: .85rem; }
.note { font-size: .75rem; margin: .5rem 0 1rem; }
.recharge-search-hint { font-size: .75rem; margin: .5rem 0 0; flex: 1 1 100%; width: 100%; }
.recharge-search-hint code { color: var(--primary); font-weight: 600; }

.info-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1rem; }
.info-grid div span { display: block; font-size: .72rem; color: var(--muted); }
.info-grid div strong { font-size: .9rem; }
.basic-info-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: .5rem 1.5rem; font-size: .82rem; }
.basic-info-grid div span { display: block; font-size: .72rem; color: var(--muted); margin-bottom: .1rem; }
.basic-info-grid div strong { font-size: .9rem; }
.basic-info-note { font-size: .75rem; margin-top: .75rem; }
.edit-hint { font-size: .75rem; color: var(--muted); margin-left: .25rem; }
.account-panel .panel-head { display: flex; justify-content: space-between; align-items: center; gap: .75rem; }
.pwd-tip { background: #fff7db; border: 1px solid #f0e0a0; color: #7a5f18; padding: .55rem .75rem; border-radius: 8px; font-size: .78rem; margin-bottom: 1rem; }
.password-form { max-width: 420px; }
.pwd-row { display: flex; align-items: center; border: 1px solid var(--border); border-radius: 8px; overflow: hidden; background: #fff; }
.pwd-row input { border: none; border-radius: 0; flex: 1; }
.pwd-row input:focus { outline: none; box-shadow: none; }
.pwd-eye { border: none; background: #fff; color: var(--muted); padding: .45rem .6rem; cursor: pointer; }
.verify-row { display: flex; gap: .5rem; }
.verify-row input { flex: 1; }
.account-submit { width: 100%; margin-top: .25rem; }

.modal-backdrop { position: fixed; inset: 0; background: rgba(15,23,42,.4); display: grid; place-items: center; z-index: 100; padding: 1rem; }
.modal { background: var(--surface); border-radius: 14px; width: min(480px,100%); max-height: 90vh; overflow: auto; box-shadow: 0 20px 40px rgba(0,0,0,.15); }
.modal.wide { width: min(560px,100%); }
.modal-head { padding: 1rem 1.25rem; border-bottom: 1px solid var(--border); display: flex; justify-content: space-between; align-items: center; }
.modal-body { padding: 1.25rem; }
.modal-foot { padding: .85rem 1.25rem; border-top: 1px solid var(--border); display: flex; justify-content: flex-end; gap: .5rem; }
.modal-foot-between { justify-content: space-between; }
.modal-foot-actions { display: flex; align-items: center; gap: .5rem; }
.confirm-modal .confirm-msg { margin: 0 0 .85rem; line-height: 1.55; color: var(--text); font-size: .9375rem; }
.confirm-detail {
  margin: 0;
  padding: .75rem .85rem;
  background: #f8fafc;
  border: 1px solid var(--border);
  border-radius: 10px;
  display: grid;
  gap: .45rem;
}
.confirm-detail > div { display: flex; gap: .65rem; font-size: .8125rem; align-items: baseline; }
.confirm-detail dt { margin: 0; min-width: 5.5rem; color: var(--muted); flex-shrink: 0; }
.confirm-detail dd { margin: 0; font-weight: 600; word-break: break-all; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0 .85rem; }
.form-grid .span2 { grid-column: span 2; }

.field label .req { color: var(--danger); }
.form-grid .field { margin-bottom: .75rem; }
.form-note-red { color: var(--danger); font-size: .75rem; line-height: 1.65; margin: 0 0 .25rem; grid-column: span 2; }
.phone-input { display: flex; align-items: stretch; border: 1px solid var(--border); border-radius: 8px; overflow: hidden; background: #fff; }
.phone-input .phone-prefix { padding: .55rem .65rem; background: #f8fafc; border-right: 1px solid var(--border); font-size: .875rem; color: var(--muted); flex-shrink: 0; }
.phone-input input { border: none; border-radius: 0; flex: 1; padding: .55rem .75rem; font-family: inherit; font-size: .875rem; }
.phone-input input:focus { outline: none; }
.file-upload-row { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; }
.file-upload-row .file-name { font-size: .78rem; max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.file-input-hidden { position: absolute; width: 0; height: 0; opacity: 0; pointer-events: none; }

.points-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: .5rem; margin: .85rem 0; }
.point-card { padding: .75rem; border: 2px solid var(--border); border-radius: 10px; background: #fff; cursor: pointer; text-align: center; font-family: inherit; }
.point-card.active { border-color: var(--primary); background: #eff6ff; }
.point-card strong { display: block; font-size: .9rem; }
.point-card span { font-size: .78rem; color: var(--muted); }
.calc-box { background: #f8fafc; border-radius: 10px; padding: .85rem; margin-bottom: 1rem; font-size: .85rem; line-height: 1.8; }
.pay-title { font-size: .78rem; color: var(--muted); margin-bottom: .5rem; }
.pay-methods { display: flex; flex-wrap: wrap; gap: .4rem; align-items: center; }
.pay-chip { padding: .4rem .7rem; border: 1px solid var(--border); border-radius: 8px; font-size: .75rem; cursor: pointer; background: #fff; }
.pay-chip.active { border-color: var(--primary); background: #eff6ff; color: var(--primary); }
.pay-more { font-size: .75rem; color: var(--primary); cursor: pointer; }

.menu-modal { width: min(320px,100%); }
.menu-list { display: flex; flex-direction: column; gap: .35rem; padding: .5rem 0; }
.menu-item { padding: .75rem 1.25rem; border: none; background: none; text-align: left; font-family: inherit; font-size: .875rem; cursor: pointer; }
.menu-item:hover { background: #f8fafc; }
.menu-item.danger { color: var(--danger); }
.level-opt { display: block; padding: .75rem; border: 2px solid var(--border); border-radius: 10px; margin-bottom: .5rem; cursor: pointer; font-size: .85rem; }
.level-opt.active { border-color: var(--primary); background: #eff6ff; }
.level-opt input { margin-right: .5rem; }
.warn-list { margin: .75rem 0; padding-left: 1.25rem; font-size: .82rem; color: var(--muted); line-height: 1.7; }
.term-modal { width: min(440px, 100%); }
.term-agent-bar { display: flex; justify-content: space-between; align-items: center; gap: .75rem; flex-wrap: wrap; background: #f1f5f9; border-radius: 8px; padding: .65rem .85rem; font-size: .84rem; margin-bottom: 1rem; }
.term-agent-bar strong { color: var(--text); font-weight: 600; }
.term-warn-title { font-size: .84rem; font-weight: 600; margin-bottom: .35rem; }
.term-warn-list { color: var(--danger); margin-top: 0; margin-bottom: 1rem; }
.term-warn-list li { margin-bottom: .15rem; }

.crypto-flow { display: grid; grid-template-columns: 1fr 320px; gap: 1rem; margin-bottom: 1rem; }
@media (max-width:960px) { .crypto-flow { grid-template-columns: 1fr; } }
.crypto-side .settle-panel { position: sticky; top: 1rem; }
.crypto-steps span.done { color: var(--success); font-weight: 600; }
.field-row { display: flex; flex-wrap: wrap; gap: .75rem; align-items: flex-end; margin-bottom: .85rem; }
.field-row .field { flex: 1; min-width: 140px; margin-bottom: 0; }
.field-row .field.flex-2 { flex: 2; min-width: 220px; }
.address-card { border: 1px solid var(--border); border-radius: 10px; padding: .85rem; margin-bottom: .75rem; background: #f8fafc; }
.address-card.active { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(37,99,235,.12); background: #eff6ff; }
.address-card-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: .5rem; }
.chain-chip { display: inline-block; padding: .2rem .55rem; border-radius: 999px; background: #dbeafe; color: #1d4ed8; font-size: .72rem; font-weight: 700; }
.addr-mono { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: .78rem; word-break: break-all; color: #334155; }
.addr-mono.lg { font-size: .82rem; line-height: 1.5; margin-bottom: .5rem; }
.addr-row { display: flex; gap: .5rem; align-items: center; flex-wrap: wrap; }
.btn-copy { margin-left: .35rem; vertical-align: middle; }
.btn-link { background: none; border: none; padding: 0; cursor: pointer; font: inherit; }
.btn-link.link-primary { color: var(--primary); text-decoration: underline; }
.btn-link.link-primary code { color: inherit; background: transparent; padding: 0; }
.detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .65rem 1rem;
  margin: 0;
}
.detail-grid > div { min-width: 0; }
.detail-grid dt { margin: 0 0 .15rem; font-size: .72rem; color: var(--muted); text-transform: uppercase; letter-spacing: .03em; }
.detail-grid dd { margin: 0; font-size: .875rem; font-weight: 600; word-break: break-all; }
@media (max-width: 640px) { .detail-grid { grid-template-columns: 1fr; } }
.badge-ok { background: #d1fae5; color: #047857; }
.badge-warn { background: #fef3c7; color: #b45309; }
.badge-danger { background: #fee2e2; color: #b91c1c; }
.badge-muted { background: #f1f5f9; color: #64748b; }
.crypto-received-ok { background: #ecfdf5; border-color: #a7f3d0; color: #047857; }
.crypto-countdown { margin-bottom: .85rem; padding: .65rem .85rem; border-radius: 8px; background: #fffbeb; border: 1px solid #fde68a; color: #92400e; }
.crypto-countdown.urgent { background: #fef2f2; border-color: #fecaca; color: #b91c1c; }

.toast { position: fixed; bottom: 1.25rem; right: 1.25rem; background: #0f172a; color: #fff; padding: .65rem 1rem; border-radius: 8px; font-size: .84rem; z-index: 200; }
.toast.error { background: var(--danger); }
.empty { text-align: center; padding: 2rem; color: var(--muted); }
