Upgrade bootstrap, add test page with slider and new navbar sketch
authorNick Downing <nick.downing@lifx.co>
Sun, 15 Mar 2020 11:53:01 +0000 (22:53 +1100)
committerNick Downing <nick.downing@lifx.co>
Sun, 15 Mar 2020 11:53:01 +0000 (22:53 +1100)
79 files changed:
_svg/techedu_horizontal.eps [new file with mode: 0644]
_svg/techedu_horizontal.svg [new file with mode: 0644]
_svg/techedu_square.eps [new file with mode: 0644]
_svg/techedu_square.svg [new file with mode: 0644]
css/bootstrap.css.less
css/bootstrap/alerts.less [moved from css/alerts.less with 88% similarity]
css/bootstrap/badges.less [moved from css/badges.less with 100% similarity]
css/bootstrap/breadcrumbs.less [moved from css/breadcrumbs.less with 100% similarity]
css/bootstrap/button-groups.less [moved from css/button-groups.less with 97% similarity]
css/bootstrap/buttons.less [moved from css/buttons.less with 96% similarity]
css/bootstrap/carousel.less [moved from css/carousel.less with 90% similarity]
css/bootstrap/close.less [moved from css/close.less with 91% similarity]
css/bootstrap/code.less [moved from css/code.less with 94% similarity]
css/bootstrap/component-animations.less [moved from css/component-animations.less with 92% similarity]
css/bootstrap/custom.less [new file with mode: 0644]
css/bootstrap/dropdowns.less [moved from css/dropdowns.less with 91% similarity]
css/bootstrap/forms.less [moved from css/forms.less with 94% similarity]
css/bootstrap/glyphicons.less [moved from css/glyphicons.less with 96% similarity]
css/bootstrap/grid.less [moved from css/grid.less with 91% similarity]
css/bootstrap/input-groups.less [moved from css/input-groups.less with 98% similarity]
css/bootstrap/jumbotron.less [moved from css/jumbotron.less with 84% similarity]
css/bootstrap/labels.less [moved from css/labels.less with 98% similarity]
css/bootstrap/list-group.less [moved from css/list-group.less with 98% similarity]
css/bootstrap/media.less [moved from css/media.less with 100% similarity]
css/bootstrap/mixins.less [moved from css/mixins.less with 100% similarity]
css/bootstrap/mixins/alerts.less [new file with mode: 0644]
css/bootstrap/mixins/background-variant.less [new file with mode: 0644]
css/bootstrap/mixins/border-radius.less [new file with mode: 0644]
css/bootstrap/mixins/buttons.less [new file with mode: 0644]
css/bootstrap/mixins/center-block.less [new file with mode: 0644]
css/bootstrap/mixins/clearfix.less [new file with mode: 0644]
css/bootstrap/mixins/forms.less [new file with mode: 0644]
css/bootstrap/mixins/gradients.less [new file with mode: 0644]
css/bootstrap/mixins/grid-framework.less [new file with mode: 0644]
css/bootstrap/mixins/grid.less [new file with mode: 0644]
css/bootstrap/mixins/hide-text.less [new file with mode: 0644]
css/bootstrap/mixins/image.less [new file with mode: 0644]
css/bootstrap/mixins/labels.less [new file with mode: 0644]
css/bootstrap/mixins/list-group.less [new file with mode: 0644]
css/bootstrap/mixins/nav-divider.less [new file with mode: 0644]
css/bootstrap/mixins/nav-vertical-align.less [new file with mode: 0644]
css/bootstrap/mixins/opacity.less [new file with mode: 0644]
css/bootstrap/mixins/pagination.less [new file with mode: 0644]
css/bootstrap/mixins/panels.less [new file with mode: 0644]
css/bootstrap/mixins/progress-bar.less [new file with mode: 0644]
css/bootstrap/mixins/reset-filter.less [new file with mode: 0644]
css/bootstrap/mixins/reset-text.less [new file with mode: 0644]
css/bootstrap/mixins/resize.less [new file with mode: 0644]
css/bootstrap/mixins/responsive-visibility.less [new file with mode: 0644]
css/bootstrap/mixins/size.less [new file with mode: 0644]
css/bootstrap/mixins/tab-focus.less [new file with mode: 0644]
css/bootstrap/mixins/table-row.less [new file with mode: 0644]
css/bootstrap/mixins/text-emphasis.less [new file with mode: 0644]
css/bootstrap/mixins/text-overflow.less [new file with mode: 0644]
css/bootstrap/mixins/vendor-prefixes.less [new file with mode: 0644]
css/bootstrap/modals.less [moved from css/modals.less with 96% similarity]
css/bootstrap/navbar.less [moved from css/navbar.less with 95% similarity]
css/bootstrap/navs.less [moved from css/navs.less with 98% similarity]
css/bootstrap/normalize.less [moved from css/normalize.less with 96% similarity]
css/bootstrap/pager.less [moved from css/pager.less with 100% similarity]
css/bootstrap/pagination.less [moved from css/pagination.less with 89% similarity]
css/bootstrap/panels.less [moved from css/panels.less with 97% similarity]
css/bootstrap/popovers.less [moved from css/popovers.less with 81% similarity]
css/bootstrap/print.less [new file with mode: 0644]
css/bootstrap/progress-bars.less [moved from css/progress-bars.less with 92% similarity]
css/bootstrap/responsive-embed.less [moved from css/responsive-embed.less with 100% similarity]
css/bootstrap/responsive-utilities.less [moved from css/responsive-utilities.less with 92% similarity]
css/bootstrap/scaffolding.less [moved from css/scaffolding.less with 88% similarity]
css/bootstrap/tables.less [moved from css/tables.less with 89% similarity]
css/bootstrap/theme.less [moved from css/theme.less with 87% similarity]
css/bootstrap/thumbnails.less [moved from css/thumbnails.less with 93% similarity]
css/bootstrap/tooltip.less [moved from css/tooltip.less with 85% similarity]
css/bootstrap/type.less [moved from css/type.less with 95% similarity]
css/bootstrap/utilities.less [moved from css/utilities.less with 94% similarity]
css/bootstrap/variables.less [moved from css/variables.less with 100% similarity]
css/bootstrap/wells.less [moved from css/wells.less with 83% similarity]
css/print.less [deleted file]
navbar.jst [new file with mode: 0644]
test.html.jst [new file with mode: 0644]

