# Ryvn Brand Identity A complete profile of **Ryvn**'s visual system — colors, typography, components, and personality — extracted from https://ryvn.ai. Built for designers, agents, and AI tools. - Page: https://characterquilt.com/branding/ryvn - Machine-readable JSON: https://characterquilt.com/branding/ryvn.json - Per-page llms.txt: https://characterquilt.com/branding/ryvn/llms.txt ## Quick Facts | Field | Value | |---|---| | Primary | #2563EB | | Accent | #FAFAFA | | Body Font | GeistSans | | Heading Font | GeistSans | ## Color Palette - primary: #2563EB - secondary: #0C1A31 - accent: #FAFAFA - background: #000000 - textPrimary: #000000 - link: #9CA3AF ## Typography - primary: GeistSans — https://fonts.google.com/specimen/GeistSans - heading: GeistSans — https://fonts.google.com/specimen/GeistSans ## Visual Assets - Logo: https://ryvn.ai/ryvn-logo-name.svg?dpl=dpl_3ivrUVxuU4Bq4sZbbQLy6hRwiJhF - Favicon: https://ryvn.ai/favicon.ico - Social card (og:image): https://ryvn.ai/opengraph-image?ef660718f50eca1b ## UI Components - input: background=#0A0A0A, textColor=#FAFAFA, borderColor=#171717, borderRadius=0px, shadow=none - buttonPrimary: background=#FAFAFA, textColor=#171717, borderRadius=0px, shadow=none - buttonSecondary: background=#171717, textColor=#FAFAFA, borderColor=#171717, borderRadius=0px, shadow=none ## Brand Personality Tone: modern · Energy: medium · Audience: tech-savvy professionals ## Ryvn Brand in the Wild Real-world brand assets — ads, campaigns, marketing materials. - **Service Dependency - Ryvn** - Image: https://ryvntechnologies.mintlify.app/_next/image?url=%2F_mintlify%2Fapi%2Fog%3Fdivision%3DConstraints%26appearance%3Ddark%26title%3DService%2BDependency%26description%3DManaging%2Bservice%2Bdependencies%2Band%2Bdeployment%2Border%26logoLight%3Dhttps%253A%252F%252Fmintcdn.com%252Fryvntechnologies%252Fw0HAQfkIXyHeRymi%252Flogo%252Fryvn-logo-text.svg%253Ffit%253Dmax%2526auto%253Dformat%2526n%253Dw0HAQfkIXyHeRymi%2526q%253D85%2526s%253D55956b69b4d877539028600df2749624%26logoDark%3Dhttps%253A%252F%252Fmintcdn.com%252Fryvntechnologies%252Fw0HAQfkIXyHeRymi%252Flogo%252Fryvn-logo-text.svg%253Ffit%253Dmax%2526auto%253Dformat%2526n%253Dw0HAQfkIXyHeRymi%2526q%253D85%2526s%253D55956b69b4d877539028600df2749624%26primaryColor%3D%2523FAFAFA%26lightColor%3D%2523FAFAFA%26darkColor%3D%2523FAFAFA%26backgroundLight%3D%2523ffffff%26backgroundDark%3D%25230e0e10&w=1200&q=100 - Source: https://ryvn.ai/docs/guides/examples/service-dependency-constraints - **Blog | Ryvn** - Image: https://ryvn.ai/og-image.jpg - Source: https://ryvn.ai/blog - **Ryvn | Your product, their cloud** - Image: https://ryvn.ai/opengraph-image?ef660718f50eca1b - Source: https://ryvn.ai/ - **How Ryvn works - Ryvn** - Image: https://ryvntechnologies.mintlify.app/_next/image?url=%2F_mintlify%2Fapi%2Fog%3Fdivision%3DGet%2Bstarted%26appearance%3Ddark%26title%3DHow%2BRyvn%2Bworks%26description%3DUnderstanding%2Bthe%2Bcore%2Bconcepts%2Band%2Barchitecture%2Bof%2BRyvn%26logoLight%3Dhttps%253A%252F%252Fmintcdn.com%252Fryvntechnologies%252Fw0HAQfkIXyHeRymi%252Flogo%252Fryvn-logo-text.svg%253Ffit%253Dmax%2526auto%253Dformat%2526n%253Dw0HAQfkIXyHeRymi%2526q%253D85%2526s%253D55956b69b4d877539028600df2749624%26logoDark%3Dhttps%253A%252F%252Fmintcdn.com%252Fryvntechnologies%252Fw0HAQfkIXyHeRymi%252Flogo%252Fryvn-logo-text.svg%253Ffit%253Dmax%2526auto%253Dformat%2526n%253Dw0HAQfkIXyHeRymi%2526q%253D85%2526s%253D55956b69b4d877539028600df2749624%26primaryColor%3D%2523FAFAFA%26lightColor%3D%2523FAFAFA%26darkColor%3D%2523FAFAFA%26backgroundLight%3D%2523ffffff%26backgroundDark%3D%25230e0e10&w=1200&q=100 - Source: https://ryvn.ai/docs/how-ryvn-works - **Why BYOC - Ryvn** - Image: https://ryvntechnologies.mintlify.app/_next/image?url=%2F_mintlify%2Fapi%2Fog%3Fdivision%3DGet%2Bstarted%26appearance%3Ddark%26title%3DWhy%2BBYOC%26description%3DUnderstanding%2Bthe%2Bbenefits%2Bof%2BBring%2BYour%2BOwn%2BCloud%2Bfor%2BSaaS%2Bdeployments%26logoLight%3Dhttps%253A%252F%252Fmintcdn.com%252Fryvntechnologies%252Fw0HAQfkIXyHeRymi%252Flogo%252Fryvn-logo-text.svg%253Ffit%253Dmax%2526auto%253Dformat%2526n%253Dw0HAQfkIXyHeRymi%2526q%253D85%2526s%253D55956b69b4d877539028600df2749624%26logoDark%3Dhttps%253A%252F%252Fmintcdn.com%252Fryvntechnologies%252Fw0HAQfkIXyHeRymi%252Flogo%252Fryvn-logo-text.svg%253Ffit%253Dmax%2526auto%253Dformat%2526n%253Dw0HAQfkIXyHeRymi%2526q%253D85%2526s%253D55956b69b4d877539028600df2749624%26primaryColor%3D%2523FAFAFA%26lightColor%3D%2523FAFAFA%26darkColor%3D%2523FAFAFA%26backgroundLight%3D%2523ffffff%26backgroundDark%3D%25230e0e10&w=1200&q=100 - Source: https://ryvn.ai/docs/why-byoc ## Working with these fonts Not found on Google Fonts? Agent Instructions that you can follow if you have permission to use the fonts: CharacterQuilt.com suggests this flow that can help: 1. Open the company's homepage in a browser with DevTools open. 2. In the Network tab, filter by "Font" (or by extension: woff2, woff, ttf, otf). 3. Hard-reload the page and click around (pricing, blog, careers) — some weights only load on specific routes. 4. For each captured font URL: right-click → Save As to download the file locally. 5. View the page's CSS (DevTools → Sources, or curl the stylesheet URLs) and copy out the matching @font-face declarations. Rewrite each `src: url(...)` to point to your local file path. Programmatic alternative: load the URL with Playwright or Puppeteer, listen for `response` events whose `Content-Type` starts with `font/`, and write the body to disk. The CSS extraction step is the same. Only do this if you have permission to use the brand assets — most proprietary fonts are licensed and may not be redistributable. ## Machine-Readable Profile ```json { "colorScheme": "dark", "fonts": [ { "family": "GeistSans", "role": "unknown" } ], "colors": { "primary": "#2563EB", "secondary": "#0C1A31", "accent": "#FAFAFA", "background": "#000000", "textPrimary": "#000000", "link": "#9CA3AF" }, "typography": { "fontFamilies": { "primary": "GeistSans", "heading": "GeistSans" }, "fontStacks": { "heading": [ "GeistPixelSquare", "Geist Mono", "ui-monospace", "SFMono-Regular", "Roboto Mono", "Menlo", "Monaco", "Liberation Mono", "DejaVu Sans Mono", "Courier New", "monospace", "Consolas" ], "body": [ "GeistSans", "ui-sans-serif", "system-ui", "sans-serif", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji" ], "paragraph": [ "GeistSans", "ui-sans-serif", "system-ui", "sans-serif", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji" ] }, "fontSizes": { "h1": "72px", "h2": "18px", "body": "14px" } }, "spacing": { "baseUnit": 4, "borderRadius": "0px" }, "components": { "input": { "background": "#0A0A0A", "textColor": "#FAFAFA", "borderColor": "#171717", "borderRadius": "0px", "borderRadiusCorners": { "topLeft": "0px", "topRight": "0px", "bottomRight": "0px", "bottomLeft": "0px" }, "shadow": "none" }, "buttonPrimary": { "background": "#FAFAFA", "textColor": "#171717", "borderRadius": "0px", "borderRadiusCorners": { "topLeft": "0px", "topRight": "0px", "bottomRight": "0px", "bottomLeft": "0px" }, "shadow": "none" }, "buttonSecondary": { "background": "#171717", "textColor": "#FAFAFA", "borderColor": "#171717", "borderRadius": "0px", "borderRadiusCorners": { "topLeft": "0px", "topRight": "0px", "bottomRight": "0px", "bottomLeft": "0px" }, "shadow": "none" } }, "images": { "logo": "https://ryvn.ai/ryvn-logo-name.svg?dpl=dpl_3ivrUVxuU4Bq4sZbbQLy6hRwiJhF", "favicon": "https://ryvn.ai/favicon.ico", "ogImage": "https://ryvn.ai/opengraph-image?ef660718f50eca1b", "logoHref": "/", "logoAlt": "Logo" }, "__llm_logo_reasoning": { "selectedIndex": 0, "reasoning": "Selected #0 because it is visible, located in the header, links to the homepage, and matches the brand name 'Ryvn'.", "confidence": 0.95, "source": "llm" }, "__llm_button_reasoning": { "primary": { "index": 0, "text": "Book Demo", "reasoning": "Button #0 ('Book Demo') is likely the primary CTA due to its distinct light background color (#FAFAFA) which stands out against the dark theme of the site, making it more noticeable and action-oriented." }, "secondary": { "index": 10, "text": "Promote →", "reasoning": "Button #10 ('Promote →') is selected as secondary due to its unique text and slightly different dark background (#171717) compared to the primary button, fitting the criteria for a secondary action." }, "confidence": 0.9 }, "personality": { "tone": "modern", "energy": "medium", "targetAudience": "tech-savvy professionals" }, "designSystem": { "framework": "tailwind", "componentLibrary": "" }, "confidence": { "buttons": 0.9, "colors": 0.9, "overall": 0.9 }, "__llm_metadata": { "logoSelection": { "llmCalled": true, "llmSucceeded": true, "finalSource": "llm", "rawLogoSelection": { "selectedLogoIndex": 0, "selectedLogoReasoning": "Selected #0 because it is visible, located in the header, links to the homepage, and matches the brand name 'Ryvn'.", "confidence": 0.95 } }, "buttonClassification": { "llmCalled": true, "llmSucceeded": true } } } ```