/* === Gemma-4-E2B Brain Atlas === */ /* Aesthetic: bright pastels on warm cream paper. Dawn-light, not dark. */ :root { /* — Surfaces — */ --bg: #efe9de; /* warm sage-cream paper */ --bg-2: #f6f1e6; /* a notch up — main card surface */ --bg-3: #fbf6ea; /* lifted card / well */ --bg-4: #ffffff; --bg-tint-rose: #f6e7e2; --bg-tint-sage: #e6efe2; --bg-tint-lavender: #ece6f1; --bg-tint-amber: #f6ecd6; --hairline: rgba(74, 58, 68, 0.13); --hairline-2: rgba(74, 58, 68, 0.22); /* — Ink (warm dark, not black) — */ --ink: #3a2a30; --ink-2: #5b454c; --ink-3: #84686c; --ink-dim: #a89090; /* — Pastels — brighter than v1 — */ --lavender: #c9b8e6; --lavender-2: #9a87cf; --rose: #ecb5be; --rose-2: #cf8d96; --sage: #aacca0; --sage-2: #7da272; --coral: #f5b9a3; --coral-2: #d97f64; --cream: #f4d99e; --gold: #f0c98a; --mint: #c4e3d2; --periwinkle: #b8c7e6; /* — Heat ramp (used in plot + bars + chips) — */ --heat-0: #ece6f1; /* pale lavender wash */ --heat-1: #d8c4dc; --heat-2: #c9a8c2; --heat-3: #d8a3b2; --heat-4: #e8aea0; --heat-5: #f0c890; --heat-6: #f4dfa0; --shadow-soft: 0 1px 0 rgba(255,255,255,0.7) inset, 0 2px 6px rgba(74,58,68,0.06); --shadow-warm: 0 8px 24px -10px rgba(74,58,68,0.15), 0 1px 0 rgba(255,255,255,0.8) inset; --shadow-lift: 0 16px 40px -16px rgba(74,58,68,0.22), 0 1px 0 rgba(255,255,255,0.9) inset; --radius-sm: 8px; --radius: 14px; --radius-lg: 20px; --radius-xl: 28px; --serif: 'Fraunces', 'Cormorant Garamond', Georgia, serif; --sans: 'Inter Tight', 'Inter', -apple-system, BlinkMacSystemFont, sans-serif; --mono: 'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace; } * { box-sizing: border-box; } html, body { margin: 0; padding: 0; } body { font-family: var(--sans); background: var(--bg); color: var(--ink); font-feature-settings: 'ss01', 'cv02', 'cv11'; -webkit-font-smoothing: antialiased; min-height: 100vh; } /* Soft watercolor glow on the page — warm dawn light */ .atlas-root { min-height: 100vh; background: radial-gradient(1200px 800px at 8% -10%, rgba(201,184,230,0.32), transparent 60%), radial-gradient(900px 700px at 100% 8%, rgba(245,185,163,0.26), transparent 60%), radial-gradient(1000px 700px at 50% 110%, rgba(170,204,160,0.28), transparent 60%), var(--bg); } .mono { font-family: var(--mono); font-variant-ligatures: none; } .muted { color: var(--ink-3); } .dim { color: var(--ink-3); } .strong { color: var(--ink); font-weight: 600; } .a-right { text-align: right; } .w-9 { width: 2.25rem; display: inline-block; } .w-12 { width: 3rem; display: inline-block; } .dot { color: var(--ink-dim); margin: 0 .4em; } /* === Page chrome === */ .shell { max-width: 1480px; margin: 0 auto; padding: 28px 36px 96px; } .topbar { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 14px 22px; border-radius: var(--radius-lg); background: linear-gradient(180deg, rgba(255,255,255,0.6), rgba(255,255,255,0.3)); border: 1px solid var(--hairline); box-shadow: var(--shadow-soft); margin-bottom: 24px; backdrop-filter: blur(4px); position: relative; z-index: 100; } .brand { display: flex; align-items: center; gap: 14px; } .brand-mark { width: 44px; height: 44px; border-radius: 14px; background: radial-gradient(circle at 30% 30%, #fff 0%, var(--rose) 30%, var(--lavender) 60%, var(--sage) 100%); box-shadow: 0 0 0 1px rgba(74,58,68,0.10), inset 0 0 12px rgba(255,255,255,0.6), 0 6px 18px rgba(201,184,230,0.40); position: relative; } .brand-mark::after { content: ''; position: absolute; inset: 0; border-radius: 14px; background: radial-gradient(circle at 70% 70%, rgba(255,255,255,0.45), transparent 50%); } .brand-text { display: flex; flex-direction: column; gap: 2px; } .brand-name { font-family: var(--serif); font-weight: 500; font-size: 22px; letter-spacing: -0.01em; line-height: 1; color: var(--ink); } .brand-name em { font-style: italic; color: var(--lavender-2); font-weight: 400; } .brand-sub { font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-3); } .topbar-meta { display: flex; align-items: center; gap: 22px; font-size: 12px; color: var(--ink-2); } .topbar-meta .k { color: var(--ink-3); margin-right: 6px; } .topbar-meta .v { color: var(--ink); font-family: var(--mono); } .credit { font-size: 11px; color: var(--ink-3); } .credit b { color: var(--ink); font-weight: 500; } /* === Hero band === */ .hero-band { display: grid; grid-template-columns: 1fr 360px; gap: 22px; margin-bottom: 22px; } .hero-copy { display: flex; flex-direction: column; gap: 14px; padding: 28px 30px 30px; background: linear-gradient(160deg, rgba(255,255,255,0.55), rgba(255,255,255,0.25)), linear-gradient(160deg, var(--bg-tint-lavender), var(--bg-tint-sage)); border: 1px solid var(--hairline); border-radius: var(--radius-lg); box-shadow: var(--shadow-warm); position: relative; overflow: hidden; } .hero-copy::before { content: ''; position: absolute; top: -100px; right: -100px; width: 260px; height: 260px; border-radius: 50%; background: radial-gradient(circle, rgba(244,217,158,0.45), transparent 70%); pointer-events: none; } .hero-eyebrow { font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--lavender-2); font-weight: 500; } .hero-title { font-family: var(--serif); font-weight: 400; font-size: 40px; line-height: 1.05; letter-spacing: -0.015em; margin: 0; text-wrap: pretty; color: var(--ink); max-width: 22ch; } .hero-title em { font-style: italic; color: var(--rose-2); } .hero-lede { font-size: 14.5px; line-height: 1.55; color: var(--ink-2); max-width: 60ch; } .hero-lede b { color: var(--ink); font-weight: 600; } .hero-stats { display: flex; gap: 28px; margin-top: 6px; flex-wrap: wrap; } .hero-stat { display: flex; flex-direction: column; gap: 4px; } .hero-stat .n { font-family: var(--serif); font-size: 24px; font-weight: 500; color: var(--ink); letter-spacing: -0.01em; } .hero-stat .l { font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-3); } .ingest-card { padding: 22px; background: linear-gradient(160deg, rgba(255,255,255,0.7), rgba(255,255,255,0.4)), linear-gradient(160deg, var(--bg-tint-rose), var(--bg-tint-amber)); border: 1px solid var(--hairline); border-radius: var(--radius-lg); box-shadow: var(--shadow-soft); display: flex; flex-direction: column; gap: 14px; } .ingest-card .bf-eyebrow { color: var(--coral-2); } .ingest-row { display: flex; justify-content: space-between; align-items: baseline; font-size: 12.5px; color: var(--ink-2); } .ingest-row .k { color: var(--ink-3); } .ingest-row .v { font-family: var(--mono); color: var(--ink); } .ingest-progress { height: 6px; border-radius: 999px; background: rgba(74,58,68,0.08); overflow: hidden; position: relative; } .ingest-progress > span { position: absolute; inset: 0 auto 0 0; background: linear-gradient(90deg, var(--rose), var(--coral), var(--gold)); border-radius: 999px; width: 50%; box-shadow: 0 0 12px rgba(245,185,163,0.5); } .ingest-note { font-size: 11.5px; color: var(--ink-3); line-height: 1.5; } /* === Section card === */ .card { background: linear-gradient(180deg, var(--bg-3), var(--bg-2)); border: 1px solid var(--hairline); border-radius: var(--radius-lg); box-shadow: var(--shadow-soft); padding: 22px 24px; } /* === Section headings shared === */ .bf-eyebrow { font-size: 10.5px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--lavender-2); font-weight: 600; } .bf-sub { font-family: var(--serif); font-style: italic; font-size: 16px; color: var(--ink-2); margin-top: 4px; } /* === Main grid: heatmap (hero) + side panel === */ .main-grid { display: grid; grid-template-columns: minmax(0, 1fr) 380px; gap: 22px; margin-bottom: 22px; } .hm-card { padding: 22px 24px 16px; display: flex; flex-direction: column; min-height: 720px; } .hm-head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 14px; } .hm-legend { display: flex; align-items: center; gap: 10px; font-size: 11px; color: var(--ink-3); } .hm-legend-bar { width: 160px; height: 8px; border-radius: 4px; background: linear-gradient(90deg, var(--heat-0) 0%, var(--heat-1) 18%, var(--heat-2) 36%, var(--heat-3) 56%, var(--heat-4) 74%, var(--heat-5) 88%, var(--heat-6) 100%); box-shadow: inset 0 0 0 1px var(--hairline); } /* === Heatmap component === */ .atlas-heatmap-shell { position: relative; flex: 1; min-height: 600px; } .atlas-heatmap-plot { width: 100%; height: 100%; } .atlas-heatmap-marker { position: absolute; width: 28px; height: 16px; transform: translate(-50%, -50%); border: 1.5px solid var(--ink); border-radius: 4px; box-shadow: 0 0 0 2px rgba(255,255,255,0.85), 0 0 18px rgba(201,184,230,0.6); pointer-events: none; animation: cell-pulse 1.6s ease-in-out infinite; } @keyframes cell-pulse { 0%, 100% { transform: translate(-50%, -50%) scale(1); } 50% { transform: translate(-50%, -50%) scale(1.06); } } .atlas-heatmap-readout { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--ink-2); padding: 10px 6px 0; border-top: 1px dashed var(--hairline); margin-top: 8px; } .atlas-heatmap-readout b { color: var(--ink); font-weight: 600; } .hm-axes { display: flex; gap: 26px; font-size: 11px; color: var(--ink-3); letter-spacing: 0.04em; } .hm-axes b { color: var(--ink); font-weight: 500; } /* === Behavior finder === */ .bf { display: flex; flex-direction: column; gap: 14px; min-height: 720px; } .bf-head {} .bf-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; } .bf-pill { appearance: none; background: rgba(255,255,255,0.5); border: 1px solid var(--hairline); border-radius: var(--radius); padding: 11px 12px 10px; text-align: left; display: grid; grid-template-columns: auto 1fr; grid-template-rows: auto auto auto; gap: 2px 10px; cursor: pointer; transition: all 160ms ease; color: var(--ink-2); font-family: var(--sans); } .bf-pill:hover { background: rgba(201,184,230,0.18); border-color: var(--lavender); transform: translateY(-1px); } .bf-pill.is-active { background: linear-gradient(160deg, rgba(201,184,230,0.45), rgba(236,181,190,0.30)); border-color: var(--lavender-2); box-shadow: 0 0 0 1px rgba(154,135,207,0.25), 0 8px 24px rgba(201,184,230,0.35); color: var(--ink); } .bf-glyph { grid-row: 1 / span 2; font-family: var(--serif); font-size: 22px; color: var(--lavender-2); line-height: 1; align-self: center; width: 28px; text-align: center; } .bf-pill.is-active .bf-glyph { color: var(--rose-2); } .bf-label { font-size: 13px; font-weight: 600; color: var(--ink); } .bf-peak { font-family: var(--mono); font-size: 10.5px; color: var(--ink-3); } .bf-curve { grid-column: 1 / -1; width: 100%; height: 22px; margin-top: 4px; } .bf-curve-line { fill: none; stroke: var(--ink-3); stroke-width: 1.2; } .bf-curve-line.is-active { stroke: var(--rose-2); stroke-width: 1.5; } .bf-curve-fill { fill: rgba(154,135,207,0.10); } .bf-curve-fill.is-active { fill: rgba(207,141,150,0.30); } .bf-foot { margin-top: auto; display: flex; justify-content: space-between; align-items: center; font-size: 12.5px; padding-top: 8px; border-top: 1px dashed var(--hairline); color: var(--ink-2); } .bf-foot b { color: var(--ink); } .link-btn { background: none; border: none; color: var(--lavender-2); font-family: var(--sans); font-size: 12px; cursor: pointer; padding: 4px 0; border-bottom: 1px dotted var(--lavender); font-weight: 500; } .link-btn:hover { color: var(--rose-2); border-color: var(--rose); } /* === Surgical targets table === */ .st { display: flex; flex-direction: column; gap: 14px; } .st-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 24px; flex-wrap: wrap; } .st-search { appearance: none; background: var(--bg-4); border: 1px solid var(--hairline-2); border-radius: 999px; padding: 9px 16px; font-family: var(--sans); font-size: 12.5px; color: var(--ink); width: 320px; outline: none; transition: all 160ms ease; } .st-search:focus { border-color: var(--lavender-2); box-shadow: 0 0 0 3px rgba(201,184,230,0.30); } .st-table-wrap { border: 1px solid var(--hairline); border-radius: var(--radius); overflow: hidden; background: var(--bg-4); } .st-table { width: 100%; border-collapse: collapse; font-size: 12.5px; } .st-table thead th { position: sticky; top: 0; background: var(--bg-2); color: var(--ink-3); font-weight: 600; font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; padding: 11px 14px; border-bottom: 1px solid var(--hairline); cursor: pointer; user-select: none; text-align: left; } .st-table thead th.a-right { text-align: right; } .st-th:hover { color: var(--ink); } .st-arrow { color: var(--lavender-2); margin-left: 4px; } .st-table tbody tr { border-top: 1px solid var(--hairline); transition: background 100ms ease; cursor: pointer; } .st-table tbody tr:hover { background: rgba(201,184,230,0.10); } .st-table tbody td { padding: 10px 14px; vertical-align: middle; color: var(--ink-2); } .st-desc { color: var(--ink); max-width: 360px; } .st-bar { display: inline-block; width: 50px; height: 5px; border-radius: 3px; background: rgba(74,58,68,0.08); margin-right: 8px; vertical-align: middle; position: relative; overflow: hidden; } .st-bar-fill { position: absolute; left: 0; top: 0; bottom: 0; width: calc(var(--v) * 100%); } .st-bar.tone-sage .st-bar-fill { background: var(--sage); } .st-bar.tone-rose .st-bar-fill { background: var(--rose); } .st-go { color: var(--lavender-2); font-size: 11px; opacity: 0; transition: opacity 100ms ease; font-weight: 500; } .st-table tbody tr:hover .st-go { opacity: 1; } .st-foot { font-size: 11.5px; color: var(--ink-3); } /* === Layer deep-dive === */ .ld { display: flex; flex-direction: column; gap: 18px; } .ld-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 24px; } .ld-title { font-family: var(--serif); font-weight: 400; font-size: 28px; letter-spacing: -0.01em; display: flex; align-items: baseline; gap: 10px; margin-top: 4px; } .ld-title .lg { font-size: 30px; color: var(--rose-2); } .ld-title .ld-sep { color: var(--ink-dim); font-family: var(--sans); } .ld-title .ld-comp { color: var(--ink); font-style: italic; font-family: var(--mono); font-size: 22px; } .ld-meta { font-size: 12px; color: var(--ink-3); display: flex; gap: 4px; align-items: center; flex-wrap: wrap; margin-top: 6px; } .ld-meta b { color: var(--ink); } .ld-close { background: none; border: 1px solid var(--hairline-2); width: 30px; height: 30px; border-radius: 50%; color: var(--ink-3); font-size: 18px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 140ms ease; } .ld-close:hover { color: var(--ink); border-color: var(--rose-2); background: rgba(207,141,150,0.10); } .ld-eyebrow { font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--lavender-2); margin-bottom: 10px; font-weight: 600; } .ld-section + .ld-section { margin-top: 4px; } .ld-comps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; } .ld-comp-chip { appearance: none; background: rgba(255,255,255,0.5); border: 1px solid var(--hairline); border-radius: var(--radius); padding: 10px 12px; cursor: pointer; text-align: left; display: grid; grid-template-columns: 1fr auto; gap: 6px 10px; transition: all 140ms ease; color: var(--ink-2); } .ld-comp-chip:hover { border-color: var(--lavender-2); background: rgba(201,184,230,0.14); } .ld-comp-chip.is-active { border-color: var(--rose-2); background: linear-gradient(160deg, rgba(236,181,190,0.34), rgba(245,185,163,0.18)); box-shadow: 0 0 0 1px rgba(207,141,150,0.30); } .ld-chip-name { font-size: 11.5px; color: var(--ink); } .ld-chip-v { font-size: 11px; color: var(--ink-3); } .ld-chip-bar { grid-column: 1 / -1; height: 4px; border-radius: 2px; background: rgba(74,58,68,0.08); overflow: hidden; } .ld-chip-bar > span { display: block; height: 100%; background: linear-gradient(90deg, var(--lavender), var(--rose)); } .ld-comp-chip.is-empty { opacity: 0.55; } .ld-cols { display: grid; grid-template-columns: 1fr 1.1fr; gap: 24px; } .ld-heads { display: flex; flex-direction: column; gap: 4px; } .ld-head-row { display: grid; grid-template-columns: 2.5rem 1fr 1fr 3rem; gap: 10px; align-items: center; font-size: 12px; padding: 6px 0; border-bottom: 1px dotted var(--hairline); } .ld-head-role { color: var(--ink-2); font-family: var(--mono); font-size: 11.5px; } .ld-head-bar { height: 5px; background: rgba(74,58,68,0.08); border-radius: 3px; overflow: hidden; } .ld-head-bar > span { display: block; height: 100%; background: linear-gradient(90deg, var(--sage-2), var(--sage), var(--gold)); } .ld-feats { display: flex; flex-direction: column; gap: 12px; } .ld-feat { padding: 12px 14px; background: var(--bg-3); border: 1px solid var(--hairline); border-radius: var(--radius-sm); } .ld-feat-top { display: flex; justify-content: space-between; align-items: baseline; font-size: 11px; color: var(--ink-3); gap: 12px; } .ld-feat-fstat { color: var(--lavender-2); font-weight: 500; } .ld-feat-dens { color: var(--sage-2); font-weight: 500; } .ld-feat-desc { font-size: 13px; color: var(--ink); margin-top: 6px; text-wrap: pretty; font-family: var(--serif); line-height: 1.4; } .ld-feat-fbar { height: 3px; border-radius: 2px; margin-top: 8px; background: rgba(74,58,68,0.08); overflow: hidden; } .ld-feat-fbar > span { display: block; height: 100%; background: linear-gradient(90deg, var(--lavender), var(--rose), var(--coral)); } .ld-empty { padding: 14px 16px; background: rgba(255,255,255,0.5); border: 1px dashed var(--hairline-2); border-radius: var(--radius-sm); font-size: 12.5px; line-height: 1.55; color: var(--ink-2); } /* === SQL box === */ .sql { display: flex; flex-direction: column; gap: 14px; } .sql-head { display: flex; justify-content: space-between; gap: 18px; align-items: flex-end; flex-wrap: wrap; } .sql-examples { display: flex; flex-wrap: wrap; gap: 6px; } .sql-ex { appearance: none; border: 1px solid var(--hairline-2); background: rgba(255,255,255,0.5); color: var(--ink-2); border-radius: 999px; padding: 6px 12px; font-family: var(--sans); font-size: 11.5px; cursor: pointer; transition: all 140ms ease; } .sql-ex:hover { background: rgba(201,184,230,0.22); color: var(--ink); border-color: var(--lavender-2); } .sql-editor-wrap { position: relative; border: 1px solid var(--hairline); border-radius: var(--radius); background: var(--bg-4); overflow: hidden; box-shadow: var(--shadow-soft); } .sql-editor { display: block; width: 100%; min-height: 156px; padding: 16px 18px; font-family: var(--mono); font-size: 13px; line-height: 1.55; background: transparent; color: var(--ink); border: none; outline: none; resize: vertical; caret-color: var(--rose-2); } .sql-editor::selection { background: rgba(201,184,230,0.45); } .sql-actions { display: flex; justify-content: space-between; align-items: center; padding: 8px 12px; border-top: 1px solid var(--hairline); background: var(--bg-2); } .sql-run { appearance: none; background: linear-gradient(180deg, var(--lavender) 0%, var(--lavender-2) 100%); border: 1px solid var(--lavender-2); color: #fff; font-family: var(--sans); font-weight: 600; font-size: 12px; padding: 7px 16px; border-radius: 999px; cursor: pointer; letter-spacing: 0.02em; box-shadow: 0 4px 14px rgba(154,135,207,0.30); transition: all 140ms ease; } .sql-run:hover { transform: translateY(-1px); box-shadow: 0 6px 20px rgba(154,135,207,0.45); } .sql-error { padding: 12px 16px; background: rgba(245,185,163,0.20); border: 1px solid var(--coral); color: var(--coral-2); border-radius: var(--radius); font-family: var(--mono); font-size: 12.5px; } .sql-result { display: flex; flex-direction: column; gap: 10px; } .sql-stats { font-size: 12px; color: var(--ink-3); } .sql-table-wrap { border: 1px solid var(--hairline); border-radius: var(--radius); overflow: auto; max-height: 360px; background: var(--bg-4); } .sql-table { width: 100%; border-collapse: collapse; font-size: 12px; } .sql-table thead th { position: sticky; top: 0; background: var(--bg-2); color: var(--ink-3); font-weight: 600; padding: 9px 12px; border-bottom: 1px solid var(--hairline); text-align: left; font-size: 10.5px; letter-spacing: 0.08em; } .sql-table tbody td { padding: 7px 12px; border-top: 1px solid var(--hairline); color: var(--ink-2); white-space: nowrap; max-width: 360px; overflow: hidden; text-overflow: ellipsis; } .sql-table tbody tr:hover { background: rgba(201,184,230,0.08); } /* === Section gaps === */ .section-grid { display: grid; grid-template-columns: 1fr; gap: 22px; margin-bottom: 22px; } /* === Footer === */ .foot { margin-top: 36px; display: flex; justify-content: space-between; align-items: center; font-size: 11.5px; color: var(--ink-3); padding: 18px 22px; border-top: 1px solid var(--hairline); } .foot b { color: var(--ink-2); font-weight: 600; } .foot a { color: var(--lavender-2); text-decoration: none; border-bottom: 1px dotted var(--lavender); } /* === Scrollbars === */ ::-webkit-scrollbar { width: 10px; height: 10px; } ::-webkit-scrollbar-track { background: transparent; } ::-webkit-scrollbar-thumb { background: rgba(74,58,68,0.15); border-radius: 999px; border: 2px solid var(--bg); } ::-webkit-scrollbar-thumb:hover { background: var(--lavender-2); } /* === Data source pill === */ .ds { position: relative; } .ds-pill { appearance: none; cursor: pointer; display: inline-flex; align-items: center; gap: 8px; background: rgba(255,255,255,0.5); border: 1px solid var(--hairline); border-radius: 999px; padding: 7px 12px; color: var(--ink-2); font-family: var(--sans); font-size: 11.5px; letter-spacing: 0.04em; transition: all 140ms ease; } .ds-pill:hover { background: rgba(201,184,230,0.22); border-color: var(--lavender-2); } .ds-led { width: 7px; height: 7px; border-radius: 50%; animation: led-pulse 2.4s ease-in-out infinite; } @keyframes led-pulse { 0%, 100% { opacity: 0.55; transform: scale(1); } 50% { opacity: 1.0; transform: scale(1.15); } } .ds-chev { color: var(--ink-dim); font-size: 9px; } .ds-panel { position: absolute; right: 0; top: calc(100% + 10px); width: 460px; z-index: 50; display: flex; flex-direction: column; gap: 14px; background: var(--bg-3); border: 1px solid var(--hairline-2); box-shadow: var(--shadow-lift); } .ds-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 16px; } .ds-repo { font-size: 12.5px; color: var(--ink); margin-top: 4px; } .ds-eyebrow { font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--lavender-2); margin-bottom: 8px; font-weight: 600; } .ds-section + .ds-section { padding-top: 12px; border-top: 1px dashed var(--hairline); } .ds-splits { display: flex; flex-direction: column; gap: 8px; max-height: 240px; overflow: auto; } .ds-split { padding: 8px 12px; background: var(--bg-4); border: 1px solid var(--hairline); border-radius: 8px; } .ds-split-top { display: flex; justify-content: space-between; align-items: center; font-size: 11.5px; color: var(--ink-2); } .ds-split-bar { margin-top: 6px; height: 3px; border-radius: 2px; background: rgba(74,58,68,0.08); overflow: hidden; } .ds-split-bar > span { display: block; height: 100%; background: linear-gradient(90deg, var(--lavender), var(--rose)); transition: width 240ms ease; } .ds-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 6px 16px; font-size: 11.5px; } .ds-stats > div { display: flex; justify-content: space-between; } .ds-stats .k { color: var(--ink-3); } .ds-stats .v { color: var(--ink); } .ds-error { background: rgba(245,185,163,0.20); border: 1px solid var(--coral); color: var(--coral-2); padding: 10px 14px; border-radius: 8px; font-size: 11.5px; } .ds-note { font-size: 11.5px; line-height: 1.5; color: var(--ink-3); } .ds-note b { color: var(--ink); } /* === Surgical-table extras === */ .st-filters { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; } .st-leaning { display: inline-flex; gap: 4px; padding: 3px; border-radius: 999px; background: var(--bg-4); border: 1px solid var(--hairline); } .st-chip { appearance: none; background: transparent; border: none; padding: 5px 12px; border-radius: 999px; font-family: var(--sans); font-size: 11px; letter-spacing: 0.04em; color: var(--ink-3); cursor: pointer; transition: all 120ms ease; font-weight: 500; } .st-chip:hover { color: var(--ink); } .st-chip.is-active { background: rgba(74,58,68,0.06); color: var(--ink); } .st-chip.tone-rose.is-active { background: rgba(236,181,190,0.40); color: var(--rose-2); } .st-chip.tone-sage.is-active { background: rgba(170,204,160,0.40); color: var(--sage-2); } .st-leaning-tag { display: inline-block; padding: 2px 8px; border-radius: 999px; font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.02em; font-weight: 500; } .st-leaning-tag.tone-rose { background: rgba(236,181,190,0.36); color: var(--rose-2); } .st-leaning-tag.tone-sage { background: rgba(170,204,160,0.36); color: var(--sage-2); } .pos { color: var(--sage-2); } .neg { color: var(--coral-2); } /* === Taxonomy strip in deep-dive === */ .ld-tax { display: flex; flex-direction: column; gap: 8px; } .ld-tax-bar { display: flex; height: 8px; border-radius: 4px; overflow: hidden; background: rgba(74,58,68,0.06); border: 1px solid var(--hairline); } .ld-tax-seg { transition: width 240ms ease; } .ld-tax-seg.tone-lavender { background: var(--lavender); } .ld-tax-seg.tone-rose { background: var(--rose); } .ld-tax-seg.tone-gold { background: var(--gold); } .ld-tax-seg.tone-sage { background: var(--sage); } .ld-tax-legend { display: grid; grid-template-columns: 1fr 1fr; gap: 6px 14px; font-size: 11px; color: var(--ink-2); } .ld-tax-leg { display: flex; align-items: center; gap: 6px; } .ld-tax-dot { width: 8px; height: 8px; border-radius: 2px; flex: 0 0 auto; } .ld-tax-dot.tone-lavender { background: var(--lavender); } .ld-tax-dot.tone-rose { background: var(--rose); } .ld-tax-dot.tone-gold { background: var(--gold); } .ld-tax-dot.tone-sage { background: var(--sage); } /* === Feature card leaning tags === */ .ld-feat-leaning { font-family: var(--mono); font-size: 10px; padding: 2px 7px; border-radius: 999px; font-weight: 500; } .ld-feat-leaning.tone-rose { background: rgba(236,181,190,0.36); color: var(--rose-2); } .ld-feat-leaning.tone-sage { background: rgba(170,204,160,0.36); color: var(--sage-2); } /* === LANDING / COVER === */ .landing-root { min-height: 100vh; overflow-x: hidden; background: radial-gradient(1400px 900px at 10% -10%, rgba(201,184,230,0.50), transparent 60%), radial-gradient(1100px 800px at 100% 5%, rgba(245,185,163,0.45), transparent 60%), radial-gradient(1300px 1000px at 50% 110%, rgba(170,204,160,0.40), transparent 60%), radial-gradient(900px 700px at 5% 100%, rgba(244,217,158,0.40), transparent 60%), var(--bg); display: flex; align-items: center; justify-content: center; padding: 40px 24px 80px; opacity: 0; animation: landing-in 800ms ease-out 80ms forwards; } @keyframes landing-in { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } } .landing-shell { max-width: 1180px; width: 100%; display: flex; flex-direction: column; gap: 44px; } .landing-head { display: flex; flex-direction: column; align-items: center; gap: 22px; text-align: center; } .landing-mark { width: 96px; height: 96px; opacity: 0; transform: scale(0.92); animation: landing-mark-in 900ms cubic-bezier(.4,0,.2,1) 280ms forwards; } @keyframes landing-mark-in { to { opacity: 1; transform: scale(1); } } .landing-eyebrow { font-size: 11.5px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--lavender-2); font-weight: 600; opacity: 0; animation: rise-in 700ms ease-out 480ms forwards; } .landing-title { font-family: var(--serif); font-weight: 400; font-size: clamp(40px, 6vw, 64px); line-height: 1.0; letter-spacing: -0.02em; margin: 0; max-width: 22ch; color: var(--ink); opacity: 0; animation: rise-in 800ms ease-out 580ms forwards; } .landing-title em { font-style: italic; color: var(--rose-2); } .landing-lede { font-family: var(--serif); font-style: italic; font-size: 18px; line-height: 1.5; max-width: 60ch; color: var(--ink-2); opacity: 0; animation: rise-in 800ms ease-out 720ms forwards; } @keyframes rise-in { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } } .landing-meta { display: flex; gap: 20px; flex-wrap: wrap; justify-content: center; font-size: 12px; color: var(--ink-3); opacity: 0; animation: rise-in 700ms ease-out 880ms forwards; } .landing-meta b { color: var(--ink); font-weight: 600; } .landing-process { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; opacity: 0; animation: rise-in 900ms ease-out 1020ms forwards; } @media (max-width: 920px) { .landing-process { grid-template-columns: repeat(2, 1fr); } } @media (max-width: 540px) { .landing-process { grid-template-columns: 1fr; } } .landing-step { padding: 22px 22px 24px; border-radius: var(--radius-lg); background: rgba(255,255,255,0.65); border: 1px solid var(--hairline); box-shadow: var(--shadow-warm); display: flex; flex-direction: column; gap: 12px; position: relative; overflow: hidden; backdrop-filter: blur(6px); transition: transform 240ms cubic-bezier(.4,0,.2,1), box-shadow 240ms ease; } .landing-step:hover { transform: translateY(-3px); box-shadow: var(--shadow-lift); } .landing-step-num { font-family: var(--serif); font-style: italic; font-size: 13px; color: var(--lavender-2); letter-spacing: 0.02em; } .landing-step-icon { width: 56px; height: 56px; border-radius: 16px; display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,0.6); border: 1px solid var(--hairline); margin-bottom: 4px; } .landing-step-title { font-family: var(--serif); font-size: 20px; color: var(--ink); font-weight: 500; line-height: 1.15; letter-spacing: -0.01em; } .landing-step-body { font-size: 13px; line-height: 1.55; color: var(--ink-2); flex: 1; } .landing-step-tag { font-family: var(--mono); font-size: 10.5px; color: var(--ink-3); padding-top: 8px; border-top: 1px dashed var(--hairline); } .landing-foot { display: flex; flex-direction: column; align-items: center; gap: 14px; opacity: 0; animation: rise-in 800ms ease-out 1240ms forwards; } .landing-enter { appearance: none; font-family: var(--sans); font-weight: 600; font-size: 14px; letter-spacing: 0.01em; padding: 14px 32px; border-radius: 999px; background: linear-gradient(180deg, var(--lavender), var(--lavender-2)); color: #fff; border: 1px solid var(--lavender-2); box-shadow: 0 10px 28px -8px rgba(154,135,207,0.55), 0 2px 0 rgba(255,255,255,0.5) inset; cursor: pointer; transition: transform 160ms ease, box-shadow 160ms ease, background 160ms ease; display: inline-flex; align-items: center; gap: 10px; } .landing-enter:hover { transform: translateY(-1px); box-shadow: 0 14px 36px -8px rgba(154,135,207,0.65), 0 2px 0 rgba(255,255,255,0.5) inset; } .landing-enter .arr { display: inline-block; transition: transform 200ms ease; } .landing-enter:hover .arr { transform: translateX(4px); } .landing-skip { font-size: 12px; color: var(--ink-3); background: none; border: none; border-bottom: 1px dotted var(--hairline-2); padding: 2px 6px; cursor: pointer; font-family: var(--sans); } .landing-skip:hover { color: var(--ink); } /* Subtle floating-petal background motes */ .landing-petals { position: absolute; inset: 0; pointer-events: none; overflow: hidden; z-index: 0; } .landing-petal { position: absolute; width: 80px; height: 80px; border-radius: 50%; filter: blur(40px); opacity: 0.35; animation: drift 24s ease-in-out infinite; } @keyframes drift { 0%, 100% { transform: translate(0, 0); } 50% { transform: translate(20px, -30px); } } .landing-shell { position: relative; z-index: 1; } /* === Reduce motion === */ @media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation: none !important; transition: none !important; } .landing-root, .landing-eyebrow, .landing-title, .landing-lede, .landing-mark, .landing-meta, .landing-process, .landing-foot { opacity: 1; transform: none; } } /* === Responsive === */ @media (max-width: 1180px) { .hero-band { grid-template-columns: 1fr; } .main-grid { grid-template-columns: 1fr; } .ld-cols { grid-template-columns: 1fr; } .ld-comps { grid-template-columns: repeat(2, 1fr); } .bf { min-height: auto; } .hm-card { min-height: 620px; } } /* ─── Convergence Valley (3D SAE training trajectory) ─────────────────── */ .cv { margin-bottom: 22px; padding: 26px 28px 22px; display: flex; flex-direction: column; gap: 18px; position: relative; overflow: hidden; background: linear-gradient(160deg, rgba(255,255,255,0.45), rgba(255,255,255,0.18)), linear-gradient(180deg, var(--bg-3), var(--bg-2)); } .cv::before { content: ''; position: absolute; top: -120px; right: -120px; width: 380px; height: 380px; border-radius: 50%; background: radial-gradient(circle, rgba(201,184,230,0.32), transparent 70%); pointer-events: none; z-index: 0; } .cv::after { content: ''; position: absolute; bottom: -160px; left: -120px; width: 420px; height: 420px; border-radius: 50%; background: radial-gradient(circle, rgba(244,217,158,0.28), transparent 70%); pointer-events: none; z-index: 0; } .cv > * { position: relative; z-index: 1; } /* — header — */ .cv-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 28px; flex-wrap: wrap; } .cv-head-left { display: flex; flex-direction: column; gap: 4px; } .cv-eyebrow { font-size: 10.5px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--lavender-2); font-weight: 600; } .cv-title { font-family: var(--serif); font-weight: 400; font-size: 30px; line-height: 1.0; letter-spacing: -0.015em; color: var(--ink); margin-top: 2px; } .cv-title em { font-style: italic; color: var(--rose-2); } .cv-sub { font-family: var(--serif); font-style: italic; font-size: 14px; color: var(--ink-2); margin-top: 6px; max-width: 56ch; line-height: 1.5; } .cv-sub b { font-style: normal; font-family: var(--sans); font-weight: 600; color: var(--ink); } .cv-sub-quiet { color: var(--ink-3); } .cv-metric-pick { display: flex; gap: 6px; padding: 4px; background: rgba(255,255,255,0.55); border: 1px solid var(--hairline); border-radius: 14px; box-shadow: var(--shadow-soft); } .cv-metric-chip { appearance: none; background: transparent; border: none; padding: 8px 14px 9px; border-radius: 10px; cursor: pointer; font-family: var(--sans); display: flex; flex-direction: column; align-items: flex-start; gap: 2px; transition: background 140ms ease, color 140ms ease, box-shadow 140ms ease; } .cv-metric-chip:hover { background: rgba(201,184,230,0.16); } .cv-metric-chip.is-active { background: linear-gradient(170deg, rgba(201,184,230,0.55), rgba(236,181,190,0.30)); box-shadow: 0 1px 0 rgba(255,255,255,0.7) inset, 0 4px 12px rgba(154,135,207,0.25); } .cv-metric-label { font-size: 12.5px; font-weight: 600; color: var(--ink-2); letter-spacing: 0.02em; } .cv-metric-chip.is-active .cv-metric-label { color: var(--ink); } .cv-metric-sub { font-size: 10px; color: var(--ink-3); letter-spacing: 0.02em; } .cv-metric-chip.is-active .cv-metric-sub { color: var(--rose-2); } /* — body grid: 3D stage + ledger sidebar — */ .cv-body { display: grid; grid-template-columns: minmax(0, 1fr) 360px; gap: 22px; } .cv-stage { position: relative; display: flex; flex-direction: column; background: radial-gradient(ellipse 80% 60% at 50% 100%, rgba(244,217,158,0.20), transparent 60%), linear-gradient(180deg, rgba(255,255,255,0.55), rgba(255,255,255,0.30)); border: 1px solid var(--hairline); border-radius: var(--radius-lg); box-shadow: inset 0 0 0 1px rgba(255,255,255,0.5), 0 1px 0 rgba(255,255,255,0.7) inset; min-height: 560px; overflow: hidden; } .cv-plot { width: 100%; flex: 1; min-height: 500px; } .cv-stage-foot { display: flex; justify-content: space-between; align-items: center; padding: 10px 18px 14px; border-top: 1px dashed var(--hairline); gap: 14px; flex-wrap: wrap; } .cv-legend { display: flex; align-items: center; gap: 8px; font-size: 11px; color: var(--ink-3); } .cv-legend-label { font-family: var(--mono); font-size: 10.5px; } .cv-legend-swatch { width: 140px; height: 8px; border-radius: 4px; box-shadow: inset 0 0 0 1px var(--hairline); } .cv-legend-metric { font-family: var(--mono); font-size: 10.5px; color: var(--lavender-2); margin-left: 4px; } .cv-hint { font-size: 10.5px; letter-spacing: 0.04em; color: var(--ink-3); font-family: var(--mono); } .cv-loading-veil { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 18px; background: linear-gradient(180deg, rgba(255,255,255,0.40), rgba(255,255,255,0.10)); backdrop-filter: blur(2px); pointer-events: none; z-index: 2; } .cv-loading-pulse { width: 64px; height: 64px; border-radius: 50%; background: radial-gradient(circle at 30% 30%, #fff, var(--lavender) 50%, var(--rose) 100%); box-shadow: 0 0 40px rgba(201,184,230,0.45); animation: cv-pulse 2.2s ease-in-out infinite; } .cv-loading-msg { font-family: var(--mono); font-size: 11.5px; color: var(--ink-2); background: rgba(255,255,255,0.7); padding: 6px 14px; border-radius: 999px; border: 1px solid var(--hairline); } .cv-loading-msg b { color: var(--rose-2); font-weight: 600; } /* — sidebar / per-layer ledger — */ .cv-side { display: flex; flex-direction: column; gap: 14px; min-width: 0; } .cv-side-actions { display: flex; align-items: center; justify-content: space-between; gap: 10px; } .cv-toggle { display: inline-flex; align-items: center; gap: 9px; cursor: pointer; font-size: 11.5px; color: var(--ink-2); user-select: none; } .cv-toggle input { position: absolute; opacity: 0; pointer-events: none; } .cv-toggle-dot { width: 30px; height: 17px; border-radius: 999px; background: rgba(74,58,68,0.12); position: relative; transition: background 180ms ease; } .cv-toggle-dot::after { content: ''; position: absolute; top: 2px; left: 2px; width: 13px; height: 13px; border-radius: 50%; background: #fff; box-shadow: 0 1px 2px rgba(74,58,68,0.25); transition: transform 180ms cubic-bezier(.4,0,.2,1); } .cv-toggle input:checked + .cv-toggle-dot { background: linear-gradient(180deg, var(--rose), var(--rose-2)); } .cv-toggle input:checked + .cv-toggle-dot::after { transform: translateX(13px); } .cv-toggle-label { font-family: var(--sans); letter-spacing: 0.01em; } .cv-camera-reset { appearance: none; background: rgba(255,255,255,0.6); border: 1px solid var(--hairline); border-radius: 999px; padding: 5px 11px 6px; font-family: var(--mono); font-size: 10.5px; color: var(--ink-2); letter-spacing: 0.04em; cursor: pointer; transition: all 140ms ease; } .cv-camera-reset:hover { background: rgba(201,184,230,0.20); border-color: var(--lavender-2); color: var(--ink); } .cv-side-head { display: flex; flex-direction: column; gap: 2px; padding-top: 4px; } .cv-side-eyebrow { font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--lavender-2); font-weight: 600; } .cv-side-sub { font-family: var(--serif); font-style: italic; font-size: 13px; color: var(--ink-2); } .cv-table { display: flex; flex-direction: column; background: rgba(255,255,255,0.55); border: 1px solid var(--hairline); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-soft); } .cv-row { display: grid; grid-template-columns: 28px 64px 1fr 1fr 1fr 1fr; align-items: center; gap: 8px; padding: 8px 12px; font-size: 11.5px; color: var(--ink-2); border-top: 1px solid var(--hairline); transition: background 120ms ease; } .cv-row:first-child { border-top: none; } .cv-row-head { background: var(--bg-2); color: var(--ink-3); font-size: 9.5px; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600; padding-top: 9px; padding-bottom: 9px; } .cv-row-empty { padding: 14px 12px; color: var(--ink-3); font-family: var(--mono); font-size: 11px; grid-template-columns: 1fr; } .cv-row.is-rolling { background: linear-gradient(180deg, rgba(201,184,230,0.10), rgba(201,184,230,0.04)); } .cv-row.is-highlight { background: linear-gradient(180deg, rgba(236,181,190,0.20), rgba(236,181,190,0.08)); box-shadow: inset 3px 0 0 var(--rose-2); } .cv-row:hover:not(.cv-row-head):not(.cv-row-empty) { background: rgba(201,184,230,0.08); } .cv-layer { font-family: var(--serif); font-size: 14px; color: var(--ink); font-weight: 500; } .cv-src { display: inline-flex; align-items: center; gap: 6px; font-family: var(--mono); font-size: 10px; color: var(--ink-2); } .cv-src-dot { width: 6px; height: 6px; border-radius: 50%; flex: 0 0 auto; } .cv-src-dot.rolling { background: var(--rose-2); box-shadow: 0 0 0 2px rgba(207,141,150,0.20); } .cv-src-dot.stable { background: var(--lavender-2); box-shadow: 0 0 0 2px rgba(154,135,207,0.20); } .cv-src-name { letter-spacing: 0.04em; } .cv-num { text-align: right; font-size: 11.5px; color: var(--ink); } .cv-num.mono { font-size: 11px; } /* ghost-run info card */ .cv-ghost-card { background: linear-gradient(160deg, rgba(236,181,190,0.18), rgba(244,217,158,0.10)); border: 1px solid var(--hairline); border-radius: var(--radius); padding: 12px 14px 13px; display: flex; flex-direction: column; gap: 10px; } .cv-ghost-eyebrow { font-size: 9.5px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--rose-2); font-weight: 600; } .cv-ghost-rows { display: flex; flex-direction: column; gap: 6px; } .cv-ghost-row { display: grid; grid-template-columns: 78px 1fr auto; align-items: center; gap: 8px; font-size: 11px; color: var(--ink-2); } .cv-ghost-layer { font-family: var(--serif); font-size: 12.5px; color: var(--ink); } .cv-ghost-stats { font-size: 10.5px; color: var(--ink-2); } .cv-ghost-tag { font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.04em; padding: 2px 7px; border-radius: 999px; font-weight: 500; } .cv-ghost-tag.tone-rose { background: rgba(207,141,150,0.30); color: #8a4756; } .cv-ghost-tag.tone-amber { background: rgba(240,201,138,0.40); color: #8a6a32; } .cv-ghost-note { font-size: 11px; line-height: 1.55; color: var(--ink-3); padding-top: 6px; border-top: 1px dashed var(--hairline); } .cv-ghost-note b { color: var(--ink); font-weight: 600; } /* — scrubber — */ .cv-scrub { display: grid; grid-template-columns: auto 1fr auto auto; align-items: center; gap: 16px; padding: 14px 18px; background: linear-gradient(180deg, rgba(255,255,255,0.55), rgba(255,255,255,0.30)); border: 1px solid var(--hairline); border-radius: var(--radius); box-shadow: var(--shadow-soft); } .cv-play { appearance: none; width: 38px; height: 38px; border-radius: 50%; border: 1px solid var(--lavender-2); background: linear-gradient(180deg, var(--lavender), var(--lavender-2)); color: #fff; cursor: pointer; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 12px rgba(154,135,207,0.30), inset 0 1px 0 rgba(255,255,255,0.5); transition: transform 120ms ease, box-shadow 140ms ease; } .cv-play:hover { transform: translateY(-1px); box-shadow: 0 6px 18px rgba(154,135,207,0.45), inset 0 1px 0 rgba(255,255,255,0.5); } .cv-play.is-playing { background: linear-gradient(180deg, var(--rose), var(--rose-2)); border-color: var(--rose-2); box-shadow: 0 4px 12px rgba(207,141,150,0.40), inset 0 1px 0 rgba(255,255,255,0.5); } .cv-play-glyph { font-size: 12px; letter-spacing: 0; line-height: 1; margin-left: 2px; /* optical alignment of the play triangle */ } .cv-play.is-playing .cv-play-glyph { margin-left: 0; font-size: 11px; } .cv-range-wrap { position: relative; padding: 4px 4px 0; min-width: 0; } .cv-range-track { height: 8px; border-radius: 999px; background: rgba(74,58,68,0.08); overflow: hidden; position: relative; } .cv-range-fill { height: 100%; background: linear-gradient(90deg, var(--lavender), var(--rose), var(--coral), var(--gold)); border-radius: 999px; box-shadow: 0 0 14px rgba(245,185,163,0.40); transition: width 80ms linear; } .cv-range { position: absolute; inset: 0; appearance: none; width: 100%; height: 100%; background: transparent; margin: 0; padding: 0; cursor: pointer; } .cv-range::-webkit-slider-thumb { appearance: none; width: 18px; height: 18px; border-radius: 50%; background: #fff; border: 2px solid var(--rose-2); box-shadow: 0 2px 6px rgba(74,58,68,0.22); cursor: grab; transition: transform 120ms ease; } .cv-range::-webkit-slider-thumb:active { transform: scale(1.12); cursor: grabbing; } .cv-range::-moz-range-thumb { width: 18px; height: 18px; border-radius: 50%; background: #fff; border: 2px solid var(--rose-2); box-shadow: 0 2px 6px rgba(74,58,68,0.22); cursor: grab; } .cv-range-ticks { display: flex; justify-content: space-between; font-family: var(--mono); font-size: 9.5px; color: var(--ink-3); padding: 6px 2px 0; letter-spacing: 0.04em; } .cv-scrub-readout { display: flex; flex-direction: column; align-items: flex-end; line-height: 1.0; } .cv-scrub-num { font-family: var(--serif); font-weight: 500; font-size: 20px; color: var(--ink); letter-spacing: -0.01em; } .cv-scrub-label { font-size: 9.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-3); margin-top: 4px; } .cv-scrub-reset { appearance: none; background: rgba(255,255,255,0.6); border: 1px solid var(--hairline); border-radius: 999px; padding: 6px 12px 7px; font-family: var(--mono); font-size: 10.5px; color: var(--ink-2); cursor: pointer; letter-spacing: 0.04em; transition: all 140ms ease; } .cv-scrub-reset:hover { background: rgba(201,184,230,0.18); border-color: var(--lavender-2); color: var(--ink); }