diff --git a/_svg/techedu_horizontal.eps b/_svg/techedu_horizontal.eps
new file mode 100644 (file)
index 0000000..3a37c82
Binary files /dev/null and b/_svg/techedu_horizontal.eps differ
diff --git a/_svg/techedu_horizontal.svg b/_svg/techedu_horizontal.svg
new file mode 100644 (file)
index 0000000..b59dbb4
--- /dev/null
@@ -0,0 +1,153 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   version="1.1"
+   id="svg2"
+   xml:space="preserve"
+   width="295.67548"
+   height="53.690205"
+   viewBox="0 0 2956.7548 536.90205"
+   sodipodi:docname="techedu_horizontal.svg"
+   inkscape:version="0.92.3 (2405546, 2018-03-11)"><metadata
+     id="metadata8"><rdf:RDF><cc:Work
+         rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title></dc:title></cc:Work></rdf:RDF></metadata><defs
+     id="defs6" /><sodipodi:namedview
+     pagecolor="#ffffff"
+     bordercolor="#666666"
+     borderopacity="1"
+     objecttolerance="10"
+     gridtolerance="10"
+     guidetolerance="10"
+     inkscape:pageopacity="0"
+     inkscape:pageshadow="2"
+     inkscape:window-width="1920"
+     inkscape:window-height="1015"
+     id="namedview4"
+     showgrid="false"
+     inkscape:zoom="0.42884779"
+     inkscape:cx="1084.3008"
+     inkscape:cy="-214.76267"
+     inkscape:window-x="0"
+     inkscape:window-y="0"
+     inkscape:window-maximized="1"
+     inkscape:current-layer="g10"
+     scale-x="10"
+     fit-margin-top="0"
+     fit-margin-left="0"
+     fit-margin-right="0"
+     fit-margin-bottom="0" /><g
+     id="g10"
+     inkscape:groupmode="layer"
+     inkscape:label="ink_ext_XXXXXX"
+     transform="matrix(1.3333333,0,0,-1.3333333,0,536.90206)"><path
+       inkscape:connector-curvature="0"
+       id="path14"
+       style="fill:#4a7cc8;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 149.714,72.641 5.072,17.5262 c 32.325,-6 64.565,11.7668 76.76,42.3138 l 17.539,-5.084 C 234.009,87.227 191.731,63.891 149.714,72.641 Z m -13.107,3.782 c -40.1836,15.052 -63.48,57.355 -54.7511,99.384 l 17.5304,-5.084 C 93.375,138.407 111.139,106.145 141.691,93.966 Z m 158.365,98.771 27.517,17.143 -14.044,38.855 -32.152,-4.442 c -3.305,5.296 -7.053,10.391 -11.159,15.185 -15.218,-3.999 -29.407,-9.852 -42.186,-16.452 24.35,-20.13 36.639,-52.645 29.928,-85.01 l -17.558,5.084 c 5.151,27.578 -7.056,55.028 -29.695,70.098 -3.435,-2.133 -6.729,-4.278 -9.859,-6.418 23.348,-12.931 35.537,-40.647 27.808,-67.389 -8.984,-31.037 -41.436,-48.9 -72.47,-39.938 -31.068,8.999 -48.95,41.441 -39.954,72.515 3.499,12.101 10.592,22.154 19.748,29.444 -2.993,2.024 -6.138,3.993 -9.389,5.92 -7.857,-6.962 -14.243,-15.737 -18.334,-25.989 l -17.53,5.078 c 4.3086,11.519 10.8648,21.638 19.003,30.031 -13.646,6.787 -27.7772,12.615 -39.7905,17.16 -3.9903,-5.235 -7.6168,-10.84 -10.8434,-16.693 l -32.3129,2.242 -11.4648,-39.582 28.6074,-15.379 c -0.5969,-8.629 -0.3301,-17.148 0.8215,-25.541 L 12.1277,123.9 26.2047,85.1371 58.393,89.475 C 62.8926,82.2641 68.2094,75.5141 74.0754,69.2922 L 61.9563,39.2121 96.1199,16.0941 119.535,38.5391 c 3.902,-1.5641 7.95,-2.9871 12.104,-4.2 4.114,-1.2051 8.277,-2.1391 12.501,-2.9262 L 151.968,0 l 41.239,1.32109 5.742,31.93911 c 8.292,2.1097 16.321,5.0898 24.005,8.75 L 247.847,21.184 280.444,46.4648 266.353,75.702 c 5.368,6.4722 10.149,13.5371 14.324,21.13 l 32.334,-2.248 11.474,39.66 -28.65,15.301 c 0.564,8.731 0.297,17.251 -0.863,25.649" /><path
+       inkscape:connector-curvature="0"
+       id="path16"
+       style="fill:#3b393d;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:0.1"
+       d="m 328.945,326.503 c -51.091,25.135 -102.119,50.404 -153.435,75.072 -4.03,1.939 -10.756,1.115 -15.082,-0.896 C 137.683,390.111 115.308,378.743 92.7934,367.671 62.3926,352.729 31.9797,337.798 0,322.092 c 6.80195,-2.394 11.6492,-3.837 16.2664,-5.812 3.7426,-1.605 10.132,-3.642 10.2984,-5.871 0.8547,-11.338 3.8512,-24.857 -0.9906,-33.771 -8.2804,-15.239 -2.8965,-29.249 -4.6719,-43.635 6.7082,0 11.6075,0 17.8457,0 -0.6179,13.174 2.7086,27.607 -2.6789,37.067 -7.98,14.016 -3.2625,26.408 -4.9925,41.266 15.0914,-4.903 27.9222,-9.072 40.757,-13.234 -0.0609,1.12 -0.1246,2.248 -0.1852,3.369 5.7325,3.563 11.0434,8.374 17.2672,10.489 55.0934,18.718 110.3754,16.658 165.4114,-0.279 5.502,-1.69 9.938,-6.841 17.313,-12.143 17.703,6.598 39.481,14.701 63.077,23.487 -3.181,1.927 -4.424,2.818 -5.772,3.478" /><path
+       inkscape:connector-curvature="0"
+       id="path18"
+       style="fill:#3b393d;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:0.1"
+       d="m 254.112,304.773 c -55.015,16.44 -110.157,18.712 -165.1452,-0.121 -2.8359,-0.975 -6.602,-4.739 -6.6957,-7.32 -0.6125,-16.434 -0.3121,-32.909 -0.3121,-49.98 0,0 73.533,-21.875 85.456,-48.277 0,0 40.444,43.006 93.032,48.277 0,17.585 0.288,33.704 -0.279,49.792 -0.096,2.691 -3.423,6.842 -6.056,7.629" /><path
+       inkscape:connector-curvature="0"
+       id="path20"
+       style="fill:#3b393d;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 450.988,225.083 c -0.802,-0.678 -1.693,-1.012 -2.675,-1.012 H 418.379 V 116.532 c 0,-0.988 -0.37,-1.849 -1.109,-2.588 -0.743,-0.739 -1.603,-1.109 -2.591,-1.109 h -24.201 c -0.988,0 -1.846,0.37 -2.588,1.109 -0.736,0.739 -1.106,1.6 -1.106,2.588 v 107.539 h -30.119 c -0.991,0 -1.849,0.334 -2.588,1.012 -0.739,0.679 -1.109,1.504 -1.109,2.504 v 19.026 c 0,0.987 0.37,1.817 1.109,2.491 0.739,0.678 1.597,1.018 2.588,1.018 h 91.648 c 0.982,0 1.873,-0.34 2.675,-1.018 0.801,-0.674 1.203,-1.504 1.203,-2.491 v -19.026 c 0,-1 -0.402,-1.825 -1.203,-2.504" /><path
+       inkscape:connector-curvature="0"
+       id="path22"
+       style="fill:#3b393d;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 516.123,175.661 c 0,6.896 -1.478,12.035 -4.438,15.422 -2.955,3.393 -7.018,5.09 -12.192,5.09 -5.175,0 -9.305,-1.733 -12.38,-5.174 -3.082,-3.455 -4.621,-8.569 -4.621,-15.338 v -0.738 h 33.631 z m 29.192,-14.785 c 0,-2.957 -1.294,-4.436 -3.881,-4.436 h -58.942 v -0.369 c 0,-2.563 0.306,-5.061 0.927,-7.502 0.612,-2.435 1.661,-4.575 3.139,-6.411 1.479,-1.83 3.418,-3.296 5.82,-4.388 2.403,-1.102 5.451,-1.654 9.144,-1.654 2.957,0 6.1,0.066 9.426,0.188 3.327,0.122 6.62,0.243 9.884,0.364 3.263,0.121 6.311,0.278 9.149,0.467 2.83,0.187 5.172,0.399 7.02,0.648 h 0.552 c 2.342,0 3.514,-0.994 3.514,-2.964 v -14.148 c 0,-1.491 -0.248,-2.606 -0.742,-3.352 -0.494,-0.745 -1.539,-1.303 -3.139,-1.678 -5.914,-1.484 -11.704,-2.599 -17.367,-3.351 -5.668,-0.745 -12.504,-1.121 -20.511,-1.121 -5.545,0 -11.086,0.812 -16.631,2.406 -5.541,1.6 -10.531,4.254 -14.964,7.943 -4.436,3.698 -8.011,8.593 -10.716,14.696 -2.715,6.095 -4.066,13.579 -4.066,22.451 v 12.93 c 0,7.393 1.045,14.107 3.141,20.136 2.094,6.035 5.142,11.151 9.141,15.344 4.006,4.181 8.902,7.41 14.692,9.701 5.79,2.272 12.38,3.417 19.769,3.417 7.514,0 14.138,-1.235 19.867,-3.696 5.729,-2.467 10.498,-5.848 14.315,-10.168 3.818,-4.315 6.687,-9.416 8.596,-15.33 1.909,-5.921 2.863,-12.381 2.863,-19.404 v -10.719" /><path
+       inkscape:connector-curvature="0"
+       id="path24"
+       style="fill:#3b393d;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 632.528,115.332 c -0.615,-0.558 -1.603,-1.012 -2.957,-1.388 -2.585,-0.617 -5.945,-1.23 -10.068,-1.848 -4.13,-0.612 -8.965,-0.927 -14.504,-0.927 -13.061,0 -23.502,4.006 -31.322,12.009 -7.823,8.018 -11.731,19.598 -11.731,34.741 v 15.531 c 0,15.137 3.908,26.723 11.731,34.733 7.82,8.005 18.261,12.01 31.322,12.01 5.539,0 10.374,-0.309 14.504,-0.927 4.123,-0.618 7.483,-1.23 10.068,-1.847 1.354,-0.377 2.342,-0.831 2.957,-1.389 0.615,-0.551 0.924,-1.508 0.924,-2.859 v -16.447 c 0,-0.993 -0.342,-1.762 -1.015,-2.308 -0.679,-0.558 -1.512,-0.837 -2.499,-0.837 h -0.367 c -3.451,0.37 -6.744,0.685 -9.886,0.928 -3.139,0.242 -7.36,0.363 -12.656,0.363 -2.096,0 -4.066,-0.339 -5.914,-1.012 -1.845,-0.679 -3.448,-1.842 -4.802,-3.508 -1.36,-1.667 -2.433,-3.879 -3.233,-6.654 -0.803,-2.769 -1.203,-6.192 -1.203,-10.246 v -15.531 c 0,-4.061 0.4,-7.484 1.203,-10.246 0.8,-2.776 1.873,-4.989 3.233,-6.655 1.354,-1.672 2.957,-2.836 4.802,-3.513 1.848,-0.68 3.818,-1.013 5.914,-1.013 5.296,0 9.517,0.115 12.656,0.364 3.142,0.248 6.435,0.557 9.886,0.927 h 0.367 c 0.987,0 1.82,-0.278 2.499,-0.837 0.673,-0.551 1.015,-1.32 1.015,-2.303 v -16.451 c 0,-1.357 -0.309,-2.308 -0.924,-2.86" /><path
+       inkscape:connector-curvature="0"
+       id="path26"
+       style="fill:#3b393d;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 742.004,114.042 c -0.803,-0.807 -1.694,-1.207 -2.675,-1.207 h -22.36 c -0.985,0 -1.849,0.4 -2.588,1.201 -0.739,0.793 -1.109,1.683 -1.109,2.672 v 61.395 c 0,3.188 -0.182,5.896 -0.554,8.115 -0.37,2.205 -1.049,3.986 -2.03,5.337 -0.988,1.352 -2.373,2.303 -4.16,2.861 -1.785,0.546 -4.096,0.83 -6.926,0.83 -2.715,0 -5.484,-0.552 -8.317,-1.66 -2.836,-1.103 -5.85,-2.521 -9.053,-4.236 v -72.642 c 0,-0.989 -0.37,-1.879 -1.109,-2.672 -0.739,-0.801 -1.603,-1.201 -2.587,-1.201 h -22.354 c -0.991,0 -1.882,0.4 -2.682,1.207 -0.803,0.793 -1.203,1.683 -1.203,2.672 v 134.147 c 0,0.987 0.37,1.849 1.112,2.581 0.737,0.746 1.6,1.115 2.585,1.115 h 22.542 c 0.984,0 1.848,-0.369 2.587,-1.115 0.739,-0.739 1.109,-1.594 1.109,-2.588 v -39.041 c 4.681,3.102 9.174,5.278 13.489,6.514 4.308,1.248 9.237,1.866 14.782,1.866 6.65,0 12.101,-1.108 16.352,-3.327 4.248,-2.223 7.577,-5.211 9.98,-8.961 2.396,-3.758 4.063,-8.193 4.987,-13.301 0.924,-5.115 1.385,-10.574 1.385,-16.361 v -61.529 c 0,-0.989 -0.403,-1.879 -1.203,-2.672" /><path
+       inkscape:connector-curvature="0"
+       id="path28"
+       style="fill:#3b393d;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 855.088,114.042 c -0.803,-0.807 -1.693,-1.207 -2.681,-1.207 H 830.05 c -0.988,0 -1.848,0.4 -2.588,1.201 -0.736,0.793 -1.108,1.683 -1.108,2.672 v 61.395 c 0,3.188 -0.183,5.896 -0.552,8.115 -0.373,2.205 -1.052,3.986 -2.036,5.337 -0.988,1.352 -2.372,2.303 -4.154,2.861 -1.791,0.546 -4.102,0.83 -6.932,0.83 -2.712,0 -5.484,-0.552 -8.314,-1.66 -2.836,-1.103 -5.853,-2.521 -9.053,-4.236 v -72.642 c 0,-0.989 -0.37,-1.879 -1.109,-2.672 -0.739,-0.801 -1.602,-1.201 -2.587,-1.201 H 769.26 c -0.988,0 -1.882,0.4 -2.681,1.207 -0.8,0.793 -1.201,1.683 -1.201,2.672 v 98.298 c 0,0.989 0.373,1.854 1.11,2.588 0.739,0.739 1.599,1.109 2.584,1.109 h 20.697 c 0.984,0 1.848,-0.37 2.587,-1.121 0.739,-0.74 1.109,-1.613 1.109,-2.6 v -4.478 c 5.048,3.6 9.853,6.108 14.41,7.538 4.56,1.418 9.795,2.145 15.706,2.145 6.653,0 12.104,-1.108 16.352,-3.327 4.251,-2.223 7.577,-5.211 9.98,-8.961 2.403,-3.758 4.066,-8.193 4.987,-13.301 0.924,-5.115 1.388,-10.574 1.388,-16.361 v -61.529 c 0,-0.989 -0.4,-1.879 -1.2,-2.672" /><path
+       inkscape:connector-curvature="0"
+       id="path30"
+       style="fill:#3b393d;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 938.326,172.153 c 0,15.016 -5.451,22.541 -16.352,22.541 -5.39,0 -9.493,-1.878 -12.313,-5.641 -2.818,-3.757 -4.227,-9.392 -4.227,-16.9 V 159.21 c 0,-7.508 1.409,-13.18 4.227,-16.991 2.82,-3.824 6.923,-5.727 12.313,-5.727 10.901,0 16.352,7.575 16.352,22.718 z m 29.931,-12.943 c 0,-7.393 -1.018,-14.034 -3.054,-19.955 -2.039,-5.914 -4.996,-10.932 -8.887,-15.051 -3.887,-4.133 -8.701,-7.339 -14.442,-9.611 -5.736,-2.279 -12.374,-3.424 -19.9,-3.424 -7.532,0 -14.167,1.145 -19.906,3.424 -5.735,2.272 -10.583,5.478 -14.531,9.611 -3.951,4.119 -6.944,9.137 -8.98,15.051 -2.039,5.921 -3.054,12.562 -3.054,19.955 v 12.943 c 0,7.393 1.015,14.033 3.054,19.954 2.036,5.908 5.029,10.932 8.98,15.052 3.948,4.133 8.796,7.326 14.531,9.617 5.739,2.272 12.374,3.417 19.906,3.417 7.526,0 14.164,-1.145 19.9,-3.417 5.741,-2.291 10.555,-5.484 14.442,-9.617 3.891,-4.12 6.848,-9.144 8.887,-15.052 2.036,-5.921 3.054,-12.561 3.054,-19.954 V 159.21" /><path
+       inkscape:connector-curvature="0"
+       id="path32"
+       style="fill:#3b393d;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 1016.21,114.042 c -0.68,-0.807 -1.52,-1.207 -2.5,-1.207 h -22.539 c -0.99,0 -1.881,0.4 -2.681,1.207 -0.803,0.793 -1.203,1.683 -1.203,2.672 v 134.147 c 0,0.987 0.4,1.849 1.203,2.581 0.8,0.746 1.691,1.115 2.681,1.115 h 22.539 c 0.98,0 1.82,-0.369 2.5,-1.115 0.67,-0.732 1.01,-1.594 1.01,-2.581 V 116.714 c 0,-0.989 -0.34,-1.879 -1.01,-2.672" /><path
+       inkscape:connector-curvature="0"
+       id="path34"
+       style="fill:#3b393d;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 1099.26,172.153 c 0,15.016 -5.45,22.541 -16.35,22.541 -5.4,0 -9.5,-1.878 -12.31,-5.641 -2.82,-3.757 -4.23,-9.392 -4.23,-16.9 V 159.21 c 0,-7.508 1.41,-13.18 4.23,-16.991 2.81,-3.824 6.91,-5.727 12.31,-5.727 10.9,0 16.35,7.575 16.35,22.718 z m 29.94,-12.943 c 0,-7.393 -1.03,-14.034 -3.06,-19.955 -2.04,-5.914 -5,-10.932 -8.89,-15.051 -3.89,-4.133 -8.7,-7.339 -14.44,-9.611 -5.74,-2.279 -12.37,-3.424 -19.9,-3.424 -7.53,0 -14.16,1.145 -19.91,3.424 -5.74,2.272 -10.58,5.478 -14.53,9.611 -3.95,4.119 -6.94,9.137 -8.98,15.051 -2.04,5.921 -3.05,12.562 -3.05,19.955 v 12.943 c 0,7.393 1.01,14.033 3.05,19.954 2.04,5.908 5.03,10.932 8.98,15.052 3.95,4.133 8.79,7.326 14.53,9.617 5.75,2.272 12.38,3.417 19.91,3.417 7.53,0 14.16,-1.145 19.9,-3.417 5.74,-2.291 10.55,-5.484 14.44,-9.617 3.89,-4.12 6.85,-9.144 8.89,-15.052 2.03,-5.921 3.06,-12.561 3.06,-19.954 V 159.21" /><path
+       inkscape:connector-curvature="0"
+       id="path36"
+       style="fill:#3b393d;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 1209.57,183.788 c 0,3.816 -1.11,6.992 -3.33,9.519 -2.22,2.521 -6.59,3.787 -13.11,3.787 -6.54,0 -10.97,-1.266 -13.31,-3.787 -2.34,-2.527 -3.52,-5.703 -3.52,-9.519 v -1.473 c 0,-1.606 0.22,-3.181 0.66,-4.721 0.42,-1.539 1.26,-2.926 2.49,-4.144 1.23,-1.236 2.93,-2.225 5.08,-2.963 2.15,-0.734 5.02,-1.109 8.6,-1.109 6.52,0 10.89,1.175 13.11,3.507 2.22,2.346 3.33,5.479 3.33,9.43 z m 0.92,-77.049 c 0,0.861 -0.22,1.691 -0.64,2.497 -0.44,0.794 -1.33,1.569 -2.68,2.309 -1.36,0.733 -3.27,1.478 -5.73,2.217 -2.47,0.734 -5.79,1.6 -9.98,2.588 l -13.67,2.957 c -1.11,-1.599 -2.01,-3.297 -2.69,-5.084 -0.67,-1.788 -1.01,-4.285 -1.01,-7.484 v -1.479 c 0,-3.199 1.29,-5.5678 3.88,-7.1131 2.59,-1.5387 7.45,-2.3078 14.6,-2.3078 3.82,0 6.89,0.2121 9.24,0.648 2.33,0.4301 4.15,1.0719 5.45,1.9391 1.29,0.866 2.15,1.8768 2.59,3.0468 0.42,1.17 0.64,2.436 0.64,3.787 z m 33.26,96.639 c 0,-1.364 -0.27,-2.284 -0.83,-2.77 -0.56,-0.496 -1.38,-0.927 -2.5,-1.297 l -5.73,-1.847 c 1.12,-1.733 2.07,-3.885 2.87,-6.465 0.8,-2.588 1.2,-4.989 1.2,-7.211 v -1.473 c 0,-12.077 -3.97,-20.857 -11.92,-26.336 -7.94,-5.483 -19.18,-8.217 -33.71,-8.217 -4.32,0 -8.14,0.268 -11.46,0.831 -3.33,0.551 -5.92,1.2 -7.76,1.933 -0.99,-0.611 -1.67,-1.26 -2.04,-1.933 -0.37,-0.678 -0.55,-1.454 -0.55,-2.315 0,-1.473 0.37,-2.588 1.11,-3.326 0.74,-0.733 2.21,-1.358 4.43,-1.842 l 20.88,-4.618 c 8.01,-1.728 14.78,-3.423 20.33,-5.084 5.54,-1.66 10.01,-3.575 13.39,-5.732 3.39,-2.158 5.82,-4.739 7.3,-7.757 1.48,-3.018 2.22,-6.75 2.22,-11.18 v -1.479 c 0,-20.0811 -16.14,-30.1151 -48.41,-30.1151 -15.4,0 -27.07,2.5801 -35.01,7.7621 -7.95,5.1692 -11.92,12.6289 -11.92,22.353 v 1.479 c 0,3.824 0.86,7.447 2.58,10.902 1.72,3.448 4.56,6.713 8.5,9.791 -3.32,1.849 -5.72,4.407 -7.2,7.672 -1.48,3.26 -2.22,6.43 -2.22,9.514 0,3.447 0.77,6.466 2.31,9.053 1.54,2.593 3.48,4.805 5.82,6.648 -2.96,2.587 -5.11,5.981 -6.47,10.168 -1.35,4.181 -2.03,8.131 -2.03,11.828 v 1.473 c 0,10.476 3.66,18.912 10.99,25.31 7.33,6.405 19.06,9.611 35.21,9.611 h 46 c 1.36,0 2.47,-0.46 3.33,-1.382 0.86,-0.927 1.29,-2.067 1.29,-3.424 v -10.525" /><path
+       inkscape:connector-curvature="0"
+       id="path38"
+       style="fill:#3b393d;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 1353.14,215.387 c 0,-0.248 -0.03,-0.399 -0.1,-0.465 -0.06,-0.061 -0.09,-0.218 -0.09,-0.461 l -31.04,-108.83 c -1.48,-5.048 -3.14,-9.447 -4.99,-13.2099 -1.85,-3.7641 -4.24,-6.8711 -7.2,-9.332 -2.97,-2.4661 -6.72,-4.345 -11.28,-5.6352 -4.56,-1.291 -10.22,-1.9398 -17,-1.9398 -1.72,0 -3.63,0.0968 -5.72,0.28 -2.1,0.1809 -4.2,0.3989 -6.29,0.6411 -2.09,0.2488 -4.06,0.5578 -5.91,0.9269 -1.85,0.3629 -3.33,0.7399 -4.44,1.109 -0.98,0.3641 -1.87,0.7699 -2.67,1.2 -0.8,0.4371 -1.2,1.1461 -1.2,2.1269 v 14.9668 c 0,0.9821 0.37,1.8184 1.11,2.4911 0.73,0.6781 1.6,1.0181 2.58,1.0181 h 0.37 c 1.48,-0.127 3.23,-0.248 5.27,-0.376 2.03,-0.1152 4.12,-0.2718 6.28,-0.4601 2.15,-0.182 4.25,-0.334 6.28,-0.4547 2.04,-0.1273 3.79,-0.1934 5.27,-0.1934 3.32,0 5.91,0.6832 7.76,2.0352 1.85,1.363 3.32,3.879 4.43,7.574 l 1.66,5.733 h -2.77 c -1.72,0 -3.35,0.146 -4.89,0.461 -1.54,0.308 -3.05,1.017 -4.53,2.121 -1.48,1.115 -2.86,2.798 -4.16,5.089 -1.29,2.279 -2.49,5.448 -3.6,9.514 l -24.39,83.144 c -0.13,0.37 -0.19,0.799 -0.19,1.297 0,1.969 1.24,2.951 3.7,2.951 h 24.58 c 0.98,0 1.75,-0.339 2.3,-1.019 0.56,-0.672 0.96,-1.502 1.21,-2.49 l 16.63,-69.473 c 0.48,-2.345 1.23,-3.508 2.22,-3.508 h 0.18 0.74 0.74 l 17.18,72.981 c 0.24,0.988 0.7,1.818 1.38,2.49 0.68,0.68 1.51,1.019 2.5,1.019 h 24.58 c 0.98,0 1.81,-0.31 2.49,-0.915 0.68,-0.624 1.02,-1.424 1.02,-2.407" /><path
+       inkscape:connector-curvature="0"
+       id="path40"
+       style="fill:#4a7cc8;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 1450.96,113.575 c -3.2,-0.497 -7.49,-1.012 -12.84,-1.57 -5.37,-0.551 -13.03,-0.836 -23.01,-0.836 -5.91,0 -11.59,0.504 -17.03,1.484 -5.45,0.982 -10.24,2.891 -14.4,5.727 -4.14,2.83 -7.46,6.865 -9.94,12.101 -2.48,5.236 -3.72,12.04 -3.72,20.42 v 61.342 c 0,8.375 1.24,15.149 3.72,20.33 2.48,5.169 5.8,9.174 9.94,12.004 4.16,2.836 8.98,4.745 14.49,5.732 5.5,0.989 11.22,1.473 17.13,1.473 4.92,0 9.26,-0.091 13.02,-0.272 3.76,-0.183 7.05,-0.4 9.89,-0.649 2.83,-0.249 5.26,-0.497 7.3,-0.739 2.03,-0.242 3.85,-0.491 5.45,-0.739 2.46,-0.371 3.69,-1.607 3.69,-3.697 v -17.185 c 0,-0.982 -0.37,-1.842 -1.1,-2.581 -0.75,-0.74 -1.61,-1.116 -2.59,-1.116 h -37.51 c -4.32,0 -7.37,-0.89 -9.15,-2.671 -1.79,-1.789 -2.68,-5.091 -2.68,-9.89 v -16.816 h 47.86 c 0.98,0 1.85,-0.363 2.59,-1.108 0.73,-0.74 1.1,-1.6 1.1,-2.588 v -17.549 c 0,-0.981 -0.37,-1.847 -1.1,-2.587 -0.74,-0.739 -1.61,-1.108 -2.59,-1.108 h -47.86 v -19.586 c 0,-4.805 0.89,-8.101 2.68,-9.883 1.78,-1.793 4.83,-2.69 9.15,-2.69 h 37.51 c 0.98,0 1.84,-0.363 2.59,-1.097 0.73,-0.739 1.1,-1.605 1.1,-2.588 v -17.184 c 0,-2.218 -1.23,-3.515 -3.69,-3.884" /><path
+       inkscape:connector-curvature="0"
+       id="path42"
+       style="fill:#4a7cc8;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 1534.11,194.507 c -2.22,0.242 -4.76,0.455 -7.58,0.648 -2.84,0.182 -5.36,0.272 -7.58,0.272 -3.33,0 -6.03,-0.557 -8.12,-1.66 -2.1,-1.108 -3.77,-2.684 -5,-4.714 -1.23,-2.024 -2.09,-4.429 -2.58,-7.205 -0.5,-2.769 -0.74,-5.756 -0.74,-8.963 v -14.409 c 0,-3.321 0.24,-6.374 0.74,-9.149 0.49,-2.77 1.35,-5.176 2.58,-7.205 1.23,-2.03 2.9,-3.6 5,-4.709 2.09,-1.109 4.79,-1.666 8.12,-1.666 3.08,0 5.95,0.127 8.59,0.369 2.65,0.249 4.84,0.491 6.57,0.74 z m 29.93,-73.17 c 0,-1.479 -0.35,-2.587 -1.02,-3.321 -0.68,-0.745 -2.25,-1.418 -4.71,-2.042 -5.3,-1.357 -11.39,-2.491 -18.29,-3.411 -6.91,-0.928 -13.93,-1.394 -21.07,-1.394 -15.03,0 -26.51,4.133 -34.46,12.386 -7.94,8.247 -11.91,19.893 -11.91,34.921 v 14.409 c 0,14.538 3.81,26.057 11.45,34.553 7.63,8.502 19.28,12.755 34.92,12.755 1.85,0 4.16,-0.127 6.93,-0.376 2.77,-0.242 5.51,-0.551 8.23,-0.92 v 31.964 c 0,0.987 0.37,1.849 1.1,2.581 0.74,0.746 1.6,1.115 2.59,1.115 h 22.36 c 0.98,0 1.87,-0.369 2.68,-1.115 0.8,-0.732 1.2,-1.594 1.2,-2.581 V 121.337" /><g
+       transform="scale(0.10289)"
+       id="g44"><path
+         inkscape:connector-curvature="0"
+         id="path46"
+         style="fill:#4a7cc8;fill-opacity:1;fill-rule:nonzero;stroke:none"
+         d="m 16289.3,1107.43 c -7.2,-7.18 -15.6,-10.77 -25.2,-10.77 H 16063 c -9.7,0 -18,3.66 -25.2,10.83 -7.1,7.31 -10.7,15.73 -10.7,25.45 v 43.46 c -49.1,-35.05 -95.8,-59.41 -140.1,-73.32 -44.3,-13.78 -95.2,-20.73 -152.6,-20.73 -64.7,0 -117.7,10.42 -159,31.39 -41.3,20.91 -73.6,49.94 -97,87.1 -23.3,37.1 -39.4,80.52 -48.5,130.15 -8.9,49.71 -13.4,102.66 -13.4,158.97 v 598 c 0,9.54 3.9,18.2 11.7,26.03 7.8,7.78 16.4,11.66 25.9,11.66 h 217.4 c 9.6,0 17.9,-3.88 25.1,-11.61 7.3,-7.81 10.8,-16.48 10.8,-25.96 v -596.65 c 0,-31.1 1.8,-57.43 5.5,-78.87 3.5,-21.48 10.1,-38.8 19.6,-51.99 9.7,-13.14 23.1,-22.44 40.4,-27.74 17.4,-5.43 39.9,-8.08 67.4,-8.08 26.4,0 53.2,5.37 80.8,16.08 27.6,10.78 56.9,24.5 88,41.28 v 705.97 c 0,9.48 3.6,18.15 10.8,25.96 7.2,7.73 15.5,11.61 25.1,11.61 h 217.3 c 9.6,0 18.3,-3.88 26,-11.66 7.8,-7.83 11.7,-16.49 11.7,-26.03 v -955.37 c 0,-9.61 -3.5,-17.97 -10.7,-25.16" /></g><g
+       transform="scale(0.108467)"
+       id="g48"><path
+         inkscape:connector-curvature="0"
+         id="path50"
+         style="fill:#4a7cc8;fill-opacity:1;fill-rule:nonzero;stroke:none"
+         d="m 16291.5,1063.29 c -5.7,-5.15 -14.7,-9.33 -27.3,-12.8 -23.8,-5.69 -54.7,-11.34 -92.8,-17.04 -38.1,-5.64 -82.6,-8.54 -133.7,-8.54 -120.4,0 -216.6,36.93 -288.7,110.71 -72.2,73.92 -108.3,180.68 -108.3,320.29 v 143.19 c 0,139.55 36.1,246.37 108.3,320.21 72.1,73.8 168.3,110.73 288.7,110.73 51.1,0 95.6,-2.85 133.7,-8.55 38.1,-5.7 69,-11.34 92.8,-17.03 12.6,-3.47 21.6,-7.66 27.3,-12.8 5.7,-5.08 8.5,-13.91 8.5,-26.36 v -151.63 c 0,-9.16 -3.1,-16.25 -9.3,-21.28 -6.3,-5.14 -13.9,-7.72 -23,-7.72 h -3.5 c -31.8,3.41 -62.1,6.32 -91.1,8.56 -29,2.23 -67.9,3.34 -116.7,3.34 -19.3,0 -37.4,-3.12 -54.6,-9.32 -16.9,-6.27 -31.7,-16.99 -44.2,-32.35 -12.5,-15.36 -22.4,-35.76 -29.8,-61.34 -7.4,-25.53 -11,-57.09 -11,-94.46 v -143.19 c 0,-37.44 3.6,-69 11,-94.46 7.4,-25.59 17.3,-46 29.8,-61.36 12.5,-15.41 27.3,-26.14 44.2,-32.38 17.2,-6.27 35.3,-9.34 54.6,-9.34 48.8,0 87.7,1.06 116.7,3.35 29,2.29 59.3,5.14 91.1,8.55 h 3.5 c 9.1,0 16.7,-2.56 23,-7.72 6.2,-5.08 9.3,-12.16 9.3,-21.23 v -151.66 c 0,-12.52 -2.8,-21.28 -8.5,-26.37" /></g><g
+       transform="scale(0.114634)"
+       id="g52"><path
+         inkscape:connector-curvature="0"
+         id="path54"
+         style="fill:#4a7cc8;fill-opacity:1;fill-rule:nonzero;stroke:none"
+         d="m 16043.7,1379.22 h -91.9 c -28,0 -51.1,-2.42 -69.3,-7.24 -18.2,-4.86 -32.8,-12.1 -43.4,-21.77 -10.9,-9.68 -18.4,-22 -22.6,-37.11 -4.4,-15.02 -6.6,-32.24 -6.6,-51.54 v -14.53 c 0,-34.37 8.4,-56.36 25.1,-66.02 16.6,-9.74 42.1,-14.54 76.5,-14.54 24.7,0 48.1,3.42 70.1,10.46 22.1,6.98 42.7,15.28 62.1,25 z m 256.3,-362.67 c 0,-8.61 -3.2,-16.12 -9.7,-22.571 -6.4,-6.447 -13.9,-9.674 -22.6,-9.674 h -180.5 c -8.6,0 -16.1,3.227 -22.6,9.674 -6.4,6.451 -9.6,13.961 -9.6,22.571 v 25.8 c -31.2,-22.58 -64.2,-40.33 -99.1,-53.23 -34.9,-12.843 -76.6,-19.349 -125,-19.349 -35.5,0 -69.6,4.648 -102.3,13.747 -32.9,9.142 -62.1,24.422 -87.8,45.982 -25.8,21.41 -46.6,49.96 -62.1,85.43 -15.7,35.41 -23.4,79.45 -23.4,132.1 v 14.53 c 0,94.57 31.5,163.6 94.3,207.11 62.9,43.5 163.6,65.33 302.2,65.33 h 87 v 57.94 c 0,46.25 -10.6,76.33 -32.3,90.29 -21.4,13.94 -50.9,20.98 -88.5,20.98 -25.8,0 -51.9,-0.27 -78.2,-0.8 -26.4,-0.57 -51.6,-1.38 -75.8,-2.48 -24.1,-1.06 -45.9,-2.32 -65.2,-3.96 -19.4,-1.65 -35.5,-3.01 -48.4,-4.08 h -8.1 c -8.6,0 -15.6,2.17 -20.9,6.5 -5.3,4.23 -8,11.8 -8,22.53 v 130.56 c 0,18.34 10.2,30.01 30.5,35.47 30.1,7.51 70.7,15.06 121.7,22.57 51.1,7.51 103.5,11.31 157.2,11.31 58,0 110.4,-6.24 157.1,-18.56 46.8,-12.36 86.3,-31.71 118.6,-58.03 32.2,-26.33 57.2,-60.22 74.9,-101.6 17.7,-41.33 26.6,-91.55 26.6,-150.7 v -575.39" /></g><g
+       transform="scale(0.119463)"
+       id="g56"><path
+         inkscape:connector-curvature="0"
+         id="path58"
+         style="fill:#4a7cc8;fill-opacity:1;fill-rule:nonzero;stroke:none"
+         d="m 16270.6,942.893 c -23.8,-4.051 -44.3,-7.148 -61.8,-9.224 -17.5,-2.034 -37.7,-3.097 -60.4,-3.097 -42,0 -79.2,3.447 -111.5,10.094 -32.3,6.648 -59.2,19.838 -80.7,39.412 -21.5,19.586 -37.9,46.612 -49.2,81.202 -11.2,34.55 -16.8,79.18 -16.8,133.87 v 448.49 l -123.8,20.09 c -8.2,2.08 -15.8,5.98 -22.5,11.62 -6.7,5.63 -10,12.63 -10,20.89 v 102.06 c 0,8.22 3.3,15.67 10,22.42 6.7,6.7 14.3,10.04 22.5,10.04 h 123.8 v 126.86 c 0,8.21 3,14.91 9.2,20.14 6.1,5.08 13.3,8.72 21.5,10.8 l 187.5,32.46 h 4.6 c 8.2,0 14.9,-2.27 20,-6.94 5.1,-4.62 7.7,-11.11 7.7,-19.37 v -163.95 h 126.8 c 8.2,0 15.5,-3.09 21.7,-9.33 6.1,-6.24 9.3,-13.55 9.3,-21.81 v -126.31 c 0,-8.37 -3.2,-15.61 -9.3,-21.86 -6.2,-6.23 -13.5,-9.33 -21.7,-9.33 h -126.8 V 1192 c 0,-30.94 2.5,-50.82 7.7,-59.5 5.2,-8.88 19.6,-13.18 43.4,-13.18 h 75.7 c 21.7,0 32.5,-8.73 32.5,-26.08 V 973.538 c 0,-17.402 -9.8,-27.597 -29.4,-30.645" /></g><g
+       transform="scale(0.122433)"
+       id="g60"><path
+         inkscape:connector-curvature="0"
+         id="path62"
+         style="fill:#4a7cc8;fill-opacity:1;fill-rule:nonzero;stroke:none"
+         d="m 16294,951.801 c 0,-8.068 -3.1,-15.1 -9.1,-21.137 -6.1,-6.036 -13.1,-9.058 -21.1,-9.058 h -184.1 c -8.2,0 -15.2,3.022 -21.2,9.058 -6,6.037 -9,13.069 -9,21.137 v 804.359 c 0,8.08 3,15.14 9,21.14 6,6.03 13,9.05 21.2,9.05 h 184.1 c 8,0 15,-3.02 21.1,-9.05 6,-6 9.1,-13.06 9.1,-21.14 z m 6,962.839 c 0,-8.07 -3,-15.05 -9.1,-21.13 -6,-6.04 -13,-9.11 -21,-9.11 h -196.3 c -8,0 -15.1,3.07 -21.1,9.11 -6,6.08 -9,13.06 -9,21.13 v 140.41 c 0,8.03 3,15 9,21.09 6,6.03 13.1,9.1 21.1,9.1 h 196.3 c 8,0 15,-3.07 21,-9.1 6.1,-6.09 9.1,-13.06 9.1,-21.09 v -140.41" /></g><g
+       transform="scale(0.129302)"
+       id="g64"><path
+         inkscape:connector-curvature="0"
+         id="path66"
+         style="fill:#4a7cc8;fill-opacity:1;fill-rule:nonzero;stroke:none"
+         d="m 16068.5,1331.4 c 0,116.13 -42.1,174.33 -126.5,174.33 -41.6,0 -73.4,-14.53 -95.1,-43.63 -21.9,-29.06 -32.7,-72.64 -32.7,-130.7 v -100.1 c 0,-58.07 10.8,-101.93 32.7,-131.4 21.7,-29.58 53.5,-44.3 95.1,-44.3 84.4,0 126.5,58.59 126.5,175.7 z m 231.5,-100.1 c 0,-57.18 -7.8,-108.54 -23.6,-154.33 -15.8,-45.74 -38.7,-84.545 -68.7,-116.401 -30.1,-31.963 -67.3,-56.759 -111.7,-74.329 -44.4,-17.625 -95.7,-26.48 -154,-26.48 -58.2,0 -109.5,8.855 -153.9,26.48 -44.3,17.57 -81.8,42.366 -112.4,74.329 -30.5,31.856 -53.7,70.661 -69.4,116.401 -15.8,45.79 -23.7,97.15 -23.7,154.33 v 100.1 c 0,57.17 7.9,108.53 23.7,154.32 15.7,45.69 38.9,84.54 69.4,116.41 30.6,31.96 68.1,56.66 112.4,74.37 44.4,17.57 95.7,26.43 153.9,26.43 58.3,0 109.6,-8.86 154,-26.43 44.4,-17.71 81.6,-42.41 111.7,-74.37 30,-31.87 52.9,-70.72 68.7,-116.41 15.8,-45.79 23.6,-97.15 23.6,-154.32 v -100.1" /></g><g
+       transform="scale(0.136047)"
+       id="g68"><path
+         inkscape:connector-curvature="0"
+         id="path70"
+         style="fill:#4a7cc8;fill-opacity:1;fill-rule:nonzero;stroke:none"
+         d="m 16291.2,838.254 c -5.9,-5.932 -12.5,-8.872 -19.7,-8.872 h -164.4 c -7.3,0 -13.5,2.94 -19,8.826 -5.4,5.829 -8.2,12.372 -8.2,19.642 v 451.28 c 0,23.43 -1.3,43.33 -4,59.64 -2.7,16.21 -7.7,29.3 -14.9,39.23 -7.3,9.94 -17.5,16.93 -30.6,21.03 -13.2,4.02 -30.1,6.1 -51,6.1 -19.9,0 -40.2,-4.05 -61,-12.2 -20.9,-8.1 -43,-18.53 -66.6,-31.13 V 857.85 c 0,-7.27 -2.7,-13.813 -8.2,-19.642 -5.4,-5.886 -11.7,-8.826 -19,-8.826 h -164.3 c -7.2,0 -13.8,2.94 -19.7,8.872 -5.9,5.829 -8.8,12.37 -8.8,19.64 v 722.526 c 0,7.27 2.7,13.63 8.1,19.02 5.4,5.44 11.7,8.16 19.1,8.16 h 152 c 7.3,0 13.6,-2.72 19.1,-8.24 5.4,-5.44 8.1,-11.86 8.1,-19.12 v -32.91 c 37.2,26.46 72.4,44.9 106,55.41 33.4,10.42 72,15.76 115.4,15.76 48.8,0 88.9,-8.14 120.2,-24.45 31.3,-16.34 55.7,-38.3 73.3,-65.87 17.6,-27.62 29.9,-60.22 36.7,-97.77 6.8,-37.59 10.2,-77.72 10.2,-120.26 V 857.894 c 0,-7.27 -2.9,-13.811 -8.8,-19.64" /></g></g></svg>
\ No newline at end of file
diff --git a/_svg/techedu_square.eps b/_svg/techedu_square.eps
new file mode 100644 (file)
index 0000000..588fd78
Binary files /dev/null and b/_svg/techedu_square.eps differ
diff --git a/_svg/techedu_square.svg b/_svg/techedu_square.svg
new file mode 100644 (file)
index 0000000..43eb5b9
--- /dev/null
@@ -0,0 +1,148 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+   xmlns:dc="http://purl.org/dc/elements/1.1/"
+   xmlns:cc="http://creativecommons.org/ns#"
+   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+   xmlns:svg="http://www.w3.org/2000/svg"
+   xmlns="http://www.w3.org/2000/svg"
+   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+   version="1.1"
+   id="svg2"
+   xml:space="preserve"
+   width="285.96243"
+   height="101.89616"
+   viewBox="0 0 2859.6243 1018.9615"
+   sodipodi:docname="techedu_square.svg"
+   inkscape:version="0.92.3 (2405546, 2018-03-11)"><metadata
+     id="metadata8"><rdf:RDF><cc:Work
+         rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type
+           rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title></dc:title></cc:Work></rdf:RDF></metadata><defs
+     id="defs6" /><sodipodi:namedview
+     pagecolor="#ffffff"
+     bordercolor="#666666"
+     borderopacity="1"
+     objecttolerance="10"
+     gridtolerance="10"
+     guidetolerance="10"
+     inkscape:pageopacity="0"
+     inkscape:pageshadow="2"
+     inkscape:window-width="1920"
+     inkscape:window-height="1015"
+     id="namedview4"
+     showgrid="false"
+     inkscape:zoom="0.62708577"
+     inkscape:cx="1160.306"
+     inkscape:cy="-407.58401"
+     inkscape:window-x="0"
+     inkscape:window-y="0"
+     inkscape:window-maximized="1"
+     inkscape:current-layer="g10"
+     fit-margin-top="0"
+     fit-margin-left="0"
+     fit-margin-right="0"
+     fit-margin-bottom="0" /><g
+     id="g10"
+     inkscape:groupmode="layer"
+     inkscape:label="ink_ext_XXXXXX"
+     transform="matrix(1.3333333,0,0,-1.3333333,0,1018.9616)"><path
+       inkscape:connector-curvature="0"
+       id="path14"
+       style="fill:#4a7cc8;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 1050.4,353.636 6.31,21.8 c 40.22,-7.454 80.32,14.644 95.49,52.646 l 21.83,-6.326 c -18.76,-49.972 -71.36,-78.999 -123.63,-68.12 z m -16.31,4.706 c -49.987,18.724 -78.966,71.352 -68.111,123.636 l 21.81,-6.322 c -7.476,-40.205 14.621,-80.336 52.631,-95.492 z m 197.02,122.879 34.23,21.323 -17.47,48.344 -40,-5.529 c -4.11,6.589 -8.77,12.929 -13.88,18.889 -18.93,-4.972 -36.58,-12.255 -52.48,-20.463 30.3,-25.045 45.58,-65.498 37.23,-105.764 l -21.84,6.326 c 6.4,34.312 -8.78,68.465 -36.94,87.21 -4.28,-2.654 -8.38,-5.326 -12.27,-7.979 29.04,-16.089 44.21,-50.57 34.59,-83.845 -11.17,-38.607 -51.54,-60.837 -90.15,-49.685 -38.65,11.196 -60.901,51.554 -49.71,90.218 4.36,15.051 13.18,27.563 24.57,36.624 -3.72,2.517 -7.64,4.974 -11.68,7.366 -9.77,-8.661 -17.72,-19.575 -22.807,-32.335 l -21.811,6.323 c 5.362,14.328 13.518,26.921 23.642,37.357 -16.976,8.448 -34.558,15.701 -49.502,21.35 -4.966,-6.514 -9.477,-13.484 -13.492,-20.77 l -40.196,2.791 -14.265,-49.244 35.589,-19.131 c -0.741,-10.732 -0.41,-21.331 1.021,-31.772 l -34.255,-21.419 17.513,-48.221 40.047,5.397 c 5.595,-8.971 12.212,-17.372 19.508,-25.111 l -15.078,-37.422 42.502,-28.764 29.134,27.924 c 4.85,-1.944 9.89,-3.717 15.05,-5.219 5.12,-1.502 10.3,-2.663 15.56,-3.645 l 9.74,-39.074 51.3,1.638 7.14,39.735 c 10.32,2.627 20.31,6.33 29.86,10.887 l 30.97,-25.909 40.56,31.455 -17.53,36.368 c 6.68,8.052 12.63,16.845 17.82,26.284 l 40.22,-2.796 14.28,49.342 -35.64,19.038 c 0.7,10.858 0.37,21.462 -1.08,31.908" /><path
+       inkscape:connector-curvature="0"
+       id="path16"
+       style="fill:#3b393d;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:0.1"
+       d="m 1263.35,669.46 c -63.56,31.27 -127.04,62.704 -190.88,93.394 -5.02,2.408 -13.38,1.383 -18.76,-1.118 -28.3,-13.143 -56.137,-27.286 -84.147,-41.061 -37.821,-18.59 -75.655,-37.165 -115.441,-56.706 8.461,-2.978 14.494,-4.767 20.236,-7.232 4.656,-1.997 12.606,-4.528 12.813,-7.3 1.062,-14.106 4.79,-30.927 -1.232,-42.013 -10.302,-18.956 -3.603,-36.386 -5.813,-54.284 8.346,0 14.44,0 22.201,0 -0.769,16.391 3.369,34.345 -3.332,46.114 -9.929,17.431 -4.06,32.85 -6.212,51.33 18.775,-6.093 34.738,-11.283 50.705,-16.463 -0.076,1.395 -0.153,2.798 -0.229,4.199 7.13,4.43 13.737,10.413 21.482,13.043 68.539,23.286 137.309,20.726 205.779,-0.343 6.85,-2.106 12.36,-8.512 21.54,-15.11 22.02,8.207 49.12,18.294 78.48,29.223 -3.97,2.399 -5.51,3.505 -7.19,4.327" /><path
+       inkscape:connector-curvature="0"
+       id="path18"
+       style="fill:#3b393d;fill-opacity:1;fill-rule:evenodd;stroke:none;stroke-width:0.1"
+       d="m 1170.25,642.423 c -68.44,20.451 -137.04,23.28 -205.445,-0.148 -3.53,-1.212 -8.216,-5.897 -8.332,-9.11 -0.76,-20.444 -0.386,-40.937 -0.386,-62.18 0,0 91.483,-27.212 106.313,-60.052 0,0 50.31,53.498 115.73,60.052 0,21.882 0.36,41.934 -0.34,61.952 -0.12,3.343 -4.26,8.507 -7.54,9.486" /><path
+       inkscape:connector-curvature="0"
+       id="path20"
+       style="fill:#4a7cc8;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 112.747,172.466 c -0.924,-0.78 -1.949,-1.168 -3.081,-1.168 H 75.2363 V 47.6059 c 0,-1.1348 -0.4258,-2.1258 -1.2761,-2.9758 -0.8508,-0.8512 -1.8418,-1.275 -2.9758,-1.275 H 43.1438 c -1.1356,0 -2.125,0.4238 -2.9758,1.275 -0.8492,0.85 -1.2742,1.841 -1.2742,2.9758 V 171.298 H 4.25 c -1.13516,0 -2.125,0.388 -2.97578,1.168 C 0.425391,173.245 0,174.199 0,175.335 v 21.893 c 0,1.132 0.425391,2.086 1.27422,2.869 0.85078,0.777 1.84062,1.168 2.97578,1.168 h 105.416 c 1.132,0 2.157,-0.391 3.081,-1.168 0.92,-0.783 1.381,-1.737 1.381,-2.869 v -21.893 c 0,-1.136 -0.461,-2.09 -1.381,-2.869" /><path
+       inkscape:connector-curvature="0"
+       id="path22"
+       style="fill:#4a7cc8;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 187.663,115.614 c 0,7.935 -1.7,13.849 -5.101,17.746 -3.4,3.899 -8.076,5.846 -14.026,5.846 -5.953,0 -10.701,-1.986 -14.24,-5.948 -3.544,-3.97 -5.315,-9.851 -5.315,-17.644 v -0.847 h 38.682 z m 33.579,-17.0019 c 0,-3.3992 -1.488,-5.1012 -4.463,-5.1012 H 148.981 V 93.091 c 0,-2.948 0.353,-5.8281 1.065,-8.6359 0.706,-2.809 1.911,-5.266 3.611,-7.3692 1.701,-2.1078 3.932,-3.7949 6.697,-5.055 2.762,-1.2649 6.268,-1.8977 10.519,-1.8977 3.399,0 7.013,0.0707 10.838,0.2129 3.827,0.1391 7.614,0.282 11.37,0.4238 3.754,0.143 7.261,0.3211 10.522,0.534 3.256,0.2102 5.95,0.4563 8.075,0.7453 h 0.637 c 2.692,0 4.039,-1.1402 4.039,-3.4113 V 52.3621 c 0,-1.716 -0.285,-2.9973 -0.851,-3.8512 -0.567,-0.8589 -1.773,-1.5027 -3.611,-1.93 -6.802,-1.7161 -13.464,-2.9969 -19.978,-3.852 -6.52,-0.8578 -14.383,-1.2848 -23.592,-1.2848 -6.376,0 -12.752,0.9219 -19.127,2.7629 -6.376,1.8399 -12.114,4.8871 -17.216,9.1379 -5.099,4.2512 -9.211,9.8813 -12.326,16.8949 -3.118,7.0133 -4.676,15.6211 -4.676,25.8231 V 110.94 c 0,8.501 1.202,16.222 3.613,23.164 2.409,6.942 5.915,12.824 10.52,17.643 4.603,4.813 10.235,8.533 16.897,11.157 6.659,2.62 14.24,3.93 22.741,3.93 8.64,0 16.258,-1.417 22.847,-4.25 6.588,-2.834 12.077,-6.729 16.469,-11.688 4.392,-4.963 7.686,-10.84 9.885,-17.638 2.195,-6.804 3.293,-14.241 3.293,-22.318 V 98.6121" /><path
+       inkscape:connector-curvature="0"
+       id="path24"
+       style="fill:#4a7cc8;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 321.556,46.2238 c -0.71,-0.6359 -1.844,-1.1668 -3.402,-1.5937 -2.974,-0.7082 -6.837,-1.4129 -11.582,-2.125 -4.749,-0.7051 -10.307,-1.061 -16.683,-1.061 -15.021,0 -27.029,4.6028 -36.025,13.8118 -8.999,9.2101 -13.495,22.5312 -13.495,39.957 v 17.8521 c 0,17.426 4.496,30.743 13.495,39.956 8.996,9.21 21.004,13.813 36.025,13.813 6.376,0 11.934,-0.353 16.683,-1.061 4.745,-0.712 8.608,-1.417 11.582,-2.125 1.558,-0.427 2.692,-0.958 3.402,-1.595 0.707,-0.637 1.062,-1.737 1.062,-3.293 v -18.917 c 0,-1.136 -0.391,-2.019 -1.169,-2.656 -0.78,-0.637 -1.737,-0.958 -2.869,-0.958 h -0.426 c -3.967,0.428 -7.757,0.781 -11.37,1.065 -3.611,0.281 -8.467,0.424 -14.558,0.424 -2.41,0 -4.676,-0.392 -6.801,-1.168 -2.126,-0.78 -3.968,-2.125 -5.526,-4.037 -1.56,-1.916 -2.799,-4.464 -3.719,-7.654 -0.922,-3.185 -1.382,-7.119 -1.382,-11.794 V 95.2129 c 0,-4.6738 0.46,-8.609 1.382,-11.7938 0.92,-3.191 2.159,-5.7402 3.719,-7.655 1.558,-1.911 3.4,-3.2602 5.526,-4.036 2.125,-0.7801 4.391,-1.1679 6.801,-1.1679 6.091,0 10.947,0.139 14.558,0.4238 3.613,0.2808 7.403,0.6371 11.37,1.0652 h 0.426 c 1.132,0 2.089,-0.3211 2.869,-0.9582 0.778,-0.6379 1.169,-1.5238 1.169,-2.6558 v -18.918 c 0,-1.5582 -0.355,-2.6551 -1.062,-3.2934" /><path
+       inkscape:connector-curvature="0"
+       id="path26"
+       style="fill:#4a7cc8;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 447.479,44.7371 c -0.923,-0.923 -1.948,-1.382 -3.081,-1.382 h -25.716 c -1.136,0 -2.125,0.459 -2.976,1.3781 -0.849,0.9188 -1.274,1.9438 -1.274,3.0746 v 70.6152 c 0,3.673 -0.212,6.785 -0.638,9.331 -0.425,2.541 -1.206,4.592 -2.338,6.147 -1.136,1.552 -2.729,2.649 -4.781,3.286 -2.056,0.637 -4.714,0.957 -7.971,0.957 -3.119,0 -6.307,-0.636 -9.563,-1.911 -3.262,-1.27 -6.733,-2.894 -10.415,-4.874 V 47.8078 c 0,-1.1308 -0.424,-2.1558 -1.275,-3.0746 -0.85,-0.9191 -1.844,-1.3781 -2.975,-1.3781 h -25.715 c -1.136,0 -2.163,0.459 -3.083,1.382 -0.922,0.918 -1.382,1.9469 -1.382,3.0828 V 202.116 c 0,1.132 0.426,2.125 1.276,2.976 0.85,0.847 1.839,1.275 2.975,1.275 h 25.929 c 1.131,0 2.125,-0.432 2.975,-1.278 0.851,-0.851 1.275,-1.845 1.275,-2.98 v -44.908 c 5.384,3.566 10.553,6.066 15.516,7.493 4.957,1.428 10.626,2.14 17.002,2.14 7.65,0 13.921,-1.275 18.808,-3.823 4.888,-2.553 8.715,-5.988 11.477,-10.31 2.763,-4.321 4.676,-9.423 5.739,-15.301 1.063,-5.881 1.593,-12.149 1.593,-18.809 V 47.8199 c 0,-1.1359 -0.461,-2.1648 -1.382,-3.0828" /><path
+       inkscape:connector-curvature="0"
+       id="path28"
+       style="fill:#4a7cc8;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 577.548,44.7371 c -0.924,-0.923 -1.949,-1.382 -3.082,-1.382 H 548.75 c -1.136,0 -2.125,0.459 -2.977,1.3781 -0.848,0.9188 -1.274,1.9438 -1.274,3.0746 v 70.6152 c 0,3.673 -0.212,6.785 -0.637,9.331 -0.425,2.541 -1.207,4.592 -2.339,6.147 -1.135,1.552 -2.729,2.649 -4.781,3.286 -2.055,0.637 -4.713,0.957 -7.971,0.957 -3.118,0 -6.306,-0.636 -9.563,-1.911 -3.261,-1.27 -6.731,-2.894 -10.415,-4.874 V 47.8078 c 0,-1.1308 -0.423,-2.1558 -1.274,-3.0746 -0.851,-0.9191 -1.844,-1.3781 -2.976,-1.3781 h -25.715 c -1.136,0 -2.162,0.459 -3.083,1.382 -0.922,0.918 -1.381,1.9469 -1.381,3.0828 V 160.886 c 0,1.131 0.426,2.125 1.277,2.975 0.848,0.848 1.838,1.275 2.973,1.275 h 23.804 c 1.132,0 2.125,-0.431 2.976,-1.289 0.851,-0.858 1.274,-1.858 1.274,-2.998 v -5.147 c 5.809,4.137 11.335,7.027 16.579,8.669 5.24,1.641 11.263,2.463 18.065,2.463 7.65,0 13.92,-1.275 18.808,-3.823 4.888,-2.553 8.715,-5.988 11.477,-10.31 2.762,-4.321 4.676,-9.423 5.739,-15.301 1.062,-5.881 1.593,-12.149 1.593,-18.809 V 47.8199 c 0,-1.1359 -0.461,-2.1648 -1.381,-3.0828" /><path
+       inkscape:connector-curvature="0"
+       id="path30"
+       style="fill:#4a7cc8;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 673.292,111.577 c 0,17.284 -6.271,25.931 -18.81,25.931 -6.2,0 -10.918,-2.164 -14.16,-6.483 -3.241,-4.325 -4.86,-10.808 -4.86,-19.448 V 96.7012 c 0,-8.6442 1.619,-15.1621 4.86,-19.5551 3.242,-4.3922 7.96,-6.5859 14.16,-6.5859 12.539,0 18.81,8.7148 18.81,26.141 z m 34.43,-14.8758 c 0,-8.502 -1.173,-16.1512 -3.514,-22.9551 -2.344,-6.7992 -5.751,-12.5731 -10.222,-17.318 -4.473,-4.7492 -10.008,-8.434 -16.61,-11.0539 -6.602,-2.6203 -14.232,-3.9301 -22.894,-3.9301 -8.66,0 -16.292,1.3098 -22.892,3.9301 -6.602,2.6199 -12.175,6.3047 -16.717,11.0539 -4.542,4.7449 -7.987,10.5188 -10.327,17.318 -2.346,6.8039 -3.514,14.4531 -3.514,22.9551 v 14.8758 c 0,8.501 1.168,16.151 3.514,22.954 2.34,6.8 5.785,12.574 10.327,17.319 4.542,4.746 10.115,8.43 16.717,11.054 6.6,2.62 14.232,3.93 22.892,3.93 8.662,0 16.292,-1.31 22.894,-3.93 6.602,-2.624 12.137,-6.308 16.61,-11.054 4.471,-4.745 7.878,-10.519 10.222,-17.319 2.341,-6.803 3.514,-14.453 3.514,-22.954 V 96.7012" /><path
+       inkscape:connector-curvature="0"
+       id="path32"
+       style="fill:#4a7cc8;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 762.872,44.7371 c -0.782,-0.923 -1.737,-1.382 -2.87,-1.382 h -25.928 c -1.136,0 -2.163,0.459 -3.083,1.382 -0.922,0.918 -1.381,1.9469 -1.381,3.0828 V 202.116 c 0,1.132 0.459,2.125 1.381,2.976 0.92,0.847 1.947,1.275 3.083,1.275 h 25.928 c 1.133,0 2.088,-0.428 2.87,-1.275 0.776,-0.851 1.168,-1.844 1.168,-2.976 V 47.8199 c 0,-1.1359 -0.392,-2.1648 -1.168,-3.0828" /><path
+       inkscape:connector-curvature="0"
+       id="path34"
+       style="fill:#4a7cc8;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 858.403,111.577 c 0,17.284 -6.27,25.931 -18.81,25.931 -6.199,0 -10.918,-2.164 -14.159,-6.483 -3.242,-4.325 -4.862,-10.808 -4.862,-19.448 V 96.7012 c 0,-8.6442 1.62,-15.1621 4.862,-19.5551 3.241,-4.3922 7.96,-6.5859 14.159,-6.5859 12.54,0 18.81,8.7148 18.81,26.141 z m 34.43,-14.8758 c 0,-8.502 -1.173,-16.1512 -3.514,-22.9551 -2.344,-6.7992 -5.751,-12.5731 -10.222,-17.318 -4.473,-4.7492 -10.009,-8.434 -16.611,-11.0539 -6.601,-2.6203 -14.232,-3.9301 -22.893,-3.9301 -8.659,0 -16.292,1.3098 -22.892,3.9301 -6.602,2.6199 -12.175,6.3047 -16.718,11.0539 -4.542,4.7449 -7.986,10.5188 -10.327,17.318 -2.345,6.8039 -3.513,14.4531 -3.513,22.9551 v 14.8758 c 0,8.501 1.168,16.151 3.513,22.954 2.341,6.8 5.785,12.574 10.327,17.319 4.543,4.746 10.116,8.43 16.718,11.054 6.6,2.62 14.233,3.93 22.892,3.93 8.661,0 16.292,-1.31 22.893,-3.93 6.602,-2.624 12.138,-6.308 16.611,-11.054 4.471,-4.745 7.878,-10.519 10.222,-17.319 2.341,-6.803 3.514,-14.453 3.514,-22.954 V 96.7012" /><path
+       inkscape:connector-curvature="0"
+       id="path36"
+       style="fill:#4a7cc8;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 985.281,124.967 c 0,4.388 -1.276,8.041 -3.827,10.946 -2.549,2.901 -7.58,4.357 -15.088,4.357 -7.512,0 -12.613,-1.456 -15.303,-4.357 -2.693,-2.905 -4.038,-6.558 -4.038,-10.946 v -1.7 c 0,-1.843 0.246,-3.652 0.744,-5.421 0.495,-1.772 1.453,-3.368 2.87,-4.781 1.415,-1.417 3.363,-2.549 5.844,-3.399 2.478,-0.852 5.771,-1.275 9.883,-1.275 7.508,0 12.539,1.342 15.088,4.037 2.551,2.688 3.827,6.301 3.827,10.839 z m 1.063,-88.624 c 0,0.9929 -0.249,1.9468 -0.744,2.8691 -0.498,0.9219 -1.524,1.8039 -3.081,2.6551 -1.561,0.8519 -3.757,1.7019 -6.589,2.5527 -2.836,0.8473 -6.661,1.8371 -11.478,2.9723 l -15.725,3.4039 c -1.277,-1.8441 -2.305,-3.7949 -3.083,-5.8449 -0.78,-2.0551 -1.169,-4.9242 -1.169,-8.6082 v -1.7032 c 0,-3.6796 1.487,-6.4066 4.463,-8.1789 2.976,-1.7699 8.571,-2.6597 16.791,-2.6597 4.389,0 7.933,0.25 10.625,0.7437 2.69,0.4992 4.782,1.2422 6.27,2.2321 1.488,0.9929 2.478,2.164 2.976,3.507 0.495,1.3492 0.744,2.8019 0.744,4.3558 z m 38.256,111.154 c 0,-1.564 -0.32,-2.624 -0.96,-3.191 -0.63,-0.565 -1.59,-1.06 -2.87,-1.487 l -6.59,-2.126 c 1.28,-1.986 2.38,-4.464 3.3,-7.435 0.92,-2.977 1.38,-5.74 1.38,-8.291 v -1.7 c 0,-13.886 -4.57,-23.9818 -13.71,-30.2869 -9.135,-6.3039 -22.067,-9.4551 -38.784,-9.4551 -4.961,0 -9.352,0.3172 -13.178,0.9539 -3.824,0.6383 -6.8,1.382 -8.925,2.2332 -1.136,-0.7121 -1.914,-1.4562 -2.337,-2.2332 -0.426,-0.7789 -0.64,-1.666 -0.64,-2.6547 0,-1.7023 0.426,-2.9773 1.277,-3.8273 0.849,-0.8508 2.55,-1.5598 5.101,-2.125 l 24.015,-5.3117 c 9.208,-1.986 17.002,-3.9332 23.378,-5.845 6.373,-1.9113 11.513,-4.1121 15.413,-6.589 3.89,-2.4821 6.69,-5.4543 8.39,-8.925 1.7,-3.475 2.55,-7.7571 2.55,-12.8582 V 34.6398 C 1021.41,11.548 1002.85,0 965.729,0 c -17.714,0 -31.137,2.975 -40.275,8.925 -9.139,5.952 -13.708,14.527 -13.708,25.7148 v 1.7032 c 0,4.3922 0.988,8.5679 2.975,12.5379 1.982,3.9652 5.24,7.7203 9.777,11.2632 -3.827,2.125 -6.59,5.0661 -8.289,8.8219 -1.7,3.752 -2.551,7.4012 -2.551,10.9461 0,3.9629 0.883,7.4359 2.657,10.4129 1.77,2.9762 4.001,5.5238 6.695,7.6488 -3.402,2.9772 -5.881,6.8722 -7.439,11.6922 -1.56,4.812 -2.339,9.351 -2.339,13.601 v 1.7 c 0,12.043 4.215,21.747 12.647,29.115 8.429,7.366 21.924,11.054 40.487,11.054 h 52.924 c 1.55,0 2.83,-0.531 3.82,-1.595 0.99,-1.061 1.49,-2.374 1.49,-3.93 v -12.114" /><path
+       inkscape:connector-curvature="0"
+       id="path38"
+       style="fill:#4a7cc8;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 1150.42,161.308 c 0,-0.284 -0.04,-0.459 -0.11,-0.529 -0.07,-0.075 -0.11,-0.25 -0.11,-0.531 l -35.7,-125.18 c -1.7,-5.809 -3.61,-10.8719 -5.74,-15.1969 -2.13,-4.3219 -4.89,-7.8961 -8.29,-10.73321 -3.4,-2.83398 -7.72,-4.99492 -12.96,-6.48281 -5.25,-1.48711 -11.76,-2.230861 -19.56,-2.230861 -1.98,0 -4.18,0.105859 -6.58,0.319922 -2.41,0.21289 -4.82,0.462889 -7.23,0.743749 -2.41,0.28399 -4.68,0.63711 -6.8,1.06133 -2.13,0.42578 -3.83,0.84961 -5.1,1.27695 -1.14,0.42383 -2.16,0.88672 -3.08,1.38203 -0.93,0.49766 -1.38,1.30899 -1.38,2.4418 v 17.2148 c 0,1.1364 0.42,2.0942 1.27,2.8692 0.85,0.7801 1.84,1.168 2.98,1.168 h 0.42 c 1.7,-0.1391 3.72,-0.2809 6.06,-0.4239 2.34,-0.1379 4.74,-0.3199 7.23,-0.5301 2.47,-0.214 4.88,-0.3878 7.22,-0.5339 2.34,-0.1391 4.36,-0.209 6.06,-0.209 3.82,0 6.8,0.7789 8.93,2.3347 2.12,1.5622 3.82,4.4641 5.09,8.7141 l 1.92,6.5902 h -3.19 c -1.99,0 -3.86,0.1739 -5.63,0.5301 -1.78,0.352 -3.51,1.1707 -5.21,2.4457 -1.7,1.2742 -3.29,3.2211 -4.78,5.8449 -1.49,2.6204 -2.87,6.268 -4.15,10.9434 l -28.05,95.6398 c -0.14,0.424 -0.21,0.919 -0.21,1.488 0,2.264 1.41,3.4 4.25,3.4 h 28.26 c 1.14,0 2.02,-0.392 2.66,-1.171 0.64,-0.78 1.1,-1.734 1.38,-2.869 l 19.13,-79.9101 c 0.56,-2.6937 1.42,-4.0398 2.55,-4.0398 h 0.21 0.85 0.85 l 19.77,83.9499 c 0.28,1.135 0.81,2.089 1.59,2.869 0.78,0.779 1.74,1.171 2.87,1.171 h 28.27 c 1.13,0 2.09,-0.356 2.87,-1.065 0.78,-0.708 1.17,-1.63 1.17,-2.763" /><path
+       inkscape:connector-curvature="0"
+       id="path40"
+       style="fill:#3b393d;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 1262.93,44.207 c -3.68,-0.5699 -8.61,-1.1718 -14.76,-1.809 -6.17,-0.6371 -14.99,-0.9539 -26.47,-0.9539 -6.8,0 -13.33,0.5661 -19.59,1.6981 -6.26,1.1316 -11.78,3.3289 -16.56,6.5887 -4.77,3.257 -8.58,7.8961 -11.43,13.9191 -2.85,6.0242 -4.27,13.848 -4.27,23.4852 v 70.5598 c 0,9.634 1.42,17.43 4.27,23.379 2.85,5.951 6.66,10.555 11.43,13.815 4.78,3.257 10.33,5.455 16.66,6.589 6.33,1.133 12.91,1.699 19.7,1.699 5.67,0 10.66,-0.107 14.99,-0.317 4.32,-0.214 8.11,-0.463 11.37,-0.744 3.26,-0.285 6.05,-0.569 8.4,-0.851 2.33,-0.285 4.42,-0.57 6.26,-0.851 2.83,-0.423 4.25,-1.844 4.25,-4.25 v -19.765 c 0,-1.136 -0.42,-2.125 -1.27,-2.975 -0.85,-0.852 -1.85,-1.276 -2.98,-1.276 h -43.14 c -4.96,0 -8.47,-1.028 -10.52,-3.082 -2.06,-2.054 -3.08,-5.845 -3.08,-11.371 v -19.34 h 55.04 c 1.14,0 2.13,-0.424 2.98,-1.275 0.85,-0.851 1.27,-1.84 1.27,-2.976 v -20.188 c 0,-1.135 -0.42,-2.125 -1.27,-2.976 -0.85,-0.85 -1.84,-1.274 -2.98,-1.274 h -55.04 V 87.1352 c 0,-5.525 1.02,-9.3161 3.08,-11.3711 2.05,-2.0532 5.56,-3.0789 10.52,-3.0789 h 43.14 c 1.13,0 2.13,-0.4262 2.98,-1.2743 0.85,-0.8507 1.27,-1.8437 1.27,-2.9757 V 48.6711 c 0,-2.5531 -1.42,-4.041 -4.25,-4.4641" /><path
+       inkscape:connector-curvature="0"
+       id="path42"
+       style="fill:#3b393d;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 1358.57,137.294 c -2.55,0.281 -5.46,0.53 -8.71,0.744 -3.26,0.214 -6.17,0.317 -8.72,0.317 -3.82,0 -6.94,-0.637 -9.35,-1.912 -2.41,-1.274 -4.33,-3.083 -5.74,-5.418 -1.42,-2.339 -2.41,-5.101 -2.97,-8.291 -0.57,-3.186 -0.86,-6.625 -0.86,-10.306 V 95.8488 c 0,-3.8226 0.29,-7.3297 0.86,-10.5187 0.56,-3.1903 1.55,-5.952 2.97,-8.2871 1.41,-2.3391 3.33,-4.1481 5.74,-5.4219 2.41,-1.275 5.53,-1.9109 9.35,-1.9109 3.54,0 6.84,0.1378 9.88,0.423 3.05,0.2848 5.56,0.566 7.55,0.8508 z M 1393,53.1309 c 0,-1.6981 -0.39,-2.9758 -1.17,-3.8239 -0.78,-0.85 -2.59,-1.6289 -5.42,-2.3379 -6.09,-1.5632 -13.11,-2.8703 -21.04,-3.9339 -7.94,-1.0614 -16.01,-1.5911 -24.23,-1.5911 -17.28,0 -30.5,4.745 -39.63,14.2387 -9.15,9.4914 -13.71,22.8793 -13.71,40.166 v 16.5792 c 0,16.717 4.39,29.967 13.17,39.743 8.79,9.775 22.18,14.663 40.17,14.663 2.13,0 4.78,-0.143 7.97,-0.424 3.19,-0.284 6.34,-0.637 9.46,-1.064 v 36.77 c 0,1.132 0.43,2.125 1.28,2.976 0.84,0.847 1.83,1.275 2.97,1.275 h 25.72 c 1.13,0 2.16,-0.428 3.08,-1.275 0.92,-0.851 1.38,-1.844 1.38,-2.976 V 53.1309" /><path
+       inkscape:connector-curvature="0"
+       id="path44"
+       style="fill:#3b393d;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 1521.79,44.6301 c -0.85,-0.8512 -1.84,-1.275 -2.97,-1.275 h -23.81 c -1.13,0 -2.12,0.4281 -2.97,1.2847 -0.86,0.8594 -1.28,1.8594 -1.28,3.0012 v 5.1481 c -5.81,-4.1403 -11.34,-7.034 -16.58,-8.6719 -5.24,-1.6371 -11.26,-2.4633 -18.06,-2.4633 -7.65,0 -13.92,1.2422 -18.81,3.7203 -4.89,2.477 -8.72,5.9168 -11.48,10.3086 -2.76,4.3902 -4.67,9.5274 -5.74,15.4082 -1.06,5.8781 -1.59,12.1461 -1.59,18.8102 v 70.7708 c 0,1.132 0.46,2.157 1.38,3.083 0.92,0.919 1.95,1.381 3.08,1.381 h 25.72 c 1.13,0 2.12,-0.462 2.98,-1.378 0.85,-0.922 1.27,-1.948 1.27,-3.076 V 90.068 c 0,-3.677 0.21,-6.7879 0.64,-9.3301 0.42,-2.5449 1.2,-4.5957 2.34,-6.1508 1.13,-1.5531 2.72,-2.65 4.78,-3.2859 2.05,-0.6371 4.71,-0.9551 7.97,-0.9551 3.11,0 6.3,0.634 9.56,1.9059 3.26,1.273 6.73,2.9 10.42,4.88 v 83.55 c 0,1.128 0.42,2.154 1.27,3.076 0.85,0.916 1.84,1.378 2.98,1.378 h 25.71 c 1.13,0 2.16,-0.462 3.09,-1.381 0.91,-0.926 1.38,-1.951 1.38,-3.083 V 47.6059 c 0,-1.1348 -0.43,-2.1258 -1.28,-2.9758" /><path
+       inkscape:connector-curvature="0"
+       id="path46"
+       style="fill:#3b393d;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.1"
+       d="m 1626.57,46.2238 c -0.71,-0.6359 -1.85,-1.1668 -3.41,-1.5937 -2.97,-0.7082 -6.83,-1.4129 -11.58,-2.125 -4.75,-0.7051 -10.3,-1.061 -16.68,-1.061 -15.02,0 -27.03,4.6028 -36.02,13.8118 -9,9.2101 -13.5,22.5312 -13.5,39.957 v 17.8521 c 0,17.426 4.5,30.743 13.5,39.956 8.99,9.21 21,13.813 36.02,13.813 6.38,0 11.93,-0.353 16.68,-1.061 4.75,-0.712 8.61,-1.417 11.58,-2.125 1.56,-0.427 2.7,-0.958 3.41,-1.595 0.7,-0.637 1.06,-1.737 1.06,-3.293 v -18.917 c 0,-1.136 -0.39,-2.019 -1.17,-2.656 -0.78,-0.637 -1.74,-0.958 -2.87,-0.958 h -0.43 c -3.96,0.428 -7.75,0.781 -11.37,1.065 -3.61,0.281 -8.46,0.424 -14.55,0.424 -2.41,0 -4.68,-0.392 -6.81,-1.168 -2.12,-0.78 -3.96,-2.125 -5.52,-4.037 -1.56,-1.916 -2.8,-4.464 -3.72,-7.654 -0.92,-3.185 -1.38,-7.119 -1.38,-11.794 V 95.2129 c 0,-4.6738 0.46,-8.609 1.38,-11.7938 0.92,-3.191 2.16,-5.7402 3.72,-7.655 1.56,-1.911 3.4,-3.2602 5.52,-4.036 2.13,-0.7801 4.4,-1.1679 6.81,-1.1679 6.09,0 10.94,0.139 14.55,0.4238 3.62,0.2808 7.41,0.6371 11.37,1.0652 h 0.43 c 1.13,0 2.09,-0.3211 2.87,-0.9582 0.78,-0.6379 1.17,-1.5238 1.17,-2.6558 v -18.918 c 0,-1.5582 -0.36,-2.6551 -1.06,-3.2934" /><g
+       transform="scale(0.106948)"
+       id="g48"><path
+         inkscape:connector-curvature="0"
+         id="path50"
+         style="fill:#3b393d;fill-opacity:1;fill-rule:nonzero;stroke:none"
+         d="m 15984,892.268 h -113.3 c -34.5,0 -62.9,-3.002 -85.4,-8.948 -22.6,-5.958 -40.5,-14.913 -53.7,-26.839 -13.3,-11.911 -22.5,-27.16 -27.9,-45.692 -5.2,-18.58 -7.9,-39.75 -7.9,-63.583 v -17.908 c 0,-42.401 10.3,-69.536 30.8,-81.45 20.5,-11.947 52,-17.905 94.5,-17.905 30.4,0 59.2,4.292 86.4,12.912 27.1,8.623 52.6,18.869 76.5,30.831 z m 316,-447.136 c 0,-10.611 -4,-19.877 -12,-27.825 -7.9,-7.959 -17.2,-11.922 -27.7,-11.922 h -222.7 c -10.6,0 -19.8,3.963 -27.8,11.922 -8,7.948 -11.9,17.214 -11.9,27.825 v 31.791 c -38.4,-27.836 -79.2,-49.667 -122.2,-65.573 -43,-15.914 -94.4,-23.833 -154,-23.833 -43.8,0 -85.9,5.629 -126.2,16.878 -40.4,11.246 -76.5,30.126 -108.3,56.643 -31.8,26.47 -57.3,61.581 -76.5,105.323 -19.3,43.713 -28.8,98.018 -28.8,162.937 v 17.908 c 0,116.533 38.7,201.676 116.2,255.344 77.5,53.66 201.7,80.48 372.6,80.48 h 107.3 v 71.53 c 0,56.96 -13.2,94.07 -39.8,111.32 -26.4,17.17 -62.9,25.82 -109.3,25.82 -31.8,0 -63.8,-0.37 -96.3,-1 -32.5,-0.7 -63.7,-1.66 -93.4,-2.99 -29.8,-1.34 -56.7,-2.97 -80.5,-4.96 -23.8,-2 -43.7,-3.66 -59.6,-4.96 h -10 c -10.5,0 -19.1,2.63 -25.8,7.96 -6.6,5.25 -9.9,14.54 -9.9,27.79 v 160.96 c 0,22.54 12.5,37.1 37.7,43.75 37.1,9.25 87.1,18.54 150.1,27.79 62.9,9.26 127.5,13.92 193.7,13.92 71.5,0 136.2,-7.63 193.8,-22.84 57.6,-15.24 106.3,-39.11 146,-71.53 39.7,-32.49 70.6,-74.23 92.5,-125.23 21.9,-50.99 32.8,-112.94 32.8,-185.8 V 445.132" /></g><g
+       transform="scale(0.112502)"
+       id="g52"><path
+         inkscape:connector-curvature="0"
+         id="path54"
+         style="fill:#3b393d;fill-opacity:1;fill-rule:nonzero;stroke:none"
+         d="m 16264.1,383.379 c -29,-4.993 -54.1,-8.764 -75.6,-11.26 -21.4,-2.472 -45.9,-3.733 -73.6,-3.733 -51.4,0 -96.8,4.08 -136.2,12.274 -39.5,8.17 -72.3,24.25 -98.6,48.159 -26.2,23.92 -46.3,56.961 -60,99.172 -13.8,42.177 -20.7,96.665 -20.7,163.439 v 547.84 l -151.1,24.54 c -10.2,2.51 -19.2,7.25 -27.4,14.18 -8.3,6.91 -12.3,15.41 -12.3,25.51 v 124.67 c 0,10.06 4,19.17 12.3,27.41 8.2,8.17 17.2,12.27 27.4,12.27 h 151.1 v 154.89 c 0,10.06 3.7,18.25 11.3,24.56 7.4,6.29 16.2,10.69 26.3,13.22 l 229,39.68 h 5.6 c 10,0 18.2,-2.84 24.4,-8.51 6.3,-5.67 9.4,-13.54 9.4,-23.6 v -200.24 h 155 c 10,0 18.9,-3.83 26.4,-11.43 7.5,-7.62 11.3,-16.54 11.3,-26.68 v -154.25 c 0,-10.19 -3.8,-19.08 -11.3,-26.7 -7.5,-7.59 -16.4,-11.42 -26.4,-11.42 h -155 V 687.624 c 0,-37.777 3.1,-62.044 9.5,-72.71 6.3,-10.729 23.9,-16.07 52.8,-16.07 h 92.7 c 26.4,0 39.6,-10.631 39.6,-31.839 V 420.819 c 0,-21.235 -11.9,-33.732 -35.9,-37.44" /></g><g
+       transform="scale(0.115918)"
+       id="g56"><path
+         inkscape:connector-curvature="0"
+         id="path58"
+         style="fill:#3b393d;fill-opacity:1;fill-rule:nonzero;stroke:none"
+         d="m 16292.7,410.686 c 0,-9.789 -3.7,-18.338 -11,-25.671 -7.3,-7.343 -15.9,-10.999 -25.7,-10.999 h -223.6 c -9.8,0 -18.4,3.656 -25.7,10.999 -7.3,7.333 -11,15.882 -11,25.671 v 977.244 c 0,9.76 3.7,18.33 11,25.67 7.3,7.31 15.9,11 25.7,11 h 223.6 c 9.8,0 18.4,-3.69 25.7,-11 7.3,-7.34 11,-15.91 11,-25.67 z m 7.3,1169.734 c 0,-9.8 -3.6,-18.33 -11,-25.64 -7.3,-7.35 -15.8,-11.03 -25.7,-11.03 H 16025 c -9.8,0 -18.3,3.68 -25.6,11.03 -7.4,7.31 -11.1,15.84 -11.1,25.64 v 170.54 c 0,9.76 3.7,18.33 11.1,25.64 7.3,7.34 15.8,11.03 25.6,11.03 h 238.3 c 9.9,0 18.4,-3.69 25.7,-11.03 7.4,-7.31 11,-15.88 11,-25.64 v -170.54" /></g><g
+       transform="scale(0.123819)"
+       id="g60"><path
+         inkscape:connector-curvature="0"
+         id="path62"
+         style="fill:#3b393d;fill-opacity:1;fill-rule:nonzero;stroke:none"
+         d="m 16022,901.129 c 0,139.591 -50.6,209.431 -151.9,209.431 -50.1,0 -88.2,-17.48 -114.4,-52.36 -26.1,-34.93 -39.2,-87.289 -39.2,-157.071 V 780.988 c 0,-69.813 13.1,-122.454 39.2,-157.933 26.2,-35.472 64.3,-53.19 114.4,-53.19 101.3,0 151.9,70.384 151.9,211.123 z m 278,-120.141 c 0,-68.664 -9.4,-130.442 -28.3,-185.392 -18.9,-54.913 -46.5,-101.544 -82.6,-139.865 -36.1,-38.356 -80.8,-68.116 -134.1,-89.275 -53.3,-21.162 -115,-31.741 -184.9,-31.741 -69.9,0 -131.6,10.579 -184.9,31.741 -53.4,21.159 -98.3,50.919 -135,89.275 -36.7,38.321 -64.5,84.952 -83.4,139.865 -19,54.95 -28.5,116.728 -28.5,185.392 v 120.141 c 0,68.658 9.5,130.441 28.5,185.381 18.9,54.92 46.7,101.56 83.4,139.88 36.7,38.33 81.6,68.08 135,89.27 53.3,21.16 115,31.74 184.9,31.74 69.9,0 131.6,-10.58 184.9,-31.74 53.3,-21.19 98,-50.94 134.1,-89.27 36.1,-38.32 63.7,-84.96 82.6,-139.88 18.9,-54.94 28.3,-116.723 28.3,-185.381 V 780.988" /></g><g
+       transform="scale(0.131577)"
+       id="g64"><path
+         inkscape:connector-curvature="0"
+         id="path66"
+         style="fill:#3b393d;fill-opacity:1;fill-rule:nonzero;stroke:none"
+         d="m 16289.6,340.008 c -7.1,-7.015 -14.8,-10.504 -23.4,-10.504 h -195.5 c -8.7,0 -16.2,3.489 -22.6,10.474 -6.4,6.983 -9.7,14.773 -9.7,23.368 v 536.685 c 0,27.915 -1.7,51.568 -4.9,70.915 -3.2,19.312 -9.2,34.904 -17.7,46.724 -8.6,11.79 -20.7,20.13 -36.4,24.97 -15.6,4.84 -35.8,7.27 -60.5,7.27 -23.8,0 -48,-4.83 -72.7,-14.52 -24.8,-9.65 -51.2,-22 -79.2,-37.045 V 363.346 c 0,-8.595 -3.2,-16.385 -9.7,-23.368 -6.4,-6.985 -14,-10.474 -22.6,-10.474 h -195.5 c -8.6,0 -16.4,3.489 -23.4,10.504 -7,6.977 -10.5,14.796 -10.5,23.43 v 859.312 c 0,8.6 3.3,16.15 9.8,22.61 6.4,6.45 13.9,9.69 22.5,9.69 h 181 c 8.6,0 16.1,-3.27 22.6,-9.79 6.4,-6.52 9.7,-14.12 9.7,-22.79 v -39.11 c 44.1,31.44 86.1,53.4 126,65.88 39.8,12.47 85.6,18.72 137.3,18.72 58.1,0 105.8,-9.69 142.9,-29.06 37.2,-19.4 66.2,-45.5 87.3,-78.35 20.9,-32.84 35.5,-71.62 43.5,-116.29 8.1,-44.697 12.2,-92.335 12.2,-142.953 V 363.438 c 0,-8.634 -3.5,-16.453 -10.5,-23.43" /></g></g></svg>
\ No newline at end of file
index f0aa08f..34f687d 100644 (file)
@@ -1,56 +1,59 @@
 /*!
- * Bootstrap v3.3.7 (http://getbootstrap.com)
- * Copyright 2011-2016 Twitter, Inc.
+ * Bootstrap v3.4.1 (https://getbootstrap.com/)
+ * Copyright 2011-2019 Twitter, Inc.
  * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
  */
 
 // Core variables and mixins
