:root { color: #172033; background: #f5f7fb; font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; } * { box-sizing: border-box; } body { margin: 0; min-width: 320px; min-height: 100vh; } button, input { font: inherit; } .page { width: min(1180px, calc(100vw - 32px)); margin: 0 auto; padding: 28px 0 48px; } .topbar { display: flex; align-items: center; justify-content: space-between; gap: 20px; margin-bottom: 24px; } .topbarActions { display: flex; align-items: center; gap: 12px; } .eyebrow { margin: 0 0 4px; color: #667085; font-size: 13px; font-weight: 700; text-transform: uppercase; } h1, h2, p { margin: 0; } h1 { font-size: 30px; line-height: 1.2; } h2 { font-size: 18px; } h3 { margin: 0; font-size: 15px; } .health { display: inline-flex; align-items: center; gap: 8px; color: #667085; font-size: 14px; } .health span { width: 9px; height: 9px; border-radius: 50%; background: #c43f3f; } .health[data-ok="true"] span { background: #1b8a5a; } .toolbar { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 12px; align-items: end; padding: 16px; margin-bottom: 18px; border: 1px solid #dde3ee; border-radius: 8px; background: #ffffff; } .tokenField { display: grid; gap: 8px; color: #4a5568; font-size: 13px; font-weight: 700; } .tokenField input { width: 100%; min-height: 42px; padding: 0 12px; border: 1px solid #cbd5e1; border-radius: 6px; color: #172033; outline: none; } .tokenField input:focus { border-color: #2b6cb0; box-shadow: 0 0 0 3px rgba(43, 108, 176, 0.14); } button { min-height: 42px; padding: 0 18px; border: 0; border-radius: 6px; background: #214e8a; color: #ffffff; font-weight: 700; cursor: pointer; } .ghostButton { min-height: 36px; padding: 0 14px; border: 1px solid #cbd5e1; background: #ffffff; color: #2d3748; } button:disabled { cursor: not-allowed; opacity: 0.5; } .authShell { display: grid; min-height: 620px; align-items: center; } .authPanel { width: min(720px, 100%); margin: 0 auto; padding: 20px; border: 1px solid #dde3ee; border-radius: 8px; background: #ffffff; } .authHeader { margin-bottom: 16px; } .segmented { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 6px; padding: 4px; margin-bottom: 16px; border: 1px solid #d8e0ec; border-radius: 8px; background: #f8fafc; } .segmentButton { min-height: 36px; padding: 0 10px; border-radius: 6px; background: transparent; color: #4a5568; } .segmentButton[data-active="true"] { background: #214e8a; color: #ffffff; } .authForm { display: grid; gap: 12px; } .authForm.twoColumn { grid-template-columns: repeat(2, minmax(0, 1fr)); } .authForm label { display: grid; gap: 8px; color: #4a5568; font-size: 13px; font-weight: 700; } .authForm input { width: 100%; min-height: 42px; padding: 0 12px; border: 1px solid #cbd5e1; border-radius: 6px; color: #172033; outline: none; } .authForm input:focus { border-color: #2b6cb0; box-shadow: 0 0 0 3px rgba(43, 108, 176, 0.14); } .authForm button[type="submit"] { grid-column: 1 / -1; } .notice { padding: 12px 14px; margin-bottom: 18px; border: 1px solid #f0b8b8; border-radius: 8px; background: #fff1f1; color: #9b2c2c; font-size: 14px; } .moduleBand { padding: 18px; margin-bottom: 18px; border: 1px solid #dde3ee; border-radius: 8px; background: #ffffff; } .sectionHeader { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 14px; } .sectionHeader span { color: #667085; font-size: 13px; font-weight: 700; } .moduleGrid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 12px; } .moduleCard { min-height: 174px; display: flex; flex-direction: column; gap: 12px; padding: 14px; border: 1px solid #e4eaf3; border-radius: 8px; background: #fbfcff; } .moduleCardTop { display: grid; gap: 6px; } .moduleCardTop span, .moduleRow span { color: #667085; font-size: 12px; font-weight: 700; } .moduleCard p, .moduleRow p { color: #4a5568; font-size: 13px; line-height: 1.5; } .moduleTags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: auto; } .moduleTags span { padding: 4px 7px; border: 1px solid #d8e0ec; border-radius: 999px; background: #ffffff; color: #3f4f67; font-size: 12px; font-weight: 700; } .detailGrid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; } .moduleList { display: grid; gap: 10px; } .moduleRow { display: grid; gap: 8px; min-height: 112px; padding: 12px; border: 1px solid #e4eaf3; border-radius: 8px; background: #fbfcff; } .moduleRow strong { display: block; margin-bottom: 4px; color: #172033; font-size: 14px; } .metrics { display: grid; grid-template-columns: repeat(auto-fit, minmax(126px, 1fr)); gap: 12px; margin-bottom: 18px; } .metric { min-height: 96px; padding: 16px; border: 1px solid #dde3ee; border-radius: 8px; background: #ffffff; } .metric span { color: #667085; font-size: 13px; font-weight: 700; } .metric strong { display: block; margin-top: 10px; font-size: 30px; } .metric[data-tone="blue"] { border-top: 3px solid #2b6cb0; } .metric[data-tone="green"] { border-top: 3px solid #1b8a5a; } .metric[data-tone="violet"] { border-top: 3px solid #6b46c1; } .metric[data-tone="amber"] { border-top: 3px solid #b7791f; } .metric[data-tone="cyan"] { border-top: 3px solid #087f8c; } .metric[data-tone="rose"] { border-top: 3px solid #b8325f; } .split { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; } .split.secondary { margin-top: 18px; } .panel { overflow: hidden; border: 1px solid #dde3ee; border-radius: 8px; background: #ffffff; } .panelHeader { display: flex; align-items: center; justify-content: space-between; padding: 16px; border-bottom: 1px solid #e7ecf4; } .panelHeader span { color: #667085; font-size: 13px; font-weight: 700; } .table { display: grid; } .row { display: grid; grid-template-columns: 1.2fr 1.2fr 0.8fr 0.6fr; gap: 12px; min-height: 46px; align-items: center; padding: 0 16px; border-bottom: 1px solid #edf1f7; color: #2d3748; font-size: 14px; } .row span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .row.head { min-height: 38px; background: #f8fafc; color: #667085; font-size: 12px; font-weight: 800; text-transform: uppercase; } .empty { padding: 22px 16px; color: #667085; font-size: 14px; } @media (max-width: 860px) { .topbar, .toolbar, .authForm.twoColumn, .segmented { grid-template-columns: 1fr; } .topbar { align-items: flex-start; flex-direction: column; } .topbarActions { align-items: flex-start; flex-direction: column; } .metrics, .split, .moduleGrid, .detailGrid { grid-template-columns: 1fr; } .row { grid-template-columns: 1fr 0.8fr; padding: 10px 16px; } } @media (min-width: 861px) and (max-width: 1180px) { .metrics, .moduleGrid { grid-template-columns: repeat(3, minmax(0, 1fr)); } .detailGrid { grid-template-columns: 1fr; } }