[e6a6d9a] | 1 | // stylelint-disable at-rule-no-vendor-prefix, declaration-no-important, selector-no-qualifying-type, property-no-vendor-prefix
|
---|
| 2 |
|
---|
| 3 | // Reboot
|
---|
| 4 | //
|
---|
| 5 | // Normalization of HTML elements, manually forked from Normalize.css to remove
|
---|
| 6 | // styles targeting irrelevant browsers while applying new styles.
|
---|
| 7 | //
|
---|
| 8 | // Normalize is licensed MIT. https://github.com/necolas/normalize.css
|
---|
| 9 |
|
---|
| 10 |
|
---|
| 11 | // Document
|
---|
| 12 | //
|
---|
| 13 | // 1. Change from `box-sizing: content-box` so that `width` is not affected by `padding` or `border`.
|
---|
| 14 | // 2. Change the default font family in all browsers.
|
---|
| 15 | // 3. Correct the line height in all browsers.
|
---|
| 16 | // 4. Prevent adjustments of font size after orientation changes in IE on Windows Phone and in iOS.
|
---|
| 17 | // 5. Change the default tap highlight to be completely transparent in iOS.
|
---|
| 18 |
|
---|
| 19 | *,
|
---|
| 20 | *::before,
|
---|
| 21 | *::after {
|
---|
| 22 | box-sizing: border-box; // 1
|
---|
| 23 | }
|
---|
| 24 |
|
---|
| 25 | html {
|
---|
| 26 | font-family: sans-serif; // 2
|
---|
| 27 | line-height: 1.15; // 3
|
---|
| 28 | -webkit-text-size-adjust: 100%; // 4
|
---|
| 29 | -webkit-tap-highlight-color: rgba($black, 0); // 5
|
---|
| 30 | }
|
---|
| 31 |
|
---|
| 32 | // Shim for "new" HTML5 structural elements to display correctly (IE10, older browsers)
|
---|
| 33 | // TODO: remove in v5
|
---|
| 34 | // stylelint-disable-next-line selector-list-comma-newline-after
|
---|
| 35 | article, aside, figcaption, figure, footer, header, hgroup, main, nav, section {
|
---|
| 36 | display: block;
|
---|
| 37 | }
|
---|
| 38 |
|
---|
| 39 | // Body
|
---|
| 40 | //
|
---|
| 41 | // 1. Remove the margin in all browsers.
|
---|
| 42 | // 2. As a best practice, apply a default `background-color`.
|
---|
| 43 | // 3. Set an explicit initial text-align value so that we can later use
|
---|
| 44 | // the `inherit` value on things like `<th>` elements.
|
---|
| 45 |
|
---|
| 46 | body {
|
---|
| 47 | margin: 0; // 1
|
---|
| 48 | font-family: $font-family-base;
|
---|
| 49 | @include font-size($font-size-base);
|
---|
| 50 | font-weight: $font-weight-base;
|
---|
| 51 | line-height: $line-height-base;
|
---|
| 52 | color: $body-color;
|
---|
| 53 | text-align: left; // 3
|
---|
| 54 | background-color: $body-bg; // 2
|
---|
| 55 | }
|
---|
| 56 |
|
---|
| 57 | // Future-proof rule: in browsers that support :focus-visible, suppress the focus outline
|
---|
| 58 | // on elements that programmatically receive focus but wouldn't normally show a visible
|
---|
| 59 | // focus outline. In general, this would mean that the outline is only applied if the
|
---|
| 60 | // interaction that led to the element receiving programmatic focus was a keyboard interaction,
|
---|
| 61 | // or the browser has somehow determined that the user is primarily a keyboard user and/or
|
---|
| 62 | // wants focus outlines to always be presented.
|
---|
| 63 | //
|
---|
| 64 | // See https://developer.mozilla.org/en-US/docs/Web/CSS/:focus-visible
|
---|
| 65 | // and https://developer.paciellogroup.com/blog/2018/03/focus-visible-and-backwards-compatibility/
|
---|
| 66 | [tabindex="-1"]:focus:not(:focus-visible) {
|
---|
| 67 | outline: 0 !important;
|
---|
| 68 | }
|
---|
| 69 |
|
---|
| 70 |
|
---|
| 71 | // Content grouping
|
---|
| 72 | //
|
---|
| 73 | // 1. Add the correct box sizing in Firefox.
|
---|
| 74 | // 2. Show the overflow in Edge and IE.
|
---|
| 75 |
|
---|
| 76 | hr {
|
---|
| 77 | box-sizing: content-box; // 1
|
---|
| 78 | height: 0; // 1
|
---|
| 79 | overflow: visible; // 2
|
---|
| 80 | }
|
---|
| 81 |
|
---|
| 82 |
|
---|
| 83 | //
|
---|
| 84 | // Typography
|
---|
| 85 | //
|
---|
| 86 |
|
---|
| 87 | // Remove top margins from headings
|
---|
| 88 | //
|
---|
| 89 | // By default, `<h1>`-`<h6>` all receive top and bottom margins. We nuke the top
|
---|
| 90 | // margin for easier control within type scales as it avoids margin collapsing.
|
---|
| 91 | // stylelint-disable-next-line selector-list-comma-newline-after
|
---|
| 92 | h1, h2, h3, h4, h5, h6 {
|
---|
| 93 | margin-top: 0;
|
---|
| 94 | margin-bottom: $headings-margin-bottom;
|
---|
| 95 | }
|
---|
| 96 |
|
---|
| 97 | // Reset margins on paragraphs
|
---|
| 98 | //
|
---|
| 99 | // Similarly, the top margin on `<p>`s get reset. However, we also reset the
|
---|
| 100 | // bottom margin to use `rem` units instead of `em`.
|
---|
| 101 | p {
|
---|
| 102 | margin-top: 0;
|
---|
| 103 | margin-bottom: $paragraph-margin-bottom;
|
---|
| 104 | }
|
---|
| 105 |
|
---|
| 106 | // Abbreviations
|
---|
| 107 | //
|
---|
| 108 | // 1. Duplicate behavior to the data-* attribute for our tooltip plugin
|
---|
| 109 | // 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
|
---|
| 110 | // 3. Add explicit cursor to indicate changed behavior.
|
---|
| 111 | // 4. Remove the bottom border in Firefox 39-.
|
---|
| 112 | // 5. Prevent the text-decoration to be skipped.
|
---|
| 113 |
|
---|
| 114 | abbr[title],
|
---|
| 115 | abbr[data-original-title] { // 1
|
---|
| 116 | text-decoration: underline; // 2
|
---|
| 117 | text-decoration: underline dotted; // 2
|
---|
| 118 | cursor: help; // 3
|
---|
| 119 | border-bottom: 0; // 4
|
---|
| 120 | text-decoration-skip-ink: none; // 5
|
---|
| 121 | }
|
---|
| 122 |
|
---|
| 123 | address {
|
---|
| 124 | margin-bottom: 1rem;
|
---|
| 125 | font-style: normal;
|
---|
| 126 | line-height: inherit;
|
---|
| 127 | }
|
---|
| 128 |
|
---|
| 129 | ol,
|
---|
| 130 | ul,
|
---|
| 131 | dl {
|
---|
| 132 | margin-top: 0;
|
---|
| 133 | margin-bottom: 1rem;
|
---|
| 134 | }
|
---|
| 135 |
|
---|
| 136 | ol ol,
|
---|
| 137 | ul ul,
|
---|
| 138 | ol ul,
|
---|
| 139 | ul ol {
|
---|
| 140 | margin-bottom: 0;
|
---|
| 141 | }
|
---|
| 142 |
|
---|
| 143 | dt {
|
---|
| 144 | font-weight: $dt-font-weight;
|
---|
| 145 | }
|
---|
| 146 |
|
---|
| 147 | dd {
|
---|
| 148 | margin-bottom: .5rem;
|
---|
| 149 | margin-left: 0; // Undo browser default
|
---|
| 150 | }
|
---|
| 151 |
|
---|
| 152 | blockquote {
|
---|
| 153 | margin: 0 0 1rem;
|
---|
| 154 | }
|
---|
| 155 |
|
---|
| 156 | b,
|
---|
| 157 | strong {
|
---|
| 158 | font-weight: $font-weight-bolder; // Add the correct font weight in Chrome, Edge, and Safari
|
---|
| 159 | }
|
---|
| 160 |
|
---|
| 161 | small {
|
---|
| 162 | @include font-size(80%); // Add the correct font size in all browsers
|
---|
| 163 | }
|
---|
| 164 |
|
---|
| 165 | //
|
---|
| 166 | // Prevent `sub` and `sup` elements from affecting the line height in
|
---|
| 167 | // all browsers.
|
---|
| 168 | //
|
---|
| 169 |
|
---|
| 170 | sub,
|
---|
| 171 | sup {
|
---|
| 172 | position: relative;
|
---|
| 173 | @include font-size(75%);
|
---|
| 174 | line-height: 0;
|
---|
| 175 | vertical-align: baseline;
|
---|
| 176 | }
|
---|
| 177 |
|
---|
| 178 | sub { bottom: -.25em; }
|
---|
| 179 | sup { top: -.5em; }
|
---|
| 180 |
|
---|
| 181 |
|
---|
| 182 | //
|
---|
| 183 | // Links
|
---|
| 184 | //
|
---|
| 185 |
|
---|
| 186 | a {
|
---|
| 187 | color: $link-color;
|
---|
| 188 | text-decoration: $link-decoration;
|
---|
| 189 | background-color: transparent; // Remove the gray background on active links in IE 10.
|
---|
| 190 |
|
---|
| 191 | @include hover() {
|
---|
| 192 | color: $link-hover-color;
|
---|
| 193 | text-decoration: $link-hover-decoration;
|
---|
| 194 | }
|
---|
| 195 | }
|
---|
| 196 |
|
---|
| 197 | // And undo these styles for placeholder links/named anchors (without href).
|
---|
| 198 | // It would be more straightforward to just use a[href] in previous block, but that
|
---|
| 199 | // causes specificity issues in many other styles that are too complex to fix.
|
---|
| 200 | // See https://github.com/twbs/bootstrap/issues/19402
|
---|
| 201 |
|
---|
| 202 | a:not([href]) {
|
---|
| 203 | color: inherit;
|
---|
| 204 | text-decoration: none;
|
---|
| 205 |
|
---|
| 206 | @include hover() {
|
---|
| 207 | color: inherit;
|
---|
| 208 | text-decoration: none;
|
---|
| 209 | }
|
---|
| 210 | }
|
---|
| 211 |
|
---|
| 212 |
|
---|
| 213 | //
|
---|
| 214 | // Code
|
---|
| 215 | //
|
---|
| 216 |
|
---|
| 217 | pre,
|
---|
| 218 | code,
|
---|
| 219 | kbd,
|
---|
| 220 | samp {
|
---|
| 221 | font-family: $font-family-monospace;
|
---|
| 222 | @include font-size(1em); // Correct the odd `em` font sizing in all browsers.
|
---|
| 223 | }
|
---|
| 224 |
|
---|
| 225 | pre {
|
---|
| 226 | // Remove browser default top margin
|
---|
| 227 | margin-top: 0;
|
---|
| 228 | // Reset browser default of `1em` to use `rem`s
|
---|
| 229 | margin-bottom: 1rem;
|
---|
| 230 | // Don't allow content to break outside
|
---|
| 231 | overflow: auto;
|
---|
| 232 | }
|
---|
| 233 |
|
---|
| 234 |
|
---|
| 235 | //
|
---|
| 236 | // Figures
|
---|
| 237 | //
|
---|
| 238 |
|
---|
| 239 | figure {
|
---|
| 240 | // Apply a consistent margin strategy (matches our type styles).
|
---|
| 241 | margin: 0 0 1rem;
|
---|
| 242 | }
|
---|
| 243 |
|
---|
| 244 |
|
---|
| 245 | //
|
---|
| 246 | // Images and content
|
---|
| 247 | //
|
---|
| 248 |
|
---|
| 249 | img {
|
---|
| 250 | vertical-align: middle;
|
---|
| 251 | border-style: none; // Remove the border on images inside links in IE 10-.
|
---|
| 252 | }
|
---|
| 253 |
|
---|
| 254 | svg {
|
---|
| 255 | // Workaround for the SVG overflow bug in IE10/11 is still required.
|
---|
| 256 | // See https://github.com/twbs/bootstrap/issues/26878
|
---|
| 257 | overflow: hidden;
|
---|
| 258 | vertical-align: middle;
|
---|
| 259 | }
|
---|
| 260 |
|
---|
| 261 |
|
---|
| 262 | //
|
---|
| 263 | // Tables
|
---|
| 264 | //
|
---|
| 265 |
|
---|
| 266 | table {
|
---|
| 267 | border-collapse: collapse; // Prevent double borders
|
---|
| 268 | }
|
---|
| 269 |
|
---|
| 270 | caption {
|
---|
| 271 | padding-top: $table-cell-padding;
|
---|
| 272 | padding-bottom: $table-cell-padding;
|
---|
| 273 | color: $table-caption-color;
|
---|
| 274 | text-align: left;
|
---|
| 275 | caption-side: bottom;
|
---|
| 276 | }
|
---|
| 277 |
|
---|
| 278 | th {
|
---|
| 279 | // Matches default `<td>` alignment by inheriting from the `<body>`, or the
|
---|
| 280 | // closest parent with a set `text-align`.
|
---|
| 281 | text-align: inherit;
|
---|
| 282 | }
|
---|
| 283 |
|
---|
| 284 |
|
---|
| 285 | //
|
---|
| 286 | // Forms
|
---|
| 287 | //
|
---|
| 288 |
|
---|
| 289 | label {
|
---|
| 290 | // Allow labels to use `margin` for spacing.
|
---|
| 291 | display: inline-block;
|
---|
| 292 | margin-bottom: $label-margin-bottom;
|
---|
| 293 | }
|
---|
| 294 |
|
---|
| 295 | // Remove the default `border-radius` that macOS Chrome adds.
|
---|
| 296 | //
|
---|
| 297 | // Details at https://github.com/twbs/bootstrap/issues/24093
|
---|
| 298 | button {
|
---|
| 299 | // stylelint-disable-next-line property-blacklist
|
---|
| 300 | border-radius: 0;
|
---|
| 301 | }
|
---|
| 302 |
|
---|
| 303 | // Work around a Firefox/IE bug where the transparent `button` background
|
---|
| 304 | // results in a loss of the default `button` focus styles.
|
---|
| 305 | //
|
---|
| 306 | // Credit: https://github.com/suitcss/base/
|
---|
| 307 | button:focus {
|
---|
| 308 | outline: 1px dotted;
|
---|
| 309 | outline: 5px auto -webkit-focus-ring-color;
|
---|
| 310 | }
|
---|
| 311 |
|
---|
| 312 | input,
|
---|
| 313 | button,
|
---|
| 314 | select,
|
---|
| 315 | optgroup,
|
---|
| 316 | textarea {
|
---|
| 317 | margin: 0; // Remove the margin in Firefox and Safari
|
---|
| 318 | font-family: inherit;
|
---|
| 319 | @include font-size(inherit);
|
---|
| 320 | line-height: inherit;
|
---|
| 321 | }
|
---|
| 322 |
|
---|
| 323 | button,
|
---|
| 324 | input {
|
---|
| 325 | overflow: visible; // Show the overflow in Edge
|
---|
| 326 | }
|
---|
| 327 |
|
---|
| 328 | button,
|
---|
| 329 | select {
|
---|
| 330 | text-transform: none; // Remove the inheritance of text transform in Firefox
|
---|
| 331 | }
|
---|
| 332 |
|
---|
| 333 | // Remove the inheritance of word-wrap in Safari.
|
---|
| 334 | //
|
---|
| 335 | // Details at https://github.com/twbs/bootstrap/issues/24990
|
---|
| 336 | select {
|
---|
| 337 | word-wrap: normal;
|
---|
| 338 | }
|
---|
| 339 |
|
---|
| 340 |
|
---|
| 341 | // 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
|
---|
| 342 | // controls in Android 4.
|
---|
| 343 | // 2. Correct the inability to style clickable types in iOS and Safari.
|
---|
| 344 | button,
|
---|
| 345 | [type="button"], // 1
|
---|
| 346 | [type="reset"],
|
---|
| 347 | [type="submit"] {
|
---|
| 348 | -webkit-appearance: button; // 2
|
---|
| 349 | }
|
---|
| 350 |
|
---|
| 351 | // Opinionated: add "hand" cursor to non-disabled button elements.
|
---|
| 352 | @if $enable-pointer-cursor-for-buttons {
|
---|
| 353 | button,
|
---|
| 354 | [type="button"],
|
---|
| 355 | [type="reset"],
|
---|
| 356 | [type="submit"] {
|
---|
| 357 | &:not(:disabled) {
|
---|
| 358 | cursor: pointer;
|
---|
| 359 | }
|
---|
| 360 | }
|
---|
| 361 | }
|
---|
| 362 |
|
---|
| 363 | // Remove inner border and padding from Firefox, but don't restore the outline like Normalize.
|
---|
| 364 | button::-moz-focus-inner,
|
---|
| 365 | [type="button"]::-moz-focus-inner,
|
---|
| 366 | [type="reset"]::-moz-focus-inner,
|
---|
| 367 | [type="submit"]::-moz-focus-inner {
|
---|
| 368 | padding: 0;
|
---|
| 369 | border-style: none;
|
---|
| 370 | }
|
---|
| 371 |
|
---|
| 372 | input[type="radio"],
|
---|
| 373 | input[type="checkbox"] {
|
---|
| 374 | box-sizing: border-box; // 1. Add the correct box sizing in IE 10-
|
---|
| 375 | padding: 0; // 2. Remove the padding in IE 10-
|
---|
| 376 | }
|
---|
| 377 |
|
---|
| 378 |
|
---|
| 379 | input[type="date"],
|
---|
| 380 | input[type="time"],
|
---|
| 381 | input[type="datetime-local"],
|
---|
| 382 | input[type="month"] {
|
---|
| 383 | // Remove the default appearance of temporal inputs to avoid a Mobile Safari
|
---|
| 384 | // bug where setting a custom line-height prevents text from being vertically
|
---|
| 385 | // centered within the input.
|
---|
| 386 | // See https://bugs.webkit.org/show_bug.cgi?id=139848
|
---|
| 387 | // and https://github.com/twbs/bootstrap/issues/11266
|
---|
| 388 | -webkit-appearance: listbox;
|
---|
| 389 | }
|
---|
| 390 |
|
---|
| 391 | textarea {
|
---|
| 392 | overflow: auto; // Remove the default vertical scrollbar in IE.
|
---|
| 393 | // Textareas should really only resize vertically so they don't break their (horizontal) containers.
|
---|
| 394 | resize: vertical;
|
---|
| 395 | }
|
---|
| 396 |
|
---|
| 397 | fieldset {
|
---|
| 398 | // Browsers set a default `min-width: min-content;` on fieldsets,
|
---|
| 399 | // unlike e.g. `<div>`s, which have `min-width: 0;` by default.
|
---|
| 400 | // So we reset that to ensure fieldsets behave more like a standard block element.
|
---|
| 401 | // See https://github.com/twbs/bootstrap/issues/12359
|
---|
| 402 | // and https://html.spec.whatwg.org/multipage/#the-fieldset-and-legend-elements
|
---|
| 403 | min-width: 0;
|
---|
| 404 | // Reset the default outline behavior of fieldsets so they don't affect page layout.
|
---|
| 405 | padding: 0;
|
---|
| 406 | margin: 0;
|
---|
| 407 | border: 0;
|
---|
| 408 | }
|
---|
| 409 |
|
---|
| 410 | // 1. Correct the text wrapping in Edge and IE.
|
---|
| 411 | // 2. Correct the color inheritance from `fieldset` elements in IE.
|
---|
| 412 | legend {
|
---|
| 413 | display: block;
|
---|
| 414 | width: 100%;
|
---|
| 415 | max-width: 100%; // 1
|
---|
| 416 | padding: 0;
|
---|
| 417 | margin-bottom: .5rem;
|
---|
| 418 | @include font-size(1.5rem);
|
---|
| 419 | line-height: inherit;
|
---|
| 420 | color: inherit; // 2
|
---|
| 421 | white-space: normal; // 1
|
---|
| 422 | }
|
---|
| 423 |
|
---|
| 424 | progress {
|
---|
| 425 | vertical-align: baseline; // Add the correct vertical alignment in Chrome, Firefox, and Opera.
|
---|
| 426 | }
|
---|
| 427 |
|
---|
| 428 | // Correct the cursor style of increment and decrement buttons in Chrome.
|
---|
| 429 | [type="number"]::-webkit-inner-spin-button,
|
---|
| 430 | [type="number"]::-webkit-outer-spin-button {
|
---|
| 431 | height: auto;
|
---|
| 432 | }
|
---|
| 433 |
|
---|
| 434 | [type="search"] {
|
---|
| 435 | // This overrides the extra rounded corners on search inputs in iOS so that our
|
---|
| 436 | // `.form-control` class can properly style them. Note that this cannot simply
|
---|
| 437 | // be added to `.form-control` as it's not specific enough. For details, see
|
---|
| 438 | // https://github.com/twbs/bootstrap/issues/11586.
|
---|
| 439 | outline-offset: -2px; // 2. Correct the outline style in Safari.
|
---|
| 440 | -webkit-appearance: none;
|
---|
| 441 | }
|
---|
| 442 |
|
---|
| 443 | //
|
---|
| 444 | // Remove the inner padding in Chrome and Safari on macOS.
|
---|
| 445 | //
|
---|
| 446 |
|
---|
| 447 | [type="search"]::-webkit-search-decoration {
|
---|
| 448 | -webkit-appearance: none;
|
---|
| 449 | }
|
---|
| 450 |
|
---|
| 451 | //
|
---|
| 452 | // 1. Correct the inability to style clickable types in iOS and Safari.
|
---|
| 453 | // 2. Change font properties to `inherit` in Safari.
|
---|
| 454 | //
|
---|
| 455 |
|
---|
| 456 | ::-webkit-file-upload-button {
|
---|
| 457 | font: inherit; // 2
|
---|
| 458 | -webkit-appearance: button; // 1
|
---|
| 459 | }
|
---|
| 460 |
|
---|
| 461 | //
|
---|
| 462 | // Correct element displays
|
---|
| 463 | //
|
---|
| 464 |
|
---|
| 465 | output {
|
---|
| 466 | display: inline-block;
|
---|
| 467 | }
|
---|
| 468 |
|
---|
| 469 | summary {
|
---|
| 470 | display: list-item; // Add the correct display in all browsers
|
---|
| 471 | cursor: pointer;
|
---|
| 472 | }
|
---|
| 473 |
|
---|
| 474 | template {
|
---|
| 475 | display: none; // Add the correct display in IE
|
---|
| 476 | }
|
---|
| 477 |
|
---|
| 478 | // Always hide an element with the `hidden` HTML attribute (from PureCSS).
|
---|
| 479 | // Needed for proper display in IE 10-.
|
---|
| 480 | [hidden] {
|
---|
| 481 | display: none !important;
|
---|
| 482 | }
|
---|