-@import "variables.less";
-@import "mixins.less";
+@import "bootstrap/variables.less";
+@import "bootstrap/mixins.less";
 
 // Reset and dependencies
-@import "normalize.less";
-@import "print.less";
-@import "glyphicons.less";
+@import "bootstrap/normalize.less";
+@import "bootstrap/print.less";
+@import "bootstrap/glyphicons.less";
 
 // Core CSS
-@import "scaffolding.less";
-@import "type.less";
-@import "code.less";
-@import "grid.less";
-@import "tables.less";
-@import "forms.less";
-@import "buttons.less";
+@import "bootstrap/scaffolding.less";
+@import "bootstrap/type.less";
+@import "bootstrap/code.less";
+@import "bootstrap/grid.less";
+@import "bootstrap/tables.less";
+@import "bootstrap/forms.less";
+@import "bootstrap/buttons.less";
 
 // Components
-@import "component-animations.less";
-@import "dropdowns.less";
-@import "button-groups.less";
-@import "input-groups.less";
-@import "navs.less";
-@import "navbar.less";
-@import "breadcrumbs.less";
-@import "pagination.less";
-@import "pager.less";
-@import "labels.less";
-@import "badges.less";
-@import "jumbotron.less";
-@import "thumbnails.less";
-@import "alerts.less";
-@import "progress-bars.less";
-@import "media.less";
-@import "list-group.less";
-@import "panels.less";
-@import "responsive-embed.less";
-@import "wells.less";
-@import "close.less";
+@import "bootstrap/component-animations.less";
+@import "bootstrap/dropdowns.less";
+@import "bootstrap/button-groups.less";
+@import "bootstrap/input-groups.less";
+@import "bootstrap/navs.less";
+@import "bootstrap/navbar.less";
+@import "bootstrap/breadcrumbs.less";
+@import "bootstrap/pagination.less";
+@import "bootstrap/pager.less";
+@import "bootstrap/labels.less";
+@import "bootstrap/badges.less";
+@import "bootstrap/jumbotron.less";
+@import "bootstrap/thumbnails.less";
+@import "bootstrap/alerts.less";
+@import "bootstrap/progress-bars.less";
+@import "bootstrap/media.less";
+@import "bootstrap/list-group.less";
+@import "bootstrap/panels.less";
+@import "bootstrap/responsive-embed.less";
+@import "bootstrap/wells.less";
+@import "bootstrap/close.less";
 
 // Components w/ JavaScript
