| |
| |
|
|
| :root { |
| |
| --bg: #efe9de; |
| --bg-2: #f6f1e6; |
| --bg-3: #fbf6ea; |
| --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: #3a2a30; |
| --ink-2: #5b454c; |
| --ink-3: #84686c; |
| --ink-dim: #a89090; |
|
|
| |
| --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-0: #ece6f1; |
| --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; |
| } |
|
|
| |
| .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; } |
|
|
| |
|
|
| .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 { |
| 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; } |
|
|
| |
|
|
| .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; |
| } |
|
|
| |
| .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 { |
| 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); |
| } |
|
|
| |
|
|
| .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; } |
|
|
| |
|
|
| .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); } |
|
|
| |
|
|
| .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); } |
|
|
| |
|
|
| .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 { 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-grid { |
| display: grid; grid-template-columns: 1fr; gap: 22px; |
| margin-bottom: 22px; |
| } |
|
|
| |
| .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); } |
|
|
| |
| ::-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); } |
|
|
| |
| .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); } |
|
|
| |
| .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); } |
|
|
| |
| .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); } |
|
|
| |
| .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-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); } |
|
|
| |
| .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; } |
|
|
| |
| @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; } |
| } |
|
|
| |
| @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; } |
| } |
|
|
| |
| .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; } |
|
|
| |
|
|
| .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); } |
|
|
| |
|
|
| .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; } |
|
|
| |
|
|
| .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; } |
|
|
| |
| .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; } |
|
|
| |
|
|
| .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; |
| } |
|
|
| .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); |
| } |
|
|
|
|