docks_theme_api 1.0.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (237) hide show
  1. checksums.yaml +15 -0
  2. data/.babelrc +4 -0
  3. data/.editorconfig +8 -0
  4. data/.eslintrc +115 -0
  5. data/.gitignore +24 -0
  6. data/.rubocop.yml +20 -0
  7. data/.travis.yml +16 -0
  8. data/Gemfile +4 -0
  9. data/README.md +5 -0
  10. data/Rakefile +3 -0
  11. data/assets/images/icons.svg +63 -0
  12. data/assets/scripts/coffeescript/pattern_library_helpers.coffee +8 -0
  13. data/assets/scripts/javascript/pattern_library_helpers.js +11 -0
  14. data/assets/scripts/pattern_library.js +10380 -0
  15. data/assets/scripts/pattern_library_demo.js +0 -0
  16. data/assets/styles/less/pattern-library-helpers.less +103 -0
  17. data/assets/styles/pattern-library-demo.css +1882 -0
  18. data/assets/styles/pattern-library.css +1882 -0
  19. data/assets/styles/sass/pattern-library-helpers.sass +90 -0
  20. data/assets/styles/scss/pattern-library-helpers.scss +99 -0
  21. data/assets/styles/stylus/pattern-library-helpers.styl +90 -0
  22. data/assets/templates/erb/demo.erb +26 -0
  23. data/assets/templates/erb/layouts/demo.erb +17 -0
  24. data/assets/templates/erb/layouts/pattern.erb +76 -0
  25. data/assets/templates/erb/partials/sidebar.erb +124 -0
  26. data/assets/templates/erb/partials/symbols/class.erb +1 -0
  27. data/assets/templates/erb/partials/symbols/demo.erb +40 -0
  28. data/assets/templates/erb/partials/symbols/factory.erb +70 -0
  29. data/assets/templates/erb/partials/symbols/function.erb +103 -0
  30. data/assets/templates/erb/partials/symbols/mixin.erb +62 -0
  31. data/assets/templates/erb/partials/symbols/variable.erb +59 -0
  32. data/assets/templates/erb/pattern.erb +102 -0
  33. data/assets/templates/haml/demo.haml +14 -0
  34. data/assets/templates/haml/layouts/demo.haml +6 -0
  35. data/assets/templates/haml/layouts/pattern.haml +38 -0
  36. data/assets/templates/haml/partials/sidebar.haml +68 -0
  37. data/assets/templates/haml/partials/symbols/class.haml +1 -0
  38. data/assets/templates/haml/partials/symbols/demo.haml +23 -0
  39. data/assets/templates/haml/partials/symbols/factory.haml +38 -0
  40. data/assets/templates/haml/partials/symbols/function.haml +54 -0
  41. data/assets/templates/haml/partials/symbols/mixin.haml +31 -0
  42. data/assets/templates/haml/partials/symbols/variable.haml +22 -0
  43. data/assets/templates/haml/pattern.haml +54 -0
  44. data/assets/templates/slim/demo.slim +24 -0
  45. data/assets/templates/slim/layouts/demo.slim +5 -0
  46. data/assets/templates/slim/layouts/pattern.slim +48 -0
  47. data/assets/templates/slim/partials/sidebar.slim +112 -0
  48. data/assets/templates/slim/partials/symbols/class.slim +1 -0
  49. data/assets/templates/slim/partials/symbols/demo.slim +30 -0
  50. data/assets/templates/slim/partials/symbols/factory.slim +57 -0
  51. data/assets/templates/slim/partials/symbols/function.slim +81 -0
  52. data/assets/templates/slim/partials/symbols/mixin.slim +45 -0
  53. data/assets/templates/slim/partials/symbols/variable.slim +35 -0
  54. data/assets/templates/slim/pattern.slim +63 -0
  55. data/docks_config.rb +32 -0
  56. data/docks_theme_api.gemspec +37 -0
  57. data/gulpfile.js +88 -0
  58. data/karma.conf.js +6 -0
  59. data/lib/docks_theme_api/components/base_component.rb +99 -0
  60. data/lib/docks_theme_api/components/code_block_component.rb +10 -0
  61. data/lib/docks_theme_api/components/popover_component.rb +15 -0
  62. data/lib/docks_theme_api/components/table_component.rb +34 -0
  63. data/lib/docks_theme_api/components/tablist_component.rb +11 -0
  64. data/lib/docks_theme_api/components.rb +21 -0
  65. data/lib/docks_theme_api/helpers/ui_helper.rb +69 -0
  66. data/lib/docks_theme_api/theme.rb +21 -0
  67. data/lib/docks_theme_api.rb +1 -0
  68. data/package.json +60 -0
  69. data/source/behaviors/filterable/filterable.coffee +353 -0
  70. data/source/behaviors/filterable/filterable.js +0 -0
  71. data/source/behaviors/filterable/filterable.scss +34 -0
  72. data/source/behaviors/filterable/package.json +3 -0
  73. data/source/behaviors/index.js +0 -0
  74. data/source/components/avatar/avatar.erb +20 -0
  75. data/source/components/avatar/avatar.js +142 -0
  76. data/source/components/avatar/avatar.scss +200 -0
  77. data/source/components/avatar/avatar_container.erb +13 -0
  78. data/source/components/avatar/package.json +3 -0
  79. data/source/components/avatar/spec/avatar_spec.js +81 -0
  80. data/source/components/badge/badge.scss +158 -0
  81. data/source/components/button/button.scss +213 -0
  82. data/source/components/card/card.scss +32 -0
  83. data/source/components/code_block/code-block.scss +353 -0
  84. data/source/components/code_block/code_block.erb +95 -0
  85. data/source/components/code_block/code_block.js +444 -0
  86. data/source/components/code_block/package.json +3 -0
  87. data/source/components/code_block/spec/code_block_spec.js +10 -0
  88. data/source/components/demo/demo.js +244 -0
  89. data/source/components/demo/demo.scss +90 -0
  90. data/source/components/demo/package.json +3 -0
  91. data/source/components/exploded/exploded.erb +25 -0
  92. data/source/components/exploded/exploded.js +694 -0
  93. data/source/components/exploded/exploded.scss +166 -0
  94. data/source/components/exploded/package.json +3 -0
  95. data/source/components/field/field.js +24 -0
  96. data/source/components/field/field.scss +101 -0
  97. data/source/components/field/package.json +3 -0
  98. data/source/components/header/header.scss +33 -0
  99. data/source/components/iframe/iframe.erb +12 -0
  100. data/source/components/iframe/iframe.js +381 -0
  101. data/source/components/iframe/package.json +3 -0
  102. data/source/components/index.js +37 -0
  103. data/source/components/inline_group/inline-group.scss +14 -0
  104. data/source/components/internal_link/internal_link.js +49 -0
  105. data/source/components/internal_link/package.json +3 -0
  106. data/source/components/list/list.scss +230 -0
  107. data/source/components/modal/modal.coffee +84 -0
  108. data/source/components/modal/modal.erb +19 -0
  109. data/source/components/modal/modal.js +0 -0
  110. data/source/components/modal/modal.scss +57 -0
  111. data/source/components/modal/package.json +3 -0
  112. data/source/components/notice/notice.scss +48 -0
  113. data/source/components/popover/package.json +3 -0
  114. data/source/components/popover/popover.coffee +562 -0
  115. data/source/components/popover/popover.erb +21 -0
  116. data/source/components/popover/popover.js +0 -0
  117. data/source/components/popover/popover.scss +139 -0
  118. data/source/components/range/range.scss +78 -0
  119. data/source/components/resizable/package.json +3 -0
  120. data/source/components/resizable/resizable.erb +30 -0
  121. data/source/components/resizable/resizable.js +250 -0
  122. data/source/components/resizable/resizable.scss +245 -0
  123. data/source/components/resizable/size_buttons.js +249 -0
  124. data/source/components/scroll_container/package.json +3 -0
  125. data/source/components/scroll_container/scroll-container.scss +4 -0
  126. data/source/components/scroll_container/scroll_container.js +24 -0
  127. data/source/components/section/section.scss +99 -0
  128. data/source/components/select/package.json +3 -0
  129. data/source/components/select/select.erb +21 -0
  130. data/source/components/select/select.js +35 -0
  131. data/source/components/select/select.scss +163 -0
  132. data/source/components/table/package.json +3 -0
  133. data/source/components/table/table.erb +16 -0
  134. data/source/components/table/table.js +351 -0
  135. data/source/components/table/table.scss +236 -0
  136. data/source/components/tablist/package.json +3 -0
  137. data/source/components/tablist/tablist.erb +13 -0
  138. data/source/components/tablist/tablist.js +246 -0
  139. data/source/components/tablist/tablist.scss +191 -0
  140. data/source/components/tablist/tablist_panel.erb +14 -0
  141. data/source/components/tablist/tablist_tab.erb +20 -0
  142. data/source/components/toggle/package.json +3 -0
  143. data/source/components/toggle/toggle.erb +11 -0
  144. data/source/components/toggle/toggle.js +211 -0
  145. data/source/components/toggle/toggle_container.erb +30 -0
  146. data/source/components/vertical_spacer/vertical-spacer.scss +3 -0
  147. data/source/components/vertical_stack/vertical-stack.scss +19 -0
  148. data/source/components/xray/package.json +3 -0
  149. data/source/components/xray/xray.erb +50 -0
  150. data/source/components/xray/xray.js +123 -0
  151. data/source/components/xray/xray.scss +79 -0
  152. data/source/foundation/app/app.js +15 -0
  153. data/source/foundation/app/package.json +3 -0
  154. data/source/pattern-library-demo.scss +13 -0
  155. data/source/pattern-library.scss +13 -0
  156. data/source/pattern_library.js +8 -0
  157. data/source/pattern_library_demo.js +8 -0
  158. data/source/structures/index.js +11 -0
  159. data/source/structures/sidebar/package.json +3 -0
  160. data/source/structures/sidebar/sidebar.js +69 -0
  161. data/source/structures/sidebar/sidebar.scss +79 -0
  162. data/source/utilities/builder/builder.js +138 -0
  163. data/source/utilities/builder/package.json +3 -0
  164. data/source/utilities/client/client.js +7 -0
  165. data/source/utilities/client/package.json +3 -0
  166. data/source/utilities/colors/colors.scss +112 -0
  167. data/source/utilities/defaults/defaults.scss +38 -0
  168. data/source/utilities/dom_cache/dom_cache.js +24 -0
  169. data/source/utilities/dom_cache/package.json +3 -0
  170. data/source/utilities/events/events.js +25 -0
  171. data/source/utilities/events/package.json +3 -0
  172. data/source/utilities/font_sizes/font-sizes.scss +85 -0
  173. data/source/utilities/foundation/a11y.scss +10 -0
  174. data/source/utilities/foundation/base.scss +29 -0
  175. data/source/utilities/foundation/icon.scss +114 -0
  176. data/source/utilities/foundation/layout.scss +67 -0
  177. data/source/utilities/foundation/page.scss +39 -0
  178. data/source/utilities/foundation/type.scss +208 -0
  179. data/source/utilities/functions/functions.scss +127 -0
  180. data/source/utilities/keycodes/keycodes.js +23 -0
  181. data/source/utilities/keycodes/package.json +3 -0
  182. data/source/utilities/markup/markup.js +90 -0
  183. data/source/utilities/markup/package.json +3 -0
  184. data/source/utilities/media/media.scss +172 -0
  185. data/source/utilities/mixins/mixins.scss +89 -0
  186. data/source/utilities/naming_convention/naming_convention.js +3 -0
  187. data/source/utilities/naming_convention/package.json +3 -0
  188. data/source/utilities/numbers/numbers.js +14 -0
  189. data/source/utilities/numbers/package.json +3 -0
  190. data/source/utilities/painting/package.json +3 -0
  191. data/source/utilities/painting/painting.js +7 -0
  192. data/source/utilities/pattern/package.json +3 -0
  193. data/source/utilities/pattern/pattern.js +50 -0
  194. data/source/utilities/query_string/package.json +3 -0
  195. data/source/utilities/query_string/query_string.js +24 -0
  196. data/source/utilities/template/package.json +3 -0
  197. data/source/utilities/template/template.js +10 -0
  198. data/source/utilities/text_range/package.json +3 -0
  199. data/source/utilities/text_range/text_range.js +30 -0
  200. data/source/utilities/ui_events/package.json +3 -0
  201. data/source/utilities/ui_events/ui_events.js +85 -0
  202. data/source/utilities/variables/variables.scss +18 -0
  203. data/source/utilities/z_indexes/z-indexes.scss +88 -0
  204. data/source/vendor/array_includes.js +28 -0
  205. data/source/vendor/highlight.js +1142 -0
  206. data/source/vendor/index.js +1 -0
  207. data/source/vendor/matrix.js +399 -0
  208. data/source/vendor/query_string.js +66 -0
  209. data/spec/assets/.eslintrc +9 -0
  210. data/spec/assets/spec_fixture.js +33 -0
  211. data/spec/assets/spec_helper.js +19 -0
  212. data/spec/lib/components/base_component_spec.rb +156 -0
  213. data/spec/lib/components_spec.rb +30 -0
  214. data/spec/lib/helpers/ui_helper_spec.rb +62 -0
  215. data/spec/lib/theme_spec.rb +25 -0
  216. data/spec/spec_helper.rb +15 -0
  217. data/tasks/gulp/.eslintrc +6 -0
  218. data/tasks/gulp/browser_sync.js +8 -0
  219. data/tasks/gulp/code_quality/scripts.js +10 -0
  220. data/tasks/gulp/config/index.js +116 -0
  221. data/tasks/gulp/minify/scripts.js +13 -0
  222. data/tasks/gulp/minify/styles.js +13 -0
  223. data/tasks/gulp/pattern_library/index.js +5 -0
  224. data/tasks/gulp/pattern_library/scripts.js +10 -0
  225. data/tasks/gulp/pattern_library/styles.js +10 -0
  226. data/tasks/gulp/scripts.js +8 -0
  227. data/tasks/gulp/spec/scripts.js +11 -0
  228. data/tasks/gulp/styles.js +17 -0
  229. data/tasks/gulp/utilities/babel/relative_require.js +22 -0
  230. data/tasks/gulp/utilities/babel/spec_helper.js +20 -0
  231. data/tasks/gulp/utilities/browserify_bundler.js +22 -0
  232. data/tasks/gulp/utilities/handle_errors.js +13 -0
  233. data/tasks/gulp/watch.js +9 -0
  234. data/tasks/rake/rspec.rake +7 -0
  235. data/tasks/rake/rubocop.rake +8 -0
  236. data/tasks/rake/templates.rake +50 -0
  237. metadata +470 -0