-@import "modals.less";
-@import "tooltip.less";
-@import "popovers.less";
-@import "carousel.less";
+@import "bootstrap/modals.less";
+@import "bootstrap/tooltip.less";
+@import "bootstrap/popovers.less";
+@import "bootstrap/carousel.less";
 
 // Utility classes
-@import "utilities.less";
-@import "responsive-utilities.less";
+@import "bootstrap/utilities.less";
+@import "bootstrap/responsive-utilities.less";
+
+// Nick
+@import "bootstrap/custom.less";
similarity index 88%
rename from css/alerts.less
rename to css/bootstrap/alerts.less
index c4199db..bdd0df2 100644 (file)
@@ -15,8 +15,7 @@
   // Headings for larger alerts
   h4 {
     margin-top: 0;
-    // Specified for the h4 to prevent conflicts of changing @headings-color
-    color: inherit;
+    color: inherit; // Specified for the h4 to prevent conflicts of changing @headings-color
   }
 
   // Provide class for links that match alerts
@@ -39,7 +38,8 @@
 //
 // Expand the right padding and account for the close button's positioning.
 
-.alert-dismissable, // The misspelled .alert-dismissable was deprecated in 3.2.0.
+// The misspelled .alert-dismissable was deprecated in 3.2.0.
+.alert-dismissable,
 .alert-dismissible {
   padding-right: (@alert-padding + 20);
 
similarity index 100%
rename from css/badges.less
rename to css/bootstrap/badges.less
index 6ee16dc..be7f8d0 100644 (file)
   padding: 3px 7px;
   font-size: @font-size-small;
   font-weight: @badge-font-weight;
-  color: @badge-color;
   line-height: @badge-line-height;
-  vertical-align: middle;
-  white-space: nowrap;
+  color: @badge-color;
   text-align: center;
+  white-space: nowrap;
+  vertical-align: middle;
   background-color: @badge-bg;
   border-radius: @badge-border-radius;
 
similarity index 100%
rename from css/breadcrumbs.less
rename to css/bootstrap/breadcrumbs.less
index cb01d50..e4e5396 100644 (file)
@@ -14,9 +14,9 @@
     display: inline-block;
 
     + li:before {
-      content: "@{breadcrumb-separator}\00a0"; // Unicode space added since inline-block means non-collapsing white-space
       padding: 0 5px;
       color: @breadcrumb-color;
+      content: "@{breadcrumb-separator}\00a0"; // Unicode space added since inline-block means non-collapsing white-space
     }
   }
 
