@hileeon/mcc 0.1.9 → 0.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (70) hide show
  1. package/README.md +6 -1
  2. package/dist/accounts/store.d.ts +11 -0
  3. package/dist/accounts/store.d.ts.map +1 -1
  4. package/dist/accounts/store.js.map +1 -1
  5. package/dist/commands/launch.d.ts.map +1 -1
  6. package/dist/commands/launch.js +8 -4
  7. package/dist/commands/launch.js.map +1 -1
  8. package/dist/commands/mcp.d.ts +11 -0
  9. package/dist/commands/mcp.d.ts.map +1 -1
  10. package/dist/commands/mcp.js +179 -1
  11. package/dist/commands/mcp.js.map +1 -1
  12. package/dist/commands/profile-test.d.ts +17 -0
  13. package/dist/commands/profile-test.d.ts.map +1 -0
  14. package/dist/commands/profile-test.js +188 -0
  15. package/dist/commands/profile-test.js.map +1 -0
  16. package/dist/core/model-router.d.ts.map +1 -1
  17. package/dist/core/model-router.js +31 -1
  18. package/dist/core/model-router.js.map +1 -1
  19. package/dist/dashboard/server.js +118 -30
  20. package/dist/dashboard/server.js.map +1 -1
  21. package/dist/mcc.js +15 -0
  22. package/dist/mcc.js.map +1 -1
  23. package/dist/mcp/external-registry.d.ts +6 -3
  24. package/dist/mcp/external-registry.d.ts.map +1 -1
  25. package/dist/mcp/external-registry.js.map +1 -1
  26. package/dist/mcp/installer.d.ts.map +1 -1
  27. package/dist/mcp/installer.js +25 -10
  28. package/dist/mcp/installer.js.map +1 -1
  29. package/dist/mcp/mcp-config.d.ts +17 -3
  30. package/dist/mcp/mcp-config.d.ts.map +1 -1
  31. package/dist/mcp/mcp-config.js +38 -19
  32. package/dist/mcp/mcp-config.js.map +1 -1
  33. package/dist/mcp/registry.d.ts +4 -2
  34. package/dist/mcp/registry.d.ts.map +1 -1
  35. package/dist/mcp/registry.js.map +1 -1
  36. package/dist/proxy/proxy-daemon.d.ts +1 -1
  37. package/dist/proxy/proxy-daemon.d.ts.map +1 -1
  38. package/dist/proxy/proxy-daemon.js +10 -5
  39. package/dist/proxy/proxy-daemon.js.map +1 -1
  40. package/dist/proxy/proxy-entry.js +6 -1
  41. package/dist/proxy/proxy-entry.js.map +1 -1
  42. package/dist/proxy/proxy-paths.d.ts +1 -0
  43. package/dist/proxy/proxy-paths.d.ts.map +1 -1
  44. package/dist/proxy/proxy-paths.js.map +1 -1
  45. package/dist/proxy/proxy-server.d.ts +1 -0
  46. package/dist/proxy/proxy-server.d.ts.map +1 -1
  47. package/dist/proxy/proxy-server.js +84 -2
  48. package/dist/proxy/proxy-server.js.map +1 -1
  49. package/dist/shared/config.d.ts +1 -0
  50. package/dist/shared/config.d.ts.map +1 -1
  51. package/dist/shared/config.js +1 -0
  52. package/dist/shared/config.js.map +1 -1
  53. package/dist/shared/provider-preset-catalog.d.ts +2 -0
  54. package/dist/shared/provider-preset-catalog.d.ts.map +1 -1
  55. package/dist/shared/provider-preset-catalog.js +31 -22
  56. package/dist/shared/provider-preset-catalog.js.map +1 -1
  57. package/dist/shared/test-image.d.ts +15 -0
  58. package/dist/shared/test-image.d.ts.map +1 -0
  59. package/dist/shared/test-image.js +89 -0
  60. package/dist/shared/test-image.js.map +1 -0
  61. package/dist/ui/assets/{index-ClqmrjNk.js → index-7kowlJw9.js} +7 -7
  62. package/dist/ui/assets/{index-CwMwQ-Z4.css → index-DnC-lskL.css} +1 -1
  63. package/dist/ui/index.html +2 -2
  64. package/dist/update.d.ts +16 -5
  65. package/dist/update.d.ts.map +1 -1
  66. package/dist/update.js +149 -37
  67. package/dist/update.js.map +1 -1
  68. package/lib/mcp-hooks/image-analysis-runtime.cjs +58 -5
  69. package/lib/shared/logger.cjs +5 -1
  70. package/package.json +2 -4
