docks_theme_api 1.0.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +15 -0
- data/.babelrc +4 -0
- data/.editorconfig +8 -0
- data/.eslintrc +115 -0
- data/.gitignore +24 -0
- data/.rubocop.yml +20 -0
- data/.travis.yml +16 -0
- data/Gemfile +4 -0
- data/README.md +5 -0
- data/Rakefile +3 -0
- data/assets/images/icons.svg +63 -0
- data/assets/scripts/coffeescript/pattern_library_helpers.coffee +8 -0
- data/assets/scripts/javascript/pattern_library_helpers.js +11 -0
- data/assets/scripts/pattern_library.js +10380 -0
- data/assets/scripts/pattern_library_demo.js +0 -0
- data/assets/styles/less/pattern-library-helpers.less +103 -0
- data/assets/styles/pattern-library-demo.css +1882 -0
- data/assets/styles/pattern-library.css +1882 -0
- data/assets/styles/sass/pattern-library-helpers.sass +90 -0
- data/assets/styles/scss/pattern-library-helpers.scss +99 -0
- data/assets/styles/stylus/pattern-library-helpers.styl +90 -0
- data/assets/templates/erb/demo.erb +26 -0
- data/assets/templates/erb/layouts/demo.erb +17 -0
- data/assets/templates/erb/layouts/pattern.erb +76 -0
- data/assets/templates/erb/partials/sidebar.erb +124 -0
- data/assets/templates/erb/partials/symbols/class.erb +1 -0
- data/assets/templates/erb/partials/symbols/demo.erb +40 -0
- data/assets/templates/erb/partials/symbols/factory.erb +70 -0
- data/assets/templates/erb/partials/symbols/function.erb +103 -0
- data/assets/templates/erb/partials/symbols/mixin.erb +62 -0
- data/assets/templates/erb/partials/symbols/variable.erb +59 -0
- data/assets/templates/erb/pattern.erb +102 -0
- data/assets/templates/haml/demo.haml +14 -0
- data/assets/templates/haml/layouts/demo.haml +6 -0
- data/assets/templates/haml/layouts/pattern.haml +38 -0
- data/assets/templates/haml/partials/sidebar.haml +68 -0
- data/assets/templates/haml/partials/symbols/class.haml +1 -0
- data/assets/templates/haml/partials/symbols/demo.haml +23 -0
- data/assets/templates/haml/partials/symbols/factory.haml +38 -0
- data/assets/templates/haml/partials/symbols/function.haml +54 -0
- data/assets/templates/haml/partials/symbols/mixin.haml +31 -0
- data/assets/templates/haml/partials/symbols/variable.haml +22 -0
- data/assets/templates/haml/pattern.haml +54 -0
- data/assets/templates/slim/demo.slim +24 -0
- data/assets/templates/slim/layouts/demo.slim +5 -0
- data/assets/templates/slim/layouts/pattern.slim +48 -0
- data/assets/templates/slim/partials/sidebar.slim +112 -0
- data/assets/templates/slim/partials/symbols/class.slim +1 -0
- data/assets/templates/slim/partials/symbols/demo.slim +30 -0
- data/assets/templates/slim/partials/symbols/factory.slim +57 -0
- data/assets/templates/slim/partials/symbols/function.slim +81 -0
- data/assets/templates/slim/partials/symbols/mixin.slim +45 -0
- data/assets/templates/slim/partials/symbols/variable.slim +35 -0
- data/assets/templates/slim/pattern.slim +63 -0
- data/docks_config.rb +32 -0
- data/docks_theme_api.gemspec +37 -0
- data/gulpfile.js +88 -0
- data/karma.conf.js +6 -0
- data/lib/docks_theme_api/components/base_component.rb +99 -0
- data/lib/docks_theme_api/components/code_block_component.rb +10 -0
- data/lib/docks_theme_api/components/popover_component.rb +15 -0
- data/lib/docks_theme_api/components/table_component.rb +34 -0
- data/lib/docks_theme_api/components/tablist_component.rb +11 -0
- data/lib/docks_theme_api/components.rb +21 -0
- data/lib/docks_theme_api/helpers/ui_helper.rb +69 -0
- data/lib/docks_theme_api/theme.rb +21 -0
- data/lib/docks_theme_api.rb +1 -0
- data/package.json +60 -0
- data/source/behaviors/filterable/filterable.coffee +353 -0
- data/source/behaviors/filterable/filterable.js +0 -0
- data/source/behaviors/filterable/filterable.scss +34 -0
- data/source/behaviors/filterable/package.json +3 -0
- data/source/behaviors/index.js +0 -0
- data/source/components/avatar/avatar.erb +20 -0
- data/source/components/avatar/avatar.js +142 -0
- data/source/components/avatar/avatar.scss +200 -0
- data/source/components/avatar/avatar_container.erb +13 -0
- data/source/components/avatar/package.json +3 -0
- data/source/components/avatar/spec/avatar_spec.js +81 -0
- data/source/components/badge/badge.scss +158 -0
- data/source/components/button/button.scss +213 -0
- data/source/components/card/card.scss +32 -0
- data/source/components/code_block/code-block.scss +353 -0
- data/source/components/code_block/code_block.erb +95 -0
- data/source/components/code_block/code_block.js +444 -0
- data/source/components/code_block/package.json +3 -0
- data/source/components/code_block/spec/code_block_spec.js +10 -0
- data/source/components/demo/demo.js +244 -0
- data/source/components/demo/demo.scss +90 -0
- data/source/components/demo/package.json +3 -0
- data/source/components/exploded/exploded.erb +25 -0
- data/source/components/exploded/exploded.js +694 -0
- data/source/components/exploded/exploded.scss +166 -0
- data/source/components/exploded/package.json +3 -0
- data/source/components/field/field.js +24 -0
- data/source/components/field/field.scss +101 -0
- data/source/components/field/package.json +3 -0
- data/source/components/header/header.scss +33 -0
- data/source/components/iframe/iframe.erb +12 -0
- data/source/components/iframe/iframe.js +381 -0
- data/source/components/iframe/package.json +3 -0
- data/source/components/index.js +37 -0
- data/source/components/inline_group/inline-group.scss +14 -0
- data/source/components/internal_link/internal_link.js +49 -0
- data/source/components/internal_link/package.json +3 -0
- data/source/components/list/list.scss +230 -0
- data/source/components/modal/modal.coffee +84 -0
- data/source/components/modal/modal.erb +19 -0
- data/source/components/modal/modal.js +0 -0
- data/source/components/modal/modal.scss +57 -0
- data/source/components/modal/package.json +3 -0
- data/source/components/notice/notice.scss +48 -0
- data/source/components/popover/package.json +3 -0
- data/source/components/popover/popover.coffee +562 -0
- data/source/components/popover/popover.erb +21 -0
- data/source/components/popover/popover.js +0 -0
- data/source/components/popover/popover.scss +139 -0
- data/source/components/range/range.scss +78 -0
- data/source/components/resizable/package.json +3 -0
- data/source/components/resizable/resizable.erb +30 -0
- data/source/components/resizable/resizable.js +250 -0
- data/source/components/resizable/resizable.scss +245 -0
- data/source/components/resizable/size_buttons.js +249 -0
- data/source/components/scroll_container/package.json +3 -0
- data/source/components/scroll_container/scroll-container.scss +4 -0
- data/source/components/scroll_container/scroll_container.js +24 -0
- data/source/components/section/section.scss +99 -0
- data/source/components/select/package.json +3 -0
- data/source/components/select/select.erb +21 -0
- data/source/components/select/select.js +35 -0
- data/source/components/select/select.scss +163 -0
- data/source/components/table/package.json +3 -0
- data/source/components/table/table.erb +16 -0
- data/source/components/table/table.js +351 -0
- data/source/components/table/table.scss +236 -0
- data/source/components/tablist/package.json +3 -0
- data/source/components/tablist/tablist.erb +13 -0
- data/source/components/tablist/tablist.js +246 -0
- data/source/components/tablist/tablist.scss +191 -0
- data/source/components/tablist/tablist_panel.erb +14 -0
- data/source/components/tablist/tablist_tab.erb +20 -0
- data/source/components/toggle/package.json +3 -0
- data/source/components/toggle/toggle.erb +11 -0
- data/source/components/toggle/toggle.js +211 -0
- data/source/components/toggle/toggle_container.erb +30 -0
- data/source/components/vertical_spacer/vertical-spacer.scss +3 -0
- data/source/components/vertical_stack/vertical-stack.scss +19 -0
- data/source/components/xray/package.json +3 -0
- data/source/components/xray/xray.erb +50 -0
- data/source/components/xray/xray.js +123 -0
- data/source/components/xray/xray.scss +79 -0
- data/source/foundation/app/app.js +15 -0
- data/source/foundation/app/package.json +3 -0
- data/source/pattern-library-demo.scss +13 -0
- data/source/pattern-library.scss +13 -0
- data/source/pattern_library.js +8 -0
- data/source/pattern_library_demo.js +8 -0
- data/source/structures/index.js +11 -0
- data/source/structures/sidebar/package.json +3 -0
- data/source/structures/sidebar/sidebar.js +69 -0
- data/source/structures/sidebar/sidebar.scss +79 -0
- data/source/utilities/builder/builder.js +138 -0
- data/source/utilities/builder/package.json +3 -0
- data/source/utilities/client/client.js +7 -0
- data/source/utilities/client/package.json +3 -0
- data/source/utilities/colors/colors.scss +112 -0
- data/source/utilities/defaults/defaults.scss +38 -0
- data/source/utilities/dom_cache/dom_cache.js +24 -0
- data/source/utilities/dom_cache/package.json +3 -0
- data/source/utilities/events/events.js +25 -0
- data/source/utilities/events/package.json +3 -0
- data/source/utilities/font_sizes/font-sizes.scss +85 -0
- data/source/utilities/foundation/a11y.scss +10 -0
- data/source/utilities/foundation/base.scss +29 -0
- data/source/utilities/foundation/icon.scss +114 -0
- data/source/utilities/foundation/layout.scss +67 -0
- data/source/utilities/foundation/page.scss +39 -0
- data/source/utilities/foundation/type.scss +208 -0
- data/source/utilities/functions/functions.scss +127 -0
- data/source/utilities/keycodes/keycodes.js +23 -0
- data/source/utilities/keycodes/package.json +3 -0
- data/source/utilities/markup/markup.js +90 -0
- data/source/utilities/markup/package.json +3 -0
- data/source/utilities/media/media.scss +172 -0
- data/source/utilities/mixins/mixins.scss +89 -0
- data/source/utilities/naming_convention/naming_convention.js +3 -0
- data/source/utilities/naming_convention/package.json +3 -0
- data/source/utilities/numbers/numbers.js +14 -0
- data/source/utilities/numbers/package.json +3 -0
- data/source/utilities/painting/package.json +3 -0
- data/source/utilities/painting/painting.js +7 -0
- data/source/utilities/pattern/package.json +3 -0
- data/source/utilities/pattern/pattern.js +50 -0
- data/source/utilities/query_string/package.json +3 -0
- data/source/utilities/query_string/query_string.js +24 -0
- data/source/utilities/template/package.json +3 -0
- data/source/utilities/template/template.js +10 -0
- data/source/utilities/text_range/package.json +3 -0
- data/source/utilities/text_range/text_range.js +30 -0
- data/source/utilities/ui_events/package.json +3 -0
- data/source/utilities/ui_events/ui_events.js +85 -0
- data/source/utilities/variables/variables.scss +18 -0
- data/source/utilities/z_indexes/z-indexes.scss +88 -0
- data/source/vendor/array_includes.js +28 -0
- data/source/vendor/highlight.js +1142 -0
- data/source/vendor/index.js +1 -0
- data/source/vendor/matrix.js +399 -0
- data/source/vendor/query_string.js +66 -0
- data/spec/assets/.eslintrc +9 -0
- data/spec/assets/spec_fixture.js +33 -0
- data/spec/assets/spec_helper.js +19 -0
- data/spec/lib/components/base_component_spec.rb +156 -0
- data/spec/lib/components_spec.rb +30 -0
- data/spec/lib/helpers/ui_helper_spec.rb +62 -0
- data/spec/lib/theme_spec.rb +25 -0
- data/spec/spec_helper.rb +15 -0
- data/tasks/gulp/.eslintrc +6 -0
- data/tasks/gulp/browser_sync.js +8 -0
- data/tasks/gulp/code_quality/scripts.js +10 -0
- data/tasks/gulp/config/index.js +116 -0
- data/tasks/gulp/minify/scripts.js +13 -0
- data/tasks/gulp/minify/styles.js +13 -0
- data/tasks/gulp/pattern_library/index.js +5 -0
- data/tasks/gulp/pattern_library/scripts.js +10 -0
- data/tasks/gulp/pattern_library/styles.js +10 -0
- data/tasks/gulp/scripts.js +8 -0
- data/tasks/gulp/spec/scripts.js +11 -0
- data/tasks/gulp/styles.js +17 -0
- data/tasks/gulp/utilities/babel/relative_require.js +22 -0
- data/tasks/gulp/utilities/babel/spec_helper.js +20 -0
- data/tasks/gulp/utilities/browserify_bundler.js +22 -0
- data/tasks/gulp/utilities/handle_errors.js +13 -0
- data/tasks/gulp/watch.js +9 -0
- data/tasks/rake/rspec.rake +7 -0
- data/tasks/rake/rubocop.rake +8 -0
- data/tasks/rake/templates.rake +50 -0
- 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-demo.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/"} */
|