similarity index 97%
rename from css/button-groups.less
rename to css/bootstrap/button-groups.less
index 16db0c6..0472800 100644 (file)
@@ -1,3 +1,5 @@
+// stylelint-disable selector-no-qualifying-type */
+
 //
 // Button groups
 // --------------------------------------------------
 
 // Give the line between buttons some depth
 .btn-group > .btn + .dropdown-toggle {
-  padding-left: 8px;
   padding-right: 8px;
+  padding-left: 8px;
 }
 .btn-group > .btn-lg + .dropdown-toggle {
-  padding-left: 12px;
   padding-right: 12px;
+  padding-left: 12px;
 }
 
 // The clickable button for toggling the menu
 // Remove the gradient and set the same inset shadow as the :active state
 .btn-group.open .dropdown-toggle {
-  .box-shadow(inset 0 3px 5px rgba(0,0,0,.125));
+  .box-shadow(inset 0 3px 5px rgba(0, 0, 0, .125));
 
   // Show no shadow for `.btn-link` since it has no other button styles.
   &.btn-link {
   border-collapse: separate;
   > .btn,
   > .btn-group {
-    float: none;
     display: table-cell;
+    float: none;
     width: 1%;
   }
   > .btn-group .btn {
     input[type="radio"],
     input[type="checkbox"] {
       position: absolute;
-      clip: rect(0,0,0,0);
+      clip: rect(0, 0, 0, 0);
       pointer-events: none;
     }
   }
similarity index 96%
rename from css/buttons.less
rename to css/bootstrap/buttons.less
index 9cbb8f4..17f076b 100644 (file)
@@ -1,3 +1,5 @@
+// stylelint-disable selector-no-qualifying-type
+
 //
 // Buttons
 // --------------------------------------------------
   margin-bottom: 0; // For input.btn
   font-weight: @btn-font-weight;
   text-align: center;
+  white-space: nowrap;
   vertical-align: middle;
   touch-action: manipulation;
   cursor: pointer;
   background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214
   border: 1px solid transparent;
-  white-space: nowrap;
   .button-size(@padding-base-vertical; @padding-base-horizontal; @font-size-base; @line-height-base; @btn-border-radius-base);
   .user-select(none);
 
@@ -38,9 +40,9 @@
 
   &:active,
   &.active {
-    outline: 0;
     background-image: none;
-    .box-shadow(inset 0 3px 5px rgba(0,0,0,.125));
+    outline: 0;
+    .box-shadow(inset 0 3px 5px rgba(0, 0, 0, .125));
   }
 
   &.disabled,
@@ -92,8 +94,8 @@
 
 // Make a button look and behave like a link
 .btn-link {
+  font-weight: 400;
   color: @link-color;
-  font-weight: normal;
   border-radius: 0;
 
   &,
similarity index 90%
rename from css/carousel.less
rename to css/bootstrap/carousel.less
index 252011e..1a24795 100644 (file)
@@ -1,3 +1,5 @@
+// stylelint-disable media-feature-name-no-unknown
+
 //
 // Carousel
 // --------------------------------------------------
 
 .carousel-inner {
   position: relative;
-  overflow: hidden;
   width: 100%;
+  overflow: hidden;
 
   > .item {
-    display: none;
     position: relative;
+    display: none;
     .transition(.6s ease-in-out left);
 
     // Account for jankitude on images
@@ -27,8 +29,8 @@
 
     // WebKit CSS3 transforms for supported devices
     @media all and (transform-3d), (-webkit-transform-3d) {
-      .transition-transform(~'0.6s ease-in-out');
-      .backface-visibility(~'hidden');
+      .transition-transform(~"0.6s ease-in-out");
+      .backface-visibility(~"hidden");
       .perspective(1000px);
 
       &.next,
 .carousel-control {
   position: absolute;
   top: 0;
-  left: 0;
   bottom: 0;
+  left: 0;
   width: @carousel-control-width;
-  .opacity(@carousel-control-opacity);
   font-size: @carousel-control-font-size;
   color: @carousel-control-color;
   text-align: center;
   text-shadow: @carousel-text-shadow;
   background-color: rgba(0, 0, 0, 0); // Fix IE9 click-thru bug
+  .opacity(@carousel-control-opacity);
   // We can't have this transition here because WebKit cancels the carousel
   // animation if you trip this while in the middle of another animation.
 
   // Set gradients for backgrounds
   &.left {
-    #gradient > .horizontal(@start-color: rgba(0,0,0,.5); @end-color: rgba(0,0,0,.0001));
+    #gradient > .horizontal(@start-color: rgba(0, 0, 0, .5); @end-color: rgba(0, 0, 0, .0001));
   }
   &.right {
-    left: auto;
     right: 0;
-    #gradient > .horizontal(@start-color: rgba(0,0,0,.0001); @end-color: rgba(0,0,0,.5));
+    left: auto;
+    #gradient > .horizontal(@start-color: rgba(0, 0, 0, .0001); @end-color: rgba(0, 0, 0, .5));
   }
 
   // Hover/focus state
   &:hover,
   &:focus {
-    outline: 0;
     color: @carousel-control-color;
     text-decoration: none;
+    outline: 0;
     .opacity(.9);
   }
 
   .glyphicon-chevron-right {
     position: absolute;
     top: 50%;
-    margin-top: -10px;
     z-index: 5;
     display: inline-block;
+    margin-top: -10px;
   }
   .icon-prev,
   .glyphicon-chevron-left {
   }
   .icon-prev,
   .icon-next {
-    width:  20px;
+    width: 20px;
     height: 20px;
-    line-height: 1;
     font-family: serif;
+    line-height: 1;
   }
 
-
   .icon-prev {
     &:before {
-      content: '\2039';// SINGLE LEFT-POINTING ANGLE QUOTATION MARK (U+2039)
+      content: "\2039";// SINGLE LEFT-POINTING ANGLE QUOTATION MARK (U+2039)
     }
   }
   .icon-next {
     &:before {
-      content: '\203a';// SINGLE RIGHT-POINTING ANGLE QUOTATION MARK (U+203A)
+      content: "\203a";// SINGLE RIGHT-POINTING ANGLE QUOTATION MARK (U+203A)
     }
   }
 }
   left: 50%;
   z-index: 15;
   width: 60%;
-  margin-left: -30%;
   padding-left: 0;
-  list-style: none;
+  margin-left: -30%;
   text-align: center;
+  list-style: none;
 
   li {
     display: inline-block;
-    width:  10px;
+    width: 10px;
     height: 10px;
     margin: 1px;
     text-indent: -999px;
-    border: 1px solid @carousel-indicator-border-color;
-    border-radius: 10px;
     cursor: pointer;
-
     // IE8-9 hack for event handling
     //
     // Internet Explorer 8-9 does not support clicks on elements without a set
     // For IE8, we set solid black as it doesn't support `rgba()`. For IE9, we
     // set alpha transparency for the best results possible.
     background-color: #000 \9; // IE8
-    background-color: rgba(0,0,0,0); // IE9
+    background-color: rgba(0, 0, 0, 0); // IE9
+
+    border: 1px solid @carousel-indicator-border-color;
+    border-radius: 10px;
   }
+
   .active {
-    margin: 0;
-    width:  12px;
+    width: 12px;
     height: 12px;
+    margin: 0;
     background-color: @carousel-indicator-active-bg;
   }
 }
 // Hidden by default for smaller viewports
 .carousel-caption {
   position: absolute;
-  left: 15%;
   right: 15%;
   bottom: 20px;
+  left: 15%;
   z-index: 10;
   padding-top: 20px;
   padding-bottom: 20px;
   color: @carousel-caption-color;
   text-align: center;
   text-shadow: @carousel-text-shadow;
+
   & .btn {
     text-shadow: none; // No shadow for button elements in carousel-caption
   }
 
   // Show and left align the captions
   .carousel-caption {
-    left: 20%;
     right: 20%;
+    left: 20%;
     padding-bottom: 30px;
   }
 
similarity index 91%
rename from css/close.less
rename to css/bootstrap/close.less
index 6d5bfe0..48baf35 100644 (file)
@@ -1,3 +1,5 @@
+// stylelint-disable property-no-vendor-prefix
+
 //
 // Close icons
 // --------------------------------------------------
@@ -30,5 +32,6 @@
     background: transparent;
     border: 0;
     -webkit-appearance: none;
+    appearance: none;
   }
 }
similarity index 94%
rename from css/code.less
rename to css/bootstrap/code.less
index a08b4d4..4e07976 100644 (file)
@@ -27,12 +27,12 @@ kbd {
   color: @kbd-color;
   background-color: @kbd-bg;
   border-radius: @border-radius-small;
-  box-shadow: inset 0 -1px 0 rgba(0,0,0,.25);
+  box-shadow: inset 0 -1px 0 rgba(0, 0, 0, .25);
 
   kbd {
     padding: 0;
     font-size: 100%;
-    font-weight: bold;
+    font-weight: 700;
     box-shadow: none;
   }
 }
@@ -44,9 +44,9 @@ pre {
   margin: 0 0 (@line-height-computed / 2);
   font-size: (@font-size-base - 1); // 14px to 13px
   line-height: @line-height-base;
+  color: @pre-color;
   word-break: break-all;
   word-wrap: break-word;
-  color: @pre-color;
   background-color: @pre-bg;
   border: 1px solid @pre-border-color;
   border-radius: @border-radius-base;
similarity index 92%
rename from css/component-animations.less
rename to css/bootstrap/component-animations.less
index 0bcee91..4e7cfd0 100644 (file)
@@ -1,3 +1,5 @@
+// stylelint-disable selector-no-qualifying-type
+
 //
 // Component animations
 // --------------------------------------------------
@@ -10,6 +12,7 @@
 .fade {
   opacity: 0;
   .transition(opacity .15s linear);
+
   &.in {
     opacity: 1;
   }
diff --git a/css/bootstrap/custom.less b/css/bootstrap/custom.less
new file mode 100644 (file)
index 0000000..4e57d4f
--- /dev/null
@@ -0,0 +1,35 @@
+// see https://www.w3schools.com/howto/howto_js_rangeslider.asp
+
+.slidecontainer {
+  width: 100%; /* Width of the outside container */
+}
+
+.slider {
+  -webkit-appearance: none;
+  width: 100%;
+  height: 8px; //15px;
+  border-radius: 5px;  
+  background: #d3d3d3;
+  outline: none;
+  opacity: 0.7;
+  -webkit-transition: .2s;
+  transition: opacity .2s;
+}
+
+.slider::-webkit-slider-thumb {
+  -webkit-appearance: none;
+  appearance: none;
+  width: 16px; //25px;
+  height: 16px; //25px;
+  border-radius: 50%; 
+  background: #4CAF50;
+  cursor: pointer;
+}
+
+.slider::-moz-range-thumb {
+  width: 16px; //25px;
+  height: 16px; //25px;
+  border-radius: 50%;
+  background: #4CAF50;
+  cursor: pointer;
+}
similarity index 91%
rename from css/dropdowns.less
rename to css/bootstrap/dropdowns.less
index f6876c1..542c004 100644 (file)
   height: 0;
   margin-left: 2px;
   vertical-align: middle;
-  border-top:   @caret-width-base dashed;
-  border-top:   @caret-width-base solid ~"\9"; // IE8
+  border-top: @caret-width-base dashed;
+  border-top: @caret-width-base solid ~"\9"; // IE8
   border-right: @caret-width-base solid transparent;
-  border-left:  @caret-width-base solid transparent;
+  border-left: @caret-width-base solid transparent;
 }
 
 // The dropdown wrapper (div)
   min-width: 160px;
   padding: 5px 0;
   margin: 2px 0 0; // override default ul
-  list-style: none;
   font-size: @font-size-base;
   text-align: left; // Ensures proper alignment if parent has it changed (e.g., modal footer)
+  list-style: none;
   background-color: @dropdown-bg;
+  background-clip: padding-box;
   border: 1px solid @dropdown-fallback-border; // IE8 fallback
   border: 1px solid @dropdown-border;
   border-radius: @border-radius-base;
-  .box-shadow(0 6px 12px rgba(0,0,0,.175));
-  background-clip: padding-box;
+  .box-shadow(0 6px 12px rgba(0, 0, 0, .175));
 
   // Aligns the dropdown menu to right
   //
     display: block;
     padding: 3px 20px;
     clear: both;
-    font-weight: normal;
+    font-weight: 400;
     line-height: @line-height-base;
     color: @dropdown-link-color;
     white-space: nowrap; // prevent links from randomly breaking onto new lines
-  }
-}
 
-// Hover/Focus state
-.dropdown-menu > li > a {
-  &:hover,
-  &:focus {
-    text-decoration: none;
-    color: @dropdown-link-hover-color;
-    background-color: @dropdown-link-hover-bg;
+    &:hover,
+    &:focus {
+      color: @dropdown-link-hover-color;
+      text-decoration: none;
+      background-color: @dropdown-link-hover-bg;
+    }
   }
 }
 
@@ -90,8 +87,8 @@
   &:focus {
     color: @dropdown-link-active-color;
     text-decoration: none;
-    outline: 0;
     background-color: @dropdown-link-active-bg;
+    outline: 0;
   }
 }
 
   &:hover,
   &:focus {
     text-decoration: none;
+    cursor: @cursor-disabled;
     background-color: transparent;
     background-image: none; // Remove CSS gradient
     .reset-filter();
-    cursor: @cursor-disabled;
   }
 }
 
 // Add extra class to `.dropdown-menu` to flip the alignment of the dropdown
 // menu with the parent.
 .dropdown-menu-right {
-  left: auto; // Reset the default from `.dropdown-menu`
   right: 0;
+  left: auto; // Reset the default from `.dropdown-menu`
 }
 // With v3, we enabled auto-flipping if you have a dropdown within a right
 // aligned nav component. To enable the undoing of that, we provide an override
 // This is only for left-aligning a dropdown menu within a `.navbar-right` or
 // `.pull-right` nav component.
 .dropdown-menu-left {
-  left: 0;
   right: auto;
+  left: 0;
 }
 
 // Dropdown section headers
 // Backdrop to catch body clicks on mobile, etc.
 .dropdown-backdrop {
   position: fixed;
-  left: 0;
+  top: 0;
   right: 0;
   bottom: 0;
-  top: 0;
+  left: 0;
   z-index: (@zindex-dropdown - 10);
 }
 
 .navbar-fixed-bottom .dropdown {
   // Reverse the caret
   .caret {
+    content: "";
     border-top: 0;
     border-bottom: @caret-width-base dashed;
     border-bottom: @caret-width-base solid ~"\9"; // IE8
-    content: "";
   }
   // Different positioning for bottom up menu
   .dropdown-menu {
similarity index 94%
rename from css/forms.less
rename to css/bootstrap/forms.less
index 9377d38..edf19bf 100644 (file)
@@ -1,3 +1,5 @@
+// stylelint-disable selector-no-qualifying-type, property-no-vendor-prefix, media-feature-name-no-vendor-prefix
+
 //
 // Forms
 // --------------------------------------------------
 // Restyle and baseline non-control form elements.
 
 fieldset {
-  padding: 0;
-  margin: 0;
-  border: 0;
   // Chrome and Firefox set a `min-width: min-content;` on fieldsets,
   // so we reset that to ensure it behaves more like a standard block element.
   // See https://github.com/twbs/bootstrap/issues/12359.
   min-width: 0;
+  padding: 0;
+  margin: 0;
+  border: 0;
 }
 
 legend {
@@ -33,7 +35,7 @@ label {
   display: inline-block;
   max-width: 100%; // Force IE8 to wrap long content (see https://github.com/twbs/bootstrap/issues/13141)
   margin-bottom: 5px;
-  font-weight: bold;
+  font-weight: 700;
 }
 
 
@@ -43,9 +45,18 @@ label {
 // is required to ensure optimum display with or without those classes to better
 // address browser inconsistencies.
 
-// Override content-box in Normalize (* isn't specific enough)
 input[type="search"] {
+  // Override content-box in Normalize (* isn't specific enough)
   .box-sizing(border-box);
+
+  // Search inputs in iOS
+  //
+  // This overrides the extra rounded corners on search inputs in iOS so that our
+  // `.form-control` class can properly style them. Note that this cannot simply
+  // be added to `.form-control` as it's not specific enough. For details, see
+  // https://github.com/twbs/bootstrap/issues/11586.
+  -webkit-appearance: none;
+  appearance: none;
 }
 
 // Position radios and checkboxes better
@@ -54,6 +65,16 @@ input[type="checkbox"] {
   margin: 4px 0 0;
   margin-top: 1px \9; // IE8-9
   line-height: normal;
+
+  // Apply same disabled cursor tweak as for inputs
+  // Some special care is needed because <label>s don't inherit their parent's `cursor`.
+  //
+  // Note: Neither radios nor checkboxes can be readonly.
+  &[disabled],
+  &.disabled,
+  fieldset[disabled] & {
+    cursor: @cursor-disabled;
+  }
 }
 
 input[type="file"] {
@@ -123,7 +144,7 @@ output {
   background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214
   border: 1px solid @input-border;
   border-radius: @input-border-radius; // Note: This has no effect on <select>s in some browsers, due to the limited stylability of <select>s in CSS.
-  .box-shadow(inset 0 1px 1px rgba(0,0,0,.075));
+  .box-shadow(inset 0 1px 1px rgba(0, 0, 0, .075));
   .transition(~"border-color ease-in-out .15s, box-shadow ease-in-out .15s");
 
   // Customize the `:focus` state to imitate native WebKit styles.
@@ -134,8 +155,8 @@ output {
 
   // Unstyle the caret on `<select>`s in IE10+.
   &::-ms-expand {
-    border: 0;
     background-color: transparent;
+    border: 0;
   }
 
   // Disabled and read-only inputs
@@ -162,18 +183,6 @@ output {
 }
 
 
-// Search inputs in iOS
-//
-// This overrides the extra rounded corners on search inputs in iOS so that our
-// `.form-control` class can properly style them. Note that this cannot simply
-// be added to `.form-control` as it's not specific enough. For details, see
-// https://github.com/twbs/bootstrap/issues/11586.
-
-input[type="search"] {
-  -webkit-appearance: none;
-}
-
-
 // Special styles for iOS temporal inputs
 //
 // In Mobile Safari, setting `display: block` on temporal inputs causes the
@@ -226,11 +235,19 @@ input[type="search"] {
   margin-top: 10px;
   margin-bottom: 10px;
 
+  // These are used on elements with <label> descendants
+  &.disabled,
+  fieldset[disabled] & {
+    label {
+      cursor: @cursor-disabled;
+    }
+  }
+
   label {
     min-height: @line-height-computed; // Ensure the input doesn't jump when there is no text
     padding-left: 20px;
     margin-bottom: 0;
-    font-weight: normal;
+    font-weight: 400;
     cursor: pointer;
   }
 }
@@ -239,8 +256,8 @@ input[type="search"] {
 .checkbox input[type="checkbox"],
 .checkbox-inline input[type="checkbox"] {
   position: absolute;
-  margin-left: -20px;
   margin-top: 4px \9;
+  margin-left: -20px;
 }
 
 .radio + .radio,
@@ -255,45 +272,20 @@ input[type="search"] {
   display: inline-block;
   padding-left: 20px;
   margin-bottom: 0;
+  font-weight: 400;
   vertical-align: middle;
-  font-weight: normal;
   cursor: pointer;
-}
-.radio-inline + .radio-inline,
-.checkbox-inline + .checkbox-inline {
-  margin-top: 0;
-  margin-left: 10px; // space out consecutive inline controls
-}
 
-// Apply same disabled cursor tweak as for inputs
-// Some special care is needed because <label>s don't inherit their parent's `cursor`.
-//
-// Note: Neither radios nor checkboxes can be readonly.
-input[type="radio"],
-input[type="checkbox"] {
-  &[disabled],
+  // These are used directly on <label>s
   &.disabled,
   fieldset[disabled] & {
     cursor: @cursor-disabled;
   }
 }
-// These classes are used directly on <label>s
-.radio-inline,
-.checkbox-inline {
-  &.disabled,
-  fieldset[disabled] & {
-    cursor: @cursor-disabled;
-  }
-}
-// These classes are used on elements with <label> descendants
-.radio,
-.checkbox {
-  &.disabled,
-  fieldset[disabled] & {
-    label {
-      cursor: @cursor-disabled;
-    }
-  }
+.radio-inline + .radio-inline,
+.checkbox-inline + .checkbox-inline {
+  margin-top: 0;
+  margin-left: 10px; // space out consecutive inline controls
 }
 
 
@@ -303,17 +295,17 @@ input[type="checkbox"] {
 // a horizontal form layout.
 
 .form-control-static {
+  min-height: (@line-height-computed + @font-size-base);
   // Size it appropriately next to real form controls
   padding-top: (@padding-base-vertical + 1);
   padding-bottom: (@padding-base-vertical + 1);
   // Remove default margin from `p`
   margin-bottom: 0;
-  min-height: (@line-height-computed + @font-size-base);
 
   &.input-lg,
   &.input-sm {
-    padding-left: 0;
     padding-right: 0;
+    padding-left: 0;
   }
 }
 
@@ -556,9 +548,9 @@ input[type="checkbox"] {
   .checkbox,
   .radio-inline,
   .checkbox-inline {
+    padding-top: (@padding-base-vertical + 1); // Default padding plus a border
     margin-top: 0;
     margin-bottom: 0;
-    padding-top: (@padding-base-vertical + 1); // Default padding plus a border
   }
   // Account for padding we're adding to ensure the alignment and of help text
   // and other content below items
@@ -576,9 +568,9 @@ input[type="checkbox"] {
   // labels on narrow viewports stack the same as a default form example.
   @media (min-width: @screen-sm-min) {
     .control-label {
-      text-align: right;
-      margin-bottom: 0;
       padding-top: (@padding-base-vertical + 1); // Default padding plus a border
+      margin-bottom: 0;
+      text-align: right;
     }
   }
 
similarity index 96%
rename from css/glyphicons.less
rename to css/bootstrap/glyphicons.less
index 7bc5852..522d504 100644 (file)
@@ -1,3 +1,5 @@
+// stylelint-disable value-list-comma-newline-after, value-list-comma-space-after, indentation, declaration-colon-newline-after, font-family-no-missing-generic-family-keyword
+
 //
 // Glyphicons for Bootstrap
 //
 
 // Import the fonts
 @font-face {
-  font-family: 'Glyphicons Halflings';
-  src: url('@{icon-font-path}@{icon-font-name}.eot');
-  src: url('@{icon-font-path}@{icon-font-name}.eot?#iefix') format('embedded-opentype'),
-       url('@{icon-font-path}@{icon-font-name}.woff2') format('woff2'),
-       url('@{icon-font-path}@{icon-font-name}.woff') format('woff'),
-       url('@{icon-font-path}@{icon-font-name}.ttf') format('truetype'),
-       url('@{icon-font-path}@{icon-font-name}.svg#@{icon-font-svg-id}') format('svg');
+  font-family: "Glyphicons Halflings";
+  src: url("@{icon-font-path}@{icon-font-name}.eot");
+  src: url("@{icon-font-path}@{icon-font-name}.eot?#iefix") format("embedded-opentype"),
+       url("@{icon-font-path}@{icon-font-name}.woff2") format("woff2"),
+       url("@{icon-font-path}@{icon-font-name}.woff") format("woff"),
+       url("@{icon-font-path}@{icon-font-name}.ttf") format("truetype"),
+       url("@{icon-font-path}@{icon-font-name}.svg#@{icon-font-svg-id}") format("svg");
 }
 
 // Catchall baseclass
@@ -23,9 +25,9 @@
   position: relative;
   top: 1px;
   display: inline-block;
-  font-family: 'Glyphicons Halflings';
+  font-family: "Glyphicons Halflings";
   font-style: normal;
-  font-weight: normal;
+  font-weight: 400;
   line-height: 1;
   -webkit-font-smoothing: antialiased;
   -moz-osx-font-smoothing: grayscale;
similarity index 91%
rename from css/grid.less
rename to css/bootstrap/grid.less
index e100655..574f462 100644 (file)
   .make-row();
 }
 
+.row-no-gutters {
+  margin-right: 0;
+  margin-left: 0;
+
+  [class*="col-"] {
+    padding-right: 0;
+    padding-left: 0;
+  }
+}
+
 
 // Columns
 //
similarity index 98%
rename from css/input-groups.less
rename to css/bootstrap/input-groups.less
index d0763db..92b67da 100644 (file)
@@ -1,3 +1,5 @@
+// stylelint-disable selector-no-qualifying-type
+
 //
 // Input groups
 // --------------------------------------------------
@@ -12,8 +14,8 @@
   // Undo padding and float of grid classes
   &[class*="col-"] {
     float: none;
-    padding-left: 0;
     padding-right: 0;
+    padding-left: 0;
   }
 
   .form-control {
@@ -77,7 +79,7 @@
 .input-group-addon {
   padding: @padding-base-vertical @padding-base-horizontal;
   font-size: @font-size-base;
-  font-weight: normal;
+  font-weight: 400;
   line-height: 1;
   color: @input-color;
   text-align: center;
similarity index 84%
rename from css/jumbotron.less
rename to css/bootstrap/jumbotron.less
index 1d9b515..cdf96ba 100644 (file)
@@ -4,7 +4,7 @@
 
 
 .jumbotron {
-  padding-top:    @jumbotron-padding;
+  padding-top: @jumbotron-padding;
   padding-bottom: @jumbotron-padding;
   margin-bottom: @jumbotron-padding;
   color: @jumbotron-color;
@@ -27,9 +27,9 @@
 
   .container &,
   .container-fluid & {
-    border-radius: @border-radius-large; // Only round corners at higher resolutions if contained in a container
-    padding-left:  (@grid-gutter-width / 2);
     padding-right: (@grid-gutter-width / 2);
+    padding-left: (@grid-gutter-width / 2);
+    border-radius: @border-radius-large; // Only round corners at higher resolutions if contained in a container
   }
 
   .container {
   }
 
   @media screen and (min-width: @screen-sm-min) {
-    padding-top:    (@jumbotron-padding * 1.6);
+    padding-top: (@jumbotron-padding * 1.6);
     padding-bottom: (@jumbotron-padding * 1.6);
 
     .container &,
     .container-fluid & {
-      padding-left:  (@jumbotron-padding * 2);
       padding-right: (@jumbotron-padding * 2);
+      padding-left: (@jumbotron-padding * 2);
     }
 
     h1,
similarity index 98%
rename from css/labels.less
rename to css/bootstrap/labels.less
index 9a5a270..cf0d48d 100644 (file)
@@ -6,7 +6,7 @@
   display: inline;
   padding: .2em .6em .3em;
   font-size: 75%;
-  font-weight: bold;
+  font-weight: 700;
   line-height: 1;
   color: @label-color;
   text-align: center;
similarity index 98%
rename from css/list-group.less
rename to css/bootstrap/list-group.less
index 216b912..f913629 100644 (file)
@@ -1,3 +1,5 @@
+// stylelint-disable selector-no-qualifying-type
+
 //
 // List groups
 // --------------------------------------------------
@@ -9,8 +11,8 @@
 
 .list-group {
   // No need to set list-style: none; since .list-group-item is block level
-  margin-bottom: 20px;
   padding-left: 0; // reset padding because ul and ol
+  margin-bottom: 20px;
 }
 
 
     margin-bottom: 0;
     .border-bottom-radius(@list-group-border-radius);
   }
-}
-
-
-// Interactive list items
-//
-// Use anchor or button elements instead of `li`s or `div`s to create interactive items.
-// Includes an extra `.active` modifier class for showing selected items.
-
-a.list-group-item,
-button.list-group-item {
-  color: @list-group-link-color;
-
-  .list-group-item-heading {
-    color: @list-group-link-heading-color;
-  }
-
-  // Hover state
-  &:hover,
-  &:focus {
-    text-decoration: none;
-    color: @list-group-link-hover-color;
-    background-color: @list-group-hover-bg;
-  }
-}
-
-button.list-group-item {
-  width: 100%;
-  text-align: left;
-}
 
-.list-group-item {
   // Disabled state
   &.disabled,
   &.disabled:hover,
   &.disabled:focus {
-    background-color: @list-group-disabled-bg;
     color: @list-group-disabled-color;
     cursor: @cursor-disabled;
+    background-color: @list-group-disabled-bg;
 
     // Force color to inherit for custom content
     .list-group-item-heading {
@@ -105,6 +77,34 @@ button.list-group-item {
 }
 
 
+// Interactive list items
+//
+// Use anchor or button elements instead of `li`s or `div`s to create interactive items.
+// Includes an extra `.active` modifier class for showing selected items.
+
+a.list-group-item,
+button.list-group-item {
+  color: @list-group-link-color;
+
+  .list-group-item-heading {
+    color: @list-group-link-heading-color;
+  }
+
+  // Hover state
+  &:hover,
+  &:focus {
+    color: @list-group-link-hover-color;
+    text-decoration: none;
+    background-color: @list-group-hover-bg;
+  }
+}
+
+button.list-group-item {
+  width: 100%;
+  text-align: left;
+}
+
+
 // Contextual variants
 //
 // Add modifier classes to change text and background color on individual items.
similarity index 100%
rename from css/media.less
rename to css/bootstrap/media.less
index 8c835e8..e4ae445 100644 (file)
@@ -9,8 +9,8 @@
 
 .media,
 .media-body {
-  zoom: 1;
   overflow: hidden;
+  zoom: 1;
 }
 
 .media-body {
similarity index 100%
rename from css/mixins.less
rename to css/bootstrap/mixins.less
diff --git a/css/bootstrap/mixins/alerts.less b/css/bootstrap/mixins/alerts.less
new file mode 100644 (file)
index 0000000..b27cc5d
--- /dev/null
@@ -0,0 +1,15 @@
+// Alerts
+
+.alert-variant(@background; @border; @text-color) {
+  color: @text-color;
+  background-color: @background;
+  border-color: @border;
+
+  hr {
+    border-top-color: darken(@border, 5%);
+  }
+
+  .alert-link {
+    color: darken(@text-color, 10%);
+  }
+}
diff --git a/css/bootstrap/mixins/background-variant.less b/css/bootstrap/mixins/background-variant.less
new file mode 100644 (file)
index 0000000..a85c22b
--- /dev/null
@@ -0,0 +1,9 @@
+// Contextual backgrounds
+
+.bg-variant(@color) {
+  background-color: @color;
+  a&:hover,
+  a&:focus {
+    background-color: darken(@color, 10%);
+  }
+}
diff --git a/css/bootstrap/mixins/border-radius.less b/css/bootstrap/mixins/border-radius.less
new file mode 100644 (file)
index 0000000..da7ea10
--- /dev/null
@@ -0,0 +1,18 @@
+// Single side border-radius
+
+.border-top-radius(@radius) {
+  border-top-left-radius: @radius;
+  border-top-right-radius: @radius;
+}
+.border-right-radius(@radius) {
+  border-top-right-radius: @radius;
+  border-bottom-right-radius: @radius;
+}
+.border-bottom-radius(@radius) {
+  border-bottom-right-radius: @radius;
+  border-bottom-left-radius: @radius;
+}
+.border-left-radius(@radius) {
+  border-top-left-radius: @radius;
+  border-bottom-left-radius: @radius;
+}
diff --git a/css/bootstrap/mixins/buttons.less b/css/bootstrap/mixins/buttons.less
new file mode 100644 (file)
index 0000000..42d3c51
--- /dev/null
@@ -0,0 +1,61 @@
+// Button variants
+//
+// Easily pump out default styles, as well as :hover, :focus, :active,
+// and disabled options for all buttons
+
+.button-variant(@color; @background; @border) {
+  color: @color;
+  background-color: @background;
+  border-color: @border;
+
+  &:focus,
+  &.focus {
+    color: @color;
+    background-color: darken(@background, 10%);
+    border-color: darken(@border, 25%);
+  }
+  &:hover {
+    color: @color;
+    background-color: darken(@background, 10%);
+    border-color: darken(@border, 12%);
+  }
+  &:active,
+  &.active,
+  .open > .dropdown-toggle& {
+    color: @color;
+    background-color: darken(@background, 10%);
+    background-image: none;
+    border-color: darken(@border, 12%);
+
+    &:hover,
+    &:focus,
+    &.focus {
+      color: @color;
+      background-color: darken(@background, 17%);
+      border-color: darken(@border, 25%);
+    }
+  }
+  &.disabled,
+  &[disabled],
+  fieldset[disabled] & {
+    &:hover,
+    &:focus,
+    &.focus {
+      background-color: @background;
+      border-color: @border;
+    }
+  }
+
+  .badge {
+    color: @background;
+    background-color: @color;
+  }
+}
+
+// Button sizes
+.button-size(@padding-vertical; @padding-horizontal; @font-size; @line-height; @border-radius) {
+  padding: @padding-vertical @padding-horizontal;
+  font-size: @font-size;
+  line-height: @line-height;
+  border-radius: @border-radius;
+}
diff --git a/css/bootstrap/mixins/center-block.less b/css/bootstrap/mixins/center-block.less
new file mode 100644 (file)
index 0000000..627cfa3
--- /dev/null
@@ -0,0 +1,7 @@
+// Center-align a block level element
+
+.center-block() {
+  display: block;
+  margin-right: auto;
+  margin-left: auto;
+}
diff --git a/css/bootstrap/mixins/clearfix.less b/css/bootstrap/mixins/clearfix.less
new file mode 100644 (file)
index 0000000..f60fcf1
--- /dev/null
@@ -0,0 +1,22 @@
+// Clearfix
+//
+// For modern browsers
+// 1. The space content is one way to avoid an Opera bug when the
+//    contenteditable attribute is included anywhere else in the document.
+//    Otherwise it causes space to appear at the top and bottom of elements
+//    that are clearfixed.
+// 2. The use of `table` rather than `block` is only necessary if using
+//    `:before` to contain the top-margins of child elements.
+//
+// Source: http://nicolasgallagher.com/micro-clearfix-hack/
+
+.clearfix() {
+  &:before,
+  &:after {
+    display: table; // 2
+    content: " "; // 1
+  }
+  &:after {
+    clear: both;
+  }
+}
diff --git a/css/bootstrap/mixins/forms.less b/css/bootstrap/mixins/forms.less
new file mode 100644 (file)
index 0000000..173dc99
--- /dev/null
@@ -0,0 +1,85 @@
+// Form validation states
+//
+// Used in forms.less to generate the form validation CSS for warnings, errors,
+// and successes.
+
+.form-control-validation(@text-color: #555; @border-color: #ccc; @background-color: #f5f5f5) {
+  // Color the label and help text
+  .help-block,
+  .control-label,
+  .radio,
+  .checkbox,
+  .radio-inline,
+  .checkbox-inline,
+  &.radio label,
+  &.checkbox label,
+  &.radio-inline label,
+  &.checkbox-inline label  {
+    color: @text-color;
+  }
+  // Set the border and box shadow on specific inputs to match
+  .form-control {
+    border-color: @border-color;
+    .box-shadow(inset 0 1px 1px rgba(0, 0, 0, .075)); // Redeclare so transitions work
+    &:focus {
+      border-color: darken(@border-color, 10%);
+      @shadow: inset 0 1px 1px rgba(0, 0, 0, .075), 0 0 6px lighten(@border-color, 20%);
+      .box-shadow(@shadow);
+    }
+  }
+  // Set validation states also for addons
+  .input-group-addon {
+    color: @text-color;
+    background-color: @background-color;
+    border-color: @border-color;
+  }
+  // Optional feedback icon
+  .form-control-feedback {
+    color: @text-color;
+  }
+}
+
+
+// Form control focus state
+//
+// Generate a customized focus state and for any input with the specified color,
+// which defaults to the `@input-border-focus` variable.
+//
+// We highly encourage you to not customize the default value, but instead use
+// this to tweak colors on an as-needed basis. This aesthetic change is based on
+// WebKit's default styles, but applicable to a wider range of browsers. Its
+// usability and accessibility should be taken into account with any change.
+//
+// Example usage: change the default blue border and shadow to white for better
+// contrast against a dark gray background.
+.form-control-focus(@color: @input-border-focus) {
+  @color-rgba: rgba(red(@color), green(@color), blue(@color), .6);
+  &:focus {
+    border-color: @color;
+    outline: 0;
+    .box-shadow(~"inset 0 1px 1px rgba(0, 0, 0, .075), 0 0 8px @{color-rgba}");
+  }
+}
+
+// Form control sizing
+//
+// Relative text size, padding, and border-radii changes for form controls. For
+// horizontal sizing, wrap controls in the predefined grid classes. `<select>`
+// element gets special love because it's special, and that's a fact!
+.input-size(@input-height; @padding-vertical; @padding-horizontal; @font-size; @line-height; @border-radius) {
+  height: @input-height;
+  padding: @padding-vertical @padding-horizontal;
+  font-size: @font-size;
+  line-height: @line-height;
+  border-radius: @border-radius;
+
+  select& {
+    height: @input-height;
+    line-height: @input-height;
+  }
+
+  textarea&,
+  select[multiple]& {
+    height: auto;
+  }
+}
diff --git a/css/bootstrap/mixins/gradients.less b/css/bootstrap/mixins/gradients.less
new file mode 100644 (file)
index 0000000..b36f591
--- /dev/null
@@ -0,0 +1,59 @@
+// stylelint-disable value-no-vendor-prefix, selector-max-id
+
+#gradient {
+
+  // Horizontal gradient, from left to right
+  //
+  // Creates two color stops, start and end, by specifying a color and position for each color stop.
+  // Color stops are not available in IE9 and below.
+  .horizontal(@start-color: #555; @end-color: #333; @start-percent: 0%; @end-percent: 100%) {
+    background-image: -webkit-linear-gradient(left, @start-color @start-percent, @end-color @end-percent); // Safari 5.1-6, Chrome 10+
+    background-image: -o-linear-gradient(left, @start-color @start-percent, @end-color @end-percent); // Opera 12
+    background-image: linear-gradient(to right, @start-color @start-percent, @end-color @end-percent); // Standard, IE10, Firefox 16+, Opera 12.10+, Safari 7+, Chrome 26+
+    filter: e(%("progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=1)", argb(@start-color), argb(@end-color))); // IE9 and down
+    background-repeat: repeat-x;
+  }
+
+  // Vertical gradient, from top to bottom
+  //
+  // Creates two color stops, start and end, by specifying a color and position for each color stop.
+  // Color stops are not available in IE9 and below.
+  .vertical(@start-color: #555; @end-color: #333; @start-percent: 0%; @end-percent: 100%) {
+    background-image: -webkit-linear-gradient(top, @start-color @start-percent, @end-color @end-percent);  // Safari 5.1-6, Chrome 10+
+    background-image: -o-linear-gradient(top, @start-color @start-percent, @end-color @end-percent);  // Opera 12
+    background-image: linear-gradient(to bottom, @start-color @start-percent, @end-color @end-percent); // Standard, IE10, Firefox 16+, Opera 12.10+, Safari 7+, Chrome 26+
+    filter: e(%("progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=0)", argb(@start-color), argb(@end-color))); // IE9 and down
+    background-repeat: repeat-x;
+  }
+
+  .directional(@start-color: #555; @end-color: #333; @deg: 45deg) {
+    background-image: -webkit-linear-gradient(@deg, @start-color, @end-color); // Safari 5.1-6, Chrome 10+
+    background-image: -o-linear-gradient(@deg, @start-color, @end-color); // Opera 12
+    background-image: linear-gradient(@deg, @start-color, @end-color); // Standard, IE10, Firefox 16+, Opera 12.10+, Safari 7+, Chrome 26+
+    background-repeat: repeat-x;
+  }
+  .horizontal-three-colors(@start-color: #00b3ee; @mid-color: #7a43b6; @color-stop: 50%; @end-color: #c3325f) {
+    background-image: -webkit-linear-gradient(left, @start-color, @mid-color @color-stop, @end-color);
+    background-image: -o-linear-gradient(left, @start-color, @mid-color @color-stop, @end-color);
+    background-image: linear-gradient(to right, @start-color, @mid-color @color-stop, @end-color);
+    filter: e(%("progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=1)", argb(@start-color), argb(@end-color))); // IE9 and down, gets no color-stop at all for proper fallback
+    background-repeat: no-repeat;
+  }
+  .vertical-three-colors(@start-color: #00b3ee; @mid-color: #7a43b6; @color-stop: 50%; @end-color: #c3325f) {
+    background-image: -webkit-linear-gradient(@start-color, @mid-color @color-stop, @end-color);
+    background-image: -o-linear-gradient(@start-color, @mid-color @color-stop, @end-color);
+    background-image: linear-gradient(@start-color, @mid-color @color-stop, @end-color);
+    filter: e(%("progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=0)", argb(@start-color), argb(@end-color))); // IE9 and down, gets no color-stop at all for proper fallback
+    background-repeat: no-repeat;
+  }
+  .radial(@inner-color: #555; @outer-color: #333) {
+    background-image: -webkit-radial-gradient(circle, @inner-color, @outer-color);
+    background-image: radial-gradient(circle, @inner-color, @outer-color);
+    background-repeat: no-repeat;
+  }
+  .striped(@color: rgba(255, 255, 255, .15); @angle: 45deg) {
+    background-image: -webkit-linear-gradient(@angle, @color 25%, transparent 25%, transparent 50%, @color 50%, @color 75%, transparent 75%, transparent);
+    background-image: -o-linear-gradient(@angle, @color 25%, transparent 25%, transparent 50%, @color 50%, @color 75%, transparent 75%, transparent);
+    background-image: linear-gradient(@angle, @color 25%, transparent 25%, transparent 50%, @color 50%, @color 75%, transparent 75%, transparent);
+  }
+}
diff --git a/css/bootstrap/mixins/grid-framework.less b/css/bootstrap/mixins/grid-framework.less
new file mode 100644 (file)
index 0000000..0c73c88
--- /dev/null
@@ -0,0 +1,91 @@
+// Framework grid generation
+//
+// Used only by Bootstrap to generate the correct number of grid classes given
+// any value of `@grid-columns`.
+
+.make-grid-columns() {
+  // Common styles for all sizes of grid columns, widths 1-12
+  .col(@index) { // initial
+    @item: ~".col-xs-@{index}, .col-sm-@{index}, .col-md-@{index}, .col-lg-@{index}";
+    .col((@index + 1), @item);
+  }
+  .col(@index, @list) when (@index =< @grid-columns) { // general; "=<" isn't a typo
+    @item: ~".col-xs-@{index}, .col-sm-@{index}, .col-md-@{index}, .col-lg-@{index}";
+    .col((@index + 1), ~"@{list}, @{item}");
+  }
+  .col(@index, @list) when (@index > @grid-columns) { // terminal
+    @{list} {
+      position: relative;
+      // Prevent columns from collapsing when empty
+      min-height: 1px;
+      // Inner gutter via padding
+      padding-right: floor((@grid-gutter-width / 2));
+      padding-left: ceil((@grid-gutter-width / 2));
+    }
+  }
+  .col(1); // kickstart it
+}
+
+.float-grid-columns(@class) {
+  .col(@index) { // initial
+    @item: ~".col-@{class}-@{index}";
+    .col((@index + 1), @item);
+  }
+  .col(@index, @list) when (@index =< @grid-columns) { // general
+    @item: ~".col-@{class}-@{index}";
+    .col((@index + 1), ~"@{list}, @{item}");
+  }
+  .col(@index, @list) when (@index > @grid-columns) { // terminal
+    @{list} {
+      float: left;
+    }
+  }
+  .col(1); // kickstart it
+}
+
+.calc-grid-column(@index, @class, @type) when (@type = width) and (@index > 0) {
+  .col-@{class}-@{index} {
+    width: percentage((@index / @grid-columns));
+  }
+}
+.calc-grid-column(@index, @class, @type) when (@type = push) and (@index > 0) {
+  .col-@{class}-push-@{index} {
+    left: percentage((@index / @grid-columns));
+  }
+}
+.calc-grid-column(@index, @class, @type) when (@type = push) and (@index = 0) {
+  .col-@{class}-push-0 {
+    left: auto;
+  }
+}
+.calc-grid-column(@index, @class, @type) when (@type = pull) and (@index > 0) {
+  .col-@{class}-pull-@{index} {
+    right: percentage((@index / @grid-columns));
+  }
+}
+.calc-grid-column(@index, @class, @type) when (@type = pull) and (@index = 0) {
+  .col-@{class}-pull-0 {
+    right: auto;
+  }
+}
+.calc-grid-column(@index, @class, @type) when (@type = offset) {
+  .col-@{class}-offset-@{index} {
+    margin-left: percentage((@index / @grid-columns));
+  }
+}
+
+// Basic looping in LESS
+.loop-grid-columns(@index, @class, @type) when (@index >= 0) {
+  .calc-grid-column(@index, @class, @type);
+  // next iteration
+  .loop-grid-columns((@index - 1), @class, @type);
+}
+
+// Create grid for specific class
+.make-grid(@class) {
+  .float-grid-columns(@class);
+  .loop-grid-columns(@grid-columns, @class, width);
+  .loop-grid-columns(@grid-columns, @class, pull);
+  .loop-grid-columns(@grid-columns, @class, push);
+  .loop-grid-columns(@grid-columns, @class, offset);
+}
diff --git a/css/bootstrap/mixins/grid.less b/css/bootstrap/mixins/grid.less
new file mode 100644 (file)
index 0000000..a9554a4
--- /dev/null
@@ -0,0 +1,122 @@
+// Grid system
+//
+// Generate semantic grid columns with these mixins.
+
+// Centered container element
+.container-fixed(@gutter: @grid-gutter-width) {
+  padding-right: ceil((@gutter / 2));
+  padding-left: floor((@gutter / 2));
+  margin-right: auto;
+  margin-left: auto;
+  &:extend(.clearfix all);
+}
+
+// Creates a wrapper for a series of columns
+.make-row(@gutter: @grid-gutter-width) {
+  margin-right: floor((@gutter / -2));
+  margin-left: ceil((@gutter / -2));
+  &:extend(.clearfix all);
+}
+
+// Generate the extra small columns
+.make-xs-column(@columns; @gutter: @grid-gutter-width) {
+  position: relative;
+  float: left;
+  width: percentage((@columns / @grid-columns));
+  min-height: 1px;
+  padding-right: (@gutter / 2);
+  padding-left: (@gutter / 2);
+}
+.make-xs-column-offset(@columns) {
+  margin-left: percentage((@columns / @grid-columns));
+}
+.make-xs-column-push(@columns) {
+  left: percentage((@columns / @grid-columns));
+}
+.make-xs-column-pull(@columns) {
+  right: percentage((@columns / @grid-columns));
+}
+
+// Generate the small columns
+.make-sm-column(@columns; @gutter: @grid-gutter-width) {
+  position: relative;
+  min-height: 1px;
+  padding-right: (@gutter / 2);
+  padding-left: (@gutter / 2);
+
+  @media (min-width: @screen-sm-min) {
+    float: left;
+    width: percentage((@columns / @grid-columns));
+  }
+}
+.make-sm-column-offset(@columns) {
+  @media (min-width: @screen-sm-min) {
+    margin-left: percentage((@columns / @grid-columns));
+  }
+}
+.make-sm-column-push(@columns) {
+  @media (min-width: @screen-sm-min) {
+    left: percentage((@columns / @grid-columns));
+  }
+}
+.make-sm-column-pull(@columns) {
+  @media (min-width: @screen-sm-min) {
+    right: percentage((@columns / @grid-columns));
+  }
+}
+
+// Generate the medium columns
+.make-md-column(@columns; @gutter: @grid-gutter-width) {
+  position: relative;
+  min-height: 1px;
+  padding-right: (@gutter / 2);
+  padding-left: (@gutter / 2);
+
+  @media (min-width: @screen-md-min) {
+    float: left;
+    width: percentage((@columns / @grid-columns));
+  }
+}
+.make-md-column-offset(@columns) {
+  @media (min-width: @screen-md-min) {
+    margin-left: percentage((@columns / @grid-columns));
+  }
+}
+.make-md-column-push(@columns) {
+  @media (min-width: @screen-md-min) {
+    left: percentage((@columns / @grid-columns));
+  }
+}
+.make-md-column-pull(@columns) {
+  @media (min-width: @screen-md-min) {
+    right: percentage((@columns / @grid-columns));
+  }
+}
+
+// Generate the large columns
+.make-lg-column(@columns; @gutter: @grid-gutter-width) {
+  position: relative;
+  min-height: 1px;
+  padding-right: (@gutter / 2);
+  padding-left: (@gutter / 2);
+
+  @media (min-width: @screen-lg-min) {
+    float: left;
+    width: percentage((@columns / @grid-columns));
+  }
+}
+.make-lg-column-offset(@columns) {
+  @media (min-width: @screen-lg-min) {
+    margin-left: percentage((@columns / @grid-columns));
+  }
+}
+.make-lg-column-push(@columns) {
+  @media (min-width: @screen-lg-min) {
+    left: percentage((@columns / @grid-columns));
+  }
+}
+.make-lg-column-pull(@columns) {
+  @media (min-width: @screen-lg-min) {
+    right: percentage((@columns / @grid-columns));
+  }
+}
diff --git a/css/bootstrap/mixins/hide-text.less b/css/bootstrap/mixins/hide-text.less
new file mode 100644 (file)
index 0000000..9b21a10
--- /dev/null
@@ -0,0 +1,23 @@
+// stylelint-disable font-family-name-quotes, font-family-no-missing-generic-family-keyword
+
+// CSS image replacement
+//
+// Heads up! v3 launched with only `.hide-text()`, but per our pattern for
+// mixins being reused as classes with the same name, this doesn't hold up. As
+// of v3.0.1 we have added `.text-hide()` and deprecated `.hide-text()`.
+//
+// Source: https://github.com/h5bp/html5-boilerplate/commit/aa0396eae757
+
+// Deprecated as of v3.0.1 (has been removed in v4)
+.hide-text() {
+  font: ~"0/0" a;
+  color: transparent;
+  text-shadow: none;
+  background-color: transparent;
+  border: 0;
+}
+
+// New mixin to use as of v3.0.1
+.text-hide() {
+  .hide-text();
+}
diff --git a/css/bootstrap/mixins/image.less b/css/bootstrap/mixins/image.less
new file mode 100644 (file)
index 0000000..f0dde6b
--- /dev/null
@@ -0,0 +1,30 @@
+// stylelint-disable media-feature-name-no-vendor-prefix, media-feature-parentheses-space-inside, media-feature-name-no-unknown, indentation, at-rule-name-space-after
+
+// Responsive image
+//
+// Keep images from scaling beyond the width of their parents.
+.img-responsive(@display: block) {
+  display: @display;
+  max-width: 100%; // Part 1: Set a maximum relative to the parent
+  height: auto; // Part 2: Scale the height according to the width, otherwise you get stretching
+}
+
+
+// Retina image
+//
+// Short retina mixin for setting background-image and -size. Note that the
+// spelling of `min--moz-device-pixel-ratio` is intentional.
+.img-retina(@file-1x; @file-2x; @width-1x; @height-1x) {
+  background-image: url("@{file-1x}");
+
+  @media
+  only screen and (-webkit-min-device-pixel-ratio: 2),
+  only screen and ( min--moz-device-pixel-ratio: 2),
+  only screen and ( -o-min-device-pixel-ratio: 2/1),
+  only screen and ( min-device-pixel-ratio: 2),
+  only screen and ( min-resolution: 192dpi),
+  only screen and ( min-resolution: 2dppx) {
+    background-image: url("@{file-2x}");
+    background-size: @width-1x @height-1x;
+  }
+}
diff --git a/css/bootstrap/mixins/labels.less b/css/bootstrap/mixins/labels.less
new file mode 100644 (file)
index 0000000..9f7a67e
--- /dev/null
@@ -0,0 +1,12 @@
+// Labels
+
+.label-variant(@color) {
+  background-color: @color;
+
+  &[href] {
+    &:hover,
+    &:focus {
+      background-color: darken(@color, 10%);
+    }
+  }
+}
diff --git a/css/bootstrap/mixins/list-group.less b/css/bootstrap/mixins/list-group.less
new file mode 100644 (file)
index 0000000..03aa190
--- /dev/null
@@ -0,0 +1,30 @@
+// List Groups
+
+.list-group-item-variant(@state; @background; @color) {
+  .list-group-item-@{state} {
+    color: @color;
+    background-color: @background;
+
+    a&,
+    button& {
+      color: @color;
+
+      .list-group-item-heading {
+        color: inherit;
+      }
+
+      &:hover,
+      &:focus {
+        color: @color;
+        background-color: darken(@background, 5%);
+      }
+      &.active,
+      &.active:hover,
+      &.active:focus {
+        color: #fff;
+        background-color: @color;
+        border-color: @color;
+      }
+    }
+  }
+}
diff --git a/css/bootstrap/mixins/nav-divider.less b/css/bootstrap/mixins/nav-divider.less
new file mode 100644 (file)
index 0000000..feb1e9e
--- /dev/null
@@ -0,0 +1,10 @@
+// Horizontal dividers
+//
+// Dividers (basically an hr) within dropdowns and nav lists
+
+.nav-divider(@color: #e5e5e5) {
+  height: 1px;
+  margin: ((@line-height-computed / 2) - 1) 0;
+  overflow: hidden;
+  background-color: @color;
+}
diff --git a/css/bootstrap/mixins/nav-vertical-align.less b/css/bootstrap/mixins/nav-vertical-align.less
new file mode 100644 (file)
index 0000000..d458c78
--- /dev/null
@@ -0,0 +1,9 @@
+// Navbar vertical align
+//
+// Vertically center elements in the navbar.
+// Example: an element has a height of 30px, so write out `.navbar-vertical-align(30px);` to calculate the appropriate top margin.
+
+.navbar-vertical-align(@element-height) {
+  margin-top: ((@navbar-height - @element-height) / 2);
+  margin-bottom: ((@navbar-height - @element-height) / 2);
+}
diff --git a/css/bootstrap/mixins/opacity.less b/css/bootstrap/mixins/opacity.less
new file mode 100644 (file)
index 0000000..32cf411
--- /dev/null
@@ -0,0 +1,7 @@
+// Opacity
+
+.opacity(@opacity) {
+  @opacity-ie: (@opacity * 100);  // IE8 filter
+  filter: ~"alpha(opacity=@{opacity-ie})";
+  opacity: @opacity;
+}
diff --git a/css/bootstrap/mixins/pagination.less b/css/bootstrap/mixins/pagination.less
new file mode 100644 (file)
index 0000000..618804f
--- /dev/null
@@ -0,0 +1,24 @@
+// Pagination
+
+.pagination-size(@padding-vertical; @padding-horizontal; @font-size; @line-height; @border-radius) {
+  > li {
+    > a,
+    > span {
+      padding: @padding-vertical @padding-horizontal;
+      font-size: @font-size;
+      line-height: @line-height;
+    }
+    &:first-child {
+      > a,
+      > span {
+        .border-left-radius(@border-radius);
+      }
+    }
+    &:last-child {
+      > a,
+      > span {
+        .border-right-radius(@border-radius);
+      }
+    }
+  }
+}
diff --git a/css/bootstrap/mixins/panels.less b/css/bootstrap/mixins/panels.less
new file mode 100644 (file)
index 0000000..49ee10d
--- /dev/null
@@ -0,0 +1,24 @@
+// Panels
+
+.panel-variant(@border; @heading-text-color; @heading-bg-color; @heading-border) {
+  border-color: @border;
+
+  & > .panel-heading {
+    color: @heading-text-color;
+    background-color: @heading-bg-color;
+    border-color: @heading-border;
+
+    + .panel-collapse > .panel-body {
+      border-top-color: @border;
+    }
+    .badge {
+      color: @heading-bg-color;
+      background-color: @heading-text-color;
+    }
+  }
+  & > .panel-footer {
+    + .panel-collapse > .panel-body {
+      border-bottom-color: @border;
+    }
+  }
+}
diff --git a/css/bootstrap/mixins/progress-bar.less b/css/bootstrap/mixins/progress-bar.less
new file mode 100644 (file)
index 0000000..f07996a
--- /dev/null
@@ -0,0 +1,10 @@
+// Progress bars
+
+.progress-bar-variant(@color) {
+  background-color: @color;
+
+  // Deprecated parent class requirement as of v3.2.0
+  .progress-striped & {
+    #gradient > .striped();
+  }
+}
diff --git a/css/bootstrap/mixins/reset-filter.less b/css/bootstrap/mixins/reset-filter.less
new file mode 100644 (file)
index 0000000..68cdb5e
--- /dev/null
@@ -0,0 +1,8 @@
+// Reset filters for IE
+//
+// When you need to remove a gradient background, do not forget to use this to reset
+// the IE filter for IE9 and below.
+
+.reset-filter() {
+  filter: e(%("progid:DXImageTransform.Microsoft.gradient(enabled = false)"));
+}
diff --git a/css/bootstrap/mixins/reset-text.less b/css/bootstrap/mixins/reset-text.less
new file mode 100644 (file)
index 0000000..a8754bd
--- /dev/null
@@ -0,0 +1,18 @@
+.reset-text() {
+  font-family: @font-family-base;
+  // We deliberately do NOT reset font-size.
+  font-style: normal;
+  font-weight: 400;
+  line-height: @line-height-base;
+  line-break: auto;
+  text-align: left; // Fallback for where `start` is not supported
+  text-align: start;
+  text-decoration: none;
+  text-shadow: none;
+  text-transform: none;
+  letter-spacing: normal;
+  word-break: normal;
+  word-spacing: normal;
+  word-wrap: normal;
+  white-space: normal;
+}
diff --git a/css/bootstrap/mixins/resize.less b/css/bootstrap/mixins/resize.less
new file mode 100644 (file)
index 0000000..c851328
--- /dev/null
@@ -0,0 +1,6 @@
+// Resize anything
+
+.resizable(@direction) {
+  overflow: auto; // Per CSS3 UI, `resize` only applies when `overflow` isn't `visible`
+  resize: @direction; // Options: horizontal, vertical, both
+}
diff --git a/css/bootstrap/mixins/responsive-visibility.less b/css/bootstrap/mixins/responsive-visibility.less
new file mode 100644 (file)
index 0000000..74d6728
--- /dev/null
@@ -0,0 +1,13 @@
+// stylelint-disable declaration-no-important
+
+.responsive-visibility() {
+  display: block !important;
+  table&  { display: table !important; }
+  tr&     { display: table-row !important; }
+  th&,
+  td&     { display: table-cell !important; }
+}
+
+.responsive-invisibility() {
+  display: none !important;
+}
diff --git a/css/bootstrap/mixins/size.less b/css/bootstrap/mixins/size.less
new file mode 100644 (file)
index 0000000..a8be650
--- /dev/null
@@ -0,0 +1,10 @@
+// Sizing shortcuts
+
+.size(@width; @height) {
+  width: @width;
+  height: @height;
+}
+
+.square(@size) {
+  .size(@size; @size);
+}
diff --git a/css/bootstrap/mixins/tab-focus.less b/css/bootstrap/mixins/tab-focus.less
new file mode 100644 (file)
index 0000000..d12d236
--- /dev/null
@@ -0,0 +1,9 @@
+// WebKit-style focus
+
+.tab-focus() {
+  // WebKit-specific. Other browsers will keep their default outline style.
+  // (Initially tried to also force default via `outline: initial`,
+  // but that seems to erroneously remove the outline in Firefox altogether.)
+  outline: 5px auto -webkit-focus-ring-color;
+  outline-offset: -2px;
+}
diff --git a/css/bootstrap/mixins/table-row.less b/css/bootstrap/mixins/table-row.less
new file mode 100644 (file)
index 0000000..0f287f1
--- /dev/null
@@ -0,0 +1,28 @@
+// Tables
+
+.table-row-variant(@state; @background) {
+  // Exact selectors below required to override `.table-striped` and prevent
+  // inheritance to nested tables.
+  .table > thead > tr,
+  .table > tbody > tr,
+  .table > tfoot > tr {
+    > td.@{state},
+    > th.@{state},
+    &.@{state} > td,
+    &.@{state} > th {
+      background-color: @background;
+    }
+  }
+
+  // Hover states for `.table-hover`
+  // Note: this is not available for cells or rows within `thead` or `tfoot`.
+  .table-hover > tbody > tr {
+    > td.@{state}:hover,
+    > th.@{state}:hover,
+    &.@{state}:hover > td,
+    &:hover > .@{state},
+    &.@{state}:hover > th {
+      background-color: darken(@background, 5%);
+    }
+  }
+}
diff --git a/css/bootstrap/mixins/text-emphasis.less b/css/bootstrap/mixins/text-emphasis.less
new file mode 100644 (file)
index 0000000..9e8a77a
--- /dev/null
@@ -0,0 +1,9 @@
+// Typography
+
+.text-emphasis-variant(@color) {
+  color: @color;
+  a&:hover,
+  a&:focus {
+    color: darken(@color, 10%);
+  }
+}
diff --git a/css/bootstrap/mixins/text-overflow.less b/css/bootstrap/mixins/text-overflow.less
new file mode 100644 (file)
index 0000000..c11ad2f
--- /dev/null
@@ -0,0 +1,8 @@
+// Text overflow
+// Requires inline-block or block for proper styling
+
+.text-overflow() {
+  overflow: hidden;
+  text-overflow: ellipsis;
+  white-space: nowrap;
+}
diff --git a/css/bootstrap/mixins/vendor-prefixes.less b/css/bootstrap/mixins/vendor-prefixes.less
new file mode 100644 (file)
index 0000000..fd0a997
--- /dev/null
@@ -0,0 +1,229 @@
+// stylelint-disable indentation, property-no-vendor-prefix, selector-no-vendor-prefix
+
+// Vendor Prefixes
+//
+// All vendor mixins are deprecated as of v3.2.0 due to the introduction of
+// Autoprefixer in our Gruntfile. They have been removed in v4.
+
+// - Animations
+// - Backface visibility
+// - Box shadow
+// - Box sizing
+// - Content columns
+// - Hyphens
+// - Placeholder text
+// - Transformations
+// - Transitions
+// - User Select
+
+
+// Animations
+.animation(@animation) {
+  -webkit-animation: @animation;
+       -o-animation: @animation;
+          animation: @animation;
+}
+.animation-name(@name) {
+  -webkit-animation-name: @name;
+          animation-name: @name;
+}
+.animation-duration(@duration) {
+  -webkit-animation-duration: @duration;
+          animation-duration: @duration;
+}
+.animation-timing-function(@timing-function) {
+  -webkit-animation-timing-function: @timing-function;
+          animation-timing-function: @timing-function;
+}
+.animation-delay(@delay) {
+  -webkit-animation-delay: @delay;
+          animation-delay: @delay;
+}
+.animation-iteration-count(@iteration-count) {
+  -webkit-animation-iteration-count: @iteration-count;
+          animation-iteration-count: @iteration-count;
+}
+.animation-direction(@direction) {
+  -webkit-animation-direction: @direction;
+          animation-direction: @direction;
+}
+.animation-fill-mode(@fill-mode) {
+  -webkit-animation-fill-mode: @fill-mode;
+          animation-fill-mode: @fill-mode;
+}
+
+// Backface visibility
+// Prevent browsers from flickering when using CSS 3D transforms.
+// Default value is `visible`, but can be changed to `hidden`
+
+.backface-visibility(@visibility) {
+  -webkit-backface-visibility: @visibility;
+     -moz-backface-visibility: @visibility;
+          backface-visibility: @visibility;
+}
+
+// Drop shadows
+//
+// Note: Deprecated `.box-shadow()` as of v3.1.0 since all of Bootstrap's
+// supported browsers that have box shadow capabilities now support it.
+
+.box-shadow(@shadow) {
+  -webkit-box-shadow: @shadow; // iOS <4.3 & Android <4.1
+          box-shadow: @shadow;
+}
+
+// Box sizing
+.box-sizing(@boxmodel) {
+  -webkit-box-sizing: @boxmodel;
+     -moz-box-sizing: @boxmodel;
+          box-sizing: @boxmodel;
+}
+
+// CSS3 Content Columns
+.content-columns(@column-count; @column-gap: @grid-gutter-width) {
+  -webkit-column-count: @column-count;
+     -moz-column-count: @column-count;
+          column-count: @column-count;
+  -webkit-column-gap: @column-gap;
+     -moz-column-gap: @column-gap;
+          column-gap: @column-gap;
+}
+
+// Optional hyphenation
+.hyphens(@mode: auto) {
+  -webkit-hyphens: @mode;
+     -moz-hyphens: @mode;
+      -ms-hyphens: @mode; // IE10+
+       -o-hyphens: @mode;
+          hyphens: @mode;
+  word-wrap: break-word;
+}
+
+// Placeholder text
+.placeholder(@color: @input-color-placeholder) {
+  // Firefox
+  &::-moz-placeholder {
+    color: @color;
+    opacity: 1; // Override Firefox's unusual default opacity; see https://github.com/twbs/bootstrap/pull/11526
+  }
+  &:-ms-input-placeholder { color: @color; } // Internet Explorer 10+
+  &::-webkit-input-placeholder  { color: @color; } // Safari and Chrome
+}
+
+// Transformations
+.scale(@ratio) {
+  -webkit-transform: scale(@ratio);
+      -ms-transform: scale(@ratio); // IE9 only
+       -o-transform: scale(@ratio);
+          transform: scale(@ratio);
+}
+.scale(@ratioX; @ratioY) {
+  -webkit-transform: scale(@ratioX, @ratioY);
+      -ms-transform: scale(@ratioX, @ratioY); // IE9 only
+       -o-transform: scale(@ratioX, @ratioY);
+          transform: scale(@ratioX, @ratioY);
+}
+.scaleX(@ratio) {
+  -webkit-transform: scaleX(@ratio);
+      -ms-transform: scaleX(@ratio); // IE9 only
+       -o-transform: scaleX(@ratio);
+          transform: scaleX(@ratio);
+}
+.scaleY(@ratio) {
+  -webkit-transform: scaleY(@ratio);
+      -ms-transform: scaleY(@ratio); // IE9 only
+       -o-transform: scaleY(@ratio);
+          transform: scaleY(@ratio);
+}
+.skew(@x; @y) {
+  -webkit-transform: skewX(@x) skewY(@y);
+      -ms-transform: skewX(@x) skewY(@y); // See https://github.com/twbs/bootstrap/issues/4885; IE9+
+       -o-transform: skewX(@x) skewY(@y);
+          transform: skewX(@x) skewY(@y);
+}
+.translate(@x; @y) {
+  -webkit-transform: translate(@x, @y);
+      -ms-transform: translate(@x, @y); // IE9 only
+       -o-transform: translate(@x, @y);
+          transform: translate(@x, @y);
+}
+.translate3d(@x; @y; @z) {
+  -webkit-transform: translate3d(@x, @y, @z);
+          transform: translate3d(@x, @y, @z);
+}
+.rotate(@degrees) {
+  -webkit-transform: rotate(@degrees);
+      -ms-transform: rotate(@degrees); // IE9 only
+       -o-transform: rotate(@degrees);
+          transform: rotate(@degrees);
+}
+.rotateX(@degrees) {
+  -webkit-transform: rotateX(@degrees);
+      -ms-transform: rotateX(@degrees); // IE9 only
+       -o-transform: rotateX(@degrees);
+          transform: rotateX(@degrees);
+}
+.rotateY(@degrees) {
+  -webkit-transform: rotateY(@degrees);
+      -ms-transform: rotateY(@degrees); // IE9 only
+       -o-transform: rotateY(@degrees);
+          transform: rotateY(@degrees);
+}
+.perspective(@perspective) {
+  -webkit-perspective: @perspective;
+     -moz-perspective: @perspective;
+          perspective: @perspective;
+}
+.perspective-origin(@perspective) {
+  -webkit-perspective-origin: @perspective;
+     -moz-perspective-origin: @perspective;
+          perspective-origin: @perspective;
+}
+.transform-origin(@origin) {
+  -webkit-transform-origin: @origin;
+     -moz-transform-origin: @origin;
+      -ms-transform-origin: @origin; // IE9 only
+          transform-origin: @origin;
+}
+
+
+// Transitions
+
+.transition(@transition) {
+  -webkit-transition: @transition;
+       -o-transition: @transition;
+          transition: @transition;
+}
+.transition-property(@transition-property) {
+  -webkit-transition-property: @transition-property;
+          transition-property: @transition-property;
+}
+.transition-delay(@transition-delay) {
+  -webkit-transition-delay: @transition-delay;
+          transition-delay: @transition-delay;
+}
+.transition-duration(@transition-duration) {
+  -webkit-transition-duration: @transition-duration;
+          transition-duration: @transition-duration;
+}
+.transition-timing-function(@timing-function) {
+  -webkit-transition-timing-function: @timing-function;
+          transition-timing-function: @timing-function;
+}
+.transition-transform(@transition) {
+  -webkit-transition: -webkit-transform @transition;
+     -moz-transition: -moz-transform @transition;
+       -o-transition: -o-transform @transition;
+          transition: transform @transition;
+}
+
+
+// User select
+// For selecting text on the page
+
+.user-select(@select) {
+  -webkit-user-select: @select;
+     -moz-user-select: @select;
+      -ms-user-select: @select; // IE10+
+          user-select: @select;
+}
similarity index 96%
rename from css/modals.less
rename to css/bootstrap/modals.less
index 767ce36..2fe8e56 100644 (file)
 
 // Container that the modal scrolls within
 .modal {
-  display: none;
-  overflow: hidden;
   position: fixed;
   top: 0;
   right: 0;
   bottom: 0;
   left: 0;
   z-index: @zindex-modal;
+  display: none;
+  overflow: hidden;
   -webkit-overflow-scrolling: touch;
 
   // Prevent Chrome on Windows from adding a focus outline. For details, see
@@ -33,7 +33,7 @@
     .translate(0, -25%);
     .transition-transform(~"0.3s ease-out");
   }
-  &.in .modal-dialog { .translate(0, 0) }
+  &.in .modal-dialog { .translate(0, 0); }
 }
 .modal-open .modal {
   overflow-x: hidden;
 .modal-content {
   position: relative;
   background-color: @modal-content-bg;
+  background-clip: padding-box;
   border: 1px solid @modal-content-fallback-border-color; //old browsers fallback (ie8 etc)
   border: 1px solid @modal-content-border-color;
   border-radius: @border-radius-large;
-  .box-shadow(0 3px 9px rgba(0,0,0,.5));
-  background-clip: padding-box;
+  .box-shadow(0 3px 9px rgba(0, 0, 0, .5));
   // Remove focus outline from opened modal
   outline: 0;
 }
 
   // Properly space out buttons
   .btn + .btn {
-    margin-left: 5px;
     margin-bottom: 0; // account for input[type="submit"] which gets the bottom margin like all other inputs
+    margin-left: 5px;
   }
   // but override that for button groups
   .btn-group .btn + .btn {
     margin: 30px auto;
   }
   .modal-content {
-    .box-shadow(0 5px 15px rgba(0,0,0,.5));
+    .box-shadow(0 5px 15px rgba(0, 0, 0, .5));
   }
 
   // Modal sizes
similarity index 95%
rename from css/navbar.less
rename to css/bootstrap/navbar.less
index fc07613..da95e37 100644 (file)
@@ -1,3 +1,5 @@
+// stylelint-disable selector-max-type, selector-max-compound-selectors, selector-max-combinators, selector-max-class, declaration-no-important, selector-no-qualifying-type
+
 //
 // Navbars
 // --------------------------------------------------
@@ -12,7 +14,7 @@
   position: relative;
   min-height: @navbar-height; // Ensure a navbar always shows (e.g., without a .navbar-brand in collapsed mode)
   margin-bottom: @navbar-margin-bottom;
-  // Nick border: 1px solid transparent;
+  border: 1px solid transparent;
 
   // Prevent floats from breaking the navbar
   &:extend(.clearfix all);
 // content for the user's viewport.
 
 .navbar-collapse {
-  overflow-x: visible;
   padding-right: @navbar-padding-horizontal;
-  padding-left:  @navbar-padding-horizontal;
+  padding-left: @navbar-padding-horizontal;
+  overflow-x: visible;
   border-top: 1px solid transparent;
-  box-shadow: inset 0 1px 0 rgba(255,255,255,.1);
+  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .1);
   &:extend(.clearfix all);
   -webkit-overflow-scrolling: touch;
 
@@ -81,8 +83,8 @@
     .navbar-fixed-top &,
     .navbar-static-top &,
     .navbar-fixed-bottom & {
-      padding-left: 0;
       padding-right: 0;
+      padding-left: 0;
     }
   }
 }
       max-height: 200px;
     }
   }
+
+  // Fix the top/bottom navbars when screen real estate supports it
+  position: fixed;
+  right: 0;
+  left: 0;
+  z-index: @zindex-navbar-fixed;
+
+  // Undo the rounded corners
+  @media (min-width: @grid-float-breakpoint) {
+    border-radius: 0;
+  }
+}
+
+.navbar-fixed-top {
+  top: 0;
+  border-width: 0 0 1px;
+}
+.navbar-fixed-bottom {
+  bottom: 0;
+  margin-bottom: 0; // override .navbar defaults
+  border-width: 1px 0 0;
 }
 
 
   > .navbar-header,
   > .navbar-collapse {
     margin-right: -@navbar-padding-horizontal;
-    margin-left:  -@navbar-padding-horizontal;
+    margin-left: -@navbar-padding-horizontal;
 
     @media (min-width: @grid-float-breakpoint) {
       margin-right: 0;
-      margin-left:  0;
+      margin-left: 0;
     }
   }
 }
   }
 }
 
-// Fix the top/bottom navbars when screen real estate supports it
-.navbar-fixed-top,
-.navbar-fixed-bottom {
-  position: fixed;
-  right: 0;
-  left: 0;
-  z-index: @zindex-navbar-fixed;
-
-  // Undo the rounded corners
-  @media (min-width: @grid-float-breakpoint) {
-    border-radius: 0;
-  }
-}
-.navbar-fixed-top {
-  top: 0;
-  border-width: 0 0 1px;
-}
-.navbar-fixed-bottom {
-  bottom: 0;
-  margin-bottom: 0; // override .navbar defaults
-  border-width: 1px 0 0;
-}
-
 
 // Brand/project name
 
 .navbar-brand {
   float: left;
+  height: @navbar-height;
   padding: @navbar-padding-vertical @navbar-padding-horizontal;
   font-size: @font-size-large;
   line-height: @line-height-computed;
-  height: @navbar-height;
 
   &:hover,
   &:focus {
 .navbar-toggle {
   position: relative;
   float: right;
-  margin-right: @navbar-padding-horizontal;
   padding: 9px 10px;
+  margin-right: @navbar-padding-horizontal;
   .navbar-vertical-align(34px);
   background-color: transparent;
   background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214
   margin: (@navbar-padding-vertical / 2) -@navbar-padding-horizontal;
 
   > li > a {
-    padding-top:    10px;
+    padding-top: 10px;
     padding-bottom: 10px;
     line-height: @line-height-computed;
   }
     > li {
       float: left;
       > a {
-        padding-top:    @navbar-padding-vertical;
+        padding-top: @navbar-padding-vertical;
         padding-bottom: @navbar-padding-vertical;
       }
     }
 // our navbars.
 
 .navbar-form {
-  margin-left: -@navbar-padding-horizontal;
-  margin-right: -@navbar-padding-horizontal;
   padding: 10px @navbar-padding-horizontal;
+  margin-right: -@navbar-padding-horizontal;
+  margin-left: -@navbar-padding-horizontal;
   border-top: 1px solid transparent;
   border-bottom: 1px solid transparent;
-  @shadow: inset 0 1px 0 rgba(255,255,255,.1), 0 1px 0 rgba(255,255,255,.1);
+  @shadow: inset 0 1px 0 rgba(255, 255, 255, .1), 0 1px 0 rgba(255, 255, 255, .1);
   .box-shadow(@shadow);
 
   // Mixin behavior for optimum display
   // Undo 100% width for pull classes
   @media (min-width: @grid-float-breakpoint) {
     width: auto;
-    border: 0;
-    margin-left: 0;
-    margin-right: 0;
     padding-top: 0;
     padding-bottom: 0;
+    margin-right: 0;
+    margin-left: 0;
+    border: 0;
     .box-shadow(none);
   }
 }
 
   @media (min-width: @grid-float-breakpoint) {
     float: left;
-    margin-left: @navbar-padding-horizontal;
     margin-right: @navbar-padding-horizontal;
+    margin-left: @navbar-padding-horizontal;
   }
 }
 
         background-color: @navbar-default-link-disabled-bg;
       }
     }
-  }
-
-  .navbar-toggle {
-    border-color: @navbar-default-toggle-border-color;
-    &:hover,
-    &:focus {
-      background-color: @navbar-default-toggle-hover-bg;
-    }
-    .icon-bar {
-      background-color: @navbar-default-toggle-icon-bar-bg;
-    }
-  }
-
-  .navbar-collapse,
-  .navbar-form {
-    border-color: @navbar-default-border;
-  }
 
-  // Dropdown menu items
-  .navbar-nav {
+    // Dropdown menu items
     // Remove background color from open dropdown
     > .open > a {
       &,
       &:hover,
       &:focus {
-        background-color: @navbar-default-link-active-bg;
         color: @navbar-default-link-active-color;
+        background-color: @navbar-default-link-active-bg;
       }
     }
 
     }
   }
 
+  .navbar-toggle {
+    border-color: @navbar-default-toggle-border-color;
+    &:hover,
+    &:focus {
+      background-color: @navbar-default-toggle-hover-bg;
+    }
+    .icon-bar {
+      background-color: @navbar-default-toggle-icon-bar-bg;
+    }
+  }
+
+  .navbar-collapse,
+  .navbar-form {
+    border-color: @navbar-default-border;
+  }
+
 
   // Links in navbars
   //
         background-color: @navbar-inverse-link-disabled-bg;
       }
     }
-  }
 
-  // Darken the responsive nav toggle
-  .navbar-toggle {
-    border-color: @navbar-inverse-toggle-border-color;
-    &:hover,
-    &:focus {
-      background-color: @navbar-inverse-toggle-hover-bg;
-    }
-    .icon-bar {
-      background-color: @navbar-inverse-toggle-icon-bar-bg;
-    }
-  }
-
-  .navbar-collapse,
-  .navbar-form {
-    border-color: darken(@navbar-inverse-bg, 7%);
-  }
-
-  // Dropdowns
-  .navbar-nav {
+    // Dropdowns
     > .open > a {
       &,
       &:hover,
       &:focus {
-        background-color: @navbar-inverse-link-active-bg;
         color: @navbar-inverse-link-active-color;
+        background-color: @navbar-inverse-link-active-bg;
       }
     }
 
     }
   }
 
+  // Darken the responsive nav toggle
+  .navbar-toggle {
+    border-color: @navbar-inverse-toggle-border-color;
+    &:hover,
+    &:focus {
+      background-color: @navbar-inverse-toggle-hover-bg;
+    }
+    .icon-bar {
+      background-color: @navbar-inverse-toggle-icon-bar-bg;
+    }
+  }
+
+  .navbar-collapse,
+  .navbar-form {
+    border-color: darken(@navbar-inverse-bg, 7%);
+  }
+
   .navbar-link {
     color: @navbar-inverse-link-color;
     &:hover {
similarity index 98%
rename from css/navs.less
rename to css/bootstrap/navs.less
index a3d11b1..45df13e 100644 (file)
@@ -1,3 +1,5 @@
+// stylelint-disable selector-no-qualifying-type, selector-max-type
+
 //
 // Navs
 // --------------------------------------------------
@@ -7,8 +9,8 @@
 // --------------------------------------------------
 
 .nav {
-  margin-bottom: 0;
   padding-left: 0; // Override default ul/ol
+  margin-bottom: 0;
   list-style: none;
   &:extend(.clearfix all);
 
@@ -35,8 +37,8 @@
       &:focus {
         color: @nav-disabled-link-hover-color;
         text-decoration: none;
-        background-color: transparent;
         cursor: @cursor-disabled;
+        background-color: transparent;
       }
     }
   }
       &:hover,
       &:focus {
         color: @nav-tabs-active-link-hover-color;
+        cursor: default;
         background-color: @nav-tabs-active-link-hover-bg;
         border: 1px solid @nav-tabs-active-link-hover-border-color;
         border-bottom-color: transparent;
-        cursor: default;
       }
     }
   }
   > li {
     float: none;
     > a {
-      text-align: center;
       margin-bottom: 5px;
+      text-align: center;
     }
   }
 
similarity index 96%
rename from css/normalize.less
rename to css/bootstrap/normalize.less
index 9dddf73..68f9c21 100644 (file)
@@ -1,3 +1,5 @@
+// stylelint-disable
+
 /*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */
 
 //
@@ -104,11 +106,14 @@ a:hover {
 // ==========================================================================
 
 //
-// Address styling not present in IE 8/9/10/11, Safari, and Chrome.
+// 1. Remove the bottom border in Chrome 57- and Firefox 39-.
+// 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 //
 
 abbr[title] {
-  border-bottom: 1px dotted;
+  border-bottom: none; // 1
+  text-decoration: underline; // 2
+  text-decoration: underline dotted; // 2
 }
 
 //
similarity index 100%
rename from css/pager.less
rename to css/bootstrap/pager.less
index 41abaaa..e77ba55 100644 (file)
@@ -6,8 +6,8 @@
 .pager {
   padding-left: 0;
   margin: @line-height-computed 0;
-  list-style: none;
   text-align: center;
+  list-style: none;
   &:extend(.clearfix all);
   li {
     display: inline;
@@ -47,8 +47,8 @@
     > a:focus,
     > span {
       color: @pager-disabled-color;
-      background-color: @pager-bg;
       cursor: @cursor-disabled;
+      background-color: @pager-bg;
     }
   }
 }
similarity index 89%
rename from css/pagination.less
rename to css/bootstrap/pagination.less
index 31f77aa..23b67cb 100644 (file)
       position: relative;
       float: left; // Collapse white-space
       padding: @padding-base-vertical @padding-base-horizontal;
+      margin-left: -1px;
       line-height: @line-height-base;
-      text-decoration: none;
       color: @pagination-color;
+      text-decoration: none;
       background-color: @pagination-bg;
       border: 1px solid @pagination-border;
-      margin-left: -1px;
+
+      &:hover,
+      &:focus {
+        z-index: 2;
+        color: @pagination-hover-color;
+        background-color: @pagination-hover-bg;
+        border-color: @pagination-hover-border;
+      }
     }
     &:first-child {
       > a,
     }
   }
 
-  > li > a,
-  > li > span {
-    &:hover,
-    &:focus {
-      z-index: 2;
-      color: @pagination-hover-color;
-      background-color: @pagination-hover-bg;
-      border-color: @pagination-hover-border;
-    }
-  }
-
   > .active > a,
   > .active > span {
     &,
@@ -54,9 +51,9 @@
     &:focus {
       z-index: 3;
       color: @pagination-active-color;
+      cursor: default;
       background-color: @pagination-active-bg;
       border-color: @pagination-active-border;
-      cursor: default;
     }
   }
 
@@ -68,9 +65,9 @@
     > a:hover,
     > a:focus {
       color: @pagination-disabled-color;
+      cursor: @cursor-disabled;
       background-color: @pagination-disabled-bg;
       border-color: @pagination-disabled-border;
-      cursor: @cursor-disabled;
     }
   }
 }