@@ -0,0 +1,1882 @@
1
+ @media screen and (max-width: 24.9375rem) {
2
+ .media__helpers--hide-before-small {
3
+ display: none; } }
4
+
5
+ @media screen and (min-width: 25.0625rem) {
6
+ .media__helpers--hide-after-small {
7
+ display: none; } }
8
+
9
+ .media__helpers--show-after-small {
10
+ display: none; }
11
+ @media screen and (min-width: 25.0625rem) {
12
+ .media__helpers--show-after-small {
13
+ display: block; } }
14
+
15
+ @media screen and (max-width: 37.4375rem) {
16
+ .media__helpers--hide-before-medium {
17
+ display: none; } }
18
+
19
+ @media screen and (min-width: 37.5625rem) {
20
+ .media__helpers--hide-after-medium {
21
+ display: none; } }
22
+
23
+ .media__helpers--show-after-medium {
24
+ display: none; }
25
+ @media screen and (min-width: 37.5625rem) {
26
+ .media__helpers--show-after-medium {
27
+ display: block; } }
28
+
29
+ @media screen and (max-width: 49.9375rem) {
30
+ .media__helpers--hide-before-large {
31
+ display: none; } }
32
+
33
+ @media screen and (min-width: 50.0625rem) {
34
+ .media__helpers--hide-after-large {
35
+ display: none; } }
36
+
37
+ .media__helpers--show-after-large {
38
+ display: none; }
39
+ @media screen and (min-width: 50.0625rem) {
40
+ .media__helpers--show-after-large {
41
+ display: block; } }
42
+
43
+ .helper--visually-hidden {
44
+ border: 0;
45
+ clip: rect(0 0 0 0);
46
+ height: 1px;
47
+ margin: -1px;
48
+ overflow: hidden;
49
+ padding: 0;
50
+ position: absolute;
51
+ width: 1px; }
52
+
53
+ html {
54
+ box-sizing: border-box; }
55
+
56
+ *,
57
+ *:before,
58
+ *:after {
59
+ box-sizing: inherit; }
60
+
61
+ body {
62
+ margin: 0;
63
+ padding: 0;
64
+ background-color: white;
65
+ min-height: 100vh; }
66
+
67
+ table {
68
+ border-collapse: collapse;
69
+ border-spacing: 0; }
70
+
71
+ .icon {
72
+ display: inline-block;
73
+ stroke-width: 2; }
74
+
75
+ .icon--medium {
76
+ height: 1.5rem;
77
+ width: 1.5rem; }
78
+
79
+ .icon--large {
80
+ height: 1.75rem;
81
+ width: 1.75rem; }
82
+
83
+ .icon--action {
84
+ height: 1.65rem;
85
+ width: 1.65rem; }
86
+
87
+ .icon--hamburger {
88
+ height: 1.65rem;
89
+ width: 2rem;
90
+ position: relative;
91
+ cursor: pointer;
92
+ opacity: 0.6;
93
+ top: 0.2em;
94
+ -webkit-transition: opacity 0.2s ease;
95
+ transition: opacity 0.2s ease; }
96
+ .icon--hamburger:hover {
97
+ opacity: 1; }
98
+ .icon--hamburger:before,
99
+ .icon--hamburger:after {
100
+ content: "";
101
+ display: block;
102
+ position: absolute;
103
+ height: 4px;
104
+ width: 100%;
105
+ border-radius: 2px;
106
+ background: #6e6f7a; }
107
+ .icon--hamburger:before {
108
+ top: 0; }
109
+ .icon--hamburger:after {
110
+ bottom: 0; }
111
+
112
+ .icon--hamburger__slice {
113
+ height: 4px;
114
+ width: 100%;
115
+ border-radius: 2px;
116
+ background: #6e6f7a;
117
+ position: absolute;
118
+ top: 50%;
119
+ left: 0;
120
+ margin-top: -2px; }
121
+
122
+ .icon--gray-darker {
123
+ fill: #9c9da5;
124
+ stroke: #9c9da5; }
125
+
126
+ .icon--close {
127
+ position: relative;
128
+ opacity: 0.6;
129
+ -webkit-transition: opacity 0.2s ease;
130
+ transition: opacity 0.2s ease;
131
+ cursor: pointer; }
132
+ .icon--close:hover {
133
+ opacity: 1; }
134
+ .icon--close:before,
135
+ .icon--close:after {
136
+ content: "";
137
+ display: block;
138
+ position: absolute;
139
+ height: 4px;
140
+ width: 140%;
141
+ border-radius: 2px;
142
+ background: #6e6f7a;
143
+ top: 50%;
144
+ left: 50%;
145
+ margin-left: -70%;
146
+ margin-top: -2px; }
147
+ .icon--close:before {
148
+ -webkit-transform: rotate(45deg);
149
+ transform: rotate(45deg); }
150
+ .icon--close:after {
151
+ -webkit-transform: rotate(-45deg);
152
+ transform: rotate(-45deg); }
153
+
154
+ .icon--disclosure {
155
+ height: 0.5rem;
156
+ width: 0.5rem;
157
+ -webkit-transform: rotate(45deg) translateY(-50%);
158
+ transform: rotate(45deg) translateY(-50%);
159
+ border-right: 2px solid #6e6f7a;
160
+ border-bottom: 2px solid #6e6f7a;
161
+ margin-left: 0.25rem; }
162
+
163
+ .grid {
164
+ display: -webkit-box;
165
+ display: -webkit-flex;
166
+ display: -ms-flexbox;
167
+ display: flex; }
168
+
169
+ .grid--vertically-centered {
170
+ -webkit-box-align: center;
171
+ -webkit-align-items: center;
172
+ -ms-flex-align: center;
173
+ align-items: center; }
174
+
175
+ .grid--align-right {
176
+ -webkit-box-pack: end;
177
+ -webkit-justify-content: flex-end;
178
+ -ms-flex-pack: end;
179
+ justify-content: flex-end; }
180
+
181
+ .grid--outside-spacing {
182
+ margin: 1rem 0;
183
+ padding: 0 1rem; }
184
+
185
+ .grid--space-between {
186
+ -webkit-box-pack: justify;
187
+ -webkit-justify-content: space-between;
188
+ -ms-flex-pack: justify;
189
+ justify-content: space-between; }
190
+ .grid--space-between > .grid__item {
191
+ -webkit-box-flex: 0;
192
+ -webkit-flex: 0 1 auto;
193
+ -ms-flex: 0 1 auto;
194
+ flex: 0 1 auto; }
195
+
196
+ .grid__item {
197
+ padding: 0 0.5rem;
198
+ -webkit-box-flex: 1;
199
+ -webkit-flex: 1 1 0%;
200
+ -ms-flex: 1 1 0%;
201
+ flex: 1 1 0%;
202
+ display: -webkit-box;
203
+ display: -webkit-flex;
204
+ display: -ms-flexbox;
205
+ display: flex;
206
+ -webkit-box-align: center;
207
+ -webkit-align-items: center;
208
+ -ms-flex-align: center;
209
+ align-items: center; }
210
+ .grid__item:first-child {
211
+ padding-left: 0; }
212
+ .grid__item:last-child {
213
+ padding-right: 0; }
214
+
215
+ .grid__item--no-flex {
216
+ -webkit-box-flex: 0;
217
+ -webkit-flex: 0 0 auto;
218
+ -ms-flex: 0 0 auto;
219
+ flex: 0 0 auto; }
220
+
221
+ .grid__item--half {
222
+ -webkit-box-flex: 0;
223
+ -webkit-flex: 0 0 50%;
224
+ -ms-flex: 0 0 50%;
225
+ flex: 0 0 50%; }
226
+
227
+ .content {
228
+ padding: 0 1rem;
229
+ margin: 1rem 0; }
230
+
231
+ .content--extra-vertical-spacing {
232
+ margin: 3rem 0; }
233
+
234
+ body {
235
+ background-color: #e3e4e6; }
236
+
237
+ .page {
238
+ height: 100vh;
239
+ max-height: 100vh;
240
+ display: -webkit-box;
241
+ display: -webkit-flex;
242
+ display: -ms-flexbox;
243
+ display: flex; }
244
+
245
+ .page__content,
246
+ .page__sidebar {
247
+ position: relative; }
248
+
249
+ .page__content {
250
+ width: 100%;
251
+ max-width: 100%;
252
+ display: -webkit-box;
253
+ display: -webkit-flex;
254
+ display: -ms-flexbox;
255
+ display: flex;
256
+ -webkit-box-flex: 1;
257
+ -webkit-flex: 1 1 0px;
258
+ -ms-flex: 1 1 0px;
259
+ flex: 1 1 0px;
260
+ z-index: 10;
261
+ background: white; }
262
+ .page__content > * {
263
+ -webkit-box-flex: 0;
264
+ -webkit-flex: 0 0 100%;
265
+ -ms-flex: 0 0 100%;
266
+ flex: 0 0 100%; }
267
+
268
+ .page__sidebar {
269
+ z-index: 20;
270
+ -webkit-box-flex: 0;
271
+ -webkit-flex: 0 0 auto;
272
+ -ms-flex: 0 0 auto;
273
+ flex: 0 0 auto; }
274
+
275
+ body {
276
+ -webkit-text-size-adjust: 100%;
277
+ -ms-text-size-adjust: 100%;
278
+ text-size-adjust: 100%;
279
+ color: #33363a;
280
+ font-family: Source Sans Pro, Helvetica Neue, Helvetica, Arial, sans-serif; }
281
+
282
+ button,
283
+ input {
284
+ font-family: Source Sans Pro, Helvetica Neue, Helvetica, Arial, sans-serif; }
285
+
286
+ h1, h2, h3, h4, h5, h6, p, .type {
287
+ margin: 0;
288
+ font-size: inherit; }
289
+
290
+ .type--heading-1 {
291
+ font-weight: 400;
292
+ line-height: 1;
293
+ color: #6e6f7a;
294
+ font-size: 2.25rem; }
295
+
296
+ .type--heading-2 {
297
+ font-weight: 400;
298
+ color: #6e6f7a;
299
+ font-size: 1.875rem; }
300
+
301
+ .type--heading-3 {
302
+ font-weight: 400;
303
+ line-height: 1;
304
+ color: #6e6f7a;
305
+ font-size: 1.5rem; }
306
+
307
+ .type--heading-4 {
308
+ margin: 1rem auto 0.5rem;
309
+ font-weight: 600;
310
+ text-transform: uppercase;
311
+ color: #d1d3d7;
312
+ font-size: 0.875rem; }
313
+
314
+ .type--heading-5 {
315
+ margin: 1rem auto 0.5rem;
316
+ font-weight: 400;
317
+ color: #6e6f7a;
318
+ font-size: 1.25rem; }
319
+ .type--heading-4 + .type--heading-5 {
320
+ margin-top: 0.5rem; }
321
+ .type--paragraph + .type--heading-5,
322
+ .user-type + .type--heading-5 {
323
+ margin-top: 1.5rem; }
324
+
325
+ .type--heading-bordered {
326
+ padding-bottom: 1rem;
327
+ margin-bottom: 1.3rem;
328
+ border-bottom: 2px solid #e3e4e6; }
329
+ .type--heading-bordered + .section {
330
+ margin-top: -1rem; }
331
+
332
+ .type--paragraph {
333
+ font-size: 1.25rem;
334
+ line-height: 1.3;
335
+ font-weight: 300;
336
+ color: #1e1e1f; }
337
+ .type--paragraph + p {
338
+ margin-top: 0.75rem; }
339
+ .type--paragraph > a {
340
+ display: inline-block;
341
+ text-decoration: none;
342
+ color: #627990;
343
+ font-weight: normal; }
344
+ .type--paragraph > a > span {
345
+ border-bottom: 2px solid #8cc2fb; }
346
+ .type--paragraph > a > code {
347
+ color: #627990;
348
+ background-color: #e6ecf4;
349
+ border-color: rgba(98, 121, 144, 0.15); }
350
+ .type--paragraph code {
351
+ font-family: Consolas, monospace;
352
+ display: inline-block;
353
+ padding: 0.05em 0.25em;
354
+ font-size: 0.8em;
355
+ background-color: #f2f2f3;
356
+ color: #6e6f7a;
357
+ border: 1px solid #e3e4e6;
358
+ border-radius: 4px; }
359
+
360
+ .type--paragraph-small {
361
+ font-size: 1.125rem; }
362
+
363
+ .type-container h1 {
364
+ font-weight: 400;
365
+ line-height: 1;
366
+ color: #6e6f7a;
367
+ font-size: 2.25rem; }
368
+
369
+ .type-container h2 {
370
+ font-weight: 400;
371
+ color: #6e6f7a;
372
+ font-size: 1.875rem; }
373
+
374
+ .type-container h3 {
375
+ font-weight: 400;
376
+ line-height: 1;
377
+ color: #6e6f7a;
378
+ font-size: 1.5rem; }
379
+
380
+ .type-container h4 {
381
+ margin: 1rem auto 0.5rem;
382
+ font-weight: 600;
383
+ text-transform: uppercase;
384
+ color: #d1d3d7;
385
+ font-size: 0.875rem; }
386
+
387
+ .type-container h5 {
388
+ margin: 1rem auto 0.5rem;
389
+ font-weight: 400;
390
+ color: #6e6f7a;
391
+ font-size: 1.25rem; }
392
+
393
+ .type-container p {
394
+ font-size: 1.25rem;
395
+ line-height: 1.3;
396
+ font-weight: 300;
397
+ color: #1e1e1f; }
398
+ .type-container p + p {
399
+ margin-top: 0.75rem; }
400
+ .type-container p > a {
401
+ display: inline-block;
402
+ text-decoration: none;
403
+ color: #627990;
404
+ font-weight: normal; }
405
+ .type-container p > a > span {
406
+ border-bottom: 2px solid #8cc2fb; }
407
+ .type-container p > a > code {
408
+ color: #627990;
409
+ background-color: #e6ecf4;
410
+ border-color: rgba(98, 121, 144, 0.15); }
411
+ .type-container p code {
412
+ font-family: Consolas, monospace;
413
+ display: inline-block;
414
+ padding: 0.05em 0.25em;
415
+ font-size: 0.8em;
416
+ background-color: #f2f2f3;
417
+ color: #6e6f7a;
418
+ border: 1px solid #e3e4e6;
419
+ border-radius: 4px; }
420
+
421
+ .type-container--small p {
422
+ font-size: 1.125rem; }
423
+
424
+ .type--display {
425
+ font-size: 1.3rem;
426
+ margin-top: 0;
427
+ font-weight: 500;
428
+ line-height: 1; }
429
+
430
+ .type--margin-bottom {
431
+ margin-bottom: 1rem; }
432
+
433
+ .type--subdued {
434
+ color: #d1d3d7; }
435
+
436
+ .type--code {
437
+ font-family: Consolas, monospace;
438
+ font-size: 0.95em;
439
+ word-wrap: break-word; }
440
+
441
+ ::-moz-selection {
442
+ background: #b7d6f6; }
443
+
444
+ ::selection {
445
+ background: #b7d6f6; }
446
+
447
+ .avatar {
448
+ z-index: 10;
449
+ position: relative;
450
+ -webkit-box-flex: 0;
451
+ -webkit-flex: 0 0 auto;
452
+ -ms-flex: 0 0 auto;
453
+ flex: 0 0 auto;
454
+ display: inline-block;
455
+ background-color: #f1f1f1;
456
+ border-radius: 4px;
457
+ overflow: hidden;
458
+ font-size: 1.25rem; }
459
+
460
+ .avatar__initials {
461
+ z-index: 10;
462
+ position: absolute;
463
+ top: 50%;
464
+ left: 0;
465
+ width: 100%;
466
+ -webkit-transform: translateY(-50%);
467
+ transform: translateY(-50%);
468
+ color: #cfcfcf;
469
+ font-size: 1em;
470
+ line-height: 1;
471
+ text-align: center;
472
+ text-transform: uppercase; }
473
+
474
+ .avatar__image {
475
+ z-index: 20;
476
+ position: relative;
477
+ height: 3rem;
478
+ width: 3rem;
479
+ opacity: 0;
480
+ -webkit-transition: opacity 0.3s ease;
481
+ transition: opacity 0.3s ease;
482
+ background-size: cover;
483
+ background-position: center center;
484
+ background-repeat: no-repeat;
485
+ overflow: hidden; }
486
+
487
+ .avatar__image--is-visible {
488
+ opacity: 1; }
489
+
490
+ .avatar__container {
491
+ display: -webkit-inline-box;
492
+ display: -webkit-inline-flex;
493
+ display: -ms-inline-flexbox;
494
+ display: inline-flex;
495
+ -webkit-flex-wrap: wrap;
496
+ -ms-flex-wrap: wrap;
497
+ flex-wrap: wrap;
498
+ overflow: hidden;
499
+ margin-right: -0.5rem !important;
500
+ margin-bottom: -0.5rem !important;
501
+ max-width: 10.5rem; }
502
+ .avatar__container > .avatar {
503
+ margin-right: 0.5rem;
504
+ margin-bottom: 0.5rem; }
505
+
506
+ .avatar__container--large {
507
+ max-width: 14rem; }
508
+
509
+ .badge {
510
+ position: relative;
511
+ -webkit-box-flex: 0;
512
+ -webkit-flex: 0 0 auto;
513
+ -ms-flex: 0 0 auto;
514
+ flex: 0 0 auto;
515
+ display: inline-block;
516
+ padding: 0.15em 0.5em 0.25em;
517
+ border-radius: 4px;
518
+ background-color: #f2f2f3;
519
+ font-size: 0.75em;
520
+ line-height: 1.3;
521
+ vertical-align: middle;
522
+ color: #9c9da5; }
523
+
524
+ .badge--warning {
525
+ background-color: #fdf7af;
526
+ color: #857e32; }
527
+
528
+ .badge--new {
529
+ background-color: #b7d6f6;
530
+ color: #627990; }
531
+
532
+ .badge--secret {
533
+ background-color: #6e6f7a;
534
+ color: #e3e4e6; }
535
+
536
+ .badge--code {
537
+ padding-bottom: 0;
538
+ padding-top: 0.2em; }
539
+
540
+ .badge--standalone {
541
+ font-size: 1rem; }
542
+
543
+ .badge__container {
544
+ display: -webkit-inline-box;
545
+ display: -webkit-inline-flex;
546
+ display: -ms-inline-flexbox;
547
+ display: inline-flex;
548
+ -webkit-flex-wrap: wrap;
549
+ -ms-flex-wrap: wrap;
550
+ flex-wrap: wrap;
551
+ overflow: hidden;
552
+ margin-right: -0.5rem !important;
553
+ margin-bottom: -0.5rem !important; }
554
+ .badge__container > .badge {
555
+ margin-right: 0.5rem;
556
+ margin-bottom: 0.5rem; }
557
+
558
+ .docks-button {
559
+ display: -webkit-inline-box;
560
+ display: -webkit-inline-flex;
561
+ display: -ms-inline-flexbox;
562
+ display: inline-flex;
563
+ -webkit-box-align: center;
564
+ -webkit-align-items: center;
565
+ -ms-flex-align: center;
566
+ align-items: center;
567
+ -webkit-box-pack: center;
568
+ -webkit-justify-content: center;
569
+ -ms-flex-pack: center;
570
+ justify-content: center;
571
+ padding: 0 0.75rem;
572
+ border-radius: 4px;
573
+ background-color: #f2f2f3;
574
+ border: none;
575
+ cursor: pointer;
576
+ opacity: 1;
577
+ -webkit-transition: opacity 0.3s ease;
578
+ transition: opacity 0.3s ease;
579
+ font-size: 1.125rem;
580
+ line-height: 2.125rem;
581
+ color: #9c9da5;
582
+ vertical-align: middle;
583
+ text-decoration: none;
584
+ white-space: nowrap; }
585
+ .docks-button:focus,
586
+ .docks-button:active {
587
+ background-color: #e3e4e6;
588
+ outline: none; }
589
+ .docks-button > *:first-child {
590
+ margin-right: 0.5rem; }
591
+
592
+ .docks-button--dark {
593
+ background-color: #d1d3d7;
594
+ color: #6e6f7a; }
595
+ .docks-button--dark:focus,
596
+ .docks-button--dark:active {
597
+ background-color: #d1d3d7;
598
+ color: #6e6f7a; }
599
+
600
+ .docks-button--is-disabled {
601
+ opacity: 0.3; }
602
+
603
+ .docks-button__container {
604
+ display: -webkit-inline-box;
605
+ display: -webkit-inline-flex;
606
+ display: -ms-inline-flexbox;
607
+ display: inline-flex;
608
+ -webkit-flex-wrap: wrap;
609
+ -ms-flex-wrap: wrap;
610
+ flex-wrap: wrap;
611
+ margin-right: -0.5rem !important;
612
+ margin-bottom: -0.5rem !important; }
613
+ .docks-button__container:after {
614
+ content: "";
615
+ display: table; }
616
+ .docks-button__container > * {
617
+ -webkit-box-flex: 0;
618
+ -webkit-flex: 0 0 auto;
619
+ -ms-flex: 0 0 auto;
620
+ flex: 0 0 auto;
621
+ margin-right: 0.5rem;
622
+ margin-bottom: 0.5rem; }
623
+
624
+ .docks-button__container--fill-width {
625
+ display: -webkit-box;
626
+ display: -webkit-flex;
627
+ display: -ms-flexbox;
628
+ display: flex;
629
+ -webkit-flex-wrap: wrap;
630
+ -ms-flex-wrap: wrap;
631
+ flex-wrap: wrap;
632
+ -webkit-box-align: start;
633
+ -webkit-align-items: flex-start;
634
+ -ms-flex-align: start;
635
+ align-items: flex-start; }
636
+ .docks-button__container--fill-width .docks-button,
637
+ .docks-button__container--fill-width > *:not(.docks-button) {
638
+ display: -webkit-box;
639
+ display: -webkit-flex;
640
+ display: -ms-flexbox;
641
+ display: flex;
642
+ -webkit-box-flex: 1;
643
+ -webkit-flex: 1 0 0%;
644
+ -ms-flex: 1 0 0%;
645
+ flex: 1 0 0%;
646
+ min-width: -webkit-min-content;
647
+ min-width: -moz-min-content;
648
+ min-width: min-content; }
649
+
650
+ .docks-button__segmented-container {
651
+ display: -webkit-inline-box;
652
+ display: -webkit-inline-flex;
653
+ display: -ms-inline-flexbox;
654
+ display: inline-flex; }
655
+ .docks-button__segmented-container > .docks-button {
656
+ border-radius: 0; }
657
+ .docks-button__segmented-container > .docks-button:not(:first-child) {
658
+ border-left: none; }
659
+ .docks-button__segmented-container > .docks-button:first-child {
660
+ border-radius: 4px 0 0 4px; }
661
+ .docks-button__segmented-container > .docks-button:last-child {
662
+ border-radius: 0 4px 4px 0; }
663
+
664
+ .card {
665
+ background-color: white;
666
+ border-radius: 4px;
667
+ overflow: hidden; }
668
+
669
+ .code-block {
670
+ margin: 1rem 0;
671
+ overflow: hidden;
672
+ background: #f2f2f3;
673
+ border-radius: 4px; }
674
+ .code-block .docks-button {
675
+ display: none; }
676
+
677
+ .code-block--condensed {
678
+ margin-top: 0.5rem; }
679
+ .code-block--condensed .code-block__code {
680
+ padding-bottom: 0.5rem;
681
+ font-size: 0.875rem; }
682
+ .code-block--condensed:not(.code-block--with-header) .code-block__code {
683
+ padding-top: 0.5rem; }
684
+
685
+ .code-block--full-width {
686
+ margin-right: 0;
687
+ margin-left: 0;
688
+ border-radius: 0; }
689
+ .content .code-block--full-width {
690
+ margin-left: -1rem;
691
+ margin-right: -1rem; }
692
+
693
+ .code-block--is-hidden:not(.code-block--with-demo) .code-block__toggler {
694
+ background-color: #f2f2f3; }
695
+
696
+ .code-block--is-hidden .code-block__content {
697
+ height: 0; }
698
+
699
+ .code-block__actions {
700
+ display: -webkit-box;
701
+ display: -webkit-flex;
702
+ display: -ms-flexbox;
703
+ display: flex;
704
+ -webkit-box-align: center;
705
+ -webkit-align-items: center;
706
+ -ms-flex-align: center;
707
+ align-items: center; }
708
+
709
+ .code-block__header {
710
+ display: -webkit-box;
711
+ display: -webkit-flex;
712
+ display: -ms-flexbox;
713
+ display: flex;
714
+ -webkit-box-pack: justify;
715
+ -webkit-justify-content: space-between;
716
+ -ms-flex-pack: justify;
717
+ justify-content: space-between;
718
+ -webkit-box-align: center;
719
+ -webkit-align-items: center;
720
+ -ms-flex-align: center;
721
+ align-items: center;
722
+ padding: 0.5rem 1rem;
723
+ -webkit-box-flex: 0 !important;
724
+ -webkit-flex: 0 0 auto !important;
725
+ -ms-flex: 0 0 auto !important;
726
+ flex: 0 0 auto !important;
727
+ background: #f2f2f3; }
728
+ .code-block__header .select,
729
+ .code-block__header .tablist {
730
+ -webkit-transition: -webkit-transform 0.2s ease;
731
+ transition: transform 0.2s ease; }
732
+ .code-block__header .tablist {
733
+ padding: 0; }
734
+
735
+ .code-block__code-container {
736
+ overflow: auto;
737
+ max-height: 100%; }
738
+
739
+ .code-block__toggler {
740
+ background-color: #e3e4e6;
741
+ width: 100%;
742
+ border: none;
743
+ display: -webkit-box;
744
+ display: -webkit-flex;
745
+ display: -ms-flexbox;
746
+ display: flex;
747
+ -webkit-box-align: center;
748
+ -webkit-align-items: center;
749
+ -ms-flex-align: center;
750
+ align-items: center;
751
+ -webkit-box-pack: center;
752
+ -webkit-justify-content: center;
753
+ -ms-flex-pack: center;
754
+ justify-content: center;
755
+ font-size: 1.125rem;
756
+ padding: 0.5rem 0;
757
+ color: #9c9da5;
758
+ -webkit-transition: background-color 0.2s ease;
759
+ transition: background-color 0.2s ease; }
760
+ .code-block__toggler:focus,
761
+ .code-block__toggler:active {
762
+ background-color: #e3e4e6;
763
+ outline: none; }
764
+ .code-block__toggler > .icon {
765
+ margin-right: 0.5rem;
766
+ opacity: 0.5; }
767
+
768
+ .code-block__content {
769
+ overflow: hidden;
770
+ -webkit-transition: height 0.3s ease;
771
+ transition: height 0.3s ease;
772
+ max-height: 15rem; }
773
+
774
+ .code-block__code {
775
+ margin: 0;
776
+ display: inline-block;
777
+ padding: 0.5rem 1rem 1rem;
778
+ font-size: 1rem;
779
+ line-height: 1.3; }
780
+ .code-block__code:focus {
781
+ outline: none; }
782
+ .code-block:not(.code-block--with-header):not(.code-block--condensed):not(.code-block--with-demo) .code-block__code {
783
+ padding-top: 1rem; }
784
+ .code-block--with-demo:not(.code-block--with-header) .code-block__code {
785
+ padding-top: 0; }
786
+ .code-block__code > code {
787
+ font-family: Consolas, monospace;
788
+ padding: 0;
789
+ background-color: transparent;
790
+ font-size: inherit !important;
791
+ border: none; }
792
+
793
+ .hljs-value,
794
+ .hljs-string,
795
+ .hljs-preprocessor {
796
+ color: #4196df; }
797
+
798
+ .hljs-symbol {
799
+ color: #1a5cab; }
800
+
801
+ .hljs-at_rule,
802
+ .hljs-attribute,
803
+ .hljs-keyword {
804
+ color: #4a4a4a; }
805
+
806
+ .hljs-comment {
807
+ color: rgba(177, 177, 177, 0.5);
808
+ font-style: italic; }
809
+
810
+ .hljs-tag,
811
+ .hljs-variable {
812
+ color: #b1b1b1; }
813
+
814
+ .code-block--with-demo .code-block__content {
815
+ padding-top: 0; }
816
+ .code-block--with-demo .code-block__content > .code-block__header {
817
+ padding-top: 0; }
818
+
819
+ .code-block__demo {
820
+ padding: 1rem; }
821
+
822
+ .code-block__demo__content {
823
+ display: none; }
824
+
825
+ .code-block__iframe {
826
+ height: 10em;
827
+ background-color: white;
828
+ border: none;
829
+ width: 100%;
830
+ margin: 0;
831
+ border-radius: 4px; }
832
+
833
+ .demo {
834
+ background-color: white;
835
+ min-height: 10rem; }
836
+
837
+ .demo__section {
838
+ position: relative;
839
+ box-sizing: border-box;
840
+ overflow: hidden;
841
+ background-color: white; }
842
+ .demo__section ~ .demo__section {
843
+ border-top: 1px solid #f1f1f1; }
844
+
845
+ .demo__header {
846
+ box-sizing: border-box;
847
+ margin-right: -0.5rem;
848
+ padding: 0.5rem 1rem 0;
849
+ text-align: right; }
850
+
851
+ .exploded--is-being-initialized .exploded__pane {
852
+ -webkit-transition: -webkit-transform 0.25s ease;
853
+ transition: transform 0.25s ease; }
854
+
855
+ .exploded__source,
856
+ .exploded__structure {
857
+ padding: 1rem 2rem; }
858
+
859
+ .exploded__structure {
860
+ position: relative;
861
+ -webkit-perspective: 2000px;
862
+ perspective: 2000px;
863
+ -webkit-transform-style: preserve-3d;
864
+ transform-style: preserve-3d;
865
+ cursor: pointer; }
866
+
867
+ .exploded__structure__content {
868
+ position: relative;
869
+ z-index: 0;
870
+ margin: 0 auto; }
871
+
872
+ .exploded__control-container {
873
+ display: -webkit-box;
874
+ display: -webkit-flex;
875
+ display: -ms-flexbox;
876
+ display: flex;
877
+ -webkit-box-align: end;
878
+ -webkit-align-items: flex-end;
879
+ -ms-flex-align: end;
880
+ align-items: flex-end;
881
+ margin: 3rem -1rem 0; }
882
+
883
+ .exploded__control {
884
+ -webkit-box-flex: 1;
885
+ -webkit-flex: 1 1 0;
886
+ -ms-flex: 1 1 0;
887
+ flex: 1 1 0;
888
+ margin-left: 1rem; }
889
+ .exploded__control:first-child {
890
+ margin-left: 0; }
891
+
892
+ .exploded__pane {
893
+ position: absolute;
894
+ box-sizing: content-box;
895
+ border-radius: 4px;
896
+ background-color: rgba(156, 157, 165, 0.6);
897
+ border: 1px solid rgba(227, 228, 230, 0.5);
898
+ -webkit-transition: background 0.3s ease;
899
+ transition: background 0.3s ease; }
900
+ .exploded__pane:hover {
901
+ background-color: #b7d6f6; }
902
+
903
+ .exploded__pane--is-selected, .exploded__pane--is-selected:hover {
904
+ background: #8cc2fb;
905
+ opacity: 1; }
906
+
907
+ .field {
908
+ border-radius: 4px;
909
+ background-color: #d1d3d7;
910
+ display: -webkit-box;
911
+ display: -webkit-flex;
912
+ display: -ms-flexbox;
913
+ display: flex;
914
+ -webkit-box-align: center;
915
+ -webkit-align-items: center;
916
+ -ms-flex-align: center;
917
+ align-items: center;
918
+ max-width: 100%;
919
+ padding: 0 0.5rem; }
920
+
921
+ .field--switch {
922
+ padding: 0;
923
+ background-color: transparent;
924
+ position: relative; }
925
+ .field--switch > .label {
926
+ margin: 0;
927
+ padding-left: 2.25rem;
928
+ position: relative;
929
+ line-height: 1.5rem;
930
+ color: #6e6f7a; }
931
+ .field--switch > .label:after {
932
+ content: '';
933
+ display: block;
934
+ height: 1.05rem;
935
+ width: 0.45rem;
936
+ position: absolute;
937
+ top: 0.75rem;
938
+ left: 0.75rem;
939
+ border-bottom: 2px solid #627990;
940
+ border-right: 2px solid #627990;
941
+ -webkit-transform: translate(-50%, -60%) rotate(45deg);
942
+ transform: translate(-50%, -60%) rotate(45deg);
943
+ display: none; }
944
+ .field--switch > .label:before {
945
+ content: '';
946
+ display: block;
947
+ height: 1.5rem;
948
+ width: 1.5rem;
949
+ background: #e3e4e6;
950
+ position: absolute;
951
+ top: 0;
952
+ left: 0;
953
+ border-radius: 4px; }
954
+ .field--switch > .field__switch:checked + .label:before {
955
+ background: #b7d6f6; }
956
+ .field--switch > .field__switch:checked + .label:after {
957
+ display: block; }
958
+ .field--switch > .field__switch {
959
+ position: absolute;
960
+ top: 0;
961
+ left: 0;
962
+ opacity: 0.1; }
963
+ .field--switch + .field--switch {
964
+ margin-top: 1rem; }
965
+
966
+ .field__icon {
967
+ -webkit-box-flex: 0;
968
+ -webkit-flex: 0 0 auto;
969
+ -ms-flex: 0 0 auto;
970
+ flex: 0 0 auto;
971
+ font-size: 0; }
972
+ .field__icon > .icon {
973
+ fill: #9c9da5;
974
+ stroke: #9c9da5; }
975
+
976
+ .field__input {
977
+ -webkit-box-flex: 1;
978
+ -webkit-flex: 1 1 auto;
979
+ -ms-flex: 1 1 auto;
980
+ flex: 1 1 auto;
981
+ margin: 0;
982
+ padding: 0;
983
+ background: transparent;
984
+ border: none;
985
+ line-height: 2.125rem;
986
+ font-size: 1.1rem;
987
+ font-family: Source Sans Pro, Helvetica Neue, Helvetica, Arial, sans-serif; }
988
+ .field__input::-webkit-input-placeholder {
989
+ color: rgba(156, 157, 165, 0.5); }
990
+ .field__input::-moz-placeholder {
991
+ color: rgba(156, 157, 165, 0.5); }
992
+ .field__input:-ms-input-placeholder {
993
+ color: rgba(156, 157, 165, 0.5); }
994
+ .field__input::placeholder {
995
+ color: rgba(156, 157, 165, 0.5); }
996
+ .field__input:focus {
997
+ outline: none; }
998
+
999
+ .page-header {
1000
+ background-color: #e3e4e6;
1001
+ padding: 1rem;
1002
+ padding-bottom: 1rem;
1003
+ min-height: 4.125rem; }
1004
+ .page-header .type--heading-1 {
1005
+ margin: -0.5em 0; }
1006
+
1007
+ .inline-group {
1008
+ display: -webkit-inline-box;
1009
+ display: -webkit-inline-flex;
1010
+ display: -ms-inline-flexbox;
1011
+ display: inline-flex;
1012
+ -webkit-flex-wrap: wrap;
1013
+ -ms-flex-wrap: wrap;
1014
+ flex-wrap: wrap;
1015
+ -webkit-box-align: center;
1016
+ -webkit-align-items: center;
1017
+ -ms-flex-align: center;
1018
+ align-items: center;
1019
+ margin-right: -0.5rem;
1020
+ margin-bottom: -0.5rem; }
1021
+
1022
+ .inline-group__item {
1023
+ margin-right: 0.5rem;
1024
+ margin-bottom: 0.5rem; }
1025
+
1026
+ .list {
1027
+ padding: 0;
1028
+ margin: 1rem 0 2rem;
1029
+ list-style: none; }
1030
+ .list .type--heading {
1031
+ padding-left: 1rem;
1032
+ padding-right: 1rem; }
1033
+ .popover .list {
1034
+ margin-bottom: 1rem; }
1035
+
1036
+ .list__item {
1037
+ display: block;
1038
+ padding: 0.25rem 1rem;
1039
+ cursor: pointer;
1040
+ text-decoration: none;
1041
+ color: #6e6f7a;
1042
+ white-space: nowrap;
1043
+ text-overflow: ellipsis;
1044
+ overflow: hidden; }
1045
+ .list__item:hover,
1046
+ .list__item:focus {
1047
+ outline: none;
1048
+ background: #f2f2f3; }
1049
+ .list__item:active {
1050
+ background-color: #b7d6f6;
1051
+ color: #627990; }
1052
+
1053
+ .list__item--is-active,
1054
+ .list__item--is-active:hover,
1055
+ .list__item--is-active:focus {
1056
+ background-color: #b7d6f6;
1057
+ color: #627990; }
1058
+
1059
+ .list__item--indented {
1060
+ padding-left: calc(1rem + 2ch);
1061
+ position: relative; }
1062
+ .list__item--indented:before {
1063
+ content: "";
1064
+ display: block;
1065
+ position: absolute;
1066
+ left: calc(1rem + 1ch);
1067
+ top: 0;
1068
+ height: 100%;
1069
+ width: 2px;
1070
+ background: rgba(30, 30, 31, 0.07); }
1071
+ .list__item--indented:last-child:before {
1072
+ height: 85%; }
1073
+ .list__item:not(.list__item--indented) + .list__item--indented:before {
1074
+ top: 15%;
1075
+ height: 85%; }
1076
+
1077
+ .link-list {
1078
+ padding: 0;
1079
+ margin: 0;
1080
+ list-style: none;
1081
+ display: -webkit-box;
1082
+ display: -webkit-flex;
1083
+ display: -ms-flexbox;
1084
+ display: flex;
1085
+ -webkit-flex-wrap: wrap;
1086
+ -ms-flex-wrap: wrap;
1087
+ flex-wrap: wrap; }
1088
+ .link-list > li {
1089
+ position: relative;
1090
+ -webkit-box-flex: 0;
1091
+ -webkit-flex: 0 0 auto;
1092
+ -ms-flex: 0 0 auto;
1093
+ flex: 0 0 auto; }
1094
+ .link-list > li:after {
1095
+ content: "";
1096
+ position: absolute;
1097
+ top: 10%;
1098
+ right: -1px;
1099
+ -webkit-transform: rotate(15deg);
1100
+ transform: rotate(15deg);
1101
+ display: block;
1102
+ height: 80%;
1103
+ border-right: 2px solid rgba(110, 111, 122, 0.1); }
1104
+ .link-list > li:last-child:after {
1105
+ display: none;
1106
+ margin-right: 0; }
1107
+
1108
+ .link-list__item {
1109
+ position: relative;
1110
+ display: block;
1111
+ cursor: pointer;
1112
+ padding: 0.25rem 0.5rem;
1113
+ -webkit-appearance: none;
1114
+ -moz-appearance: none;
1115
+ background: none;
1116
+ border: none;
1117
+ opacity: 0.6;
1118
+ font-size: 1em;
1119
+ line-height: 1;
1120
+ color: #9c9da5;
1121
+ -webkit-transition: opacity 0.25s ease;
1122
+ transition: opacity 0.25s ease; }
1123
+ .link-list__item:hover,
1124
+ .link-list__item:focus {
1125
+ opacity: 1;
1126
+ outline: none; }
1127
+
1128
+ .unstyled-list {
1129
+ margin: 0;
1130
+ padding: 0;
1131
+ list-style: none; }
1132
+ .unstyled-list > li {
1133
+ margin: 2rem 0; }
1134
+ .unstyled-list > li:first-child {
1135
+ margin-top: 0; }
1136
+
1137
+ .details-sheet {
1138
+ max-width: 90%;
1139
+ position: fixed;
1140
+ top: 50%;
1141
+ left: 50%;
1142
+ -webkit-transform: translate(-50%, -50%);
1143
+ transform: translate(-50%, -50%);
1144
+ background-color: white;
1145
+ border-radius: 0.4rem;
1146
+ box-shadow: 0 0 10px rgba(30, 30, 31, 0.3);
1147
+ z-index: 20;
1148
+ display: none; }
1149
+
1150
+ .details-sheet--is-active {
1151
+ display: block; }
1152
+
1153
+ .details-sheet__overlay {
1154
+ background: rgba(30, 30, 31, 0.9);
1155
+ position: absolute;
1156
+ top: 0;
1157
+ bottom: 0;
1158
+ right: 0;
1159
+ left: 0;
1160
+ z-index: 19;
1161
+ display: none; }
1162
+
1163
+ .details-sheet__overlay--is-active {
1164
+ display: block; }
1165
+
1166
+ .details-sheet__section {
1167
+ padding: 1rem; }
1168
+ .details-sheet__section + .details-sheet__section {
1169
+ border-top: 1px solid; }
1170
+
1171
+ .details-sheet__name {
1172
+ display: inline-block;
1173
+ padding: 0.1rem 0.25em;
1174
+ border-radius: 0.25em;
1175
+ color: #37393c;
1176
+ font-size: 1.2em;
1177
+ font-family: Consolas, monospace;
1178
+ margin: 0; }
1179
+
1180
+ .details-sheet__subtitle {
1181
+ margin: 0 0 0.5rem;
1182
+ font-size: 0.6rem;
1183
+ text-transform: uppercase;
1184
+ color: #37393c;
1185
+ opacity: 0.3;
1186
+ font-weight: 600; }
1187
+
1188
+ .notice {
1189
+ background-color: #fdf7af;
1190
+ width: -webkit-fit-content;
1191
+ width: -moz-fit-content;
1192
+ width: fit-content;
1193
+ color: #857e32;
1194
+ padding: 1rem;
1195
+ border-radius: 4px;
1196
+ font-size: 1.125rem;
1197
+ position: relative; }
1198
+ .notice .type, .notice p, .notice code {
1199
+ color: inherit;
1200
+ font-size: inherit; }
1201
+ .notice .type--heading {
1202
+ font-weight: 400; }
1203
+
1204
+ .notice--new {
1205
+ background-color: #b7d6f6;
1206
+ color: #627990; }
1207
+
1208
+ /*============================================================================
1209
+ Next Popover
1210
+ ==============================================================================*/
1211
+ .popover__container {
1212
+ position: relative;
1213
+ display: -webkit-inline-box;
1214
+ display: -webkit-inline-flex;
1215
+ display: -ms-inline-flexbox;
1216
+ display: inline-flex;
1217
+ z-index: 20; }
1218
+ .popover__container > *:focus {
1219
+ outline: 0; }
1220
+
1221
+ .popover__container--contains-active-popover {
1222
+ z-index: 40; }
1223
+
1224
+ .popover__container--is-deactivating {
1225
+ z-index: 30; }
1226
+
1227
+ .popover__container--full-width {
1228
+ display: -webkit-box;
1229
+ display: -webkit-flex;
1230
+ display: -ms-flexbox;
1231
+ display: flex; }
1232
+
1233
+ .popover {
1234
+ position: absolute;
1235
+ left: 0;
1236
+ top: 100%;
1237
+ -webkit-transform: scale(0);
1238
+ transform: scale(0);
1239
+ display: inline-block;
1240
+ max-width: 100%;
1241
+ margin: 0.8125rem 1rem;
1242
+ background-color: white;
1243
+ border-radius: 4px;
1244
+ opacity: 0;
1245
+ box-shadow: 0 0 0 1px rgba(51, 54, 58, 0.05), 0 2px 7px 1px rgba(51, 54, 58, 0.16);
1246
+ -webkit-transition: -webkit-transform 0.35s cubic-bezier(0.27, 1.41, 0.53, 0.97), opacity 0.2s ease;
1247
+ transition: transform 0.35s cubic-bezier(0.27, 1.41, 0.53, 0.97), opacity 0.2s ease; }
1248
+
1249
+ .popover--is-active {
1250
+ -webkit-transform: scale(1);
1251
+ transform: scale(1);
1252
+ opacity: 1; }
1253
+
1254
+ .popover--is-positioned-above {
1255
+ top: auto;
1256
+ bottom: 100%; }
1257
+ .popover--is-positioned-above .popover__tooltip {
1258
+ top: 100%; }
1259
+ .popover--is-positioned-above .popover__tooltip:after {
1260
+ top: -0.3125rem; }
1261
+
1262
+ .popover__tooltip {
1263
+ position: absolute;
1264
+ left: 50%;
1265
+ top: -1.25rem;
1266
+ width: 1.25rem;
1267
+ height: 1.25rem;
1268
+ margin-left: -0.625rem;
1269
+ overflow: hidden; }
1270
+ .popover__tooltip:after {
1271
+ content: "";
1272
+ position: absolute;
1273
+ top: 0.9375rem;
1274
+ left: 50%;
1275
+ -webkit-transform: rotate(45deg);
1276
+ transform: rotate(45deg);
1277
+ margin-left: -0.3125rem;
1278
+ display: block;
1279
+ height: 0.625rem;
1280
+ width: 0.625rem;
1281
+ background-color: white;
1282
+ box-shadow: 0 0 0 1px rgba(51, 54, 58, 0.05), 0 2px 7px 1px rgba(51, 54, 58, 0.16); }
1283
+
1284
+ .popover__content-wrapper {
1285
+ display: -webkit-box;
1286
+ display: -webkit-flex;
1287
+ display: -ms-flexbox;
1288
+ display: flex;
1289
+ max-width: 25rem;
1290
+ max-height: 50rem;
1291
+ border-radius: 4px;
1292
+ overflow: hidden; }
1293
+
1294
+ .popover__content {
1295
+ -webkit-box-flex: 0;
1296
+ -webkit-flex: 0 0 auto;
1297
+ -ms-flex: 0 0 auto;
1298
+ flex: 0 0 auto;
1299
+ display: -webkit-inline-box;
1300
+ display: -webkit-inline-flex;
1301
+ display: -ms-inline-flexbox;
1302
+ display: inline-flex;
1303
+ -webkit-box-orient: vertical;
1304
+ -webkit-box-direction: normal;
1305
+ -webkit-flex-direction: column;
1306
+ -ms-flex-direction: column;
1307
+ flex-direction: column;
1308
+ max-height: 100%;
1309
+ min-width: 9.375rem; }
1310
+ .popover__content > *:first-child {
1311
+ margin-top: 0; }
1312
+ .popover__content > *:last-child {
1313
+ margin-bottom: 0; }
1314
+
1315
+ .popover__pane {
1316
+ -webkit-box-flex: 0;
1317
+ -webkit-flex: 0 1 auto;
1318
+ -ms-flex: 0 1 auto;
1319
+ flex: 0 1 auto;
1320
+ overflow: auto;
1321
+ -webkit-overflow-scrolling: touch;
1322
+ max-width: 100%; }
1323
+
1324
+ .range {
1325
+ width: 100%;
1326
+ margin: 0;
1327
+ -webkit-appearance: none;
1328
+ -moz-appearance: none;
1329
+ appearance: none;
1330
+ background-color: transparent; }
1331
+ .range:focus {
1332
+ outline: none; }
1333
+
1334
+ .range::-webkit-slider-runnable-track {
1335
+ width: 100%;
1336
+ height: 2.625rem;
1337
+ cursor: pointer;
1338
+ background-color: #d1d3d7;
1339
+ border-radius: 1.3125rem;
1340
+ padding: 0.2625rem; }
1341
+
1342
+ .range:focus::-webkit-slider-runnable-track {
1343
+ outline: none; }
1344
+
1345
+ .range::-moz-range-track {
1346
+ width: 100%;
1347
+ height: 2.625rem;
1348
+ cursor: pointer;
1349
+ background-color: #d1d3d7;
1350
+ border-radius: 1.3125rem;
1351
+ padding: 0.2625rem; }
1352
+
1353
+ .range::-ms-track {
1354
+ width: 100%;
1355
+ height: 2.625rem;
1356
+ cursor: pointer;
1357
+ background-color: #d1d3d7;
1358
+ border-radius: 1.3125rem;
1359
+ padding: 0.2625rem; }
1360
+
1361
+ .range::-webkit-slider-thumb {
1362
+ height: 2.1rem;
1363
+ width: 2.1rem;
1364
+ box-shadow: 1px 1px 3px rgba(30, 30, 31, 0.15);
1365
+ border-radius: 1.05rem;
1366
+ background: #f2f2f3;
1367
+ cursor: pointer;
1368
+ -webkit-appearance: none;
1369
+ appearance: none; }
1370
+
1371
+ .range::-moz-range-thumb {
1372
+ height: 2.1rem;
1373
+ width: 2.1rem;
1374
+ box-shadow: 1px 1px 3px rgba(30, 30, 31, 0.15);
1375
+ border-radius: 1.05rem;
1376
+ background: #f2f2f3;
1377
+ cursor: pointer;
1378
+ -webkit-appearance: none;
1379
+ -moz-appearance: none;
1380
+ appearance: none; }
1381
+
1382
+ .range::-ms-thumb {
1383
+ height: 2.1rem;
1384
+ width: 2.1rem;
1385
+ box-shadow: 1px 1px 3px rgba(30, 30, 31, 0.15);
1386
+ border-radius: 1.05rem;
1387
+ background: #f2f2f3;
1388
+ cursor: pointer;
1389
+ -webkit-appearance: none;
1390
+ appearance: none; }
1391
+
1392
+ .resizable {
1393
+ position: relative;
1394
+ margin: 0 auto;
1395
+ width: 100%;
1396
+ min-width: 19.25rem;
1397
+ border-radius: 4px;
1398
+ line-height: 0; }
1399
+ .resizable > .card {
1400
+ position: relative;
1401
+ padding-right: 1.25rem; }
1402
+ .resizable .iframe {
1403
+ width: 100%;
1404
+ min-height: 10rem;
1405
+ -webkit-transition: height 0.3s ease;
1406
+ transition: height 0.3s ease;
1407
+ overflow: hidden; }
1408
+
1409
+ .resizable--is-transitioning-width {
1410
+ -webkit-transition: width 0.3s ease;
1411
+ transition: width 0.3s ease; }
1412
+
1413
+ .resizable__handle {
1414
+ position: absolute;
1415
+ top: 0;
1416
+ right: 0;
1417
+ width: 1.25rem;
1418
+ height: 100%;
1419
+ cursor: col-resize;
1420
+ background: #d1d3d7;
1421
+ border-radius: 0 4px 4px 0; }
1422
+ .resizable__handle:hover,
1423
+ .resizable__handle:focus {
1424
+ outline: none; }
1425
+ .resizable__handle:after {
1426
+ content: "";
1427
+ position: absolute;
1428
+ top: 50%;
1429
+ left: 50%;
1430
+ display: block;
1431
+ height: 2rem;
1432
+ width: 0.4375rem;
1433
+ margin-top: -1rem;
1434
+ margin-left: -0.21875rem;
1435
+ border-right: 1px solid #9c9da5;
1436
+ border-left: 1px solid #9c9da5; }
1437
+
1438
+ .resizable__actions {
1439
+ display: -webkit-box;
1440
+ display: -webkit-flex;
1441
+ display: -ms-flexbox;
1442
+ display: flex;
1443
+ -webkit-box-pack: justify;
1444
+ -webkit-justify-content: space-between;
1445
+ -ms-flex-pack: justify;
1446
+ justify-content: space-between;
1447
+ -webkit-box-align: end;
1448
+ -webkit-align-items: flex-end;
1449
+ -ms-flex-align: end;
1450
+ align-items: flex-end;
1451
+ margin-bottom: 0.5rem; }
1452
+
1453
+ .resizable__width-indicator {
1454
+ color: #b1b1b1;
1455
+ font: 300 1rem/1 Consolas, monospace;
1456
+ opacity: 0.4;
1457
+ -webkit-transition: opacity 0.3s ease;
1458
+ transition: opacity 0.3s ease; }
1459
+
1460
+ .resizable__width-indicator--is-visible {
1461
+ opacity: 1; }
1462
+
1463
+ .resizable__size-buttons {
1464
+ display: -webkit-box;
1465
+ display: -webkit-flex;
1466
+ display: -ms-flexbox;
1467
+ display: flex; }
1468
+
1469
+ .resizable__size-button {
1470
+ position: relative;
1471
+ margin-left: 0.5rem;
1472
+ cursor: pointer;
1473
+ opacity: 0.5;
1474
+ -webkit-transition: opacity 0.3s ease;
1475
+ transition: opacity 0.3s ease; }
1476
+ .resizable__size-button > .icon {
1477
+ height: 1.8rem;
1478
+ width: 1.8rem;
1479
+ fill: #e3e4e6;
1480
+ stroke: #e3e4e6;
1481
+ -webkit-transition: fill 0.3s ease;
1482
+ transition: fill 0.3s ease; }
1483
+ .resizable__size-button:hover,
1484
+ .resizable__size-button:focus,
1485
+ .resizable__size-button:active,
1486
+ .resizable__size-button.resizable__size-button--is-active {
1487
+ outline: none; }
1488
+ .resizable__size-button:hover,
1489
+ .resizable__size-button:focus {
1490
+ opacity: 0.8; }
1491
+ .resizable__size-button.resizable__size-button--is-active,
1492
+ .resizable__size-button:active {
1493
+ opacity: 1; }
1494
+ .resizable__size-button.resizable__size-button--is-active > .icon,
1495
+ .resizable__size-button:active > .icon {
1496
+ fill: #4196df;
1497
+ stroke: #4196df; }
1498
+
1499
+ .resizable__size-button--is-hidden {
1500
+ display: none; }
1501
+
1502
+ .scroll-container {
1503
+ overflow: hidden; }
1504
+
1505
+ .section {
1506
+ margin: 2rem 0;
1507
+ padding: 1rem 0; }
1508
+ .section > *:first-child,
1509
+ .section > *:first-child > *:first-child {
1510
+ margin-top: 0; }
1511
+ .section > *:last-child,
1512
+ .section > *:last-child > *:last-child {
1513
+ margin-bottom: 0; }
1514
+
1515
+ .section--small {
1516
+ border: none;
1517
+ padding: 0;
1518
+ margin: 1rem 0; }
1519
+
1520
+ .section--subdued {
1521
+ background: #f1f1f1;
1522
+ overflow: hidden; }
1523
+ .section--subdued.section--small {
1524
+ padding: 1rem 0;
1525
+ margin: 0; }
1526
+
1527
+ .section__container > .section:first-child {
1528
+ margin-top: 2rem; }
1529
+
1530
+ .section__container > .section:last-child {
1531
+ margin-bottom: 2rem; }
1532
+
1533
+ .section__container > .section--small:first-child {
1534
+ margin-top: 1rem; }
1535
+
1536
+ .section__container > .section--small:last-child {
1537
+ margin-bottom: 1rem; }
1538
+
1539
+ .select {
1540
+ position: relative;
1541
+ display: inline-block;
1542
+ border-radius: 4px;
1543
+ background-color: #e3e4e6; }
1544
+ .select:after {
1545
+ content: "";
1546
+ position: absolute;
1547
+ right: 0.75rem;
1548
+ top: 50%;
1549
+ -webkit-transform: rotate(45deg);
1550
+ transform: rotate(45deg);
1551
+ display: block;
1552
+ height: 0.63281rem;
1553
+ width: 0.63281rem;
1554
+ margin-top: -0.47461rem;
1555
+ border: solid rgba(156, 157, 165, 0.5);
1556
+ border-width: 0 2px 2px 0;
1557
+ pointer-events: none; }
1558
+ .select + .docks-button {
1559
+ margin-left: 0.5rem; }
1560
+
1561
+ .select--is-focused {
1562
+ border-color: #4196df; }
1563
+
1564
+ .select--code > .select__input {
1565
+ font-family: Consolas, monospace; }
1566
+
1567
+ .select__input {
1568
+ -webkit-appearance: none;
1569
+ -moz-appearance: none;
1570
+ box-sizing: border-box;
1571
+ display: block;
1572
+ width: 100%;
1573
+ max-width: none;
1574
+ height: auto;
1575
+ padding: 0 2.13281rem 0 0.75rem;
1576
+ background: transparent;
1577
+ border: none;
1578
+ font-size: 1.0125rem;
1579
+ line-height: 2.125rem;
1580
+ font-family: inherit;
1581
+ color: #9c9da5; }
1582
+ .select__input:focus {
1583
+ outline: none;
1584
+ border: none; }
1585
+ .select__input > option {
1586
+ color: #33363a; }
1587
+
1588
+ _:-ms-input-placeholder, :root .select__input::-ms-expand {
1589
+ display: none; }
1590
+
1591
+ _:-ms-input-placeholder, :root .select__input:focus::-ms-value {
1592
+ background: transparent; }
1593
+
1594
+ @supports (-moz-appearance: meterbar) and (background-blend-mode: difference, normal) {
1595
+ _::-moz-progress-bar,
1596
+ body:last-child .select__input__wrapper {
1597
+ overflow: hidden; }
1598
+ _::-moz-progress-bar,
1599
+ body:last-child .select__input {
1600
+ width: calc(100% + 30px); } }
1601
+
1602
+ .select__input:-moz-focusring {
1603
+ color: transparent;
1604
+ text-shadow: 0 0 0 black; }
1605
+
1606
+ .table {
1607
+ width: 100%;
1608
+ min-width: 31.25rem;
1609
+ border-collapse: separate;
1610
+ border-spacing: 0; }
1611
+
1612
+ .table__container {
1613
+ margin: 1rem auto; }
1614
+
1615
+ .table__container--is-overflowing .table__cell:first-child {
1616
+ position: absolute;
1617
+ z-index: 20;
1618
+ left: 0;
1619
+ height: 100%;
1620
+ box-shadow: 3px 0 4px -1px rgba(30, 30, 31, 0);
1621
+ -webkit-transition: box-shadow 0.2s ease;
1622
+ transition: box-shadow 0.2s ease; }
1623
+
1624
+ .table__container--is-overflowing .table__actions {
1625
+ -webkit-transform: translateY(0);
1626
+ transform: translateY(0);
1627
+ max-height: 3rem;
1628
+ padding-bottom: 0.5rem; }
1629
+
1630
+ .table__scroller {
1631
+ max-width: 100%;
1632
+ overflow-x: auto;
1633
+ overflow-y: hidden;
1634
+ -webkit-overflow-scrolling: touch; }
1635
+
1636
+ .table__scroller--is-scrolled .table__cell:first-child {
1637
+ box-shadow: 3px 0 4px -1px rgba(30, 30, 31, 0.1); }
1638
+
1639
+ .table__backdrop {
1640
+ position: relative;
1641
+ z-index: 30;
1642
+ max-width: 100%;
1643
+ clear: both;
1644
+ overflow: hidden;
1645
+ border: 1px solid #f1f1f1;
1646
+ border-radius: 8px; }
1647
+
1648
+ .table__actions {
1649
+ -webkit-transform: translateY(140%);
1650
+ transform: translateY(140%);
1651
+ max-height: 0;
1652
+ float: right;
1653
+ -webkit-transition: -webkit-transform 0.3s cubic-bezier(0.32, 1.44, 0.46, 0.99), max-height 0.3s ease, padding-bottom 0.3s ease;
1654
+ transition: transform 0.3s cubic-bezier(0.32, 1.44, 0.46, 0.99), max-height 0.3s ease, padding-bottom 0.3s ease; }
1655
+
1656
+ .table__header {
1657
+ font-weight: 400;
1658
+ padding: 0;
1659
+ text-align: left; }
1660
+
1661
+ .table__body > .table__row:nth-child(odd) > .table__cell {
1662
+ background-color: #f8f8f8; }
1663
+
1664
+ .table__row {
1665
+ overflow: hidden; }
1666
+
1667
+ .table__cell {
1668
+ position: relative;
1669
+ z-index: 10;
1670
+ vertical-align: top;
1671
+ padding: 0.5rem;
1672
+ background-color: white; }
1673
+
1674
+ .table__cell--centered {
1675
+ text-align: center; }
1676
+
1677
+ .tablist {
1678
+ margin: 0;
1679
+ padding: 0;
1680
+ display: -webkit-box;
1681
+ display: -webkit-flex;
1682
+ display: -ms-flexbox;
1683
+ display: flex;
1684
+ -webkit-box-pack: center;
1685
+ -webkit-justify-content: center;
1686
+ -ms-flex-pack: center;
1687
+ justify-content: center;
1688
+ padding: 0.5rem;
1689
+ margin-right: -0.5rem;
1690
+ list-style: none; }
1691
+
1692
+ .tablist--large {
1693
+ margin: 2rem 0; }
1694
+ .tablist--large > .tablist__tab {
1695
+ font-size: 1.5rem;
1696
+ line-height: 1;
1697
+ padding: 1rem 2.5rem 1.2rem;
1698
+ border: none !important;
1699
+ opacity: 1 !important; }
1700
+ .tablist--large > .tablist__tab--is-active {
1701
+ background-color: #f2f2f3; }
1702
+
1703
+ .tablist__tab {
1704
+ display: inline-block;
1705
+ padding: 0 0.75rem;
1706
+ opacity: 0.3;
1707
+ overflow: hidden;
1708
+ border: 1px solid transparent;
1709
+ border-radius: 4px;
1710
+ -webkit-transition: opacity 0.3s ease, border-color 0.3s ease;
1711
+ transition: opacity 0.3s ease, border-color 0.3s ease;
1712
+ font-size: 1.125rem;
1713
+ line-height: 2.125rem;
1714
+ color: #9c9da5;
1715
+ text-align: center;
1716
+ text-decoration: none;
1717
+ white-space: nowrap;
1718
+ text-overflow: ellipsis; }
1719
+ .tablist__tab:focus,
1720
+ .tablist__tab:hover {
1721
+ outline: none;
1722
+ opacity: 0.5; }
1723
+ .tablist__tab > .icon {
1724
+ height: 2rem;
1725
+ width: 2rem;
1726
+ fill: #d1d3d7;
1727
+ stroke: #d1d3d7;
1728
+ stroke-width: 3px; }
1729
+
1730
+ .tablist__tab--is-active, .tablist__tab--is-active:hover, .tablist__tab--is-active:focus {
1731
+ border-color: #9c9da5;
1732
+ opacity: 1; }
1733
+
1734
+ .tablist__tab__text {
1735
+ display: block; }
1736
+
1737
+ .tablist__panel {
1738
+ display: none; }
1739
+
1740
+ .tablist__panel--is-active {
1741
+ display: block; }
1742
+
1743
+ .vertical-spacer {
1744
+ margin: 0.5rem 0; }
1745
+
1746
+ .vertical-stack {
1747
+ display: -webkit-box;
1748
+ display: -webkit-flex;
1749
+ display: -ms-flexbox;
1750
+ display: flex;
1751
+ -webkit-box-orient: vertical;
1752
+ -webkit-box-direction: normal;
1753
+ -webkit-flex-direction: column;
1754
+ -ms-flex-direction: column;
1755
+ flex-direction: column;
1756
+ -webkit-align-self: stretch;
1757
+ -ms-flex-item-align: stretch;
1758
+ align-self: stretch;
1759
+ width: 100%; }
1760
+
1761
+ .vertical-stack__item {
1762
+ -webkit-box-flex: 1;
1763
+ -webkit-flex: 1 1 0px;
1764
+ -ms-flex: 1 1 0px;
1765
+ flex: 1 1 0px;
1766
+ max-width: 100%;
1767
+ overflow-x: hidden;
1768
+ overflow-y: auto;
1769
+ -webkit-overflow-scrolling: touch; }
1770
+
1771
+ .vertical-stack__item--fixed {
1772
+ -webkit-box-flex: 0;
1773
+ -webkit-flex: 0 0 auto;
1774
+ -ms-flex: 0 0 auto;
1775
+ flex: 0 0 auto;
1776
+ overflow: visible; }
1777
+
1778
+ body {
1779
+ position: relative; }
1780
+ body.x-ray__helpers--x-ray-is-active {
1781
+ overflow: hidden; }
1782
+
1783
+ .x-ray {
1784
+ background: white;
1785
+ position: absolute;
1786
+ top: 0;
1787
+ bottom: 0;
1788
+ left: 0;
1789
+ right: 0;
1790
+ z-index: -1;
1791
+ overflow-x: hidden;
1792
+ overflow-y: auto;
1793
+ opacity: 0;
1794
+ -webkit-transition: opacity 0.3s ease;
1795
+ transition: opacity 0.3s ease;
1796
+ min-height: 100%; }
1797
+ .x-ray .page-header {
1798
+ -webkit-box-flex: 0;
1799
+ -webkit-flex: 0 0 auto;
1800
+ -ms-flex: 0 0 auto;
1801
+ flex: 0 0 auto; }
1802
+
1803
+ .x-ray--is-active {
1804
+ opacity: 1;
1805
+ z-index: 1200; }
1806
+
1807
+ .x-ray__content {
1808
+ padding-bottom: 3rem; }
1809
+
1810
+ .x-ray__list {
1811
+ padding: 1rem;
1812
+ background-color: #f2f2f3; }
1813
+
1814
+ .x-ray__closer {
1815
+ background: transparent;
1816
+ border: none;
1817
+ padding: 0;
1818
+ -webkit-appearance: none;
1819
+ -moz-appearance: none;
1820
+ appearance: none; }
1821
+
1822
+ .x-ray__diagram {
1823
+ padding: 1rem 0 0;
1824
+ background: #e3e4e6; }
1825
+
1826
+ .x-ray__details {
1827
+ display: none; }
1828
+
1829
+ .x-ray__details--is-visible {
1830
+ display: block; }
1831
+
1832
+ .x-ray__details__tagname {
1833
+ display: inline-block;
1834
+ font-size: 0.75em;
1835
+ background-color: #f2f2f3;
1836
+ padding: 0.3em 0.4em 0.2em;
1837
+ border-radius: 4px;
1838
+ line-height: 1;
1839
+ color: #9c9da5;
1840
+ margin-right: 0.25rem; }
1841
+
1842
+ .x-ray__details__description {
1843
+ margin-bottom: 2rem; }
1844
+
1845
+ .sidebar {
1846
+ position: absolute;
1847
+ left: 0;
1848
+ top: 0;
1849
+ -webkit-transform: translate3d(-100%, 0, 0);
1850
+ transform: translate3d(-100%, 0, 0);
1851
+ -webkit-transition: -webkit-transform 0.2s ease;
1852
+ transition: transform 0.2s ease;
1853
+ max-width: 15rem;
1854
+ display: -webkit-box;
1855
+ display: -webkit-flex;
1856
+ display: -ms-flexbox;
1857
+ display: flex;
1858
+ height: 100vh;
1859
+ background-color: white;
1860
+ box-shadow: 0 0 4px rgba(30, 30, 31, 0.3); }
1861
+ @media screen and (min-width: 40.0625rem) {
1862
+ .sidebar {
1863
+ position: static;
1864
+ -webkit-transform: translate3d(0, 0, 0);
1865
+ transform: translate3d(0, 0, 0); } }
1866
+
1867
+ .sidebar--is-active {
1868
+ -webkit-transform: translate3d(0, 0, 0);
1869
+ transform: translate3d(0, 0, 0); }
1870
+
1871
+ .sidebar__toggler {
1872
+ background: transparent;
1873
+ padding: 0;
1874
+ margin: 0;
1875
+ -webkit-appearance: none;
1876
+ -moz-appearance: none;
1877
+ appearance: none;
1878
+ border: none; }
1879
+ .sidebar__toggler:focus {
1880
+ outline: none; }
1881
+
1882
+ /*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["utilities/media/media.scss","utilities/foundation/a11y.scss","utilities/foundation/base.scss","utilities/colors/colors.scss","utilities/foundation/icon.scss","utilities/functions/functions.scss","utilities/foundation/layout.scss","utilities/defaults/defaults.scss","utilities/foundation/page.scss","utilities/z_indexes/z-indexes.scss","utilities/foundation/type.scss","utilities/font_sizes/font-sizes.scss","components/avatar/avatar.scss","components/badge/badge.scss","components/button/button.scss","components/card/card.scss","components/code_block/code-block.scss","components/demo/demo.scss","components/exploded/exploded.scss","components/field/field.scss","components/header/header.scss","components/inline_group/inline-group.scss","components/list/list.scss","utilities/mixins/mixins.scss","components/modal/modal.scss","components/notice/notice.scss","components/popover/popover.scss","components/range/range.scss","components/resizable/resizable.scss","components/scroll_container/scroll-container.scss","components/section/section.scss","components/select/select.scss","components/table/table.scss","components/tablist/tablist.scss","components/vertical_spacer/vertical-spacer.scss","components/vertical_stack/vertical-stack.scss","components/xray/xray.scss","structures/sidebar/sidebar.scss"],"names":[],"mappings":"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","file":"pattern-library.css","sourcesContent":["//        ___          ___        _____                  ___\n//       /__/\\        /  /\\      /  /::\\     ___        /  /\\\n//      |  |::\\      /  /:/_    /  /:/\\:\\   /  /\\      /  /::\\\n//      |  |:|:\\    /  /:/ /\\  /  /:/  \\:\\ /  /:/     /  /:/\\:\\\n//    __|__|:|\\:\\  /  /:/ /:/_/__/:/ \\__\\:/__/::\\    /  /:/~/::\\\n//   /__/::::| \\:\\/__/:/ /:/ /\\  \\:\\ /  /:|__\\/\\:\\__/__/:/ /:/\\:\\\n//   \\  \\:\\~~\\__\\/\\  \\:\\/:/ /:/\\  \\:\\  /:/   \\  \\:\\/\\  \\:\\/:/__\\/\n//    \\  \\:\\       \\  \\::/ /:/  \\  \\:\\/:/     \\__\\::/\\  \\::/\n//     \\  \\:\\       \\  \\:\\/:/    \\  \\::/      /__/:/  \\  \\:\\\n//      \\  \\:\\       \\  \\::/      \\__\\/       \\__\\/    \\  \\:\\\n//       \\__\\/        \\__\\/                             \\__\\/\n\n\n\n$BREAKPOINTS: (\n  small: 25rem,\n  medium: 37.5rem,\n  large: 50rem\n);\n\n$BREAKPOINT_INCREMENTS: (\n  rem: 0.0625rem,\n  em: 0.0625em,\n  px: 1px,\n  vw: 1vw\n);\n\n\n\n@function breakpoint-value-for($breakpoint) {\n  @return map-get($BREAKPOINTS, $breakpoint);\n}\n\n@function breakpoint-clean-value($point) {\n  @if type-of($point) == number {\n    @return $point;\n  }\n\n  @return breakpoint-value-for($point);\n}\n\n@function breakpoint-increment-for($value) {\n  @return map-get($BREAKPOINT_INCREMENTS, unit($value));\n}\n\n@function breakpoint-default-inclusivity($value, $default) {\n  $inclusivity: null;\n  @if length($value) > 1 { $inclusivity: nth($value, 2); }\n\n  @if $inclusivity {\n    @return $inclusivity == inclusive;\n  } @else {\n    @return $default;\n  }\n}\n\n@function breakpoint-adjusted-for-inclusivity($value, $min-or-max, $inclusive: false) {\n  $value: breakpoint-clean-value($value);\n\n  @if not $inclusive {\n    @if $min-or-max == min {\n      $value: $value + breakpoint-increment-for($value);\n    } @else {\n      $value: $value - breakpoint-increment-for($value);\n    }\n  }\n\n  @return \"(#{$min-or-max}-width: #{$value})\";\n}\n\n@function breakpoint-retinize-media-query($media-query) {\n  @return \"#{$media-query} and (-webkit-min-device-pixel-ratio: 2), #{$media-query} and (min-resolution: 192dpi)\";\n}\n\n\n\n\n\n@mixin breakpoint-after($point) {\n  @media screen and #{breakpoint-adjusted-for-inclusivity($point, min)} {\n    @content;\n  }\n}\n\n@mixin after($point) { @include breakpoint-after($point) { @content; } }\n\n@mixin breakpoint-before($point) {\n  @media screen and #{breakpoint-adjusted-for-inclusivity($point, max)} {\n    @content;\n  }\n}\n\n@mixin before($point) { @include breakpoint-before($point) { @content; } }\n\n@mixin breakpoint($after: null, $before: null, $from: null, $to: null, $until: null, $retina: false) {\n  $min-width: null;\n  $max-width: null;\n  $min-inclusive: null;\n  $max-inclusive: null;\n\n  // $after defaults to exclusive\n  @if $after {\n    $min-width: nth($after, 1);\n    $min-inclusive: breakpoint-default-inclusivity($after, false);\n  }\n\n  // $from defaults to inclusive\n  @if $from {\n    $min-width: nth($from, 1);\n    $min-inclusive: breakpoint-default-inclusivity($from, true);\n  }\n\n  // $before defaults to exclusive\n  @if $before {\n    $max-width: nth($before, 1);\n    $max-inclusive: breakpoint-default-inclusivity($before, false);\n  }\n\n  // $to defaults to inclusive\n  @if $to {\n    $max-width: nth($to, 1);\n    $max-inclusive: breakpoint-default-inclusivity($to, true);\n  }\n\n  // $until defaults to exclusive\n  @if $until {\n    $max-width: nth($until, 1);\n    $max-inclusive: breakpoint-default-inclusivity($until, false);\n  }\n\n  @if $max-width { $max-width: breakpoint-adjusted-for-inclusivity($max-width, max, $max-inclusive); }\n  @if $min-width { $min-width: breakpoint-adjusted-for-inclusivity($min-width, min, $min-inclusive); }\n\n  $media-query: \"screen\";\n  @if $min-width { $media-query: $media-query + \" and #{$min-width}\"; }\n  @if $max-width { $media-query: $media-query + \" and #{$max-width}\"; }\n  @if $retina { $media-query: breakpoint-retinize-media-query($media-query); }\n\n  @media #{$media-query} {\n    @content;\n  }\n}\n\n\n\n@mixin print() {\n  @media print { @content; }\n}\n\n\n\n@mixin retina() {\n  @media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) { @content; }\n}\n\n\n\n@each $breakpoint, $width in $BREAKPOINTS {\n  .media__helpers--hide-before-#{$breakpoint} {\n    @include before($width) { display: none; }\n  }\n\n  .media__helpers--hide-after-#{$breakpoint} {\n    @include after($width) { display: none; }\n  }\n\n  .media__helpers--show-after-#{$breakpoint} {\n    display: none;\n\n    @include after($width) { display: block; }\n  }\n}\n",".helper--visually-hidden {\n  border: 0;\n  clip: rect(0 0 0 0);\n  height: 1px;\n  margin: -1px;\n  overflow: hidden;\n  padding: 0;\n  position: absolute;\n  width: 1px;\n}\n","//                    ___          ___          ___\n//       _____       /  /\\        /  /\\        /  /\\\n//      /  /::\\     /  /::\\      /  /:/_      /  /:/_\n//     /  /:/\\:\\   /  /:/\\:\\    /  /:/ /\\    /  /:/ /\\\n//    /  /:/~/::\\ /  /:/~/::\\  /  /:/ /::\\  /  /:/ /:/_\n//   /__/:/ /:/\\:/__/:/ /:/\\:\\/__/:/ /:/\\:\\/__/:/ /:/ /\\\n//   \\  \\:\\/:/~/:|  \\:\\/:/__\\/\\  \\:\\/:/~/:/\\  \\:\\/:/ /:/\n//    \\  \\::/ /:/ \\  \\::/      \\  \\::/ /:/  \\  \\::/ /:/\n//     \\  \\:\\/:/   \\  \\:\\       \\__\\/ /:/    \\  \\:\\/:/\n//      \\  \\::/     \\  \\:\\        /__/:/      \\  \\::/\n//       \\__\\/       \\__\\/        \\__\\/        \\__\\/\n\nhtml { box-sizing: border-box; }\n\n*,\n*:before,\n*:after { box-sizing: inherit; }\n\nbody {\n  margin: 0;\n  padding: 0;\n  background-color: color(white);\n  min-height: 100vh;\n}\n\ntable {\n  border-collapse: collapse;\n  border-spacing: 0;\n}\n","//*\n// @pattern Colors\n// @group Helper\n//\n// This stylesheet provides a centralized location to manage colors. Colors\n// should **never** be declared in CSS directly; instead, add the color to the\n// `$COLORS` map (following the \"color-modifier\" naming convention) and\n// then include it as required using the `color()` function described below.\n//\n// The color component also provides some utility methods to darken (`shade()`)\n// and lighten (`tint()`) colors — use these only for one-offs that are deemed\n// absolutely necessary. For variations that are used in multiple places, add\n// a new variation to the `$COLORS` map.\n\n\n$UI_COLORS: (\n  white: ( base: rgb(255, 255, 255) ),\n  black: ( base: rgb(30, 30, 31) ),\n\n  gray: (\n    light: rgb(242, 242, 243),\n    base: rgb(227, 228, 230),\n    dark: rgb(209, 211, 215),\n    darker: rgb(156, 157, 165),\n    darkest: rgb(110, 111, 122)\n  ),\n\n  yellow: (\n    base: rgb(253, 247, 175),\n    dark: rgb(133, 126, 50)\n  ),\n\n  blue: (\n    base: rgb(183, 214, 246),\n    dark: rgb(140, 194, 251),\n    darker: rgb(98, 121, 144)\n  )\n);\n\n@function ui-color($color, $shade: base) {\n  @return map-get(map-get($UI_COLORS, $color), $shade);\n}\n\n\n$COLORS: (\n  white: rgb(255, 255, 255),\n  black: rgb(30, 30, 31),\n\n  blue-light: rgb(135, 194, 235),\n  blue: rgb(65, 150, 223),\n  blue-dark: rgb(40, 134, 214),\n  blue-darker: rgb(26, 92, 171),\n\n  yellow: rgb(252, 246, 161),\n  yellow-dark: rgb(139, 134, 72),\n\n  slate-light: rgb(55, 57, 60),\n  slate: rgb(51, 54, 58),\n\n  gray-lighter: rgb(248, 248, 248),\n  gray-light: rgb(241, 241, 241),\n  gray: rgb(207, 207, 207),\n  gray-dark: rgb(177, 177, 177),\n  gray-darker: rgb(74, 74, 74)\n);\n\n\n//*\n// Returns the color associated with the passed identifier.\n//\n// @author Chris Sauve (github: lemonmade)\n//\n// @param {String} $color - The color (or other identifier that\n//                          maps to a color) to search for in the\n//                          global `$COLORS` map.\n//\n// @example scss\n// .foo {\n//   background: color(red); // => background: rgb(245, 79, 84);\n// }\n//\n// @returns {Color}\n\n@function color($color) {\n  @return map-get($COLORS, $color);\n}\n\n\n//*\n// Slightly lighten a color.\n//\n// @param {Color} $color - The color to tint.\n// @param {Number} $percentage - Percentage of `$color` in the returned color.\n//\n// @returns {Color}\n\n@function tint($color, $percentage) {\n  @return mix($color, color(white), $percentage);\n}\n\n\n//*\n// Slightly darken a color.\n//\n// @param {Color} $color - The color to shade.\n// @param {Number} $percentage - Percentage of `$color` in the returned color.\n//\n// @returns {Color}\n\n@function shade($color, $percentage) {\n  @return mix($color, color(black), $percentage);\n}\n","@mixin icon--recolor($color, $variant: base) {\n  fill: ui-color($color, $variant);\n  stroke: ui-color($color, $variant);\n}\n\n\n.icon {\n  display: inline-block;\n  stroke-width: 2;\n}\n\n$icon--size-medium: rem(24);\n$icon--size-large: rem(28);\n\n.icon--medium {\n  height: $icon--size-medium;\n  width: $icon--size-medium;\n}\n\n.icon--large {\n  height: $icon--size-large;\n  width: $icon--size-large;\n}\n\n\n$icon-action--size: 1.65rem;\n\n.icon--action {\n  height: $icon-action--size;\n  width: $icon-action--size;\n}\n\n$icon-hamburger--width: 2rem;\n$icon-hamburger--slice-height: 4px;\n\n.icon--hamburger {\n  height: $icon-action--size;\n  width: $icon-hamburger--width;\n  position: relative;\n  cursor: pointer;\n  opacity: 0.6;\n  top: 0.2em;\n  transition: opacity 0.2s ease;\n\n  &:hover {\n    opacity: 1;\n  }\n\n  &:before,\n  &:after {\n    content: \"\";\n    display: block;\n    position: absolute;\n    height: $icon-hamburger--slice-height;\n    width: 100%;\n    border-radius: ($icon-hamburger--slice-height / 2);\n    background: ui-color(gray, darkest);\n  }\n\n  &:before { top: 0; }\n  &:after { bottom: 0; }\n}\n\n.icon--hamburger__slice {\n  height: $icon-hamburger--slice-height;\n  width: 100%;\n  border-radius: ($icon-hamburger--slice-height / 2);\n  background: ui-color(gray, darkest);\n  position: absolute;\n  top: 50%; left: 0;\n  margin-top: (-0.5 * $icon-hamburger--slice-height);\n}\n\n.icon--gray-darker {\n  @include icon--recolor(gray, darker);\n}\n\n.icon--close {\n  position: relative;\n  opacity: 0.6;\n  transition: opacity 0.2s ease;\n  cursor: pointer;\n\n  &:hover {\n    opacity: 1;\n  }\n\n  &:before,\n  &:after {\n    content: \"\";\n    display: block;\n    position: absolute;\n    height: $icon-hamburger--slice-height;\n    width: 140%;\n    border-radius: ($icon-hamburger--slice-height / 2);\n    background: ui-color(gray, darkest);\n    top: 50%;\n    left: 50%;\n    margin-left: -70%;\n    margin-top: ($icon-hamburger--slice-height / -2);\n  }\n\n  &:before { transform: rotate(45deg); }\n  &:after { transform: rotate(-45deg); }\n}\n\n.icon--disclosure {\n  height: half(default(spacing));\n  width: half(default(spacing));\n  transform: rotate(45deg) translateY(-50%);\n  border-right: 2px solid ui-color(gray, darkest);\n  border-bottom: 2px solid ui-color(gray, darkest);\n  margin-left: quarter(default(spacing));\n}\n","//        ___      ___          ___          ___          ___\n//       /  /\\    /__/\\        /__/\\        /  /\\        /  /\\\n//      /  /:/_   \\  \\:\\       \\  \\:\\      /  /:/       /  /:/_\n//     /  /:/ /\\   \\  \\:\\       \\  \\:\\    /  /:/       /  /:/ /\\\n//    /  /:/ /:/__  \\  \\:\\  _____\\__\\:\\  /  /:/  ___  /  /:/ /::\\\n//   /__/:/ /:/__/\\  \\__\\:\\/__/::::::::\\/__/:/  /  /\\/__/:/ /:/\\:\\\n//   \\  \\:\\/:/\\  \\:\\ /  /:/\\  \\:\\~~\\~~\\/\\  \\:\\ /  /:/\\  \\:\\/:/~/:/\n//    \\  \\::/  \\  \\:\\  /:/  \\  \\:\\  ~~~  \\  \\:\\  /:/  \\  \\::/ /:/\n//     \\  \\:\\   \\  \\:\\/:/    \\  \\:\\       \\  \\:\\/:/    \\__\\/ /:/\n//      \\  \\:\\   \\  \\::/      \\  \\:\\       \\  \\::/       /__/:/\n//       \\__\\/    \\__\\/        \\__\\/        \\__\\/        \\__\\/\n//\n//*\n// @pattern Functions\n// @group Helper\n// @author Chris Sauve (github: lemonmade)\n//\n// Functions simply return a value: they don't actually add a any styles to\n// the compiled stylesheet. Use these to provide solutions to common calculations\n// or Sass operations.\n\n\n\n//*\n// Removes the units from a number.\n//\n// @deprecated 2.1.0\n// @private\n//\n// @param {Number} $value - The number (usually a measurement) that you would\n//                          like to remove units from.\n// @returns {Number}\n//\n// @example\n// $foo: strip-units(4rem); // => 4\n// $bar: strip-units(30%); // => 30\n\n@function strip-units($value) {\n  @return ($value / ($value*0 + 1));\n}\n\n//*\n// Converts the passed value (assumed to be in pixels) to the corresponding `rem`\n// value. This conversion assumes a base font size of `16px`.\n//\n// @param {Number} $value - The pixel value to convert.\n// @returns {Number}\n\n@function rem($value) {\n  @return (strip-units($value) / 16 * 1rem);\n}\n\n//*\n// Halves a given measurement.\n//\n// @param {Number} $measurement - The measurement to halve.\n// @returns {Number}\n// @alias half\n//\n// @example\n// $foo: halve(4rem); // => 2rem\n// $bar: half(36); // => 18\n\n@function halve($measurement) {\n  @return ($measurement / 2);\n}\n\n@function half($measurement) {\n  @return halve($measurement);\n}\n\n//*\n// Quarters a given measurement.\n//\n// @param {Number} $measurement - The measurement to quarter.\n// @returns {Number}\n//\n// @example\n// $foo: quarter(4rem); // => 1rem\n\n@function quarter($measurement) {\n  @return ($measurement / 4);\n}\n\n//*\n// Doubles a given measurement.\n//\n// @param {Number} $measurement - The measurement to double.\n// @returns {Number}\n//\n// @example\n// $foo: double(4rem); // => 8rem\n\n@function double($measurement) {\n  @return ($measurement * 2);\n}\n\n//*\n// Negates a given measurement.\n//\n// @param {Number} $measurement - The measurement to negate.\n// @returns {Number}\n//\n// @example\n// $foo: negative(4rem); // => -4rem\n// $bar: negative(-4rem); // => 4rem\n\n@function negative($measurement) {\n  @return ($measurement * -1);\n}\n\n//*\n// Multiples a given measurement by the provided factor. Use this in those\n// (rare) instances where you need a factor that is not `2`, `0.5`, `0.25`, or\n// `-1` (in which case, use the relevant multiplication function directly).\n//\n// @param {Number} $measurement - The measurement to multiple.\n// @param {Number} $factor      - The multiplication factor.\n// @returns {Number}\n//\n// @example\n// $foo: multiply(4rem, 3); // => 12rem\n// $bar: multiply(4rem, 2); // => 8rem BUT don't do this — use double(4rem) instead\n\n@function multiply($measurement, $factor) {\n  @return ($measurement * $factor);\n}\n","//                    ___                 ___          ___\n//                   /  /\\        ___    /  /\\        /__/\\        ___\n//                  /  /::\\      /__/|  /  /::\\       \\  \\:\\      /  /\\\n//    ___     ___  /  /:/\\:\\    |  |:| /  /:/\\:\\       \\  \\:\\    /  /:/\n//   /__/\\   /  /\\/  /:/~/::\\   |  |:|/  /:/  \\:\\  ___  \\  \\:\\  /  /:/\n//   \\  \\:\\ /  /:/__/:/ /:/\\:\\__|__|:/__/:/ \\__\\:\\/__/\\  \\__\\:\\/  /::\\\n//    \\  \\:\\  /:/\\  \\:\\/:/__\\/__/::::\\  \\:\\ /  /:/\\  \\:\\ /  /:/__/:/\\:\\\n//     \\  \\:\\/:/  \\  \\::/       ~\\~~\\:\\  \\:\\  /:/  \\  \\:\\  /:/\\__\\/  \\:\\\n//      \\  \\::/    \\  \\:\\         \\  \\:\\  \\:\\/:/    \\  \\:\\/:/      \\  \\:\\\n//       \\__\\/      \\  \\:\\         \\__\\/\\  \\::/      \\  \\::/        \\__\\/\n//                   \\__\\/               \\__\\/        \\__\\/\n\n.grid {\n  display: flex;\n}\n\n.grid--vertically-centered {\n  align-items: center;\n}\n\n.grid--align-right {\n  justify-content: flex-end;\n}\n\n.grid--outside-spacing {\n  margin: default(spacing) 0;\n  padding: 0 default(spacing);\n}\n\n.grid--space-between {\n  justify-content: space-between;\n\n  > .grid__item {\n    flex: 0 1 auto;\n  }\n}\n\n.grid__item {\n  padding: 0 (default(spacing) / 2);\n  flex: 1 1 0%;\n  display: flex;\n  align-items: center;\n\n  &:first-child { padding-left: 0; }\n  &:last-child { padding-right: 0; }\n}\n\n.grid__item--no-flex {\n  flex: 0 0 auto;\n}\n\n.grid__item--half {\n  flex: 0 0 50%;\n}\n\n\n\n\n\n.content {\n  padding: 0 default(spacing);\n  margin: default(spacing) 0;\n}\n\n.content--extra-vertical-spacing {\n  margin: multiply(default(spacing), 3) 0;\n}\n","//    ___  ___ ___ _  _   _ _  _____ ___\n//   |   \\| __| __/_\\| | | | ||_   _/ __|\n//   | |) | _|| _/ _ \\ |_| | |__| | \\__ \\\n//   |___/|___|_/_/ \\_\\___/|____|_| |___/\n//\n// =========================================================================================\n// =========================================================================================\n//\n// This stylesheet decalres default values for common visual elements. Use this\n// map in place of declaring variables, which could be slightly harder to remember\n// the name of and present more of a risk of naming conflicts. To add a default,\n// add a descriptive key name to the map that references a map that has an `ios`\n// and an `android` key. Then, retrieve the value using `default($property, $platform)`,\n// where platform defaults to iOS. If the property you are adding is also a valid\n// CSS property (i.e., default borders or border radii), you can directly include\n// that declaration in CSS using the mixin version of `default()`.\n\n\n\n$DEFAULTS: (\n  spacing: 1rem,\n  border-radius: 4px,\n  line-height: 1.3,\n  control-size: rem(34),\n  control-size--large: rem(42),\n  control-padding: 0.75rem,\n  box-shadow: 0 0 4px rgba(color(black), 0.3)\n);\n\n\n\n@function default($property) {\n  @return map-get($DEFAULTS, $property);\n}\n\n@mixin default($property) {\n  #{$property}: default($property);\n}\n","$context: z-index-stacking-context(global,\n  (\n    content: 10,\n    sidebar: 20\n  )\n);\n\nbody {\n  background-color: ui-color(gray);\n}\n\n.page {\n  height: 100vh;\n  max-height: 100vh;\n  display: flex;\n}\n\n.page__content,\n.page__sidebar {\n  position: relative;\n}\n\n.page__content {\n  width: 100%;\n  max-width: 100%;\n  display: flex;\n  flex: 1 1 0px;\n  @include z-index(content, global);\n  background: color(white);\n\n  > * {\n    flex: 0 0 100%;\n  }\n}\n\n.page__sidebar {\n  @include z-index(sidebar, global);\n  flex: 0 0 auto;\n}\n","//        ___                     ___         _____         ___          ___\n//       /  /\\       ___         /__/\\       /  /::\\       /  /\\        /__/|\n//      /  /::|     /  /\\        \\  \\:\\     /  /:/\\:\\     /  /:/_      |  |:|\n//     /  /:/:|    /  /:/         \\  \\:\\   /  /:/  \\:\\   /  /:/ /\\     |  |:|\n//    /  /:/|:|__ /__/::\\     _____\\__\\:\\ /__/:/ \\__\\:| /  /:/ /:/_  __|__|:|\n//   /__/:/ |:| /\\\\__\\/\\:\\__ /__/::::::::\\\\  \\:\\ /  /://__/:/ /:/ /\\/__/::::\\____\n//   \\__\\/  |:|/:/   \\  \\:\\/\\\\  \\:\\~~\\~~\\/ \\  \\:\\  /:/ \\  \\:\\/:/ /:/   ~\\~~\\::::/\n//       |  |:/:/     \\__\\::/ \\  \\:\\  ~~~   \\  \\:\\/:/   \\  \\::/ /:/     |~~|:|~~\n//       |  |::/      /__/:/   \\  \\:\\        \\  \\::/     \\  \\:\\/:/      |  |:|\n//       |  |:/       \\__\\/     \\  \\:\\        \\__\\/       \\  \\::/       |  |:|\n//       |__|/                   \\__\\/                     \\__\\/        |__|/\n//\n//*\n// @pattern Z-Index\n// @tagline Stack it up!\n// @group Helper\n//\n// `z-index` is managed in this centralized stylesheet to create a manageable\n// and self-documenting system. The process to add z-indexes is as follows:\n//\n// 1. For each stacking context (a set of elements for which you would like\n//    to maintain the stacking order), create a new map with a descriptive\n//    variable name.\n//\n// 2. Add entries to the map for each element that you would like to control the\n//    stacking context of. The delta between elements should not matter, only\n//    the numeric order. Elements with higher numbers will stack on top of\n//    elements with lower z-indexes.\n//\n// 3. `@include z-index` in your stylesheet with the name of the component you are\n//    setting z-index for and the map name defined in step 1.\n//\n// 4. Profit.\n\n\n\n$Z_INDEXES: (\n  global: (\n    content: 10,\n    sidebar: 20\n  ),\n\n  page: (\n    avatar: 10,\n    popover-resting: 20,\n    popover-deactivating: 30,\n    popover-active: 40\n  ),\n\n  avatar: (\n    initials: 10,\n    image: 20\n  ),\n\n  table: (\n    cell: 10,\n    cell-persistant: 20,\n    backdrop: 30\n  )\n);\n\n\n\n//*\n// This mixin creates a z-index declaration based on the element and context\n// passed in. The mixin will attempt to retrieve the `$context` as a key from\n// the global `$Z-INDEXES` map, and will then try to retrieve the `$element`\n// from that map. If this is successful, the z-index declaration is included.\n//\n// @param {String} $element - The element within the stacking context you are\n//                            adding the rule for.\n// @param {String} $context - The stacking context you want to search in for\n//                            `$element`.\n\n@mixin z-index($element, $context) {\n  $index: map-get(map-get($Z_INDEXES, $context), $element);\n\n  @if $index {\n    z-index: $index;\n  }\n}\n\n@function z-index-stacking-context($name, $stack-order) {\n  $new-stack-order: ( $name: $stack-order );\n  $Z_INDEXES: map-merge($Z_INDEXES, $new-stack-order);\n\n  @return true;\n}\n","//        ___      ___          ___                 ___\n//       /  /\\    /  /\\        /__/\\        ___    /  /\\\n//      /  /:/_  /  /::\\       \\  \\:\\      /  /\\  /  /:/_\n//     /  /:/ /\\/  /:/\\:\\       \\  \\:\\    /  /:/ /  /:/ /\\\n//    /  /:/ /:/  /:/  \\:\\  _____\\__\\:\\  /  /:/ /  /:/ /::\\\n//   /__/:/ /:/__/:/ \\__\\:\\/__/::::::::\\/  /::\\/__/:/ /:/\\:\\\n//   \\  \\:\\/:/\\  \\:\\ /  /:/\\  \\:\\~~\\~~\\/__/:/\\:\\  \\:\\/:/~/:/\n//    \\  \\::/  \\  \\:\\  /:/  \\  \\:\\  ~~~\\__\\/  \\:\\  \\::/ /:/\n//     \\  \\:\\   \\  \\:\\/:/    \\  \\:\\         \\  \\:\\__\\/ /:/\n//      \\  \\:\\   \\  \\::/      \\  \\:\\         \\__\\/ /__/:/\n//       \\__\\/    \\__\\/        \\__\\/               \\__\\/\n\n@mixin type--default-font-family {\n  font-family: Source Sans Pro, Helvetica Neue, Helvetica, Arial, sans-serif;\n}\n\n@mixin type--monospace-font-family {\n  font-family: Consolas, monospace;\n}\n\nbody {\n  text-size-adjust: 100%;\n  color: color(slate);\n  @include type--default-font-family;\n}\n\nbutton,\ninput {\n  @include type--default-font-family;\n}\n\n\n\n\nh1, h2, h3, h4, h5, h6, p, .type {\n  margin: 0;\n  font-size: inherit;\n}\n\n@mixin type--heading-1 {\n  font-weight: 400;\n  line-height: 1;\n  color: ui-color(gray, darkest);\n  @include font-size(heading-1);\n}\n\n@mixin type--heading-2 {\n  font-weight: 400;\n  color: ui-color(gray, darkest);\n  @include font-size(heading-2);\n}\n\n@mixin type--heading-3 {\n  font-weight: 400;\n  line-height: 1;\n  color: ui-color(gray, darkest);\n  @include font-size(heading-3);\n}\n\n@mixin type--heading-4 {\n  margin: default(spacing) auto half(default(spacing));\n  font-weight: 600;\n  text-transform: uppercase;\n  color: ui-color(gray, dark);\n  @include font-size(heading-4);\n}\n\n@mixin type--heading-5 {\n  margin: default(spacing) auto half(default(spacing));\n  font-weight: 400;\n  color: ui-color(gray, darkest);\n  @include font-size(heading-5);\n}\n\n@mixin type--paragraph {\n  @include font-size(paragraph);\n  @include default(line-height);\n  font-weight: 300;\n  color: ui-color(black);\n\n  + p {\n    margin-top: (0.75 * default(spacing));\n  }\n\n  > a {\n    display: inline-block;\n    text-decoration: none;\n    color: ui-color(blue, darker);\n    font-weight: normal;\n\n    > span {\n      border-bottom: 2px solid ui-color(blue, dark);\n    }\n\n    > code {\n      color: ui-color(blue, darker);\n      background-color: mix(ui-color(gray, light), ui-color(blue), 80%);\n      border-color: rgba(ui-color(blue, darker), 0.15);\n    }\n  }\n\n  code {\n    @include type--monospace-font-family;\n    display: inline-block;\n    padding: 0.05em 0.25em;\n    font-size: 0.8em;\n    background-color: ui-color(gray, light);\n    color: ui-color(gray, darkest);\n    border: 1px solid ui-color(gray);\n    @include default(border-radius);\n  }\n}\n\n@mixin type--paragraph-small {\n  @include font-size(paragraph-small);\n}\n\n@mixin type--after-paragraph {\n  .type--paragraph + &,\n  .user-type + & {\n    @content;\n  }\n}\n\n\n\n.type--heading-1 { @include type--heading-1; }\n.type--heading-2 { @include type--heading-2; }\n.type--heading-3 { @include type--heading-3; }\n.type--heading-4 {\n  @include type--heading-4;\n}\n\n.type--heading-5 {\n  @include type--heading-5;\n\n  .type--heading-4 + & {\n    margin-top: half(default(spacing));\n  }\n\n  @include type--after-paragraph {\n    margin-top: (1.5 * default(spacing));\n  }\n}\n\n.type--heading-bordered {\n  padding-bottom: default(spacing);\n  margin-bottom: multiply(default(spacing), 1.3);\n  border-bottom: 2px solid ui-color(gray);\n\n  + .section {\n    margin-top: negative(default(spacing));\n  }\n}\n\n.type--paragraph { @include type--paragraph; }\n.type--paragraph-small { @include type--paragraph-small; }\n\n.type-container {\n  h1 { @include type--heading-1; }\n  h2 { @include type--heading-2; }\n  h3 { @include type--heading-3; }\n  h4 { @include type--heading-4; }\n  h5 { @include type--heading-5; }\n\n  p { @include type--paragraph; }\n}\n\n.type-container--small {\n  p { @include type--paragraph-small; }\n}\n\n\n\n.type--display {\n  font-size: 1.3rem;\n  margin-top: 0;\n  font-weight: 500;\n  line-height: 1;\n}\n\n.type--margin-bottom {\n  margin-bottom: default(spacing);\n}\n\n.type--subdued {\n  color: ui-color(gray, dark);\n}\n\n\n\n\n\n\n\n\n\n\n\n.type--code {\n  @include type--monospace-font-family;\n  font-size: 0.95em;\n  word-wrap: break-word;\n}\n\n::selection {\n  background: ui-color(blue);\n}\n","//        ___      ___          ___                             ___                   ___          ___\n//       /  /\\    /  /\\        /__/\\        ___                /  /\\      ___        /  /\\        /  /\\\n//      /  /:/_  /  /::\\       \\  \\:\\      /  /\\              /  /:/_    /  /\\      /  /::|      /  /:/_\n//     /  /:/ /\\/  /:/\\:\\       \\  \\:\\    /  /:/             /  /:/ /\\  /  /:/     /  /:/:|     /  /:/ /\\\n//    /  /:/ /:/  /:/  \\:\\  _____\\__\\:\\  /  /:/             /  /:/ /::\\/__/::\\    /  /:/|:|__  /  /:/ /:/_\n//   /__/:/ /:/__/:/ \\__\\:\\/__/::::::::\\/  /::\\            /__/:/ /:/\\:\\__\\/\\:\\__/__/:/ |:| /\\/__/:/ /:/ /\\\n//   \\  \\:\\/:/\\  \\:\\ /  /:/\\  \\:\\~~\\~~\\/__/:/\\:\\           \\  \\:\\/:/~/:/  \\  \\:\\/\\__\\/  |:|/:/\\  \\:\\/:/ /:/\n//    \\  \\::/  \\  \\:\\  /:/  \\  \\:\\  ~~~\\__\\/  \\:\\           \\  \\::/ /:/    \\__\\::/   |  |:/:/  \\  \\::/ /:/\n//     \\  \\:\\   \\  \\:\\/:/    \\  \\:\\         \\  \\:\\           \\__\\/ /:/     /__/:/    |  |::/    \\  \\:\\/:/\n//      \\  \\:\\   \\  \\::/      \\  \\:\\         \\__\\/             /__/:/      \\__\\/     |  |:/      \\  \\::/\n//       \\__\\/    \\__\\/        \\__\\/                           \\__\\/                 |__|/        \\__\\/\n//\n//*\n// @pattern Font Sizes\n// @group Helper\n//\n// The stylesheet exists as a single place to manage all font sizes. To use\n// a font size in your stylesheet, follow this procedure:\n//\n// 1. Add a well-named entry to the `$FONT-SIZES` map with the value set to\n//    the font size for that element.\n//\n// 2. If you wish to include a `font-size` declaration in your stylesheet,\n//    `@include font-size()`, passing it the name of the component to retrieve\n//    the font-size for.\n//\n// 3. Retrieving the actual font-size dimension (for example, to be used in a\n//    calculation to determine necessary padding) should be done by passing the\n//    same argument discussed above to the `font-size` *function*.\n\n\n\n$FONT_SIZES: (\n  heading-1: rem(36),\n  heading-2: rem(30),\n  heading-3: rem(24),\n  heading-4: rem(14),\n  heading-5: rem(20),\n  label: rem(16),\n  paragraph: rem(20),\n  paragraph-small: rem(18),\n  avatar: rem(20),\n  badge: 0.75em,\n  badge--standalone: rem(16),\n  code-block: rem(16),\n  code-block--condensed: rem(14),\n  list-heading: rem(20),\n  select: rem(16),\n  tablist: rem(16),\n  tablist--large: rem(24),\n  control: rem(18)\n);\n\n\n\n//*\n// Retrives the font-size for an element declared in the global\n// `$FONT_SIZES` map. This will not actually add a CSS rule — if you\n// would like the actual `font-size` rule to be printed, use the\n// `@mixin` version. Use this function when you want to retrive the font\n// size for use in other calculations.\n//\n// @param {String} $element - The element whose font-size should be retrieved.\n// @returns {Number}\n\n@function font-size($element) {\n  @return map-get($FONT-SIZES, $element);\n}\n\n\n\n//*\n// Retrives the font-size for an element declared in the global\n// `$FONT_SIZES` map **and** prints the `font-size` rule.\n//\n// @param {String} $element - The element whose font-size should be retrieved.\n//\n// @example\n// .type--heading-1 {\n//   @include font-size(heading-1); // => font-size: 2rem;\n// }\n\n@mixin font-size($element) {\n  font-size: font-size($element);\n}\n","//        ___                     ___                 ___          ___\n//       /  /\\        ___        /  /\\        ___    /  /\\        /  /\\\n//      /  /::\\      /__/\\      /  /::\\      /  /\\  /  /::\\      /  /::\\\n//     /  /:/\\:\\     \\  \\:\\    /  /:/\\:\\    /  /:/ /  /:/\\:\\    /  /:/\\:\\\n//    /  /:/~/::\\     \\  \\:\\  /  /:/~/::\\  /  /:/ /  /:/~/::\\  /  /:/~/:/\n//   /__/:/ /:/\\:\\___  \\__\\:\\/__/:/ /:/\\:\\/  /::\\/__/:/ /:/\\:\\/__/:/ /:/___\n//   \\  \\:\\/:/__\\/__/\\ |  |:|\\  \\:\\/:/__\\/__/:/\\:\\  \\:\\/:/__\\/\\  \\:\\/:::::/\n//    \\  \\::/    \\  \\:\\|  |:| \\  \\::/    \\__\\/  \\:\\  \\::/      \\  \\::/~~~~\n//     \\  \\:\\     \\  \\:\\__|:|  \\  \\:\\         \\  \\:\\  \\:\\       \\  \\:\\\n//      \\  \\:\\     \\__\\::::/    \\  \\:\\         \\__\\/\\  \\:\\       \\  \\:\\\n//       \\__\\/         ~~~~      \\__\\/               \\__\\/        \\__\\/\n\n//*\n// @pattern Avatar\n//\n// A small image representing someone associated with this project. The script\n// part of this component allows it to fetch avatar images from Github, Twitter,\n// or Gravatar, depending on the information provided. If no images are found\n// for the avatar, it will fall back to displaying their initials.\n//\n// @since 1.0.0\n\n//*\n// The size (height and width) of an `avatar`.\n// @type Length\n\n$avatar--size: 3rem;\n\n//*\n// The margin that should appear between two `avatar`s (including those on a\n// new line).\n// @type Length\n\n$avatar--spacing: half(default(spacing));\n\n//*\n// The core container for a single avatar. An avatar supports fetching of the\n// background image through either a [Github](http://github.com) profile name,\n// a [Twitter](http://twitter.com) username, or an email address that is\n// associated with a [Gravatar](http://gravatar.com) account. If any of the\n// above are given, clicking on the avatar will open a tab with the relevant\n// profile page open (or, compose a new email if email was the provided\n// identifier). If none of the above are given, the initials of the user's name\n// will be shown.\n//\n// @helper\n// <% docks_component(\"avatar:container\") do %>\n//   <%= docks_component(\"avatar\", author: OpenStruct.new(name: \"Chris Sauve\", github: \"lemonmade\")) %>\n// <% end %>\n\n.avatar {\n  // position\n  @include z-index(avatar, page);\n  position: relative;\n\n  // box model\n  flex: 0 0 auto;\n  display: inline-block;\n\n  // backdrop\n  background-color: color(gray-light);\n  border-radius: default(border-radius);\n  overflow: hidden;\n\n  // type\n  @include font-size(avatar);\n}\n\n//*\n// A container that shows the initals of the user. This will always be present\n// so that it is visible immediately on page load. The avatar image, which is\n// fetched by JavaScript, will be faded in over top of this subcomponent, if\n// available.\n//\n// Every initial of the passed name will be shown. There is enough space for\n// 2–3 initials, but any more than this will overflow the avatar. As such,\n// please restrict names to first and last or first, middle, and last.\n\n.avatar__initials {\n  // position\n  @include z-index(initials, avatar);\n  position: absolute;\n  top: 50%; left: 0;\n\n  // box model\n  width: 100%;\n  transform: translateY(-50%);\n\n  // backdrop\n  color: color(gray);\n\n  // type\n  font-size: 1em;\n  line-height: 1;\n  text-align: center;\n  text-transform: uppercase;\n}\n\n//*\n// The container for the avatar image. The image will be set by JavaScript as\n// a background image on this subcomponent, so if no image is provided this\n// container will effectively be invisible. Once the background image is\n// fetched (which will be done with a slight delay to prevent too much from\n// happening on page load), it is faded into place using the\n// `avatar__image--is-visible` state.\n\n.avatar__image {\n  // position\n  @include z-index(image, avatar);\n  position: relative;\n\n  // box model\n  height: $avatar--size;\n  width: $avatar--size;\n\n  // backdrop\n  opacity: 0;\n  transition: opacity 0.3s ease;\n  background-size: cover;\n  background-position: center center;\n  background-repeat: no-repeat;\n  overflow: hidden;\n}\n\n//*\n// The variation that causes the image to be faded into view.\n//\n// @demo_type none\n// @set_by Avatar#show_image\n\n.avatar__image--is-visible {\n  opacity: 1;\n}\n\n//*\n// Creates the rules that are required to restrict an `avatar__container` to\n// a particular number of `avatar`s per line.\n//\n// @param {Number} $n - The maximum number of `avatar`s allowed per line.\n\n@mixin avatar--restrict-to-n-avatars($n) {\n  max-width: (($n * $avatar--size) + ($n * $avatar--spacing));\n}\n\n//*\n// The container around a set of avatars. This container is important because it\n// eliminates the excess margin below and to the right of `avatar`s on the\n// outside edges of the container, but still allows them to be properly spaced\n// out horizontally and vertically. This is accomplished using negative margin\n// on the bottom and right to offset the margin of the contained `avatar`s.\n//\n// This container allows three avatars side-by-side, with additional avatars\n// breaking onto a new line. If you only need a single avatar, this container\n// is not necessary.\n//\n// You can create this component using the `\"avatar:container\"` helper. this\n// helper allows you to specify the size of the container:\n//\n// ```erb_demo\n// <div>\n//   <% docks_component(\"avatar:container\") do %>\n//     <% 4.times do %>\n//       <%= docks_component(\"avatar\", author: OpenStruct.new(name: \"Chris Sauve\", github: \"lemonmade\")) %>\n//     <% end %>\n//   <% end %>\n// </div>\n//\n// <div>\n//   <% docks_component(\"avatar:container\", size: :large) do %>\n//     <% 4.times do %>\n//       <%= docks_component(\"avatar\", author: OpenStruct.new(name: \"Chris Sauve\", github: \"lemonmade\")) %>\n//     <% end %>\n//   <% end %>\n// </div>\n// ```\n\n.avatar__container {\n  display: inline-flex;\n  flex-wrap: wrap;\n  overflow: hidden;\n  margin-right: negative($avatar--spacing) !important;\n  margin-bottom: negative($avatar--spacing) !important;\n  @include avatar--restrict-to-n-avatars(3);\n\n  > .avatar {\n    margin-right: $avatar--spacing;\n    margin-bottom: $avatar--spacing;\n  }\n}\n\n//*\n// A container that can hold more `avatar`s on a single line (four, instead of\n// the base three). Use this for situations in which you have more room\n// available for ancillary information like contributor information.\n//\n// @set_by :size (:large)\n\n.avatar__container--large {\n  @include avatar--restrict-to-n-avatars(4);\n}\n","//                    ___        _____        ___          ___\n//       _____       /  /\\      /  /::\\      /  /\\        /  /\\\n//      /  /::\\     /  /::\\    /  /:/\\:\\    /  /:/_      /  /:/_\n//     /  /:/\\:\\   /  /:/\\:\\  /  /:/  \\:\\  /  /:/ /\\    /  /:/ /\\\n//    /  /:/~/::\\ /  /:/~/::\\/__/:/ \\__\\:|/  /:/_/::\\  /  /:/ /:/_\n//   /__/:/ /:/\\:/__/:/ /:/\\:\\  \\:\\ /  /:/__/:/__\\/\\:\\/__/:/ /:/ /\\\n//   \\  \\:\\/:/~/:|  \\:\\/:/__\\/\\  \\:\\  /:/\\  \\:\\ /~~/:/\\  \\:\\/:/ /:/\n//    \\  \\::/ /:/ \\  \\::/      \\  \\:\\/:/  \\  \\:\\  /:/  \\  \\::/ /:/\n//     \\  \\:\\/:/   \\  \\:\\       \\  \\::/    \\  \\:\\/:/    \\  \\:\\/:/\n//      \\  \\::/     \\  \\:\\       \\__\\/      \\  \\::/      \\  \\::/\n//       \\__\\/       \\__\\/                   \\__\\/        \\__\\/\n\n//*\n// @pattern Badge\n//\n// A badge is a small chunk of text in a colored box that denotes a particular\n// attribute about the interface element to which it is attached. When\n// additional explanatory text is required, use a `notice` instead — badges\n// should only ever be one word in length. It is appropriate to have multiple\n// badges attached to a single element if additional details about that\n// element need to be indicated.\n//\n// @since 1.0.0\n\n\n$badge--spacing: half(default(spacing));\n\n\n\n//*\n// The actual badge. Each badge provides spacing between itself and badges it\n// is next to, so they must be wrapped in a `badge__container` to remove any\n// excess outside spacing if you include more than a single badge.\n//\n// Because badges most often sit allongside other text, they are designed to\n// scale with the size of whatever container they are in. They will always be\n// slightly smaller than the text size of the content to which they are\n// attached such that the top and bottom of the badge approximately match the\n// ascenders/ descenders of the text.\n//\n// @markup\n// <div class=\"badge__container\">\n//   <% 5.times do |i| %>\n//     <div class=\"badge\">Badge <%= i + 1 %></div>\n//   <% end %>\n// </div>\n\n.badge {\n  // position\n  position: relative;\n\n  // box model\n  flex: 0 0 auto;\n  display: inline-block;\n  // A little extra bottom padding to make it look centered.\n  padding: 0.15em 0.5em 0.25em;\n\n  // backdrop\n  @include default(border-radius);\n  background-color: ui-color(gray, light);\n\n  // type\n  @include font-size(badge);\n  line-height: default(line-height);\n  vertical-align: middle;\n  color: ui-color(gray, darker);\n}\n\n//*\n// Use this badge variation when you are trying to indicate some sort of\n// warning to the user — for example, when the content to which this badge is\n// attached has been deprecated or has a common pitfall.\n//\n// @demo_type joint\n\n.badge--warning {\n  background-color: ui-color(yellow);\n  color: ui-color(yellow, dark);\n}\n\n//*\n// Use this badge variation when you are trying to indicate a new or updated\n// status for the attached content. For example, this badge might be used to\n// indicate something is in beta or has recently been upgraded or released.\n//\n// @demo_type joint\n\n.badge--new {\n  background-color: ui-color(blue);\n  color: ui-color(blue, darker);\n}\n\n//*\n// Use this badge variation when the attached content is meant to be\n// concealed, secret, or in some other way not intended to be used in the\n// average case. For example, this badge can be used to indicate that\n// something is private/ for internal use only.\n//\n// @demo_type joint\n\n.badge--secret {\n  background-color: ui-color(gray, darkest);\n  color: ui-color(gray);\n}\n\n//*\n// This variation is used to fix the vertical padding on badges that are meant\n// to contain content styled as code. Because the monospace font family has\n// different font properties, leaving the existing `padding`/ `line-height`\n// along results in the text sitting too closely to the top of the badge. This\n// fixes the problem using a very un-scientific redistribution of the\n// available padding.\n//\n// Note that, because the monospace font has more space allocated for each\n// character, a badge with this variant will be wider than one without it,\n// even if they have the same content.\n//\n// @demo_type select\n\n.badge--code {\n  // @include type--monospace-font-family;\n  padding-bottom: 0;\n  padding-top: 0.2em;\n}\n\n//*\n// A badge that is used on its own (that is, not beside other text, but may be\n// beside other buttons).\n//\n// @demo_type select\n\n.badge--standalone {\n  @include font-size(badge--standalone);\n}\n\n\n\n//*\n// This container should always be wrapped around a set of badges. It removes\n// any excess right and bottom margin (which every contained badge has to\n// allow for spacing between rows and columns of badges), while still allowing\n// the badges to break onto a new line if there is not enough space to contain\n// them all on a single line.\n//\n// If only a single badge exists, this container can be omitted.\n\n.badge__container {\n  display: inline-flex;\n  flex-wrap: wrap;\n  overflow: hidden;\n  margin-right: negative($badge--spacing) !important;\n  margin-bottom: negative($badge--spacing) !important;\n\n  > .badge {\n    margin-right: $badge--spacing;\n    margin-bottom: $badge--spacing;\n  }\n}\n","//                     ___                             ___          ___\n//       _____        /__/\\         ___       ___     /  /\\        /__/\\\n//      /  /::\\       \\  \\:\\       /  /\\     /  /\\   /  /::\\       \\  \\:\\\n//     /  /:/\\:\\       \\  \\:\\     /  /:/    /  /:/  /  /:/\\:\\       \\  \\:\\\n//    /  /:/~/::\\  ___  \\  \\:\\   /  /:/    /  /:/  /  /:/  \\:\\  _____\\__\\:\\\n//   /__/:/ /:/\\:|/__/\\  \\__\\:\\ /  /::\\   /  /::\\ /__/:/ \\__\\:\\/__/::::::::\\\n//   \\  \\:\\/:/~/:/\\  \\:\\ /  /://__/:/\\:\\ /__/:/\\:\\\\  \\:\\ /  /:/\\  \\:\\~~\\~~\\/\n//    \\  \\::/ /:/  \\  \\:\\  /:/ \\__\\/  \\:\\\\__\\/  \\:\\\\  \\:\\  /:/  \\  \\:\\  ~~~\n//     \\  \\:\\/:/    \\  \\:\\/:/       \\  \\:\\    \\  \\:\\\\  \\:\\/:/    \\  \\:\\\n//      \\  \\::/      \\  \\::/         \\__\\/     \\__\\/ \\  \\::/      \\  \\:\\\n//       \\__\\/        \\__\\/                           \\__\\/        \\__\\/\n//\n//*\n// @pattern Buttons\n// @tagline Capture all the clicks.\n//\n// Buttons are what the user should press to initiate most actions. Actions\n// may take place on the page (for example, by activating a popover or x-ray\n// mode) or may send the user to another site to perform an action (the most\n// notable example of this are the buttons that send the user to Github). The\n// element on which to apply these classes will depend on whether the action\n// is internal or external to the page.\n//\n// @since 1.0.0\n\n\n\n$button--spacing: half(default(spacing));\n\n\n\n//*\n// @title Standard Buttons\n//\n// A standard button. This component normalizes the styles of both `button` and\n// `a` elements so that these classes can be placed on either one. If the action\n// is internal (i.e., doesn't require a `GET` request), use a `button`. If the\n// action does require a `GET`, use a URL. Never use an `a` tag with a blank\n// (or `\"#\"`) `href` attribute.\n//\n// Any variations on this button should ensure that they design and implement\n// designs for the `:focus` state, `:active` state, `:hover` state (optional),\n// and for icons with buttons (using a child selector to the `icon` component),\n// if adjustments to the contained icons are required.\n//\n// A single button can be included on its own, without any container. If\n// multiple buttons have to be placed beside each other, wrap all of the buttons\n// in a `docks-button__container`.\n//\n// @markup\n// <div class=\"docks-button__container\">\n//   <button class=\"docks-button\">button!</button>\n//\n//   <button class=\"docks-button\">\n//     <%= docks_icon :github, size: :medium %>\n//     <span class=\"docks-button__text\">icon + text</span>\n//   </button>\n//\n//   <button class=\"docks-button\">\n//     <span class=\"docks-button__text\">text + icon</span>\n//     <%= docks_icon :github, size: :medium %>\n//   </button>\n//\n//   <div class=\"docks-button__segmented-container\">\n//     <button class=\"docks-button\">Segment 1</button>\n//     <button class=\"docks-button\">Segment 2</button>\n//   </div>\n// </div>\n\n.docks-button {\n  // box model\n  display: inline-flex;\n  align-items: center;\n  justify-content: center;\n  padding: 0 default(control-padding);\n\n  // backdrop\n  @include default(border-radius);\n  background-color: ui-color(gray, light);\n  border: none;\n  cursor: pointer;\n  opacity: 1;\n  transition: opacity 0.3s ease;\n\n  // type\n  // @include type--default-font-family;\n  @include font-size(control);\n  line-height: default(control-size);\n  color: ui-color(gray, darker);\n  vertical-align: middle;\n  text-decoration: none;\n  white-space: nowrap;\n\n  &:focus,\n  &:active {\n    background-color: ui-color(gray);\n    outline: none;\n  }\n\n  > *:first-child { margin-right: $button--spacing; }\n}\n\n//*\n// A slighter dark variation.\n\n.docks-button--dark {\n  background-color: ui-color(gray, dark);\n  color: ui-color(gray, darkest);\n\n  &:focus,\n  &:active {\n    background-color: ui-color(gray, dark);\n    color: ui-color(gray, darkest);\n  }\n}\n\n//*\n// A button that can no longer be pressed. Make sure to always also include the\n// `disabled` attribute on the actual `button` — this improves usability by\n// preventing the button from being tabbed to, and prevents any event handlers\n// on the `button` from running.\n//\n// @javascript_action this.classList.add(\"docks-button--is-disabled\"); this.disabled = true\n\n.docks-button--is-disabled {\n  opacity: 0.3;\n}\n\n\n\n//*\n// A container for a collection of buttons that normalizes the margin on the\n// outside. This is necessary because each button inside the container has\n// right and bottom margin so that there is vertical and horizontal space\n// between each of any number of buttons.\n\n.docks-button__container {\n  display: inline-flex;\n  flex-wrap: wrap;\n  margin-right: negative($button--spacing) !important;\n  margin-bottom: negative($button--spacing) !important;\n\n  // Prevents margin from collapsing while still allowing overflow/\n\n  &:after { content: \"\"; display: table; }\n\n  // Allow for anything inside the container — this is useful for, for example,\n  // contained buttons that activate popovers and thus have popover containers\n  // around them.\n\n  > * {\n    flex: 0 0 auto;\n    margin-right: $button--spacing;\n    margin-bottom: $button--spacing;\n  }\n}\n\n//*\n// Use this container variation when you want all of the buttons inside the\n// container to consume an equal part of the total width available to the\n// container. Note that potentially-unexpected behavior may occur when the\n// buttons in this button group have a total intrinsic minimum width greater\n// than that of the container — buttons with smaller intrinsic widths in the\n// group will shrink as much as possible, and then buttons will start, one-by-one\n// as required, breaking onto additional lines (and filling them completely,\n// resulting in some buttons likely being larger than others).\n//\n// For the best results, try to have only two buttons side-by-side in a\n// container using this variant.\n\n.docks-button__container--fill-width {\n  display: flex;\n  flex-wrap: wrap;\n  align-items: flex-start;\n\n  // For both buttons and non-button-ey things in button groups, like popover\n  // containers.\n\n  .docks-button,\n  > *:not(.docks-button) {\n    display: flex;\n    flex: 1 0 0%;\n    min-width: -webkit-min-content;\n    min-width: -moz-min-content;\n    min-width: min-content;\n  }\n}\n\n\n\n//*\n// The text for a button. This container is not necessary unless there is also\n// an icon in the button.\n\n.docks-button__text {}\n\n\n\n//*\n// A wrapper around buttons that causes them to look like one button segmented\n// into pieces.\n\n.docks-button__segmented-container {\n  display: inline-flex;\n\n  > .docks-button {\n    border-radius: 0;\n\n    &:not(:first-child) { border-left: none; }\n    &:first-child { border-radius: default(border-radius) 0 0 default(border-radius); }\n    &:last-child { border-radius: 0 default(border-radius) default(border-radius) 0; }\n  }\n}\n","//        ___          ___          ___        _____\n//       /  /\\        /  /\\        /  /\\      /  /::\\\n//      /  /:/       /  /::\\      /  /::\\    /  /:/\\:\\\n//     /  /:/       /  /:/\\:\\    /  /:/\\:\\  /  /:/  \\:\\\n//    /  /:/  ___  /  /:/~/::\\  /  /:/~/:/ /__/:/ \\__\\:|\n//   /__/:/  /  /\\/__/:/ /:/\\:\\/__/:/ /:/__\\  \\:\\ /  /:/\n//   \\  \\:\\ /  /:/\\  \\:\\/:/__\\/\\  \\:\\/:::::/\\  \\:\\  /:/\n//    \\  \\:\\  /:/  \\  \\::/      \\  \\::/~~~~  \\  \\:\\/:/\n//     \\  \\:\\/:/    \\  \\:\\       \\  \\:\\       \\  \\::/\n//      \\  \\::/      \\  \\:\\       \\  \\:\\       \\__\\/\n//       \\__\\/        \\__\\/        \\__\\/\n//\n//*\n// @pattern Card\n//\n// A simple, clean container for content that is to appear on an area with a\n// colored background but that requires a completely neutral background to\n// appear properly.\n//\n// @since 1.0.0\n\n//*\n// @markup\n// <div class=\"card\">\n//   <div style=\"height: 1rem; width: 1rem; margin: 2rem auto;\"></div>\n// </div>\n\n.card {\n  background-color: color(white);\n  border-radius: default(border-radius);\n  overflow: hidden;\n}\n","//        ___          ___        _____        ___\n//       /  /\\        /  /\\      /  /::\\      /  /\\\n//      /  /:/       /  /::\\    /  /:/\\:\\    /  /:/_\n//     /  /:/       /  /:/\\:\\  /  /:/  \\:\\  /  /:/ /\\\n//    /  /:/  ___  /  /:/  \\:\\/__/:/ \\__\\:|/  /:/ /:/_\n//   /__/:/  /  /\\/__/:/ \\__\\:\\  \\:\\ /  /:/__/:/ /:/ /\\\n//   \\  \\:\\ /  /:/\\  \\:\\ /  /:/\\  \\:\\  /:/\\  \\:\\/:/ /:/\n//    \\  \\:\\  /:/  \\  \\:\\  /:/  \\  \\:\\/:/  \\  \\::/ /:/\n//     \\  \\:\\/:/    \\  \\:\\/:/    \\  \\::/    \\  \\:\\/:/\n//      \\  \\::/      \\  \\::/      \\__\\/      \\  \\::/\n//       \\__\\/        \\__\\/                   \\__\\/\n\n//*\n// @pattern Code Block\n//\n// This component provides a full-featured container for code demos, including\n// support for multiple languages being shown in a single code block, a\n// rendered demo of the code in the code block, hiding the markup, and\n// switching between different components. The component can be scaled to\n// include as much or as little of these features as desired.\n//\n// This thing needs he following components:\n//\n// - [`button`](@link)\n//\n// - [`resizable::focus_size_button`](@link)\n//\n// - [`exploded::Exploded#set_markup`](@link)\n//\n// The JavaScript part of this component also supports communication with an\n// `iframe`ed demo, in-place updating of helper and rendered markup for\n// components, and, through [highlight.js](https://highlightjs.org/), syntax\n// highlighting of many common languages.\n//\n// @since 1.0.0\n\n\n\n//*\n// @title Code Block\n//\n// This is he overall container for the code block. It's primary purpose is to\n// provide margin above and below the code block, and to provide a hook to\n// make adjustments to many subcomponents through variations such as\n// `code-block--condensed` and `code-block--hidden`.\n//\n// Code blocks can go from the incredibly complex (see the demo above), to\n// more moderate levels of detail — such as a code block that gets rendered\n// inline based on a templating language and a stub, and that outputs an\n// attached demo:\n//\n// ```erb_demo\n// <%= docks_code_block code: \"<p style='color: gray;'>Hello world!</p>\",\n//                      language: \"erb\",\n//                      demo?: true,\n//                      hidden?: true %>\n// ```\n//\n// All the way to an incredibly simple code block:\n//\n// ```erb_demo\n// <%= docks_code_block code: \"<p class='type type--paragraph'>Hello world!</p>\" %>\n// ```\n//\n// @helper\n// <%= docks_code_block code: \"<p style='color: gray;'>Hello world!</p>\",\n//                      language: \"erb\",\n//                      demo?: true,\n//                      hidden?: true %>\n\n.code-block {\n  margin: default(spacing) 0;\n  overflow: hidden;\n  background: ui-color(gray, light);\n  @include default(border-radius);\n\n  .docks-button { display: none; }\n}\n\n\n//*\n// A code block with less internal padding and a smaller font size. Use this\n// variant for situations in which the code is secondary or would clash with\n// a more important code block.\n//\n// @set_by :condensed?\n\n.code-block--condensed {\n  margin-top: half(default(spacing));\n\n  .code-block__code {\n    padding-bottom: half(default(spacing));\n    @include font-size(code-block--condensed);\n  }\n\n  &:not(.code-block--with-header) {\n    .code-block__code {\n      padding-top: half(default(spacing));\n    }\n  }\n}\n\n//*\n// A code block that is full-bleed within the viewport. This will remove any\n// unnecessary border radius and side padding/ borders.\n//\n// @set_by :full_width?\n\n.code-block--full-width {\n  margin-right: 0;\n  margin-left: 0;\n  border-radius: 0;\n\n  .content & {\n    margin-left: negative(default(spacing));\n    margin-right: negative(default(spacing));\n  }\n}\n\n//*\n// A code block that has hidden the contained markup and most of its UI. Use\n// this for the initial state of a code block only when it has a demo attached\n// to it, otherwise the code block will appear as a strange strip of color\n// with no indication of its purpose. Hideable code blocks (as set by\n// `:hideable?`) can have this state toggled by clicking on the contained\n// button.\n//\n// When the code block is hidden, all of the UI in the header except for the\n// button to toggle visibility is hidden (that is, tabs to switch between\n// languages and the `select` to switch between demos, if they exist).\n//\n// @set_by :hidden?, CodeBlock#toggle\n// @javascript_action Docks.CodeBlock.for(this).toggle()\n\n.code-block--is-hidden {\n  &:not(.code-block--with-demo) {\n    .code-block__toggler {\n      background-color: ui-color(gray, light);\n    }\n  }\n\n  .code-block__content {\n    height: 0;\n  }\n}\n\n\n\n//*\n// This component sits in the `code-block__header` and wraps around both the\n// button to hide the code block and a `select` to switch between sets of\n// code that may be shown in this code block, if either or both are required.\n\n.code-block__actions {\n  display: flex;\n  align-items: center;\n}\n\n\n\n//*\n// The container for all actions related to this code block. If the code block\n// includes both helper and compiled markup, the header will contain the\n// tablist required to switch between them. If the code block is hideable,\n// the header will also include a button to hide it. Finally, if there are\n// multiple sets of code that may be shown in this code block, the header will\n// contain a `select` to switch between them.\n\n.code-block__header {\n  // box model\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  padding: half(default(spacing)) default(spacing);\n  flex: 0 0 auto !important;\n\n  // backdrop\n  background: ui-color(gray, light);\n\n  .select,\n  .tablist {\n    transition: transform 0.2s ease\n  }\n\n  .tablist {\n    padding: 0;\n  }\n}\n\n\n\n//*\n// This component allows the code to scroll both vertically and horizontally.\n\n.code-block__code-container {\n  overflow: auto;\n  max-height: 100%;\n}\n\n\n//*\n// The thing that toggles.\n\n.code-block__toggler {\n  background-color: ui-color(gray);\n  width: 100%;\n  border: none;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  @include font-size(control);\n  padding: half(default(spacing)) 0;\n  color: ui-color(gray, darker);\n  transition: background-color 0.2s ease;\n\n  &:focus,\n  &:active {\n    background-color: ui-color(gray);\n    outline: none;\n  }\n\n  > .icon {\n    // @include icon--recolor(gray, darker);\n    margin-right: half(default(spacing));\n    opacity: 0.5;\n  }\n}\n\n//*\n// Container around the code and header.\n\n.code-block__content {\n  overflow: hidden;\n  transition: height 0.3s ease;\n  max-height: 15rem;\n}\n\n\n\n//*\n// The actual code for the associated demo. This is where all of the styles\n// for the syntax highlighting should go. This subcomponent wraps around the\n// code and provides the required side padding so that the code is scrollable\n// when it overflows.\n\n.code-block__code {\n  // box model\n  margin: 0;\n  display: inline-block;\n\n  // Only provide half spacing on the top (with matching half spacing on the\n  // bottom of the header).\n  padding: half(default(spacing)) default(spacing) default(spacing);\n\n  // type\n  @include font-size(code-block);\n  line-height: 1.3;\n\n  &:focus {\n    outline: none;\n  }\n\n  // Needs full padding top when there is no header.\n  .code-block:not(.code-block--with-header):not(.code-block--condensed):not(.code-block--with-demo) & {\n    padding-top: default(spacing);\n  }\n\n  .code-block--with-demo:not(.code-block--with-header) & {\n    padding-top: 0;\n  }\n\n  // Ensure very basic styles for code.\n  > code {\n    @include type--monospace-font-family;\n    padding: 0;\n    background-color: transparent;\n    font-size: inherit !important;\n    border: none;\n  }\n}\n\n\n\n// Syntax highlighting styles.\n\n.hljs-value,\n.hljs-string,\n.hljs-preprocessor {\n  color: color(blue)\n}\n\n.hljs-symbol {\n  color: color(blue-darker);\n}\n\n.hljs-at_rule,\n.hljs-attribute,\n.hljs-keyword {\n  color: color(gray-darker);\n}\n\n.hljs-comment {\n  color: rgba(color(gray-dark), 0.5);\n  font-style: italic\n}\n\n.hljs-tag,\n.hljs-variable {\n  color: color(gray-dark);\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n.code-block--with-demo {\n  .code-block__content {\n    padding-top: 0;\n\n    > .code-block__header {\n      padding-top: 0;\n    }\n  }\n}\n\n.code-block__demo {\n  padding: default(spacing);\n}\n\n.code-block__demo__content {\n  display: none;\n}\n\n.code-block__iframe {\n  height: 10em;\n  background-color: color(white);\n  border: none;\n  width: 100%;\n  margin: 0;\n  @include default(border-radius);\n}\n","//       _____         ___          ___          ___\n//      /  /::\\       /  /\\        /__/\\        /  /\\\n//     /  /:/\\:\\     /  /:/_      |  |::\\      /  /::\\\n//    /  /:/  \\:\\   /  /:/ /\\     |  |:|:\\    /  /:/\\:\\\n//   /__/:/ \\__\\:| /  /:/ /:/_  __|__|:|\\:\\  /  /:/  \\:\\\n//   \\  \\:\\ /  /://__/:/ /:/ /\\/__/::::| \\:\\/__/:/ \\__\\:\\\n//    \\  \\:\\  /:/ \\  \\:\\/:/ /:/\\  \\:\\~~\\__\\/\\  \\:\\ /  /:/\n//     \\  \\:\\/:/   \\  \\::/ /:/  \\  \\:\\       \\  \\:\\  /:/\n//      \\  \\::/     \\  \\:\\/:/    \\  \\:\\       \\  \\:\\/:/\n//       \\__\\/       \\  \\::/      \\  \\:\\       \\  \\::/\n//                    \\__\\/        \\__\\/        \\__\\/\n//\n//*\n// @pattern Demo\n//\n// A container around a demo (or set of demos) of a component. The styles for\n// this component are very light — they are meant not to interfere with the\n// components being demonstrated. The JavaScript component, however, controls\n// much of the child-`iframe`-side communication, including communicating\n// height changes, updating classes, sending markup, and running registered\n// event handlers.\n//\n// @since 1.0.0\n\n\n\n$demo--min-height: rem(160);\n\n\n\n//*\n// A container for a demo of a component and, optionally, variations on that\n// component that the developer has specified to display jointly.\n//\n// @helper\n// <% markup = \"<div class='foo' style='height: 2rem;'></div>\" %>\n// <%= docks_demo ::OpenStruct.new(\n//   name: \"foo\",\n//   component: ::OpenStruct.new(name: \"foo\", markup: markup),\n//   joint_variations: [\n//     ::OpenStruct.new(name: \"foo--bar\", markup: markup),\n//     ::OpenStruct.new(name: \"foo--baz\", markup: markup)\n//   ]\n// ) %>\n\n.demo {\n  background-color: color(white);\n  min-height: $demo--min-height;\n}\n\n\n\n//*\n// A single demo within the resizable iframe. Spacing styles are only applied to\n// siblings of another demo section so that the separation only applies to the\n// second through last element of a joint demo.\n//\n// The JavaScript component will ensure that the minimum height noted above\n// will be evenly allocated among the `demo__section`s within a `demo`.\n//\n// You can make use of the helpers in `demo-helpers.scss` to provide custom\n// styles for sections containing given components. The JavaScript component\n// will find the last section and assign its background color to the\n// background of the entire demo so that there is no flash of white on the\n// bottom of the demo during resizes.\n\n.demo__section {\n  position: relative;\n  box-sizing: border-box;\n  overflow: hidden;\n  background-color: color(white);\n\n  ~ .demo__section {\n    border-top: 1px solid color(gray-light);\n  }\n}\n\n\n\n//*\n// A descriptor for the current section's demo. This is provided in order to\n// distinguish variants within a joint demo.\n\n.demo__header {\n  box-sizing: border-box;\n  margin-right: negative(half(default(spacing)));\n  padding: half(default(spacing)) default(spacing) 0;\n\n  text-align: right;\n}\n","//        ___          ___         ___                   ___        _____        ___        _____\n//       /  /\\        /__/|       /  /\\                 /  /\\      /  /::\\      /  /\\      /  /::\\\n//      /  /:/_      |  |:|      /  /::\\               /  /::\\    /  /:/\\:\\    /  /:/_    /  /:/\\:\\\n//     /  /:/ /\\     |  |:|     /  /:/\\:\\___     ___  /  /:/\\:\\  /  /:/  \\:\\  /  /:/ /\\  /  /:/  \\:\\\n//    /  /:/ /:/_  __|__|:|    /  /:/~/:/__/\\   /  /\\/  /:/  \\:\\/__/:/ \\__\\:|/  /:/ /:/_/__/:/ \\__\\:|\n//   /__/:/ /:/ /\\/__/::::\\___/__/:/ /:/\\  \\:\\ /  /:/__/:/ \\__\\:\\  \\:\\ /  /:/__/:/ /:/ /\\  \\:\\ /  /:/\n//   \\  \\:\\/:/ /:/   ~\\~~\\::::|  \\:\\/:/  \\  \\:\\  /:/\\  \\:\\ /  /:/\\  \\:\\  /:/\\  \\:\\/:/ /:/\\  \\:\\  /:/\n//    \\  \\::/ /:/     |~~|:|~~ \\  \\::/    \\  \\:\\/:/  \\  \\:\\  /:/  \\  \\:\\/:/  \\  \\::/ /:/  \\  \\:\\/:/\n//     \\  \\:\\/:/      |  |:|    \\  \\:\\     \\  \\::/    \\  \\:\\/:/    \\  \\::/    \\  \\:\\/:/    \\  \\::/\n//      \\  \\::/       |  |:|     \\  \\:\\     \\__\\/      \\  \\::/      \\__\\/      \\  \\::/      \\__\\/\n//       \\__\\/        |__|/       \\__\\/                 \\__\\/                   \\__\\/\n\n//*\n// @pattern Exploded\n//\n// An exploded view of a given DOM structure that can be freely rotated. It\n// allows the user to see the structure of the component as it is rendered,\n// helping them learn about subcomponents that make up the overall structure.\n//\n// @since 1.0.0\n\n\n\n//*\n// This is the base component for an explosion. It contains the source markup\n// and the exploded representation, as well as communicates overall states of\n// the component to subcomponents.\n//\n// @helper\n// <%= docks_exploded markup: %Q(\n//   <div class=\"foo\" style=\"padding: 1em;\">\n//     <div class=\"foo__bar\" style=\"height: 5em; position: relative;\">\n//       <div class=\"foo__bar__baz\" style=\"width: 50%; height: 100%; position: absolute; top: 0; left: 0;\"></div>\n//       <div class=\"foo__bar__baz\" style=\"width: 50%; height: 100%; position: absolute; top: 0; left: 50%;\"></div>\n//     </div>\n//   </div>\n// ) %>\n\n.exploded {}\n\n.exploded--is-being-initialized {\n  .exploded__pane {\n    transition: transform 0.25s ease;\n  }\n}\n\n\n\n.exploded__source,\n.exploded__structure {\n  padding: default(spacing) double(default(spacing));\n}\n\n\n\n//*\n// The container for the original source markup for the component. This is\n// kept around so that each pane can be associated to a source DOM node for\n// any consumer of the explosion pane selection to display source structure\n// details.\n\n.exploded__source {}\n\n//*\n// A container that wraps exactly around the source markup. This extra\n// container (corresponding to the structure's `exploded__structure__content`)\n// is required to simplify absolute positioning calculations for the\n// JavaScript component.\n\n.exploded__source__content {}\n\n\n\n//*\n// The container around the exploded representation. This container provides\n// the perspective required to make the component three-dimensional.\n\n.exploded__structure {\n  position: relative;\n  perspective: 2000px;\n  transform-style: preserve-3d;\n  cursor: pointer;\n}\n\n\n\n//*\n// The container that wraps exactly around the exploded structure. This extra\n// container exists so that `exploded__structure` can provide some padding/\n// horizontal centering of the exploded structure while also providing a\n// simple relative container (this subcomponent) from which to make absolute\n// positioning calculations.\n\n.exploded__structure__content {\n  position: relative;\n  z-index: 0;\n  margin: 0 auto;\n}\n\n\n\n//*\n// The container for all controls (range sliders) that can be used to\n// manipulate the component.\n\n.exploded__control-container {\n  display: flex;\n  align-items: flex-end;\n  margin: 3rem negative(default(spacing)) 0;\n}\n\n//*\n// A container for a single control that manipulates the component.\n\n.exploded__control {\n  flex: 1 1 0;\n  margin-left: default(spacing);\n\n  &:first-child {\n    margin-left: 0;\n  }\n}\n\n\n\n//*\n// A single pane representing a DOM node in the source markup. These panes are\n// absolutely positioned by the JavaScript part of this components and,\n// likewise, are rotated in three-dimensional space as the user drags over the\n// component.\n\n.exploded__pane {\n  // position\n  position: absolute;\n\n  // box model\n  box-sizing: content-box;\n\n  // backdrop\n  @include default(border-radius);\n  background-color: rgba(ui-color(gray, darker), 0.6);\n  border: 1px solid rgba(ui-color(gray), 0.5);\n\n  // transition\n  transition: background 0.3s ease;\n\n  &:hover {\n    background-color: ui-color(blue);\n  }\n}\n\n//*\n// The JavaScript adds this state to panes that have been clicked/ tapped by\n// the user. The actual representation of the active pane is deferred to other\n// components (this is done by firing an event with a reference to this\n// selected pane).\n//\n// @demo_type none\n// @set_by Exploded.click\n\n.exploded__pane--is-selected {\n  &, &:hover {\n    background: ui-color(blue, dark);\n    opacity: 1;\n  }\n}\n",".field {\n  @include default(border-radius);\n  background-color: ui-color(gray, dark);\n  display: flex;\n  align-items: center;\n  max-width: 100%;\n  padding: 0 half(default(spacing));\n}\n\n$field--switch--size: multiply(1.5, default(spacing));\n\n.field--switch {\n  padding: 0;\n  background-color: transparent;\n  position: relative;\n\n  > .label {\n    margin: 0;\n    padding-left: multiply(1.5, $field--switch--size);\n    position: relative;\n    line-height: $field--switch--size;\n    color: ui-color(gray, darkest);\n\n    &:after {\n      content: '';\n      display: block;\n      height: multiply($field--switch--size, 0.7);\n      width: multiply(0.3, $field--switch--size);\n      position: absolute;\n      top: half($field--switch--size);\n      left: half($field--switch--size);\n      border-bottom: 2px solid ui-color(blue, darker);\n      border-right: 2px solid ui-color(blue, darker);\n      transform: translate(-50%, -60%) rotate(45deg);\n      display: none;\n    }\n\n    &:before {\n      content: '';\n      display: block;\n      height: $field--switch--size;\n      width: $field--switch--size;\n      background: ui-color(gray);\n      position: absolute;\n      top: 0; left: 0;\n      @include default(border-radius);\n    }\n  }\n\n  > .field__switch:checked + .label:before {\n    background: ui-color(blue);\n  }\n\n  > .field__switch:checked + .label:after {\n    display: block;\n  }\n\n  > .field__switch {\n    position: absolute;\n    top: 0;\n    left: 0;\n    opacity: 0.1;\n  }\n\n  + .field--switch {\n    margin-top: default(spacing);\n  }\n}\n\n.field__icon {\n  flex: 0 0 auto;\n  font-size: 0;\n\n  > .icon {\n    @include icon--recolor(gray, darker);\n  }\n}\n\n.field__input {\n  flex: 1 1 auto;\n  margin: 0;\n  padding: 0;\n  background: transparent;\n  border: none;\n  line-height: default(control-size);\n  font-size: 1.1rem;\n  @include type--default-font-family;\n\n  &::-webkit-input-placeholder {\n    color: rgba(ui-color(gray, darker), 0.5);\n  }\n\n  &::placeholder {\n    color: rgba(ui-color(gray, darker), 0.5);\n  }\n\n  &:focus {\n    outline: none;\n  }\n}\n\n","//*\n// @pattern Page Header\n// @group Partials\n//\n// A group of headings and other page-level information that appears at the\n// top of a given page or section.\n//\n// @since 1.0.0\n\n//*\n// @markup\n// <header class=\"page-header\">\n//   <div class=\"grid grid--vertically-centered\">\n//     <div class=\"grid__item\">\n//       <h1 class=\"type type--heading type--heading-1\">The title</h1>\n//     </div>\n//\n//     <div class=\"grid__item grid__item--no-flex\">\n//       <button class=\"docks-button docks-button--dark\">Action</button>\n//     </div>\n//   </div>\n// </header>\n\n.page-header {\n  background-color: ui-color(gray);\n  padding: default(spacing);\n  padding-bottom: default(spacing);\n  min-height: rem(66);\n\n  .type--heading-1 {\n    margin: -0.5em 0;\n  }\n}\n","$inline-group--spacing: half(default(spacing));\n\n.inline-group {\n  display: inline-flex;\n  flex-wrap: wrap;\n  align-items: center;\n  margin-right: negative($inline-group--spacing);\n  margin-bottom: negative($inline-group--spacing);\n}\n\n.inline-group__item {\n  margin-right: $inline-group--spacing;\n  margin-bottom: $inline-group--spacing;\n}\n","//                               ___\n//                   ___        /  /\\        ___\n//                  /  /\\      /  /:/_      /  /\\\n//    ___     ___  /  /:/     /  /:/ /\\    /  /:/\n//   /__/\\   /  /\\/__/::\\    /  /:/ /::\\  /  /:/\n//   \\  \\:\\ /  /:/\\__\\/\\:\\__/__/:/ /:/\\:\\/  /::\\\n//    \\  \\:\\  /:/    \\  \\:\\/\\  \\:\\/:/~/:/__/:/\\:\\\n//     \\  \\:\\/:/      \\__\\::/\\  \\::/ /:/\\__\\/  \\:\\\n//      \\  \\::/       /__/:/  \\__\\/ /:/      \\  \\:\\\n//       \\__\\/        \\__\\/     /__/:/        \\__\\/\n//                              \\__\\/\n\n//*\n// @pattern List\n//\n// A list allows you to present a set of selectable items vertically. These\n// lists can be be separated into any number of sublists, and two levels of\n// subheadings are available (so, you can have a sublist within a sublist).\n//\n// The sublists can optionally allow a subheading to toggle the visibility of\n// the associated sublist. It also supports the ability to filter the contents\n// of a list to only items matching a given string, hiding subheadings as\n// necessary.\n//\n// @since 1.0.0\n\n\n\n//*\n// The core container for a list. List items can go directly in this container\n// or, if you want to provide toggle-able or filter-able sublists, within a\n// sublist.\n\n.list {\n  padding: 0;\n  margin: default(spacing) 0 double(default(spacing));\n  list-style: none;\n\n  .type--heading {\n    padding-left: default(spacing);\n    padding-right: default(spacing);\n  }\n\n  .popover & {\n    margin-bottom: default(spacing);\n  }\n}\n\n//*\n// An individual item within a list. These items have hover, focus, and active\n// states so that it is clear what item is actionable/ being actioned.\n\n.list__item {\n  // box model\n  display: block;\n  padding: quarter(default(spacing)) default(spacing);\n\n  // backdrop\n  cursor: pointer;\n\n  // type\n  text-decoration: none;\n  color: ui-color(gray, darkest);\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  overflow: hidden;\n\n  &:hover,\n  &:focus {\n    outline: none;\n    background: ui-color(gray, light);\n  }\n\n  &:active {\n    background-color: ui-color(blue);\n    color: ui-color(blue, darker);\n  }\n}\n\n//*\n// An item that is currently active For example, in the sidebar, this class is\n// used for the item representing the currently-active pattern.\n\n.list__item--is-active {\n  &,\n  &:hover,\n  &:focus {\n    background-color: ui-color(blue);\n    color: ui-color(blue, darker);\n  }\n}\n\n//*\n// A list item that is indented on the left to indicate that it is related to\n// the closest, non-indented item above it.\n\n.list__item--indented {\n  padding-left: calc(#{default(spacing)} + 2ch);\n  position: relative;\n\n  &:before {\n    content: \"\";\n    display: block;\n    position: absolute;\n    left: calc(#{default(spacing)} + 1ch);\n    top: 0;\n    height: 100%;\n    width: 2px;\n    background: rgba(ui-color(black), 0.07);\n  }\n\n  &:last-child:before {\n    height: 85%;\n  }\n\n  .list__item:not(.list__item--indented) + &:before {\n    top: 15%;\n    height: 85%;\n  }\n}\n\n//*\n// A subset of items that have their own hading to distinguish them. This\n// subcomponent can contain any number of items and/ or other sublists. This\n// grouping also allows the [`Filterable`](@link filterable) component to\n// accurately hide subsets of the list, including headings within a group\n// where all items are hidden.\n\n.list__group {}\n\n\n\n//*\n// A horizontal list of links separated by slashes.\n\n.link-list {\n  padding: 0;\n  margin: 0;\n  list-style: none;\n  display: flex;\n  flex-wrap: wrap;\n\n  > li {\n    position: relative;\n    flex: 0 0 auto;\n\n    &:after {\n      $link-list__item--separator-height: 80%;\n\n      content: \"\";\n\n      // position\n      position: absolute;\n      top: half(100% - $link-list__item--separator-height);\n      right: -1px;\n      transform: rotate(15deg);\n\n      // box model\n      display: block;\n      height: $link-list__item--separator-height;\n\n      // backdrop\n      border-right: 2px solid rgba(ui-color(gray, darkest), 0.1);\n    }\n\n    &:last-child:after {\n      display: none;\n      margin-right: 0;\n    }\n  }\n}\n\n//*\n// An individual list within a link list. This class should go on the actual\n// anchor (or `button`, if there is no reasonable `href`) element so that\n// there is as large a hit target as possible.\n//\n// Each item (except for the last one) is given a small separator so that it is\n// clear where the hit areas end. This is placed on the containing `li` since\n// the `link-list__item` can be a `button`.\n//\n// In the dark theme, the colors for each list item invert.\n\n.link-list__item {\n  // position\n  position: relative;\n\n  // box model\n  display: block;\n  cursor: pointer;\n  padding: quarter(default(spacing)) half(default(spacing));\n\n  // backdrop\n  @include remove-browser-styling;\n  background: none;\n  border: none;\n  opacity: 0.6;\n\n  // type\n  font-size: 1em;\n  line-height: 1;\n  color: ui-color(gray, darker);\n  transition: opacity 0.25s ease;\n\n  &:hover,\n  &:focus {\n    opacity: 1;\n    outline: none;\n  }\n}\n\n\n\n//*\n// A list that simply arranges the contained `li`s with some spacing between\n// them.\n\n.unstyled-list {\n  margin: 0;\n  padding: 0;\n  list-style: none;\n\n  > li {\n    margin: double(default(spacing)) 0;\n\n    &:first-child {\n      margin-top: 0;\n    }\n  }\n}\n","//        ___                  ___                   ___\n//       /__/\\      ___       /__/|      ___        /__/\\\n//      |  |::\\    /  /\\     |  |:|     /  /\\       \\  \\:\\\n//      |  |:|:\\  /  /:/     |  |:|    /  /:/        \\  \\:\\\n//    __|__|:|\\:\\/__/::\\   __|__|:|   /__/::\\    _____\\__\\:\\\n//   /__/::::| \\:\\__\\/\\:\\_/__/::::\\___\\__\\/\\:\\__/__/::::::::\\\n//   \\  \\:\\~~\\__\\/  \\  \\:\\/\\ ~\\~~\\::::/  \\  \\:\\/\\  \\:\\~~\\~~\\/\n//    \\  \\:\\         \\__\\::/  |~~|:|~~    \\__\\::/\\  \\:\\  ~~~\n//     \\  \\:\\        /__/:/   |  |:|      /__/:/  \\  \\:\\\n//      \\  \\:\\       \\__\\/    |  |:|      \\__\\/    \\  \\:\\\n//       \\__\\/                |__|/                 \\__\\/\n//\n// Mixins are used to include common functionality in components.\n// Use these over placeholders even when no variables are required:\n// `@extends` is more trouble than it's worth, and proper compression\n// mostly solves the problem of duplicated markup from mixins.\n\n//    ___ ___ ___ ___ _      ___   __\n//   |   \\_ _/ __| _ \\ |    /_\\ \\ / /\n//   | |) | |\\__ \\  _/ |__ / _ \\ V /\n//   |___/___|___/_| |____/_/ \\_\\_|\n//\n// =========================================================\n// Placeholders providing common display/ positioning patterns.\n\n@mixin composite-layer {\n  backface-visibility: hidden;\n}\n\n@mixin clearfix {\n  &:after {\n    content: \"\";\n    display: table;\n    clear: both;\n  }\n}\n\n@mixin center {\n  position: absolute;\n  top: 50%; left: 50%;\n  transform: translate(-50%, -50%);\n}\n\n@mixin cover-all {\n  position: absolute;\n  top: 0; left: 0;\n  width: 100%; height: 100%;\n}\n\n@mixin remove-browser-styling {\n  -webkit-appearance: none;\n  -moz-appearance: none;\n}\n\n\n\n//    _____ ___  _   _  ___ _  _\n//   |_   _/ _ \\| | | |/ __| || |\n//     | || (_) | |_| | (__| __ |\n//     |_| \\___/ \\___/ \\___|_||_|\n//\n// ======================================================\n// Placeholders to help with touch devices.\n\n@mixin touch-scroll {\n  overflow: auto;\n  -webkit-overflow-scrolling: touch;\n}\n\n\n\n//    _______   _____ ___\n//   |_   _\\ \\ / / _ \\ __|\n//     | |  \\ V /|  _/ _|\n//     |_|   |_| |_| |___|\n//\n// ======================================================\n// Placholders to add nice features to text content.\n\n@mixin word-wrap {\n  word-break: break-word;\n  hyphens: auto;\n}\n\n@mixin ellipsis {\n  overflow: hidden;\n  white-space: nowrap;\n  text-overflow: ellipsis;\n}\n",".details-sheet {\n  max-width: 90%;\n  position: fixed;\n  top: 50%; left: 50%;\n  transform: translate(-50%, -50%);\n  background-color: white;\n  border-radius: 0.4rem;\n  box-shadow: 0 0 10px rgba(color(black), 0.3);\n  z-index: 20;\n  display: none;\n}\n\n.details-sheet--is-active {\n  display: block;\n}\n\n.details-sheet__overlay {\n  background: rgba(color(black), 0.9);\n  position: absolute;\n  top: 0; bottom: 0;\n  right: 0; left: 0;\n  z-index: 19;\n  display: none;\n}\n\n.details-sheet__overlay--is-active {\n  display: block;\n}\n\n\n.details-sheet__section {\n  padding: 1rem;\n\n  + .details-sheet__section {\n    border-top: 1px solid color(sky-dark);\n  }\n}\n\n.details-sheet__name {\n  display: inline-block;\n  background-color: color(sky-light);\n  padding: 0.1rem 0.25em;\n  border-radius: 0.25em;\n  color: color(slate-light);\n  font-size: 1.2em;\n  font-family: Consolas, monospace;\n  margin: 0;\n}\n\n.details-sheet__subtitle {\n  margin: 0 0 0.5rem;\n  font-size: 0.6rem;\n  text-transform: uppercase;\n  color: color(slate-light);\n  opacity: 0.3;\n  font-weight: 600;\n}\n","//*\n// @pattern Notice\n//\n// A simple, colored container around that emphasizes the contained text. This\n// should be used for important details about a symbol; for example, to\n// indicate that a component is deprecated or experimental.\n//\n// @since 1.0.0\n\n\n//*\n// A regular notice.\n//\n// @markup\n// <div class=\"notice\">\n//   <div class=\"type-container\">\n//     <p>Please don't use this component anymore! It's no good.</p>\n//   </div>\n// </div>\n\n.notice {\n  background-color: ui-color(yellow);\n  width: fit-content;\n  color: ui-color(yellow, dark);\n  padding: 1rem;\n  border-radius: default(border-radius);\n  @include font-size(paragraph-small);\n  position: relative;\n\n  .type, p, code {\n    color: inherit;\n    font-size: inherit;\n  }\n\n  .type--heading {\n    font-weight: 400;\n  }\n}\n\n//*\n// A notice that indicates something is new about the attached symbol.\n//\n// @demo_type joint\n\n.notice--new {\n  background-color: ui-color(blue);\n  color: ui-color(blue, darker);\n}\n"," /*============================================================================\n  Next Popover\n ==============================================================================*/\n\n$popover-tooltip-size: rem(10);\n$popover-max-width: rem(400);\n$popover-min-width: rem(150);\n$popover-max-width-percent: 100%;\n$popover-max-height: rem(800);\n$popover-vertical-margin: half(default(spacing)) + ($popover-tooltip-size / 2);\n$popover-background-color: color(white);\n$popover-section-border: 1px solid color(gray-light);\n$popover-box-shadow: 0 0 0 1px rgba(color(slate), 0.05), 0 2px 7px 1px rgba(color(slate), 0.16);\n\n\n\n.popover__container {\n  position: relative;\n  display: inline-flex;\n  @include z-index(popover-resting, page);\n\n  > *:focus { outline: 0; }\n}\n\n.popover__container--contains-active-popover {\n  @include z-index(popover-active, page);\n}\n\n.popover__container--is-deactivating {\n  @include z-index(popover-deactivating, page);\n}\n\n.popover__container--full-width {\n  display: flex;\n}\n\n\n\n.popover {\n  position: absolute;\n  left: 0;\n  top: 100%;\n\n  transform: scale(0);\n  display: inline-block;\n  max-width: $popover-max-width-percent;\n  margin: $popover-vertical-margin default(spacing);\n\n  background-color: $popover-background-color;\n  border-radius: default(border-radius);\n  opacity: 0;\n  box-shadow: $popover-box-shadow;\n\n  transition: transform 0.35s cubic-bezier(.27,1.41,.53,.97), opacity 0.2s ease;\n}\n\n.popover--is-active {\n  transform: scale(1);\n  opacity: 1;\n}\n\n.popover--is-positioned-above {\n  top: auto;\n  bottom: 100%;\n\n  .popover__tooltip {\n    top: 100%;\n\n    &:after { top: $popover-tooltip-size / -2; }\n  }\n}\n\n\n.popover__tooltip {\n  position: absolute;\n  left: 50%;\n  top: (-2 * $popover-tooltip-size);\n\n  width: ($popover-tooltip-size * 2);\n  height: ($popover-tooltip-size * 2);\n  margin-left: ($popover-tooltip-size * -1);\n  overflow: hidden;\n\n  &:after {\n    content: \"\";\n\n    position: absolute;\n    top: ($popover-tooltip-size * 3 / 2);\n    left: 50%;\n    transform: rotate(45deg);\n\n    margin-left: ($popover-tooltip-size / -2);\n\n    display: block;\n    height: $popover-tooltip-size;\n    width: $popover-tooltip-size;\n\n    background-color: $popover-background-color;\n    box-shadow: $popover-box-shadow;\n  }\n}\n\n\n\n.popover__content-wrapper {\n  display: flex;\n  max-width: $popover-max-width;\n  max-height: $popover-max-height;\n  border-radius: default(border-radius);\n  overflow: hidden;\n}\n\n\n\n.popover__content {\n  flex: 0 0 auto;\n  display: inline-flex;\n  flex-direction: column;\n  max-height: 100%;\n  min-width: $popover-min-width;\n\n  > *:first-child {\n    margin-top: 0;\n  }\n\n  > *:last-child {\n    margin-bottom: 0;\n  }\n}\n\n\n\n\n.popover__pane {\n  flex: 0 1 auto;\n  overflow: auto;\n  -webkit-overflow-scrolling: touch;\n  max-width: 100%;\n}\n","//        ___                              _____        ___          ___\n//       /  /\\                   ___      /  /::\\      /  /\\        /  /\\\n//      /  /:/_                 /  /\\    /  /:/\\:\\    /  /:/_      /  /::\\\n//     /  /:/ /\\  ___     ___  /  /:/   /  /:/  \\:\\  /  /:/ /\\    /  /:/\\:\\\n//    /  /:/ /::\\/__/\\   /  /\\/__/::\\  /__/:/ \\__\\:|/  /:/ /:/_  /  /:/~/:/\n//   /__/:/ /:/\\:\\  \\:\\ /  /:/\\__\\/\\:\\_\\  \\:\\ /  /:/__/:/ /:/ /\\/__/:/ /:/___\n//   \\  \\:\\/:/~/:/\\  \\:\\  /:/    \\  \\:\\/\\  \\:\\  /:/\\  \\:\\/:/ /:/\\  \\:\\/:::::/\n//    \\  \\::/ /:/  \\  \\:\\/:/      \\__\\::/\\  \\:\\/:/  \\  \\::/ /:/  \\  \\::/~~~~\n//     \\__\\/ /:/    \\  \\::/       /__/:/  \\  \\::/    \\  \\:\\/:/    \\  \\:\\\n//       /__/:/      \\__\\/        \\__\\/    \\__\\/      \\  \\::/      \\  \\:\\\n//       \\__\\/                                         \\__\\/        \\__\\/\n\n//*\n// @pattern Slider\n//\n// A simple range slider. Use this component for situations where the user has\n// to select from a continuous range of values with a minimum and maximum. For\n// example, this component is used to change the perspective and pane gap for\n// the `Exploded` component.\n//\n// @since 1.0.0\n\n//*\n// @markup\n// <label class=\"label\" for=\"range\">Try something in range</label>\n// <input class=\"range\" name=\"range\" id=\"range\" type=\"range\">\n\n.range {\n  width: 100%;\n  margin: 0;\n\n  -webkit-appearance: none;\n  appearance: none;\n  background-color: transparent;\n\n  &:focus {\n    outline: none;\n  }\n}\n\n$range__track--size: default(control-size--large);\n$range__thumb--spacing: (0.1 * default(control-size--large));\n$range__thumb--size: ($range__track--size - double($range__thumb--spacing));\n\n@mixin range__track {\n  // box model\n  width: 100%;\n  height: $range__track--size;\n\n  // backdrop\n  cursor: pointer;\n  background-color: ui-color(gray, dark);\n  border-radius: half($range__track--size);\n  padding: $range__thumb--spacing;\n}\n\n@mixin range__thumb {\n  // box model\n  height: $range__thumb--size;\n  width: $range__thumb--size;\n\n  // backdrop\n  box-shadow: 1px 1px 3px rgba(color(black), 0.15);\n  border-radius: half($range__thumb--size);\n  background: ui-color(gray, light);\n  cursor: pointer;\n  -webkit-appearance: none;\n  appearance: none;\n}\n\n.range::-webkit-slider-runnable-track { @include range__track; }\n.range:focus::-webkit-slider-runnable-track { outline: none; }\n.range::-moz-range-track { @include range__track; }\n.range::-ms-track { @include range__track; }\n\n.range::-webkit-slider-thumb { @include range__thumb; }\n.range::-moz-range-thumb { @include range__thumb; }\n.range::-ms-thumb { @include range__thumb; }\n","//        ___          ___          ___                     ___          ___\n//       /  /\\        /  /\\        /  /\\       ___         /  /\\        /  /\\\n//      /  /::\\      /  /:/_      /  /:/_     /  /\\       /  /::|      /  /:/_\n//     /  /:/\\:\\    /  /:/ /\\    /  /:/ /\\   /  /:/      /  /:/:|     /  /:/ /\\\n//    /  /:/~/:/   /  /:/ /:/_  /  /:/ /::\\ /__/::\\     /  /:/|:|__  /  /:/ /:/_\n//   /__/:/ /:/___/__/:/ /:/ /\\/__/:/ /:/\\:\\\\__\\/\\:\\__ /__/:/ |:| /\\/__/:/ /:/ /\\\n//   \\  \\:\\/:::::/\\  \\:\\/:/ /:/\\  \\:\\/:/~/:/   \\  \\:\\/\\\\__\\/  |:|/:/\\  \\:\\/:/ /:/\n//    \\  \\::/~~~~  \\  \\::/ /:/  \\  \\::/ /:/     \\__\\::/    |  |:/:/  \\  \\::/ /:/\n//     \\  \\:\\       \\  \\:\\/:/    \\__\\/ /:/      /__/:/     |  |::/    \\  \\:\\/:/\n//      \\  \\:\\       \\  \\::/       /__/:/       \\__\\/      |  |:/      \\  \\::/\n//       \\__\\/        \\__\\/        \\__\\/                   |__|/        \\__\\/\n\n//*\n// @pattern Resizable\n//\n// A container that can be resized by dragging on a handle\n// (`.resizable__handle`) with a contained iframe that shows the actual demo\n// content. This allows the user to see how the design would actually behave\n// at different viewport widths, and allows for fixed and absolute positioned\n// elements to be displayed in a reasonable way.\n//\n// The JavaScript portion of this component manages the communication of\n// height changes from the `iframe` to make sure that the demo is entirely\n// visible and shows the current width and allows the user to see a small\n// number of preset widths.\n//\n// @since 1.0.0\n\n\n\n$resizable--min-width: 18rem;\n$resizable--border: 1px solid ui-color(gray, darker);\n$resizable--default-transition-timing: 0.3s ease;\n\n$resizable__handle--width: 1.25rem;\n$resizable__handle--groove-height: double(default(spacing));\n$resizable__handle--groove-percentage-width: 0.35;\n\n$resizable__size-button__icon--size: 1.8rem;\n\n\n\n//*\n// The core component of a `Resizable`. This part of the component contains\n// the handle and `iframe`, and is the part of the component that is actually\n// resized when dragging the handle/ using the size buttons. The `min-width`\n// specified here should account for both the `min-width` of the content *and*\n// the width of the handle (which will be positioned absolutely over the right\n// side).\n//\n// @helper docks_resizable\n\n.resizable {\n  // position\n  position: relative;\n\n  // box model\n  margin: 0 auto;\n  width: 100%;\n  min-width: ($resizable--min-width + $resizable__handle--width);\n\n  // backdrop\n  @include default(border-radius);\n\n  // type\n  line-height: 0;\n\n  > .card {\n    position: relative;\n    padding-right: $resizable__handle--width;\n  }\n\n  .iframe {\n    width: 100%;\n    min-height: 10rem;\n    transition: height $resizable--default-transition-timing;\n    overflow: hidden;\n  }\n}\n\n//*\n// Provides a transition that smoothly moves the resizable container from one\n// width to the next. This is not done by default as dragging the handle would\n// appear broken.\n\n.resizable--is-transitioning-width {\n  transition: width $resizable--default-transition-timing;\n}\n\n\n\n//*\n// The handle by which to resize the container. Default style gives two small\n// grooves in the middle of the handle that affords its draggability.\n\n.resizable__handle {\n  // position\n  position: absolute;\n  top: 0; right: 0;\n\n  // box model\n  width: $resizable__handle--width;\n  height: 100%;\n\n  // backdrop\n  cursor: col-resize;\n  background: ui-color(gray, dark);\n  border-radius: 0 default(border-radius) default(border-radius) 0;\n\n  &:hover,\n  &:focus {\n    outline: none;\n  }\n\n  &:after {\n    $resizable__handle--groove-width: $resizable__handle--groove-percentage-width * $resizable__handle--width;\n\n    content: \"\";\n\n    // position\n    position: absolute;\n    top: 50%; left: 50%;\n\n    // box model\n    display: block;\n    height: $resizable__handle--groove-height;\n    width: $resizable__handle--groove-width;\n    margin-top: negative(half($resizable__handle--groove-height));\n    margin-left: negative(half($resizable__handle--groove-width));\n\n    // backdrop\n    border-right: $resizable--border;\n    border-left: $resizable--border;\n  }\n}\n\n\n\n//*\n// A container for all of the information and acions available for the\n// component.\n\n.resizable__actions {\n  display: flex;\n  justify-content: space-between;\n  align-items: flex-end;\n  margin-bottom: half(default(spacing));\n}\n\n\n\n\n//*\n// A small notice that shows the current width of the (content of the) resizable\n// module. This indicator slides in when the size changes (through the use of\n// the `resizable__width-indicator--is-visible` variant).\n//\n// The indicator shows the width in both `px` and `em` values which are\n// contained in the submodules `resizable__width-indicator__px` and\n// `resizable__width-indicator__em`, respectively.\n//\n// @state --is-visible - The indicator is currently being shown.\n\n.resizable__width-indicator {\n  // type\n  color: color(gray-dark);\n  font: 300 1rem/1 Consolas, monospace;;\n\n  // backdrop\n  opacity: 0.4;\n  transition: opacity $resizable--default-transition-timing;\n}\n\n.resizable__width-indicator--is-visible { opacity: 1; }\n\n\n\n//*\n// A vertically-oriented set of buttons that resize the resizable module to\n// predetermined widths. These widths have been set in the Javascript part of\n// this module.\n\n.resizable__size-buttons {\n  display: flex;\n}\n\n\n\n//*\n// A single button that resizes the module.\n//\n// @state --is-active (select)\n// Indicates that this button has been pressed and that the user has not\n// subsequently resized the module in some other way.\n//\n// @state --is-hidden (none)\n// Indicates that the button should be hidden because not enough screen space\n// exists for its resize.\n//\n// @variant --small  (none) - Resizes to a roughly smartphone-sized width.\n// @variant --medium (none) - Resizes to a roughly tablet-sized width.\n// @variant --large  (none) - Resizes to a roughly desktop-sized width.\n\n.resizable__size-button {\n  position: relative;\n  margin-left: half(default(spacing));\n  cursor: pointer;\n\n  opacity: 0.5;\n  transition: opacity $resizable--default-transition-timing;\n\n  > .icon {\n    height: $resizable__size-button__icon--size;\n    width: $resizable__size-button__icon--size;\n\n    @include icon--recolor(gray);\n    transition: fill $resizable--default-transition-timing;\n  }\n\n  &:hover,\n  &:focus,\n  &:active,\n  &.resizable__size-button--is-active {\n    outline: none;\n  }\n\n  &:hover,\n  &:focus {\n    opacity: 0.8;\n  }\n\n  &.resizable__size-button--is-active,\n  &:active {\n    opacity: 1;\n\n    > .icon {\n      fill: color(blue);\n      stroke: color(blue);\n    }\n  }\n}\n\n.resizable__size-button--is-hidden {\n  display: none;\n}\n",".scroll-container {\n  // Contain any interior margins\n  overflow: hidden;\n}\n","//        ___          ___          ___                          ___          ___\n//       /  /\\        /  /\\        /  /\\        ___  ___        /  /\\        /__/\\\n//      /  /:/_      /  /:/_      /  /:/       /  /\\/  /\\      /  /::\\       \\  \\:\\\n//     /  /:/ /\\    /  /:/ /\\    /  /:/       /  /:/  /:/     /  /:/\\:\\       \\  \\:\\\n//    /  /:/ /::\\  /  /:/ /:/_  /  /:/  ___  /  /:/__/::\\    /  /:/  \\:\\  _____\\__\\:\\\n//   /__/:/ /:/\\:\\/__/:/ /:/ /\\/__/:/  /  /\\/  /::\\__\\/\\:\\__/__/:/ \\__\\:\\/__/::::::::\\\n//   \\  \\:\\/:/~/:/\\  \\:\\/:/ /:/\\  \\:\\ /  /:/__/:/\\:\\ \\  \\:\\/\\  \\:\\ /  /:/\\  \\:\\~~\\~~\\/\n//    \\  \\::/ /:/  \\  \\::/ /:/  \\  \\:\\  /:/\\__\\/  \\:\\ \\__\\::/\\  \\:\\  /:/  \\  \\:\\  ~~~\n//     \\__\\/ /:/    \\  \\:\\/:/    \\  \\:\\/:/      \\  \\:\\/__/:/  \\  \\:\\/:/    \\  \\:\\\n//       /__/:/      \\  \\::/      \\  \\::/        \\__\\/\\__\\/    \\  \\::/      \\  \\:\\\n//       \\__\\/        \\__\\/        \\__\\/                        \\__\\/        \\__\\/\n\n//*\n// @pattern Section\n//\n// Sections are simply ways of grouping related content and provising\n// separation between that contained content and \"sibling\" content.\n//\n// Smaller variations are available for more condensed content, like content\n// inside of a popover.\n//\n// @since 1.0.0\n\n\n\n//*\n// A container around some content that provides the vertical separation from\n// other `section`s. This will also remove any top/ bottom padding from the\n// first/ last child, respectively, to avoid more vertical padding than\n// necessary.\n\n.section {\n  margin: double(default(spacing)) 0;\n  padding: default(spacing) 0;\n\n  > *:first-child {\n    &,\n    & > *:first-child {\n      margin-top: 0;\n    }\n  }\n\n  > *:last-child {\n    &,\n    & > *:last-child {\n      margin-bottom: 0;\n    }\n  }\n}\n\n//*\n// A smaller section with no border separating content. Use this variant for\n// places where the base amount of vertical padding is excessive (for example,\n// in popovers or other limited-width containers).\n\n.section--small {\n  border: none;\n  padding: 0;\n  margin: default(spacing) 0;\n}\n\n//*\n// A section with a light gray background that separates it visually from the\n// other sections. Use this to differentiate between significantly different\n// groups of content. It is best to only use this with `section--small` —\n// regular `section`s already have sufficient separation in most cases.\n\n.section--subdued {\n  background: color(gray-light);\n  overflow: hidden;\n\n  &.section--small {\n    padding: default(spacing) 0;\n    margin: 0;\n  }\n}\n\n\n\n//*\n// Use this container for when you want a group of sections to have additional\n// vertical separation from the content around it. The amount of additional\n// space depends on whether the container contains regular or `--small`\n// `section`s.\n//\n// This container is not necessary — for example, sections can sit on their own\n// inside a popover.\n\n.section__container {\n  > .section {\n    &:first-child { margin-top: double(default(spacing)); }\n    &:last-child { margin-bottom: double(default(spacing)); }\n  }\n\n  > .section--small {\n    &:first-child { margin-top: default(spacing); }\n    &:last-child { margin-bottom: default(spacing); }\n  }\n}\n","//        ___          ___                     ___          ___\n//       /  /\\        /  /\\                   /  /\\        /  /\\        ___\n//      /  /:/_      /  /:/_                 /  /:/_      /  /:/       /  /\\\n//     /  /:/ /\\    /  /:/ /\\  ___     ___  /  /:/ /\\    /  /:/       /  /:/\n//    /  /:/ /::\\  /  /:/ /:/_/__/\\   /  /\\/  /:/ /:/_  /  /:/  ___  /  /:/\n//   /__/:/ /:/\\:\\/__/:/ /:/ /\\  \\:\\ /  /:/__/:/ /:/ /\\/__/:/  /  /\\/  /::\\\n//   \\  \\:\\/:/~/:/\\  \\:\\/:/ /:/\\  \\:\\  /:/\\  \\:\\/:/ /:/\\  \\:\\ /  /:/__/:/\\:\\\n//    \\  \\::/ /:/  \\  \\::/ /:/  \\  \\:\\/:/  \\  \\::/ /:/  \\  \\:\\  /:/\\__\\/  \\:\\\n//     \\__\\/ /:/    \\  \\:\\/:/    \\  \\::/    \\  \\:\\/:/    \\  \\:\\/:/      \\  \\:\\\n//       /__/:/      \\  \\::/      \\__\\/      \\  \\::/      \\  \\::/        \\__\\/\n//       \\__\\/        \\__\\/                   \\__\\/        \\__\\/\n\n//*\n// @pattern Select\n//\n// A custom `select` element. In order to present these in the same way across\n// browsers, most of the styling is done on a node wrapped around an actual\n// `select` element, and a bit of JavaScript that translates the focus/ blur\n// on the contained `select` into a state class.\n//\n// @since 1.0.0\n\n\n\n$select--font-size: (font-size(control) * 0.9);\n$select--horizontal-padding: default(control-padding);\n$select--line-height: default(control-size);\n$select--icon-size: $select--font-size / 1.6;\n\n\n\n//*\n// The wrapper around a `select`. This wrapper provides most of the visual\n// styling, including the focus styling. This part of the component also\n// creates a triangle icon in place of the browser-supplied one.\n//\n// @helper\n// <%= docks_select options: %w(Super_long_option_that_is_quite_long normal_size SMALL) %>\n\n.select {\n  // position\n  position: relative;\n\n  // box model\n  display: inline-block;\n\n  // backdrop\n  border-radius: default(border-radius);\n  background-color: ui-color(gray);\n\n  &:after {\n    content: \"\";\n\n    // position\n    position: absolute;\n    right: $select--horizontal-padding;\n    top: 50%;\n    transform: rotate(45deg);\n\n    // box model\n    display: block;\n    height: $select--icon-size;\n    width: $select--icon-size;\n    margin-top: (-0.75 * $select--icon-size);\n\n    // backdrop\n    border: solid rgba(ui-color(gray, darker), 0.5);\n    border-width: 0 2px 2px 0;\n    pointer-events: none;\n  }\n\n  + .docks-button {\n    margin-left: half(default(spacing));\n  }\n}\n\n//*\n// This state is applied to a `select` whose contained input is focused.\n\n.select--is-focused {\n  border-color: color(blue);\n}\n\n//*\n// A select that should be displayed in a monospace font (for example, because\n// it is choosing a class name).\n\n.select--code {\n  > .select__input {\n    @include type--monospace-font-family;\n  }\n}\n\n\n\n//*\n// The actual `select`. Most of the styles here go to undoing the default\n// browser styles for `select`s. All of the font sizing for the component must\n// be placed here for those styles to display correctly.\n\n.select__input {\n  // box model\n  @include remove-browser-styling;\n  box-sizing: border-box;\n  display: block;\n  width: 100%;\n  max-width: none;\n  height: auto;\n  padding: 0 (double($select--horizontal-padding) + $select--icon-size) 0 $select--horizontal-padding;\n\n  // backdrop\n  background: transparent;\n  border: none;\n\n  // type\n  font-size: $select--font-size;\n  line-height: default(control-size);\n  font-family: inherit;\n  color: ui-color(gray, darker);\n  // font-family: Consolas, monospace;\n\n  &:focus {\n    outline: none;\n    border: none;\n  }\n\n  > option {\n    color: color(slate);\n  }\n}\n\n// All of the below hacks courtesy of Todd Parker's fine worK here:\n// http://jsbin.com / yaruh / 49 / edit\n\n// Hides native select arrow in IE 10+\n_:-ms-input-placeholder, :root .select__input::-ms-expand {\n  display: none;\n}\n\n// Hides blue background on focus in IE 10+\n_:-ms-input-placeholder, :root .select__input:focus::-ms-value {\n  background: transparent;\n}\n\n// Crazy hacks to target FF and clip the native select arrow\n@supports (-moz-appearance:meterbar) and (background-blend-mode:difference,normal) {\n\n  _::-moz-progress-bar,\n  body:last-child .select__input__wrapper {\n    overflow: hidden;\n  }\n\n  _::-moz-progress-bar,\n  body:last-child .select__input {\n    width: calc(100% + 30px);\n  }\n}\n\n// Kills the stupid focus ring in FF\n.select__input:-moz-focusring {\n  color: transparent;\n  text-shadow: 0 0 0 black;\n}\n","//                ___                                  ___\n//        ___    /  /\\        _____                   /  /\\\n//       /  /\\  /  /::\\      /  /::\\                 /  /:/_\n//      /  /:/ /  /:/\\:\\    /  /:/\\:\\  ___     ___  /  /:/ /\\\n//     /  /:/ /  /:/~/::\\  /  /:/~/::\\/__/\\   /  /\\/  /:/ /:/_\n//    /  /::\\/__/:/ /:/\\:\\/__/:/ /:/\\:\\  \\:\\ /  /:/__/:/ /:/ /\\\n//   /__/:/\\:\\  \\:\\/:/__\\/\\  \\:\\/:/~/:/\\  \\:\\  /:/\\  \\:\\/:/ /:/\n//   \\__\\/  \\:\\  \\::/      \\  \\::/ /:/  \\  \\:\\/:/  \\  \\::/ /:/\n//        \\  \\:\\  \\:\\       \\  \\:\\/:/    \\  \\::/    \\  \\:\\/:/\n//         \\__\\/\\  \\:\\       \\  \\::/      \\__\\/      \\  \\::/\n//               \\__\\/        \\__\\/                   \\__\\/\n\n//*\n// @pattern Table\n//\n// Tables are used to present tabular data only — never for layout! These tables\n// are smarter than the average table, however. They will determine their\n// intrinsic size (up to a stylesheet-specified maximum) and, when the space\n// available to them is less than that size, they will begin to scroll.\n//\n// As you scroll, the first column will stay fixed, so you always have context,\n// and the any given column will always be small enough to be fully visible. Not\n// only that, but the table provides both keyboard input and interface elements\n// that allow you to quickly shift to overscrolled columns.\n//\n// @since 1.0.0\n\n\n\n$table--border: 1px solid color(gray-light);\n$table--border-radius: double(default(border-radius));\n$table--box-shadow-size: 3px 0 4px -1px;\n\n\n\n//*\n// A smarter `table` element. The `min-width` placed here will not actually\n// be the minimum width of the rendered table; the provided minimum width will\n// instead be used as the maximum width allowed in determining the preferred/\n// intrinsic size of the table cells. That is, a table whose natural size is\n// less than this amount will not overflow until the space it has is less than\n// its intrinsic size, where a table with large cells will overflow at the\n// provided `min-width` breakpoint.\n//\n// Visually, all tables will be 100% width. As noted above, tables will overflow\n// once the lesser of the `min-width` below or the intrisic size of the table\n// is reached. This overflowing is managed by the JavaScript component.\n//\n// @helper docks_table\n\n.table {\n  width: 100%;\n  min-width: rem(500);\n\n  border-collapse: separate;\n  border-spacing: 0;\n}\n\n\n\n//*\n// The outermost wrapper around a table. This wrapper is used to signal to the\n// entire component when the table is in overflow (via the\n// `table__container--is-overflowing` state). Doing so on the outmost container\n// allows adjustments to both the table itself and the `table__actions`.\n//\n// In addition, `table__containers` will automatically create the required\n// space between themselves and other content.\n\n.table__container {\n  margin: default(spacing) auto;\n}\n\n//*\n// Signals to the `table` that it should force the first cell in each row\n// to float about the rest of the rows (the required left padding on the\n// second cell in each row to account for the absolutely-positioned first cell\n// is done automatically by the JavaScript side of things, as is the\n// equalization of all of the first cells' widths). Additionally, this\n// state causes the `table__actions` to be made visible.\n//\n// @set_by Table#check_for_overflow\n// @demo_type none\n\n.table__container--is-overflowing {\n  .table__cell:first-child {\n    position: absolute;\n    @include z-index(cell-persistant, table);\n    left: 0;\n\n    height: 100%;\n\n    // Start box shadow as transparent so it can be animated into view when\n    // the table is actually being scrolled.\n    box-shadow: $table--box-shadow-size rgba(color(black), 0);\n    transition: box-shadow 0.2s ease;\n  }\n\n  .table__actions {\n    transform: translateY(0);\n    max-height: 3rem;\n    padding-bottom: half(default(spacing));\n  }\n}\n\n\n\n//*\n// A wrapper around the `table` that allows it to scroll when the minimum\n// width of its columns (their intrinsic width or their width when the table\n// is larger than the `min-width` set on `table`) is larger than the space\n// available to this container.\n\n.table__scroller {\n  max-width: 100%;\n  overflow-x: auto;\n  overflow-y: hidden;\n  -webkit-overflow-scrolling: touch;\n}\n\n//*\n// The state that is added by the JavaScript component when the table is\n// overflowed **and** the scroll position of this subcomponent is not fully\n// pinned to the left.\n//\n// @set_by Table#handle_scroll, Table#shift_table\n\n.table__scroller--is-scrolled {\n  .table__cell:first-child {\n    box-shadow: $table--box-shadow-size rgba(color(black), 0.1);\n  }\n}\n\n\n\n//*\n// The wrapper around a `table` that provides a few visual pieces. Most\n// noticeably, this adds the border and border radius on the outside of the\n// table. These pieces must be on this container rather than the\n// `table__container` subcomponent because it should only wrap around the\n// `table`, and not the `table__actions`. These rules can't be on the\n// `table__scroller` subcomponent, either, because it must be `overflow: hidden`\n// (to hide the parts outside the rounded corners), where the scroller must\n// be allowed to scroll.\n//\n// More importantly, however, this container is `position: relative` and, as\n// such, acts as the element against which the persistant cells are\n// positioned. These rules can't be on the `table__scroller` because it scrolls,\n// where the persistant cells should be fixed even as the rest of the table\n// scrolls.\n\n.table__backdrop {\n  // position\n  position: relative;\n  @include z-index(backdrop, table);\n\n  // box model\n  max-width: 100%;\n  clear: both;\n\n  // backdrop\n  overflow: hidden;\n  border: $table--border;\n  border-radius: $table--border-radius;\n}\n\n\n\n//*\n// A container around the actions that can be performed on the `table`. For now,\n// this includes only the segmented button to shift the table right/ left by\n// one column.\n\n.table__actions {\n  transform: translateY(140%);\n  max-height: 0;\n  float: right;\n\n  transition: transform 0.3s $bouncy-transition,\n              max-height 0.3s ease,\n              padding-bottom 0.3s ease;\n}\n\n\n\n//*\n// The header row of the table.\n\n.table__header {\n  font-weight: 400;\n  padding: 0;\n  text-align: left;\n}\n\n\n\n//*\n// The container around the rows that make up the body of the table.\n\n.table__body {\n  // Striped rows!\n  > .table__row:nth-child(odd) > .table__cell {\n    background-color: color(gray-lighter);\n  }\n}\n\n\n\n//*\n// A row of table cells.\n\n.table__row {\n  // Hide the overflow so that box shadows on persistant cells don't bleed\n  // between rows.\n  overflow: hidden;\n}\n\n\n\n//*\n// An individual table cell.\n\n.table__cell {\n  position: relative;\n  @include z-index(cell, table);\n  vertical-align: top;\n  padding: half(default(spacing));\n  background-color: color(white);\n}\n\n//*\n// A table cell with center-aligned text.\n\n.table__cell--centered {\n  text-align: center;\n}\n","//                ___                                             ___\n//        ___    /  /\\        _____                   ___        /  /\\        ___\n//       /  /\\  /  /::\\      /  /::\\                 /  /\\      /  /:/_      /  /\\\n//      /  /:/ /  /:/\\:\\    /  /:/\\:\\  ___     ___  /  /:/     /  /:/ /\\    /  /:/\n//     /  /:/ /  /:/~/::\\  /  /:/~/::\\/__/\\   /  /\\/__/::\\    /  /:/ /::\\  /  /:/\n//    /  /::\\/__/:/ /:/\\:\\/__/:/ /:/\\:\\  \\:\\ /  /:/\\__\\/\\:\\__/__/:/ /:/\\:\\/  /::\\\n//   /__/:/\\:\\  \\:\\/:/__\\/\\  \\:\\/:/~/:/\\  \\:\\  /:/    \\  \\:\\/\\  \\:\\/:/~/:/__/:/\\:\\\n//   \\__\\/  \\:\\  \\::/      \\  \\::/ /:/  \\  \\:\\/:/      \\__\\::/\\  \\::/ /:/\\__\\/  \\:\\\n//        \\  \\:\\  \\:\\       \\  \\:\\/:/    \\  \\::/       /__/:/  \\__\\/ /:/      \\  \\:\\\n//         \\__\\/\\  \\:\\       \\  \\::/      \\__\\/        \\__\\/     /__/:/        \\__\\/\n//               \\__\\/        \\__\\/                              \\__\\/\n\n//*\n// @pattern Tablist\n//\n// Tablists are used to create groups of related content that is conditionally\n// shown or hidden based on the selected tab. The JavaScript part of this\n// components ensures that the required accessibility-related markup is added\n// to the tabs, and a number of different styles are available depending on\n// the context in which the tabs are being used.\n//\n// @since 1.0.0\n\n//*\n// The container for a set of tabs. While panels and tabs both use `tablist`\n// as their base component, only `tablist__tab`s are child nodes of this\n// component; `tablist__panel`s (and their container) are separate from the\n// document to allow tabs to move around the page independently of the content\n// they actually activate.\n//\n// The `tablist--manages-url` variant is unique in that it has no visual\n// differences, but will preserve the selected tab via a query string parameter\n// and restore the selected tab on subsequent page loads. To add this\n// functionality, simply pass `true` for the `:manage_url` option of the\n// `docks_tablist` view helper.\n//\n// @helper docks_tablist\n\n.tablist {\n  // box model\n  margin: 0;\n  padding: 0;\n  display: flex;\n  justify-content: center;\n  padding: half(default(spacing));\n  margin-right: negative(half(default(spacing)));\n\n  // backdrop\n  list-style: none;\n}\n\n//*\n// A larger set of tabs (both in terms of the font size of the tabs and the\n// padding within each tab).\n//\n// @set_by :size (:large)\n\n.tablist--large {\n  margin: double(default(spacing)) 0;\n\n  > .tablist__tab {\n    @include font-size(tablist--large);\n    line-height: 1;\n    padding: default(spacing) multiply(default(spacing), 2.5) multiply(default(spacing), 1.2);\n    border: none !important;\n    opacity: 1 !important;\n  }\n\n  > .tablist__tab--is-active {\n    background-color: ui-color(gray, light);\n  }\n}\n\n//*\n// A variation of the tablist that forces the JavaScript to preserve the\n// selected tab and reload that tab on subsequent page loads.\n//\n// @demo_type none\n// @set_by :manage_url\n\n.tablist--manages-url {}\n\n\n\n\n//*\n// A single tab in the tablist. Tabs will be a relatively light color by\n// default with progressively darker shades used on `:focus`/`:hover` and when\n// `:active`.\n//\n// Tabs should still work even when there is no JavaScript or CSS. To make this\n// work, ensure that each `tablist__tab` is an `a` tag with an `href` that\n// points to the `id` of the relevant `tablist__panel`. Likewise, the `id`s of\n// the tab and panel should match up vai the `aria-controls` and\n// `aria-labelledby` properties. The JavaScript component, if run, will\n// guarantee all of these associations.\n//\n// @helper docks_tablist_tab\n\n.tablist__tab {\n  // box model\n  display: inline-block;\n  padding: 0 default(control-padding);\n\n  // backdrop\n  opacity: 0.3;\n  overflow: hidden;\n  border: 1px solid transparent;\n  border-radius: default(border-radius);\n  transition: opacity 0.3s ease, border-color 0.3s ease;\n\n  // type\n  @include font-size(control);\n  line-height: default(control-size);\n  color: ui-color(gray, darker);\n  text-align: center;\n  text-decoration: none;\n  white-space: nowrap;\n  text-overflow: ellipsis;\n\n  &:focus,\n  &:hover {\n    outline: none;\n    opacity: 0.5;\n  }\n\n  > .icon {\n    height: double(default(spacing));\n    width: double(default(spacing));\n    @include icon--recolor(gray, dark);\n    stroke-width: 3px;\n  }\n}\n\n//*\n// The variation added to the tab whose corresponding tab is currently\n// visible. This class can either be applied manually by setting the `:active?`\n// argument to the helper method to `true` or by clicking on the correct tab\n// (which does all the required attribute manipulations through the JavaScript\n// component).\n//\n// @demo_type none\n// @set_by :active?\n\n.tablist__tab--is-active {\n  &, &:hover, &:focus {\n    border-color: ui-color(gray, darker);\n    opacity: 1;\n  }\n}\n\n//*\n// The text within a tab. This container is required in order for the text and\n// (optional) icon to be above one another.\n\n.tablist__tab__text {\n  display: block;\n}\n\n\n\n//*\n// A panel that contains the content that should be shown when the associated\n// tab is active.\n//\n// @helper docks_tablist_panel\n\n.tablist__panel {\n  display: none;\n}\n\n//*\n// A state indicating that the associated tab is active and the contents of\n// this panel should be made visible. There is no animation when switching\n// between tabs — they simply pop in and out of view.\n//\n// @demo_type none\n// @set_by :active?\n\n.tablist__panel--is-active {\n  display: block;\n}\n\n\n\n//*\n// A container around all of the panels for a tablist. This container\n// technically does nothing, but is a nice way to isolate a set of tab panels\n// from the surrounding content.\n\n.tablist__panel-container {}\n",".vertical-spacer {\n    margin: half(default(spacing)) 0;\n}\n",".vertical-stack {\n  display: flex;\n  flex-direction: column;\n  align-self: stretch;\n  width: 100%;\n}\n\n.vertical-stack__item {\n  flex: 1 1 0px;\n  max-width: 100%;\n  overflow-x: hidden;\n  overflow-y: auto;\n  -webkit-overflow-scrolling: touch;\n}\n\n.vertical-stack__item--fixed {\n  flex: 0 0 auto;\n  overflow: visible;\n}\n","body {\n  position: relative;\n\n  &.x-ray__helpers--x-ray-is-active {\n    overflow: hidden;\n  }\n}\n\n.x-ray {\n  background: ui-color(white);\n  position: absolute;\n  top: 0; bottom: 0;\n  left: 0; right: 0;\n  z-index: -1;\n  overflow-x: hidden;\n  overflow-y: auto;\n  opacity: 0;\n  transition: opacity 0.3s ease;\n  min-height: 100%;\n\n  .page-header {\n    flex: 0 0 auto;\n  }\n}\n\n.x-ray--is-active {\n  opacity: 1;\n  z-index: 1200;\n}\n\n\n\n.x-ray__content {\n  padding-bottom: 3rem;\n}\n\n\n.x-ray__list {\n  padding: default(spacing);\n  background-color: ui-color(gray, light);\n}\n\n.x-ray__closer {\n  background: transparent;\n  border: none;\n  padding: 0;\n  appearance: none;\n}\n\n\n\n.x-ray__diagram {\n  padding: default(spacing) 0 0;\n  background: ui-color(gray);\n}\n\n\n.x-ray__details {\n  display: none;\n}\n\n.x-ray__details--is-visible {\n  display: block;\n}\n\n.x-ray__details__tagname {\n  display: inline-block;\n  font-size: 0.75em;\n  background-color: ui-color(gray, light);\n  padding: 0.3em 0.4em 0.2em;\n  @include default(border-radius);\n  line-height: 1;\n  color: ui-color(gray, darker);\n  margin-right: 0.25rem;\n}\n\n.x-ray__details__description {\n  margin-bottom: (2 * default(spacing));\n}\n","//        ___                 _____        ___                      ___          ___\n//       /  /\\      ___      /  /::\\      /  /\\        _____       /  /\\        /  /\\\n//      /  /:/_    /  /\\    /  /:/\\:\\    /  /:/_      /  /::\\     /  /::\\      /  /::\\\n//     /  /:/ /\\  /  /:/   /  /:/  \\:\\  /  /:/ /\\    /  /:/\\:\\   /  /:/\\:\\    /  /:/\\:\\\n//    /  /:/ /::\\/__/::\\  /__/:/ \\__\\:|/  /:/ /:/_  /  /:/~/::\\ /  /:/~/::\\  /  /:/~/:/\n//   /__/:/ /:/\\:\\__\\/\\:\\_\\  \\:\\ /  /:/__/:/ /:/ /\\/__/:/ /:/\\:/__/:/ /:/\\:\\/__/:/ /:/___\n//   \\  \\:\\/:/~/:/  \\  \\:\\/\\  \\:\\  /:/\\  \\:\\/:/ /:/\\  \\:\\/:/~/:|  \\:\\/:/__\\/\\  \\:\\/:::::/\n//    \\  \\::/ /:/    \\__\\::/\\  \\:\\/:/  \\  \\::/ /:/  \\  \\::/ /:/ \\  \\::/      \\  \\::/~~~~\n//     \\__\\/ /:/     /__/:/  \\  \\::/    \\  \\:\\/:/    \\  \\:\\/:/   \\  \\:\\       \\  \\:\\\n//       /__/:/      \\__\\/    \\__\\/      \\  \\::/      \\  \\::/     \\  \\:\\       \\  \\:\\\n//       \\__\\/                            \\__\\/        \\__\\/       \\__\\/        \\__\\/\n\n//*\n// @pattern Sidebar\n// @group Partials\n//\n// The main sidebar for the page. This sidebar is activated by a toggle\n// (`sidebar__toggler`) and slides over the main content (without moving the\n// main content).\n//\n// @since 1.0.0\n\n//*\n// The main piece of the sidebar. This provides the visual backing of the\n// sidebar and manages the reveal/ hide transition.\n\n.sidebar {\n  // position\n  position: absolute;\n  left: 0; top: 0;\n  -webkit-transform: translate3d(-100%, 0, 0);\n  transform: translate3d(-100%, 0, 0);\n  transition: transform 0.2s ease;\n  max-width: 15rem;\n\n  // box model\n  display: flex;\n  height: 100vh;\n\n  // backdrop\n  background-color: ui-color(white);\n  @include default(box-shadow);\n\n  @include after(40rem) {\n    position: static;\n    transform: translate3d(0, 0, 0);\n  }\n}\n\n//*\n// The state that is added by the JavaScript component when the sidebar is\n// visible.\n\n.sidebar--is-active {\n  transform: translate3d(0, 0, 0);\n}\n\n\n\n//*\n// The container for the item that should activate the sidebar. The JavaScript\n// component will look for any instances of this class and will attach `click`\n// handlers that that toggle the sidebar's visibility.\n\n.sidebar__toggler {\n  background: transparent;\n  padding: 0;\n  margin: 0;\n  appearance: none;\n  border: none;\n\n  &:focus {\n    outline: none;\n  }\n\n  // @include after(40rem) {\n  //   display: none;\n  // }\n}\n"],"sourceRoot":"/source/"} */