/** * Admin Cliente Dashboard - Visao 360 Estrategica por Cliente * Health Score, Churn Risk, Revenue Intelligence, Netting, Behavioral Insights */ const { buildHeader, buildFooter, buildHead, getChartJsScript } = require('./ui-template'); function buildAdminClienteHTML(user) { const role = user.role || 'admin'; const pageScripts = getChartJsScript(); const now = new Date(); const today = now.toISOString().slice(0, 10); const thirtyDaysAgo = new Date(now.getTime() - 30 * 86400000).toISOString().slice(0, 10); const pageCSS = ` html { scroll-behavior: smooth; scroll-padding-top: 20px; } /* === TRADING CONSOLE === */ body.trading-console { --tc-accent: #1E8E3E; --tc-accent-bg: rgba(30,142,62,0.08); --tc-accent-border: rgba(30,142,62,0.15); --tc-glass: rgba(255,255,255,0.85); --tc-grid: rgba(0,0,0,0.06); background: var(--bg); color: var(--text); } [data-theme="dark"] body.trading-console { --bg: #0D1117; --card: #131A24; --text: #E2E8F0; --text-secondary: #94A3B8; --text-muted: #64748B; --border: rgba(0,255,136,0.1); --green: #00FF88; --green-bg: rgba(0,255,136,0.08); --blue: #58A6FF; --blue-bg: rgba(88,166,255,0.08); --orange: #F0883E; --orange-bg: rgba(240,136,62,0.08); --red: #FF4444; --red-bg: rgba(255,68,68,0.08); --purple: #BC8CFF; --purple-bg: rgba(188,140,255,0.08); --admin-accent: #00FF88; --admin-bg: rgba(0,255,136,0.05); --tc-accent: #00FF88; --tc-accent-bg: rgba(0,255,136,0.08); --tc-accent-border: rgba(0,255,136,0.15); --tc-glass: rgba(15,25,35,0.92); --tc-grid: rgba(0,255,136,0.06); background: #0A0F18 !important; color: var(--text); color-scheme: dark; } /* Cards */ body.trading-console .hero-card, body.trading-console .chart-card, body.trading-console .metric-card, body.trading-console .filter-bar, body.trading-console .profile-card, body.trading-console .intel-card { background: var(--card); border: 1px solid var(--border); box-shadow: 0 2px 8px rgba(0,0,0,0.06); } [data-theme="dark"] body.trading-console .hero-card, [data-theme="dark"] body.trading-console .chart-card, [data-theme="dark"] body.trading-console .metric-card, [data-theme="dark"] body.trading-console .filter-bar, [data-theme="dark"] body.trading-console .profile-card, [data-theme="dark"] body.trading-console .intel-card { background: rgba(255,255,255,0.03); border: 1px solid rgba(0,255,136,0.1); box-shadow: 0 2px 12px rgba(0,0,0,0.3), inset 0 1px 0 rgba(0,255,136,0.05); } body.trading-console .hero-value { font-variant-numeric: tabular-nums; } [data-theme="dark"] body.trading-console .hero-value { font-family: 'SF Mono','Fira Code','Consolas',monospace; text-shadow: 0 0 8px rgba(226,232,240,0.15); } body.trading-console .section-title { color: var(--text-secondary); letter-spacing: 1px; } body.trading-console .section-title .icon { background: var(--tc-accent-bg) !important; color: var(--tc-accent) !important; } [data-theme="dark"] body.trading-console .section-title { color: rgba(0,255,136,0.7); font-family: 'SF Mono','Fira Code','Consolas',monospace; letter-spacing: 2px; } [data-theme="dark"] body.trading-console .section-title .icon { background: rgba(0,255,136,0.08) !important; color: #00FF88 !important; } body.trading-console .data-table th { background: var(--bg); color: var(--text-muted); } [data-theme="dark"] body.trading-console .data-table th { background: rgba(0,255,136,0.03); color: rgba(0,255,136,0.6); font-family: 'SF Mono','Fira Code','Consolas',monospace; } [data-theme="dark"] body.trading-console .data-table td { font-family: 'SF Mono','Fira Code','Consolas',monospace; font-size: 12px; border-bottom-color: rgba(0,255,136,0.06); } [data-theme="dark"] body.trading-console .data-table tr:hover td { background: rgba(0,255,136,0.05); } [data-theme="dark"] body.trading-console .preset-btn { background: rgba(255,255,255,0.03); color: var(--text-secondary); border-color: rgba(0,255,136,0.1); } [data-theme="dark"] body.trading-console .preset-btn:hover { border-color: #00FF88; color: #00FF88; } [data-theme="dark"] body.trading-console .preset-btn.active { background: rgba(0,255,136,0.15); color: #00FF88; border-color: rgba(0,255,136,0.3); } [data-theme="dark"] body.trading-console .gran-btn { background: rgba(255,255,255,0.03); color: var(--text-secondary); border-color: rgba(0,255,136,0.1); } [data-theme="dark"] body.trading-console .gran-btn:hover { border-color: #F9A825; color: #F9A825; } [data-theme="dark"] body.trading-console .gran-btn.active { background: rgba(249,168,37,0.15); color: #F9A825; border-color: rgba(249,168,37,0.3); } [data-theme="dark"] body.trading-console .date-inputs input[type="date"] { background: rgba(255,255,255,0.03); color: var(--text); border-color: rgba(0,255,136,0.1); } [data-theme="dark"] body.trading-console .app-footer { background: #0A0F18; border-top-color: rgba(0,255,136,0.1); color: var(--text-muted); } [data-theme="dark"] body.trading-console ::-webkit-scrollbar { width: 6px; height: 6px; } [data-theme="dark"] body.trading-console ::-webkit-scrollbar-track { background: rgba(0,0,0,0.2); } [data-theme="dark"] body.trading-console ::-webkit-scrollbar-thumb { background: rgba(0,255,136,0.2); border-radius: 3px; } /* === Console Nav === */ .console-nav { position: fixed; right: 0; top: 50%; transform: translateY(-50%); z-index: 1000; display: flex; flex-direction: column; } .console-nav-btn { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px; width: 38px; padding: 14px 0; background: var(--card); border: 1px solid var(--border); border-right: none; border-radius: 8px 0 0 8px; margin-bottom: -1px; color: var(--text-muted); font-size: 11px; font-weight: 600; cursor: pointer; transition: all 0.2s; text-decoration: none; box-shadow: -2px 0 6px rgba(0,0,0,0.04); } .console-nav-btn:hover { color: var(--text); background: var(--bg); width: 42px; } .console-nav-btn.active { color: var(--tc-accent); background: var(--bg); width: 44px; border-color: var(--tc-accent); border-right: 1px solid var(--bg); z-index: 2; } [data-theme="dark"] .console-nav-btn { background: #161B22; border-color: rgba(0,255,136,0.1); color: rgba(255,255,255,0.35); } [data-theme="dark"] .console-nav-btn:hover { background: #1A2332; color: rgba(255,255,255,0.7); } [data-theme="dark"] .console-nav-btn.active { background: #0D1117; color: #00FF88; border-color: rgba(0,255,136,0.3); border-right-color: #0D1117; text-shadow: 0 0 8px rgba(0,255,136,0.4); } .console-nav-btn .nav-icon { font-size: 15px; line-height: 1; } .console-nav-btn .nav-label { writing-mode: vertical-rl; text-orientation: mixed; font-size: 9px; letter-spacing: 1px; text-transform: uppercase; font-weight: 700; white-space: nowrap; } [data-theme="dark"] .console-nav-btn .nav-label { font-family: 'SF Mono','Fira Code','Consolas',monospace; } @media (min-width: 769px) { body.trading-console .app-container { padding-right: 50px; } } @media (max-width: 768px) { .console-nav-btn .nav-label { display: none; } .console-nav-btn { width: 36px; padding: 12px 0; } } @media (max-width: 480px) { .console-nav-btn { width: 30px; padding: 10px 0; } .console-nav-btn .nav-icon { font-size: 13px; } } /* === Client Search === */ .client-search-wrap { position: relative; max-width: 600px; margin: 0 auto 24px; } .client-search-input { width: 100%; padding: 14px 20px; border: 2px solid var(--border); border-radius: 12px; font-size: 15px; font-family: inherit; background: var(--card); color: var(--text); transition: border-color 0.2s; outline: none; } .client-search-input:focus { border-color: var(--tc-accent); } .client-search-input::placeholder { color: var(--text-muted); } [data-theme="dark"] .client-search-input { background: rgba(255,255,255,0.03); border-color: rgba(0,255,136,0.15); } [data-theme="dark"] .client-search-input:focus { border-color: #00FF88; } .client-dropdown { position: absolute; top: 100%; left: 0; right: 0; z-index: 100; background: var(--card); border: 1px solid var(--border); border-radius: 12px; box-shadow: 0 8px 32px rgba(0,0,0,0.15); max-height: 360px; overflow-y: auto; display: none; margin-top: 4px; } .client-dropdown.open { display: block; } [data-theme="dark"] .client-dropdown { background: #161B22; border-color: rgba(0,255,136,0.15); } .client-dropdown-item { padding: 12px 20px; cursor: pointer; font-size: 14px; color: var(--text); border-bottom: 1px solid var(--border); transition: background 0.1s; } .client-dropdown-item:last-child { border-bottom: none; } .client-dropdown-item:hover { background: var(--bg); } [data-theme="dark"] .client-dropdown-item:hover { background: rgba(0,255,136,0.05); } .client-dropdown-item .item-id { font-size: 11px; color: var(--text-muted); margin-left: 8px; } .client-selected-badge { display: none; align-items: center; gap: 12px; padding: 12px 20px; background: var(--tc-accent-bg); border: 1px solid var(--tc-accent-border); border-radius: 12px; font-size: 15px; font-weight: 600; color: var(--text); max-width: 600px; margin: 0 auto 24px; } .client-selected-badge.visible { display: flex; } .client-selected-badge .badge-name { flex: 1; } .client-selected-badge .badge-clear { background: none; border: 1px solid var(--border); border-radius: 8px; padding: 6px 14px; font-size: 12px; font-weight: 600; cursor: pointer; color: var(--text-secondary); font-family: inherit; } .client-selected-badge .badge-clear:hover { border-color: var(--red); color: var(--red); } /* Empty State */ .empty-state { text-align: center; padding: 40px 20px 20px; color: var(--text-muted); } .empty-state .empty-icon { font-size: 48px; margin-bottom: 12px; opacity: 0.3; } .empty-state h2 { font-size: 20px; font-weight: 700; margin-bottom: 6px; color: var(--text-secondary); } .empty-state p { font-size: 14px; margin-bottom: 0; } /* Top Clients Grid */ .top-clients-section { max-width: 1200px; margin: 0 auto; padding: 0 16px; } .top-clients-tier { margin-bottom: 20px; } .tier-header { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; padding: 0 4px; } .tier-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; } .tier-dot.tier-high { background: var(--green, #1E8E3E); } .tier-dot.tier-mid { background: var(--blue, #58A6FF); } .tier-dot.tier-low { background: var(--orange, #F0883E); } .tier-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted); } .tier-count { font-size: 11px; color: var(--text-muted); margin-left: auto; } .top-clients-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 10px; } .top-client-card { padding: 14px 16px; border-radius: 10px; cursor: pointer; transition: all 0.15s; background: var(--card); border: 1px solid var(--border); position: relative; overflow: hidden; } .top-client-card:hover { border-color: var(--tc-accent); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(0,0,0,0.1); } [data-theme="dark"] .top-client-card { background: rgba(255,255,255,0.02); } [data-theme="dark"] .top-client-card:hover { background: rgba(0,255,136,0.04); border-color: #00FF88; box-shadow: 0 4px 16px rgba(0,255,136,0.08); } .top-client-card .tc-rank { position: absolute; top: 8px; right: 10px; font-size: 10px; font-weight: 800; color: var(--text-muted); opacity: 0.5; } .top-client-card .tc-name { font-size: 13px; font-weight: 700; color: var(--text); margin-bottom: 6px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; padding-right: 24px; } .top-client-card .tc-stats { display: flex; gap: 12px; font-size: 11px; color: var(--text-secondary); } .top-client-card .tc-stats span { display: flex; align-items: center; gap: 3px; } .top-client-card .tc-vol { font-weight: 700; color: var(--tc-accent); } [data-theme="dark"] .top-client-card .tc-name { font-family: 'SF Mono','Fira Code','Consolas',monospace; } @media (max-width: 480px) { .top-clients-grid { grid-template-columns: 1fr 1fr; gap: 8px; } .top-client-card { padding: 10px 12px; } } /* === Profile Card === */ .profile-card { border-radius: 16px; padding: 24px; margin-bottom: 24px; display: flex; align-items: center; gap: 24px; flex-wrap: wrap; } .profile-left { display: flex; align-items: center; gap: 16px; min-width: 200px; } .profile-avatar { width: 56px; height: 56px; border-radius: 50%; background: var(--tc-accent-bg); color: var(--tc-accent); display: flex; align-items: center; justify-content: center; font-size: 20px; font-weight: 800; flex-shrink: 0; } .profile-name { font-size: 20px; font-weight: 800; color: var(--text); } .profile-id { font-size: 12px; color: var(--text-muted); } .profile-stats { display: flex; gap: 20px; flex-wrap: wrap; flex: 1; } .profile-stat { text-align: center; min-width: 70px; } .profile-stat-label { font-size: 10px; font-weight: 700; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.5px; } .profile-stat-value { font-size: 15px; font-weight: 800; color: var(--text); font-variant-numeric: tabular-nums; } [data-theme="dark"] .profile-stat-value { font-family: 'SF Mono','Fira Code','Consolas',monospace; } /* Health Score in Profile */ .health-score-box { display: flex; flex-direction: column; align-items: center; gap: 4px; min-width: 90px; padding: 12px 16px; border-radius: 12px; border: 2px solid var(--border); } .health-score-box.score-green { border-color: var(--green); background: var(--green-bg); } .health-score-box.score-blue { border-color: var(--blue); background: var(--blue-bg); } .health-score-box.score-orange { border-color: var(--orange); background: var(--orange-bg); } .health-score-box.score-red { border-color: var(--red); background: var(--red-bg); } .health-score-number { font-size: 28px; font-weight: 800; font-variant-numeric: tabular-nums; line-height: 1; } .health-score-number.green { color: var(--green); } .health-score-number.blue { color: var(--blue); } .health-score-number.orange { color: var(--orange); } .health-score-number.red { color: var(--red); } .health-score-label { font-size: 9px; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; color: var(--text-muted); } [data-theme="dark"] .health-score-number { font-family: 'SF Mono','Fira Code','Consolas',monospace; text-shadow: 0 0 12px currentColor; } /* === Filter Bar === */ .filter-bar { background: var(--card); border-radius: 16px; padding: 20px 24px; border: 1px solid var(--border); margin-bottom: 24px; display: flex; align-items: center; gap: 16px; flex-wrap: wrap; } .filter-bar-label { font-size: 13px; font-weight: 600; color: var(--text-secondary); } .filter-presets { display: flex; gap: 8px; } .preset-btn { padding: 8px 16px; border: 1px solid var(--border); border-radius: 8px; background: var(--bg); font-size: 13px; font-weight: 600; cursor: pointer; color: var(--text-secondary); transition: all 0.15s; font-family: inherit; } .preset-btn:hover { border-color: var(--admin-accent); color: var(--admin-accent); } .preset-btn.active { background: var(--admin-accent); color: white; border-color: var(--admin-accent); } .filter-divider { width: 1px; height: 32px; background: var(--border); } .date-inputs { display: flex; align-items: center; gap: 8px; } .date-inputs label { font-size: 12px; font-weight: 600; color: var(--text-muted); } .date-inputs input[type="date"] { padding: 8px 12px; border: 1px solid var(--border); border-radius: 8px; font-size: 13px; font-family: inherit; background: var(--bg); color: var(--text); } .period-info { margin-left: auto; font-size: 12px; color: var(--text-muted); font-weight: 500; background: var(--bg); padding: 6px 12px; border-radius: 6px; } .export-btn { background: var(--green); color: white; border: none; padding: 8px 16px; border-radius: 6px; font-size: 12px; font-weight: 600; cursor: pointer; white-space: nowrap; transition: all 0.15s; } .export-btn:hover { opacity: 0.85; transform: translateY(-1px); } [data-theme="dark"] .export-btn { background: rgba(0,255,136,0.15); color: #00FF88; border: 1px solid rgba(0,255,136,0.3); } /* === Hero KPIs === */ .hero-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 14px; margin-bottom: 28px; } .hero-card { background: var(--card); border-radius: 16px; padding: 18px 16px; border: 1px solid var(--border); position: relative; overflow: hidden; min-width: 0; } .hero-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; } .hero-card.volume::before { background: linear-gradient(90deg, var(--blue), #42A5F5); } .hero-card.transactions::before { background: linear-gradient(90deg, var(--purple), #AB47BC); } .hero-card.spread::before { background: linear-gradient(90deg, var(--green), #4CAF50); } .hero-card.ticket::before { background: linear-gradient(90deg, #00897B, #26A69A); } .hero-card.arpa::before { background: linear-gradient(90deg, #F9A825, #FFD54F); } .hero-card.avgspread::before { background: linear-gradient(90deg, var(--orange), #FFA726); } .hero-label { font-size: 10px; font-weight: 700; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 6px; } .hero-value { font-size: clamp(13px, 1.4vw, 24px); font-weight: 800; color: var(--text); margin-bottom: 4px; font-variant-numeric: tabular-nums; word-break: break-word; min-width: 0; line-height: 1.2; } .hero-badge { display: inline-block; font-size: 10px; font-weight: 700; padding: 2px 8px; border-radius: 12px; } .hero-badge.up { background: var(--green-bg); color: var(--green); } .hero-badge.down { background: var(--red-bg); color: var(--red); } .hero-badge.neutral { background: var(--blue-bg); color: var(--blue); } .hero-sub { font-size: 11px; color: var(--text-muted); margin-top: 4px; } /* === Sections === */ .section-title { font-size: 14px; font-weight: 700; color: var(--text-secondary); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 16px; display: flex; align-items: center; gap: 8px; } .section-title .icon { width: 28px; height: 28px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 14px; } /* Charts */ .charts-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 28px; } .charts-row.triple { grid-template-columns: 1fr 1fr 1fr; } .charts-row.wide-left { grid-template-columns: 2fr 1fr; } .chart-card { background: var(--card); border-radius: 16px; padding: 24px; border: 1px solid var(--border); } .chart-card h3 { font-size: 14px; font-weight: 700; color: var(--text); margin-bottom: 16px; display: flex; align-items: center; gap: 8px; } .chart-card h3 .badge { font-size: 10px; padding: 3px 8px; border-radius: 10px; font-weight: 700; background: var(--bg); color: var(--text-muted); } .chart-wrap { position: relative; height: 280px; } .chart-wrap.short { height: 220px; } .gran-selector { display: flex; align-items: center; gap: 6px; } .gran-btn { padding: 6px 14px; border: 1px solid var(--border); border-radius: 8px; background: var(--bg); font-size: 12px; font-weight: 600; cursor: pointer; color: var(--text-secondary); transition: all 0.15s; font-family: inherit; } .gran-btn:hover { border-color: #F9A825; color: #F9A825; } .gran-btn.active { background: #F9A825; color: white; border-color: #F9A825; } /* === Intel Cards (Health/Risk/Netting) === */ .intel-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 20px; margin-bottom: 28px; } .intel-card { border-radius: 16px; padding: 24px; } .intel-card h3 { font-size: 13px; font-weight: 700; color: var(--text); margin-bottom: 16px; display: flex; align-items: center; gap: 8px; } /* Health Breakdown */ .health-gauge-wrap { display: flex; align-items: center; gap: 24px; } .health-gauge { position: relative; width: 140px; height: 140px; flex-shrink: 0; } .health-gauge svg { width: 100%; height: 100%; transform: rotate(-90deg); } .health-gauge-bg { fill: none; stroke: var(--border); stroke-width: 10; } .health-gauge-fill { fill: none; stroke-width: 10; stroke-linecap: round; transition: stroke-dashoffset 0.8s ease; } .health-gauge-center { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; } .health-gauge-score { font-size: 36px; font-weight: 800; line-height: 1; } .health-gauge-label { font-size: 10px; font-weight: 700; text-transform: uppercase; color: var(--text-muted); margin-top: 2px; } [data-theme="dark"] .health-gauge-score { font-family: 'SF Mono','Fira Code','Consolas',monospace; text-shadow: 0 0 16px currentColor; } .health-breakdown { flex: 1; display: flex; flex-direction: column; gap: 8px; } .health-row { display: flex; justify-content: space-between; align-items: center; } .health-row-label { font-size: 12px; color: var(--text-secondary); } .health-row-bar { width: 80px; height: 6px; border-radius: 3px; background: var(--bg); overflow: hidden; } .health-row-fill { height: 100%; border-radius: 3px; transition: width 0.6s; } .health-row-val { font-size: 12px; font-weight: 700; min-width: 30px; text-align: right; } /* Risk Indicators */ .risk-level-badge { display: inline-block; padding: 4px 14px; border-radius: 8px; font-size: 12px; font-weight: 800; letter-spacing: 1px; } .risk-level-badge.baixo { background: var(--green-bg); color: var(--green); } .risk-level-badge.medio { background: var(--blue-bg); color: var(--blue); } .risk-level-badge.alto { background: var(--orange-bg); color: var(--orange); } .risk-level-badge.critico { background: var(--red-bg); color: var(--red); } .risk-row { display: flex; justify-content: space-between; align-items: center; padding: 10px 0; border-bottom: 1px solid var(--border); } .risk-row:last-child { border-bottom: none; } .risk-row-label { font-size: 12px; color: var(--text-secondary); } .risk-row-value { font-size: 14px; font-weight: 700; font-variant-numeric: tabular-nums; } .risk-row-value.positive { color: var(--green); } .risk-row-value.negative { color: var(--red); } .risk-row-value.neutral { color: var(--text-muted); } /* Netting */ .netting-row { display: flex; justify-content: space-between; align-items: center; padding: 10px 0; border-bottom: 1px solid var(--border); } .netting-row:last-child { border-bottom: none; } .netting-label { font-size: 13px; color: var(--text-secondary); font-weight: 600; } .netting-value { font-size: 15px; font-weight: 700; font-variant-numeric: tabular-nums; } .netting-value.green { color: var(--green); } .netting-value.red { color: var(--red); } .netting-value.blue { color: var(--blue); } .gauge-bar { height: 8px; border-radius: 4px; background: var(--bg); overflow: hidden; margin: 8px 0; } .gauge-bar-fill { height: 100%; border-radius: 4px; transition: width 0.6s; } .gauge-bar-fill.green { background: linear-gradient(90deg, var(--green), #4CAF50); } .gauge-bar-fill.blue { background: linear-gradient(90deg, var(--blue), #42A5F5); } /* === Data Table === */ .data-table { width: 100%; border-collapse: collapse; font-size: 13px; } .data-table th { text-align: left; padding: 10px 12px; font-weight: 700; font-size: 11px; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-muted); border-bottom: 2px solid var(--border); cursor: pointer; user-select: none; white-space: nowrap; } .data-table th:hover { color: var(--tc-accent); } .data-table th .sort-arrow { font-size: 10px; margin-left: 4px; opacity: 0.4; } .data-table th.sorted .sort-arrow { opacity: 1; color: var(--tc-accent); } .data-table td { padding: 10px 12px; border-bottom: 1px solid var(--border); color: var(--text); font-variant-numeric: tabular-nums; } .data-table tr:last-child td { border-bottom: none; } .data-table tr:hover td { background: var(--bg); } .data-table tfoot td { font-weight: 700; border-top: 2px solid var(--border); background: var(--bg); } .flow-tag { display: inline-block; padding: 2px 8px; border-radius: 6px; font-size: 11px; font-weight: 700; } .flow-tag.brl-usd { background: var(--blue-bg); color: var(--blue); } .flow-tag.usd-brl { background: var(--green-bg); color: var(--green); } /* Pagination */ .table-controls { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 12px 0; flex-wrap: wrap; } .table-controls select { padding: 6px 10px; border: 1px solid var(--border); border-radius: 6px; font-size: 12px; font-family: inherit; background: var(--bg); color: var(--text); } .pagination { display: flex; align-items: center; gap: 4px; } .page-btn { padding: 6px 12px; border: 1px solid var(--border); border-radius: 6px; background: var(--bg); font-size: 12px; font-weight: 600; cursor: pointer; color: var(--text-secondary); font-family: inherit; } .page-btn:hover { border-color: var(--tc-accent); color: var(--tc-accent); } .page-btn.active { background: var(--tc-accent); color: white; border-color: var(--tc-accent); } .page-btn:disabled { opacity: 0.4; cursor: default; } .page-info { font-size: 12px; color: var(--text-muted); } .btn-export { padding: 8px 16px; border: 1px solid var(--border); border-radius: 8px; background: var(--bg); font-size: 12px; font-weight: 600; cursor: pointer; color: var(--text-secondary); font-family: inherit; } .btn-export:hover { border-color: var(--tc-accent); color: var(--tc-accent); } /* Misc */ .loading-overlay { position: absolute; inset: 0; background: rgba(255,255,255,0.8); display: flex; align-items: center; justify-content: center; border-radius: 16px; z-index: 10; font-size: 13px; color: var(--text-muted); } [data-theme="dark"] .loading-overlay { background: rgba(13,17,23,0.85); } .content-area { display: none; } .content-area.visible { display: block; } [data-theme="dark"] .preset-btn { background: var(--card); color: var(--text-secondary); border-color: var(--border); } [data-theme="dark"] .preset-btn:hover { border-color: var(--admin-accent); color: var(--green); } [data-theme="dark"] .date-inputs input[type="date"] { background: var(--card); color: var(--text); border-color: var(--border); } [data-theme="dark"] .data-table tr:hover td { background: rgba(255,255,255,0.03); } /* === Skeleton Loading Shimmer === */ @keyframes shimmer { 0% { background-position: -400px 0; } 100% { background-position: 400px 0; } } .skel { background: linear-gradient(90deg, var(--card-bg,var(--card)) 25%, var(--border) 50%, var(--card-bg,var(--card)) 75%); background-size: 800px 100%; animation: shimmer 1.5s infinite ease-in-out; border-radius: 6px; display: inline-block; } .skel-value { height: 32px; width: 55%; } .skel-badge { height: 18px; width: 70px; } .skel-text { height: 14px; width: 80%; margin: 4px 0; } .skel-chart { height: 100%; width: 100%; min-height: 180px; border-radius: 12px; position: absolute; top: 0; left: 0; z-index: 2; } .skel-row { height: 32px; margin: 6px 0; width: 100%; } .skel-gauge { height: 40px; width: 90px; } .skel-avatar { width: 56px; height: 56px; border-radius: 50%; } .skel-name { height: 22px; width: 160px; } .skel-stat { height: 18px; width: 70px; } /* === Merchant / Checkout === */ .merchant-badge { display: none; padding: 4px 12px; border-radius: 8px; font-size: 11px; font-weight: 800; letter-spacing: 0.5px; background: var(--purple-bg); color: var(--purple, #7B1FA2); text-transform: uppercase; margin-top: 4px; } .merchant-badge.visible { display: inline-block; } .hero-card.checkout::before { background: linear-gradient(90deg, var(--purple, #7B1FA2), #AB47BC); } .checkout-section { display: none; } .checkout-section.visible { display: block; } .flow-tag.checkout { background: var(--purple-bg); color: var(--purple, #7B1FA2); } .top-payer-row { display: flex; align-items: center; padding: 10px 0; border-bottom: 1px solid var(--border); cursor: pointer; transition: background 0.1s; } .top-payer-row:last-child { border-bottom: none; } .top-payer-row:hover { background: var(--bg); } [data-theme="dark"] .top-payer-row:hover { background: rgba(0,255,136,0.04); } .top-payer-rank { width: 28px; font-size: 11px; font-weight: 800; color: var(--text-muted); text-align: center; } .top-payer-info { flex: 1; min-width: 0; } .top-payer-name { font-size: 13px; font-weight: 700; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .top-payer-stats { font-size: 11px; color: var(--text-muted); } .top-payer-vol { font-size: 14px; font-weight: 700; color: var(--purple, #7B1FA2); font-variant-numeric: tabular-nums; } [data-theme="dark"] .top-payer-vol { color: #BC8CFF; } [data-theme="dark"] .top-payer-name { font-family: 'SF Mono','Fira Code','Consolas',monospace; } /* === Responsive === */ @media (max-width: 1200px) { .hero-grid { grid-template-columns: repeat(3, 1fr); } .intel-grid { grid-template-columns: 1fr 1fr; } } @media (max-width: 900px) { .charts-row, .charts-row.wide-left { grid-template-columns: 1fr; } .charts-row.triple { grid-template-columns: 1fr 1fr; } .charts-row.triple > :last-child { grid-column: span 2; } .intel-grid { grid-template-columns: 1fr; } .filter-divider { display: none; } .profile-card { flex-direction: column; text-align: center; } .profile-left { flex-direction: column; } .profile-stats { justify-content: center; } .health-gauge-wrap { flex-direction: column; align-items: center; } } @media (max-width: 768px) { .filter-bar { padding: 14px 16px; gap: 10px; flex-direction: column; align-items: stretch; } .filter-bar-label { text-align: center; } .filter-presets { flex-wrap: wrap; justify-content: center; } .preset-btn { padding: 10px 14px; min-height: 44px; flex: 1; min-width: 55px; text-align: center; } .date-inputs { flex-wrap: wrap; justify-content: center; } .date-inputs input[type="date"] { flex: 1; min-width: 130px; min-height: 44px; } .period-info { margin-left: 0; width: 100%; text-align: center; } .hero-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; } .hero-card { padding: 14px; } .hero-value { font-size: 20px; } .charts-row, .charts-row.triple { grid-template-columns: 1fr; } .charts-row.triple > :last-child { grid-column: span 1; } .chart-card { padding: 18px; } .chart-wrap { height: 250px; } .section-title { font-size: 13px; } .table-controls { flex-direction: column; align-items: stretch; } .data-table { font-size: 12px; } .data-table th { padding: 10px 8px; font-size: 10px; } .data-table td { padding: 10px 8px; white-space: nowrap; } } @media (max-width: 480px) { .hero-grid { grid-template-columns: 1fr; } .chart-card { padding: 14px; } .chart-wrap { height: 200px; } .chart-wrap.short { height: 160px; } .data-table { font-size: 11px; } .data-table th { padding: 8px 6px; font-size: 9px; } .data-table td { padding: 8px 6px; } .intel-card { padding: 16px; } .health-gauge { width: 110px; height: 110px; } .health-gauge-score { font-size: 28px; } } `; return `
${buildHead('Clientes 360', pageCSS, pageScripts)} ${buildHeader({ role: role, userName: user.nome, activePage: 'cliente', permissions: user.permissions || [] })}Busque acima ou clique em um dos top clientes abaixo
| Data ▲ | Fluxo ▲ | USD ▲ | BRL ▲ | Taxa ▲ | PTAX ▲ | Spread% ▲ | IOF ▲ | Status ▲ | Provider ▲ |
|---|---|---|---|---|---|---|---|---|---|