similarity index 97%
rename from css/panels.less
rename to css/bootstrap/panels.less
index 65aa3a8..f230a84 100644 (file)
@@ -1,3 +1,5 @@
+// stylelint-disable selector-max-type, selector-max-compound-selectors, selector-max-combinators, no-duplicate-selectors
+
 //
 // Panels
 // --------------------------------------------------
@@ -9,7 +11,7 @@
   background-color: @panel-bg;
   border: 1px solid transparent;
   border-radius: @panel-border-radius;
-  .box-shadow(0 1px 1px rgba(0,0,0,.05));
+  .box-shadow(0 1px 1px rgba(0, 0, 0, .05));
 }
 
 // Panel contents
     margin-bottom: 0;
 
     caption {
-      padding-left: @panel-body-padding;
       padding-right: @panel-body-padding;
+      padding-left: @panel-body-padding;
     }
   }
   // Add border top radius for first one
     > tbody:last-child,
     > tfoot:last-child {
       > tr:last-child {
-        border-bottom-left-radius: (@panel-border-radius - 1);
         border-bottom-right-radius: (@panel-border-radius - 1);
+        border-bottom-left-radius: (@panel-border-radius - 1);
 
         td:first-child,
         th:first-child {
     }
   }
   > .table-responsive {
-    border: 0;
     margin-bottom: 0;
+    border: 0;
   }
 }
 
