@primer/primitives
Version:
Typography, spacing, and color primitives for Primer design system
200 lines (199 loc) • 10 kB
CSS
: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). */
}