machinaos 0.0.76 → 0.0.78
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.
- package/README.md +143 -107
- package/client/dist/assets/ActionBar-Du2MSFSz.js +1 -0
- package/client/dist/assets/ApiKeyInput-k2LBmBjb.js +1 -0
- package/client/dist/assets/ApiKeyPanel-C_bV9U0X.js +1 -0
- package/client/dist/assets/ApiUsageSection-CmVfwZzL.js +1 -0
- package/client/dist/assets/EmailPanel-CeKIMGu-.js +1 -0
- package/client/dist/assets/OAuthPanel-KA3t3Q2K.js +1 -0
- package/client/dist/assets/QrPairingPanel-NgNpJNuk.js +1 -0
- package/client/dist/assets/RateLimitSection-Du5YNVIA.js +1 -0
- package/client/dist/assets/StatusCard-DNLyayXc.js +1 -0
- package/client/dist/assets/index-DQ0nwhec.js +257 -0
- package/client/dist/assets/index-DxmbVskS.css +1 -0
- package/client/dist/assets/vendor-flow-CZmBvHRo.js +1 -0
- package/client/dist/assets/vendor-icons-CVrPjN2Q.js +22 -0
- package/client/dist/assets/vendor-markdown-CRou3yQ5.js +62 -0
- package/client/dist/assets/vendor-misc-C4VxKHs5.js +1 -0
- package/client/dist/assets/vendor-query-SzWcOU0G.js +1 -0
- package/client/dist/assets/vendor-radix-Dnos29jG.js +56 -0
- package/client/dist/assets/vendor-react-DvWIbVx0.js +1 -0
- package/client/dist/index.html +37 -3
- package/client/index.html +28 -1
- package/client/package.json +44 -40
- package/client/src/App.tsx +2 -0
- package/client/src/Dashboard.tsx +157 -45
- package/client/src/ParameterPanel.tsx +3 -5
- package/client/src/adapters/nodeSpecToDescription.ts +1 -0
- package/client/src/assets/icons/NodeIcon.tsx +32 -0
- package/client/src/assets/icons/index.ts +4 -0
- package/client/src/assets/icons/stripe.svg +1 -0
- package/client/src/assets/icons/themedGlyphs.ts +404 -0
- package/client/src/components/AIAgentNode.tsx +77 -53
- package/client/src/components/GenericNode.tsx +34 -52
- package/client/src/components/OutputPanel.tsx +64 -147
- package/client/src/components/ParameterRenderer.tsx +5 -3
- package/client/src/components/SkillEditorModal.tsx +9 -18
- package/client/src/components/SquareNode.tsx +97 -115
- package/client/src/components/StartNode.tsx +32 -42
- package/client/src/components/SvgFilterDefs.tsx +54 -0
- package/client/src/components/TeamMonitorNode.tsx +12 -14
- package/client/src/components/ToolkitNode.tsx +35 -60
- package/client/src/components/TriggerNode.tsx +43 -77
- package/client/src/components/__tests__/CredentialsModal.test.tsx +49 -45
- package/client/src/components/credentials/CredentialsModal.tsx +98 -30
- package/client/src/components/credentials/CredentialsPalette.tsx +73 -5
- package/client/src/components/credentials/catalogueAdapter.ts +17 -1
- package/client/src/components/credentials/panels/ApiKeyPanel.tsx +102 -37
- package/client/src/components/credentials/panels/EmailPanel.tsx +7 -19
- package/client/src/components/credentials/panels/OAuthPanel.tsx +5 -1
- package/client/src/components/credentials/panels/QrPairingPanel.tsx +1 -3
- package/client/src/components/credentials/primitives/ActionBar.tsx +7 -11
- package/client/src/components/credentials/primitives/OAuthConnect.tsx +19 -28
- package/client/src/components/credentials/sections/ProviderDefaultsSection.tsx +24 -3
- package/client/src/components/credentials/types.ts +12 -2
- package/client/src/components/credentials/useCredentialPanel.ts +43 -19
- package/client/src/components/icons/AIProviderIcons.tsx +16 -0
- package/client/src/components/onboarding/OnboardingWizard.tsx +23 -63
- package/client/src/components/onboarding/nodeRoleClasses.ts +23 -0
- package/client/src/components/onboarding/steps/CanvasStep.tsx +15 -21
- package/client/src/components/onboarding/steps/ConceptsStep.tsx +2 -11
- package/client/src/components/onboarding/steps/GetStartedStep.tsx +2 -10
- package/client/src/components/parameterPanel/InputSection.tsx +9 -7
- package/client/src/components/parameterPanel/MasterSkillEditor.tsx +84 -198
- package/client/src/components/parameterPanel/MiddleSection.tsx +57 -80
- package/client/src/components/parameterPanel/ToolSchemaEditor.tsx +31 -25
- package/client/src/components/parameterPanel/__tests__/InputSection.test.tsx +7 -2
- package/client/src/components/ui/AIResultModal.tsx +1 -1
- package/client/src/components/ui/CollapsibleSection.tsx +9 -5
- package/client/src/components/ui/CommandPalette.tsx +147 -0
- package/client/src/components/ui/CommandPaletteHost.tsx +189 -0
- package/client/src/components/ui/ComponentItem.tsx +13 -7
- package/client/src/components/ui/ComponentPalette.tsx +24 -13
- package/client/src/components/ui/ConsolePanel.tsx +19 -11
- package/client/src/components/ui/DropCap.tsx +28 -0
- package/client/src/components/ui/EditableNodeLabel.tsx +10 -2
- package/client/src/components/ui/InputNodesPanel.tsx +1 -1
- package/client/src/components/ui/Modal.tsx +38 -6
- package/client/src/components/ui/OutputDisplayPanel.tsx +1 -1
- package/client/src/components/ui/SettingsPanel.tsx +42 -13
- package/client/src/components/ui/StatusBar.tsx +108 -0
- package/client/src/components/ui/ThemeSwitcher.tsx +109 -0
- package/client/src/components/ui/TopToolbar.tsx +42 -25
- package/client/src/components/ui/WorkflowSidebar.tsx +32 -16
- package/client/src/components/ui/action-button.tsx +40 -15
- package/client/src/components/ui/button.tsx +24 -1
- package/client/src/components/ui/dropdown-menu.tsx +24 -2
- package/client/src/components/ui/input.tsx +19 -2
- package/client/src/components/ui/select.tsx +15 -0
- package/client/src/components/ui/textarea.tsx +15 -2
- package/client/src/contexts/AuthContext.tsx +148 -109
- package/client/src/contexts/ThemeContext.tsx +93 -17
- package/client/src/contexts/WebSocketContext.tsx +373 -206
- package/client/src/contexts/__tests__/AuthContext.test.tsx +221 -0
- package/client/src/hooks/__tests__/useDragVariable.test.ts +7 -1
- package/client/src/hooks/__tests__/useWorkflowOpsListener.test.ts +142 -0
- package/client/src/hooks/useAppTheme.ts +209 -7
- package/client/src/hooks/useAutoSkillEdges.ts +7 -2
- package/client/src/hooks/useCatalogueQuery.ts +67 -1
- package/client/src/hooks/useDragVariable.ts +1 -1
- package/client/src/hooks/useNodeAllowlist.ts +115 -8
- package/client/src/hooks/useOnboarding.ts +20 -8
- package/client/src/hooks/useParameterPanel.ts +2 -1
- package/client/src/hooks/useReactFlowNodes.ts +2 -1
- package/client/src/hooks/useSound.ts +185 -0
- package/client/src/hooks/useWorkflowManagement.ts +6 -8
- package/client/src/hooks/useWorkflowOpsListener.ts +90 -0
- package/client/src/index.css +65 -3
- package/client/src/lib/__tests__/connectionConfig.test.ts +91 -0
- package/client/src/lib/aiModelProviders.ts +8 -0
- package/client/src/lib/connectionConfig.ts +107 -0
- package/client/src/lib/queryPersist.ts +13 -5
- package/client/src/lib/sound.ts +393 -0
- package/client/src/main.tsx +20 -0
- package/client/src/store/useAppStore.ts +26 -0
- package/client/src/styles/canvasAnimations.ts +37 -36
- package/client/src/styles/theme.ts +36 -20
- package/client/src/test/setup.ts +1 -0
- package/client/src/themes/atomic.css +253 -0
- package/client/src/themes/base.css +373 -0
- package/client/src/themes/cyber.css +890 -0
- package/client/src/themes/dark.css +70 -0
- package/client/src/themes/edo.css +246 -0
- package/client/src/themes/greek.css +293 -0
- package/client/src/themes/light.css +78 -0
- package/client/src/themes/plague.css +253 -0
- package/client/src/themes/renaissance.css +727 -0
- package/client/src/themes/rot.css +249 -0
- package/client/src/themes/steampunk.css +272 -0
- package/client/src/themes/surveillance.css +289 -0
- package/client/src/themes/wasteland.css +250 -0
- package/client/src/types/INodeProperties.ts +5 -0
- package/client/src/types/NodeTypes.ts +11 -1
- package/client/src/types/__tests__/cloudEvents.test.ts +99 -0
- package/client/src/types/cloudEvents.ts +78 -0
- package/client/src/vite-env.d.ts +7 -0
- package/client/tsconfig.json +1 -1
- package/client/vite.config.js +62 -2
- package/install.ps1 +1 -1
- package/install.sh +1 -1
- package/machina/commands/build.py +51 -7
- package/machina/pyproject.toml +4 -0
- package/machina/supervisor.py +12 -2
- package/machina/tree.py +71 -21
- package/package.json +4 -4
- package/scripts/install.js +16 -1
- package/server/config/ai_cli_providers.json +54 -0
- package/server/config/credential_providers.json +109 -2
- package/server/config/llm_defaults.json +24 -0
- package/server/config/model_registry.json +338 -499
- package/server/config/node_allowlist.json +16 -1
- package/server/config/pricing.json +8 -0
- package/server/constants.py +38 -15
- package/server/core/container.py +2 -2
- package/server/core/credentials_database.py +35 -2
- package/server/core/logging.py +4 -3
- package/server/main.py +99 -13
- package/server/models/node_metadata.py +1 -0
- package/server/nodejs/package.json +8 -6
- package/server/nodejs/src/index.ts +22 -5
- package/server/nodes/README.md +31 -4
- package/server/nodes/agent/_inline.py +2 -0
- package/server/nodes/agent/_specialized.py +6 -3
- package/server/nodes/agent/ai_agent.py +13 -3
- package/server/nodes/agent/chat_agent.py +6 -3
- package/server/nodes/agent/claude_code_agent.py +287 -75
- package/server/nodes/agent/codex_agent.py +239 -0
- package/server/nodes/agent/deep_agent.py +3 -3
- package/server/nodes/agent/rlm_agent.py +3 -3
- package/server/nodes/android/__init__.py +31 -1
- package/server/nodes/android/_base.py +9 -5
- package/server/{services/android_service.py → nodes/android/_dispatcher.py} +2 -2
- package/server/nodes/android/_handlers.py +154 -0
- package/server/nodes/android/_option_loaders.py +44 -0
- package/server/nodes/android/_refresh.py +127 -0
- package/server/{services/android → nodes/android/_relay}/client.py +4 -4
- package/server/{routers/android.py → nodes/android/_router.py} +27 -8
- package/server/nodes/browser/browser.py +2 -2
- package/server/nodes/code/_base.py +6 -2
- package/server/nodes/code/_claude_code.py +134 -0
- package/server/nodes/document/embedding_generator.py +3 -3
- package/server/nodes/document/http_scraper.py +3 -3
- package/server/nodes/document/vector_store.py +5 -5
- package/server/nodes/email/__init__.py +11 -1
- package/server/nodes/email/_filters.py +21 -0
- package/server/{services/himalaya_service.py → nodes/email/_himalaya.py} +6 -10
- package/server/{services/email_service.py → nodes/email/_service.py} +9 -13
- package/server/nodes/email/email_read.py +1 -1
- package/server/nodes/email/email_receive.py +54 -5
- package/server/nodes/email/email_send.py +1 -1
- package/server/nodes/filesystem/shell.py +24 -1
- package/server/nodes/google/__init__.py +55 -1
- package/server/{services/handlers/google_auth.py → nodes/google/_auth_helper.py} +8 -5
- package/server/nodes/google/_base.py +2 -2
- package/server/nodes/google/_credentials.py +5 -5
- package/server/nodes/google/_filters.py +25 -0
- package/server/nodes/google/_handlers.py +57 -0
- package/server/{services/google_oauth.py → nodes/google/_oauth.py} +195 -162
- package/server/nodes/google/_option_loaders.py +107 -0
- package/server/nodes/google/_refresh.py +66 -0
- package/server/nodes/google/_router.py +131 -0
- package/server/nodes/google/gmail_receive.py +41 -4
- package/server/nodes/groups.py +1 -0
- package/server/nodes/location/_credentials.py +45 -1
- package/server/{services/maps.py → nodes/location/_service.py} +18 -3
- package/server/nodes/location/gmaps_create.py +4 -4
- package/server/nodes/location/gmaps_locations.py +4 -4
- package/server/nodes/location/gmaps_nearby_places.py +4 -4
- package/server/nodes/model/_base.py +8 -3
- package/server/nodes/model/_credentials.py +96 -8
- package/server/nodes/model/_local_validator.py +345 -0
- package/server/nodes/model/lmstudio_chat_model.py +23 -0
- package/server/nodes/model/ollama_chat_model.py +25 -0
- package/server/nodes/proxy/_usage.py +2 -2
- package/server/nodes/proxy/proxy_config.py +14 -14
- package/server/nodes/proxy/proxy_request.py +4 -4
- package/server/nodes/scraper/_credentials.py +29 -1
- package/server/nodes/scraper/apify_actor.py +9 -9
- package/server/nodes/scraper/crawlee_scraper.py +5 -5
- package/server/nodes/search/brave_search.py +4 -0
- package/server/nodes/search/perplexity_search.py +9 -0
- package/server/nodes/search/serper_search.py +3 -0
- package/server/nodes/skill/simple_memory.py +12 -0
- package/server/nodes/social/_base.py +2 -2
- package/server/nodes/stripe/__init__.py +46 -0
- package/server/nodes/stripe/_credentials.py +33 -0
- package/server/nodes/stripe/_handlers.py +270 -0
- package/server/nodes/stripe/_install.py +127 -0
- package/server/nodes/stripe/_source.py +174 -0
- package/server/nodes/stripe/stripe_action.py +81 -0
- package/server/nodes/stripe/stripe_receive.py +92 -0
- package/server/nodes/telegram/_credentials.py +52 -1
- package/server/nodes/telegram/_handlers.py +19 -18
- package/server/nodes/telegram/_service.py +134 -32
- package/server/nodes/telegram/telegram_send.py +5 -6
- package/server/nodes/text/file_handler.py +2 -2
- package/server/nodes/text/text_generator.py +2 -2
- package/server/nodes/tool/agent_builder.py +630 -0
- package/server/nodes/tool/task_manager.py +144 -2
- package/server/nodes/twitter/__init__.py +38 -1
- package/server/nodes/twitter/_base.py +7 -7
- package/server/nodes/twitter/_credentials.py +1 -1
- package/server/nodes/twitter/_filters.py +37 -0
- package/server/nodes/twitter/_handlers.py +77 -0
- package/server/nodes/twitter/_oauth.py +124 -0
- package/server/nodes/twitter/_refresh.py +78 -0
- package/server/nodes/twitter/_router.py +29 -0
- package/server/nodes/twitter/twitter_receive.py +4 -0
- package/server/nodes/visuals.json +64 -19
- package/server/nodes/whatsapp/__init__.py +45 -5
- package/server/nodes/whatsapp/_base.py +3 -3
- package/server/nodes/whatsapp/_filters.py +137 -0
- package/server/nodes/whatsapp/_handlers.py +167 -0
- package/server/nodes/whatsapp/_option_loaders.py +68 -0
- package/server/nodes/whatsapp/_refresh.py +62 -0
- package/server/nodes/whatsapp/_runtime.py +1 -1
- package/server/pyproject.toml +29 -7
- package/server/routers/schemas.py +2 -2
- package/server/routers/webhook.py +26 -9
- package/server/routers/websocket.py +149 -810
- package/server/services/ai.py +89 -8
- package/server/services/auth.py +220 -43
- package/server/services/claude_oauth.py +126 -100
- package/server/services/cli_agent/__init__.py +78 -0
- package/server/services/cli_agent/_handlers.py +237 -0
- package/server/services/cli_agent/config.py +112 -0
- package/server/services/cli_agent/factory.py +48 -0
- package/server/services/cli_agent/lockfile.py +141 -0
- package/server/services/cli_agent/mcp_server.py +482 -0
- package/server/services/cli_agent/protocol.py +173 -0
- package/server/services/cli_agent/providers/__init__.py +9 -0
- package/server/services/cli_agent/providers/anthropic_claude.py +419 -0
- package/server/services/cli_agent/providers/google_gemini.py +80 -0
- package/server/services/cli_agent/providers/openai_codex.py +310 -0
- package/server/services/cli_agent/service.py +607 -0
- package/server/services/cli_agent/session.py +618 -0
- package/server/services/cli_agent/types.py +227 -0
- package/server/services/cli_agent/workflow_tools.py +233 -0
- package/server/services/credential_registry.py +26 -1
- package/server/services/deployment/manager.py +26 -145
- package/server/services/deployment/poll_registry.py +59 -0
- package/server/services/event_waiter.py +76 -246
- package/server/services/events/__init__.py +54 -0
- package/server/services/events/cli.py +78 -0
- package/server/services/events/daemon.py +163 -0
- package/server/services/events/envelope.py +281 -0
- package/server/services/events/lifecycle.py +99 -0
- package/server/services/events/oauth_lifecycle.py +534 -0
- package/server/services/events/polling.py +60 -0
- package/server/services/events/push.py +36 -0
- package/server/services/events/source.py +63 -0
- package/server/services/events/triggers.py +118 -0
- package/server/services/events/verifiers/__init__.py +25 -0
- package/server/services/events/verifiers/base.py +28 -0
- package/server/services/events/verifiers/github.py +25 -0
- package/server/services/events/verifiers/hmac_basic.py +32 -0
- package/server/services/events/verifiers/standard_webhooks.py +47 -0
- package/server/services/events/verifiers/stripe.py +42 -0
- package/server/services/events/webhook.py +105 -0
- package/server/services/handlers/tools.py +28 -186
- package/server/services/llm/config.py +7 -0
- package/server/services/llm/factory.py +8 -2
- package/server/services/memory/__init__.py +52 -0
- package/server/services/memory/jsonl.py +80 -0
- package/server/services/memory/markdown.py +65 -0
- package/server/services/memory/state.py +112 -0
- package/server/services/memory/vector_store.py +40 -0
- package/server/services/model_registry.py +76 -0
- package/server/services/node_allowlist.py +71 -15
- package/server/services/node_executor.py +2 -2
- package/server/services/node_output_schemas.py +21 -10
- package/server/services/node_spec.py +1 -1
- package/server/services/oauth_utils.py +1 -1
- package/server/services/plugin/__init__.py +2 -0
- package/server/services/plugin/base.py +44 -2
- package/server/services/plugin/credential.py +288 -1
- package/server/services/plugin/deps.py +105 -0
- package/server/services/plugin/edge_walker.py +12 -4
- package/server/services/plugin/oauth.py +381 -0
- package/server/services/plugin/polling.py +247 -0
- package/server/services/plugin/registry.py +145 -0
- package/server/services/plugin/singleton.py +65 -0
- package/server/services/plugin/ws.py +81 -0
- package/server/services/process_service.py +31 -2
- package/server/services/status_broadcaster.py +155 -238
- package/server/services/temporal/workflow.py +7 -7
- package/server/services/workflow.py +21 -3
- package/server/services/ws_handler_registry.py +111 -28
- package/server/skills/GUIDE.md +16 -1
- package/server/skills/assistant/agent-builder-skill/SKILL.md +166 -0
- package/server/skills/payments_agent/stripe-skill/SKILL.md +306 -0
- package/server/tests/credentials/test_auth_service.py +16 -9
- package/server/tests/credentials/test_credential_broadcasts.py +219 -0
- package/server/tests/credentials/test_google_oauth.py +6 -6
- package/server/tests/credentials/test_oauth_utils.py +1 -1
- package/server/tests/credentials/test_twitter_oauth.py +2 -2
- package/server/tests/credentials/test_websocket_handlers.py +44 -20
- package/server/tests/llm/test_factory.py +1 -0
- package/server/tests/llm/test_wiring.py +5 -1
- package/server/tests/nodes/_compat.py +24 -24
- package/server/tests/nodes/test_agent_builder.py +439 -0
- package/server/tests/nodes/test_ai_tools.py +18 -14
- package/server/tests/nodes/test_code_fs_process.py +17 -8
- package/server/tests/nodes/test_email.py +10 -9
- package/server/tests/nodes/test_google_workspace.py +2 -2
- package/server/tests/nodes/test_specialized_agents.py +100 -53
- package/server/tests/nodes/test_stripe_plugin.py +293 -0
- package/server/tests/nodes/test_telegram_social.py +4 -4
- package/server/tests/nodes/test_twitter.py +1 -1
- package/server/tests/nodes/test_web_automation.py +2 -2
- package/server/tests/nodes/test_whatsapp.py +9 -9
- package/server/tests/services/cli_agent/__init__.py +0 -0
- package/server/tests/services/cli_agent/test_mcp_server.py +432 -0
- package/server/tests/services/cli_agent/test_providers.py +358 -0
- package/server/tests/services/cli_agent/test_service.py +298 -0
- package/server/tests/services/memory/__init__.py +0 -0
- package/server/tests/services/memory/test_jsonl.py +188 -0
- package/server/tests/services/test_events.py +333 -0
- package/server/tests/test_node_spec.py +56 -16
- package/server/tests/test_plugin_helpers.py +116 -0
- package/server/tests/test_plugin_self_containment.py +486 -0
- package/server/tests/test_status_broadcasts.py +425 -0
- package/workflows/{AI Assistant_workflow-1777421105154-0m4snkzjf.json → AI Assistant_workflow-1778504793388-ou1m1tz2x.json } +70 -266
- package/workflows/{AI Employee_workflow-1777720598005-u4cm858dv.json → AI Employee_example_workflow-1777720598005-u4cm858dv.json } +112 -112
- package/workflows/Claude Assistant_workflow-1778380124051-mdibn807c.json +709 -0
- package/client/dist/assets/ActionBar-vzPpSR77.js +0 -1
- package/client/dist/assets/ApiKeyInput-Ds7AKFe8.js +0 -1
- package/client/dist/assets/ApiKeyPanel-gfblELep.js +0 -1
- package/client/dist/assets/ApiUsageSection-BMNWTe2r.js +0 -1
- package/client/dist/assets/EmailPanel-B1Om64p5.js +0 -1
- package/client/dist/assets/OAuthPanel-CXyQYGBz.js +0 -1
- package/client/dist/assets/QrPairingPanel-BgNuI1we.js +0 -1
- package/client/dist/assets/RateLimitSection-YYK8sx1T.js +0 -1
- package/client/dist/assets/StatusCard-DuYA5hJR.js +0 -1
- package/client/dist/assets/index-D9tZfgvi.js +0 -363
- package/client/dist/assets/index-al7snTkG.css +0 -1
- package/client/src/components/credentials/providers.tsx +0 -177
- package/server/routers/google.py +0 -277
- package/server/routers/maps.py +0 -142
- package/server/routers/twitter.py +0 -365
- package/server/services/claude_code_service.py +0 -106
- package/server/services/memory.py +0 -159
- package/server/services/node_option_loaders/__init__.py +0 -77
- package/server/services/node_option_loaders/android_loaders.py +0 -55
- package/server/services/node_option_loaders/google_loaders.py +0 -97
- package/server/services/node_option_loaders/whatsapp_loaders.py +0 -69
- package/server/services/twitter_oauth.py +0 -411
- package/server/services/websocket_client.py +0 -29
- /package/server/{services/android → nodes/android/_relay}/__init__.py +0 -0
- /package/server/{services/android → nodes/android/_relay}/broadcaster.py +0 -0
- /package/server/{services/android → nodes/android/_relay}/manager.py +0 -0
- /package/server/{services/android → nodes/android/_relay}/protocol.py +0 -0
- /package/server/{services/browser_service.py → nodes/browser/_service.py} +0 -0
- /package/server/{services/whatsapp_service.py → nodes/whatsapp/_service.py} +0 -0
- /package/server/skills/{task_agent → assistant}/write-todos-skill/SKILL.md +0 -0
|
@@ -0,0 +1,249 @@
|
|
|
1
|
+
/* ============================================================================
|
|
2
|
+
* themes/rot.css — moss-overgrown crypt lit by guttering candles.
|
|
3
|
+
*
|
|
4
|
+
* Bone whites, cold green, candleflame amber on charcoal. Reads like a
|
|
5
|
+
* grimoire. Ported from design_handoff_machinaos_themes/themes/rot.css.
|
|
6
|
+
* ============================================================================ */
|
|
7
|
+
|
|
8
|
+
:root[data-theme="rot"] {
|
|
9
|
+
--bg-app: #14181a;
|
|
10
|
+
--bg-panel: #1c2226;
|
|
11
|
+
--bg-canvas: #0a0e10;
|
|
12
|
+
--bg-elevated: #242c30;
|
|
13
|
+
--bg-input: #0a0e10;
|
|
14
|
+
--bg-hover: rgba(120, 200, 120, 0.08);
|
|
15
|
+
--bg-active: rgba(120, 200, 120, 0.18);
|
|
16
|
+
--bg-overlay: rgba(0, 4, 6, 0.85);
|
|
17
|
+
|
|
18
|
+
--border-default: #2a3a30;
|
|
19
|
+
--border-strong: #4a6a4a;
|
|
20
|
+
--border-focus: #78c878;
|
|
21
|
+
--ornament-frame: none;
|
|
22
|
+
|
|
23
|
+
--fg-default: #c8d8c0;
|
|
24
|
+
--fg-muted: #788878;
|
|
25
|
+
--fg-faint: #485848;
|
|
26
|
+
--fg-on-accent: #0a0e10;
|
|
27
|
+
--fg-on-success: #0a0e10;
|
|
28
|
+
--fg-on-danger: #c8d8c0;
|
|
29
|
+
--fg-on-warning: #0a0e10;
|
|
30
|
+
|
|
31
|
+
--bone: #d8d0b8;
|
|
32
|
+
--candle: #e8a838;
|
|
33
|
+
--crypt: #4a3838;
|
|
34
|
+
--moss: #78c878;
|
|
35
|
+
|
|
36
|
+
--font-display: 'Pirata One', 'UnifrakturCook', serif;
|
|
37
|
+
--font-body: 'EB Garamond', 'Cormorant Garamond', serif;
|
|
38
|
+
--font-mono: 'JetBrains Mono', monospace;
|
|
39
|
+
--type-scale-base: 14px;
|
|
40
|
+
--type-tracking-display: 0.04em;
|
|
41
|
+
--type-uppercase: none;
|
|
42
|
+
|
|
43
|
+
--radius-sm: 1px;
|
|
44
|
+
--radius-md: 2px;
|
|
45
|
+
--radius-lg: 4px;
|
|
46
|
+
--radius-pill: 999px;
|
|
47
|
+
|
|
48
|
+
--dur-fast: 140ms;
|
|
49
|
+
--dur-default: 320ms;
|
|
50
|
+
--dur-slow: 680ms;
|
|
51
|
+
--ease-default: cubic-bezier(0.4, 0, 0.6, 1);
|
|
52
|
+
--ease-emphasis: cubic-bezier(0.4, 0, 0.6, 1);
|
|
53
|
+
--motion-style: drift;
|
|
54
|
+
--sound-pack: crypt;
|
|
55
|
+
|
|
56
|
+
/* Wave 30: phosphor-green pulse — high-contrast against the moss
|
|
57
|
+
* + crypt-brown canvas backplane. */
|
|
58
|
+
--node-pulse-color: hsl(var(--accent));
|
|
59
|
+
|
|
60
|
+
--cursor-default: auto;
|
|
61
|
+
--cursor-pointer: pointer;
|
|
62
|
+
--scrollbar-track: #14181a;
|
|
63
|
+
--scrollbar-thumb: #4a6a4a;
|
|
64
|
+
|
|
65
|
+
/* Shadcn HSL bridge */
|
|
66
|
+
--background: 200 13% 9%;
|
|
67
|
+
--foreground: 90 22% 80%;
|
|
68
|
+
--card: 199 14% 17%;
|
|
69
|
+
--card-foreground: 90 22% 80%;
|
|
70
|
+
--popover: 199 14% 17%;
|
|
71
|
+
--popover-foreground: 90 22% 80%;
|
|
72
|
+
|
|
73
|
+
--primary: 120 43% 63%; /* moss bloom */
|
|
74
|
+
--primary-foreground: 200 25% 5%;
|
|
75
|
+
--secondary: 198 16% 13%;
|
|
76
|
+
--secondary-foreground: 90 22% 80%;
|
|
77
|
+
--muted: 198 16% 13%;
|
|
78
|
+
--muted-foreground: 120 6% 50%;
|
|
79
|
+
--accent: 35 78% 56%; /* candleflame amber */
|
|
80
|
+
--accent-foreground: 200 25% 5%;
|
|
81
|
+
|
|
82
|
+
--destructive: 0 49% 44%;
|
|
83
|
+
--destructive-foreground: 90 22% 80%;
|
|
84
|
+
--success: 120 43% 63%;
|
|
85
|
+
--warning: 35 78% 56%;
|
|
86
|
+
--info: 200 36% 53%;
|
|
87
|
+
|
|
88
|
+
--border: 145 16% 28%;
|
|
89
|
+
--input: 145 16% 28%;
|
|
90
|
+
--ring: 120 43% 63%;
|
|
91
|
+
|
|
92
|
+
/* Action role bridge */
|
|
93
|
+
--action-run: 120 43% 63%;
|
|
94
|
+
--action-run-soft: 120 43% 63% / 0.18;
|
|
95
|
+
--action-run-hover: 120 43% 63% / 0.32;
|
|
96
|
+
--action-run-border: 120 43% 63% / 0.7;
|
|
97
|
+
|
|
98
|
+
--action-stop: 0 49% 44%;
|
|
99
|
+
--action-stop-soft: 0 49% 44% / 0.20;
|
|
100
|
+
--action-stop-hover: 0 49% 44% / 0.34;
|
|
101
|
+
--action-stop-border: 0 49% 44% / 0.7;
|
|
102
|
+
|
|
103
|
+
--action-save: 35 78% 56%;
|
|
104
|
+
--action-save-soft: 35 78% 56% / 0.20;
|
|
105
|
+
--action-save-hover: 35 78% 56% / 0.34;
|
|
106
|
+
--action-save-border: 35 78% 56% / 0.7;
|
|
107
|
+
|
|
108
|
+
--action-config: 35 78% 56%;
|
|
109
|
+
--action-config-soft: 35 78% 56% / 0.18;
|
|
110
|
+
--action-config-hover: 35 78% 56% / 0.30;
|
|
111
|
+
--action-config-border: 35 78% 56% / 0.6;
|
|
112
|
+
|
|
113
|
+
--action-secret: 200 36% 53%;
|
|
114
|
+
--action-secret-soft: 200 36% 53% / 0.16;
|
|
115
|
+
--action-secret-hover: 200 36% 53% / 0.30;
|
|
116
|
+
--action-secret-border: 200 36% 53% / 0.6;
|
|
117
|
+
|
|
118
|
+
--action-tools: 120 43% 63%;
|
|
119
|
+
--action-tools-soft: 120 43% 63% / 0.16;
|
|
120
|
+
--action-tools-hover: 120 43% 63% / 0.30;
|
|
121
|
+
--action-tools-border: 120 43% 63% / 0.6;
|
|
122
|
+
|
|
123
|
+
--tint-soft: 16%;
|
|
124
|
+
--tint-border: 40%;
|
|
125
|
+
|
|
126
|
+
/* Canvas backplane — flagstone crypt floor on 80x80 tile */
|
|
127
|
+
--canvas-grid:
|
|
128
|
+
url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='80' height='80'><g stroke='%234a6a4a' stroke-width='0.4' fill='none' opacity='0.25'><path d='M0 30 H80 M30 0 V80 M0 60 H80 M60 0 V80'/></g></svg>");
|
|
129
|
+
--canvas-grid-opacity: 1;
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
/* Body — moss + damp stone */
|
|
133
|
+
:root[data-theme="rot"] body {
|
|
134
|
+
background:
|
|
135
|
+
radial-gradient(ellipse 80% 60% at 50% 0%, rgba(120,200,120,0.04), transparent 60%),
|
|
136
|
+
url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='300' height='300'><filter id='m'><feTurbulence baseFrequency='0.6' numOctaves='2'/><feColorMatrix values='0 0 0 0 0.05 0 0 0 0 0.10 0 0 0 0 0.05 0 0 0 0.4 0'/></filter><rect width='300' height='300' filter='url(%23m)'/></svg>"),
|
|
137
|
+
var(--bg-app);
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
:root[data-theme="rot"] ::selection {
|
|
141
|
+
background: rgba(120, 200, 120, 0.4);
|
|
142
|
+
color: #14181a;
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
/* Rot scrollbars — mossy thumb on swamp track */
|
|
146
|
+
:root[data-theme="rot"] ::-webkit-scrollbar {
|
|
147
|
+
width: 12px;
|
|
148
|
+
height: 12px;
|
|
149
|
+
}
|
|
150
|
+
:root[data-theme="rot"] ::-webkit-scrollbar-track {
|
|
151
|
+
background: var(--scrollbar-track);
|
|
152
|
+
}
|
|
153
|
+
:root[data-theme="rot"] ::-webkit-scrollbar-thumb {
|
|
154
|
+
background: var(--scrollbar-thumb);
|
|
155
|
+
border-radius: var(--radius-sm, 1px);
|
|
156
|
+
}
|
|
157
|
+
:root[data-theme="rot"] ::-webkit-scrollbar-thumb:hover {
|
|
158
|
+
background: color-mix(in srgb, var(--scrollbar-thumb) 80%, white);
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
/* ── Per-component decorations (Wave 16 port from handoff) ─── */
|
|
162
|
+
|
|
163
|
+
:root[data-theme="rot"] .toolbar,
|
|
164
|
+
:root[data-theme="rot"] .sidebar,
|
|
165
|
+
:root[data-theme="rot"] .palette,
|
|
166
|
+
:root[data-theme="rot"] .chat {
|
|
167
|
+
background:
|
|
168
|
+
linear-gradient(180deg, rgba(120,200,120,0.02), transparent),
|
|
169
|
+
var(--bg-panel);
|
|
170
|
+
}
|
|
171
|
+
:root[data-theme="rot"] .toolbar { border-bottom: 1px solid var(--border-strong); }
|
|
172
|
+
:root[data-theme="rot"] .sidebar { border-right: 1px solid var(--border-strong); }
|
|
173
|
+
:root[data-theme="rot"] .palette { border-left: 1px solid var(--border-strong); }
|
|
174
|
+
:root[data-theme="rot"] .chat { border-top: 1px solid var(--border-strong); }
|
|
175
|
+
|
|
176
|
+
/* CANVAS — flagstone crypt floor, candlelight pools */
|
|
177
|
+
:root[data-theme="rot"] .canvas {
|
|
178
|
+
background:
|
|
179
|
+
radial-gradient(circle 200px at 25% 30%, rgba(232,168,56,0.06), transparent 70%),
|
|
180
|
+
radial-gradient(circle 180px at 78% 65%, rgba(232,168,56,0.05), transparent 70%),
|
|
181
|
+
url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='80' height='80'><g stroke='%234a6a4a' stroke-width='0.4' fill='none' opacity='0.25'><path d='M0 30 H80 M30 0 V80 M0 60 H80 M60 0 V80'/></g></svg>"),
|
|
182
|
+
var(--bg-canvas);
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
/* TYPOGRAPHY — gothic */
|
|
186
|
+
:root[data-theme="rot"] body { font-family: var(--font-body); color: var(--fg-default); font-size: 14px; line-height: 1.55; }
|
|
187
|
+
:root[data-theme="rot"] h1, :root[data-theme="rot"] h2, :root[data-theme="rot"] h3,
|
|
188
|
+
:root[data-theme="rot"] .v-display {
|
|
189
|
+
font-family: var(--font-display); letter-spacing: 0.04em; color: var(--bone); font-weight: 400;
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
/* SQUARE NODE — bone-pale tombstone */
|
|
193
|
+
:root[data-theme="rot"] .sq-node-box {
|
|
194
|
+
background: linear-gradient(180deg, var(--bone), #a8a088);
|
|
195
|
+
border: 1px solid #2a2418; border-radius: 4px 4px 2px 2px;
|
|
196
|
+
box-shadow: inset 0 -2px 0 rgba(0,0,0,0.2), 0 4px 8px rgba(0,0,0,0.5);
|
|
197
|
+
color: var(--crypt);
|
|
198
|
+
}
|
|
199
|
+
:root[data-theme="rot"] .sq-node.selected .sq-node-box {
|
|
200
|
+
border-color: hsl(var(--accent)); box-shadow: 0 0 16px rgba(120,200,120,0.4), 0 4px 8px rgba(0,0,0,0.5);
|
|
201
|
+
}
|
|
202
|
+
:root[data-theme="rot"] .sq-node-gear { background: var(--crypt); color: var(--bone); border: none; }
|
|
203
|
+
:root[data-theme="rot"] .sq-node-label { font-family: var(--font-display); color: var(--crypt); font-weight: 400; }
|
|
204
|
+
:root[data-theme="rot"] .sq-node-handle.out { background: hsl(var(--accent)); box-shadow: 0 0 6px hsl(var(--accent)); }
|
|
205
|
+
|
|
206
|
+
/* ACTIONS — guttering candleflame */
|
|
207
|
+
:root[data-theme="rot"] .action-btn {
|
|
208
|
+
font-family: var(--font-display); font-size: 13px; letter-spacing: 0.04em; font-weight: 400;
|
|
209
|
+
border-radius: 2px; border-width: 1px;
|
|
210
|
+
}
|
|
211
|
+
:root[data-theme="rot"] .action-run { background: hsl(var(--success-soft)); color: hsl(var(--accent)); border-color: hsl(var(--success)); }
|
|
212
|
+
:root[data-theme="rot"] .action-deploy { background: hsl(var(--info-soft)); color: hsl(var(--info)); border-color: hsl(var(--info)); }
|
|
213
|
+
:root[data-theme="rot"] .action-save { background: hsl(var(--warning-soft)); color: var(--candle); border-color: var(--candle); }
|
|
214
|
+
|
|
215
|
+
/* CARDS */
|
|
216
|
+
:root[data-theme="rot"] .wf-card,
|
|
217
|
+
:root[data-theme="rot"] .cat,
|
|
218
|
+
:root[data-theme="rot"] .comp,
|
|
219
|
+
:root[data-theme="rot"] .settings-section,
|
|
220
|
+
:root[data-theme="rot"] .cred-card {
|
|
221
|
+
background: var(--bg-elevated); border: 1px solid var(--border-default); border-radius: 2px;
|
|
222
|
+
}
|
|
223
|
+
:root[data-theme="rot"] .wf-card.selected { border-color: hsl(var(--accent)); background: hsl(var(--success-soft)); }
|
|
224
|
+
:root[data-theme="rot"] .cat-tile { background: var(--crypt); color: var(--bone); border: 1px solid var(--border-strong); }
|
|
225
|
+
:root[data-theme="rot"] .cat-name { font-family: var(--font-display); color: var(--bone); font-weight: 400; }
|
|
226
|
+
:root[data-theme="rot"] .comp-ico { background: var(--bg-panel); color: hsl(var(--accent)); border: 1px solid var(--border-strong); }
|
|
227
|
+
|
|
228
|
+
/* CHAT */
|
|
229
|
+
:root[data-theme="rot"] .chat-msg-user { background: hsl(var(--success-soft)); border: 1px solid hsl(var(--accent)); }
|
|
230
|
+
:root[data-theme="rot"] .chat-msg-bot { background: var(--bg-elevated); border-left: 2px solid var(--candle); }
|
|
231
|
+
|
|
232
|
+
/* STATUS BAR */
|
|
233
|
+
:root[data-theme="rot"] .statusbar {
|
|
234
|
+
background: var(--bg-panel); border-top: 1px solid var(--border-strong);
|
|
235
|
+
font-family: var(--font-mono); color: var(--fg-muted);
|
|
236
|
+
}
|
|
237
|
+
:root[data-theme="rot"] .statusbar .pip { background: hsl(var(--accent)); box-shadow: 0 0 6px hsl(var(--accent)); }
|
|
238
|
+
|
|
239
|
+
/* MODAL */
|
|
240
|
+
:root[data-theme="rot"] .modal {
|
|
241
|
+
background: var(--bg-elevated); border: 1px solid var(--border-strong); border-radius: 4px;
|
|
242
|
+
box-shadow: 0 0 0 1px rgba(120,200,120,0.10), 0 30px 80px rgba(0,0,0,0.8);
|
|
243
|
+
}
|
|
244
|
+
:root[data-theme="rot"] .modal-head { border-bottom: 1px solid var(--border-default); }
|
|
245
|
+
:root[data-theme="rot"] .modal-title { font-family: var(--font-display); color: var(--bone); font-weight: 400; }
|
|
246
|
+
|
|
247
|
+
/* CMDK */
|
|
248
|
+
:root[data-theme="rot"] .cmdk { background: var(--bg-elevated); border: 1px solid var(--border-strong); border-radius: 4px; }
|
|
249
|
+
:root[data-theme="rot"] .cmdk-item.active { background: var(--bg-active); color: hsl(var(--accent)); }
|
|
@@ -0,0 +1,272 @@
|
|
|
1
|
+
/* ============================================================================
|
|
2
|
+
* themes/steampunk.css — brass, copper, oiled leather, riveted plates.
|
|
3
|
+
*
|
|
4
|
+
* Reads like the inside of a Verne submarine.
|
|
5
|
+
* Ported from design_handoff_machinaos_themes/themes/steampunk.css.
|
|
6
|
+
* ============================================================================ */
|
|
7
|
+
|
|
8
|
+
:root[data-theme="steampunk"] {
|
|
9
|
+
--bg-app: #2a1f12;
|
|
10
|
+
--bg-panel: #3a2a18;
|
|
11
|
+
--bg-canvas: #1a1208;
|
|
12
|
+
--bg-elevated: #4a3620;
|
|
13
|
+
--bg-input: #1a1208;
|
|
14
|
+
--bg-hover: rgba(200, 140, 40, 0.10);
|
|
15
|
+
--bg-active: rgba(200, 140, 40, 0.20);
|
|
16
|
+
--bg-overlay: rgba(20, 12, 6, 0.7);
|
|
17
|
+
|
|
18
|
+
--border-default: #6a4a20;
|
|
19
|
+
--border-strong: #b88838;
|
|
20
|
+
--border-focus: #d8a848;
|
|
21
|
+
--ornament-frame: none;
|
|
22
|
+
|
|
23
|
+
--fg-default: #e8d8b0;
|
|
24
|
+
--fg-muted: #b8a070;
|
|
25
|
+
--fg-faint: #786040;
|
|
26
|
+
--fg-on-accent: #2a1f12;
|
|
27
|
+
--fg-on-success: #2a1f12;
|
|
28
|
+
--fg-on-danger: #e8d8b0;
|
|
29
|
+
--fg-on-warning: #2a1f12;
|
|
30
|
+
|
|
31
|
+
--copper: #b8602a;
|
|
32
|
+
--rust: #8a3a1a;
|
|
33
|
+
--leather: #4a2818;
|
|
34
|
+
--brass: #d8a848;
|
|
35
|
+
|
|
36
|
+
--font-display: 'IM Fell English SC', 'Cinzel', serif;
|
|
37
|
+
--font-body: 'IM Fell English', 'EB Garamond', serif;
|
|
38
|
+
--font-mono: 'Special Elite', 'Courier Prime', monospace;
|
|
39
|
+
--type-scale-base: 14px;
|
|
40
|
+
--type-tracking-display: 0.10em;
|
|
41
|
+
--type-uppercase: uppercase;
|
|
42
|
+
|
|
43
|
+
--radius-sm: 2px;
|
|
44
|
+
--radius-md: 4px;
|
|
45
|
+
--radius-lg: 8px;
|
|
46
|
+
--radius-pill: 999px;
|
|
47
|
+
|
|
48
|
+
--dur-fast: 110ms;
|
|
49
|
+
--dur-default: 240ms;
|
|
50
|
+
--dur-slow: 480ms;
|
|
51
|
+
--ease-default: cubic-bezier(0.5, 0, 0.4, 1.1);
|
|
52
|
+
--ease-emphasis: cubic-bezier(0.7, -0.1, 0.3, 1.2);
|
|
53
|
+
--motion-style: mechanical;
|
|
54
|
+
--sound-pack: clockwork;
|
|
55
|
+
|
|
56
|
+
/* Wave 30: copper-accent pulse — high-contrast against leather +
|
|
57
|
+
* brass canvas, matches the rivet decorations. */
|
|
58
|
+
--node-pulse-color: hsl(var(--accent));
|
|
59
|
+
|
|
60
|
+
--cursor-default: auto;
|
|
61
|
+
--cursor-pointer: pointer;
|
|
62
|
+
--scrollbar-track: #2a1f12;
|
|
63
|
+
--scrollbar-thumb: #b88838;
|
|
64
|
+
|
|
65
|
+
/* Shadcn HSL bridge */
|
|
66
|
+
--background: 28 41% 12%;
|
|
67
|
+
--foreground: 40 53% 80%;
|
|
68
|
+
--card: 31 38% 21%;
|
|
69
|
+
--card-foreground: 40 53% 80%;
|
|
70
|
+
--popover: 31 38% 21%;
|
|
71
|
+
--popover-foreground: 40 53% 80%;
|
|
72
|
+
|
|
73
|
+
--primary: 40 64% 56%; /* brass */
|
|
74
|
+
--primary-foreground: 28 41% 12%;
|
|
75
|
+
--secondary: 30 39% 16%;
|
|
76
|
+
--secondary-foreground: 40 53% 80%;
|
|
77
|
+
--muted: 30 39% 16%;
|
|
78
|
+
--muted-foreground: 40 35% 58%;
|
|
79
|
+
--accent: 18 63% 44%; /* copper */
|
|
80
|
+
--accent-foreground: 28 41% 12%;
|
|
81
|
+
|
|
82
|
+
--destructive: 14 68% 32%; /* rust */
|
|
83
|
+
--destructive-foreground: 40 53% 80%;
|
|
84
|
+
--success: 79 41% 38%;
|
|
85
|
+
--warning: 40 64% 56%;
|
|
86
|
+
--info: 200 39% 47%;
|
|
87
|
+
|
|
88
|
+
--border: 33 53% 27%;
|
|
89
|
+
--input: 33 53% 27%;
|
|
90
|
+
--ring: 40 64% 56%;
|
|
91
|
+
|
|
92
|
+
/* Action role bridge */
|
|
93
|
+
--action-run: 79 41% 38%;
|
|
94
|
+
--action-run-soft: 79 41% 38% / 0.20;
|
|
95
|
+
--action-run-hover: 79 41% 38% / 0.34;
|
|
96
|
+
--action-run-border: 79 41% 38% / 0.7;
|
|
97
|
+
|
|
98
|
+
--action-stop: 14 68% 32%;
|
|
99
|
+
--action-stop-soft: 14 68% 32% / 0.20;
|
|
100
|
+
--action-stop-hover: 14 68% 32% / 0.34;
|
|
101
|
+
--action-stop-border: 14 68% 32% / 0.7;
|
|
102
|
+
|
|
103
|
+
--action-save: 40 64% 56%;
|
|
104
|
+
--action-save-soft: 40 64% 56% / 0.22;
|
|
105
|
+
--action-save-hover: 40 64% 56% / 0.36;
|
|
106
|
+
--action-save-border: 40 64% 56% / 0.7;
|
|
107
|
+
|
|
108
|
+
--action-config: 40 64% 56%;
|
|
109
|
+
--action-config-soft: 40 64% 56% / 0.18;
|
|
110
|
+
--action-config-hover: 40 64% 56% / 0.30;
|
|
111
|
+
--action-config-border: 40 64% 56% / 0.6;
|
|
112
|
+
|
|
113
|
+
--action-secret: 200 39% 47%;
|
|
114
|
+
--action-secret-soft: 200 39% 47% / 0.18;
|
|
115
|
+
--action-secret-hover: 200 39% 47% / 0.30;
|
|
116
|
+
--action-secret-border: 200 39% 47% / 0.6;
|
|
117
|
+
|
|
118
|
+
--action-tools: 18 63% 44%;
|
|
119
|
+
--action-tools-soft: 18 63% 44% / 0.20;
|
|
120
|
+
--action-tools-hover: 18 63% 44% / 0.34;
|
|
121
|
+
--action-tools-border: 18 63% 44% / 0.6;
|
|
122
|
+
|
|
123
|
+
--tint-soft: 16%;
|
|
124
|
+
--tint-border: 40%;
|
|
125
|
+
|
|
126
|
+
/* Canvas backplane — engine-room brass bolts on 80x80 tile */
|
|
127
|
+
--canvas-grid:
|
|
128
|
+
url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='80' height='80'><g fill='%23b88838' opacity='0.10'><circle cx='40' cy='40' r='1.5'/><circle cx='10' cy='10' r='1'/><circle cx='70' cy='70' r='1'/></g></svg>");
|
|
129
|
+
--canvas-grid-opacity: 1;
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
/* Body — riveted leather grain */
|
|
133
|
+
:root[data-theme="steampunk"] body {
|
|
134
|
+
background:
|
|
135
|
+
url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='l'><feTurbulence baseFrequency='0.8' numOctaves='2'/><feColorMatrix values='0 0 0 0 0.16 0 0 0 0 0.10 0 0 0 0 0.04 0 0 0 0.4 0'/></filter><rect width='200' height='200' filter='url(%23l)'/></svg>"),
|
|
136
|
+
var(--bg-app);
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
:root[data-theme="steampunk"] ::selection {
|
|
140
|
+
background: rgba(216, 168, 72, 0.5);
|
|
141
|
+
color: #2a1f12;
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
/* Steampunk scrollbars — brass thumb on leather track with metallic highlight */
|
|
145
|
+
:root[data-theme="steampunk"] ::-webkit-scrollbar {
|
|
146
|
+
width: 12px;
|
|
147
|
+
height: 12px;
|
|
148
|
+
}
|
|
149
|
+
:root[data-theme="steampunk"] ::-webkit-scrollbar-track {
|
|
150
|
+
background: var(--scrollbar-track);
|
|
151
|
+
}
|
|
152
|
+
:root[data-theme="steampunk"] ::-webkit-scrollbar-thumb {
|
|
153
|
+
background: var(--scrollbar-thumb);
|
|
154
|
+
border-radius: var(--radius-sm, 2px);
|
|
155
|
+
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2);
|
|
156
|
+
}
|
|
157
|
+
:root[data-theme="steampunk"] ::-webkit-scrollbar-thumb:hover {
|
|
158
|
+
background: color-mix(in srgb, var(--scrollbar-thumb) 80%, white);
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
/* ── Per-component decorations (Wave 16 port from handoff) ─────────────── */
|
|
162
|
+
|
|
163
|
+
:root[data-theme="steampunk"] .toolbar,
|
|
164
|
+
:root[data-theme="steampunk"] .sidebar,
|
|
165
|
+
:root[data-theme="steampunk"] .palette,
|
|
166
|
+
:root[data-theme="steampunk"] .chat {
|
|
167
|
+
background:
|
|
168
|
+
linear-gradient(180deg, rgba(216,168,72,0.04), transparent 30%, rgba(0,0,0,0.2)),
|
|
169
|
+
url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='l'><feTurbulence baseFrequency='0.7' numOctaves='2'/><feColorMatrix values='0 0 0 0 0.20 0 0 0 0 0.13 0 0 0 0 0.06 0 0 0 0.5 0'/></filter><rect width='200' height='200' filter='url(%23l)'/></svg>"),
|
|
170
|
+
var(--bg-panel);
|
|
171
|
+
}
|
|
172
|
+
/* Riveted edges */
|
|
173
|
+
:root[data-theme="steampunk"] .toolbar {
|
|
174
|
+
border-bottom: 4px ridge var(--border-strong);
|
|
175
|
+
box-shadow: inset 0 -3px 0 var(--copper);
|
|
176
|
+
}
|
|
177
|
+
:root[data-theme="steampunk"] .sidebar { border-right: 3px solid var(--border-strong); }
|
|
178
|
+
:root[data-theme="steampunk"] .palette { border-left: 3px solid var(--border-strong); }
|
|
179
|
+
:root[data-theme="steampunk"] .chat { border-top: 3px solid var(--border-strong); }
|
|
180
|
+
|
|
181
|
+
/* Canvas — engine-room floor with bolt pattern */
|
|
182
|
+
:root[data-theme="steampunk"] .canvas {
|
|
183
|
+
background:
|
|
184
|
+
radial-gradient(circle at 20% 20%, var(--copper) 0%, transparent 1.5%),
|
|
185
|
+
radial-gradient(circle at 80% 30%, var(--copper) 0%, transparent 1.5%),
|
|
186
|
+
radial-gradient(circle at 30% 80%, var(--copper) 0%, transparent 1.5%),
|
|
187
|
+
radial-gradient(circle at 90% 90%, var(--copper) 0%, transparent 1.5%),
|
|
188
|
+
url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='80' height='80'><g fill='%23b88838' opacity='0.10'><circle cx='40' cy='40' r='1.5'/><circle cx='10' cy='10' r='1'/><circle cx='70' cy='70' r='1'/></g></svg>"),
|
|
189
|
+
var(--bg-canvas);
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
/* Typography */
|
|
193
|
+
:root[data-theme="steampunk"] body { font-family: var(--font-body); color: var(--fg-default); }
|
|
194
|
+
:root[data-theme="steampunk"] h1, :root[data-theme="steampunk"] h2, :root[data-theme="steampunk"] h3,
|
|
195
|
+
:root[data-theme="steampunk"] .v-display {
|
|
196
|
+
font-family: var(--font-display); letter-spacing: 0.16em; text-transform: uppercase; color: hsl(var(--accent));
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
/* Square node — riveted brass plate */
|
|
200
|
+
:root[data-theme="steampunk"] .sq-node-box {
|
|
201
|
+
background: linear-gradient(180deg, hsl(var(--accent)), var(--copper));
|
|
202
|
+
border: 2px solid var(--leather); border-radius: 4px;
|
|
203
|
+
box-shadow:
|
|
204
|
+
inset 0 0 0 1px hsl(var(--accent)),
|
|
205
|
+
inset 1px 1px 2px rgba(255,220,160,0.4),
|
|
206
|
+
inset -2px -2px 4px rgba(0,0,0,0.4),
|
|
207
|
+
0 4px 0 var(--leather);
|
|
208
|
+
color: var(--leather);
|
|
209
|
+
position: relative;
|
|
210
|
+
}
|
|
211
|
+
:root[data-theme="steampunk"] .sq-node-box::before,
|
|
212
|
+
:root[data-theme="steampunk"] .sq-node-box::after {
|
|
213
|
+
content: ''; position: absolute; width: 4px; height: 4px; border-radius: 50%;
|
|
214
|
+
background: radial-gradient(circle, var(--copper), var(--leather));
|
|
215
|
+
box-shadow: inset 0 0 0 1px rgba(0,0,0,0.4);
|
|
216
|
+
}
|
|
217
|
+
:root[data-theme="steampunk"] .sq-node-box::before { top: 3px; left: 3px; }
|
|
218
|
+
:root[data-theme="steampunk"] .sq-node-box::after { bottom: 3px; right: 3px; }
|
|
219
|
+
:root[data-theme="steampunk"] .sq-node.selected .sq-node-box {
|
|
220
|
+
box-shadow: inset 0 0 0 2px hsl(var(--accent)), 0 0 12px hsl(var(--accent)), 0 4px 0 var(--leather);
|
|
221
|
+
}
|
|
222
|
+
:root[data-theme="steampunk"] .sq-node-gear { background: var(--copper); color: hsl(var(--accent)); border: 1px solid var(--leather); }
|
|
223
|
+
:root[data-theme="steampunk"] .sq-node-label { font-family: var(--font-display); letter-spacing: 0.10em; color: hsl(var(--accent)); }
|
|
224
|
+
|
|
225
|
+
/* Actions — engraved brass plates */
|
|
226
|
+
:root[data-theme="steampunk"] .action-btn {
|
|
227
|
+
font-family: var(--font-display); letter-spacing: 0.12em; text-transform: uppercase;
|
|
228
|
+
border-radius: 2px; border-width: 2px;
|
|
229
|
+
background: linear-gradient(180deg, rgba(216,168,72,0.20), rgba(216,168,72,0.05));
|
|
230
|
+
}
|
|
231
|
+
:root[data-theme="steampunk"] .action-run { background: linear-gradient(180deg, rgba(106,138,58,0.4), rgba(106,138,58,0.1)); color: #c8e08a; border-color: hsl(var(--success)); }
|
|
232
|
+
:root[data-theme="steampunk"] .action-deploy { color: hsl(var(--accent)); border-color: hsl(var(--accent)); }
|
|
233
|
+
:root[data-theme="steampunk"] .action-save { color: hsl(var(--accent)); border-color: hsl(var(--accent)); }
|
|
234
|
+
|
|
235
|
+
/* Panels */
|
|
236
|
+
:root[data-theme="steampunk"] .wf-card,
|
|
237
|
+
:root[data-theme="steampunk"] .cat,
|
|
238
|
+
:root[data-theme="steampunk"] .comp,
|
|
239
|
+
:root[data-theme="steampunk"] .settings-section,
|
|
240
|
+
:root[data-theme="steampunk"] .cred-card {
|
|
241
|
+
background: var(--bg-elevated); border: 1px solid var(--copper); border-radius: 2px;
|
|
242
|
+
box-shadow: inset 0 1px 0 rgba(255,220,160,0.10);
|
|
243
|
+
}
|
|
244
|
+
:root[data-theme="steampunk"] .cat-tile { background: hsl(var(--accent)); color: var(--leather); border: 1px solid var(--leather); border-radius: 2px; }
|
|
245
|
+
:root[data-theme="steampunk"] .cat-name { font-family: var(--font-display); color: hsl(var(--accent)); }
|
|
246
|
+
|
|
247
|
+
/* Chat */
|
|
248
|
+
:root[data-theme="steampunk"] .chat-msg-user { background: rgba(216,168,72,0.16); border: 1px solid hsl(var(--accent)); color: hsl(var(--accent)); }
|
|
249
|
+
:root[data-theme="steampunk"] .chat-msg-bot { background: var(--bg-elevated); border: 1px solid var(--copper); }
|
|
250
|
+
|
|
251
|
+
/* Status bar — gauge readout */
|
|
252
|
+
:root[data-theme="steampunk"] .statusbar {
|
|
253
|
+
background: linear-gradient(180deg, var(--bg-panel), var(--leather));
|
|
254
|
+
border-top: 3px ridge var(--border-strong);
|
|
255
|
+
font-family: var(--font-mono); color: hsl(var(--accent)); letter-spacing: 0.10em;
|
|
256
|
+
}
|
|
257
|
+
:root[data-theme="steampunk"] .statusbar .pip { background: hsl(var(--success)); box-shadow: 0 0 4px hsl(var(--success)); }
|
|
258
|
+
|
|
259
|
+
/* Modal */
|
|
260
|
+
:root[data-theme="steampunk"] .modal {
|
|
261
|
+
background: linear-gradient(180deg, var(--bg-elevated), var(--bg-panel));
|
|
262
|
+
border: 4px ridge var(--border-strong); border-radius: 4px;
|
|
263
|
+
box-shadow: 0 0 0 2px var(--leather), 0 30px 80px rgba(0,0,0,0.6);
|
|
264
|
+
}
|
|
265
|
+
:root[data-theme="steampunk"] .modal-head { border-bottom: 3px ridge var(--copper); }
|
|
266
|
+
:root[data-theme="steampunk"] .modal-title { font-family: var(--font-display); color: hsl(var(--accent)); letter-spacing: 0.14em; }
|
|
267
|
+
|
|
268
|
+
/* CMDK */
|
|
269
|
+
:root[data-theme="steampunk"] .cmdk {
|
|
270
|
+
background: var(--bg-elevated); border: 4px ridge var(--border-strong); border-radius: 4px;
|
|
271
|
+
}
|
|
272
|
+
:root[data-theme="steampunk"] .cmdk-item.active { background: var(--bg-active); color: hsl(var(--accent)); border-left: 3px solid var(--copper); }
|