similarity index 81%
rename from css/popovers.less
rename to css/bootstrap/popovers.less
index 3a62a64..3920eb5 100644 (file)
   // So reset our font and text properties to avoid inheriting weird values.
   .reset-text();
   font-size: @font-size-base;
-
   background-color: @popover-bg;
   background-clip: padding-box;
   border: 1px solid @popover-fallback-border-color;
   border: 1px solid @popover-border-color;
   border-radius: @border-radius-large;
-  .box-shadow(0 5px 10px rgba(0,0,0,.2));
+  .box-shadow(0 5px 10px rgba(0, 0, 0, .2));
 
   // Offset the popover to account for the popover arrow
-  &.top     { margin-top: -@popover-arrow-width; }
-  &.right   { margin-left: @popover-arrow-width; }
-  &.bottom  { margin-top: @popover-arrow-width; }
-  &.left    { margin-left: -@popover-arrow-width; }
-}
+  &.top { margin-top: -@popover-arrow-width; }
+  &.right { margin-left: @popover-arrow-width; }
+  &.bottom { margin-top: @popover-arrow-width; }
+  &.left { margin-left: -@popover-arrow-width; }
 
-.popover-title {
-  margin: 0; // reset heading margin
-  padding: 8px 14px;
-  font-size: @font-size-base;
-  background-color: @popover-title-bg;
-  border-bottom: 1px solid darken(@popover-title-bg, 5%);
-  border-radius: (@border-radius-large - 1) (@border-radius-large - 1) 0 0;
-}
+  // Arrows
+  // .arrow is outer, .arrow:after is inner
+  > .arrow {
+    border-width: @popover-arrow-outer-width;
 
-.popover-content {
-  padding: 9px 14px;
-}
-
-// Arrows
-//
-// .arrow is outer, .arrow:after is inner
+    &,
+    &:after {
+      position: absolute;
+      display: block;
+      width: 0;
+      height: 0;
+      border-color: transparent;
+      border-style: solid;
+    }
 
-.popover > .arrow {
-  &,
-  &:after {
-    position: absolute;
-    display: block;
-    width: 0;
-    height: 0;
-    border-color: transparent;
-    border-style: solid;
+    &:after {
+      content: "";
+      border-width: @popover-arrow-width;
+    }
   }
-}
-.popover > .arrow {
-  border-width: @popover-arrow-outer-width;
-}
-.popover > .arrow:after {
-  border-width: @popover-arrow-width;
-  content: "";
-}
 
-.popover {
   &.top > .arrow {
+    bottom: -@popover-arrow-outer-width;
     left: 50%;
     margin-left: -@popover-arrow-outer-width;
-    border-bottom-width: 0;
     border-top-color: @popover-arrow-outer-fallback-color; // IE8 fallback
     border-top-color: @popover-arrow-outer-color;
-    bottom: -@popover-arrow-outer-width;
+    border-bottom-width: 0;
     &:after {
-      content: " ";
       bottom: 1px;
       margin-left: -@popover-arrow-width;
-      border-bottom-width: 0;
+      content: " ";
       border-top-color: @popover-arrow-color;
+      border-bottom-width: 0;
     }
   }
   &.right > .arrow {
     top: 50%;
     left: -@popover-arrow-outer-width;
     margin-top: -@popover-arrow-outer-width;
-    border-left-width: 0;
     border-right-color: @popover-arrow-outer-fallback-color; // IE8 fallback
     border-right-color: @popover-arrow-outer-color;
+    border-left-width: 0;
     &:after {
-      content: " ";
-      left: 1px;
       bottom: -@popover-arrow-width;
-      border-left-width: 0;
+      left: 1px;
+      content: " ";
       border-right-color: @popover-arrow-color;
+      border-left-width: 0;
     }
   }
   &.bottom > .arrow {
+    top: -@popover-arrow-outer-width;
     left: 50%;
     margin-left: -@popover-arrow-outer-width;
     border-top-width: 0;
     border-bottom-color: @popover-arrow-outer-fallback-color; // IE8 fallback
     border-bottom-color: @popover-arrow-outer-color;
-    top: -@popover-arrow-outer-width;
     &:after {
-      content: " ";
       top: 1px;
       margin-left: -@popover-arrow-width;
+      content: " ";
       border-top-width: 0;
       border-bottom-color: @popover-arrow-color;
     }
     border-left-color: @popover-arrow-outer-fallback-color; // IE8 fallback
     border-left-color: @popover-arrow-outer-color;
     &:after {
-      content: " ";
       right: 1px;
+      bottom: -@popover-arrow-width;
+      content: " ";
       border-right-width: 0;
       border-left-color: @popover-arrow-color;
-      bottom: -@popover-arrow-width;
     }
   }
 }
+
+.popover-title {
+  padding: 8px 14px;
+  margin: 0; // reset heading margin
+  font-size: @font-size-base;
+  background-color: @popover-title-bg;
+  border-bottom: 1px solid darken(@popover-title-bg, 5%);
+  border-radius: (@border-radius-large - 1) (@border-radius-large - 1) 0 0;
+}
+
+.popover-content {
+  padding: 9px 14px;
+}
diff --git a/css/bootstrap/print.less b/css/bootstrap/print.less
new file mode 100644 (file)
index 0000000..80458c3
--- /dev/null
@@ -0,0 +1,101 @@
+// stylelint-disable declaration-no-important, selector-no-qualifying-type
+
+/*! Source: https://github.com/h5bp/html5-boilerplate/blob/master/src/css/main.css */
+
+// ==========================================================================
+// Print styles.
+// Inlined to avoid the additional HTTP request: h5bp.com/r
+// ==========================================================================
+
+@media print {
+  *,
+  *:before,
+  *:after {
+    color: #000 !important; // Black prints faster: h5bp.com/s
+    text-shadow: none !important;
+    background: transparent !important;
+    box-shadow: none !important;
+  }
+
+  a,
+  a:visited {
+    text-decoration: underline;
+  }
+
+  a[href]:after {
+    content: " (" attr(href) ")";
+  }
+
+  abbr[title]:after {
+    content: " (" attr(title) ")";
+  }
+
+  // Don't show links that are fragment identifiers,
+  // or use the `javascript:` pseudo protocol
+  a[href^="#"]:after,
+  a[href^="javascript:"]:after {
+    content: "";
+  }
+
+  pre,
+  blockquote {
+    border: 1px solid #999;
+    page-break-inside: avoid;
+  }
+
+  thead {
+    display: table-header-group; // h5bp.com/t
+  }
+
+  tr,
+  img {
+    page-break-inside: avoid;
+  }
+
+  img {
+    max-width: 100% !important;
+  }
+
+  p,
+  h2,
+  h3 {
+    orphans: 3;
+    widows: 3;
+  }
+
+  h2,
+  h3 {
+    page-break-after: avoid;
+  }
+
+  // Bootstrap specific changes start
+
+  // Bootstrap components
+  .navbar {
+    display: none;
+  }
+  .btn,
+  .dropup > .btn {
+    > .caret {
+      border-top-color: #000 !important;
+    }
+  }
+  .label {
+    border: 1px solid #000;
+  }
+
+  .table {
+    border-collapse: collapse !important;
+
+    td,
+    th {
+      background-color: #fff !important;
+    }
+  }
+  .table-bordered {
+    th,
+    td {
+      border: 1px solid #ddd !important;
+    }
+  }
+}
similarity index 92%
rename from css/progress-bars.less
rename to css/bootstrap/progress-bars.less
index 8868a1f..c40ab15 100644 (file)
@@ -1,3 +1,5 @@
+// stylelint-disable at-rule-no-vendor-prefix
+
 //
 // Progress bars
 // --------------------------------------------------
 
 // Outer container
 .progress {
-  overflow: hidden;
   height: @line-height-computed;
   margin-bottom: @line-height-computed;
+  overflow: hidden;
   background-color: @progress-bg;
   border-radius: @progress-border-radius;
-  .box-shadow(inset 0 1px 2px rgba(0,0,0,.1));
+  .box-shadow(inset 0 1px 2px rgba(0, 0, 0, .1));
 }
 
 // Bar of progress
@@ -42,7 +44,7 @@
   color: @progress-bar-color;
   text-align: center;
   background-color: @progress-bar-bg;
-  .box-shadow(inset 0 -1px 0 rgba(0,0,0,.15));
+  .box-shadow(inset 0 -1px 0 rgba(0, 0, 0, .15));
   .transition(width .6s ease);
 }
 
