| :root { |
| --bg: #fafafa; |
| --fg: #000; |
| --accents-1: #eaeaea; |
| --accents-2: #999; |
| --accents-3: #888; |
| --accents-4: #666; |
| --accents-5: #444; |
| --accents-6: #333; |
| --accents-7: #111; |
| --border: #eaeaea; |
| --success: #0070f3; |
| --error: #e00; |
| --warning: #f5a623; |
| --radius: 6px; |
| } |
|
|
| body { |
| font-family: 'Geist Sans', -apple-system, BlinkMacSystemFont, sans-serif; |
| background-color: var(--bg); |
| color: var(--fg); |
| -webkit-font-smoothing: antialiased; |
| } |
|
|
| #app-header { |
| height: 56px; |
| } |
|
|
| .font-mono { |
| font-family: 'Geist Mono', monospace; |
| } |
|
|
| .table-empty { |
| color: var(--accents-4); |
| font-size: 12px; |
| font-weight: 400; |
| padding: 48px 0; |
| text-align: center; |
| } |
|
|
| td.table-empty { |
| height: auto; |
| } |
|
|
| .fade-in { |
| animation: fadeIn 0.5s ease-out forwards; |
| } |
|
|
| @keyframes fadeIn { |
| from { |
| opacity: 0; |
| transform: translateY(10px); |
| } |
|
|
| to { |
| opacity: 1; |
| transform: translateY(0); |
| } |
| } |
|
|
| .fade-in-centered { |
| animation: fadeInCentered 0.5s ease-out forwards; |
| } |
|
|
| @keyframes fadeInCentered { |
| from { |
| opacity: 0; |
| transform: translate(-50%, 10px); |
| } |
|
|
| to { |
| opacity: 1; |
| transform: translate(-50%, 0); |
| } |
| } |
|
|
| .geist-input { |
| width: 100%; |
| font-size: 0.8125rem; |
| border-radius: 0.5rem; |
| padding: 0.35rem 0.5rem; |
| outline: none; |
| border: 1px solid transparent; |
| transition: all 0.2s; |
| background: #fff; |
| border: 1px solid #e6e6e6; |
| color: var(--accents-7); |
| } |
|
|
| .geist-input:focus { |
| border-color: #bdbdbd; |
| box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.03); |
| } |
|
|
| .geist-input:disabled { |
| background: #f5f5f5; |
| color: var(--accents-4); |
| cursor: not-allowed; |
| } |
|
|
| .geist-input::placeholder { |
| color: var(--accents-3); |
| } |
|
|
| .geist-button { |
| height: 32px; |
| font-size: 0.875rem; |
| font-weight: 600; |
| background-color: #000; |
| color: #fff; |
| border-radius: 0.5rem; |
| padding: 0 1rem; |
| transition: opacity 0.2s; |
| display: flex; |
| align-items: center; |
| justify-content: center; |
| white-space: nowrap; |
| } |
|
|
| .geist-button:hover { |
| opacity: 0.9; |
| } |
|
|
| .geist-button:disabled { |
| opacity: 0.5; |
| cursor: not-allowed; |
| } |
|
|
| .geist-button-outline { |
| height: 32px; |
| font-size: 0.875rem; |
| font-weight: 500; |
| background-color: transparent; |
| color: var(--fg); |
| border: 1px solid var(--border); |
| border-radius: 0.5rem; |
| padding: 0 1rem; |
| transition: all 0.2s; |
| display: flex; |
| align-items: center; |
| justify-content: center; |
| white-space: nowrap; |
| } |
|
|
| .geist-button-outline:hover { |
| border-color: #000; |
| } |
|
|
| .geist-button-outline:disabled { |
| opacity: 0.5; |
| cursor: not-allowed; |
| } |
|
|
| .geist-button-danger { |
| height: 32px; |
| font-size: 0.875rem; |
| font-weight: 500; |
| background-color: #e00; |
| color: #fff; |
| border-radius: 0.5rem; |
| padding: 0 1rem; |
| transition: opacity 0.2s; |
| display: flex; |
| align-items: center; |
| justify-content: center; |
| white-space: nowrap; |
| } |
|
|
| .geist-button-danger:hover { |
| opacity: 0.9; |
| } |
|
|
| .geist-button-danger:disabled { |
| opacity: 0.5; |
| cursor: not-allowed; |
| } |
|
|
| .nav-link { |
| color: var(--accents-4); |
| transition: color 0.15s; |
| } |
|
|
| .nav-link:hover { |
| color: var(--fg); |
| } |
|
|
| .nav-link.active { |
| color: var(--fg); |
| font-weight: 500; |
| } |
|
|
| .nav-group { |
| position: relative; |
| } |
|
|
| .nav-group-trigger { |
| background: transparent; |
| border: 0; |
| padding: 0; |
| font: inherit; |
| cursor: pointer; |
| } |
|
|
| .nav-group-menu { |
| position: absolute; |
| top: 100%; |
| left: -8px; |
| margin-top: 8px; |
| min-width: 140px; |
| background: #fff; |
| border: 1px solid var(--border); |
| border-radius: 10px; |
| padding: 6px; |
| display: flex; |
| flex-direction: column; |
| gap: 2px; |
| opacity: 0; |
| visibility: hidden; |
| transform: translateY(-6px); |
| transition: opacity 0.15s ease, transform 0.15s ease, visibility 0.15s; |
| box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08); |
| z-index: 20; |
| } |
|
|
| .nav-group:hover .nav-group-menu, |
| .nav-group:focus-within .nav-group-menu { |
| opacity: 1; |
| visibility: visible; |
| transform: translateY(0); |
| } |
|
|
| .nav-group-menu .nav-link { |
| padding: 6px 10px; |
| border-radius: 6px; |
| display: flex; |
| align-items: center; |
| color: var(--accents-5); |
| } |
|
|
| .nav-group-menu .nav-link:hover { |
| background: #f5f5f5; |
| color: var(--fg); |
| } |
|
|
| .nav-group-menu .nav-link.active { |
| background: #f0f0f0; |
| color: var(--fg); |
| font-weight: 500; |
| } |
|
|
| .nav-badge { |
| display: inline-flex; |
| align-items: center; |
| height: 28px; |
| padding: 0 10px; |
| border-radius: 999px; |
| font-size: 12px; |
| color: var(--accents-5); |
| background: #f7f7f7; |
| border: 1px solid var(--border); |
| white-space: nowrap; |
| } |
|
|
| .nav-actions { |
| display: flex; |
| align-items: center; |
| gap: 10px; |
| } |
|
|
| .nav-action-btn { |
| height: 24px; |
| padding: 0 8px; |
| border-radius: 999px; |
| border: 1px solid var(--border); |
| background: #fff; |
| font-size: 11px; |
| font-weight: 500; |
| color: var(--accents-5); |
| display: inline-flex; |
| align-items: center; |
| justify-content: center; |
| white-space: nowrap; |
| transition: all 0.2s; |
| } |
|
|
| .nav-action-btn:hover { |
| border-color: #000; |
| color: #000; |
| } |
|
|
| .nav-action-btn.storage-ready { |
| background: #ecfdf3; |
| border-color: #a7f3d0; |
| color: #047857; |
| } |
|
|
| .brand-link { |
| display: inline-flex; |
| align-items: center; |
| gap: 6px; |
| color: inherit; |
| text-decoration: none; |
| } |
|
|
| .github-icon { |
| width: 14px; |
| height: 14px; |
| fill: currentColor; |
| } |
|
|
| .app-footer { |
| position: fixed; |
| right: 16px; |
| left: auto; |
| bottom: 12px; |
| color: var(--accents-4); |
| font-size: 12px; |
| background: transparent; |
| text-align: right; |
| z-index: 10; |
| } |
|
|
| .app-footer a { |
| color: inherit; |
| transition: color 0.15s; |
| } |
|
|
| .app-footer a:hover { |
| color: var(--fg); |
| } |
|
|
| .stat-card { |
| background: #fff; |
| border: 1px solid transparent; |
| border-radius: 10px; |
| padding: 14px 18px; |
| box-shadow: none; |
| transition: all 0.2s; |
| } |
|
|
| .stat-card:hover { |
| border-color: #000; |
| box-shadow: none; |
| } |
|
|
| .stat-value { |
| font-size: 20px; |
| font-weight: 600; |
| line-height: 1.2; |
| letter-spacing: -0.01em; |
| } |
|
|
| .stat-label { |
| font-size: 12px; |
| color: var(--accents-4); |
| margin-top: 2px; |
| } |
|
|