{"version":3,"sources":["../src/src/forms/form-control.scss","../src/src/support/variables/typography.scss","../src/src/support/variables/misc.scss","../src/src/support/mixins/layout.scss","../src/src/support/variables/layout.scss","../src/src/forms/form-select.scss","../src/src/support/mixins/color-modes.scss","../src/src/forms/form-group.scss","../src/src/forms/form-validation.scss","../src/src/forms/input-group.scss","../src/src/forms/radio-group.scss"],"names":[],"mappings":"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","file":"forms.css","sourcesContent":["// Needs refactoring\n// stylelint-disable selector-no-qualifying-type, selector-max-compound-selectors\n// stylelint-disable selector-max-type\n// Base form controls\n//\n// Overrides for common inputs for easier styling.\n\nfieldset {\n  padding: 0;\n  margin: 0;\n  border: 0;\n}\n\nlabel {\n  font-weight: $font-weight-bold;\n}\n\n.form-control,\n.form-select {\n  // stylelint-disable-next-line primer/spacing\n  padding: 5px 12px;\n  font-size: $body-font-size;\n  // stylelint-disable-next-line primer/typography\n  line-height: 20px;\n  color: var(--color-text-primary);\n  vertical-align: middle;\n  background-color: var(--color-input-bg);\n  background-repeat: no-repeat; // Repeat and position set for form states (success, error, etc)\n  background-position: right 8px center; // For form validation. This keeps images 8px from right and centered vertically.\n  border: $border-width $border-style var(--color-input-border);\n  border-radius: $border-radius;\n  outline: none;\n  box-shadow: var(--color-shadow-inset);\n\n  &.focus,\n  &:focus {\n    border-color: var(--color-state-focus-border);\n    outline: none;\n    box-shadow: var(--color-state-focus-shadow);\n  }\n\n  &[disabled] {\n    color: var(--color-text-disabled);\n    background-color: var(--color-input-disabled-bg);\n    border-color: var(--color-input-disabled-border);\n  }\n\n  // Ensures inputs don't zoom on mobile iPhone but are body-font size on iPad\n  @supports (-webkit-touch-callout: none) {\n    font-size: $h4-size;\n    @include breakpoint(md) {\n      font-size: $body-font-size;\n    }\n  }\n}\n\n// Textarea\ntextarea.form-control {\n  padding-top: $spacer-2;\n  padding-bottom: $spacer-2;\n  line-height: $lh-default;\n}\n\n// Inputs with contrast for easy light gray backgrounds against white.\n.input-contrast {\n  background-color: var(--color-input-contrast-bg);\n\n  &:focus { background-color: var(--color-input-bg); }\n}\n\n// Custom styling for HTML5 validation bubbles (WebKit only)\n::placeholder {\n  color: var(--color-text-placeholder);\n  opacity: 1; // override opacity in normalize.css\n}\n\n// Mini inputs, to match .minibutton\n.input-sm {\n  min-height: $size-4;\n  // stylelint-disable-next-line primer/spacing\n  padding-top: 3px;\n  // stylelint-disable-next-line primer/spacing\n  padding-bottom: 3px;\n  font-size: $font-size-small;\n  // stylelint-disable-next-line primer/typography\n  line-height: 20px;\n}\n\n// Large inputs\n.input-lg {\n  font-size: $h4-size;\n}\n\n// Full-width inputs\n.input-block {\n  display: block;\n  width: 100%;\n}\n\n// Inputs with monospace text\n.input-monospace {\n  font-family: $mono-font;\n}\n\n// Hide the icon that tries to autofill contact info in webkit\n.input-hide-webkit-autofill {\n  &::-webkit-contacts-auto-fill-button {\n    position: absolute;\n    right: 0;\n    display: none !important;\n    pointer-events: none;\n    visibility: hidden;\n  }\n}\n\n// Checkboxes and Radiobuttons\n//\n// For checkboxes and radio button selections.\n.form-checkbox {\n  // stylelint-disable-next-line primer/spacing\n  padding-left: 20px;\n  // stylelint-disable-next-line primer/spacing\n  margin: 15px 0;\n  vertical-align: middle;\n\n  label {\n    em.highlight {\n      position: relative;\n      left: -$spacer-1;\n      // stylelint-disable-next-line primer/spacing\n      padding: 2px $spacer-1;\n      font-style: normal;\n      // stylelint-disable-next-line primer/colors\n      background: var(--color-attention-subtle, var(--color-auto-yellow-1));\n      border-radius: $border-radius;\n    }\n  }\n\n  input[type=checkbox],\n  input[type=radio] {\n    float: left;\n    // stylelint-disable-next-line primer/spacing\n    margin: 5px 0 0 -20px;\n    vertical-align: middle;\n  }\n\n  .note {\n    display: block;\n    margin: 0;\n    font-size: $font-size-small;\n    font-weight: $font-weight-normal;\n    color: var(--color-text-secondary);\n  }\n}\n\n.form-checkbox-details {\n  display: none;\n}\n\n.form-checkbox-details-trigger {\n  &:checked {\n    // child of sibling or sibling\n    ~ * .form-checkbox-details,\n    ~ .form-checkbox-details { // eslint-disable selector-combinator-space-before\n      display: block;\n    }\n  }\n}\n\n// Field groups\n//\n// Wrap field groups in `<div.hfields>` to lay them out horizontally - great for\n// the top of pages with autosave.\n.hfields {\n  // stylelint-disable-next-line primer/spacing\n  margin: 15px 0;\n  @include clearfix;\n\n  .form-group {\n    float: left;\n    // stylelint-disable-next-line primer/spacing\n    margin: 0 30px 0 0;\n\n    dt, // TODO: Deprecate\n    .form-group-header {\n      label {\n        display: inline-block;\n        // stylelint-disable-next-line primer/spacing\n        margin: 5px 0 0;\n        color: var(--color-text-secondary);\n      }\n\n      img {\n        position: relative;\n        top: -2px;\n      }\n    }\n  }\n\n  .btn {\n    float: left;\n    // stylelint-disable-next-line primer/spacing\n    margin: 28px 25px 0 -20px;\n  }\n\n  // stylelint-disable-next-line primer/spacing\n  .form-select { margin-top: 5px; }\n}\n\n// Hide the up/down buttons in <input type=\"number\"> in the login form, the\n// input is used for two-factor auth codes, type=\"number\" makes it more usable\n// on phones\ninput::-webkit-outer-spin-button,\ninput::-webkit-inner-spin-button {\n  margin: 0;\n  appearance: none;\n}\n\n// Input groups\n\n.form-actions {\n  @include clearfix;\n\n  .btn {\n    float: right;\n\n    + .btn {\n      // stylelint-disable-next-line primer/spacing\n      margin-right: 5px;\n    }\n  }\n}\n\n.form-warning {\n  padding: $spacer-2 10px;\n  // stylelint-disable-next-line primer/spacing\n  margin: 10px 0;\n  font-size: $h5-size;\n  color: var(--color-text-warning);\n  background: var(--color-bg-warning);\n  border: $border-width $border-style var(--color-border-warning);\n  border-radius: $border-radius;\n\n  p {\n    margin: 0;\n    line-height: $lh-default;\n  }\n\n  a { font-weight: $font-weight-bold; }\n}\n","// Typography variables\n\n// Heading sizes - mobile\n// h4-h6 remain the same size on both mobile & desktop\n$h00-size-mobile: 40px !default;\n$h0-size-mobile: 32px !default;\n$h1-size-mobile: 26px !default;\n$h2-size-mobile: 22px !default;\n$h3-size-mobile: 18px !default;\n\n// Heading sizes - desktop\n$h00-size: 48px !default;\n$h0-size: 40px !default;\n$h1-size: 32px !default;\n$h2-size: 24px !default;\n$h3-size: 20px !default;\n$h4-size: 16px !default;\n$h5-size: 14px !default;\n$h6-size: 12px !default;\n\n$font-size-small: 12px !default;\n\n// Font weights\n$font-weight-bold: 600 !default;\n$font-weight-semibold: 500 !default;\n$font-weight-normal: 400 !default;\n$font-weight-light: 300 !default;\n\n// Line heights\n$lh-condensed-ultra: 1 !default;\n$lh-condensed: 1.25 !default;\n$lh-default: 1.5 !default;\n\n// Font stacks\n// stylelint-disable no-eol-whitespace\n$body-font:\n  // Apple OSs\n  -apple-system,\n  BlinkMacSystemFont,\n  \n  // Windows\n  // Note this should be prioritized over `system-ui` to avoid legacy fonts.\n  // See https://infinnie.github.io/blog/2017/systemui.html\n  \"Segoe UI Variable\",\n  \"Segoe UI\",\n  \n  // Linux-friendly system-level fonts + fallbacks\n  system-ui,\n  ui-sans-serif,\n  Helvetica,\n  Arial,\n  sans-serif,\n  \n  // Emojis\n  \"Apple Color Emoji\",\n  \"Segoe UI Emoji\" !default;\n// stylelint-enable no-eol-whitespace\n\n// Monospace font stack\n// Note: SFMono-Regular needs to come before SF Mono to fix an older version of the font in Chrome\n$mono-font: ui-monospace, SFMono-Regular, SF Mono, Menlo, Consolas, Liberation Mono, monospace !default;\n\n// The base body size\n$body-font-size: 14px !default;\n$body-line-height: $lh-default !default;\n","// Miscellaneous variables\n\n// Border\n$border-width: 1px !default;\n$border-style: solid !default;\n$border: $border-width $border-style var(--color-border-primary) !default;\n\n// Border Radius\n$border-radius-1:  4px !default;\n$border-radius-2:  6px !default;\n$border-radius-3:  8px !default;\n$border-radius: $border-radius-2 !default;\n\n// Tooltips\n$tooltip-max-width: 250px !default;\n$tooltip-delay: 0.4s !default;\n$tooltip-duration: 0.1s !default;\n","// Responsive media queries\n\n@mixin breakpoint($breakpoint) {\n  @if $breakpoint == \"\" {\n    @content;\n  }\n\n  @else {\n    // Retrieves the value from the key\n    $value: map-get($breakpoints, $breakpoint);\n\n    // If the key exists in the map\n    @if $value != null {\n      // Prints a media query based on the value\n      @media (min-width: $value) {\n        @content;\n      }\n    }\n\n    // If the key doesn't exist in the map\n    @else {\n      @warn \"Unfortunately, no value could be retrieved from `#{$breakpoint}`. \"\n        + \"Please make sure it is defined in `$breakpoints` map.\";\n    }\n  }\n}\n\n// Retina media query\n\n@mixin retina-media-query {\n  @media\n    only screen and (-webkit-min-device-pixel-ratio: 2),\n    only screen and (min--moz-device-pixel-ratio: 2),\n    only screen and (-moz-min-device-pixel-ratio: 2),\n    only screen and (-o-min-device-pixel-ratio: 2/1),\n    only screen and (min-device-pixel-ratio: 2),\n    only screen and (min-resolution: 192dpi),\n    only screen and (min-resolution: 2dppx) {\n    @content;\n  }\n}\n\n// Clearfix\n//\n// Clears floats via mixin.\n\n@mixin clearfix {\n  &::before {\n    display: table;\n    content: \"\";\n  }\n\n  &::after {\n    display: table;\n    clear: both;\n    content: \"\";\n  }\n}\n","// Layout variables\n\n// these are values for the display CSS property\n$display-values: (\n  block,\n  flex,\n  inline,\n  inline-block,\n  inline-flex,\n  none,\n  table,\n  table-cell\n) !default;\n\n// maps edges to respective corners for border-radius\n$edges: (\n  top: (top-left, top-right),\n  right: (top-right, bottom-right),\n  bottom: (bottom-right, bottom-left),\n  left: (bottom-left, top-left)\n) !default;\n\n// These are our margin and padding utility spacers. The default step size we\n// use is 8px. This gives us a key of:\n//    0 => 0px\n//    1 => 4px\n//    2 => 8px\n//    3 => 16px\n//    4 => 24px\n//    5 => 32px\n//    6 => 40px\n$spacer: 8px !default;\n\n// Our spacing scale\n$spacer-0: 0 !default;                  // 0\n$spacer-1: $spacer * 0.5 !default;      // 4px\n$spacer-2: $spacer !default;            // 8px\n$spacer-3: $spacer * 2 !default;        // 16px\n$spacer-4: $spacer * 3 !default;        // 24px\n$spacer-5: $spacer * 4 !default;        // 32px\n$spacer-6: $spacer * 5 !default;        // 40px\n\n// The list of spacer values\n$spacers: (\n  $spacer-0,\n  $spacer-1,\n  $spacer-2,\n  $spacer-3,\n  $spacer-4,\n  $spacer-5,\n  $spacer-6,\n) !default;\n\n// And the map of spacers, for easier looping:\n// @each $scale, $length in $spacer-map { ... }\n$spacer-map: (\n  0: $spacer-0,\n  1: $spacer-1,\n  2: $spacer-2,\n  3: $spacer-3,\n  4: $spacer-4,\n  5: $spacer-5,\n  6: $spacer-6,\n) !default;\n\n// Increases the core spacing scale first by 8px for $spacer-7, then by 16px\n// increments from $spacer-8 to $spacer-12, i.e. after 40px, we have 48, 64,\n// 80, 96, etc.\n$spacer-7:  $spacer * 6 !default;  // 48px\n$spacer-8:  $spacer * 8 !default;  // 64px\n$spacer-9:  $spacer * 10 !default; // 80px\n$spacer-10: $spacer * 12 !default; // 96px\n$spacer-11: $spacer * 14 !default; // 112px\n$spacer-12: $spacer * 16 !default; // 128px\n\n$spacers-large: (\n  7: $spacer-7,\n  8: $spacer-8,\n  9: $spacer-9,\n  10: $spacer-10,\n  11: $spacer-11,\n  12: $spacer-12,\n) !default;\n\n$spacer-map-extended: map-merge(\n  (\n    0: 0,\n    1: $spacer-1,\n    2: $spacer-2,\n    3: $spacer-3,\n    4: $spacer-4,\n    5: $spacer-5,\n    6: $spacer-6,\n  ),\n  $spacers-large,\n) !default;\n\n// Em spacer variables\n$em-spacer-1: 0.0625em !default; // 1/16\n$em-spacer-2: 0.125em !default;  // 1/8\n$em-spacer-3: 0.25em !default;   // 1/4\n$em-spacer-4: 0.375em !default;  // 3/8\n$em-spacer-5: 0.5em !default;    // 1/2\n$em-spacer-6: 0.75em !default;   // 3/4\n\n// Size scale\n// Used for buttons, inputs, labels, avatars etc.\n$size: 16px !default;\n\n$size-0: 0 !default;\n$size-1: $size !default;           // 16px\n$size-2: $size-1 +  4px !default;  // 20px\n$size-3: $size-2 +  4px !default;  // 24px\n$size-4: $size-3 +  4px !default;  // 28px\n$size-5: $size-4 +  4px !default;  // 32px\n$size-6: $size-5 +  8px !default;  // 40px\n$size-7: $size-6 +  8px !default;  // 48px\n$size-8: $size-7 + 16px !default;  // 64px\n\n// Fixed-width container variables\n$container-width: 980px !default;\n$grid-gutter:     10px !default;\n\n// Breakpoint widths\n$width-xs: 0 !default;\n// Small screen / phone\n$width-sm: 544px !default;\n// Medium screen / tablet\n$width-md: 768px !default;\n// Large screen / desktop (980 + (16 * 2)) <= container + gutters\n$width-lg: 1012px !default;\n// Extra large screen / wide desktop\n$width-xl: 1280px !default;\n\n// Responsive container widths\n$container-sm: $width-sm !default;\n$container-md: $width-md !default;\n$container-lg: $width-lg !default;\n$container-xl: $width-xl !default;\n\n// Breakpoints in the form (name: length)\n$breakpoints: (\n  sm: $width-sm,\n  md: $width-md,\n  lg: $width-lg,\n  xl: $width-xl\n) !default;\n\n// This map in the form (breakpoint: variant) is used to iterate over\n// breakpoints and create both responsive and non-responsive classes in one\n// loop:\n//\n// ```scss\n// @each $breakpoint, $variant of $responsive-variants {\n//   @include breakpoint($breakpoint) {\n//     .foo#{$variant}-bar { foo: bar !important; }\n//   }\n// }\n// ```\n$responsive-variants: (\n  \"\": \"\",\n  sm: \"-sm\",\n  md: \"-md\",\n  lg: \"-lg\",\n  xl: \"-xl\",\n) !default;\n\n// responive utility position values\n$responsive-positions: (\n  static,\n  relative,\n  absolute,\n  fixed,\n  sticky\n) !default;\n\n$sidebar-width: (\n  sm: 220px,\n  md: 256px,\n  lg: 296px,\n  xl: 320px\n) !default;\n\n$sidebar-narrow-width: (\n  md: 240px,\n  lg: 256px,\n  xl: 296px\n) !default;\n\n$sidebar-wide-width: (\n  md: 296px,\n  lg: 320px,\n  xl: 344px\n) !default;\n\n$gutter: (\n  md: $spacer-3,\n  lg: $spacer-4,\n  xl: $spacer-5\n) !default;\n\n$gutter-condensed: (\n  md: $spacer-3,\n  lg: $spacer-3,\n  xl: $spacer-4\n) !default;\n\n$gutter-spacious: (\n  md: $spacer-4,\n  lg: $spacer-5,\n  xl: $spacer-6\n) !default;\n","// Custom select\n//\n// Apply `.select` to any `<select>` element for custom styles.\n.form-select {\n  display: inline-block;\n  max-width: 100%;\n  height: $size-5;\n  padding-right: $spacer-4;\n  background-color: var(--color-bg-primary);\n  // SVG with fill: #586069 (--color-icon-secondary)\n  background-image: url(\"\");\n  background-repeat: no-repeat;\n  background-position: right 4px center;\n  background-size: 16px;\n  appearance: none;\n\n  // Hides the default caret in IE11\n  &::-ms-expand {\n    opacity: 0;\n  }\n\n  &[multiple] {\n    height: auto;\n  }\n}\n\n@include color-mode(dark) {\n  .form-select {\n    // SVG with fill: #6e7681 (--color-icon-secondary)\n    background-image: url(\"\");\n  }\n}\n\n.select-sm {\n  height: $size-4;\n  // stylelint-disable-next-line primer/spacing\n  padding-top: 3px;\n  // stylelint-disable-next-line primer/spacing\n  padding-bottom: 3px;\n  font-size: $font-size-small;\n\n  &[multiple] {\n    height: auto;\n    min-height: 0;\n  }\n}\n","@mixin color-mode-theme($theme-name, $include-root: false) {\n  @if $include-root {\n    :root,\n    [data-color-mode=\"light\"][data-light-theme=\"#{$theme-name}\"],\n    [data-color-mode=\"dark\"][data-dark-theme=\"#{$theme-name}\"] {\n      @content;\n\n      /*! */ // This is a fix for a cssstats bug see https://github.com/cssstats/cssstats/issues/331\n    }\n  }\n  @else {\n    [data-color-mode=\"light\"][data-light-theme=\"#{$theme-name}\"],\n    [data-color-mode=\"dark\"][data-dark-theme=\"#{$theme-name}\"] {\n      @content;\n    }\n  }\n\n  @media (prefers-color-scheme: light) {\n    [data-color-mode=\"auto\"][data-light-theme=\"#{$theme-name}\"] {\n      @content;\n    }\n  }\n\n  @media (prefers-color-scheme: dark) {\n    [data-color-mode=\"auto\"][data-dark-theme=\"#{$theme-name}\"] {\n      @content;\n    }\n  }\n}\n\n@mixin color-mode($mode) {\n  @if $mode == light {\n    :root,\n    [data-color-mode=\"light\"][data-light-theme*=\"#{$mode}\"],\n    [data-color-mode=\"dark\"][data-dark-theme*=\"#{$mode}\"] {\n      @content;\n    }\n  }\n  @else {\n    [data-color-mode=\"light\"][data-light-theme*=\"#{$mode}\"],\n    [data-color-mode=\"dark\"][data-dark-theme*=\"#{$mode}\"] {\n      @content;\n    }\n  }\n\n  @media (prefers-color-scheme: light) {\n    [data-color-mode=\"auto\"][data-light-theme*=\"#{$mode}\"] {\n      @content;\n    }\n  }\n\n  @media (prefers-color-scheme: dark) {\n    [data-color-mode=\"auto\"][data-dark-theme*=\"#{$mode}\"] {\n      @content;\n    }\n  }\n}\n\n// This mixin takes a map of color mode vars and splits them into dark and light mode\n// The goal is to reduce the amount of dark/light mode selectors compiled.\n//\n// Example input for $color-map\n//\n// @include color-variables((\"custom-css-variable-1\": (\n//     light: var(--color-scale-gray-3),\n//     dark: var(--color-scale-gray-5)\n//   ),\n//   \"custom-css-variable-2\": (\n//     light: var(--color-scale-gray-2),\n//     dark: var(--color-scale-gray-6)\n//   ),\n//   \"custom-css-variable-3\": (\n//     light: var(--color-scale-gray-2),\n//     dark: var(--color-scale-gray-6)\n//   )\n// ));\n@mixin color-variables($color-map) {\n  // Create map to store incoming variables\n  $dark-colors: ();\n  $light-colors: ();\n\n  @each $name, $value in $color-map {\n    @each $type, $color in $value {\n      @if $type == dark {\n        $dark-colors: append($dark-colors, (--color-#{$name}, #{$color}));\n      }\n      @else {\n        $light-colors: append($light-colors, (--color-#{$name}, #{$color}));\n      }\n    }\n  }\n\n  $mode-colors: (\n    dark: $dark-colors,\n    light: $light-colors\n  );\n\n  // Loop through sorted list\n  @each $mode, $variables in $mode-colors {\n    @include color-mode($mode) {\n      @each $prop, $val in $variables {\n        #{$prop}: $val;\n      }\n    }\n  }\n}\n","// stylelint-disable selector-max-compound-selectors\n// stylelint-disable selector-max-type\n\n// Form groups\n//\n// Usage:\n//\n// <div class=\"form-group\">\n//   <div class=\"form-group-header\"> containing the label\n//   <div class=\"form-group-body\"> containing the form elements\n// </div>\n\n.form-group {\n  // stylelint-disable-next-line primer/spacing\n  margin: 15px 0;\n\n  // Text fields\n  .form-control {\n    width: 440px;\n    max-width: 100%;\n    // stylelint-disable-next-line primer/spacing\n    margin-right: 5px;\n    background-color: var(--color-input-contrast-bg);\n\n    &:focus {\n      background-color: var(--color-input-bg);\n    }\n\n    &.shorter { width: 130px; }\n\n    &.short { width: 250px; }\n\n    &.long { width: 100%; }\n  }\n\n  // Textarea\n  // stylelint-disable selector-no-qualifying-type\n  textarea.form-control {\n    width: 100%;\n    height: 200px;\n    min-height: 200px;\n\n    &.short {\n      height: 50px;\n      min-height: 50px;\n    }\n  }\n  // stylelint-enable selector-no-qualifying-type\n\n  // The Label\n  dt, // TODO: Deprecate\n  .form-group-header {\n    // stylelint-disable-next-line primer/spacing\n    margin: 0 0 6px;\n  }\n\n  label {\n    position: relative;\n  }\n\n  &.flattened dt, // TODO: Deprecate\n  &.flattened .form-group-header {\n    float: left;\n    margin: 0;\n    // stylelint-disable-next-line primer/typography\n    line-height: 32px;\n  }\n\n  &.flattened dd, // TODO: Deprecate\n  &.flattened .form-group-body {\n    // stylelint-disable-next-line primer/typography\n    line-height: 32px;\n  }\n\n  //\n  // Form Elements\n  //\n  // stylelint-disable selector-no-qualifying-type\n  dd, // TODO: Deprecate\n  .form-group-body {\n    h4 {\n      margin: $spacer-1 0 0;\n\n      &.is-error { color: var(--color-text-danger); }\n\n      &.is-success { color: var(--color-text-success); }\n\n      + .note {\n        margin-top: 0;\n      }\n    }\n  }\n  // stylelint-enable selector-no-qualifying-type\n\n  //\n  // Variants\n  //\n\n  &.required {\n    dt label::after, // TODO: Deprecate\n    .form-group-header label::after {\n      // stylelint-disable-next-line primer/spacing\n      padding-left: 5px;\n      color: var(--color-text-danger);\n      content: \"*\";\n    }\n  }\n\n  // Form AJAX states\n  //\n  // Form fields that need feedback for AJAX loading, success\n  // states and errored states.\n  .success,\n  .error,\n  .indicator {\n    display: none;\n    font-size: $font-size-small;\n    font-weight: $font-weight-bold;\n  }\n\n  &.loading {\n    opacity: 0.5;\n\n    .indicator {\n      display: inline;\n    }\n\n    .spinner {\n      display: inline-block;\n      vertical-align: middle;\n    }\n  }\n\n  &.successful {\n    .success {\n      display: inline;\n      color: var(--color-text-success);\n    }\n  }\n\n  // Form validation\n  //\n  // Our inline errors\n\n  &.successed,\n  &.warn,\n  &.errored {\n    .success,\n    .warning,\n    .error {\n      position: absolute;\n      z-index: 10;\n      display: block; // Show up in errored/warn state\n      max-width: 450px; // Keep our long errors readable\n      padding: $spacer-1 $spacer-2;\n      margin: $spacer-2 0 0;\n      font-size: $font-size-small;\n      font-weight: $font-weight-normal;\n      border-style: $border-style;\n      border-width: $border-width;\n      border-radius: $border-radius;\n\n      &::after,\n      &::before {\n        position: absolute;\n        bottom: 100%;\n        left: 10px;\n        z-index: 15;\n        width: 0;\n        height: 0;\n        pointer-events: none;\n        content: \" \";\n        // stylelint-disable-next-line primer/borders\n        border: $border-style transparent;\n      }\n\n      &::after {\n        // stylelint-disable-next-line primer/borders\n        border-width: 5px;\n      }\n\n      &::before {\n        // stylelint-disable-next-line primer/spacing\n        margin-left: -1px;\n        // stylelint-disable-next-line primer/borders\n        border-width: 6px;\n      }\n    }\n  }\n\n  &.successed {\n    .success {\n      color: var(--color-input-tooltip-success-text);\n      background-color: var(--color-bg-canvas); // Makes sure the background is opaque to cover any content underneath\n      background-image: linear-gradient(var(--color-input-tooltip-success-bg), var(--color-input-tooltip-success-bg));\n      border-color: var(--color-input-tooltip-success-border);\n\n      &::after { border-bottom-color: var(--color-input-tooltip-success-bg); } // stylelint-disable-line primer/borders\n      &::before { border-bottom-color: var(--color-input-tooltip-success-border); }\n    }\n  }\n\n  &.warn {\n    .form-control {\n      border-color: var(--color-input-warning-border);\n    }\n\n    .warning {\n      color: var(--color-input-tooltip-warning-text);\n      background-color: var(--color-bg-canvas); // Makes sure the background is opaque to cover any content underneath\n      background-image: linear-gradient(var(--color-input-tooltip-warning-bg), var(--color-input-tooltip-warning-bg));\n      border-color: var(--color-input-tooltip-warning-border);\n\n      &::after { border-bottom-color: var(--color-input-tooltip-warning-bg); } // stylelint-disable-line primer/borders\n      &::before { border-bottom-color: var(--color-input-tooltip-warning-border); }\n    }\n  }\n\n  &.errored {\n    .form-control {\n      border-color: var(--color-input-error-border);\n    }\n\n    label {\n      color: var(--color-text-danger);\n    }\n\n    .error {\n      color: var(--color-input-tooltip-error-text);\n      background-color: var(--color-bg-canvas); // Makes sure the background is opaque to cover any content underneath\n      background-image: linear-gradient(var(--color-input-tooltip-error-bg), var(--color-input-tooltip-error-bg));\n      border-color: var(--color-input-tooltip-error-border);\n\n      &::after { border-bottom-color: var(--color-input-tooltip-error-bg); } // stylelint-disable-line primer/borders\n      &::before { border-bottom-color: var(--color-input-tooltip-error-border); }\n    }\n  }\n}\n\n// tooltip\n.note {\n  min-height: 17px;\n  margin: $spacer-1 0 2px;\n  font-size: $font-size-small;\n  color: var(--color-text-secondary);\n\n  .spinner {\n    // stylelint-disable-next-line primer/spacing\n    margin-right: 3px;\n    vertical-align: middle;\n  }\n}\n","// Needs refactoring\n// stylelint-disable selector-no-qualifying-type, selector-max-type\ndl.form-group > dd, // TODO: Deprecate\n.form-group > .form-group-body {\n  .form-control {\n    &.is-autocheck-loading,\n    &.is-autocheck-successful,\n    &.is-autocheck-errored {\n      // stylelint-disable-next-line primer/spacing\n      padding-right: 30px; // Leave some space for our validation icons\n    }\n\n    &.is-autocheck-loading {\n      background-image: url(\"/images/spinners/octocat-spinner-16px.gif\");\n    }\n\n    &.is-autocheck-successful {\n      background-image: url(\"/images/modules/ajax/success.png\");\n    }\n\n    &.is-autocheck-errored {\n      background-image: url(\"/images/modules/ajax/error.png\");\n    }\n  }\n}\n\n// Retinization of form validation icons that aren't octicons yet\n@include retina-media-query {\n  dl.form-group > dd, // TODO: Deprecate\n  .form-group > .form-group-body {\n    .form-control {\n      &.is-autocheck-loading,\n      &.is-autocheck-successful,\n      &.is-autocheck-errored {\n        background-size: 16px 16px;\n      }\n\n      &.is-autocheck-loading {\n        background-image: url(\"/images/spinners/octocat-spinner-32.gif\");\n      }\n\n      &.is-autocheck-successful {\n        background-image: url(\"/images/modules/ajax/success@2x.png\");\n      }\n\n      &.is-autocheck-errored {\n        background-image: url(\"/images/modules/ajax/error@2x.png\");\n      }\n    }\n  }\n}\n\n// Inline verification\n// This overrides primer's inline form stuff\n.status-indicator {\n  display: inline-block;\n  width: 16px;\n  height: 16px;\n  // stylelint-disable-next-line primer/spacing\n  margin-left: 5px;\n\n  .octicon {\n    display: none;\n  }\n}\n\n.status-indicator-success {\n  // Override primer\n  &::before {\n    content: \"\";\n  }\n\n  .octicon-check {\n    display: inline-block;\n    color: var(--color-text-success);\n    fill: var(--color-icon-success);\n  }\n\n  .octicon-x {\n    display: none;\n  }\n}\n\n.status-indicator-failed {\n  // Override primer\n  &::before {\n    content: \"\";\n  }\n\n  .octicon-check {\n    display: none;\n  }\n\n  .octicon-x {\n    display: inline-block;\n    color: var(--color-text-danger);\n    fill: var(--color-icon-danger);\n  }\n}\n\n.status-indicator-loading {\n  width: 16px;\n  background-image: url(\"/images/spinners/octocat-spinner-32-EAF2F5.gif\");\n  background-repeat: no-repeat;\n  background-position: 0 0;\n  background-size: 16px;\n}\n\n.inline-form {\n  display: inline-block;\n\n  .btn-plain {\n    background-color: transparent;\n    border: 0;\n  }\n}\n\n// Drag and drop\n//\n// Previously part of `_forms.scss` in Primer. Needs accounting for.\n\n.drag-and-drop {\n  // stylelint-disable-next-line primer/spacing\n  padding: 7px 10px;\n  margin: 0;\n  // stylelint-disable-next-line primer/typography\n  font-size: 13px;\n  // stylelint-disable-next-line primer/typography\n  line-height: 16px;\n  color: var(--color-text-secondary);\n  background-color: var(--color-bg-secondary);\n  border: $border-width $border-style var(--color-drag-and-drop-border);\n  border-top: 0;\n  border-bottom-right-radius: $border-radius;\n  border-bottom-left-radius: $border-radius;\n\n  .default,\n  .loading,\n  .error {\n    display: none;\n  }\n\n  .error {\n    color: var(--color-text-danger);\n  }\n\n  // Spinner\n  img {\n    vertical-align: top;\n  }\n}\n\n.is-default .drag-and-drop .default {\n  display: inline-block;\n}\n\n.is-uploading .drag-and-drop .loading {\n  display: inline-block;\n}\n\n.is-bad-file .drag-and-drop .bad-file {\n  display: inline-block;\n}\n\n.is-duplicate-filename .drag-and-drop .duplicate-filename {\n  display: inline-block;\n}\n\n.is-too-big .drag-and-drop .too-big {\n  display: inline-block;\n}\n\n.is-hidden-file .drag-and-drop .hidden-file {\n  display: inline-block;\n}\n\n.is-empty .drag-and-drop .empty {\n  display: inline-block;\n}\n\n.is-bad-permissions .drag-and-drop .bad-permissions {\n  display: inline-block;\n}\n\n.is-repository-required .drag-and-drop .repository-required {\n  display: inline-block;\n}\n\n.drag-and-drop-error-info {\n  font-weight: $font-weight-normal;\n  color: var(--color-text-secondary);\n\n  a {\n    color: var(--color-text-link);\n  }\n}\n\n.is-failed .drag-and-drop .failed-request {\n  display: inline-block;\n}\n\n.manual-file-chooser {\n  position: absolute;\n  width: 240px;\n  // stylelint-disable-next-line primer/spacing\n  padding: 5px;\n  // stylelint-disable-next-line primer/spacing\n  margin-left: -80px;\n  cursor: pointer;\n  opacity: 0.0001;\n}\n\n.manual-file-chooser:hover + .manual-file-chooser-text {\n  text-decoration: underline;\n}\n\n.btn {\n  // align manual-file-chooser inside a button\n  .manual-file-chooser {\n    top: 0;\n    padding: 0;\n    // stylelint-disable-next-line primer/typography\n    line-height: 34px;\n  }\n}\n\n// Focused Textarea styles\n.upload-enabled {\n  textarea {\n    display: block;\n    // stylelint-disable-next-line primer/borders\n    border-bottom: $border-width dashed var(--color-upload-enabled-border);\n    border-bottom-right-radius: 0;\n    border-bottom-left-radius: 0;\n  }\n\n  &.focused {\n    border-radius: $border-radius;\n    box-shadow: var(--color-input-shadow), var(--color-state-focus-shadow);\n\n    .form-control {\n      box-shadow: none;\n    }\n\n    .drag-and-drop {\n      border-color: var(--color-upload-enabled-border-focused);\n    }\n  }\n}\n\n// Dropping a file on top\n.dragover textarea,\n.dragover .drag-and-drop {\n  // stylelint-disable-next-line primer/box-shadow\n  box-shadow: rgba(#c9ff00, 1) 0 0 3px;\n}\n\n.write-content {\n  position: relative;\n}\n\n// Form style with a write and a preview tab\n.previewable-comment-form {\n  position: relative;\n\n  .tabnav {\n    position: relative;\n    padding: $spacer-2 $spacer-2 0;\n  }\n\n  .comment {\n    border: $border-width $border-style var(--color-previewable-comment-form-border);\n  }\n\n  .comment-form-error { margin-bottom: $spacer-2; }\n\n  .write-content,\n  .preview-content {\n    display: none;\n    margin: 0 $spacer-2 $spacer-2;\n  }\n\n  &.write-selected .write-content,\n  &.preview-selected .preview-content {\n    display: block;\n  }\n\n  textarea {\n    display: block;\n    width: 100%;\n    min-height: 100px;\n    max-height: 500px;\n    padding: $spacer-2;\n    resize: vertical;\n  }\n}\n\n// Used in our boxed-group-less form styles. Give the sumbit button enough space\n// to breathe without the need for the extra hr.\n.form-action-spacious {\n  // stylelint-disable-next-line primer/spacing\n  margin-top: 10px;\n}\n\n// A two column form, with a .main and a .sidebar column\n//\n// Override some `.timeline-comment-wrapper` defaults.\n// The `div` is needed to be more specific than the other class.\ndiv.composer {\n  margin-top: 0;\n  border: 0;\n}\n\n// Override the previewable comment form defaults\n.composer .comment-form-textarea {\n  height: 200px;\n  min-height: 200px;\n}\n\n// stylelint-disable-next-line primer/spacing\n.composer .tabnav { margin: 0 0 10px; }\n\n// Misc CSS\n//\n// Previously part of `_forms.scss` in Primer. Needs accounting for.\n\nh2.account {\n  // stylelint-disable-next-line primer/spacing\n  margin: 15px 0 0;\n  // stylelint-disable-next-line primer/typography\n  font-size: 18px;\n  font-weight: $font-weight-normal;\n  color: var(--color-text-secondary);\n}\n\np.explain {\n  position: relative;\n  font-size: $font-size-small;\n  color: var(--color-text-secondary);\n\n  strong {\n    color: var(--color-text-primary);\n  }\n\n  .octicon {\n    // stylelint-disable-next-line primer/spacing\n    margin-right: 5px;\n    // stylelint-disable-next-line primer/colors\n    color: var(--color-icon-tertiary);\n  }\n\n  .minibutton {\n    top: -4px;\n    float: right;\n  }\n}\n\n// fix for chrome bug, see https://github.com/github/github/issues/53931\n.form-group label {\n  position: static;\n}\n",".input-group {\n  display: table;\n\n  .form-control {\n    position: relative;\n    width: 100%;\n\n    &:focus {\n      z-index: 2;\n    }\n\n    + .btn {\n      margin-left: 0;\n    }\n  }\n\n  // For when you want the input group to behave like inline-block.\n  &.inline {\n    display: inline-table;\n  }\n}\n\n.input-group .form-control,\n.input-group-button {\n  display: table-cell;\n}\n\n.input-group-button {\n  width: 1%;\n  vertical-align: middle; // Match the inputs\n}\n\n.input-group .form-control:first-child,\n.input-group-button:first-child .btn {\n  border-top-right-radius: 0;\n  border-bottom-right-radius: 0;\n}\n\n.input-group-button:first-child .btn {\n  // stylelint-disable-next-line primer/spacing\n  margin-right: -1px;\n}\n\n.input-group .form-control:last-child,\n.input-group-button:last-child .btn {\n  border-top-left-radius: 0;\n  border-bottom-left-radius: 0;\n}\n\n.input-group-button:last-child .btn {\n  // stylelint-disable-next-line primer/spacing\n  margin-left: -1px;\n}\n","// Tab like radio group\n\n.radio-group {\n  @include clearfix;\n}\n\n.radio-label {\n  float: left;\n  // stylelint-disable-next-line primer/spacing\n  padding: 6px $spacer-3 6px ($spacer-3 + 12px + $spacer-2); // 12px is the size of the radio-input\n  // stylelint-disable-next-line primer/spacing\n  margin-left: -1px;\n  font-size: $body-font-size;\n  // stylelint-disable-next-line primer/typography\n  line-height: 20px; // Specifically not inherit our `<body>` default\n  color: var(--color-text-primary);\n  cursor: pointer;\n  border: $border-width $border-style var(--color-border-primary);\n\n  :checked + & {\n    position: relative;\n    z-index: 1;\n    border-color: var(--color-border-info);\n  }\n\n  &:first-of-type {\n    margin-left: 0;\n    border-top-left-radius: $border-radius;\n    border-bottom-left-radius: $border-radius;\n  }\n\n  &:last-of-type {\n    border-top-right-radius: $border-radius;\n    border-bottom-right-radius: $border-radius;\n  }\n}\n\n.radio-input {\n  z-index: 3;\n  float: left;\n  // stylelint-disable-next-line primer/spacing\n  margin: 10px (-$spacer-5) 0 $spacer-3;\n}\n"]}