similarity index 100%
rename from css/responsive-embed.less
rename to css/bootstrap/responsive-embed.less
index 080a511..5a0e0b8 100644 (file)
   video {
     position: absolute;
     top: 0;
-    left: 0;
     bottom: 0;
-    height: 100%;
+    left: 0;
     width: 100%;
+    height: 100%;
     border: 0;
   }
 }
similarity index 92%
rename from css/responsive-utilities.less
rename to css/bootstrap/responsive-utilities.less
index b1db31d..5d7740a 100644 (file)
@@ -1,3 +1,5 @@
+// stylelint-disable declaration-no-important, at-rule-no-vendor-prefix
+
 //
 // Responsive: Utility classes
 // --------------------------------------------------
@@ -14,9 +16,9 @@
 // For more information, see the following:
 //
 // Issue: https://github.com/twbs/bootstrap/issues/10497
-// Docs: http://getbootstrap.com/getting-started/#support-ie10-width
-// Source: http://timkadlec.com/2013/01/windows-phone-8-and-device-width/
-// Source: http://timkadlec.com/2012/10/ie10-snap-mode-and-responsive-design/
+// Docs: https://getbootstrap.com/docs/3.4/getting-started/#support-ie10-width
+// Source: https://timkadlec.com/2013/01/windows-phone-8-and-device-width/
+// Source: https://timkadlec.com/2012/10/ie10-snap-mode-and-responsive-design/
 
 @-ms-viewport {
   width: device-width;
similarity index 88%
rename from css/scaffolding.less
rename to css/bootstrap/scaffolding.less
index 64a29c6..df91f07 100644 (file)
@@ -7,7 +7,7 @@
 //
 // Heads up! This reset may cause conflicts with some third-party widgets.
 // For recommendations on resolving such conflicts, see
-// http://getbootstrap.com/getting-started/#third-box-sizing
+// https://getbootstrap.com/docs/3.4/getting-started/#third-box-sizing
 * {
   .box-sizing(border-box);
 }
@@ -21,7 +21,7 @@
 
 html {
   font-size: 10px;
-  -webkit-tap-highlight-color: rgba(0,0,0,0);
+  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
 }
 
 body {
@@ -111,7 +111,7 @@ img {
 // Horizontal rules
 
 hr {
-  margin-top:    @line-height-computed;
+  margin-top: @line-height-computed;
   margin-bottom: @line-height-computed;
   border: 0;
   border-top: 1px solid @hr-border;
@@ -120,21 +120,21 @@ hr {
 
 // Only display content to screen readers
 //
-// See: http://a11yproject.com/posts/how-to-hide-content
+// See: https://a11yproject.com/posts/how-to-hide-content
 
 .sr-only {
   position: absolute;
   width: 1px;
   height: 1px;
-  margin: -1px;
   padding: 0;
+  margin: -1px;
   overflow: hidden;
-  clip: rect(0,0,0,0);
+  clip: rect(0, 0, 0, 0);
   border: 0;
 }
 
 // Use in conjunction with .sr-only to only display content when it's focused.
-// Useful for "Skip to main content" links; see http://www.w3.org/TR/2013/NOTE-WCAG20-TECHS-20130905/G1
+// Useful for "Skip to main content" links; see https://www.w3.org/TR/2013/NOTE-WCAG20-TECHS-20130905/G1
 // Credit: HTML5 Boilerplate
 
 .sr-only-focusable {
similarity index 89%
rename from css/tables.less
rename to css/bootstrap/tables.less
index 2242c03..43411b3 100644 (file)
@@ -1,3 +1,5 @@
+// stylelint-disable selector-max-type, selector-max-compound-selectors, selector-no-qualifying-type
+
 //
 // Tables
 // --------------------------------------------------
@@ -5,13 +7,34 @@
 
 table {
   background-color: @table-bg;
+
+  // Table cell sizing
+  //
+  // Reset default table behavior
+
+  col[class*="col-"] {
+    position: static; // Prevent border hiding in Firefox and IE9-11 (see https://github.com/twbs/bootstrap/issues/11623)
+    display: table-column;
+    float: none;
+  }
+
+  td,
+  th {
+    &[class*="col-"] {
+      position: static; // Prevent border hiding in Firefox and IE9-11 (see https://github.com/twbs/bootstrap/issues/11623)
+      display: table-cell;
+      float: none;
+    }
+  }
 }
+
 caption {
   padding-top: @table-cell-padding;
   padding-bottom: @table-cell-padding;
   color: @text-muted;
   text-align: left;
 }
+
 th {
   text-align: left;
 }
@@ -128,27 +151,6 @@ th {
 }
 
 
-// Table cell sizing
-//
-// Reset default table behavior
-
-table col[class*="col-"] {
-  position: static; // Prevent border hiding in Firefox and IE9-11 (see https://github.com/twbs/bootstrap/issues/11623)
-  float: none;
-  display: table-column;
-}
-table {
-  td,
-  th {
-    &[class*="col-"] {
-      position: static; // Prevent border hiding in Firefox and IE9-11 (see https://github.com/twbs/bootstrap/issues/11623)
-      float: none;
-      display: table-cell;
-    }
-  }
-}
-
-
 // Table backgrounds
 //
 // Exact selectors below required to override `.table-striped` and prevent
@@ -169,12 +171,12 @@ table {
 // will display normally.
 
 .table-responsive {
+  min-height: .01%; // Workaround for IE9 bug (see https://github.com/twbs/bootstrap/issues/14837)
   overflow-x: auto;
-  min-height: 0.01%; // Workaround for IE9 bug (see https://github.com/twbs/bootstrap/issues/14837)
 
   @media screen and (max-width: @screen-xs-max) {
     width: 100%;
-    margin-bottom: (@line-height-computed * 0.75);
+    margin-bottom: (@line-height-computed * .75);
     overflow-y: hidden;
     -ms-overflow-style: -ms-autohiding-scrollbar;
     border: 1px solid @table-border-color;
similarity index 87%
rename from css/theme.less
rename to css/bootstrap/theme.less
index fb61744..8c66f49 100644 (file)
@@ -1,6 +1,8 @@
+// stylelint-disable selector-no-qualifying-type, selector-max-compound-selectors
+
 /*!
- * Bootstrap v3.3.7 (http://getbootstrap.com)
- * Copyright 2011-2016 Twitter, Inc.
+ * Bootstrap v3.4.1 (https://getbootstrap.com/)
+ * Copyright 2011-2019 Twitter, Inc.
  * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
  */
 
 .btn-info,
 .btn-warning,
 .btn-danger {
-  text-shadow: 0 -1px 0 rgba(0,0,0,.2);
-  @shadow: inset 0 1px 0 rgba(255,255,255,.15), 0 1px 1px rgba(0,0,0,.075);
+  text-shadow: 0 -1px 0 rgba(0, 0, 0, .2);
+  @shadow: inset 0 1px 0 rgba(255, 255, 255, .15), 0 1px 1px rgba(0, 0, 0, .075);
   .box-shadow(@shadow);
 
   // Reset the shadow
   &:active,
   &.active {
-    .box-shadow(inset 0 3px 5px rgba(0,0,0,.125));
+    .box-shadow(inset 0 3px 5px rgba(0, 0, 0, .125));
   }
 
   &.disabled,
 }
 
 // Apply the mixin to the buttons
-.btn-default { .btn-styles(@btn-default-bg); text-shadow: 0 1px 0 #fff; border-color: #ccc; }
+.btn-default {
+  .btn-styles(@btn-default-bg);
+  text-shadow: 0 1px 0 #fff;
+  border-color: #ccc;
+}
 .btn-primary { .btn-styles(@btn-primary-bg); }
 .btn-success { .btn-styles(@btn-success-bg); }
 .btn-info    { .btn-styles(@btn-info-bg); }
 
 .thumbnail,
 .img-thumbnail {
-  .box-shadow(0 1px 2px rgba(0,0,0,.075));
+  .box-shadow(0 1px 2px rgba(0, 0, 0, .075));
 }
 
 
   #gradient > .vertical(@start-color: lighten(@navbar-default-bg, 10%); @end-color: @navbar-default-bg);
   .reset-filter(); // Remove gradient in IE<10 to fix bug where dropdowns don't get triggered
   border-radius: @navbar-border-radius;
-  @shadow: inset 0 1px 0 rgba(255,255,255,.15), 0 1px 5px rgba(0,0,0,.075);
+  @shadow: inset 0 1px 0 rgba(255, 255, 255, .15), 0 1px 5px rgba(0, 0, 0, .075);
   .box-shadow(@shadow);
 
   .navbar-nav > .open > a,
   .navbar-nav > .active > a {
     #gradient > .vertical(@start-color: darken(@navbar-default-link-active-bg, 5%); @end-color: darken(@navbar-default-link-active-bg, 2%));
-    .box-shadow(inset 0 3px 9px rgba(0,0,0,.075));
+    .box-shadow(inset 0 3px 9px rgba(0, 0, 0, .075));
   }
 }
 .navbar-brand,
 .navbar-nav > li > a {
-  text-shadow: 0 1px 0 rgba(255,255,255,.25);
+  text-shadow: 0 1px 0 rgba(255, 255, 255, .25);
 }
 
 // Inverted navbar
   .navbar-nav > .open > a,
   .navbar-nav > .active > a {
     #gradient > .vertical(@start-color: @navbar-inverse-link-active-bg; @end-color: lighten(@navbar-inverse-link-active-bg, 2.5%));
-    .box-shadow(inset 0 3px 9px rgba(0,0,0,.25));
+    .box-shadow(inset 0 3px 9px rgba(0, 0, 0, .25));
   }
 
   .navbar-brand,
   .navbar-nav > li > a {
-    text-shadow: 0 -1px 0 rgba(0,0,0,.25);
+    text-shadow: 0 -1px 0 rgba(0, 0, 0, .25);
   }
 }
 
 
 // Common styles
 .alert {
-  text-shadow: 0 1px 0 rgba(255,255,255,.2);
-  @shadow: inset 0 1px 0 rgba(255,255,255,.25), 0 1px 2px rgba(0,0,0,.05);
+  text-shadow: 0 1px 0 rgba(255, 255, 255, .2);
+  @shadow: inset 0 1px 0 rgba(255, 255, 255, .25), 0 1px 2px rgba(0, 0, 0, .05);
   .box-shadow(@shadow);
 }
 
 
 .list-group {
   border-radius: @border-radius-base;
-  .box-shadow(0 1px 2px rgba(0,0,0,.075));
+  .box-shadow(0 1px 2px rgba(0, 0, 0, .075));
 }
 .list-group-item.active,
 .list-group-item.active:hover,
 
 // Common styles
 .panel {
-  .box-shadow(0 1px 2px rgba(0,0,0,.05));
+  .box-shadow(0 1px 2px rgba(0, 0, 0, .05));
 }
 
 // Mixin for generating new styles
 .well {
   #gradient > .vertical(@start-color: darken(@well-bg, 5%); @end-color: @well-bg);
   border-color: darken(@well-bg, 10%);
-  @shadow: inset 0 1px 3px rgba(0,0,0,.05), 0 1px 0 rgba(255,255,255,.1);
+  @shadow: inset 0 1px 3px rgba(0, 0, 0, .05), 0 1px 0 rgba(255, 255, 255, .1);
   .box-shadow(@shadow);
 }
similarity index 93%
rename from css/thumbnails.less
rename to css/bootstrap/thumbnails.less
index 0713e67..11bea9b 100644 (file)
@@ -1,3 +1,5 @@
+// stylelint-disable selector-no-qualifying-type
+
 //
 // Thumbnails
 // --------------------------------------------------
@@ -17,8 +19,8 @@
   > img,
   a > img {
     &:extend(.img-responsive);
-    margin-left: auto;
     margin-right: auto;
+    margin-left: auto;
   }
 
   // Add a hover state for linked versions only
similarity index 85%
rename from css/tooltip.less
rename to css/bootstrap/tooltip.less
index b48d63e..650ab42 100644 (file)
 
   .opacity(0);
 
-  &.in     { .opacity(@tooltip-opacity); }
-  &.top    { margin-top:  -3px; padding: @tooltip-arrow-width 0; }
-  &.right  { margin-left:  3px; padding: 0 @tooltip-arrow-width; }
-  &.bottom { margin-top:   3px; padding: @tooltip-arrow-width 0; }
-  &.left   { margin-left: -3px; padding: 0 @tooltip-arrow-width; }
-}
-
-// Wrapper for the tooltip content
-.tooltip-inner {
-  max-width: @tooltip-max-width;
-  padding: 3px 8px;
-  color: @tooltip-color;
-  text-align: center;
-  background-color: @tooltip-bg;
-  border-radius: @border-radius-base;
-}
+  &.in { .opacity(@tooltip-opacity); }
+  &.top {
+    padding: @tooltip-arrow-width 0;
+    margin-top: -3px;
+  }
+  &.right {
+    padding: 0 @tooltip-arrow-width;
+    margin-left: 3px;
+  }
+  &.bottom {
+    padding: @tooltip-arrow-width 0;
+    margin-top: 3px;
+  }
+  &.left {
+    padding: 0 @tooltip-arrow-width;
+    margin-left: -3px;
+  }
 
-// Arrows
-.tooltip-arrow {
-  position: absolute;
-  width: 0;
-  height: 0;
-  border-color: transparent;
-  border-style: solid;
-}
-// Note: Deprecated .top-left, .top-right, .bottom-left, and .bottom-right as of v3.3.1
-.tooltip {
+  // Note: Deprecated .top-left, .top-right, .bottom-left, and .bottom-right as of v3.3.1
   &.top .tooltip-arrow {
     bottom: 0;
     left: 50%;
@@ -50,8 +42,8 @@
     border-top-color: @tooltip-arrow-color;
   }
   &.top-left .tooltip-arrow {
-    bottom: 0;
     right: @tooltip-arrow-width;
+    bottom: 0;
     margin-bottom: -@tooltip-arrow-width;
     border-width: @tooltip-arrow-width @tooltip-arrow-width 0;
     border-top-color: @tooltip-arrow-color;
     border-bottom-color: @tooltip-arrow-color;
   }
 }
+
+// Wrapper for the tooltip content
+.tooltip-inner {
+  max-width: @tooltip-max-width;
+  padding: 3px 8px;
+  color: @tooltip-color;
+  text-align: center;
+  background-color: @tooltip-bg;
+  border-radius: @border-radius-base;
+}
+
+// Arrows
+.tooltip-arrow {
+  position: absolute;
+  width: 0;
+  height: 0;
+  border-color: transparent;
+  border-style: solid;
+}
similarity index 95%
rename from css/type.less
rename to css/bootstrap/type.less
index 0d4fee4..1980e40 100644 (file)
@@ -1,3 +1,5 @@
+// stylelint-disable selector-list-comma-newline-after, selector-no-qualifying-type
+
 //
 // Typography
 // --------------------------------------------------
@@ -15,7 +17,7 @@ h1, h2, h3, h4, h5, h6,
 
   small,
   .small {
-    font-weight: normal;
+    font-weight: 400;
     line-height: 1;
     color: @headings-small-color;
   }
@@ -82,8 +84,8 @@ small,
 
 mark,
 .mark {
-  background-color: @state-warning-bg;
   padding: .2em;
+  background-color: @state-warning-bg;
 }
 
 // Alignment
@@ -180,8 +182,8 @@ ol {
 
   > li {
     display: inline-block;
-    padding-left: 5px;
     padding-right: 5px;
+    padding-left: 5px;
   }
 }
 
@@ -195,7 +197,7 @@ dd {
   line-height: @line-height-base;
 }
 dt {
-  font-weight: bold;
+  font-weight: 700;
 }
 dd {
   margin-left: 0; // Undo browser default
@@ -230,12 +232,12 @@ dd {
 // -------------------------
 
 // Abbreviations and acronyms
-abbr[title],
 // Add data-* attribute to help out our tooltip plugin, per https://github.com/twbs/bootstrap/issues/5257
+abbr[title],
 abbr[data-original-title] {
   cursor: help;
-  border-bottom: 1px dotted @abbr-border-color;
 }
+
 .initialism {
   font-size: 90%;
   .text-uppercase();
@@ -267,7 +269,7 @@ blockquote {
     color: @blockquote-small-color;
 
     &:before {
-      content: '\2014 \00A0'; // em dash, nbsp
+      content: "\2014 \00A0"; // em dash, nbsp
     }
   }
 }
@@ -279,17 +281,17 @@ blockquote {
 blockquote.pull-right {
   padding-right: 15px;
   padding-left: 0;
+  text-align: right;
   border-right: 5px solid @blockquote-border-color;
   border-left: 0;
-  text-align: right;
 
   // Account for citation
   footer,
   small,
   .small {
-    &:before { content: ''; }
+    &:before { content: ""; }
     &:after {
-      content: '\00A0 \2014'; // nbsp, em dash
+      content: "\00A0 \2014"; // nbsp, em dash
     }
   }
 }
similarity index 94%
rename from css/utilities.less
rename to css/bootstrap/utilities.less
index 7a8ca27..834f5b7 100644 (file)
@@ -1,3 +1,5 @@
+// stylelint-disable declaration-no-important
+
 //
 // Utility classes
 // --------------------------------------------------
similarity index 83%
rename from css/wells.less
rename to css/bootstrap/wells.less
index 15d072b..9f5bdaa 100644 (file)
   background-color: @well-bg;
   border: 1px solid @well-border;
   border-radius: @border-radius-base;
-  .box-shadow(inset 0 1px 1px rgba(0,0,0,.05));
+  .box-shadow(inset 0 1px 1px rgba(0, 0, 0, .05));
   blockquote {
     border-color: #ddd;
-    border-color: rgba(0,0,0,.15);
+    border-color: rgba(0, 0, 0, .15);
   }
 }
 
diff --git a/css/print.less b/css/print.less
deleted file mode 100644 (file)
index 66e54ab..0000000
+++ /dev/null
@@ -1,101 +0,0 @@
-/*! Source: https://github.com/h5bp/html5-boilerplate/blob/master/src/css/main.css */
-
-// ==========================================================================
-// Print styles.
-// Inlined to avoid the additional HTTP request: h5bp.com/r
-// ==========================================================================
-
-@media print {
-    *,
-    *:before,
-    *:after {
-        background: transparent !important;
-        color: #000 !important; // Black prints faster: h5bp.com/s
-        box-shadow: none !important;
-        text-shadow: none !important;
-    }
-
-    a,
-    a:visited {
-        text-decoration: underline;
-    }
-
-    a[href]:after {
-        content: " (" attr(href) ")";
-    }
-
-    abbr[title]:after {
-        content: " (" attr(title) ")";
-    }
-
-    // Don't show links that are fragment identifiers,
-    // or use the `javascript:` pseudo protocol
-    a[href^="#"]:after,
-    a[href^="javascript:"]:after {
-        content: "";
-    }
-
-    pre,
-    blockquote {
-        border: 1px solid #999;
-        page-break-inside: avoid;
-    }
-
-    thead {
-        display: table-header-group; // h5bp.com/t
-    }
-
-    tr,
-    img {
-        page-break-inside: avoid;
-    }
-
-    img {
-        max-width: 100% !important;
-    }
-
-    p,
-    h2,
-    h3 {
-        orphans: 3;
-        widows: 3;
-    }
-
-    h2,
-    h3 {
-        page-break-after: avoid;
-    }
-
-    // Bootstrap specific changes start
-
-    // Bootstrap components
-    .navbar {
-        display: none;
-    }
-    .btn,
-    .dropup > .btn {
-        > .caret {
-            border-top-color: #000 !important;
-        }
-    }
-    .label {
-        border: 1px solid #000;
-    }
-
-    .table {
-        border-collapse: collapse !important;
-
-        td,
-        th {
-            background-color: #fff !important;
-        }
-    }
-    .table-bordered {
-        th,
-        td {
-            border: 1px solid #ddd !important;
-        }
-    }
-
-    // Bootstrap specific changes end
-}
diff --git a/navbar.jst b/navbar.jst
new file mode 100644 (file)
index 0000000..4663255
--- /dev/null
@@ -0,0 +1,46 @@
+let XDate = require('xdate')
+
+return async (env, head, body, scripts) => {
+  let page = await _require('/page.jst')
+  let techedu_horizontal = await env.site.get_min_svg('/_svg/techedu_horizontal.svg')
+
+  await page(
+    env,
+    // head
+    async _out => {
+      title {'TechEdu: Page title'}
+
+      await head(_out)
+    },
+    // body
+    async _out => {
+      div(style="padding-left: calc(100vw - 100%);") {
+        div.container {
+          div.row {
+            div.'col-sm-3' {
+              _out.push(techedu_horizontal)
+            }
+            div.'col-sm-9' {
+              'Breadcrumbs'
+            }
+          }
+          div.row {
+            div.'col-sm-3' {
+              'Navigation'
+            }
+            div.'col-sm-9' {
+              await body(_out)
+            }
+          }
+        }
+      }
+      div.footer(style="padding-left: calc(100vw - 100%);") {
+        div.container {
+          `Copyright © ${new XDate().getUTCFullYear()} Technology Education Pty Ltd.`
+        }
+      }
+    },
+    // scripts
+    scripts
+  )
+}
diff --git a/test.html.jst b/test.html.jst
new file mode 100644 (file)
index 0000000..a9a9ec8
--- /dev/null
@@ -0,0 +1,33 @@
+return async env => {
+  let navbar = await _require('navbar.jst')
+
+  await navbar(
+    env,
+    // head
+    async _out => {},
+    // body
+    async _out => {
+      div.slidecontainer {
+        input.slider#myRange(type="range" min="1" max="100" value="50") {}
+      }
+      div {
+        'Value: '
+        span#demo {'50'}
+      }
+    }
+    // scripts
+    async _out => {
+      script {
+        // see https://www.w3schools.com/howto/howto_js_rangeslider.asp
+        var slider = document.getElementById("myRange");
+        var output = document.getElementById("demo");
+        output.innerHTML = slider.value; // Display the default slider value
+
+        // Update the current slider value (each time you drag the slider handle)
+        slider.oninput = function() {
+          output.innerHTML = this.value;
+        }
+      }
+    }
+  )
+}