UNPKG

@primer/primitives

Version:

Typography, spacing, and color primitives for Primer design system

200 lines (199 loc) 10 kB
:root { --base-duration-0: 0ms; --base-duration-100: 100ms; --base-duration-1000: 1s; --base-duration-200: 200ms; --base-duration-300: 300ms; --base-duration-400: 400ms; --base-duration-50: 50ms; --base-duration-500: 500ms; --base-duration-600: 600ms; --base-duration-700: 700ms; --base-duration-800: 800ms; --base-duration-900: 900ms; --base-easing-easeIn: cubic-bezier(0.7, 0.1, 0.75, 0.9); /* Ideal for movement that starts on the page and ends off the page. */ --base-easing-easeInOut: cubic-bezier(0.6, 0, 0.2, 1); /* Ideal for movement that starts and ends on the page. */ --base-easing-easeOut: cubic-bezier(0.3, 0.8, 0.6, 1); /* Ideal for movement that starts off the page and ends on the page. */ --base-easing-linear: cubic-bezier(0, 0, 1, 1); /* Ideal for non-movement properties, like opacity or background color. */ } :root { --base-size-112: 7rem; --base-size-12: 0.75rem; --base-size-128: 8rem; --base-size-16: 1rem; --base-size-2: 0.125rem; --base-size-20: 1.25rem; --base-size-24: 1.5rem; --base-size-28: 1.75rem; --base-size-32: 2rem; --base-size-36: 2.25rem; --base-size-4: 0.25rem; --base-size-40: 2.5rem; --base-size-44: 2.75rem; --base-size-48: 3rem; --base-size-6: 0.375rem; --base-size-64: 4rem; --base-size-8: 0.5rem; --base-size-80: 5rem; --base-size-96: 6rem; } :root { --base-text-weight-light: 300; --base-text-weight-medium: 500; --base-text-weight-normal: 400; --base-text-weight-semibold: 600; } :root { --borderRadius-full: 624.9375rem; /* Use this border radius for pill shaped elements */ --borderRadius-large: 0.75rem; --borderRadius-medium: 0.375rem; --borderRadius-small: 0.1875rem; --borderWidth-thick: 0.125rem; --borderWidth-thicker: 0.25rem; --borderWidth-thin: 0.0625rem; --outline-focus-offset: -0.125rem; --outline-focus-width: 0.125rem; --borderRadius-default: var(--borderRadius-medium); --borderWidth-default: var(--borderWidth-thin); --boxShadow-thick: inset 0 0 0 var(--borderWidth-thick); --boxShadow-thicker: inset 0 0 0 var(--borderWidth-thicker); --boxShadow-thin: inset 0 0 0 var(--borderWidth-thin); /* Thin shadow for borders */ } :root { --breakpoint-large: 63.25rem; --breakpoint-medium: 48rem; --breakpoint-small: 34rem; --breakpoint-xlarge: 80rem; --breakpoint-xsmall: 20rem; --breakpoint-xxlarge: 87.5rem; } @media (pointer: coarse) { :root { --control-minTarget-auto: 2.75rem; --controlStack-medium-gap-auto: 0.75rem; --controlStack-small-gap-auto: 1rem; } } @media (pointer: fine) { :root { --control-minTarget-auto: 1rem; --controlStack-medium-gap-auto: 0.5rem; --controlStack-small-gap-auto: 0.5rem; } } :root { --control-large-paddingBlock: 0.625rem; --control-medium-paddingBlock: 0.375rem; --control-xlarge-paddingBlock: 0.875rem; --control-xsmall-paddingBlock: 0.125rem; --overlay-height-large: 27rem; --overlay-height-medium: 20rem; --overlay-height-small: 16rem; --overlay-height-xlarge: 37.5rem; --overlay-offset: 0.25rem; --overlay-width-large: 40rem; --overlay-width-medium: 30rem; --overlay-width-small: 20rem; --overlay-width-xlarge: 60rem; --overlay-width-xsmall: 12rem; --spinner-strokeWidth-default: 0.125rem; --control-large-gap: 0.5rem; --control-large-lineBoxHeight: 1.25rem; --control-large-paddingInline-normal: 0.75rem; --control-large-paddingInline-spacious: 1rem; --control-large-size: 2.5rem; --control-medium-gap: 0.5rem; --control-medium-lineBoxHeight: 1.25rem; --control-medium-paddingInline-condensed: 0.5rem; --control-medium-paddingInline-normal: 0.75rem; --control-medium-paddingInline-spacious: 1rem; --control-medium-size: 2rem; --control-minTarget-coarse: 2.75rem; --control-minTarget-fine: 1rem; --control-small-gap: 0.25rem; --control-small-lineBoxHeight: 1.25rem; --control-small-paddingBlock: 0.25rem; --control-small-paddingInline-condensed: 0.5rem; --control-small-paddingInline-normal: 0.75rem; --control-small-size: 1.75rem; --control-xlarge-gap: 0.5rem; --control-xlarge-lineBoxHeight: 1.25rem; --control-xlarge-paddingInline-normal: 0.75rem; --control-xlarge-paddingInline-spacious: 1rem; --control-xlarge-size: 3rem; --control-xsmall-gap: 0.25rem; --control-xsmall-lineBoxHeight: 1.25rem; --control-xsmall-paddingInline-condensed: 0.25rem; --control-xsmall-paddingInline-normal: 0.5rem; --control-xsmall-paddingInline-spacious: 0.75rem; --control-xsmall-size: 1.5rem; --controlStack-large-gap-auto: 0.5rem; --controlStack-large-gap-condensed: 0.5rem; --controlStack-large-gap-spacious: 0.75rem; --controlStack-medium-gap-condensed: 0.5rem; --controlStack-medium-gap-spacious: 0.75rem; --controlStack-small-gap-condensed: 0.5rem; --controlStack-small-gap-spacious: 1rem; --overlay-borderRadius: 0.375rem; --overlay-padding-condensed: 0.5rem; --overlay-padding-normal: 1rem; --overlay-paddingBlock-condensed: 0.25rem; --overlay-paddingBlock-normal: 0.75rem; --spinner-size-large: 4rem; --spinner-size-medium: 2rem; --spinner-size-small: 1rem; --stack-gap-condensed: 0.5rem; --stack-gap-normal: 1rem; --stack-gap-spacious: 1.5rem; --stack-padding-condensed: 0.5rem; --stack-padding-normal: 1rem; --stack-padding-spacious: 1.5rem; } :root { --fontStack-monospace: ui-monospace, SFMono-Regular, SF Mono, Menlo, Consolas, Liberation Mono, monospace; --fontStack-sansSerif: -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans", Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji"; --fontStack-sansSerifDisplay: -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans", Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji"; --fontStack-system: -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans", Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji"; --text-body-lineHeight-large: 1.5; --text-body-lineHeight-medium: 1.4285; --text-body-lineHeight-small: 1.6666; --text-body-size-large: 1rem; --text-body-size-medium: 0.875rem; --text-body-size-small: 0.75rem; --text-caption-lineHeight: 1.3333; --text-caption-size: 0.75rem; --text-codeBlock-lineHeight: 1.5385; --text-codeBlock-size: 0.8125rem; --text-codeInline-size: 0.9285em; --text-display-lineBoxHeight: 1.4; --text-display-lineHeight: 1.4; --text-display-size: 2.5rem; --text-subtitle-lineHeight: 1.6; --text-subtitle-size: 1.25rem; --text-title-lineHeight-large: 1.5; --text-title-lineHeight-medium: 1.6; --text-title-lineHeight-small: 1.5; --text-title-size-large: 2rem; --text-title-size-medium: 1.25rem; --text-title-size-small: 1rem; --text-body-weight: var(--base-text-weight-normal); --text-caption-weight: var(--base-text-weight-normal); --text-codeBlock-weight: var(--base-text-weight-normal); --text-codeInline-weight: var(--base-text-weight-normal); --text-display-weight: var(--base-text-weight-medium); --text-subtitle-weight: var(--base-text-weight-normal); --text-title-weight-large: var(--base-text-weight-semibold); --text-title-weight-medium: var(--base-text-weight-semibold); --text-title-weight-small: var(--base-text-weight-semibold); --text-body-shorthand-large: var(--text-body-weight) var(--text-body-size-large) / var(--text-body-lineHeight-large) var(--fontStack-sansSerif); /* User-generated content, markdown rendering. */ --text-body-shorthand-medium: var(--text-body-weight) var(--text-body-size-medium) / var(--text-body-lineHeight-medium) var(--fontStack-sansSerif); /* Default UI font. Most commonly used for body text. */ --text-body-shorthand-small: var(--text-body-weight) var(--text-body-size-small) / var(--text-body-lineHeight-small) var(--fontStack-sansSerif); /* Small body text for discrete UI applications, such as helper, footnote text. Should be used sparingly across pages. Line-height matches Body (medium) at 20px. */ --text-caption-shorthand: var(--text-caption-weight) var(--text-caption-size) / var(--text-caption-lineHeight) var(--fontStack-sansSerif); /* Compact small font with a smaller line height of 16px. Use it for single-line scenarios, as the small sizing doesn’t pass accessibility requirements. */ --text-codeBlock-shorthand: var(--text-codeBlock-weight) var(--text-codeBlock-size) / var(--text-codeBlock-lineHeight) var(--fontStack-monospace); /* Default style for rendering code blocks. */ --text-codeInline-shorthand: var(--text-codeInline-weight) var(--text-codeInline-size) var(--fontStack-monospace); /* Inline code blocks using em units to inherit size from its parent. */ --text-display-shorthand: var(--text-display-weight) var(--text-display-size) / var(--text-display-lineHeight) var(--fontStack-sansSerifDisplay); /* Hero-style text for brand to product transition pages. Utilize Title (large) styles on narrow viewports. */ --text-subtitle-shorthand: var(--text-subtitle-weight) var(--text-subtitle-size) / var(--text-subtitle-lineHeight) var(--fontStack-sansSerifDisplay); /* Page sections/sub headings, or less important object names in page titles (automated action titles, for example). Same line-height as title (medium). */ --text-title-shorthand-large: var(--text-title-weight-large) var(--text-title-size-large) / var(--text-title-lineHeight-large) var(--fontStack-sansSerifDisplay); /* Page headings for user-created objects, such as issues or pull requests. Utilize title (medium) styles on narrow viewports. */ --text-title-shorthand-medium: var(--text-title-weight-medium) var(--text-title-size-medium) / var(--text-title-lineHeight-medium) var(--fontStack-sansSerifDisplay); /* Default page title. The 32px-equivalent line-height matches with button and other medium control heights. Great for page header composition. */ --text-title-shorthand-small: var(--text-title-weight-small) var(--text-title-size-small) / var(--text-title-lineHeight-small) var(--fontStack-sansSerif); /* Uses the same size as body (large) with a heavier weight of semibold (600). */ }