@@ -1 +1 @@
1
- :root{--paper-50: #fbf7ee;--paper-100: #f5efe1;--paper-200: #ede5d2;--paper-300: #ddd2b6;--paper-400: #c4b896;--ink-50: #f6f4ee;--ink-200: #a09c92;--ink-400: #5e5b54;--ink-600: #2c2b27;--ink-900: #16161a;--arcade-tangerine: #ff8a3d;--arcade-tangerine-soft: #ffd9bc;--arcade-tangerine-ink: #6b2f00;--arcade-lagoon: #2bbfd9;--arcade-lagoon-soft: #bff0f8;--arcade-lagoon-ink: #0a4a57;--arcade-leaf: #5fb84f;--arcade-leaf-soft: #cdebc4;--arcade-leaf-ink: #1d4a17;--arcade-hibiscus: #ff5470;--arcade-hibiscus-soft: #ffd1da;--arcade-hibiscus-ink: #71132a;--arcade-sunshine: #ffc83a;--arcade-sunshine-soft: #ffe9a8;--arcade-sunshine-ink: #6b4500;--arcade-lilac: #a875ff;--arcade-lilac-soft: #e0d0ff;--arcade-lilac-ink: #391a72;--white: #ffffff;--black: #000000;--pixel-grid: rgba(22, 22, 26, .06);--space-0: 0px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 28px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--font-2xs: 10px;--font-xs: 11px;--font-sm: 13px;--font-base: 14px;--font-md: 15px;--font-lg: 18px;--font-xl: 22px;--font-2xl: 28px;--font-3xl: 38px;--radius-none: 0px;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-2xl: 28px;--radius-full: 9999px;--weight-regular: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--weight-black: 800;--font-sans: "Inter Tight", -apple-system, BlinkMacSystemFont, "SF Pro Text", "PingFang SC", "Hiragino Sans GB", system-ui, sans-serif;--font-rounded: ui-rounded, "SF Pro Rounded", "Plus Jakarta Sans", "Inter Tight", -apple-system, sans-serif;--font-pixel: "Silkscreen", "VT323", "Press Start 2P", ui-monospace, monospace;--font-mono: "JetBrains Mono", "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--shadow-soft-1: 0 1px 1px rgba(22, 22, 26, .04), 0 4px 12px rgba(22, 22, 26, .06);--shadow-soft-2: 0 1px 1px rgba(22, 22, 26, .05), 0 12px 28px rgba(22, 22, 26, .1);--shadow-soft-3: 0 2px 4px rgba(22, 22, 26, .06), 0 24px 48px rgba(22, 22, 26, .14);--shadow-pixel-1: 2px 2px 0 0 var(--ink-900);--shadow-pixel-2: 4px 4px 0 0 var(--ink-900);--shadow-pixel-3: 6px 6px 0 0 var(--ink-900);--shadow-inset: inset 0 1px 0 rgba(255, 255, 255, .7), inset 0 -1px 0 rgba(22, 22, 26, .06);--ease-out-quart: cubic-bezier(.25, 1, .5, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--dur-fast: .12s;--dur-base: .2s;--dur-slow: .32s}:root{--color-bg-base: var(--paper-100);--color-bg-surface: var(--paper-50);--color-bg-surface-muted: var(--paper-200);--color-bg-overlay: rgb(22 22 26 / .42);--color-bg-elevated: var(--white);--color-text-primary: var(--ink-900);--color-text-secondary: var(--ink-600);--color-text-muted: var(--ink-400);--color-text-faint: var(--ink-200);--color-text-inverse: var(--paper-50);--color-text-mono: var(--ink-900);--color-accent: var(--arcade-tangerine);--color-accent-hover: #f0782b;--color-accent-soft: var(--arcade-tangerine-soft);--color-accent-on-soft: var(--arcade-tangerine-ink);--color-accent-foreground: var(--ink-900);--color-success: var(--arcade-leaf);--color-success-soft: var(--arcade-leaf-soft);--color-success-on-soft: var(--arcade-leaf-ink);--color-success-dot: var(--arcade-leaf);--color-warning: var(--arcade-sunshine);--color-warning-soft: var(--arcade-sunshine-soft);--color-warning-on-soft: var(--arcade-sunshine-ink);--color-warning-border: var(--arcade-sunshine);--color-danger: var(--arcade-hibiscus);--color-danger-hover: #ef3357;--color-danger-soft: var(--arcade-hibiscus-soft);--color-danger-on-soft: var(--arcade-hibiscus-ink);--color-info: var(--arcade-lagoon);--color-info-soft: var(--arcade-lagoon-soft);--color-info-on-soft: var(--arcade-lagoon-ink);--color-special: var(--arcade-lilac);--color-special-soft: var(--arcade-lilac-soft);--color-special-on-soft: var(--arcade-lilac-ink);--color-border: var(--paper-300);--color-border-muted: var(--paper-200);--color-border-strong: var(--ink-900);--color-focus-ring: var(--arcade-lagoon);--space-inline: var(--space-2);--space-block: var(--space-4);--space-section: var(--space-6);--radius-control: var(--radius-md);--radius-card: var(--radius-lg);--radius-pill: var(--radius-full)}:root{--app-bg: var(--color-bg-base);--app-text: var(--color-text-primary);--card-bg: var(--color-bg-surface);--card-bg-raised: var(--color-bg-elevated);--card-border: var(--color-border-strong);--card-border-soft: var(--color-border);--card-text: var(--color-text-primary);--card-text-muted: var(--color-text-muted);--card-radius: var(--radius-card);--card-padding: var(--space-block);--card-shadow: var(--shadow-soft-1);--card-shadow-raised: var(--shadow-pixel-2);--card-shadow-press: var(--shadow-pixel-1);--button-bg: var(--color-accent);--button-bg-hover: var(--color-accent-hover);--button-text: var(--color-accent-foreground);--button-radius: var(--radius-control);--button-padding: var(--space-2) var(--space-4);--button-border: var(--ink-900);--button-shadow: var(--shadow-pixel-1);--button-shadow-hover: var(--shadow-pixel-2);--button-danger-bg: var(--color-danger);--button-danger-bg-hover: var(--color-danger-hover);--button-danger-text: var(--color-text-inverse);--button-ghost-text: var(--color-text-secondary);--button-ghost-hover-bg: var(--paper-200);--input-bg: var(--color-bg-elevated);--input-border: var(--color-border);--input-border-strong: var(--ink-900);--input-text: var(--color-text-primary);--input-placeholder: var(--color-text-faint);--input-radius: var(--radius-control);--input-shadow: var(--shadow-inset);--input-focus-ring: var(--color-focus-ring);--badge-bg: var(--color-bg-surface-muted);--badge-text: var(--color-text-muted);--badge-radius: var(--radius-pill);--badge-success-bg: var(--color-success-soft);--badge-success-text: var(--color-success-on-soft);--badge-warning-bg: var(--color-warning-soft);--badge-warning-text: var(--color-warning-on-soft);--badge-info-bg: var(--color-info-soft);--badge-info-text: var(--color-info-on-soft);--badge-special-bg: var(--color-special-soft);--badge-special-text: var(--color-special-on-soft);--status-online-text: var(--color-success-on-soft);--status-online-dot: var(--color-success-dot);--status-offline-text: var(--color-danger-on-soft);--status-offline-dot: var(--color-danger);--banner-warning-bg: var(--color-warning-soft);--banner-warning-border: var(--color-warning-border);--banner-warning-text: var(--color-warning-on-soft);--banner-success-bg: var(--color-success-soft);--banner-success-border: var(--color-success);--banner-success-text: var(--color-success-on-soft);--banner-error-bg: var(--color-danger-soft);--banner-error-border: var(--color-danger);--banner-error-text: var(--color-danger-on-soft);--banner-info-bg: var(--color-info-soft);--banner-info-border: var(--color-info);--banner-info-text: var(--color-info-on-soft);--code-text: var(--color-text-mono);--code-text-faint: var(--color-text-faint);--code-bg: var(--paper-200);--tabs-bg: transparent;--tabs-trigger-text: var(--color-text-secondary);--tabs-trigger-active-bg: var(--color-bg-elevated);--tabs-trigger-active-text: var(--color-text-primary);--tabs-trigger-active-border: var(--ink-900);--sheet-bg: var(--color-bg-elevated);--sheet-overlay: var(--color-bg-overlay)}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter Tight,system-ui,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:JetBrains Mono,ui-monospace,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--background: 40 53% 92%;--foreground: 240 10% 9%;--card: 38 56% 96%;--card-foreground: 240 10% 9%;--popover: 38 56% 96%;--popover-foreground: 240 10% 9%;--primary: 23 100% 62%;--primary-foreground: 240 10% 9%;--secondary: 40 39% 82%;--secondary-foreground: 240 10% 9%;--muted: 40 39% 88%;--muted-foreground: 36 5% 36%;--accent: 40 39% 86%;--accent-foreground: 240 10% 9%;--destructive: 350 100% 66%;--destructive-foreground: 0 0% 100%;--border: 38 26% 78%;--input: 38 26% 78%;--ring: 188 70% 51%;--radius: .875rem}html,body,#root{height:100%}*{border-color:hsl(var(--border))}body{background:var(--app-bg);color:var(--app-text);font-family:var(--font-sans);font-feature-settings:"ss01","cv11";-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{background-color:var(--paper-100);background-image:radial-gradient(ellipse 80% 60% at 12% 8%,rgba(255,138,61,.16),transparent 60%),radial-gradient(ellipse 70% 60% at 92% 18%,rgba(43,191,217,.16),transparent 60%),radial-gradient(ellipse 65% 55% at 80% 95%,rgba(168,117,255,.12),transparent 60%),linear-gradient(var(--pixel-grid) 1px,transparent 1px),linear-gradient(90deg,var(--pixel-grid) 1px,transparent 1px);background-size:auto,auto,auto,20px 20px,20px 20px;background-position:0 0,0 0,0 0,-1px -1px,-1px -1px;background-attachment:fixed}::-moz-selection{background:var(--arcade-sunshine);color:var(--ink-900)}::selection{background:var(--arcade-sunshine);color:var(--ink-900)}.container{width:100%;margin-right:auto;margin-left:auto;padding-right:2rem;padding-left:2rem}@media(min-width:1400px){.container{max-width:1400px}}.font-pixel{font-family:var(--font-pixel);letter-spacing:.02em}.font-rounded{font-family:var(--font-rounded);letter-spacing:-.01em}.font-mono{font-family:var(--font-mono)}.arcade-card{background:var(--card-bg);border:1.5px solid var(--card-border);border-radius:var(--card-radius);box-shadow:var(--card-shadow-raised);transition:box-shadow var(--dur-base) var(--ease-out-quart),transform var(--dur-base) var(--ease-out-quart)}.arcade-card-soft{background:var(--card-bg);border:1px solid var(--card-border-soft);border-radius:var(--card-radius);box-shadow:var(--card-shadow)}.arcade-card-press:hover{transform:translate(-1px,-1px);box-shadow:var(--shadow-pixel-3)}.arcade-card-press:active{transform:translate(2px,2px);box-shadow:0 0 0 0 var(--ink-900)}.arcade-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--button-padding);font-family:var(--font-rounded);font-weight:var(--weight-semibold);font-size:var(--font-sm);color:var(--button-text);background:var(--button-bg);border:1.5px solid var(--button-border);border-radius:var(--button-radius);box-shadow:var(--button-shadow);cursor:pointer;transition:transform var(--dur-fast) var(--ease-out-quart),box-shadow var(--dur-fast) var(--ease-out-quart),background var(--dur-fast) var(--ease-out-quart);-webkit-user-select:none;-moz-user-select:none;user-select:none;white-space:nowrap}.arcade-btn:hover{background:var(--button-bg-hover);transform:translate(-1px,-1px);box-shadow:var(--button-shadow-hover)}.arcade-btn:active{transform:translate(2px,2px);box-shadow:0 0 0 0 var(--ink-900)}.arcade-btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.arcade-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:var(--button-shadow)}.arcade-btn-ghost{background:transparent;border-color:transparent;box-shadow:none;color:var(--button-ghost-text)}.arcade-btn-ghost:hover{background:var(--button-ghost-hover-bg);transform:none;box-shadow:none}.arcade-btn-ghost:active{transform:none;box-shadow:none}.arcade-btn-outline{background:var(--color-bg-elevated);color:var(--ink-900)}.arcade-btn-outline:hover{background:var(--paper-100)}.arcade-btn-danger{background:var(--button-danger-bg);color:var(--button-danger-text)}.arcade-btn-danger:hover{background:var(--button-danger-bg-hover)}.arcade-btn-sm{font-size:var(--font-xs);padding:var(--space-1) var(--space-3)}.pixel-chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px 8px;font-family:var(--font-pixel);font-size:var(--font-2xs);letter-spacing:.06em;text-transform:uppercase;background:var(--badge-bg);color:var(--badge-text);border-radius:var(--radius-sm);border:1px solid var(--color-border);line-height:1.4}.pixel-chip-success{background:var(--badge-success-bg);color:var(--badge-success-text);border-color:var(--color-success)}.pixel-chip-info{background:var(--badge-info-bg);color:var(--badge-info-text);border-color:var(--arcade-lagoon)}.pixel-chip-tangerine{background:var(--arcade-tangerine-soft);color:var(--arcade-tangerine-ink);border-color:var(--arcade-tangerine)}.arcade-input{width:100%;background:var(--input-bg);border:1.5px solid var(--input-border);border-radius:var(--input-radius);padding:var(--space-2) var(--space-3);font-family:var(--font-sans);font-size:var(--font-sm);color:var(--input-text);transition:border-color var(--dur-fast) var(--ease-out-quart),box-shadow var(--dur-fast) var(--ease-out-quart)}.arcade-input::-moz-placeholder{color:var(--input-placeholder)}.arcade-input::placeholder{color:var(--input-placeholder)}.arcade-input:focus,.arcade-input:focus-visible{outline:none;border-color:var(--input-border-strong);box-shadow:var(--shadow-pixel-1)}.arcade-input:disabled{background:var(--paper-200);color:var(--color-text-muted)}.status-online{color:var(--status-online-text)}.status-online-dot{background:var(--status-online-dot);box-shadow:0 0 0 3px #5fb84f33;animation:pulse-online 2s ease-in-out infinite}.status-offline{color:var(--status-offline-text)}.status-offline-dot{background:var(--status-offline-dot);box-shadow:0 0 0 3px #ff547033}@keyframes pulse-online{0%,to{box-shadow:0 0 0 3px #5fb84f2e}50%{box-shadow:0 0 0 6px #5fb84f0f}}.banner-warning{background:var(--banner-warning-bg);border:1.5px solid var(--banner-warning-border);color:var(--banner-warning-text);border-radius:var(--radius-md)}.banner-success{background:var(--banner-success-bg);border:1.5px solid var(--banner-success-border);color:var(--banner-success-text);border-radius:var(--radius-md)}.banner-error{background:var(--banner-error-bg);border:1.5px solid var(--banner-error-border);color:var(--banner-error-text);border-radius:var(--radius-md)}.code-mono{font-family:var(--font-mono);color:var(--code-text)}.arcade-tabs-list{display:inline-flex;gap:var(--space-1);padding:var(--space-1);background:var(--color-bg-surface-muted);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-inset)}.arcade-tabs-trigger{padding:var(--space-2) var(--space-4);font-family:var(--font-rounded);font-weight:var(--weight-semibold);font-size:var(--font-sm);color:var(--tabs-trigger-text);border-radius:var(--radius-lg);transition:all var(--dur-base) var(--ease-out-quart);cursor:pointer;display:inline-flex;align-items:center;gap:var(--space-2)}.arcade-tabs-trigger[data-state=active]{background:var(--tabs-trigger-active-bg);color:var(--tabs-trigger-active-text);box-shadow:var(--shadow-soft-1)}.arcade-tabs-trigger:hover{color:var(--tabs-trigger-active-text)}.provider-halo{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:var(--radius-lg);border:1.5px solid var(--ink-900);background:var(--paper-50);box-shadow:var(--shadow-pixel-1);flex-shrink:0}.provider-halo-sm{width:40px;height:40px;border-radius:var(--radius-md)}.sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--sheet-overlay);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:40;animation:fade-in var(--dur-base) var(--ease-out-quart)}.sheet-panel{position:fixed;z-index:50;background:var(--sheet-bg);border:1.5px solid var(--ink-900);border-radius:var(--radius-2xl);box-shadow:var(--shadow-pixel-3),var(--shadow-soft-3)}.sheet-panel-center{top:50%;left:50%;transform:translate(-50%,-50%);width:min(92vw,540px);max-height:88vh;overflow-y:auto;animation:sheet-pop var(--dur-base) var(--ease-spring)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes sheet-pop{0%{opacity:0;transform:translate(-50%,-50%) scale(.92)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.crt-scanline{position:relative;overflow:hidden}.crt-scanline:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:repeating-linear-gradient(0deg,rgba(22,22,26,.05) 0,rgba(22,22,26,.05) 1px,transparent 1px,transparent 4px);opacity:.4}.section-kicker{font-family:var(--font-pixel);font-size:var(--font-2xs);letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-muted)}.section-title{font-family:var(--font-rounded);font-weight:var(--weight-bold);font-size:var(--font-2xl);line-height:1.1;letter-spacing:-.02em;color:var(--color-text-primary)}.section-sub{font-family:var(--font-sans);font-size:var(--font-sm);color:var(--color-text-muted);line-height:1.5}.pointer-events-none{pointer-events:none}.absolute{position:absolute}.relative{position:relative}.inset-x-0{left:0;right:0}.-bottom-5{bottom:-1.25rem}.bottom-0{bottom:0}.left-0{left:0}.left-3{left:.75rem}.left-4{left:1rem}.right-0{right:0}.right-1\.5{right:.375rem}.right-2{right:.5rem}.right-3{right:.75rem}.top-0{top:0}.top-1\/2{top:50%}.top-3{top:.75rem}.z-20{z-index:20}.z-50{z-index:50}.mx-auto{margin-left:auto;margin-right:auto}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.ml-1{margin-left:.25rem}.mr-2{margin-right:.5rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-12{margin-top:3rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-6{margin-top:1.5rem}.mt-auto{margin-top:auto}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-14{height:3.5rem}.h-2{height:.5rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-9{height:2.25rem}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-full{height:100%}.h-screen{height:100vh}.max-h-48{max-height:12rem}.max-h-96{max-height:24rem}.min-h-screen{min-height:100vh}.w-1\.5{width:.375rem}.w-12{width:3rem}.w-14{width:3.5rem}.w-2{width:.5rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-9{width:2.25rem}.w-full{width:100%}.min-w-0{min-width:0px}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.max-w-6xl{max-width:72rem}.max-w-lg{max-width:32rem}.max-w-sm{max-width:24rem}.flex-1{flex:1 1 0%}.flex-shrink-0,.shrink-0{flex-shrink:0}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-baseline{align-items:baseline}.items-stretch{align-items:stretch}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.space-y-0\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.125rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.125rem * var(--tw-space-y-reverse))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.375rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.break-all{word-break:break-all}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:.75rem}.rounded-t-\[26px\]{border-top-left-radius:26px;border-top-right-radius:26px}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-arcade-hibiscus{border-color:var(--arcade-hibiscus)}.border-arcade-leaf{border-color:var(--arcade-leaf)}.border-ink-900{border-color:var(--ink-900)}.border-input{border-color:hsl(var(--input))}.border-paper-300{border-color:var(--paper-300)}.border-transparent{border-color:transparent}.bg-arcade-lagoon{background-color:var(--arcade-lagoon)}.bg-arcade-sunshine{background-color:var(--arcade-sunshine)}.bg-background{background-color:hsl(var(--background))}.bg-paper-400{background-color:var(--paper-400)}.bg-paper-50{background-color:var(--paper-50)}.bg-transparent{background-color:transparent}.p-0{padding:0}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-10{padding:2.5rem}.p-2\.5{padding:.625rem}.p-3\.5{padding:.875rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.pb-16{padding-bottom:4rem}.pb-3{padding-bottom:.75rem}.pb-4{padding-bottom:1rem}.pb-8{padding-bottom:2rem}.pl-2{padding-left:.5rem}.pl-9{padding-left:2.25rem}.pr-10{padding-right:2.5rem}.pr-8{padding-right:2rem}.pt-1{padding-top:.25rem}.pt-2{padding-top:.5rem}.pt-3{padding-top:.75rem}.pt-5{padding-top:1.25rem}.pt-6{padding-top:1.5rem}.pt-7{padding-top:1.75rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:JetBrains Mono,ui-monospace,monospace}.font-pixel{font-family:Silkscreen,VT323,monospace}.font-rounded{font-family:Plus Jakarta Sans,ui-rounded,sans-serif}.text-2xl{font-size:1.5rem;line-height:2rem}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.leading-none{line-height:1}.leading-tight{line-height:1.25}.tracking-\[0\.22em\]{letter-spacing:.22em}.tracking-\[0\.3em\]{letter-spacing:.3em}.tracking-tight{letter-spacing:-.025em}.tracking-widest{letter-spacing:.1em}.text-arcade-hibiscus{color:var(--arcade-hibiscus)}.text-arcade-lagoon{color:var(--arcade-lagoon)}.text-arcade-leaf{color:var(--arcade-leaf)}.text-arcade-sunshine{color:var(--arcade-sunshine)}.text-current{color:currentColor}.text-ink-400{color:var(--ink-400)}.text-ink-600{color:var(--ink-600)}.text-ink-900{color:var(--ink-900)}.text-muted-foreground{color:hsl(var(--muted-foreground))}.underline{text-decoration-line:underline}.underline-offset-4{text-underline-offset:4px}.opacity-70{opacity:.7}.opacity-80{opacity:.8}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-pixel1{--tw-shadow: var(--shadow-pixel-1);--tw-shadow-colored: var(--shadow-pixel-1);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.ring-0{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-2{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-offset-background{--tw-ring-offset-color: hsl(var(--background))}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.pixelated{image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges;shape-rendering:crispEdges}.placeholder\:text-muted-foreground::-moz-placeholder{color:hsl(var(--muted-foreground))}.placeholder\:text-muted-foreground::placeholder{color:hsl(var(--muted-foreground))}.last\:border-b-0:last-child{border-bottom-width:0px}.hover\:border-ink-400:hover{border-color:var(--ink-400)}.hover\:border-ink-900:hover{border-color:var(--ink-900)}.hover\:bg-paper-200:hover{background-color:var(--paper-200)}.hover\:text-arcade-hibiscus:hover{color:var(--arcade-hibiscus)}.hover\:text-ink-900:hover{color:var(--ink-900)}.hover\:opacity-100:hover{opacity:1}.hover\:shadow-pixel1:hover{--tw-shadow: var(--shadow-pixel-1);--tw-shadow-colored: var(--shadow-pixel-1);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.focus\:bg-accent:focus{background-color:hsl(var(--accent))}.focus\:text-accent-foreground:focus{color:hsl(var(--accent-foreground))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-ring:focus{--tw-ring-color: hsl(var(--ring))}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color: hsl(var(--ring))}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width: 2px}.focus-visible\:ring-offset-background:focus-visible{--tw-ring-offset-color: hsl(var(--background))}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:translate-x-0\.5{--tw-translate-x: .125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.peer:disabled~.peer-disabled\:cursor-not-allowed{cursor:not-allowed}.peer:disabled~.peer-disabled\:opacity-70{opacity:.7}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=checked\]\:translate-x-4[data-state=checked]{--tw-translate-x: 1rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=unchecked\]\:translate-x-0[data-state=unchecked]{--tw-translate-x: 0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:hsl(var(--primary))}.data-\[state\=unchecked\]\:bg-input[data-state=unchecked]{background-color:hsl(var(--input))}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}@media(min-width:640px){.sm\:inline{display:inline}.sm\:w-72{width:18rem}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-end{align-items:flex-end}.sm\:justify-between{justify-content:space-between}.sm\:px-8{padding-left:2rem;padding-right:2rem}.sm\:pt-10{padding-top:2.5rem}.sm\:text-3xl{font-size:1.875rem;line-height:2.25rem}.sm\:text-sm{font-size:.875rem;line-height:1.25rem}}@media(min-width:1024px){.lg\:col-span-2{grid-column:span 2 / span 2}.lg\:col-span-3{grid-column:span 3 / span 3}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}}
1
+ :root{--paper-50: #fbf7ee;--paper-100: #f5efe1;--paper-200: #ede5d2;--paper-300: #ddd2b6;--paper-400: #c4b896;--ink-50: #f6f4ee;--ink-200: #a09c92;--ink-400: #5e5b54;--ink-600: #2c2b27;--ink-900: #16161a;--arcade-tangerine: #ff8a3d;--arcade-tangerine-soft: #ffd9bc;--arcade-tangerine-ink: #6b2f00;--arcade-lagoon: #2bbfd9;--arcade-lagoon-soft: #bff0f8;--arcade-lagoon-ink: #0a4a57;--arcade-leaf: #5fb84f;--arcade-leaf-soft: #cdebc4;--arcade-leaf-ink: #1d4a17;--arcade-hibiscus: #ff5470;--arcade-hibiscus-soft: #ffd1da;--arcade-hibiscus-ink: #71132a;--arcade-sunshine: #ffc83a;--arcade-sunshine-soft: #ffe9a8;--arcade-sunshine-ink: #6b4500;--arcade-lilac: #a875ff;--arcade-lilac-soft: #e0d0ff;--arcade-lilac-ink: #391a72;--white: #ffffff;--black: #000000;--pixel-grid: rgba(22, 22, 26, .06);--space-0: 0px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 28px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--font-2xs: 10px;--font-xs: 11px;--font-sm: 13px;--font-base: 14px;--font-md: 15px;--font-lg: 18px;--font-xl: 22px;--font-2xl: 28px;--font-3xl: 38px;--radius-none: 0px;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-2xl: 28px;--radius-full: 9999px;--weight-regular: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--weight-black: 800;--font-sans: "Inter Tight", -apple-system, BlinkMacSystemFont, "SF Pro Text", "PingFang SC", "Hiragino Sans GB", system-ui, sans-serif;--font-rounded: ui-rounded, "SF Pro Rounded", "Plus Jakarta Sans", "Inter Tight", -apple-system, sans-serif;--font-pixel: "Silkscreen", "VT323", "Press Start 2P", ui-monospace, monospace;--font-mono: "JetBrains Mono", "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--shadow-soft-1: 0 1px 1px rgba(22, 22, 26, .04), 0 4px 12px rgba(22, 22, 26, .06);--shadow-soft-2: 0 1px 1px rgba(22, 22, 26, .05), 0 12px 28px rgba(22, 22, 26, .1);--shadow-soft-3: 0 2px 4px rgba(22, 22, 26, .06), 0 24px 48px rgba(22, 22, 26, .14);--shadow-pixel-1: 2px 2px 0 0 var(--ink-900);--shadow-pixel-2: 4px 4px 0 0 var(--ink-900);--shadow-pixel-3: 6px 6px 0 0 var(--ink-900);--shadow-inset: inset 0 1px 0 rgba(255, 255, 255, .7), inset 0 -1px 0 rgba(22, 22, 26, .06);--ease-out-quart: cubic-bezier(.25, 1, .5, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--dur-fast: .12s;--dur-base: .2s;--dur-slow: .32s}:root{--color-bg-base: var(--paper-100);--color-bg-surface: var(--paper-50);--color-bg-surface-muted: var(--paper-200);--color-bg-overlay: rgb(22 22 26 / .42);--color-bg-elevated: var(--white);--color-text-primary: var(--ink-900);--color-text-secondary: var(--ink-600);--color-text-muted: var(--ink-400);--color-text-faint: var(--ink-200);--color-text-inverse: var(--paper-50);--color-text-mono: var(--ink-900);--color-accent: var(--arcade-tangerine);--color-accent-hover: #f0782b;--color-accent-soft: var(--arcade-tangerine-soft);--color-accent-on-soft: var(--arcade-tangerine-ink);--color-accent-foreground: var(--ink-900);--color-success: var(--arcade-leaf);--color-success-soft: var(--arcade-leaf-soft);--color-success-on-soft: var(--arcade-leaf-ink);--color-success-dot: var(--arcade-leaf);--color-warning: var(--arcade-sunshine);--color-warning-soft: var(--arcade-sunshine-soft);--color-warning-on-soft: var(--arcade-sunshine-ink);--color-warning-border: var(--arcade-sunshine);--color-danger: var(--arcade-hibiscus);--color-danger-hover: #ef3357;--color-danger-soft: var(--arcade-hibiscus-soft);--color-danger-on-soft: var(--arcade-hibiscus-ink);--color-info: var(--arcade-lagoon);--color-info-soft: var(--arcade-lagoon-soft);--color-info-on-soft: var(--arcade-lagoon-ink);--color-special: var(--arcade-lilac);--color-special-soft: var(--arcade-lilac-soft);--color-special-on-soft: var(--arcade-lilac-ink);--color-border: var(--paper-300);--color-border-muted: var(--paper-200);--color-border-strong: var(--ink-900);--color-focus-ring: var(--arcade-lagoon);--space-inline: var(--space-2);--space-block: var(--space-4);--space-section: var(--space-6);--radius-control: var(--radius-md);--radius-card: var(--radius-lg);--radius-pill: var(--radius-full)}:root{--app-bg: var(--color-bg-base);--app-text: var(--color-text-primary);--card-bg: var(--color-bg-surface);--card-bg-raised: var(--color-bg-elevated);--card-border: var(--color-border-strong);--card-border-soft: var(--color-border);--card-text: var(--color-text-primary);--card-text-muted: var(--color-text-muted);--card-radius: var(--radius-card);--card-padding: var(--space-block);--card-shadow: var(--shadow-soft-1);--card-shadow-raised: var(--shadow-pixel-2);--card-shadow-press: var(--shadow-pixel-1);--button-bg: var(--color-accent);--button-bg-hover: var(--color-accent-hover);--button-text: var(--color-accent-foreground);--button-radius: var(--radius-control);--button-padding: var(--space-2) var(--space-4);--button-border: var(--ink-900);--button-shadow: var(--shadow-pixel-1);--button-shadow-hover: var(--shadow-pixel-2);--button-danger-bg: var(--color-danger);--button-danger-bg-hover: var(--color-danger-hover);--button-danger-text: var(--color-text-inverse);--button-ghost-text: var(--color-text-secondary);--button-ghost-hover-bg: var(--paper-200);--input-bg: var(--color-bg-elevated);--input-border: var(--color-border);--input-border-strong: var(--ink-900);--input-text: var(--color-text-primary);--input-placeholder: var(--color-text-faint);--input-radius: var(--radius-control);--input-shadow: var(--shadow-inset);--input-focus-ring: var(--color-focus-ring);--badge-bg: var(--color-bg-surface-muted);--badge-text: var(--color-text-muted);--badge-radius: var(--radius-pill);--badge-success-bg: var(--color-success-soft);--badge-success-text: var(--color-success-on-soft);--badge-warning-bg: var(--color-warning-soft);--badge-warning-text: var(--color-warning-on-soft);--badge-info-bg: var(--color-info-soft);--badge-info-text: var(--color-info-on-soft);--badge-special-bg: var(--color-special-soft);--badge-special-text: var(--color-special-on-soft);--status-online-text: var(--color-success-on-soft);--status-online-dot: var(--color-success-dot);--status-offline-text: var(--color-danger-on-soft);--status-offline-dot: var(--color-danger);--banner-warning-bg: var(--color-warning-soft);--banner-warning-border: var(--color-warning-border);--banner-warning-text: var(--color-warning-on-soft);--banner-success-bg: var(--color-success-soft);--banner-success-border: var(--color-success);--banner-success-text: var(--color-success-on-soft);--banner-error-bg: var(--color-danger-soft);--banner-error-border: var(--color-danger);--banner-error-text: var(--color-danger-on-soft);--banner-info-bg: var(--color-info-soft);--banner-info-border: var(--color-info);--banner-info-text: var(--color-info-on-soft);--code-text: var(--color-text-mono);--code-text-faint: var(--color-text-faint);--code-bg: var(--paper-200);--tabs-bg: transparent;--tabs-trigger-text: var(--color-text-secondary);--tabs-trigger-active-bg: var(--color-bg-elevated);--tabs-trigger-active-text: var(--color-text-primary);--tabs-trigger-active-border: var(--ink-900);--sheet-bg: var(--color-bg-elevated);--sheet-overlay: var(--color-bg-overlay)}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter Tight,system-ui,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:JetBrains Mono,ui-monospace,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--background: 40 53% 92%;--foreground: 240 10% 9%;--card: 38 56% 96%;--card-foreground: 240 10% 9%;--popover: 38 56% 96%;--popover-foreground: 240 10% 9%;--primary: 23 100% 62%;--primary-foreground: 240 10% 9%;--secondary: 40 39% 82%;--secondary-foreground: 240 10% 9%;--muted: 40 39% 88%;--muted-foreground: 36 5% 36%;--accent: 40 39% 86%;--accent-foreground: 240 10% 9%;--destructive: 350 100% 66%;--destructive-foreground: 0 0% 100%;--border: 38 26% 78%;--input: 38 26% 78%;--ring: 188 70% 51%;--radius: .875rem}html,body,#root{height:100%}*{border-color:hsl(var(--border))}body{background:var(--app-bg);color:var(--app-text);font-family:var(--font-sans);font-feature-settings:"ss01","cv11";-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{background-color:var(--paper-100);background-image:radial-gradient(ellipse 80% 60% at 12% 8%,rgba(255,138,61,.16),transparent 60%),radial-gradient(ellipse 70% 60% at 92% 18%,rgba(43,191,217,.16),transparent 60%),radial-gradient(ellipse 65% 55% at 80% 95%,rgba(168,117,255,.12),transparent 60%),linear-gradient(var(--pixel-grid) 1px,transparent 1px),linear-gradient(90deg,var(--pixel-grid) 1px,transparent 1px);background-size:auto,auto,auto,20px 20px,20px 20px;background-position:0 0,0 0,0 0,-1px -1px,-1px -1px;background-attachment:fixed}::-moz-selection{background:var(--arcade-sunshine);color:var(--ink-900)}::selection{background:var(--arcade-sunshine);color:var(--ink-900)}.container{width:100%;margin-right:auto;margin-left:auto;padding-right:2rem;padding-left:2rem}@media(min-width:1400px){.container{max-width:1400px}}.font-pixel{font-family:var(--font-pixel);letter-spacing:.02em}.font-rounded{font-family:var(--font-rounded);letter-spacing:-.01em}.font-mono{font-family:var(--font-mono)}.arcade-card{background:var(--card-bg);border:1.5px solid var(--card-border);border-radius:var(--card-radius);box-shadow:var(--card-shadow-raised);transition:box-shadow var(--dur-base) var(--ease-out-quart),transform var(--dur-base) var(--ease-out-quart)}.arcade-card-soft{background:var(--card-bg);border:1px solid var(--card-border-soft);border-radius:var(--card-radius);box-shadow:var(--card-shadow)}.arcade-card-press:hover{transform:translate(-1px,-1px);box-shadow:var(--shadow-pixel-3)}.arcade-card-press:active{transform:translate(2px,2px);box-shadow:0 0 0 0 var(--ink-900)}.arcade-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--button-padding);font-family:var(--font-rounded);font-weight:var(--weight-semibold);font-size:var(--font-sm);color:var(--button-text);background:var(--button-bg);border:1.5px solid var(--button-border);border-radius:var(--button-radius);box-shadow:var(--button-shadow);cursor:pointer;transition:transform var(--dur-fast) var(--ease-out-quart),box-shadow var(--dur-fast) var(--ease-out-quart),background var(--dur-fast) var(--ease-out-quart);-webkit-user-select:none;-moz-user-select:none;user-select:none;white-space:nowrap}.arcade-btn:hover{background:var(--button-bg-hover);transform:translate(-1px,-1px);box-shadow:var(--button-shadow-hover)}.arcade-btn:active{transform:translate(2px,2px);box-shadow:0 0 0 0 var(--ink-900)}.arcade-btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.arcade-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:var(--button-shadow)}.arcade-btn-ghost{background:transparent;border-color:transparent;box-shadow:none;color:var(--button-ghost-text)}.arcade-btn-ghost:hover{background:var(--button-ghost-hover-bg);transform:none;box-shadow:none}.arcade-btn-ghost:active{transform:none;box-shadow:none}.arcade-btn-outline{background:var(--color-bg-elevated);color:var(--ink-900)}.arcade-btn-outline:hover{background:var(--paper-100)}.arcade-btn-danger{background:var(--button-danger-bg);color:var(--button-danger-text)}.arcade-btn-danger:hover{background:var(--button-danger-bg-hover)}.arcade-btn-sm{font-size:var(--font-xs);padding:var(--space-1) var(--space-3)}.pixel-chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px 8px;font-family:var(--font-pixel);font-size:var(--font-2xs);letter-spacing:.06em;text-transform:uppercase;background:var(--badge-bg);color:var(--badge-text);border-radius:var(--radius-sm);border:1px solid var(--color-border);line-height:1.4}.pixel-chip-success{background:var(--badge-success-bg);color:var(--badge-success-text);border-color:var(--color-success)}.pixel-chip-info{background:var(--badge-info-bg);color:var(--badge-info-text);border-color:var(--arcade-lagoon)}.pixel-chip-tangerine{background:var(--arcade-tangerine-soft);color:var(--arcade-tangerine-ink);border-color:var(--arcade-tangerine)}.arcade-input{width:100%;background:var(--input-bg);border:1.5px solid var(--input-border);border-radius:var(--input-radius);padding:var(--space-2) var(--space-3);font-family:var(--font-sans);font-size:var(--font-sm);color:var(--input-text);transition:border-color var(--dur-fast) var(--ease-out-quart),box-shadow var(--dur-fast) var(--ease-out-quart)}.arcade-input::-moz-placeholder{color:var(--input-placeholder)}.arcade-input::placeholder{color:var(--input-placeholder)}.arcade-input:focus,.arcade-input:focus-visible{outline:none;border-color:var(--input-border-strong);box-shadow:var(--shadow-pixel-1)}.arcade-input:disabled{background:var(--paper-200);color:var(--color-text-muted)}.status-online{color:var(--status-online-text)}.status-online-dot{background:var(--status-online-dot);box-shadow:0 0 0 3px #5fb84f33;animation:pulse-online 2s ease-in-out infinite}.status-offline{color:var(--status-offline-text)}.status-offline-dot{background:var(--status-offline-dot);box-shadow:0 0 0 3px #ff547033}@keyframes pulse-online{0%,to{box-shadow:0 0 0 3px #5fb84f2e}50%{box-shadow:0 0 0 6px #5fb84f0f}}.banner-warning{background:var(--banner-warning-bg);border:1.5px solid var(--banner-warning-border);color:var(--banner-warning-text);border-radius:var(--radius-md)}.banner-success{background:var(--banner-success-bg);border:1.5px solid var(--banner-success-border);color:var(--banner-success-text);border-radius:var(--radius-md)}.banner-error{background:var(--banner-error-bg);border:1.5px solid var(--banner-error-border);color:var(--banner-error-text);border-radius:var(--radius-md)}.code-mono{font-family:var(--font-mono);color:var(--code-text)}.arcade-tabs-list{display:inline-flex;gap:var(--space-1);padding:var(--space-1);background:var(--color-bg-surface-muted);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-inset)}.arcade-tabs-trigger{padding:var(--space-2) var(--space-4);font-family:var(--font-rounded);font-weight:var(--weight-semibold);font-size:var(--font-sm);color:var(--tabs-trigger-text);border-radius:var(--radius-lg);transition:all var(--dur-base) var(--ease-out-quart);cursor:pointer;display:inline-flex;align-items:center;gap:var(--space-2)}.arcade-tabs-trigger[data-state=active]{background:var(--tabs-trigger-active-bg);color:var(--tabs-trigger-active-text);box-shadow:var(--shadow-soft-1)}.arcade-tabs-trigger:hover{color:var(--tabs-trigger-active-text)}.provider-halo{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:var(--radius-lg);border:1.5px solid var(--ink-900);background:var(--paper-50);box-shadow:var(--shadow-pixel-1);flex-shrink:0}.provider-halo-sm{width:40px;height:40px;border-radius:var(--radius-md)}.sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--sheet-overlay);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:40;animation:fade-in var(--dur-base) var(--ease-out-quart)}.sheet-panel{position:fixed;z-index:50;background:var(--sheet-bg);border:1.5px solid var(--ink-900);border-radius:var(--radius-2xl);box-shadow:var(--shadow-pixel-3),var(--shadow-soft-3)}.sheet-panel-center{top:50%;left:50%;transform:translate(-50%,-50%);width:min(92vw,540px);max-height:88vh;overflow-y:auto;animation:sheet-pop var(--dur-base) var(--ease-spring)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes sheet-pop{0%{opacity:0;transform:translate(-50%,-50%) scale(.92)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.crt-scanline{position:relative;overflow:hidden}.crt-scanline:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:repeating-linear-gradient(0deg,rgba(22,22,26,.05) 0,rgba(22,22,26,.05) 1px,transparent 1px,transparent 4px);opacity:.4}.section-kicker{font-family:var(--font-pixel);font-size:var(--font-2xs);letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-muted)}.section-title{font-family:var(--font-rounded);font-weight:var(--weight-bold);font-size:var(--font-2xl);line-height:1.1;letter-spacing:-.02em;color:var(--color-text-primary)}.section-sub{font-family:var(--font-sans);font-size:var(--font-sm);color:var(--color-text-muted);line-height:1.5}.pointer-events-none{pointer-events:none}.absolute{position:absolute}.relative{position:relative}.inset-x-0{left:0;right:0}.-bottom-5{bottom:-1.25rem}.bottom-0{bottom:0}.left-0{left:0}.left-3{left:.75rem}.left-4{left:1rem}.right-0{right:0}.right-1\.5{right:.375rem}.right-2{right:.5rem}.right-3{right:.75rem}.top-0{top:0}.top-1\/2{top:50%}.top-3{top:.75rem}.z-20{z-index:20}.z-50{z-index:50}.mx-auto{margin-left:auto;margin-right:auto}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.ml-1{margin-left:.25rem}.mr-2{margin-right:.5rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-12{margin-top:3rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-6{margin-top:1.5rem}.mt-auto{margin-top:auto}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-14{height:3.5rem}.h-2{height:.5rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-9{height:2.25rem}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-full{height:100%}.h-screen{height:100vh}.max-h-48{max-height:12rem}.max-h-96{max-height:24rem}.min-h-screen{min-height:100vh}.w-1\.5{width:.375rem}.w-12{width:3rem}.w-14{width:3.5rem}.w-2{width:.5rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-9{width:2.25rem}.w-full{width:100%}.min-w-0{min-width:0px}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.max-w-6xl{max-width:72rem}.max-w-lg{max-width:32rem}.max-w-sm{max-width:24rem}.flex-1{flex:1 1 0%}.flex-shrink-0,.shrink-0{flex-shrink:0}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-baseline{align-items:baseline}.items-stretch{align-items:stretch}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.space-y-0\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.125rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.125rem * var(--tw-space-y-reverse))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.375rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.break-all{word-break:break-all}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:.75rem}.rounded-t-\[26px\]{border-top-left-radius:26px;border-top-right-radius:26px}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-arcade-hibiscus{border-color:var(--arcade-hibiscus)}.border-arcade-leaf{border-color:var(--arcade-leaf)}.border-ink-900{border-color:var(--ink-900)}.border-input{border-color:hsl(var(--input))}.border-paper-300{border-color:var(--paper-300)}.border-transparent{border-color:transparent}.bg-arcade-lagoon{background-color:var(--arcade-lagoon)}.bg-arcade-sunshine{background-color:var(--arcade-sunshine)}.bg-background{background-color:hsl(var(--background))}.bg-paper-400{background-color:var(--paper-400)}.bg-paper-50{background-color:var(--paper-50)}.bg-transparent{background-color:transparent}.p-0{padding:0}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-10{padding:2.5rem}.p-2\.5{padding:.625rem}.p-3\.5{padding:.875rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.pb-16{padding-bottom:4rem}.pb-3{padding-bottom:.75rem}.pb-4{padding-bottom:1rem}.pb-8{padding-bottom:2rem}.pl-2{padding-left:.5rem}.pl-9{padding-left:2.25rem}.pr-10{padding-right:2.5rem}.pr-8{padding-right:2rem}.pt-1{padding-top:.25rem}.pt-2{padding-top:.5rem}.pt-3{padding-top:.75rem}.pt-5{padding-top:1.25rem}.pt-6{padding-top:1.5rem}.pt-7{padding-top:1.75rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:JetBrains Mono,ui-monospace,monospace}.font-pixel{font-family:Silkscreen,VT323,monospace}.font-rounded{font-family:Plus Jakarta Sans,ui-rounded,sans-serif}.text-2xl{font-size:1.5rem;line-height:2rem}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.leading-none{line-height:1}.leading-tight{line-height:1.25}.tracking-\[0\.22em\]{letter-spacing:.22em}.tracking-\[0\.3em\]{letter-spacing:.3em}.tracking-tight{letter-spacing:-.025em}.tracking-widest{letter-spacing:.1em}.text-arcade-hibiscus{color:var(--arcade-hibiscus)}.text-arcade-lagoon{color:var(--arcade-lagoon)}.text-arcade-leaf{color:var(--arcade-leaf)}.text-arcade-sunshine{color:var(--arcade-sunshine)}.text-current{color:currentColor}.text-ink-400{color:var(--ink-400)}.text-ink-600{color:var(--ink-600)}.text-ink-900{color:var(--ink-900)}.text-muted-foreground{color:hsl(var(--muted-foreground))}.underline{text-decoration-line:underline}.underline-offset-4{text-underline-offset:4px}.opacity-70{opacity:.7}.opacity-80{opacity:.8}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-pixel1{--tw-shadow: var(--shadow-pixel-1);--tw-shadow-colored: var(--shadow-pixel-1);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.ring-0{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-2{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-offset-background{--tw-ring-offset-color: hsl(var(--background))}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.pixelated{image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges;shape-rendering:crispEdges}.placeholder\:text-muted-foreground::-moz-placeholder{color:hsl(var(--muted-foreground))}.placeholder\:text-muted-foreground::placeholder{color:hsl(var(--muted-foreground))}.last\:border-b-0:last-child{border-bottom-width:0px}.hover\:border-ink-400:hover{border-color:var(--ink-400)}.hover\:border-ink-900:hover{border-color:var(--ink-900)}.hover\:bg-paper-200:hover{background-color:var(--paper-200)}.hover\:text-arcade-hibiscus:hover{color:var(--arcade-hibiscus)}.hover\:text-ink-900:hover{color:var(--ink-900)}.hover\:opacity-100:hover{opacity:1}.hover\:shadow-pixel1:hover{--tw-shadow: var(--shadow-pixel-1);--tw-shadow-colored: var(--shadow-pixel-1);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.focus\:bg-accent:focus{background-color:hsl(var(--accent))}.focus\:text-accent-foreground:focus{color:hsl(var(--accent-foreground))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-ring:focus{--tw-ring-color: hsl(var(--ring))}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color: hsl(var(--ring))}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width: 2px}.focus-visible\:ring-offset-background:focus-visible{--tw-ring-offset-color: hsl(var(--background))}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:translate-x-0\.5{--tw-translate-x: .125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.peer:disabled~.peer-disabled\:cursor-not-allowed{cursor:not-allowed}.peer:disabled~.peer-disabled\:opacity-70{opacity:.7}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=checked\]\:translate-x-4[data-state=checked]{--tw-translate-x: 1rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=unchecked\]\:translate-x-0[data-state=unchecked]{--tw-translate-x: 0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:hsl(var(--primary))}.data-\[state\=unchecked\]\:bg-input[data-state=unchecked]{background-color:hsl(var(--input))}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}@media(min-width:640px){.sm\:inline{display:inline}.sm\:w-72{width:18rem}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-end{align-items:flex-end}.sm\:justify-between{justify-content:space-between}.sm\:px-8{padding-left:2rem;padding-right:2rem}.sm\:pt-10{padding-top:2.5rem}.sm\:text-3xl{font-size:1.875rem;line-height:2.25rem}.sm\:text-sm{font-size:.875rem;line-height:1.25rem}}@media(min-width:1024px){.lg\:col-span-2{grid-column:span 2 / span 2}.lg\:col-span-3{grid-column:span 3 / span 3}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}}
@@ -12,8 +12,8 @@
12
12
  href="https://fonts.googleapis.com/css2?family=Inter+Tight:wght@400;500;600;700;800&family=Plus+Jakarta+Sans:wght@500;600;700;800&family=Silkscreen:wght@400;700&family=VT323&family=JetBrains+Mono:wght@400;500;600&display=swap"
13
13
  rel="stylesheet"
14
14
  />
15
- <script type="module" crossorigin src="./assets/index-ClqmrjNk.js"></script>
16
- <link rel="stylesheet" crossorigin href="./assets/index-CwMwQ-Z4.css">
15
+ <script type="module" crossorigin src="./assets/index-7kowlJw9.js"></script>
16
+ <link rel="stylesheet" crossorigin href="./assets/index-DnC-lskL.css">
17
17
  </head>
18
18
  <body>
19
19
  <div id="root"></div>
package/dist/update.d.ts CHANGED
@@ -1,11 +1,22 @@
1
1
  /**
2
2
  * Update checker + one-shot upgrade command.
3
3
  *
4
- * - checkForUpdates() runs at startup. It defers to `update-notifier`, which
5
- * forks a child to query the npm registry and caches the result for a day.
6
- * The notification is printed on the NEXT run (defer:false here makes it
7
- * print at process exit of the current run if a cached result is already
8
- * present).
4
+ * Why not `update-notifier`? Its background-check path proved unreliable here:
5
+ * the detached child it spawns to query the registry never persisted a result
6
+ * to configstore, so the "update available" banner effectively never fired —
7
+ * and even when it works it's deferred by one run and rate-limited to once/day,
8
+ * so a freshly published version isn't noticed for up to a day. We replaced it
9
+ * with a self-managed check:
10
+ *
11
+ * - checkForUpdates() runs at startup. It reads a small cache
12
+ * (~/.mcc/update-cache.json). If the cache already knows a newer version, the
13
+ * banner prints on THIS run (registered at process 'exit' so it lands on the
14
+ * clean shell prompt after Claude's TUI closes — not buried under it). If the
15
+ * cache is stale, it kicks off an in-process registry fetch that writes the
16
+ * cache. The fetch's socket is unref'd, so it never delays a fast command
17
+ * like `mcc -v`; on the long-lived `mcc <profile>` launch path the spawned
18
+ * `claude` keeps the event loop alive, so the fetch completes and the cache
19
+ * refreshes for next time.
9
20
  *
10
21
  * - runUpdate() detects how the binary was installed (npm/pnpm/yarn/bun) and
11
22
  * invokes the matching `add -g` command. Detection is a path heuristic; the
@@ -1 +1 @@
1
- {"version":3,"file":"update.d.ts","sourceRoot":"","sources":["../src/update.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAQH,KAAK,cAAc,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,KAAK,CAAC;AAItD,wBAAgB,eAAe,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI,CAwB5D;AAED;;;;;;;GAOG;AACH,wBAAgB,oBAAoB,IAAI,cAAc,CASrD;AAYD,wBAAsB,SAAS,CAAC,IAAI,GAAE;IAAE,SAAS,CAAC,EAAE,OAAO,CAAC;IAAC,UAAU,CAAC,EAAE,cAAc,CAAA;CAAO,GAAG,OAAO,CAAC,IAAI,CAAC,CAoD9G;AAYD,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI,CAc/D"}
1
+ {"version":3,"file":"update.d.ts","sourceRoot":"","sources":["../src/update.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AASH,KAAK,cAAc,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,KAAK,CAAC;AAmHtD,wBAAgB,eAAe,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI,CAuB5D;AAED;;;;;;;GAOG;AACH,wBAAgB,oBAAoB,IAAI,cAAc,CASrD;AAYD,wBAAsB,SAAS,CAAC,IAAI,GAAE;IAAE,SAAS,CAAC,EAAE,OAAO,CAAC;IAAC,UAAU,CAAC,EAAE,cAAc,CAAA;CAAO,GAAG,OAAO,CAAC,IAAI,CAAC,CAkD9G;AAYD,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI,CAc/D"}
package/dist/update.js CHANGED
@@ -2,11 +2,22 @@
2
2
  /**
3
3
  * Update checker + one-shot upgrade command.
4
4
  *
5
- * - checkForUpdates() runs at startup. It defers to `update-notifier`, which
6
- * forks a child to query the npm registry and caches the result for a day.
7
- * The notification is printed on the NEXT run (defer:false here makes it
8
- * print at process exit of the current run if a cached result is already
9
- * present).
5
+ * Why not `update-notifier`? Its background-check path proved unreliable here:
6
+ * the detached child it spawns to query the registry never persisted a result
7
+ * to configstore, so the "update available" banner effectively never fired —
8
+ * and even when it works it's deferred by one run and rate-limited to once/day,
9
+ * so a freshly published version isn't noticed for up to a day. We replaced it
10
+ * with a self-managed check:
11
+ *
12
+ * - checkForUpdates() runs at startup. It reads a small cache
13
+ * (~/.mcc/update-cache.json). If the cache already knows a newer version, the
14
+ * banner prints on THIS run (registered at process 'exit' so it lands on the
15
+ * clean shell prompt after Claude's TUI closes — not buried under it). If the
16
+ * cache is stale, it kicks off an in-process registry fetch that writes the
17
+ * cache. The fetch's socket is unref'd, so it never delays a fast command
18
+ * like `mcc -v`; on the long-lived `mcc <profile>` launch path the spawned
19
+ * `claude` keeps the event loop alive, so the fetch completes and the cache
20
+ * refreshes for next time.
10
21
  *
11
22
  * - runUpdate() detects how the binary was installed (npm/pnpm/yarn/bun) and
12
23
  * invokes the matching `add -g` command. Detection is a path heuristic; the
@@ -54,34 +65,138 @@ exports.detectPackageManager = detectPackageManager;
54
65
  exports.runUpdate = runUpdate;
55
66
  exports.setUpdateCheckCmd = setUpdateCheckCmd;
56
67
  const child_process_1 = require("child_process");
68
+ const fs = __importStar(require("fs"));
69
+ const https = __importStar(require("https"));
57
70
  const path = __importStar(require("path"));
58
71
  const picocolors_1 = __importDefault(require("picocolors"));
59
- const update_notifier_1 = __importDefault(require("update-notifier"));
60
72
  const config_1 = require("./shared/config");
61
73
  const PKG_NAME = '@hileeon/mcc';
74
+ // How long a cached registry result is trusted before we refresh in the
75
+ // background. The refresh is free (backgrounded + unref'd), so this is just a
76
+ // politeness throttle on registry hits, not a freshness ceiling the user feels.
77
+ const CHECK_INTERVAL_MS = 1000 * 60 * 60; // 1 hour
78
+ function getCachePath() {
79
+ return path.join((0, config_1.getMccHome)(), 'update-cache.json');
80
+ }
81
+ function readCache() {
82
+ try {
83
+ return JSON.parse(fs.readFileSync(getCachePath(), 'utf8'));
84
+ }
85
+ catch {
86
+ return null;
87
+ }
88
+ }
89
+ function writeCache(cache) {
90
+ try {
91
+ const home = (0, config_1.getMccHome)();
92
+ if (!fs.existsSync(home))
93
+ fs.mkdirSync(home, { recursive: true });
94
+ fs.writeFileSync(getCachePath(), JSON.stringify(cache));
95
+ }
96
+ catch {
97
+ // Cache is best-effort; a write failure just means we re-check next run.
98
+ }
99
+ }
100
+ /** Strict-enough semver compare for this project's plain x.y.z versions. */
101
+ function parseVersion(v) {
102
+ return v.split('-')[0].split('.').map((n) => parseInt(n, 10) || 0);
103
+ }
104
+ function isNewer(latest, current) {
105
+ const a = parseVersion(latest);
106
+ const b = parseVersion(current);
107
+ for (let i = 0; i < 3; i++) {
108
+ const x = a[i] ?? 0;
109
+ const y = b[i] ?? 0;
110
+ if (x > y)
111
+ return true;
112
+ if (x < y)
113
+ return false;
114
+ }
115
+ return false;
116
+ }
117
+ /**
118
+ * Fetch the latest published version straight from the npm registry over native
119
+ * https — no transitive dependency, no detached child. Resolves to null on any
120
+ * failure (offline, registry error, timeout).
121
+ *
122
+ * `background: true` unref's the socket so a pending request never keeps a
123
+ * fast-exiting command (e.g. `mcc -v`) alive — used by the startup check, where
124
+ * the result is fire-and-forget. The awaited `mcc update --check` path must NOT
125
+ * unref: with the promise suspended, an unref'd socket is the only thing left to
126
+ * keep the loop alive, so Node would exit 0 before the fetch resolves.
127
+ */
128
+ function fetchLatest(opts = {}) {
129
+ const { timeoutMs = 5000, background = false } = opts;
130
+ return new Promise((resolve) => {
131
+ // The `/latest` endpoint returns the latest dist-tag's manifest, which has
132
+ // `.version`. Note: do NOT send the abbreviated-metadata Accept header here —
133
+ // that content-type only applies to the full packument, and `/latest`
134
+ // answers it with 406 Not Acceptable.
135
+ const url = `https://registry.npmjs.org/${PKG_NAME.replace('/', '%2F')}/latest`;
136
+ const req = https.get(url, (res) => {
137
+ if (res.statusCode !== 200) {
138
+ res.resume();
139
+ return resolve(null);
140
+ }
141
+ let body = '';
142
+ res.on('data', (c) => (body += c));
143
+ res.on('end', () => {
144
+ try {
145
+ resolve(JSON.parse(body).version ?? null);
146
+ }
147
+ catch {
148
+ resolve(null);
149
+ }
150
+ });
151
+ });
152
+ req.on('error', () => resolve(null));
153
+ req.setTimeout(timeoutMs, () => {
154
+ req.destroy();
155
+ resolve(null);
156
+ });
157
+ // For the background startup check, don't let an in-flight request hold the
158
+ // process open on its own. (Never unref on the awaited path — see above.)
159
+ if (background)
160
+ req.on('socket', (s) => s.unref());
161
+ });
162
+ }
163
+ let bannerArmed = false;
164
+ function armBanner(current, latest) {
165
+ if (bannerArmed)
166
+ return;
167
+ bannerArmed = true;
168
+ // Print at exit so it lands on the clean shell prompt — after Claude's
169
+ // full-screen TUI has closed — instead of scrolling away behind it.
170
+ process.on('exit', () => {
171
+ process.stderr.write('\n' +
172
+ ` ${picocolors_1.default.yellow('✨ Update available')} ${picocolors_1.default.dim(current)} → ${picocolors_1.default.green(latest)}\n` +
173
+ ` Run ${picocolors_1.default.cyan('mcc update')} to upgrade ${picocolors_1.default.dim('·')} ` +
174
+ `${picocolors_1.default.dim('silence with')} ${picocolors_1.default.cyan('mcc update-check off')}\n\n`);
175
+ });
176
+ }
62
177
  function checkForUpdates(currentVersion) {
63
178
  if (!(0, config_1.isUpdateCheckEnabled)())
64
179
  return;
65
180
  if (process.env.CI || process.env.MCC_NO_UPDATE_NOTIFIER)
66
181
  return;
67
182
  try {
68
- const notifier = (0, update_notifier_1.default)({
69
- pkg: { name: PKG_NAME, version: currentVersion },
70
- updateCheckInterval: 1000 * 60 * 60 * 24, // 1 day
71
- shouldNotifyInNpmScript: false,
72
- });
73
- if (notifier.update) {
74
- notifier.notify({
75
- defer: false,
76
- isGlobal: true,
77
- message: `Update available ${picocolors_1.default.dim('{currentVersion}')} ${picocolors_1.default.green('{latestVersion}')}\n` +
78
- `Run ${picocolors_1.default.cyan('mcc update')} to upgrade\n` +
79
- `${picocolors_1.default.dim('Disable with `mcc update-check off`')}`,
183
+ const cache = readCache();
184
+ // If we already know about a newer version, surface it on this run.
185
+ if (cache?.latest && isNewer(cache.latest, currentVersion)) {
186
+ armBanner(currentVersion, cache.latest);
187
+ }
188
+ // Refresh in the background when the cache is missing or stale. Fire and
189
+ // forget — unref'd, so it never delays exit.
190
+ const stale = !cache || Date.now() - cache.lastCheck > CHECK_INTERVAL_MS;
191
+ if (stale) {
192
+ void fetchLatest({ background: true }).then((latest) => {
193
+ if (latest)
194
+ writeCache({ lastCheck: Date.now(), latest });
80
195
  });
81
196
  }
82
197
  }
83
198
  catch {
84
- // Network failures, registry errors, etc. never block the CLI.
199
+ // Never let the update check block or crash the CLI.
85
200
  }
86
201
  }
87
202
  /**
@@ -117,26 +232,21 @@ function buildInstallCommand(pm, target) {
117
232
  async function runUpdate(opts = {}) {
118
233
  const pm = opts.pmOverride ?? detectPackageManager();
119
234
  if (opts.checkOnly) {
120
- // Force a synchronous check by asking update-notifier directly. We do this
121
- // via fetchInfo() so we don't depend on the deferred notification path.
122
- const notifier = (0, update_notifier_1.default)({
123
- pkg: { name: PKG_NAME, version: getOwnVersion() },
124
- updateCheckInterval: 0,
125
- });
126
- try {
127
- const info = await notifier.fetchInfo();
128
- if (info.type === 'latest') {
129
- console.log(`${picocolors_1.default.green('✓')} mcc is up to date (${info.current})`);
130
- }
131
- else {
132
- console.log(`${picocolors_1.default.yellow('!')} Update available: ${picocolors_1.default.dim(info.current)} → ${picocolors_1.default.green(info.latest)}`);
133
- console.log(` Run ${picocolors_1.default.cyan('mcc update')} to upgrade`);
134
- }
135
- }
136
- catch (e) {
137
- console.error(`[!] Could not reach the npm registry: ${e.message}`);
235
+ const current = getOwnVersion();
236
+ const latest = await fetchLatest();
237
+ if (latest === null) {
238
+ console.error(`[!] Could not reach the npm registry.`);
138
239
  process.exit(1);
139
240
  }
241
+ if (isNewer(latest, current)) {
242
+ console.log(`${picocolors_1.default.yellow('!')} Update available: ${picocolors_1.default.dim(current)} → ${picocolors_1.default.green(latest)}`);
243
+ console.log(` Run ${picocolors_1.default.cyan('mcc update')} to upgrade`);
244
+ }
245
+ else {
246
+ console.log(`${picocolors_1.default.green('✓')} mcc is up to date (${current})`);
247
+ }
248
+ // Keep the cache warm so the next launch reflects what we just learned.
249
+ writeCache({ lastCheck: Date.now(), latest });
140
250
  return;
141
251
  }
142
252
  const target = `${PKG_NAME}@latest`;
@@ -156,6 +266,8 @@ async function runUpdate(opts = {}) {
156
266
  });
157
267
  child.on('exit', (code) => {
158
268
  if (code === 0) {
269
+ // Clear the stale "update available" cache so we don't nag post-upgrade.
270
+ writeCache({ lastCheck: Date.now(), latest: getOwnVersion() });
159
271
  console.log(`\n${picocolors_1.default.green('✓')} mcc upgraded. Run ${picocolors_1.default.cyan('mcc -v')} to confirm.`);
160
272
  }
161
273
  else {
@@ -1 +1 @@
1
- {"version":3,"file":"update.js","sourceRoot":"","sources":["../src/update.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"update.js","sourceRoot":"","sources":["../src/update.ts"],"names":[],"mappings":"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"}
@@ -348,12 +348,12 @@ function getFormat() {
348
348
  return (process.env.MCC_IMAGE_ANALYSIS_FORMAT || 'anthropic').trim().toLowerCase();
349
349
  }
350
350
 
351
- function analyzeViaCliProxy(base64Data, mediaType, model, prompt, timeoutMs) {
351
+ function analyzeViaCliProxy(provider, base64Data, mediaType, model, prompt, timeoutMs) {
352
352
  return new Promise((resolve, reject) => {
353
- const endpoint = new URL(getRuntimeEndpoint());
353
+ const endpoint = new URL(provider.endpoint);
354
354
  const transport = endpoint.protocol === 'https:' ? https : http;
355
- const apiKey = getApiKey();
356
- const format = getFormat();
355
+ const apiKey = provider.apiKey || 'mcc-internal-managed';
356
+ const format = (provider.format || 'anthropic').toLowerCase();
357
357
 
358
358
  log.debug('ImageRuntime', `API call endpoint=${endpoint.toString()} model=${model} format=${format} prompt=${prompt.substring(0, 100)} imageSize=${Math.round(base64Data.length * 3 / 4 / 1024)}KB`);
359
359
 
@@ -440,14 +440,66 @@ function analyzeViaCliProxy(base64Data, mediaType, model, prompt, timeoutMs) {
440
440
  });
441
441
  }
442
442
 
443
+ /**
444
+ * Parse the provider fallback chain emitted by model-router
445
+ * (MCC_IMAGE_ANALYSIS_PROVIDERS = JSON array). Each entry is self-contained
446
+ * — its own baseUrl / apiKey / model / format — so the runtime can try a
447
+ * different provider entirely when one 402s or errors. Returns null when the
448
+ * env var is absent, so the legacy single-endpoint path is preserved.
449
+ */
450
+ function getProvidersToTry() {
451
+ const raw = process.env.MCC_IMAGE_ANALYSIS_PROVIDERS;
452
+ if (!raw || !raw.trim()) return null;
453
+ let arr;
454
+ try {
455
+ arr = JSON.parse(raw);
456
+ } catch {
457
+ return null;
458
+ }
459
+ if (!Array.isArray(arr) || arr.length === 0) return null;
460
+ const providers = arr
461
+ .filter((p) => p && p.baseUrl && p.apiKey && p.model)
462
+ .map((p) => {
463
+ const format = (p.format || 'anthropic').toLowerCase();
464
+ const base = String(p.baseUrl).trim().replace(/\/+$/, '');
465
+ const endpoint = format === 'openai' ? `${base}/chat/completions` : `${base}/v1/messages`;
466
+ return { id: p.id || base, endpoint, apiKey: p.apiKey, format, model: p.model };
467
+ });
468
+ return providers.length > 0 ? providers : null;
469
+ }
470
+
443
471
  async function analyzeWithRetry(base64Data, mediaType, prompt, timeoutMs) {
472
+ // Preferred path: explicit provider chain → try each provider in order,
473
+ // falling through on ANY error (402 / auth / rate-limit / network).
474
+ const providers = getProvidersToTry();
475
+ if (providers) {
476
+ let lastError = null;
477
+ for (const [index, p] of providers.entries()) {
478
+ try {
479
+ log.debug('ImageRuntime', `Trying provider ${index + 1}/${providers.length} id=${p.id} model=${p.model} endpoint=${p.endpoint}`);
480
+ const description = await analyzeViaCliProxy(
481
+ { endpoint: p.endpoint, apiKey: p.apiKey, format: p.format },
482
+ base64Data, mediaType, p.model, prompt, timeoutMs,
483
+ );
484
+ return { description, model: p.model, provider: p.id };
485
+ } catch (error) {
486
+ lastError = error;
487
+ const more = index < providers.length - 1;
488
+ log.debug('ImageRuntime', `Provider ${p.id} failed: ${error.message}${more ? ' — falling back to next' : ' — no more providers'}`);
489
+ }
490
+ }
491
+ throw lastError || new Error('No image analysis providers succeeded');
492
+ }
493
+
494
+ // Legacy path: single endpoint from env, retry across model candidates.
495
+ const envProvider = { endpoint: getRuntimeEndpoint(), apiKey: getApiKey(), format: getFormat() };
444
496
  const models = getModelsToTry();
445
497
  let lastError = null;
446
498
 
447
499
  for (const [index, model] of models.entries()) {
448
500
  try {
449
501
  log.debug('ImageRuntime', `Trying model ${index + 1}/${models.length} model=${model}`);
450
- const description = await analyzeViaCliProxy(base64Data, mediaType, model, prompt, timeoutMs);
502
+ const description = await analyzeViaCliProxy(envProvider, base64Data, mediaType, model, prompt, timeoutMs);
451
503
  return { description, model };
452
504
  } catch (error) {
453
505
  lastError = error;
@@ -492,6 +544,7 @@ async function analyzeFile(filePath, options = {}) {
492
544
  return {
493
545
  description: result.description,
494
546
  model: result.model,
547
+ provider: result.provider,
495
548
  fileSize: stats.size,
496
549
  mediaType,
497
550
  template,
@@ -95,8 +95,12 @@ function format(level, message, component) {
95
95
  function write(level, message, component) {
96
96
  if (levelValue(level) > _minLevel) return;
97
97
  const line = format(level, message, component);
98
- process.stderr.write(line + '\n');
99
98
  writeFile(line);
99
+ // error/warn always echo to stderr; debug echoes only when debug mode is on; info is file-only
100
+ const lv = levelValue(level);
101
+ if (lv <= LEVELS.warn || _minLevel >= LEVELS.debug) {
102
+ process.stderr.write(line + '\n');
103
+ }
100
104
  }
101
105
 
102
106
  // --- 导出---
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@hileeon/mcc",
3
- "version": "0.1.9",
3
+ "version": "0.3.0",
4
4
  "description": "My Claude Code - Multi-provider account and model switching for Claude Code",
5
5
  "license": "MIT",
6
6
  "author": "Leeon",
@@ -38,14 +38,12 @@
38
38
  "dependencies": {
39
39
  "cors": "^2.8.5",
40
40
  "express": "^4.18.2",
41
- "picocolors": "^1.1.1",
42
- "update-notifier": "^5.1.0"
41
+ "picocolors": "^1.1.1"
43
42
  },
44
43
  "devDependencies": {
45
44
  "@types/cors": "^2.8.17",
46
45
  "@types/express": "^4.17.21",
47
46
  "@types/node": "^20.0.0",
48
- "@types/update-notifier": "^6.0.8",
49
47
  "concurrently": "^10.0.3",
50
48
  "tsx": "^4.22.4",
51
49
  "typescript": "^5.3.0"