diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Drivers/HeadingElementDriver.cs b/src/Orchard.Web/Modules/Orchard.Layouts/Drivers/HeadingElementDriver.cs new file mode 100644 index 000000000..e88d23aa1 --- /dev/null +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Drivers/HeadingElementDriver.cs @@ -0,0 +1,45 @@ +using System.Collections.Generic; +using System.Linq; +using Orchard.Layouts.Elements; +using Orchard.Layouts.Framework.Display; +using Orchard.Layouts.Framework.Drivers; +using Orchard.Layouts.ViewModels; +using Orchard.Services; + +namespace Orchard.Layouts.Drivers { + public class HeadingElementDriver : ElementDriver { + private readonly IEnumerable _htmlFilters; + public HeadingElementDriver(IEnumerable htmlFilters) { + _htmlFilters = htmlFilters; + } + + protected override EditorResult OnBuildEditor(Heading element, ElementEditorContext context) { + var viewModel = new HeadingEditorViewModel { + Text = element.Content, + Level = element.Level + }; + var editor = context.ShapeFactory.EditorTemplate(TemplateName: "Elements.Heading", Model: viewModel); + + if (context.Updater != null) { + context.Updater.TryUpdateModel(viewModel, context.Prefix, null, null); + element.Content = viewModel.Text; + element.Level = viewModel.Level; + } + + return Editor(context, editor); + } + + protected override void OnDisplaying(Heading element, ElementDisplayContext context) { + var text = element.Content; + var flavor = "html"; + var processedText = ApplyHtmlFilters(text, flavor); + + context.ElementShape.ProcessedText = processedText; + context.ElementShape.Level = element.Level; + } + + private string ApplyHtmlFilters(string content, string flavor) { + return _htmlFilters.Aggregate(content, (t, filter) => filter.ProcessContent(t, flavor)); + } + } +} \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Drivers/ParagraphElementDriver.cs b/src/Orchard.Web/Modules/Orchard.Layouts/Drivers/ParagraphElementDriver.cs index f892486cb..ca30d5e2b 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Drivers/ParagraphElementDriver.cs +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Drivers/ParagraphElementDriver.cs @@ -8,11 +8,6 @@ using Orchard.Services; namespace Orchard.Layouts.Drivers { public class ParagraphElementDriver : ElementDriver { - private readonly IEnumerable _htmlFilters; - public ParagraphElementDriver(IEnumerable htmlFilters) { - _htmlFilters = htmlFilters; - } - protected override EditorResult OnBuildEditor(Paragraph element, ElementEditorContext context) { var viewModel = new ParagraphEditorViewModel { Text = element.Content @@ -26,17 +21,5 @@ namespace Orchard.Layouts.Drivers { return Editor(context, editor); } - - protected override void OnDisplaying(Paragraph element, ElementDisplayingContext context) { - var text = element.Content; - var flavor = "html"; - var processedText = ApplyHtmlFilters(text, flavor); - - context.ElementShape.ProcessedText = processedText; - } - - private string ApplyHtmlFilters(string content, string flavor) { - return _htmlFilters.Aggregate(content, (t, filter) => filter.ProcessContent(t, flavor)); - } } } \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Elements/Heading.cs b/src/Orchard.Web/Modules/Orchard.Layouts/Elements/Heading.cs new file mode 100644 index 000000000..f1d47f305 --- /dev/null +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Elements/Heading.cs @@ -0,0 +1,24 @@ +using Orchard.Layouts.Helpers; +using Orchard.Localization; + +namespace Orchard.Layouts.Elements { + public class Heading : ContentElement { + + public override string Category { + get { return "Content"; } + } + + public override LocalizedString DisplayText { + get { return T("Heading h1-h6"); } + } + + public override string ToolboxIcon { + get { return "\uf1dc"; } + } + + public int Level { + get { return this.Retrieve(h => h.Level); } + set { this.Store(h => h.Level, value);} + } + } +} \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Orchard.Layouts.csproj b/src/Orchard.Web/Modules/Orchard.Layouts/Orchard.Layouts.csproj index d99bca333..b16e2d0c3 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Orchard.Layouts.csproj +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Orchard.Layouts.csproj @@ -320,13 +320,15 @@ - + + + @@ -427,6 +429,7 @@ + @@ -568,6 +571,12 @@ + + + + + + 10.0 $(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v$(VisualStudioVersion) diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor.js b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor.js index a57e633d4..4acf88d9a 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor.js +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor.js @@ -4,17 +4,29 @@ var LayoutEditor; var Clipboard = function () { var self = this; - this.clipboardData = {}; - this.setData = function(contentType, data, realClipBoard) { - self.clipboardData[contentType] = data; - }; - this.getData = function (contentType, realClipBoard) { - return self.clipboardData[contentType]; - }; + this._clipboardData = {}; + this._isDisabled = false; + this._wasInvoked = false; - this.disable = function() { - this.disabled = true; + this.setData = function(contentType, data) { + self._clipboardData[contentType] = data; + self._wasInvoked = true; }; + this.getData = function (contentType) { + return self._clipboardData[contentType]; + self._wasInvoked = true; + }; + this.disable = function() { + self._isDisabled = true; + self._wasInvoked = false; + self._clipboardData = {}; + }; + this.isDisabled = function () { + return self._isDisabled; + } + this.wasInvoked = function () { + return self._wasInvoked; + } } LayoutEditor.Clipboard = new Clipboard(); @@ -26,7 +38,9 @@ var LayoutEditor; return { setData: LayoutEditor.Clipboard.setData, getData: LayoutEditor.Clipboard.getData, - disable: LayoutEditor.Clipboard.disable + disable: LayoutEditor.Clipboard.disable, + isDisabled: LayoutEditor.Clipboard.isDisabled, + wasInvoked: LayoutEditor.Clipboard.wasInvoked }; } ]); @@ -48,12 +62,11 @@ angular var resetFocus = false; var element = $scope.element; - if (element.editor.isDragging || element.editor.inlineEditingIsActive) return; - // If the "real" clipboard works, then the pseudo-clipboard will have been disabled. - if (!clipboard.disabled) { + // If native clipboard support exists, the pseudo-clipboard will have been disabled. + if (!clipboard.isDisabled()) { var focusedElement = element.editor.focusedElement; if (!!focusedElement) { // Pseudo clipboard handling for browsers not allowing real clipboard operations. @@ -468,34 +481,46 @@ angular }; $(document).on("cut copy paste", function (e) { - // The real clipboard is supported, so disable the peudo clipboard. - clipboard.disable(); - var focusedElement = $scope.element.focusedElement; - if (!!focusedElement) { - $scope.$apply(function () { - switch (e.type) { - case "copy": - focusedElement.copy(e.originalEvent.clipboardData); - break; - case "cut": - focusedElement.cut(e.originalEvent.clipboardData); - break; - case "paste": - focusedElement.paste(e.originalEvent.clipboardData); - break; - } - }); - - // HACK: Workaround because of how Angular treats the DOM when elements are shifted around - input focus is sometimes lost. - window.setTimeout(function () { - $scope.$apply(function () { - if (!!$scope.element.focusedElement) - $scope.element.focusedElement.setIsFocused(); - }); - }, 100); - + // If the pseudo clipboard was already invoked (which happens on the first clipboard + // operation after page load even if native clipboard support exists) then sit this + // one operation out, but make sure whatever is on the pseudo clipboard gets migrated + // to the native clipboard for subsequent operations. + if (clipboard.wasInvoked()) { + e.originalEvent.clipboardData.setData("text/plain", clipboard.getData("text/plain")); + e.originalEvent.clipboardData.setData("text/json", clipboard.getData("text/json")); e.preventDefault(); } + else { + var focusedElement = $scope.element.focusedElement; + if (!!focusedElement) { + $scope.$apply(function () { + switch (e.type) { + case "copy": + focusedElement.copy(e.originalEvent.clipboardData); + break; + case "cut": + focusedElement.cut(e.originalEvent.clipboardData); + break; + case "paste": + focusedElement.paste(e.originalEvent.clipboardData); + break; + } + }); + + // HACK: Workaround because of how Angular treats the DOM when elements are shifted around - input focus is sometimes lost. + window.setTimeout(function () { + $scope.$apply(function () { + if (!!$scope.element.focusedElement) + $scope.element.focusedElement.setIsFocused(); + }); + }, 100); + + e.preventDefault(); + } + } + + // Native clipboard support obviously exists, so disable the peudo clipboard from now on. + clipboard.disable(); }); } ], @@ -1024,4 +1049,4 @@ angular }; } ]); -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["Module.js","Clipboard.js","ScopeConfigurator.js","Editor.js","Canvas.js","Child.js","Column.js","Content.js","Html.js","Grid.js","Row.js","Popup.js","Toolbox.js","ToolboxGroup.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC/BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AChUA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC/KA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACnEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACnCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC/CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACjMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"LayoutEditor.js","sourcesContent":["angular.module(\"LayoutEditor\", [\"ngSanitize\", \"ngResource\", \"ui.sortable\"]);","var LayoutEditor;\n(function(LayoutEditor) {\n\n    var Clipboard = function () {\n        var self = this;\n        this.clipboardData = {};\n        this.setData = function(contentType, data, realClipBoard) {\n            self.clipboardData[contentType] = data;\n        };\n        this.getData = function (contentType, realClipBoard) {\n            return self.clipboardData[contentType];\n        };\n\n        this.disable = function() {\n            this.disabled = true;\n        };\n    }\n\n    LayoutEditor.Clipboard = new Clipboard();\n\n    angular\n        .module(\"LayoutEditor\")\n        .factory(\"clipboard\", [\n            function() {\n                return {\n                    setData: LayoutEditor.Clipboard.setData,\n                    getData: LayoutEditor.Clipboard.getData,\n                    disable: LayoutEditor.Clipboard.disable\n                };\n            }\n        ]);\n})(LayoutEditor || (LayoutEditor = {}));","angular\n    .module(\"LayoutEditor\")\n    .factory(\"scopeConfigurator\", [\"$timeout\", \"clipboard\",\n        function ($timeout, clipboard) {\n            return {\n\n                configureForElement: function ($scope, $element) {\n                \n                    $element.find(\".layout-panel\").click(function (e) {\n                        e.stopPropagation();\n                    });\n\n                    $element.parent().keydown(function (e) {\n                        var handled = false;\n                        var resetFocus = false;\n                        var element = $scope.element;\n                    \n\n                        if (element.editor.isDragging || element.editor.inlineEditingIsActive)\n                            return;\n\n                        // If the \"real\" clipboard works, then the pseudo-clipboard will have been disabled.\n                        if (!clipboard.disabled) {\n                            var focusedElement = element.editor.focusedElement;\n                            if (!!focusedElement) {\n                                // Pseudo clipboard handling for browsers not allowing real clipboard operations.\n                                if (e.ctrlKey) {\n                                    switch (e.which) {\n                                    case 67: // C\n                                        focusedElement.copy(clipboard);\n                                        break;\n                                    case 88: // X\n                                        focusedElement.cut(clipboard);\n                                        break;\n                                    case 86: // V\n                                        focusedElement.paste(clipboard);\n                                        break;\n                                    }\n                                }\n                            }\n                        }\n\n                        if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 46) { // Del\n                            $scope.delete(element);\n                            handled = true;\n                        } else if (!e.ctrlKey && !e.shiftKey && !e.altKey && (e.which == 32 || e.which == 27)) { // Space or Esc\n                            $element.find(\".layout-panel-action-properties\").first().click();\n                            handled = true;\n                        }\n\n                        if (element.type == \"Content\") { // This is a content element.\n                            if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 13) { // Enter\n                                $element.find(\".layout-panel-action-edit\").first().click();\n                                handled = true;\n                            }\n                        }\n\n                        if (!!element.children) { // This is a container.\n                            if (!e.ctrlKey && !e.shiftKey && e.altKey && e.which == 40) { // Alt+Down\n                                if (element.children.length > 0)\n                                    element.children[0].setIsFocused();\n                                handled = true;\n                            }\n\n                            if (element.type == \"Column\") { // This is a column.\n                                var connectAdjacent = !e.ctrlKey;\n                                if (e.which == 37) { // Left\n                                    if (e.altKey)\n                                        element.expandLeft(connectAdjacent);\n                                    if (e.shiftKey)\n                                        element.contractRight(connectAdjacent);\n                                    handled = true;\n                                } else if (e.which == 39) { // Right\n                                    if (e.altKey)\n                                        element.contractLeft(connectAdjacent);\n                                    if (e.shiftKey)\n                                        element.expandRight(connectAdjacent);\n                                    handled = true;\n                                }\n                            }\n                        }\n\n                        if (!!element.parent) { // This is a child.\n                            if (e.altKey && e.which == 38) { // Alt+Up\n                                element.parent.setIsFocused();\n                                handled = true;\n                            }\n\n                            if (element.parent.type == \"Row\") { // Parent is a horizontal container.\n                                if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 37) { // Left\n                                    element.parent.moveFocusPrevChild(element);\n                                    handled = true;\n                                }\n                                else if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 39) { // Right\n                                    element.parent.moveFocusNextChild(element);\n                                    handled = true;\n                                }\n                                else if (e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 37) { // Ctrl+Left\n                                    element.moveUp();\n                                    resetFocus = true;\n                                    handled = true;\n                                }\n                                else if (e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 39) { // Ctrl+Right\n                                    element.moveDown();\n                                    handled = true;\n                                }\n                            }\n                            else { // Parent is a vertical container.\n                                if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 38) { // Up\n                                    element.parent.moveFocusPrevChild(element);\n                                    handled = true;\n                                }\n                                else if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 40) { // Down\n                                    element.parent.moveFocusNextChild(element);\n                                    handled = true;\n                                }\n                                else if (e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 38) { // Ctrl+Up\n                                    element.moveUp();\n                                    resetFocus = true;\n                                    handled = true;\n                                }\n                                else if (e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 40) { // Ctrl+Down\n                                    element.moveDown();\n                                    handled = true;\n                                }\n                            }\n                        }\n\n                        if (handled) {\n                            e.preventDefault();\n                        }\n\n                        e.stopPropagation();\n\n                        $scope.$apply(); // Event is not triggered by Angular directive but raw event handler on element.\n\n                        // HACK: Workaround because of how Angular treats the DOM when elements are shifted around - input focus is sometimes lost.\n                        if (resetFocus) {\n                            window.setTimeout(function () {\n                                $scope.$apply(function () {\n                                    element.editor.focusedElement.setIsFocused();\n                                });\n                            }, 100);\n                        }\n                    });\n\n                    $scope.element.setIsFocusedEventHandlers.push(function () {\n                        $element.parent().focus();\n                    });\n\n                    $scope.delete = function (element) {\n                        element.delete();\n                    }\n                },\n\n                configureForContainer: function ($scope, $element) {\n                    var element = $scope.element;\n\n                    //$scope.isReceiving = false; // True when container is receiving an external element via drag/drop.\n                    $scope.getShowChildrenPlaceholder = function () {\n                        return $scope.element.children.length === 0 && !$scope.element.getIsDropTarget();\n                    };\n\n                    $scope.sortableOptions = {\n                        cursor: \"move\",\n                        delay: 150,\n                        disabled: element.getIsSealed(),\n                        distance: 5,\n                        //handle: element.children.length < 2 ? \".imaginary-class\" : false, // For some reason doesn't get re-evaluated after adding more children.\n                        start: function (e, ui) {\n                            $scope.$apply(function () {\n                                element.setIsDropTarget(true);\n                                element.editor.isDragging = true;\n                            });\n                            // Make the drop target placeholder as high as the item being dragged.\n                            ui.placeholder.height(ui.item.height() - 4);\n                            ui.placeholder.css(\"min-height\", 0);\n                        },\n                        stop: function (e, ui) {\n                            $scope.$apply(function () {\n                                element.editor.isDragging = false;\n                                element.setIsDropTarget(false);\n                            });\n                        },\n                        over: function (e, ui) {\n                            if (!!ui.sender && !!ui.sender[0].isToolbox) {\n                                if (!!ui.sender[0].dropTargetTimeout) {\n                                    $timeout.cancel(ui.sender[0].dropTargetTimeout);\n                                    ui.sender[0].dropTargetTimeout = null;\n                                }\n                                $timeout(function () {\n                                    if (element.type == \"Row\") {\n                                        // If there was a previous drop target and it was a row, roll back any pending column adds to it.\n                                        var previousDropTarget = element.editor.dropTargetElement;\n                                        if (!!previousDropTarget && previousDropTarget.type == \"Row\")\n                                            previousDropTarget.rollbackAddColumn();\n                                    }\n                                    element.setIsDropTarget(false);\n                                });\n                                ui.sender[0].dropTargetTimeout = $timeout(function () {\n                                    if (element.type == \"Row\") {\n                                        var receivedColumn = ui.item.sortable.model;\n                                        var receivedColumnWidth = Math.floor(12 / (element.children.length + 1));\n                                        receivedColumn.width = receivedColumnWidth;\n                                        receivedColumn.offset = 0;\n                                        element.beginAddColumn(receivedColumnWidth);\n                                        // Make the drop target placeholder the correct width and as high as the highest existing column in the row.\n                                        var maxHeight = _.max(_($element.find(\"> .layout-children > .layout-column:not(.ui-sortable-placeholder)\")).map(function (e) {\n                                            return $(e).height();\n                                        }));\n                                        for (i = 1; i <= 12; i++)\n                                            ui.placeholder.removeClass(\"col-xs-\" + i);\n                                        ui.placeholder.addClass(\"col-xs-\" + receivedColumn.width);\n                                        if (maxHeight > 0) {\n                                            ui.placeholder.height(maxHeight);\n                                            ui.placeholder.css(\"min-height\", 0);\n                                        }\n                                        else {\n                                            ui.placeholder.height(0);\n                                            ui.placeholder.css(\"min-height\", \"\");\n                                        }\n                                    }\n                                    element.setIsDropTarget(true);\n                                }, 150);\n                            }\n                        },\n                        receive: function (e, ui) {\n                            if (!!ui.sender && !!ui.sender[0].isToolbox) {\n                                $scope.$apply(function () {\n                                    var receivedElement = ui.item.sortable.model;\n                                    if (!!receivedElement) {\n                                        if (element.type == \"Row\")\n                                            element.commitAddColumn();\n                                        // Should ideally call LayoutEditor.Container.addChild() instead, but since this handler\n                                        // is run *before* the ui-sortable directive's handler, if we try to add the child to the\n                                        // array that handler will get an exception when trying to do the same.\n                                        // Because of this, we need to invoke \"setParent\" so that specific container types can perform element speficic initialization.\n                                        receivedElement.setEditor(element.editor);\n                                        receivedElement.setParent(element);\n                                        if (!!receivedElement.hasEditor) {\n                                            $scope.$root.editElement(receivedElement).then(function (args) {\n                                                if (!args.cancel) {\n                                                    receivedElement.data = args.element.data;\n\n                                                    if (receivedElement.setHtml)\n                                                        receivedElement.setHtml(args.element.html);\n                                                }\n                                                $timeout(function () {\n                                                    if (!!args.cancel)\n                                                        receivedElement.delete();\n                                                    else\n                                                        receivedElement.setIsFocused();\n                                                    //$scope.isReceiving = false;\n                                                    element.setIsDropTarget(false);\n\n                                                });\n                                                return;\n                                            });\n                                        }\n                                    }\n                                    $timeout(function () {\n                                        //$scope.isReceiving = false;\n                                        element.setIsDropTarget(false);\n                                        if (!!receivedElement)\n                                            receivedElement.setIsFocused();\n                                    });\n                                });\n                            }\n                        }\n                    };\n\n                    $scope.click = function (child, e) {\n                        if (!child.editor.isDragging)\n                            child.setIsFocused();\n                        e.stopPropagation();\n                    };\n\n                    $scope.getClasses = function (child) {\n                        var result = [\"layout-element\"];\n\n                        if (!!child.children) {\n                            result.push(\"layout-container\");\n                            if (child.getIsSealed())\n                                result.push(\"layout-container-sealed\");\n                        }\n\n                        result.push(\"layout-\" + child.type.toLowerCase());\n\n                        if (!!child.dropTargetClass)\n                            result.push(child.dropTargetClass);\n\n                        // TODO: Move these to either the Column directive or the Column model class.\n                        if (child.type == \"Row\") {\n                            result.push(\"row\");\n                            if (!child.canAddColumn())\n                                result.push(\"layout-row-full\");\n                        }\n                        if (child.type == \"Column\") {\n                            result.push(\"col-xs-\" + child.width);\n                            result.push(\"col-xs-offset-\" + child.offset);\n                        }\n                        if (child.type == \"Content\")\n                            result.push(\"layout-content-\" + child.contentTypeClass);\n\n                        if (child.getIsActive())\n                            result.push(\"layout-element-active\");\n                        if (child.getIsFocused())\n                            result.push(\"layout-element-focused\");\n                        if (child.getIsSelected())\n                            result.push(\"layout-element-selected\");\n                        if (child.getIsDropTarget())\n                            result.push(\"layout-element-droptarget\");\n                        if (child.isTemplated)\n                            result.push(\"layout-element-templated\");\n\n                        return result;\n                    };\n                }\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutEditor\", [\"environment\",\n        function (environment) {\n            return {\n                restrict: \"E\",\n                scope: {},\n                controller: [\"$scope\", \"$element\", \"$attrs\", \"$compile\", \"clipboard\",\n                    function ($scope, $element, $attrs, $compile, clipboard) {\n                        if (!!$attrs.model)\n                            $scope.element = eval($attrs.model);\n                        else\n                            throw new Error(\"The 'model' attribute must evaluate to a LayoutEditor.Editor object.\");\n\n                        $scope.click = function (canvas, e) {\n                            if (!canvas.editor.isDragging)\n                                canvas.setIsFocused();\n                            e.stopPropagation();\n                        };\n\n                        $scope.getClasses = function (canvas) {\n                            var result = [\"layout-element\", \"layout-container\", \"layout-canvas\"];\n\n                            if (canvas.getIsActive())\n                                result.push(\"layout-element-active\");\n                            if (canvas.getIsFocused())\n                                result.push(\"layout-element-focused\");\n                            if (canvas.getIsSelected())\n                                result.push(\"layout-element-selected\");\n                            if (canvas.getIsDropTarget())\n                                result.push(\"layout-element-droptarget\");\n                            if (canvas.isTemplated)\n                                result.push(\"layout-element-templated\");\n\n                            return result;\n                        };\n\n                        // An unfortunate side-effect of the next hack on line 54 is that the created elements aren't added to the DOM yet, so we can't use it to get to the parent \".layout-desiger\" element.\n                        // Work around: access that element directly (which efectively turns multiple layout editors on a single page impossible). \n                        // //var layoutDesignerHost = $element.closest(\".layout-designer\").data(\"layout-designer-host\");\n                        var layoutDesignerHost = $(\".layout-designer\").data(\"layout-designer-host\");\n\n                        $scope.$root.layoutDesignerHost = layoutDesignerHost;\n\n                        layoutDesignerHost.element.on(\"replacecanvas\", function (e, args) {\n                            var editor = $scope.element;\n                            var canvasData = {\n                                data: args.canvas.data,\n                                htmlId: args.canvas.htmlId,\n                                htmlClass: args.canvas.htmlClass,\n                                htmlStyle: args.canvas.htmlStyle,\n                                isTemplated: args.canvas.isTemplated,\n                                children: args.canvas.children\n                            };\n\n                            // HACK: Instead of simply updating the $scope.element with a new instance, we need to replace the entire orc-layout-editor markup\n                            // in order for angular to rebind starting with the Canvas element. Otherwise, for some reason, it will rebind starting with the first child of Canvas.\n                            // You can see this happening when setting a breakpoint in ScopeConfigurator where containers are initialized with drag & drop: on page load, the first element\n                            // is a Canvas (good), but after having selected another template, the first element is (typically) a Grid (bad).\n                            // Simply recompiling the orc-layout-editor directive will cause the entire thing to be generated, which works just fine as well (even though not is nice as simply leveraging model binding).\n                            layoutDesignerHost.editor = window.layoutEditor = new LayoutEditor.Editor(editor.config, canvasData);\n                            var template = \"<orc-layout-editor\" + \" model='window.layoutEditor' />\";\n                            var html = $compile(template)($scope);\n                            $(\".layout-editor-holder\").html(html);\n                        });\n\n                        $scope.$root.editElement = function (element) {\n                            var host = $scope.$root.layoutDesignerHost;\n                            return host.editElement(element);\n                        };\n\n                        $scope.$root.addElement = function (contentType) {\n                            var host = $scope.$root.layoutDesignerHost;\n                            return host.addElement(contentType);\n                        };\n\n                        $scope.toggleInlineEditing = function () {\n                            if (!$scope.element.inlineEditingIsActive) {\n                                $scope.element.inlineEditingIsActive = true;\n                                $element.find(\".layout-toolbar-container\").show();\n                                var selector = \"#layout-editor-\" + $scope.$id + \" .layout-html .layout-content-markup[data-templated=false]\";\n                                var firstContentEditorId = $(selector).first().attr(\"id\");\n                                tinymce.init({\n                                    selector: selector,\n                                    theme: \"modern\",\n                                    schema: \"html5\",\n                                    plugins: [\n                                        \"advlist autolink lists link image charmap print preview hr anchor pagebreak\",\n                                        \"searchreplace wordcount visualblocks visualchars code fullscreen\",\n                                        \"insertdatetime media nonbreaking table contextmenu directionality\",\n                                        \"emoticons template paste textcolor colorpicker textpattern\",\n                                        \"fullscreen autoresize\"\n                                    ],\n                                    toolbar: \"undo redo cut copy paste | bold italic | bullist numlist outdent indent formatselect | alignleft aligncenter alignright alignjustify ltr rtl | link unlink charmap | code fullscreen close\",\n                                    convert_urls: false,\n                                    valid_elements: \"*[*]\",\n                                    // Shouldn't be needed due to the valid_elements setting, but TinyMCE would strip script.src without it.\n                                    extended_valid_elements: \"script[type|defer|src|language]\",\n                                    statusbar: false,\n                                    skin: \"orchardlightgray\",\n                                    inline: true,\n                                    fixed_toolbar_container: \"#layout-editor-\" + $scope.$id + \" .layout-toolbar-container\",\n                                    init_instance_callback: function (editor) {\n                                        if (editor.id == firstContentEditorId)\n                                            tinymce.execCommand(\"mceFocus\", false, editor.id);\n                                    }\n                                });\n                            }\n                            else {\n                                tinymce.remove(\"#layout-editor-\" + $scope.$id + \" .layout-content-markup\");\n                                $element.find(\".layout-toolbar-container\").hide();\n                                $scope.element.inlineEditingIsActive = false;\n                            }\n                        };\n\n                        $(document).on(\"cut copy paste\", function (e) {\n                            // The real clipboard is supported, so disable the peudo clipboard.\n                            clipboard.disable();\n                            var focusedElement = $scope.element.focusedElement;\n                            if (!!focusedElement) {\n                                $scope.$apply(function () {\n                                    switch (e.type) {\n                                        case \"copy\":\n                                            focusedElement.copy(e.originalEvent.clipboardData);\n                                            break;\n                                        case \"cut\":\n                                            focusedElement.cut(e.originalEvent.clipboardData);\n                                            break;\n                                        case \"paste\":\n                                            focusedElement.paste(e.originalEvent.clipboardData);\n                                            break;\n                                    }\n                                });\n\n                                // HACK: Workaround because of how Angular treats the DOM when elements are shifted around - input focus is sometimes lost.\n                                window.setTimeout(function () {\n                                    $scope.$apply(function () {\n                                        if (!!$scope.element.focusedElement)\n                                            $scope.element.focusedElement.setIsFocused();\n                                    });\n                                }, 100);\n\n                                e.preventDefault();\n                            }\n                        });\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"Editor\"),\n                replace: true,\n                link: function (scope, element) {\n                    // No clicks should propagate from the TinyMCE toolbars.\n                    element.find(\".layout-toolbar-container\").click(function (e) {\n                        e.stopPropagation();\n                    });\n                    // Intercept mousedown on editor while in inline editing mode to \n                    // prevent current editor from losing focus.\n                    element.mousedown(function (e) {\n                        if (scope.element.inlineEditingIsActive) {\n                            e.preventDefault();\n                            e.stopPropagation();\n                        }\n                    })\n                    // Unfocus and unselect everything on click outside of canvas.\n                    $(window).click(function (e) {\n                        // Except when in inline editing mode.\n                        if (!scope.element.inlineEditingIsActive) {\n                            scope.$apply(function () {\n                                scope.element.activeElement = null;\n                                scope.element.focusedElement = null;\n                            });\n                        }\n                    });\n                }\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutCanvas\", [\"scopeConfigurator\", \"environment\",\n        function (scopeConfigurator, environment) {\n            return {\n                restrict: \"E\",\n                scope: { element: \"=\" },\n                controller: [\"$scope\", \"$element\", \"$attrs\",\n                    function ($scope, $element, $attrs) {\n                        scopeConfigurator.configureForElement($scope, $element);\n                        scopeConfigurator.configureForContainer($scope, $element);\n                        $scope.sortableOptions[\"axis\"] = \"y\";\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"Canvas\"),\n                replace: true\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutChild\", [\"$compile\",\n        function ($compile) {\n            return {\n                restrict: \"E\",\n                scope: { element: \"=\" },\n                link: function (scope, element) {\n                    var template = \"<orc-layout-\" + scope.element.type.toLowerCase() + \" element='element' />\";\n                    var html = $compile(template)(scope);\n                    $(element).replaceWith(html);\n                }\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutColumn\", [\"$compile\", \"scopeConfigurator\", \"environment\",\n        function ($compile, scopeConfigurator, environment) {\n            return {\n                restrict: \"E\",\n                scope: { element: \"=\" },\n                controller: [\"$scope\", \"$element\",\n                    function ($scope, $element) {\n                        scopeConfigurator.configureForElement($scope, $element);\n                        scopeConfigurator.configureForContainer($scope, $element);\n                        $scope.sortableOptions[\"axis\"] = \"y\";\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"Column\"),\n                replace: true,\n                link: function (scope, element, attrs) {\n                    element.find(\".layout-column-resize-bar\").draggable({\n                        axis: \"x\",\n                        helper: \"clone\",\n                        revert: true,\n                        start: function (e, ui) {\n                            scope.$apply(function () {\n                                scope.element.editor.isResizing = true;\n                            });\n                        },\n                        drag: function (e, ui) {\n                            var columnElement = element.parent();\n                            var columnSize = columnElement.width() / scope.element.width;\n                            var connectAdjacent = !e.ctrlKey;\n                            if ($(e.target).hasClass(\"layout-column-resize-bar-left\")) {\n                                var delta = ui.offset.left - columnElement.offset().left;\n                                if (delta < -columnSize && scope.element.canExpandLeft(connectAdjacent)) {\n                                    scope.$apply(function () {\n                                        scope.element.expandLeft(connectAdjacent);\n                                    });\n                                }\n                                else if (delta > columnSize && scope.element.canContractLeft(connectAdjacent)) {\n                                    scope.$apply(function () {\n                                        scope.element.contractLeft(connectAdjacent);\n                                    });\n                                }\n                            }\n                            else if ($(e.target).hasClass(\"layout-column-resize-bar-right\")) {\n                                var delta = ui.offset.left - columnElement.width() - columnElement.offset().left;\n                                if (delta > columnSize && scope.element.canExpandRight(connectAdjacent)) {\n                                    scope.$apply(function () {\n                                        scope.element.expandRight(connectAdjacent);\n                                    });\n                                }\n                                else if (delta < -columnSize && scope.element.canContractRight(connectAdjacent)) {\n                                    scope.$apply(function () {\n                                        scope.element.contractRight(connectAdjacent);\n                                    });\n                                }\n                            }\n\n                        },\n                        stop: function (e, ui) {\n                            scope.$apply(function () {\n                              scope.element.editor.isResizing = false;\n                            });\n                        }\n                    });\n                }\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutContent\", [\"$sce\", \"scopeConfigurator\", \"environment\",\n        function ($sce, scopeConfigurator, environment) {\n            return {\n                restrict: \"E\",\n                scope: { element: \"=\" },\n                controller: [\"$scope\", \"$element\",\n                    function ($scope, $element) {\n                        scopeConfigurator.configureForElement($scope, $element);\n                        $scope.edit = function () {\n                            $scope.$root.editElement($scope.element).then(function (args) {\n                                $scope.$apply(function () {\n                                    if (args.cancel)\n                                        return;\n\n                                    $scope.element.data = args.element.data;\n                                    $scope.element.setHtml(args.element.html);\n                                });\n                            });\n                        };\n\n                        // Overwrite the setHtml function so that we can use the $sce service to trust the html (and not have the html binding strip certain tags).\n                        $scope.element.setHtml = function (html) {\n                            $scope.element.html = html;\n                            $scope.element.htmlUnsafe = $sce.trustAsHtml(html);\n                        };\n\n                        $scope.element.setHtml($scope.element.html);\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"Content\"),\n                replace: true\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutHtml\", [\"$sce\", \"scopeConfigurator\", \"environment\",\n        function ($sce, scopeConfigurator, environment) {\n            return {\n                restrict: \"E\",\n                scope: { element: \"=\" },\n                controller: [\"$scope\", \"$element\",\n                    function ($scope, $element) {\n                        scopeConfigurator.configureForElement($scope, $element);\n                        $scope.edit = function () {\n                            $scope.$root.editElement($scope.element).then(function (args) {\n                                $scope.$apply(function () {\n                                    if (args.cancel)\n                                        return;\n\n                                    $scope.element.data = args.element.data;\n                                    $scope.element.setHtml(args.element.html);\n                                });\n                            });\n                        };\n                        $scope.updateContent = function (e) {\n                            $scope.element.setHtml(e.target.innerHTML);\n                        };\n\n                        // Overwrite the setHtml function so that we can use the $sce service to trust the html (and not have the html binding strip certain tags).\n                        $scope.element.setHtml = function (html) {\n                            $scope.element.html = html;\n                            $scope.element.htmlUnsafe = $sce.trustAsHtml(html);\n                        };\n\n                        $scope.element.setHtml($scope.element.html);\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"Html\"),\n                replace: true,\n                link: function (scope, element) {\n                    // Mouse down events must not be intercepted by drag and drop while inline editing is active,\n                    // otherwise clicks in inline editors will have no effect.\n                    element.find(\".layout-content-markup\").mousedown(function (e) {\n                        if (scope.element.editor.inlineEditingIsActive) {\n                            e.stopPropagation();\n                        }\n                    });\n                }\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutGrid\", [\"$compile\", \"scopeConfigurator\", \"environment\",\n        function ($compile, scopeConfigurator, environment) {\n            return {\n                restrict: \"E\",\n                scope: { element: \"=\" },\n                controller: [\"$scope\", \"$element\",\n                    function ($scope, $element) {\n                        scopeConfigurator.configureForElement($scope, $element);\n                        scopeConfigurator.configureForContainer($scope, $element);\n                        $scope.sortableOptions[\"axis\"] = \"y\";\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"Grid\"),\n                replace: true\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutRow\", [\"$compile\", \"scopeConfigurator\", \"environment\",\n        function ($compile, scopeConfigurator, environment) {\n            return {\n                restrict: \"E\",\n                scope: { element: \"=\" },\n                controller: [\"$scope\", \"$element\",\n                    function ($scope, $element) {\n                        scopeConfigurator.configureForElement($scope, $element);\n                        scopeConfigurator.configureForContainer($scope, $element);\n                        $scope.sortableOptions[\"axis\"] = \"x\";\n                        $scope.sortableOptions[\"ui-floating\"] = true;\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"Row\"),\n                replace: true\n            };\n        }\n    ]);","angular\r\n    .module(\"LayoutEditor\")\r\n    .directive(\"orcLayoutPopup\", [\r\n        function () {\r\n            return {\r\n                restrict: \"A\",\r\n                link: function (scope, element, attrs) {\r\n                    var popup = $(element);\r\n                    var trigger = popup.closest(\".layout-popup-trigger\");\r\n                    var parentElement = popup.closest(\".layout-element\");\r\n                    trigger.click(function () {\r\n                        popup.toggle();\r\n                        if (popup.is(\":visible\")) {\r\n                            popup.position({\r\n                                my: attrs.orcLayoutPopupMy || \"left top\",\r\n                                at: attrs.orcLayoutPopupAt || \"left bottom+4px\",\r\n                                of: trigger\r\n                            });\r\n                            popup.find(\"input\").first().focus();\r\n                        }\r\n                    });\r\n                    popup.click(function (e) {\r\n                        e.stopPropagation();\r\n                    });\r\n                    parentElement.click(function (e) {\r\n                        popup.hide();\r\n                    });\r\n                    popup.keydown(function (e) {\r\n                        if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 27) // Esc\r\n                            popup.hide();\r\n                        e.stopPropagation();\r\n                    });\r\n                    popup.on(\"cut copy paste\", function (e) {\n                        // Allow clipboard operations in popup without invoking clipboard event handlers on parent element.\n                        e.stopPropagation();\r\n                    });\r\n                }\r\n            };\r\n        }\r\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutToolbox\", [\"$compile\", \"environment\",\n        function ($compile, environment) {\n            return {\n                restrict: \"E\",\n                controller: [\"$scope\", \"$element\",\n                    function ($scope, $element) {\n\n                        $scope.resetElements = function () {\n\n                            $scope.gridElements = [\n                                LayoutEditor.Grid.from({\n                                    toolboxIcon: \"\\uf00a\",\n                                    toolboxLabel: \"Grid\",\n                                    toolboxDescription: \"Empty grid.\",\n                                    children: []\n                                })\n                            ];\n\n                            $scope.rowElements = [\n                                LayoutEditor.Row.from({\n                                    toolboxIcon: \"\\uf0c9\",\n                                    toolboxLabel: \"Row (1 column)\",\n                                    toolboxDescription: \"Row with 1 column.\",\n                                    children: LayoutEditor.Column.times(1)\n                                }),\n                                LayoutEditor.Row.from({\n                                    toolboxIcon: \"\\uf0c9\",\n                                    toolboxLabel: \"Row (2 columns)\",\n                                    toolboxDescription: \"Row with 2 columns.\",\n                                    children: LayoutEditor.Column.times(2)\n                                }),\n                                LayoutEditor.Row.from({\n                                    toolboxIcon: \"\\uf0c9\",\n                                    toolboxLabel: \"Row (3 columns)\",\n                                    toolboxDescription: \"Row with 3 columns.\",\n                                    children: LayoutEditor.Column.times(3)\n                                }),\n                                LayoutEditor.Row.from({\n                                    toolboxIcon: \"\\uf0c9\",\n                                    toolboxLabel: \"Row (4 columns)\",\n                                    toolboxDescription: \"Row with 4 columns.\",\n                                    children: LayoutEditor.Column.times(4)\n                                }),\n                                LayoutEditor.Row.from({\n                                    toolboxIcon: \"\\uf0c9\",\n                                    toolboxLabel: \"Row (6 columns)\",\n                                    toolboxDescription: \"Row with 6 columns.\",\n                                    children: LayoutEditor.Column.times(6)\n                                }),\n                                LayoutEditor.Row.from({\n                                    toolboxIcon: \"\\uf0c9\",\n                                    toolboxLabel: \"Row (12 columns)\",\n                                    toolboxDescription: \"Row with 12 columns.\",\n                                    children: LayoutEditor.Column.times(12)\n                                }), LayoutEditor.Row.from({\n                                    toolboxIcon: \"\\uf0c9\",\n                                    toolboxLabel: \"Row (empty)\",\n                                    toolboxDescription: \"Empty row.\",\n                                    children: []\n                                })\n                            ];\n\n                            $scope.columnElements = [\n                                LayoutEditor.Column.from({\n                                    toolboxIcon: \"\\uf0db\",\n                                    toolboxLabel: \"Column\",\n                                    toolboxDescription: \"Empty column.\",\n                                    width: 1,\n                                    offset: 0,\n                                    children: []\n                                })\n                            ];\n\n                            $scope.contentElementCategories = _($scope.element.config.categories).map(function (category) {\n                                return {\n                                    name: category.name,\n                                    elements: _(category.contentTypes).map(function (contentType) {\n                                        var type = contentType.type;\n                                        var factory = LayoutEditor.factories[type] || LayoutEditor.factories[\"Content\"];\n                                        var item = {\n                                            isTemplated: false,\n                                            contentType: contentType.id,\n                                            contentTypeLabel: contentType.label,\n                                            contentTypeClass: contentType.typeClass,\n                                            data: null,\n                                            hasEditor: contentType.hasEditor,\n                                            html: contentType.html\n                                        };\n                                        var element = factory(item);\n                                        element.toolboxIcon = contentType.icon || \"\\uf1c9\";\n                                        element.toolboxLabel = contentType.label;\n                                        element.toolboxDescription = contentType.description;\n                                        return element;\n                                    })\n                                };\n                            });\n\n                        };\n\n                        $scope.resetElements();\n\n                        $scope.getSortableOptions = function (type) {\n                            var editorId = $element.closest(\".layout-editor\").attr(\"id\");\n                            var parentClasses;\n                            var placeholderClasses;\n                            var floating = false;\n\n                            switch (type) {\n                                case \"Grid\":\n                                    parentClasses = [\".layout-canvas\", \".layout-column\", \".layout-common-holder\"];\n                                    placeholderClasses = \"layout-element layout-container layout-grid ui-sortable-placeholder\";\n                                    break;\n                                case \"Row\":\n                                    parentClasses = [\".layout-grid\"];\n                                    placeholderClasses = \"layout-element layout-container layout-row row ui-sortable-placeholder\";\n                                    break;\n                                case \"Column\":\n                                    parentClasses = [\".layout-row:not(.layout-row-full)\"];\n                                    placeholderClasses = \"layout-element layout-container layout-column ui-sortable-placeholder\";\n                                    floating = true; // To ensure a smooth horizontal-list reordering. https://github.com/angular-ui/ui-sortable#floating\n                                    break;\n                                case \"Content\":\n                                    parentClasses = [\".layout-canvas\", \".layout-column\", \".layout-common-holder\"];\n                                    placeholderClasses = \"layout-element layout-content ui-sortable-placeholder\";\n                                    break;\n                            }\n\n                            return {\n                                cursor: \"move\",\n                                connectWith: _(parentClasses).map(function (e) { return \"#\" + editorId + \" \" + e + \":not(.layout-container-sealed) > .layout-element-wrapper > .layout-children\"; }).join(\", \"),\n                                placeholder: placeholderClasses,\n                                \"ui-floating\": floating,\n                                create: function (e, ui) {\n                                    e.target.isToolbox = true; // Will indicate to connected sortables that dropped items were sent from toolbox.\n                                },\n                                start: function (e, ui) {\n                                    $scope.$apply(function () {\n                                        $scope.element.isDragging = true;\n                                    });\n                                },\n                                stop: function (e, ui) {\n                                    $scope.$apply(function () {\n                                        $scope.element.isDragging = false;\n                                        $scope.resetElements();\n                                    });\n                                },\n                                over: function (e, ui) {\n                                    $scope.$apply(function () {\n                                        $scope.element.canvas.setIsDropTarget(false);\n                                    });\n                                },\n                            }\n                        };\n\n                        var layoutIsCollapsedCookieName = \"layoutToolboxCategory_Layout_IsCollapsed\";\n                        $scope.layoutIsCollapsed = $.cookie(layoutIsCollapsedCookieName) === \"true\";\n\n                        $scope.toggleLayoutIsCollapsed = function (e) {\n                            $scope.layoutIsCollapsed = !$scope.layoutIsCollapsed;\n                            $.cookie(layoutIsCollapsedCookieName, $scope.layoutIsCollapsed, { expires: 365 }); // Remember collapsed state for a year.\n                            e.preventDefault();\n                            e.stopPropagation();\n                        };\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"Toolbox\"),\n                replace: true,\n                link: function (scope, element) {\n                    var toolbox = element.find(\".layout-toolbox\");\n                    $(window).on(\"resize scroll\", function (e) {\r\n                        var canvas = element.parent().find(\".layout-canvas\");\r\n                        // If the canvas is taller than the toolbox, make the toolbox sticky-positioned within the editor\r\n                        // to help the user avoid excessive vertical scrolling.\r\n                        var canvasIsTaller = !!canvas && canvas.height() > toolbox.height();\r\n                        var windowPos = $(window).scrollTop();\r\n                        if (canvasIsTaller && windowPos > element.offset().top + element.height() - toolbox.height()) {\r\n                            toolbox.addClass(\"sticky-bottom\");\r\n                            toolbox.removeClass(\"sticky-top\");\r\n                        }\r\n                        else if (canvasIsTaller && windowPos > element.offset().top) {\r\n                            toolbox.addClass(\"sticky-top\");\r\n                            toolbox.removeClass(\"sticky-bottom\");\r\n                        }\r\n                        else {\r\n                            toolbox.removeClass(\"sticky-top\");\r\n                            toolbox.removeClass(\"sticky-bottom\");\r\n                        }\r\n                    });\r\n                }\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutToolboxGroup\", [\"$compile\", \"environment\",\n        function ($compile, environment) {\n            return {\n                restrict: \"E\",\n                scope: { category: \"=\" },\n                controller: [\"$scope\", \"$element\",\n                    function ($scope, $element) {\n                        var isCollapsedCookieName = \"layoutToolboxCategory_\" + $scope.category.name + \"_IsCollapsed\";\n                        $scope.isCollapsed = $.cookie(isCollapsedCookieName) === \"true\";\n                        $scope.toggleIsCollapsed = function (e) {\n                            $scope.isCollapsed = !$scope.isCollapsed;\n                            $.cookie(isCollapsedCookieName, $scope.isCollapsed, { expires: 365 }); // Remember collapsed state for a year.\n                            e.preventDefault();\n                            e.stopPropagation();\n                        };\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"ToolboxGroup\"),\n                replace: true\n            };\n        }\n    ]);"],"sourceRoot":"/source/"} +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["Module.js","Clipboard.js","ScopeConfigurator.js","Editor.js","Canvas.js","Child.js","Column.js","Content.js","Html.js","Grid.js","Row.js","Popup.js","Toolbox.js","ToolboxGroup.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC/TA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC3LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACnEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACnCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC/CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC9MA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"LayoutEditor.js","sourcesContent":["angular.module(\"LayoutEditor\", [\"ngSanitize\", \"ngResource\", \"ui.sortable\"]);","var LayoutEditor;\r\n(function(LayoutEditor) {\r\n\r\n    var Clipboard = function () {\r\n        var self = this;\r\n        this._clipboardData = {};\r\n        this._isDisabled = false;\r\n        this._wasInvoked = false;\r\n\r\n        this.setData = function(contentType, data) {\r\n            self._clipboardData[contentType] = data;\r\n            self._wasInvoked = true;\r\n        };\r\n        this.getData = function (contentType) {\r\n            return self._clipboardData[contentType];\r\n            self._wasInvoked = true;\r\n        };\r\n        this.disable = function() {\r\n            self._isDisabled = true;\r\n            self._wasInvoked = false;\r\n            self._clipboardData = {};\r\n        };\r\n        this.isDisabled = function () {\r\n            return self._isDisabled;\r\n        }\r\n        this.wasInvoked = function () {\r\n            return self._wasInvoked;\r\n        }\r\n    }\r\n\r\n    LayoutEditor.Clipboard = new Clipboard();\r\n\r\n    angular\r\n        .module(\"LayoutEditor\")\r\n        .factory(\"clipboard\", [\r\n            function() {\r\n                return {\r\n                    setData: LayoutEditor.Clipboard.setData,\r\n                    getData: LayoutEditor.Clipboard.getData,\r\n                    disable: LayoutEditor.Clipboard.disable,\r\n                    isDisabled: LayoutEditor.Clipboard.isDisabled,\r\n                    wasInvoked: LayoutEditor.Clipboard.wasInvoked\r\n                };\r\n            }\r\n        ]);\r\n})(LayoutEditor || (LayoutEditor = {}));","angular\r\n    .module(\"LayoutEditor\")\r\n    .factory(\"scopeConfigurator\", [\"$timeout\", \"clipboard\",\r\n        function ($timeout, clipboard) {\r\n            return {\r\n\r\n                configureForElement: function ($scope, $element) {\r\n                \r\n                    $element.find(\".layout-panel\").click(function (e) {\r\n                        e.stopPropagation();\r\n                    });\r\n\r\n                    $element.parent().keydown(function (e) {\r\n                        var handled = false;\r\n                        var resetFocus = false;\r\n                        var element = $scope.element;\r\n                    \r\n                        if (element.editor.isDragging || element.editor.inlineEditingIsActive)\r\n                            return;\r\n\r\n                        // If native clipboard support exists, the pseudo-clipboard will have been disabled.\r\n                        if (!clipboard.isDisabled()) {\r\n                            var focusedElement = element.editor.focusedElement;\r\n                            if (!!focusedElement) {\r\n                                // Pseudo clipboard handling for browsers not allowing real clipboard operations.\r\n                                if (e.ctrlKey) {\r\n                                    switch (e.which) {\r\n                                    case 67: // C\r\n                                        focusedElement.copy(clipboard);\r\n                                        break;\r\n                                    case 88: // X\r\n                                        focusedElement.cut(clipboard);\r\n                                        break;\r\n                                    case 86: // V\r\n                                        focusedElement.paste(clipboard);\r\n                                        break;\r\n                                    }\r\n                                }\r\n                            }\r\n                        }\r\n\r\n                        if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 46) { // Del\r\n                            $scope.delete(element);\r\n                            handled = true;\r\n                        } else if (!e.ctrlKey && !e.shiftKey && !e.altKey && (e.which == 32 || e.which == 27)) { // Space or Esc\r\n                            $element.find(\".layout-panel-action-properties\").first().click();\r\n                            handled = true;\r\n                        }\r\n\r\n                        if (element.type == \"Content\") { // This is a content element.\r\n                            if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 13) { // Enter\r\n                                $element.find(\".layout-panel-action-edit\").first().click();\r\n                                handled = true;\r\n                            }\r\n                        }\r\n\r\n                        if (!!element.children) { // This is a container.\r\n                            if (!e.ctrlKey && !e.shiftKey && e.altKey && e.which == 40) { // Alt+Down\r\n                                if (element.children.length > 0)\r\n                                    element.children[0].setIsFocused();\r\n                                handled = true;\r\n                            }\r\n\r\n                            if (element.type == \"Column\") { // This is a column.\r\n                                var connectAdjacent = !e.ctrlKey;\r\n                                if (e.which == 37) { // Left\r\n                                    if (e.altKey)\r\n                                        element.expandLeft(connectAdjacent);\r\n                                    if (e.shiftKey)\r\n                                        element.contractRight(connectAdjacent);\r\n                                    handled = true;\r\n                                } else if (e.which == 39) { // Right\r\n                                    if (e.altKey)\r\n                                        element.contractLeft(connectAdjacent);\r\n                                    if (e.shiftKey)\r\n                                        element.expandRight(connectAdjacent);\r\n                                    handled = true;\r\n                                }\r\n                            }\r\n                        }\r\n\r\n                        if (!!element.parent) { // This is a child.\r\n                            if (e.altKey && e.which == 38) { // Alt+Up\r\n                                element.parent.setIsFocused();\r\n                                handled = true;\r\n                            }\r\n\r\n                            if (element.parent.type == \"Row\") { // Parent is a horizontal container.\r\n                                if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 37) { // Left\r\n                                    element.parent.moveFocusPrevChild(element);\r\n                                    handled = true;\r\n                                }\r\n                                else if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 39) { // Right\r\n                                    element.parent.moveFocusNextChild(element);\r\n                                    handled = true;\r\n                                }\r\n                                else if (e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 37) { // Ctrl+Left\r\n                                    element.moveUp();\r\n                                    resetFocus = true;\r\n                                    handled = true;\r\n                                }\r\n                                else if (e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 39) { // Ctrl+Right\r\n                                    element.moveDown();\r\n                                    handled = true;\r\n                                }\r\n                            }\r\n                            else { // Parent is a vertical container.\r\n                                if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 38) { // Up\r\n                                    element.parent.moveFocusPrevChild(element);\r\n                                    handled = true;\r\n                                }\r\n                                else if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 40) { // Down\r\n                                    element.parent.moveFocusNextChild(element);\r\n                                    handled = true;\r\n                                }\r\n                                else if (e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 38) { // Ctrl+Up\r\n                                    element.moveUp();\r\n                                    resetFocus = true;\r\n                                    handled = true;\r\n                                }\r\n                                else if (e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 40) { // Ctrl+Down\r\n                                    element.moveDown();\r\n                                    handled = true;\r\n                                }\r\n                            }\r\n                        }\r\n\r\n                        if (handled) {\r\n                            e.preventDefault();\r\n                        }\r\n\r\n                        e.stopPropagation();\r\n\r\n                        $scope.$apply(); // Event is not triggered by Angular directive but raw event handler on element.\r\n\r\n                        // HACK: Workaround because of how Angular treats the DOM when elements are shifted around - input focus is sometimes lost.\r\n                        if (resetFocus) {\r\n                            window.setTimeout(function () {\r\n                                $scope.$apply(function () {\r\n                                    element.editor.focusedElement.setIsFocused();\r\n                                });\r\n                            }, 100);\r\n                        }\r\n                    });\r\n\r\n                    $scope.element.setIsFocusedEventHandlers.push(function () {\r\n                        $element.parent().focus();\r\n                    });\r\n\r\n                    $scope.delete = function (element) {\r\n                        element.delete();\r\n                    }\r\n                },\r\n\r\n                configureForContainer: function ($scope, $element) {\r\n                    var element = $scope.element;\r\n\r\n                    //$scope.isReceiving = false; // True when container is receiving an external element via drag/drop.\r\n                    $scope.getShowChildrenPlaceholder = function () {\r\n                        return $scope.element.children.length === 0 && !$scope.element.getIsDropTarget();\r\n                    };\r\n\r\n                    $scope.sortableOptions = {\r\n                        cursor: \"move\",\r\n                        delay: 150,\r\n                        disabled: element.getIsSealed(),\r\n                        distance: 5,\r\n                        //handle: element.children.length < 2 ? \".imaginary-class\" : false, // For some reason doesn't get re-evaluated after adding more children.\r\n                        start: function (e, ui) {\r\n                            $scope.$apply(function () {\r\n                                element.setIsDropTarget(true);\r\n                                element.editor.isDragging = true;\r\n                            });\r\n                            // Make the drop target placeholder as high as the item being dragged.\r\n                            ui.placeholder.height(ui.item.height() - 4);\r\n                            ui.placeholder.css(\"min-height\", 0);\r\n                        },\r\n                        stop: function (e, ui) {\r\n                            $scope.$apply(function () {\r\n                                element.editor.isDragging = false;\r\n                                element.setIsDropTarget(false);\r\n                            });\r\n                        },\r\n                        over: function (e, ui) {\r\n                            if (!!ui.sender && !!ui.sender[0].isToolbox) {\r\n                                if (!!ui.sender[0].dropTargetTimeout) {\r\n                                    $timeout.cancel(ui.sender[0].dropTargetTimeout);\r\n                                    ui.sender[0].dropTargetTimeout = null;\r\n                                }\r\n                                $timeout(function () {\r\n                                    if (element.type == \"Row\") {\r\n                                        // If there was a previous drop target and it was a row, roll back any pending column adds to it.\r\n                                        var previousDropTarget = element.editor.dropTargetElement;\r\n                                        if (!!previousDropTarget && previousDropTarget.type == \"Row\")\r\n                                            previousDropTarget.rollbackAddColumn();\r\n                                    }\r\n                                    element.setIsDropTarget(false);\r\n                                });\r\n                                ui.sender[0].dropTargetTimeout = $timeout(function () {\r\n                                    if (element.type == \"Row\") {\r\n                                        var receivedColumn = ui.item.sortable.model;\r\n                                        var receivedColumnWidth = Math.floor(12 / (element.children.length + 1));\r\n                                        receivedColumn.width = receivedColumnWidth;\r\n                                        receivedColumn.offset = 0;\r\n                                        element.beginAddColumn(receivedColumnWidth);\r\n                                        // Make the drop target placeholder the correct width and as high as the highest existing column in the row.\r\n                                        var maxHeight = _.max(_($element.find(\"> .layout-children > .layout-column:not(.ui-sortable-placeholder)\")).map(function (e) {\r\n                                            return $(e).height();\r\n                                        }));\r\n                                        for (i = 1; i <= 12; i++)\r\n                                            ui.placeholder.removeClass(\"col-xs-\" + i);\r\n                                        ui.placeholder.addClass(\"col-xs-\" + receivedColumn.width);\r\n                                        if (maxHeight > 0) {\r\n                                            ui.placeholder.height(maxHeight);\r\n                                            ui.placeholder.css(\"min-height\", 0);\r\n                                        }\r\n                                        else {\r\n                                            ui.placeholder.height(0);\r\n                                            ui.placeholder.css(\"min-height\", \"\");\r\n                                        }\r\n                                    }\r\n                                    element.setIsDropTarget(true);\r\n                                }, 150);\r\n                            }\r\n                        },\r\n                        receive: function (e, ui) {\r\n                            if (!!ui.sender && !!ui.sender[0].isToolbox) {\r\n                                $scope.$apply(function () {\r\n                                    var receivedElement = ui.item.sortable.model;\r\n                                    if (!!receivedElement) {\r\n                                        if (element.type == \"Row\")\r\n                                            element.commitAddColumn();\r\n                                        // Should ideally call LayoutEditor.Container.addChild() instead, but since this handler\r\n                                        // is run *before* the ui-sortable directive's handler, if we try to add the child to the\r\n                                        // array that handler will get an exception when trying to do the same.\r\n                                        // Because of this, we need to invoke \"setParent\" so that specific container types can perform element speficic initialization.\r\n                                        receivedElement.setEditor(element.editor);\r\n                                        receivedElement.setParent(element);\r\n                                        if (!!receivedElement.hasEditor) {\r\n                                            $scope.$root.editElement(receivedElement).then(function (args) {\r\n                                                if (!args.cancel) {\r\n                                                    receivedElement.data = args.element.data;\r\n\r\n                                                    if (receivedElement.setHtml)\r\n                                                        receivedElement.setHtml(args.element.html);\r\n                                                }\r\n                                                $timeout(function () {\r\n                                                    if (!!args.cancel)\r\n                                                        receivedElement.delete();\r\n                                                    else\r\n                                                        receivedElement.setIsFocused();\r\n                                                    //$scope.isReceiving = false;\r\n                                                    element.setIsDropTarget(false);\r\n\r\n                                                });\r\n                                                return;\r\n                                            });\r\n                                        }\r\n                                    }\r\n                                    $timeout(function () {\r\n                                        //$scope.isReceiving = false;\r\n                                        element.setIsDropTarget(false);\r\n                                        if (!!receivedElement)\r\n                                            receivedElement.setIsFocused();\r\n                                    });\r\n                                });\r\n                            }\r\n                        }\r\n                    };\r\n\r\n                    $scope.click = function (child, e) {\r\n                        if (!child.editor.isDragging)\r\n                            child.setIsFocused();\r\n                        e.stopPropagation();\r\n                    };\r\n\r\n                    $scope.getClasses = function (child) {\r\n                        var result = [\"layout-element\"];\r\n\r\n                        if (!!child.children) {\r\n                            result.push(\"layout-container\");\r\n                            if (child.getIsSealed())\r\n                                result.push(\"layout-container-sealed\");\r\n                        }\r\n\r\n                        result.push(\"layout-\" + child.type.toLowerCase());\r\n\r\n                        if (!!child.dropTargetClass)\r\n                            result.push(child.dropTargetClass);\r\n\r\n                        // TODO: Move these to either the Column directive or the Column model class.\r\n                        if (child.type == \"Row\") {\r\n                            result.push(\"row\");\r\n                            if (!child.canAddColumn())\r\n                                result.push(\"layout-row-full\");\r\n                        }\r\n                        if (child.type == \"Column\") {\r\n                            result.push(\"col-xs-\" + child.width);\r\n                            result.push(\"col-xs-offset-\" + child.offset);\r\n                        }\r\n                        if (child.type == \"Content\")\r\n                            result.push(\"layout-content-\" + child.contentTypeClass);\r\n\r\n                        if (child.getIsActive())\r\n                            result.push(\"layout-element-active\");\r\n                        if (child.getIsFocused())\r\n                            result.push(\"layout-element-focused\");\r\n                        if (child.getIsSelected())\r\n                            result.push(\"layout-element-selected\");\r\n                        if (child.getIsDropTarget())\r\n                            result.push(\"layout-element-droptarget\");\r\n                        if (child.isTemplated)\r\n                            result.push(\"layout-element-templated\");\r\n\r\n                        return result;\r\n                    };\r\n                }\r\n            };\r\n        }\r\n    ]);","angular\r\n    .module(\"LayoutEditor\")\r\n    .directive(\"orcLayoutEditor\", [\"environment\",\r\n        function (environment) {\r\n            return {\r\n                restrict: \"E\",\r\n                scope: {},\r\n                controller: [\"$scope\", \"$element\", \"$attrs\", \"$compile\", \"clipboard\",\r\n                    function ($scope, $element, $attrs, $compile, clipboard) {\r\n                        if (!!$attrs.model)\r\n                            $scope.element = eval($attrs.model);\r\n                        else\r\n                            throw new Error(\"The 'model' attribute must evaluate to a LayoutEditor.Editor object.\");\r\n\r\n                        $scope.click = function (canvas, e) {\r\n                            if (!canvas.editor.isDragging)\r\n                                canvas.setIsFocused();\r\n                            e.stopPropagation();\r\n                        };\r\n\r\n                        $scope.getClasses = function (canvas) {\r\n                            var result = [\"layout-element\", \"layout-container\", \"layout-canvas\"];\r\n\r\n                            if (canvas.getIsActive())\r\n                                result.push(\"layout-element-active\");\r\n                            if (canvas.getIsFocused())\r\n                                result.push(\"layout-element-focused\");\r\n                            if (canvas.getIsSelected())\r\n                                result.push(\"layout-element-selected\");\r\n                            if (canvas.getIsDropTarget())\r\n                                result.push(\"layout-element-droptarget\");\r\n                            if (canvas.isTemplated)\r\n                                result.push(\"layout-element-templated\");\r\n\r\n                            return result;\r\n                        };\r\n\r\n                        // An unfortunate side-effect of the next hack on line 54 is that the created elements aren't added to the DOM yet, so we can't use it to get to the parent \".layout-desiger\" element.\r\n                        // Work around: access that element directly (which efectively turns multiple layout editors on a single page impossible). \r\n                        // //var layoutDesignerHost = $element.closest(\".layout-designer\").data(\"layout-designer-host\");\r\n                        var layoutDesignerHost = $(\".layout-designer\").data(\"layout-designer-host\");\r\n\r\n                        $scope.$root.layoutDesignerHost = layoutDesignerHost;\r\n\r\n                        layoutDesignerHost.element.on(\"replacecanvas\", function (e, args) {\r\n                            var editor = $scope.element;\r\n                            var canvasData = {\r\n                                data: args.canvas.data,\r\n                                htmlId: args.canvas.htmlId,\r\n                                htmlClass: args.canvas.htmlClass,\r\n                                htmlStyle: args.canvas.htmlStyle,\r\n                                isTemplated: args.canvas.isTemplated,\r\n                                children: args.canvas.children\r\n                            };\r\n\r\n                            // HACK: Instead of simply updating the $scope.element with a new instance, we need to replace the entire orc-layout-editor markup\r\n                            // in order for angular to rebind starting with the Canvas element. Otherwise, for some reason, it will rebind starting with the first child of Canvas.\r\n                            // You can see this happening when setting a breakpoint in ScopeConfigurator where containers are initialized with drag & drop: on page load, the first element\r\n                            // is a Canvas (good), but after having selected another template, the first element is (typically) a Grid (bad).\r\n                            // Simply recompiling the orc-layout-editor directive will cause the entire thing to be generated, which works just fine as well (even though not is nice as simply leveraging model binding).\r\n                            layoutDesignerHost.editor = window.layoutEditor = new LayoutEditor.Editor(editor.config, canvasData);\r\n                            var template = \"<orc-layout-editor\" + \" model='window.layoutEditor' />\";\r\n                            var html = $compile(template)($scope);\r\n                            $(\".layout-editor-holder\").html(html);\r\n                        });\r\n\r\n                        $scope.$root.editElement = function (element) {\r\n                            var host = $scope.$root.layoutDesignerHost;\r\n                            return host.editElement(element);\r\n                        };\r\n\r\n                        $scope.$root.addElement = function (contentType) {\r\n                            var host = $scope.$root.layoutDesignerHost;\r\n                            return host.addElement(contentType);\r\n                        };\r\n\r\n                        $scope.toggleInlineEditing = function () {\r\n                            if (!$scope.element.inlineEditingIsActive) {\r\n                                $scope.element.inlineEditingIsActive = true;\r\n                                $element.find(\".layout-toolbar-container\").show();\r\n                                var selector = \"#layout-editor-\" + $scope.$id + \" .layout-html .layout-content-markup[data-templated=false]\";\r\n                                var firstContentEditorId = $(selector).first().attr(\"id\");\r\n                                tinymce.init({\r\n                                    selector: selector,\r\n                                    theme: \"modern\",\r\n                                    schema: \"html5\",\r\n                                    plugins: [\r\n                                        \"advlist autolink lists link image charmap print preview hr anchor pagebreak\",\r\n                                        \"searchreplace wordcount visualblocks visualchars code fullscreen\",\r\n                                        \"insertdatetime media nonbreaking table contextmenu directionality\",\r\n                                        \"emoticons template paste textcolor colorpicker textpattern\",\r\n                                        \"fullscreen autoresize\"\r\n                                    ],\r\n                                    toolbar: \"undo redo cut copy paste | bold italic | bullist numlist outdent indent formatselect | alignleft aligncenter alignright alignjustify ltr rtl | link unlink charmap | code fullscreen close\",\r\n                                    convert_urls: false,\r\n                                    valid_elements: \"*[*]\",\r\n                                    // Shouldn't be needed due to the valid_elements setting, but TinyMCE would strip script.src without it.\r\n                                    extended_valid_elements: \"script[type|defer|src|language]\",\r\n                                    statusbar: false,\r\n                                    skin: \"orchardlightgray\",\r\n                                    inline: true,\r\n                                    fixed_toolbar_container: \"#layout-editor-\" + $scope.$id + \" .layout-toolbar-container\",\r\n                                    init_instance_callback: function (editor) {\r\n                                        if (editor.id == firstContentEditorId)\r\n                                            tinymce.execCommand(\"mceFocus\", false, editor.id);\r\n                                    }\r\n                                });\r\n                            }\r\n                            else {\r\n                                tinymce.remove(\"#layout-editor-\" + $scope.$id + \" .layout-content-markup\");\r\n                                $element.find(\".layout-toolbar-container\").hide();\r\n                                $scope.element.inlineEditingIsActive = false;\r\n                            }\r\n                        };\r\n\r\n                        $(document).on(\"cut copy paste\", function (e) {\r\n                            // If the pseudo clipboard was already invoked (which happens on the first clipboard\r\n                            // operation after page load even if native clipboard support exists) then sit this\r\n                            // one operation out, but make sure whatever is on the pseudo clipboard gets migrated\r\n                            // to the native clipboard for subsequent operations.\r\n                            if (clipboard.wasInvoked()) {\r\n                                e.originalEvent.clipboardData.setData(\"text/plain\", clipboard.getData(\"text/plain\"));\r\n                                e.originalEvent.clipboardData.setData(\"text/json\", clipboard.getData(\"text/json\"));\r\n                                e.preventDefault();\r\n                            }\r\n                            else {\r\n                                var focusedElement = $scope.element.focusedElement;\r\n                                if (!!focusedElement) {\r\n                                    $scope.$apply(function () {\r\n                                        switch (e.type) {\r\n                                            case \"copy\":\r\n                                                focusedElement.copy(e.originalEvent.clipboardData);\r\n                                                break;\r\n                                            case \"cut\":\r\n                                                focusedElement.cut(e.originalEvent.clipboardData);\r\n                                                break;\r\n                                            case \"paste\":\r\n                                                focusedElement.paste(e.originalEvent.clipboardData);\r\n                                                break;\r\n                                        }\r\n                                    });\r\n\r\n                                    // HACK: Workaround because of how Angular treats the DOM when elements are shifted around - input focus is sometimes lost.\r\n                                    window.setTimeout(function () {\r\n                                        $scope.$apply(function () {\r\n                                            if (!!$scope.element.focusedElement)\r\n                                                $scope.element.focusedElement.setIsFocused();\r\n                                        });\r\n                                    }, 100);\r\n\r\n                                    e.preventDefault();\r\n                                }\r\n                            }\r\n\r\n                            // Native clipboard support obviously exists, so disable the peudo clipboard from now on.\r\n                            clipboard.disable();\r\n                        });\r\n                    }\r\n                ],\r\n                templateUrl: environment.templateUrl(\"Editor\"),\r\n                replace: true,\r\n                link: function (scope, element) {\r\n                    // No clicks should propagate from the TinyMCE toolbars.\r\n                    element.find(\".layout-toolbar-container\").click(function (e) {\r\n                        e.stopPropagation();\r\n                    });\r\n                    // Intercept mousedown on editor while in inline editing mode to \r\n                    // prevent current editor from losing focus.\r\n                    element.mousedown(function (e) {\r\n                        if (scope.element.inlineEditingIsActive) {\r\n                            e.preventDefault();\r\n                            e.stopPropagation();\r\n                        }\r\n                    })\r\n                    // Unfocus and unselect everything on click outside of canvas.\r\n                    $(window).click(function (e) {\r\n                        // Except when in inline editing mode.\r\n                        if (!scope.element.inlineEditingIsActive) {\r\n                            scope.$apply(function () {\r\n                                scope.element.activeElement = null;\r\n                                scope.element.focusedElement = null;\r\n                            });\r\n                        }\r\n                    });\r\n                }\r\n            };\r\n        }\r\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutCanvas\", [\"scopeConfigurator\", \"environment\",\n        function (scopeConfigurator, environment) {\n            return {\n                restrict: \"E\",\n                scope: { element: \"=\" },\n                controller: [\"$scope\", \"$element\", \"$attrs\",\n                    function ($scope, $element, $attrs) {\n                        scopeConfigurator.configureForElement($scope, $element);\n                        scopeConfigurator.configureForContainer($scope, $element);\n                        $scope.sortableOptions[\"axis\"] = \"y\";\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"Canvas\"),\n                replace: true\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutChild\", [\"$compile\",\n        function ($compile) {\n            return {\n                restrict: \"E\",\n                scope: { element: \"=\" },\n                link: function (scope, element) {\n                    var template = \"<orc-layout-\" + scope.element.type.toLowerCase() + \" element='element' />\";\n                    var html = $compile(template)(scope);\n                    $(element).replaceWith(html);\n                }\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutColumn\", [\"$compile\", \"scopeConfigurator\", \"environment\",\n        function ($compile, scopeConfigurator, environment) {\n            return {\n                restrict: \"E\",\n                scope: { element: \"=\" },\n                controller: [\"$scope\", \"$element\",\n                    function ($scope, $element) {\n                        scopeConfigurator.configureForElement($scope, $element);\n                        scopeConfigurator.configureForContainer($scope, $element);\n                        $scope.sortableOptions[\"axis\"] = \"y\";\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"Column\"),\n                replace: true,\n                link: function (scope, element, attrs) {\n                    element.find(\".layout-column-resize-bar\").draggable({\n                        axis: \"x\",\n                        helper: \"clone\",\n                        revert: true,\n                        start: function (e, ui) {\n                            scope.$apply(function () {\n                                scope.element.editor.isResizing = true;\n                            });\n                        },\n                        drag: function (e, ui) {\n                            var columnElement = element.parent();\n                            var columnSize = columnElement.width() / scope.element.width;\n                            var connectAdjacent = !e.ctrlKey;\n                            if ($(e.target).hasClass(\"layout-column-resize-bar-left\")) {\n                                var delta = ui.offset.left - columnElement.offset().left;\n                                if (delta < -columnSize && scope.element.canExpandLeft(connectAdjacent)) {\n                                    scope.$apply(function () {\n                                        scope.element.expandLeft(connectAdjacent);\n                                    });\n                                }\n                                else if (delta > columnSize && scope.element.canContractLeft(connectAdjacent)) {\n                                    scope.$apply(function () {\n                                        scope.element.contractLeft(connectAdjacent);\n                                    });\n                                }\n                            }\n                            else if ($(e.target).hasClass(\"layout-column-resize-bar-right\")) {\n                                var delta = ui.offset.left - columnElement.width() - columnElement.offset().left;\n                                if (delta > columnSize && scope.element.canExpandRight(connectAdjacent)) {\n                                    scope.$apply(function () {\n                                        scope.element.expandRight(connectAdjacent);\n                                    });\n                                }\n                                else if (delta < -columnSize && scope.element.canContractRight(connectAdjacent)) {\n                                    scope.$apply(function () {\n                                        scope.element.contractRight(connectAdjacent);\n                                    });\n                                }\n                            }\n\n                        },\n                        stop: function (e, ui) {\n                            scope.$apply(function () {\n                              scope.element.editor.isResizing = false;\n                            });\n                        }\n                    });\n                }\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutContent\", [\"$sce\", \"scopeConfigurator\", \"environment\",\n        function ($sce, scopeConfigurator, environment) {\n            return {\n                restrict: \"E\",\n                scope: { element: \"=\" },\n                controller: [\"$scope\", \"$element\",\n                    function ($scope, $element) {\n                        scopeConfigurator.configureForElement($scope, $element);\n                        $scope.edit = function () {\n                            $scope.$root.editElement($scope.element).then(function (args) {\n                                $scope.$apply(function () {\n                                    if (args.cancel)\n                                        return;\n\n                                    $scope.element.data = args.element.data;\n                                    $scope.element.setHtml(args.element.html);\n                                });\n                            });\n                        };\n\n                        // Overwrite the setHtml function so that we can use the $sce service to trust the html (and not have the html binding strip certain tags).\n                        $scope.element.setHtml = function (html) {\n                            $scope.element.html = html;\n                            $scope.element.htmlUnsafe = $sce.trustAsHtml(html);\n                        };\n\n                        $scope.element.setHtml($scope.element.html);\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"Content\"),\n                replace: true\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutHtml\", [\"$sce\", \"scopeConfigurator\", \"environment\",\n        function ($sce, scopeConfigurator, environment) {\n            return {\n                restrict: \"E\",\n                scope: { element: \"=\" },\n                controller: [\"$scope\", \"$element\",\n                    function ($scope, $element) {\n                        scopeConfigurator.configureForElement($scope, $element);\n                        $scope.edit = function () {\n                            $scope.$root.editElement($scope.element).then(function (args) {\n                                $scope.$apply(function () {\n                                    if (args.cancel)\n                                        return;\n\n                                    $scope.element.data = args.element.data;\n                                    $scope.element.setHtml(args.element.html);\n                                });\n                            });\n                        };\n                        $scope.updateContent = function (e) {\n                            $scope.element.setHtml(e.target.innerHTML);\n                        };\n\n                        // Overwrite the setHtml function so that we can use the $sce service to trust the html (and not have the html binding strip certain tags).\n                        $scope.element.setHtml = function (html) {\n                            $scope.element.html = html;\n                            $scope.element.htmlUnsafe = $sce.trustAsHtml(html);\n                        };\n\n                        $scope.element.setHtml($scope.element.html);\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"Html\"),\n                replace: true,\n                link: function (scope, element) {\n                    // Mouse down events must not be intercepted by drag and drop while inline editing is active,\n                    // otherwise clicks in inline editors will have no effect.\n                    element.find(\".layout-content-markup\").mousedown(function (e) {\n                        if (scope.element.editor.inlineEditingIsActive) {\n                            e.stopPropagation();\n                        }\n                    });\n                }\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutGrid\", [\"$compile\", \"scopeConfigurator\", \"environment\",\n        function ($compile, scopeConfigurator, environment) {\n            return {\n                restrict: \"E\",\n                scope: { element: \"=\" },\n                controller: [\"$scope\", \"$element\",\n                    function ($scope, $element) {\n                        scopeConfigurator.configureForElement($scope, $element);\n                        scopeConfigurator.configureForContainer($scope, $element);\n                        $scope.sortableOptions[\"axis\"] = \"y\";\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"Grid\"),\n                replace: true\n            };\n        }\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutRow\", [\"$compile\", \"scopeConfigurator\", \"environment\",\n        function ($compile, scopeConfigurator, environment) {\n            return {\n                restrict: \"E\",\n                scope: { element: \"=\" },\n                controller: [\"$scope\", \"$element\",\n                    function ($scope, $element) {\n                        scopeConfigurator.configureForElement($scope, $element);\n                        scopeConfigurator.configureForContainer($scope, $element);\n                        $scope.sortableOptions[\"axis\"] = \"x\";\n                        $scope.sortableOptions[\"ui-floating\"] = true;\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"Row\"),\n                replace: true\n            };\n        }\n    ]);","angular\r\n    .module(\"LayoutEditor\")\r\n    .directive(\"orcLayoutPopup\", [\r\n        function () {\r\n            return {\r\n                restrict: \"A\",\r\n                link: function (scope, element, attrs) {\r\n                    var popup = $(element);\r\n                    var trigger = popup.closest(\".layout-popup-trigger\");\r\n                    var parentElement = popup.closest(\".layout-element\");\r\n                    trigger.click(function () {\r\n                        popup.toggle();\r\n                        if (popup.is(\":visible\")) {\r\n                            popup.position({\r\n                                my: attrs.orcLayoutPopupMy || \"left top\",\r\n                                at: attrs.orcLayoutPopupAt || \"left bottom+4px\",\r\n                                of: trigger\r\n                            });\r\n                            popup.find(\"input\").first().focus();\r\n                        }\r\n                    });\r\n                    popup.click(function (e) {\r\n                        e.stopPropagation();\r\n                    });\r\n                    parentElement.click(function (e) {\r\n                        popup.hide();\r\n                    });\r\n                    popup.keydown(function (e) {\r\n                        if (!e.ctrlKey && !e.shiftKey && !e.altKey && e.which == 27) // Esc\r\n                            popup.hide();\r\n                        e.stopPropagation();\r\n                    });\r\n                    popup.on(\"cut copy paste\", function (e) {\r\n                        // Allow clipboard operations in popup without invoking clipboard event handlers on parent element.\r\n                        e.stopPropagation();\r\n                    });\r\n                }\r\n            };\r\n        }\r\n    ]);","angular\r\n    .module(\"LayoutEditor\")\r\n    .directive(\"orcLayoutToolbox\", [\"$compile\", \"environment\",\r\n        function ($compile, environment) {\r\n            return {\r\n                restrict: \"E\",\r\n                controller: [\"$scope\", \"$element\",\r\n                    function ($scope, $element) {\r\n\r\n                        $scope.resetElements = function () {\r\n\r\n                            $scope.gridElements = [\r\n                                LayoutEditor.Grid.from({\r\n                                    toolboxIcon: \"\\uf00a\",\r\n                                    toolboxLabel: \"Grid\",\r\n                                    toolboxDescription: \"Empty grid.\",\r\n                                    children: []\r\n                                })\r\n                            ];\r\n\r\n                            $scope.rowElements = [\r\n                                LayoutEditor.Row.from({\r\n                                    toolboxIcon: \"\\uf0c9\",\r\n                                    toolboxLabel: \"Row (1 column)\",\r\n                                    toolboxDescription: \"Row with 1 column.\",\r\n                                    children: LayoutEditor.Column.times(1)\r\n                                }),\r\n                                LayoutEditor.Row.from({\r\n                                    toolboxIcon: \"\\uf0c9\",\r\n                                    toolboxLabel: \"Row (2 columns)\",\r\n                                    toolboxDescription: \"Row with 2 columns.\",\r\n                                    children: LayoutEditor.Column.times(2)\r\n                                }),\r\n                                LayoutEditor.Row.from({\r\n                                    toolboxIcon: \"\\uf0c9\",\r\n                                    toolboxLabel: \"Row (3 columns)\",\r\n                                    toolboxDescription: \"Row with 3 columns.\",\r\n                                    children: LayoutEditor.Column.times(3)\r\n                                }),\r\n                                LayoutEditor.Row.from({\r\n                                    toolboxIcon: \"\\uf0c9\",\r\n                                    toolboxLabel: \"Row (4 columns)\",\r\n                                    toolboxDescription: \"Row with 4 columns.\",\r\n                                    children: LayoutEditor.Column.times(4)\r\n                                }),\r\n                                LayoutEditor.Row.from({\r\n                                    toolboxIcon: \"\\uf0c9\",\r\n                                    toolboxLabel: \"Row (6 columns)\",\r\n                                    toolboxDescription: \"Row with 6 columns.\",\r\n                                    children: LayoutEditor.Column.times(6)\r\n                                }),\r\n                                LayoutEditor.Row.from({\r\n                                    toolboxIcon: \"\\uf0c9\",\r\n                                    toolboxLabel: \"Row (12 columns)\",\r\n                                    toolboxDescription: \"Row with 12 columns.\",\r\n                                    children: LayoutEditor.Column.times(12)\r\n                                }), LayoutEditor.Row.from({\r\n                                    toolboxIcon: \"\\uf0c9\",\r\n                                    toolboxLabel: \"Row (empty)\",\r\n                                    toolboxDescription: \"Empty row.\",\r\n                                    children: []\r\n                                })\r\n                            ];\r\n\r\n                            $scope.columnElements = [\r\n                                LayoutEditor.Column.from({\r\n                                    toolboxIcon: \"\\uf0db\",\r\n                                    toolboxLabel: \"Column\",\r\n                                    toolboxDescription: \"Empty column.\",\r\n                                    width: 1,\r\n                                    offset: 0,\r\n                                    children: []\r\n                                })\r\n                            ];\r\n\r\n                            $scope.canvasElements = [\r\n                                LayoutEditor.Canvas.from({\r\n                                    toolboxIcon: \"\\uf044\",\r\n                                    toolboxLabel: \"Canvas\",\r\n                                    toolboxDescription: \"Empty canvas.\",\r\n                                    children: []\r\n                                })\r\n                            ];\r\n\r\n                            $scope.contentElementCategories = _($scope.element.config.categories).map(function (category) {\r\n                                return {\r\n                                    name: category.name,\r\n                                    elements: _(category.contentTypes).map(function (contentType) {\r\n                                        var type = contentType.type;\r\n                                        var factory = LayoutEditor.factories[type] || LayoutEditor.factories[\"Content\"];\r\n                                        var item = {\r\n                                            isTemplated: false,\r\n                                            contentType: contentType.id,\r\n                                            contentTypeLabel: contentType.label,\r\n                                            contentTypeClass: contentType.typeClass,\r\n                                            data: null,\r\n                                            hasEditor: contentType.hasEditor,\r\n                                            html: contentType.html\r\n                                        };\r\n                                        var element = factory(item);\r\n                                        element.toolboxIcon = contentType.icon || \"\\uf1c9\";\r\n                                        element.toolboxLabel = contentType.label;\r\n                                        element.toolboxDescription = contentType.description;\r\n                                        return element;\r\n                                    })\r\n                                };\r\n                            });\r\n\r\n                        };\r\n\r\n                        $scope.resetElements();\r\n\r\n                        $scope.getSortableOptions = function (type) {\r\n                            var editorId = $element.closest(\".layout-editor\").attr(\"id\");\r\n                            var parentClasses;\r\n                            var placeholderClasses;\r\n                            var floating = false;\r\n\r\n                            switch (type) {\r\n                                case \"Grid\":\r\n                                    parentClasses = [\".layout-canvas\", \".layout-column\", \".layout-common-holder\"];\r\n                                    placeholderClasses = \"layout-element layout-container layout-grid ui-sortable-placeholder\";\r\n                                    break;\r\n                                case \"Row\":\r\n                                    parentClasses = [\".layout-grid\"];\r\n                                    placeholderClasses = \"layout-element layout-container layout-row row ui-sortable-placeholder\";\r\n                                    break;\r\n                                case \"Column\":\r\n                                    parentClasses = [\".layout-row:not(.layout-row-full)\"];\r\n                                    placeholderClasses = \"layout-element layout-container layout-column ui-sortable-placeholder\";\r\n                                    floating = true; // To ensure a smooth horizontal-list reordering. https://github.com/angular-ui/ui-sortable#floating\r\n                                    break;\r\n                                case \"Content\":\r\n                                    parentClasses = [\".layout-canvas\", \".layout-column\", \".layout-common-holder\"];\r\n                                    placeholderClasses = \"layout-element layout-content ui-sortable-placeholder\";\r\n                                    break;\r\n                                case \"Canvas\":\r\n                                    parentClasses = [\".layout-canvas\", \".layout-column\", \".layout-common-holder\"];\r\n                                    placeholderClasses = \"layout-element layout-container layout-grid ui-sortable-placeholder\";\r\n                                    break;\r\n                            }\r\n\r\n                            return {\r\n                                cursor: \"move\",\r\n                                connectWith: _(parentClasses).map(function (e) { return \"#\" + editorId + \" \" + e + \":not(.layout-container-sealed) > .layout-element-wrapper > .layout-children\"; }).join(\", \"),\r\n                                placeholder: placeholderClasses,\r\n                                \"ui-floating\": floating,\r\n                                create: function (e, ui) {\r\n                                    e.target.isToolbox = true; // Will indicate to connected sortables that dropped items were sent from toolbox.\r\n                                },\r\n                                start: function (e, ui) {\r\n                                    $scope.$apply(function () {\r\n                                        $scope.element.isDragging = true;\r\n                                    });\r\n                                },\r\n                                stop: function (e, ui) {\r\n                                    $scope.$apply(function () {\r\n                                        $scope.element.isDragging = false;\r\n                                        $scope.resetElements();\r\n                                    });\r\n                                },\r\n                                over: function (e, ui) {\r\n                                    $scope.$apply(function () {\r\n                                        $scope.element.canvas.setIsDropTarget(false);\r\n                                    });\r\n                                },\r\n                            }\r\n                        };\r\n\r\n                        var layoutIsCollapsedCookieName = \"layoutToolboxCategory_Layout_IsCollapsed\";\r\n                        $scope.layoutIsCollapsed = $.cookie(layoutIsCollapsedCookieName) === \"true\";\r\n\r\n                        $scope.toggleLayoutIsCollapsed = function (e) {\r\n                            $scope.layoutIsCollapsed = !$scope.layoutIsCollapsed;\r\n                            $.cookie(layoutIsCollapsedCookieName, $scope.layoutIsCollapsed, { expires: 365 }); // Remember collapsed state for a year.\r\n                            e.preventDefault();\r\n                            e.stopPropagation();\r\n                        };\r\n                    }\r\n                ],\r\n                templateUrl: environment.templateUrl(\"Toolbox\"),\r\n                replace: true,\r\n                link: function (scope, element) {\r\n                    var toolbox = element.find(\".layout-toolbox\");\r\n                    $(window).on(\"resize scroll\", function (e) {\r\n                        var canvas = element.parent().find(\".layout-canvas\");\r\n                        // If the canvas is taller than the toolbox, make the toolbox sticky-positioned within the editor\r\n                        // to help the user avoid excessive vertical scrolling.\r\n                        var canvasIsTaller = !!canvas && canvas.height() > toolbox.height();\r\n                        var windowPos = $(window).scrollTop();\r\n                        if (canvasIsTaller && windowPos > element.offset().top + element.height() - toolbox.height()) {\r\n                            toolbox.addClass(\"sticky-bottom\");\r\n                            toolbox.removeClass(\"sticky-top\");\r\n                        }\r\n                        else if (canvasIsTaller && windowPos > element.offset().top) {\r\n                            toolbox.addClass(\"sticky-top\");\r\n                            toolbox.removeClass(\"sticky-bottom\");\r\n                        }\r\n                        else {\r\n                            toolbox.removeClass(\"sticky-top\");\r\n                            toolbox.removeClass(\"sticky-bottom\");\r\n                        }\r\n                    });\r\n                }\r\n            };\r\n        }\r\n    ]);","angular\n    .module(\"LayoutEditor\")\n    .directive(\"orcLayoutToolboxGroup\", [\"$compile\", \"environment\",\n        function ($compile, environment) {\n            return {\n                restrict: \"E\",\n                scope: { category: \"=\" },\n                controller: [\"$scope\", \"$element\",\n                    function ($scope, $element) {\n                        var isCollapsedCookieName = \"layoutToolboxCategory_\" + $scope.category.name + \"_IsCollapsed\";\n                        $scope.isCollapsed = $.cookie(isCollapsedCookieName) === \"true\";\n                        $scope.toggleIsCollapsed = function (e) {\n                            $scope.isCollapsed = !$scope.isCollapsed;\n                            $.cookie(isCollapsedCookieName, $scope.isCollapsed, { expires: 365 }); // Remember collapsed state for a year.\n                            e.preventDefault();\n                            e.stopPropagation();\n                        };\n                    }\n                ],\n                templateUrl: environment.templateUrl(\"ToolboxGroup\"),\n                replace: true\n            };\n        }\n    ]);"],"sourceRoot":"/source/"} \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor.min.js b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor.min.js index 43793db82..aa045d45d 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor.min.js +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor.min.js @@ -1 +1 @@ -angular.module("LayoutEditor",["ngSanitize","ngResource","ui.sortable"]);var LayoutEditor;!function(e){var t=function(){var e=this;this.clipboardData={},this.setData=function(t,o,n){e.clipboardData[t]=o},this.getData=function(t,o){return e.clipboardData[t]},this.disable=function(){this.disabled=!0}};e.Clipboard=new t,angular.module("LayoutEditor").factory("clipboard",[function(){return{setData:e.Clipboard.setData,getData:e.Clipboard.getData,disable:e.Clipboard.disable}}])}(LayoutEditor||(LayoutEditor={})),angular.module("LayoutEditor").factory("scopeConfigurator",["$timeout","clipboard",function(e,t){return{configureForElement:function(e,o){o.find(".layout-panel").click(function(e){e.stopPropagation()}),o.parent().keydown(function(n){var l=!1,i=!1,a=e.element;if(!a.editor.isDragging&&!a.editor.inlineEditingIsActive){if(!t.disabled){var r=a.editor.focusedElement;if(r&&n.ctrlKey)switch(n.which){case 67:r.copy(t);break;case 88:r.cut(t);break;case 86:r.paste(t)}}if(n.ctrlKey||n.shiftKey||n.altKey||46!=n.which?n.ctrlKey||n.shiftKey||n.altKey||32!=n.which&&27!=n.which||(o.find(".layout-panel-action-properties").first().click(),l=!0):(e["delete"](a),l=!0),"Content"==a.type&&(n.ctrlKey||n.shiftKey||n.altKey||13!=n.which||(o.find(".layout-panel-action-edit").first().click(),l=!0)),a.children&&(n.ctrlKey||n.shiftKey||!n.altKey||40!=n.which||(a.children.length>0&&a.children[0].setIsFocused(),l=!0),"Column"==a.type)){var c=!n.ctrlKey;37==n.which?(n.altKey&&a.expandLeft(c),n.shiftKey&&a.contractRight(c),l=!0):39==n.which&&(n.altKey&&a.contractLeft(c),n.shiftKey&&a.expandRight(c),l=!0)}a.parent&&(n.altKey&&38==n.which&&(a.parent.setIsFocused(),l=!0),"Row"==a.parent.type?n.ctrlKey||n.shiftKey||n.altKey||37!=n.which?n.ctrlKey||n.shiftKey||n.altKey||39!=n.which?!n.ctrlKey||n.shiftKey||n.altKey||37!=n.which?!n.ctrlKey||n.shiftKey||n.altKey||39!=n.which||(a.moveDown(),l=!0):(a.moveUp(),i=!0,l=!0):(a.parent.moveFocusNextChild(a),l=!0):(a.parent.moveFocusPrevChild(a),l=!0):n.ctrlKey||n.shiftKey||n.altKey||38!=n.which?n.ctrlKey||n.shiftKey||n.altKey||40!=n.which?!n.ctrlKey||n.shiftKey||n.altKey||38!=n.which?!n.ctrlKey||n.shiftKey||n.altKey||40!=n.which||(a.moveDown(),l=!0):(a.moveUp(),i=!0,l=!0):(a.parent.moveFocusNextChild(a),l=!0):(a.parent.moveFocusPrevChild(a),l=!0)),l&&n.preventDefault(),n.stopPropagation(),e.$apply(),i&&window.setTimeout(function(){e.$apply(function(){a.editor.focusedElement.setIsFocused()})},100)}}),e.element.setIsFocusedEventHandlers.push(function(){o.parent().focus()}),e["delete"]=function(e){e["delete"]()}},configureForContainer:function(t,o){var n=t.element;t.getShowChildrenPlaceholder=function(){return 0===t.element.children.length&&!t.element.getIsDropTarget()},t.sortableOptions={cursor:"move",delay:150,disabled:n.getIsSealed(),distance:5,start:function(e,o){t.$apply(function(){n.setIsDropTarget(!0),n.editor.isDragging=!0}),o.placeholder.height(o.item.height()-4),o.placeholder.css("min-height",0)},stop:function(e,o){t.$apply(function(){n.editor.isDragging=!1,n.setIsDropTarget(!1)})},over:function(t,l){l.sender&&l.sender[0].isToolbox&&(l.sender[0].dropTargetTimeout&&(e.cancel(l.sender[0].dropTargetTimeout),l.sender[0].dropTargetTimeout=null),e(function(){if("Row"==n.type){var e=n.editor.dropTargetElement;e&&"Row"==e.type&&e.rollbackAddColumn()}n.setIsDropTarget(!1)}),l.sender[0].dropTargetTimeout=e(function(){if("Row"==n.type){var e=l.item.sortable.model,t=Math.floor(12/(n.children.length+1));e.width=t,e.offset=0,n.beginAddColumn(t);var a=_.max(_(o.find("> .layout-children > .layout-column:not(.ui-sortable-placeholder)")).map(function(e){return $(e).height()}));for(i=1;i<=12;i++)l.placeholder.removeClass("col-xs-"+i);l.placeholder.addClass("col-xs-"+e.width),a>0?(l.placeholder.height(a),l.placeholder.css("min-height",0)):(l.placeholder.height(0),l.placeholder.css("min-height",""))}n.setIsDropTarget(!0)},150))},receive:function(o,l){l.sender&&l.sender[0].isToolbox&&t.$apply(function(){var o=l.item.sortable.model;o&&("Row"==n.type&&n.commitAddColumn(),o.setEditor(n.editor),o.setParent(n),o.hasEditor&&t.$root.editElement(o).then(function(t){t.cancel||(o.data=t.element.data,o.setHtml&&o.setHtml(t.element.html)),e(function(){t.cancel?o["delete"]():o.setIsFocused(),n.setIsDropTarget(!1)})})),e(function(){n.setIsDropTarget(!1),o&&o.setIsFocused()})})}},t.click=function(e,t){e.editor.isDragging||e.setIsFocused(),t.stopPropagation()},t.getClasses=function(e){var t=["layout-element"];return e.children&&(t.push("layout-container"),e.getIsSealed()&&t.push("layout-container-sealed")),t.push("layout-"+e.type.toLowerCase()),e.dropTargetClass&&t.push(e.dropTargetClass),"Row"==e.type&&(t.push("row"),e.canAddColumn()||t.push("layout-row-full")),"Column"==e.type&&(t.push("col-xs-"+e.width),t.push("col-xs-offset-"+e.offset)),"Content"==e.type&&t.push("layout-content-"+e.contentTypeClass),e.getIsActive()&&t.push("layout-element-active"),e.getIsFocused()&&t.push("layout-element-focused"),e.getIsSelected()&&t.push("layout-element-selected"),e.getIsDropTarget()&&t.push("layout-element-droptarget"),e.isTemplated&&t.push("layout-element-templated"),t}}}}]),angular.module("LayoutEditor").directive("orcLayoutEditor",["environment",function(environment){return{restrict:"E",scope:{},controller:["$scope","$element","$attrs","$compile","clipboard",function($scope,$element,$attrs,$compile,clipboard){if(!$attrs.model)throw new Error("The 'model' attribute must evaluate to a LayoutEditor.Editor object.");$scope.element=eval($attrs.model),$scope.click=function(e,t){e.editor.isDragging||e.setIsFocused(),t.stopPropagation()},$scope.getClasses=function(e){var t=["layout-element","layout-container","layout-canvas"];return e.getIsActive()&&t.push("layout-element-active"),e.getIsFocused()&&t.push("layout-element-focused"),e.getIsSelected()&&t.push("layout-element-selected"),e.getIsDropTarget()&&t.push("layout-element-droptarget"),e.isTemplated&&t.push("layout-element-templated"),t};var layoutDesignerHost=$(".layout-designer").data("layout-designer-host");$scope.$root.layoutDesignerHost=layoutDesignerHost,layoutDesignerHost.element.on("replacecanvas",function(e,t){var o=$scope.element,n={data:t.canvas.data,htmlId:t.canvas.htmlId,htmlClass:t.canvas.htmlClass,htmlStyle:t.canvas.htmlStyle,isTemplated:t.canvas.isTemplated,children:t.canvas.children};layoutDesignerHost.editor=window.layoutEditor=new LayoutEditor.Editor(o.config,n);var l="",i=$compile(l)($scope);$(".layout-editor-holder").html(i)}),$scope.$root.editElement=function(e){var t=$scope.$root.layoutDesignerHost;return t.editElement(e)},$scope.$root.addElement=function(e){var t=$scope.$root.layoutDesignerHost;return t.addElement(e)},$scope.toggleInlineEditing=function(){if($scope.element.inlineEditingIsActive)tinymce.remove("#layout-editor-"+$scope.$id+" .layout-content-markup"),$element.find(".layout-toolbar-container").hide(),$scope.element.inlineEditingIsActive=!1;else{$scope.element.inlineEditingIsActive=!0,$element.find(".layout-toolbar-container").show();var e="#layout-editor-"+$scope.$id+" .layout-html .layout-content-markup[data-templated=false]",t=$(e).first().attr("id");tinymce.init({selector:e,theme:"modern",schema:"html5",plugins:["advlist autolink lists link image charmap print preview hr anchor pagebreak","searchreplace wordcount visualblocks visualchars code fullscreen","insertdatetime media nonbreaking table contextmenu directionality","emoticons template paste textcolor colorpicker textpattern","fullscreen autoresize"],toolbar:"undo redo cut copy paste | bold italic | bullist numlist outdent indent formatselect | alignleft aligncenter alignright alignjustify ltr rtl | link unlink charmap | code fullscreen close",convert_urls:!1,valid_elements:"*[*]",extended_valid_elements:"script[type|defer|src|language]",statusbar:!1,skin:"orchardlightgray",inline:!0,fixed_toolbar_container:"#layout-editor-"+$scope.$id+" .layout-toolbar-container",init_instance_callback:function(e){e.id==t&&tinymce.execCommand("mceFocus",!1,e.id)}})}},$(document).on("cut copy paste",function(e){clipboard.disable();var t=$scope.element.focusedElement;t&&($scope.$apply(function(){switch(e.type){case"copy":t.copy(e.originalEvent.clipboardData);break;case"cut":t.cut(e.originalEvent.clipboardData);break;case"paste":t.paste(e.originalEvent.clipboardData)}}),window.setTimeout(function(){$scope.$apply(function(){$scope.element.focusedElement&&$scope.element.focusedElement.setIsFocused()})},100),e.preventDefault())})}],templateUrl:environment.templateUrl("Editor"),replace:!0,link:function(e,t){t.find(".layout-toolbar-container").click(function(e){e.stopPropagation()}),t.mousedown(function(t){e.element.inlineEditingIsActive&&(t.preventDefault(),t.stopPropagation())}),$(window).click(function(t){e.element.inlineEditingIsActive||e.$apply(function(){e.element.activeElement=null,e.element.focusedElement=null})})}}}]),angular.module("LayoutEditor").directive("orcLayoutCanvas",["scopeConfigurator","environment",function(e,t){return{restrict:"E",scope:{element:"="},controller:["$scope","$element","$attrs",function(t,o,n){e.configureForElement(t,o),e.configureForContainer(t,o),t.sortableOptions.axis="y"}],templateUrl:t.templateUrl("Canvas"),replace:!0}}]),angular.module("LayoutEditor").directive("orcLayoutChild",["$compile",function(e){return{restrict:"E",scope:{element:"="},link:function(t,o){var n="",l=e(n)(t);$(o).replaceWith(l)}}}]),angular.module("LayoutEditor").directive("orcLayoutColumn",["$compile","scopeConfigurator","environment",function(e,t,o){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(e,o){t.configureForElement(e,o),t.configureForContainer(e,o),e.sortableOptions.axis="y"}],templateUrl:o.templateUrl("Column"),replace:!0,link:function(e,t,o){t.find(".layout-column-resize-bar").draggable({axis:"x",helper:"clone",revert:!0,start:function(t,o){e.$apply(function(){e.element.editor.isResizing=!0})},drag:function(o,n){var l=t.parent(),i=l.width()/e.element.width,a=!o.ctrlKey;if($(o.target).hasClass("layout-column-resize-bar-left")){var r=n.offset.left-l.offset().left;-i>r&&e.element.canExpandLeft(a)?e.$apply(function(){e.element.expandLeft(a)}):r>i&&e.element.canContractLeft(a)&&e.$apply(function(){e.element.contractLeft(a)})}else if($(o.target).hasClass("layout-column-resize-bar-right")){var r=n.offset.left-l.width()-l.offset().left;r>i&&e.element.canExpandRight(a)?e.$apply(function(){e.element.expandRight(a)}):-i>r&&e.element.canContractRight(a)&&e.$apply(function(){e.element.contractRight(a)})}},stop:function(t,o){e.$apply(function(){e.element.editor.isResizing=!1})}})}}}]),angular.module("LayoutEditor").directive("orcLayoutContent",["$sce","scopeConfigurator","environment",function(e,t,o){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(o,n){t.configureForElement(o,n),o.edit=function(){o.$root.editElement(o.element).then(function(e){o.$apply(function(){e.cancel||(o.element.data=e.element.data,o.element.setHtml(e.element.html))})})},o.element.setHtml=function(t){o.element.html=t,o.element.htmlUnsafe=e.trustAsHtml(t)},o.element.setHtml(o.element.html)}],templateUrl:o.templateUrl("Content"),replace:!0}}]),angular.module("LayoutEditor").directive("orcLayoutHtml",["$sce","scopeConfigurator","environment",function(e,t,o){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(o,n){t.configureForElement(o,n),o.edit=function(){o.$root.editElement(o.element).then(function(e){o.$apply(function(){e.cancel||(o.element.data=e.element.data,o.element.setHtml(e.element.html))})})},o.updateContent=function(e){o.element.setHtml(e.target.innerHTML)},o.element.setHtml=function(t){o.element.html=t,o.element.htmlUnsafe=e.trustAsHtml(t)},o.element.setHtml(o.element.html)}],templateUrl:o.templateUrl("Html"),replace:!0,link:function(e,t){t.find(".layout-content-markup").mousedown(function(t){e.element.editor.inlineEditingIsActive&&t.stopPropagation()})}}}]),angular.module("LayoutEditor").directive("orcLayoutGrid",["$compile","scopeConfigurator","environment",function(e,t,o){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(e,o){t.configureForElement(e,o),t.configureForContainer(e,o),e.sortableOptions.axis="y"}],templateUrl:o.templateUrl("Grid"),replace:!0}}]),angular.module("LayoutEditor").directive("orcLayoutRow",["$compile","scopeConfigurator","environment",function(e,t,o){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(e,o){t.configureForElement(e,o),t.configureForContainer(e,o),e.sortableOptions.axis="x",e.sortableOptions["ui-floating"]=!0}],templateUrl:o.templateUrl("Row"),replace:!0}}]),angular.module("LayoutEditor").directive("orcLayoutPopup",[function(){return{restrict:"A",link:function(e,t,o){var n=$(t),l=n.closest(".layout-popup-trigger"),i=n.closest(".layout-element");l.click(function(){n.toggle(),n.is(":visible")&&(n.position({my:o.orcLayoutPopupMy||"left top",at:o.orcLayoutPopupAt||"left bottom+4px",of:l}),n.find("input").first().focus())}),n.click(function(e){e.stopPropagation()}),i.click(function(e){n.hide()}),n.keydown(function(e){e.ctrlKey||e.shiftKey||e.altKey||27!=e.which||n.hide(),e.stopPropagation()}),n.on("cut copy paste",function(e){e.stopPropagation()})}}}]),angular.module("LayoutEditor").directive("orcLayoutToolbox",["$compile","environment",function(e,t){return{restrict:"E",controller:["$scope","$element",function(e,t){e.resetElements=function(){e.gridElements=[LayoutEditor.Grid.from({toolboxIcon:"",toolboxLabel:"Grid",toolboxDescription:"Empty grid.",children:[]})],e.rowElements=[LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (1 column)",toolboxDescription:"Row with 1 column.",children:LayoutEditor.Column.times(1)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (2 columns)",toolboxDescription:"Row with 2 columns.",children:LayoutEditor.Column.times(2)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (3 columns)",toolboxDescription:"Row with 3 columns.",children:LayoutEditor.Column.times(3)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (4 columns)",toolboxDescription:"Row with 4 columns.",children:LayoutEditor.Column.times(4)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (6 columns)",toolboxDescription:"Row with 6 columns.",children:LayoutEditor.Column.times(6)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (12 columns)",toolboxDescription:"Row with 12 columns.",children:LayoutEditor.Column.times(12)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (empty)",toolboxDescription:"Empty row.",children:[]})],e.columnElements=[LayoutEditor.Column.from({toolboxIcon:"",toolboxLabel:"Column",toolboxDescription:"Empty column.",width:1,offset:0,children:[]})],e.contentElementCategories=_(e.element.config.categories).map(function(e){return{name:e.name,elements:_(e.contentTypes).map(function(e){var t=e.type,o=LayoutEditor.factories[t]||LayoutEditor.factories.Content,n={isTemplated:!1,contentType:e.id,contentTypeLabel:e.label,contentTypeClass:e.typeClass,data:null,hasEditor:e.hasEditor,html:e.html},l=o(n);return l.toolboxIcon=e.icon||"",l.toolboxLabel=e.label,l.toolboxDescription=e.description,l})}})},e.resetElements(),e.getSortableOptions=function(o){var n,l,i=t.closest(".layout-editor").attr("id"),a=!1;switch(o){case"Grid":n=[".layout-canvas",".layout-column",".layout-common-holder"],l="layout-element layout-container layout-grid ui-sortable-placeholder";break;case"Row":n=[".layout-grid"],l="layout-element layout-container layout-row row ui-sortable-placeholder";break;case"Column":n=[".layout-row:not(.layout-row-full)"],l="layout-element layout-container layout-column ui-sortable-placeholder",a=!0;break;case"Content":n=[".layout-canvas",".layout-column",".layout-common-holder"],l="layout-element layout-content ui-sortable-placeholder"}return{cursor:"move",connectWith:_(n).map(function(e){return"#"+i+" "+e+":not(.layout-container-sealed) > .layout-element-wrapper > .layout-children"}).join(", "),placeholder:l,"ui-floating":a,create:function(e,t){e.target.isToolbox=!0},start:function(t,o){e.$apply(function(){e.element.isDragging=!0})},stop:function(t,o){e.$apply(function(){e.element.isDragging=!1,e.resetElements()})},over:function(t,o){e.$apply(function(){e.element.canvas.setIsDropTarget(!1)})}}};var o="layoutToolboxCategory_Layout_IsCollapsed";e.layoutIsCollapsed="true"===$.cookie(o),e.toggleLayoutIsCollapsed=function(t){e.layoutIsCollapsed=!e.layoutIsCollapsed,$.cookie(o,e.layoutIsCollapsed,{expires:365}),t.preventDefault(),t.stopPropagation()}}],templateUrl:t.templateUrl("Toolbox"),replace:!0,link:function(e,t){var o=t.find(".layout-toolbox");$(window).on("resize scroll",function(e){var n=t.parent().find(".layout-canvas"),l=!!n&&n.height()>o.height(),i=$(window).scrollTop();l&&i>t.offset().top+t.height()-o.height()?(o.addClass("sticky-bottom"),o.removeClass("sticky-top")):l&&i>t.offset().top?(o.addClass("sticky-top"),o.removeClass("sticky-bottom")):(o.removeClass("sticky-top"),o.removeClass("sticky-bottom"))})}}}]),angular.module("LayoutEditor").directive("orcLayoutToolboxGroup",["$compile","environment",function(e,t){return{restrict:"E",scope:{category:"="},controller:["$scope","$element",function(e,t){var o="layoutToolboxCategory_"+e.category.name+"_IsCollapsed";e.isCollapsed="true"===$.cookie(o),e.toggleIsCollapsed=function(t){e.isCollapsed=!e.isCollapsed,$.cookie(o,e.isCollapsed,{expires:365}),t.preventDefault(),t.stopPropagation()}}],templateUrl:t.templateUrl("ToolboxGroup"),replace:!0}}]); \ No newline at end of file +angular.module("LayoutEditor",["ngSanitize","ngResource","ui.sortable"]);var LayoutEditor;!function(e){var t=function(){var e=this;this._clipboardData={},this._isDisabled=!1,this._wasInvoked=!1,this.setData=function(t,o){e._clipboardData[t]=o,e._wasInvoked=!0},this.getData=function(t){return e._clipboardData[t]},this.disable=function(){e._isDisabled=!0,e._wasInvoked=!1,e._clipboardData={}},this.isDisabled=function(){return e._isDisabled},this.wasInvoked=function(){return e._wasInvoked}};e.Clipboard=new t,angular.module("LayoutEditor").factory("clipboard",[function(){return{setData:e.Clipboard.setData,getData:e.Clipboard.getData,disable:e.Clipboard.disable,isDisabled:e.Clipboard.isDisabled,wasInvoked:e.Clipboard.wasInvoked}}])}(LayoutEditor||(LayoutEditor={})),angular.module("LayoutEditor").factory("scopeConfigurator",["$timeout","clipboard",function(e,t){return{configureForElement:function(e,o){o.find(".layout-panel").click(function(e){e.stopPropagation()}),o.parent().keydown(function(n){var l=!1,a=!1,i=e.element;if(!i.editor.isDragging&&!i.editor.inlineEditingIsActive){if(!t.isDisabled()){var r=i.editor.focusedElement;if(r&&n.ctrlKey)switch(n.which){case 67:r.copy(t);break;case 88:r.cut(t);break;case 86:r.paste(t)}}if(n.ctrlKey||n.shiftKey||n.altKey||46!=n.which?n.ctrlKey||n.shiftKey||n.altKey||32!=n.which&&27!=n.which||(o.find(".layout-panel-action-properties").first().click(),l=!0):(e["delete"](i),l=!0),"Content"==i.type&&(n.ctrlKey||n.shiftKey||n.altKey||13!=n.which||(o.find(".layout-panel-action-edit").first().click(),l=!0)),i.children&&(n.ctrlKey||n.shiftKey||!n.altKey||40!=n.which||(i.children.length>0&&i.children[0].setIsFocused(),l=!0),"Column"==i.type)){var c=!n.ctrlKey;37==n.which?(n.altKey&&i.expandLeft(c),n.shiftKey&&i.contractRight(c),l=!0):39==n.which&&(n.altKey&&i.contractLeft(c),n.shiftKey&&i.expandRight(c),l=!0)}i.parent&&(n.altKey&&38==n.which&&(i.parent.setIsFocused(),l=!0),"Row"==i.parent.type?n.ctrlKey||n.shiftKey||n.altKey||37!=n.which?n.ctrlKey||n.shiftKey||n.altKey||39!=n.which?!n.ctrlKey||n.shiftKey||n.altKey||37!=n.which?!n.ctrlKey||n.shiftKey||n.altKey||39!=n.which||(i.moveDown(),l=!0):(i.moveUp(),a=!0,l=!0):(i.parent.moveFocusNextChild(i),l=!0):(i.parent.moveFocusPrevChild(i),l=!0):n.ctrlKey||n.shiftKey||n.altKey||38!=n.which?n.ctrlKey||n.shiftKey||n.altKey||40!=n.which?!n.ctrlKey||n.shiftKey||n.altKey||38!=n.which?!n.ctrlKey||n.shiftKey||n.altKey||40!=n.which||(i.moveDown(),l=!0):(i.moveUp(),a=!0,l=!0):(i.parent.moveFocusNextChild(i),l=!0):(i.parent.moveFocusPrevChild(i),l=!0)),l&&n.preventDefault(),n.stopPropagation(),e.$apply(),a&&window.setTimeout(function(){e.$apply(function(){i.editor.focusedElement.setIsFocused()})},100)}}),e.element.setIsFocusedEventHandlers.push(function(){o.parent().focus()}),e["delete"]=function(e){e["delete"]()}},configureForContainer:function(t,o){var n=t.element;t.getShowChildrenPlaceholder=function(){return 0===t.element.children.length&&!t.element.getIsDropTarget()},t.sortableOptions={cursor:"move",delay:150,disabled:n.getIsSealed(),distance:5,start:function(e,o){t.$apply(function(){n.setIsDropTarget(!0),n.editor.isDragging=!0}),o.placeholder.height(o.item.height()-4),o.placeholder.css("min-height",0)},stop:function(e,o){t.$apply(function(){n.editor.isDragging=!1,n.setIsDropTarget(!1)})},over:function(t,l){l.sender&&l.sender[0].isToolbox&&(l.sender[0].dropTargetTimeout&&(e.cancel(l.sender[0].dropTargetTimeout),l.sender[0].dropTargetTimeout=null),e(function(){if("Row"==n.type){var e=n.editor.dropTargetElement;e&&"Row"==e.type&&e.rollbackAddColumn()}n.setIsDropTarget(!1)}),l.sender[0].dropTargetTimeout=e(function(){if("Row"==n.type){var e=l.item.sortable.model,t=Math.floor(12/(n.children.length+1));e.width=t,e.offset=0,n.beginAddColumn(t);var a=_.max(_(o.find("> .layout-children > .layout-column:not(.ui-sortable-placeholder)")).map(function(e){return $(e).height()}));for(i=1;i<=12;i++)l.placeholder.removeClass("col-xs-"+i);l.placeholder.addClass("col-xs-"+e.width),a>0?(l.placeholder.height(a),l.placeholder.css("min-height",0)):(l.placeholder.height(0),l.placeholder.css("min-height",""))}n.setIsDropTarget(!0)},150))},receive:function(o,l){l.sender&&l.sender[0].isToolbox&&t.$apply(function(){var o=l.item.sortable.model;o&&("Row"==n.type&&n.commitAddColumn(),o.setEditor(n.editor),o.setParent(n),o.hasEditor&&t.$root.editElement(o).then(function(t){t.cancel||(o.data=t.element.data,o.setHtml&&o.setHtml(t.element.html)),e(function(){t.cancel?o["delete"]():o.setIsFocused(),n.setIsDropTarget(!1)})})),e(function(){n.setIsDropTarget(!1),o&&o.setIsFocused()})})}},t.click=function(e,t){e.editor.isDragging||e.setIsFocused(),t.stopPropagation()},t.getClasses=function(e){var t=["layout-element"];return e.children&&(t.push("layout-container"),e.getIsSealed()&&t.push("layout-container-sealed")),t.push("layout-"+e.type.toLowerCase()),e.dropTargetClass&&t.push(e.dropTargetClass),"Row"==e.type&&(t.push("row"),e.canAddColumn()||t.push("layout-row-full")),"Column"==e.type&&(t.push("col-xs-"+e.width),t.push("col-xs-offset-"+e.offset)),"Content"==e.type&&t.push("layout-content-"+e.contentTypeClass),e.getIsActive()&&t.push("layout-element-active"),e.getIsFocused()&&t.push("layout-element-focused"),e.getIsSelected()&&t.push("layout-element-selected"),e.getIsDropTarget()&&t.push("layout-element-droptarget"),e.isTemplated&&t.push("layout-element-templated"),t}}}}]),angular.module("LayoutEditor").directive("orcLayoutEditor",["environment",function(environment){return{restrict:"E",scope:{},controller:["$scope","$element","$attrs","$compile","clipboard",function($scope,$element,$attrs,$compile,clipboard){if(!$attrs.model)throw new Error("The 'model' attribute must evaluate to a LayoutEditor.Editor object.");$scope.element=eval($attrs.model),$scope.click=function(e,t){e.editor.isDragging||e.setIsFocused(),t.stopPropagation()},$scope.getClasses=function(e){var t=["layout-element","layout-container","layout-canvas"];return e.getIsActive()&&t.push("layout-element-active"),e.getIsFocused()&&t.push("layout-element-focused"),e.getIsSelected()&&t.push("layout-element-selected"),e.getIsDropTarget()&&t.push("layout-element-droptarget"),e.isTemplated&&t.push("layout-element-templated"),t};var layoutDesignerHost=$(".layout-designer").data("layout-designer-host");$scope.$root.layoutDesignerHost=layoutDesignerHost,layoutDesignerHost.element.on("replacecanvas",function(e,t){var o=$scope.element,n={data:t.canvas.data,htmlId:t.canvas.htmlId,htmlClass:t.canvas.htmlClass,htmlStyle:t.canvas.htmlStyle,isTemplated:t.canvas.isTemplated,children:t.canvas.children};layoutDesignerHost.editor=window.layoutEditor=new LayoutEditor.Editor(o.config,n);var l="",a=$compile(l)($scope);$(".layout-editor-holder").html(a)}),$scope.$root.editElement=function(e){var t=$scope.$root.layoutDesignerHost;return t.editElement(e)},$scope.$root.addElement=function(e){var t=$scope.$root.layoutDesignerHost;return t.addElement(e)},$scope.toggleInlineEditing=function(){if($scope.element.inlineEditingIsActive)tinymce.remove("#layout-editor-"+$scope.$id+" .layout-content-markup"),$element.find(".layout-toolbar-container").hide(),$scope.element.inlineEditingIsActive=!1;else{$scope.element.inlineEditingIsActive=!0,$element.find(".layout-toolbar-container").show();var e="#layout-editor-"+$scope.$id+" .layout-html .layout-content-markup[data-templated=false]",t=$(e).first().attr("id");tinymce.init({selector:e,theme:"modern",schema:"html5",plugins:["advlist autolink lists link image charmap print preview hr anchor pagebreak","searchreplace wordcount visualblocks visualchars code fullscreen","insertdatetime media nonbreaking table contextmenu directionality","emoticons template paste textcolor colorpicker textpattern","fullscreen autoresize"],toolbar:"undo redo cut copy paste | bold italic | bullist numlist outdent indent formatselect | alignleft aligncenter alignright alignjustify ltr rtl | link unlink charmap | code fullscreen close",convert_urls:!1,valid_elements:"*[*]",extended_valid_elements:"script[type|defer|src|language]",statusbar:!1,skin:"orchardlightgray",inline:!0,fixed_toolbar_container:"#layout-editor-"+$scope.$id+" .layout-toolbar-container",init_instance_callback:function(e){e.id==t&&tinymce.execCommand("mceFocus",!1,e.id)}})}},$(document).on("cut copy paste",function(e){if(clipboard.wasInvoked())e.originalEvent.clipboardData.setData("text/plain",clipboard.getData("text/plain")),e.originalEvent.clipboardData.setData("text/json",clipboard.getData("text/json")),e.preventDefault();else{var t=$scope.element.focusedElement;t&&($scope.$apply(function(){switch(e.type){case"copy":t.copy(e.originalEvent.clipboardData);break;case"cut":t.cut(e.originalEvent.clipboardData);break;case"paste":t.paste(e.originalEvent.clipboardData)}}),window.setTimeout(function(){$scope.$apply(function(){$scope.element.focusedElement&&$scope.element.focusedElement.setIsFocused()})},100),e.preventDefault())}clipboard.disable()})}],templateUrl:environment.templateUrl("Editor"),replace:!0,link:function(e,t){t.find(".layout-toolbar-container").click(function(e){e.stopPropagation()}),t.mousedown(function(t){e.element.inlineEditingIsActive&&(t.preventDefault(),t.stopPropagation())}),$(window).click(function(t){e.element.inlineEditingIsActive||e.$apply(function(){e.element.activeElement=null,e.element.focusedElement=null})})}}}]),angular.module("LayoutEditor").directive("orcLayoutCanvas",["scopeConfigurator","environment",function(e,t){return{restrict:"E",scope:{element:"="},controller:["$scope","$element","$attrs",function(t,o,n){e.configureForElement(t,o),e.configureForContainer(t,o),t.sortableOptions.axis="y"}],templateUrl:t.templateUrl("Canvas"),replace:!0}}]),angular.module("LayoutEditor").directive("orcLayoutChild",["$compile",function(e){return{restrict:"E",scope:{element:"="},link:function(t,o){var n="",l=e(n)(t);$(o).replaceWith(l)}}}]),angular.module("LayoutEditor").directive("orcLayoutColumn",["$compile","scopeConfigurator","environment",function(e,t,o){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(e,o){t.configureForElement(e,o),t.configureForContainer(e,o),e.sortableOptions.axis="y"}],templateUrl:o.templateUrl("Column"),replace:!0,link:function(e,t,o){t.find(".layout-column-resize-bar").draggable({axis:"x",helper:"clone",revert:!0,start:function(t,o){e.$apply(function(){e.element.editor.isResizing=!0})},drag:function(o,n){var l=t.parent(),a=l.width()/e.element.width,i=!o.ctrlKey;if($(o.target).hasClass("layout-column-resize-bar-left")){var r=n.offset.left-l.offset().left;-a>r&&e.element.canExpandLeft(i)?e.$apply(function(){e.element.expandLeft(i)}):r>a&&e.element.canContractLeft(i)&&e.$apply(function(){e.element.contractLeft(i)})}else if($(o.target).hasClass("layout-column-resize-bar-right")){var r=n.offset.left-l.width()-l.offset().left;r>a&&e.element.canExpandRight(i)?e.$apply(function(){e.element.expandRight(i)}):-a>r&&e.element.canContractRight(i)&&e.$apply(function(){e.element.contractRight(i)})}},stop:function(t,o){e.$apply(function(){e.element.editor.isResizing=!1})}})}}}]),angular.module("LayoutEditor").directive("orcLayoutContent",["$sce","scopeConfigurator","environment",function(e,t,o){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(o,n){t.configureForElement(o,n),o.edit=function(){o.$root.editElement(o.element).then(function(e){o.$apply(function(){e.cancel||(o.element.data=e.element.data,o.element.setHtml(e.element.html))})})},o.element.setHtml=function(t){o.element.html=t,o.element.htmlUnsafe=e.trustAsHtml(t)},o.element.setHtml(o.element.html)}],templateUrl:o.templateUrl("Content"),replace:!0}}]),angular.module("LayoutEditor").directive("orcLayoutHtml",["$sce","scopeConfigurator","environment",function(e,t,o){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(o,n){t.configureForElement(o,n),o.edit=function(){o.$root.editElement(o.element).then(function(e){o.$apply(function(){e.cancel||(o.element.data=e.element.data,o.element.setHtml(e.element.html))})})},o.updateContent=function(e){o.element.setHtml(e.target.innerHTML)},o.element.setHtml=function(t){o.element.html=t,o.element.htmlUnsafe=e.trustAsHtml(t)},o.element.setHtml(o.element.html)}],templateUrl:o.templateUrl("Html"),replace:!0,link:function(e,t){t.find(".layout-content-markup").mousedown(function(t){e.element.editor.inlineEditingIsActive&&t.stopPropagation()})}}}]),angular.module("LayoutEditor").directive("orcLayoutGrid",["$compile","scopeConfigurator","environment",function(e,t,o){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(e,o){t.configureForElement(e,o),t.configureForContainer(e,o),e.sortableOptions.axis="y"}],templateUrl:o.templateUrl("Grid"),replace:!0}}]),angular.module("LayoutEditor").directive("orcLayoutRow",["$compile","scopeConfigurator","environment",function(e,t,o){return{restrict:"E",scope:{element:"="},controller:["$scope","$element",function(e,o){t.configureForElement(e,o),t.configureForContainer(e,o),e.sortableOptions.axis="x",e.sortableOptions["ui-floating"]=!0}],templateUrl:o.templateUrl("Row"),replace:!0}}]),angular.module("LayoutEditor").directive("orcLayoutPopup",[function(){return{restrict:"A",link:function(e,t,o){var n=$(t),l=n.closest(".layout-popup-trigger"),a=n.closest(".layout-element");l.click(function(){n.toggle(),n.is(":visible")&&(n.position({my:o.orcLayoutPopupMy||"left top",at:o.orcLayoutPopupAt||"left bottom+4px",of:l}),n.find("input").first().focus())}),n.click(function(e){e.stopPropagation()}),a.click(function(e){n.hide()}),n.keydown(function(e){e.ctrlKey||e.shiftKey||e.altKey||27!=e.which||n.hide(),e.stopPropagation()}),n.on("cut copy paste",function(e){e.stopPropagation()})}}}]),angular.module("LayoutEditor").directive("orcLayoutToolbox",["$compile","environment",function(e,t){return{restrict:"E",controller:["$scope","$element",function(e,t){e.resetElements=function(){e.gridElements=[LayoutEditor.Grid.from({toolboxIcon:"",toolboxLabel:"Grid",toolboxDescription:"Empty grid.",children:[]})],e.rowElements=[LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (1 column)",toolboxDescription:"Row with 1 column.",children:LayoutEditor.Column.times(1)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (2 columns)",toolboxDescription:"Row with 2 columns.",children:LayoutEditor.Column.times(2)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (3 columns)",toolboxDescription:"Row with 3 columns.",children:LayoutEditor.Column.times(3)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (4 columns)",toolboxDescription:"Row with 4 columns.",children:LayoutEditor.Column.times(4)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (6 columns)",toolboxDescription:"Row with 6 columns.",children:LayoutEditor.Column.times(6)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (12 columns)",toolboxDescription:"Row with 12 columns.",children:LayoutEditor.Column.times(12)}),LayoutEditor.Row.from({toolboxIcon:"",toolboxLabel:"Row (empty)",toolboxDescription:"Empty row.",children:[]})],e.columnElements=[LayoutEditor.Column.from({toolboxIcon:"",toolboxLabel:"Column",toolboxDescription:"Empty column.",width:1,offset:0,children:[]})],e.canvasElements=[LayoutEditor.Canvas.from({toolboxIcon:"",toolboxLabel:"Canvas",toolboxDescription:"Empty canvas.",children:[]})],e.contentElementCategories=_(e.element.config.categories).map(function(e){return{name:e.name,elements:_(e.contentTypes).map(function(e){var t=e.type,o=LayoutEditor.factories[t]||LayoutEditor.factories.Content,n={isTemplated:!1,contentType:e.id,contentTypeLabel:e.label,contentTypeClass:e.typeClass,data:null,hasEditor:e.hasEditor,html:e.html},l=o(n);return l.toolboxIcon=e.icon||"",l.toolboxLabel=e.label,l.toolboxDescription=e.description,l})}})},e.resetElements(),e.getSortableOptions=function(o){var n,l,a=t.closest(".layout-editor").attr("id"),i=!1;switch(o){case"Grid":n=[".layout-canvas",".layout-column",".layout-common-holder"],l="layout-element layout-container layout-grid ui-sortable-placeholder";break;case"Row":n=[".layout-grid"],l="layout-element layout-container layout-row row ui-sortable-placeholder";break;case"Column":n=[".layout-row:not(.layout-row-full)"],l="layout-element layout-container layout-column ui-sortable-placeholder",i=!0;break;case"Content":n=[".layout-canvas",".layout-column",".layout-common-holder"],l="layout-element layout-content ui-sortable-placeholder";break;case"Canvas":n=[".layout-canvas",".layout-column",".layout-common-holder"],l="layout-element layout-container layout-grid ui-sortable-placeholder"}return{cursor:"move",connectWith:_(n).map(function(e){return"#"+a+" "+e+":not(.layout-container-sealed) > .layout-element-wrapper > .layout-children"}).join(", "),placeholder:l,"ui-floating":i,create:function(e,t){e.target.isToolbox=!0},start:function(t,o){e.$apply(function(){e.element.isDragging=!0})},stop:function(t,o){e.$apply(function(){e.element.isDragging=!1,e.resetElements()})},over:function(t,o){e.$apply(function(){e.element.canvas.setIsDropTarget(!1)})}}};var o="layoutToolboxCategory_Layout_IsCollapsed";e.layoutIsCollapsed="true"===$.cookie(o),e.toggleLayoutIsCollapsed=function(t){e.layoutIsCollapsed=!e.layoutIsCollapsed,$.cookie(o,e.layoutIsCollapsed,{expires:365}),t.preventDefault(),t.stopPropagation()}}],templateUrl:t.templateUrl("Toolbox"),replace:!0,link:function(e,t){var o=t.find(".layout-toolbox");$(window).on("resize scroll",function(e){var n=t.parent().find(".layout-canvas"),l=!!n&&n.height()>o.height(),a=$(window).scrollTop();l&&a>t.offset().top+t.height()-o.height()?(o.addClass("sticky-bottom"),o.removeClass("sticky-top")):l&&a>t.offset().top?(o.addClass("sticky-top"),o.removeClass("sticky-bottom")):(o.removeClass("sticky-top"),o.removeClass("sticky-bottom"))})}}}]),angular.module("LayoutEditor").directive("orcLayoutToolboxGroup",["$compile","environment",function(e,t){return{restrict:"E",scope:{category:"="},controller:["$scope","$element",function(e,t){var o="layoutToolboxCategory_"+e.category.name+"_IsCollapsed";e.isCollapsed="true"===$.cookie(o),e.toggleIsCollapsed=function(t){e.isCollapsed=!e.isCollapsed,$.cookie(o,e.isCollapsed,{expires:365}),t.preventDefault(),t.stopPropagation()}}],templateUrl:t.templateUrl("ToolboxGroup"),replace:!0}}]); \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor/Directives/Editor.js b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor/Directives/Editor.js index 43207591e..8595615e8 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor/Directives/Editor.js +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor/Directives/Editor.js @@ -114,34 +114,46 @@ }; $(document).on("cut copy paste", function (e) { - // The real clipboard is supported, so disable the peudo clipboard. - clipboard.disable(); - var focusedElement = $scope.element.focusedElement; - if (!!focusedElement) { - $scope.$apply(function () { - switch (e.type) { - case "copy": - focusedElement.copy(e.originalEvent.clipboardData); - break; - case "cut": - focusedElement.cut(e.originalEvent.clipboardData); - break; - case "paste": - focusedElement.paste(e.originalEvent.clipboardData); - break; - } - }); - - // HACK: Workaround because of how Angular treats the DOM when elements are shifted around - input focus is sometimes lost. - window.setTimeout(function () { - $scope.$apply(function () { - if (!!$scope.element.focusedElement) - $scope.element.focusedElement.setIsFocused(); - }); - }, 100); - + // If the pseudo clipboard was already invoked (which happens on the first clipboard + // operation after page load even if native clipboard support exists) then sit this + // one operation out, but make sure whatever is on the pseudo clipboard gets migrated + // to the native clipboard for subsequent operations. + if (clipboard.wasInvoked()) { + e.originalEvent.clipboardData.setData("text/plain", clipboard.getData("text/plain")); + e.originalEvent.clipboardData.setData("text/json", clipboard.getData("text/json")); e.preventDefault(); } + else { + var focusedElement = $scope.element.focusedElement; + if (!!focusedElement) { + $scope.$apply(function () { + switch (e.type) { + case "copy": + focusedElement.copy(e.originalEvent.clipboardData); + break; + case "cut": + focusedElement.cut(e.originalEvent.clipboardData); + break; + case "paste": + focusedElement.paste(e.originalEvent.clipboardData); + break; + } + }); + + // HACK: Workaround because of how Angular treats the DOM when elements are shifted around - input focus is sometimes lost. + window.setTimeout(function () { + $scope.$apply(function () { + if (!!$scope.element.focusedElement) + $scope.element.focusedElement.setIsFocused(); + }); + }, 100); + + e.preventDefault(); + } + } + + // Native clipboard support obviously exists, so disable the peudo clipboard from now on. + clipboard.disable(); }); } ], diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor/Services/Clipboard.js b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor/Services/Clipboard.js index b0be0d474..013672249 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor/Services/Clipboard.js +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor/Services/Clipboard.js @@ -3,17 +3,29 @@ var Clipboard = function () { var self = this; - this.clipboardData = {}; - this.setData = function(contentType, data, realClipBoard) { - self.clipboardData[contentType] = data; - }; - this.getData = function (contentType, realClipBoard) { - return self.clipboardData[contentType]; - }; + this._clipboardData = {}; + this._isDisabled = false; + this._wasInvoked = false; - this.disable = function() { - this.disabled = true; + this.setData = function(contentType, data) { + self._clipboardData[contentType] = data; + self._wasInvoked = true; }; + this.getData = function (contentType) { + return self._clipboardData[contentType]; + self._wasInvoked = true; + }; + this.disable = function() { + self._isDisabled = true; + self._wasInvoked = false; + self._clipboardData = {}; + }; + this.isDisabled = function () { + return self._isDisabled; + } + this.wasInvoked = function () { + return self._wasInvoked; + } } LayoutEditor.Clipboard = new Clipboard(); @@ -25,7 +37,9 @@ return { setData: LayoutEditor.Clipboard.setData, getData: LayoutEditor.Clipboard.getData, - disable: LayoutEditor.Clipboard.disable + disable: LayoutEditor.Clipboard.disable, + isDisabled: LayoutEditor.Clipboard.isDisabled, + wasInvoked: LayoutEditor.Clipboard.wasInvoked }; } ]); diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor/Services/ScopeConfigurator.js b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor/Services/ScopeConfigurator.js index a6b450e32..d7da1feb8 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor/Services/ScopeConfigurator.js +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/LayoutEditor/Services/ScopeConfigurator.js @@ -15,12 +15,11 @@ var resetFocus = false; var element = $scope.element; - if (element.editor.isDragging || element.editor.inlineEditingIsActive) return; - // If the "real" clipboard works, then the pseudo-clipboard will have been disabled. - if (!clipboard.disabled) { + // If native clipboard support exists, the pseudo-clipboard will have been disabled. + if (!clipboard.isDisabled()) { var focusedElement = element.editor.focusedElement; if (!!focusedElement) { // Pseudo clipboard handling for browsers not allowing real clipboard operations. diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models.js b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models.js index 992e39743..f80f8c550 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models.js +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models.js @@ -243,7 +243,6 @@ var LayoutEditor; this.copy = function (clipboardData) { var text = this.getInnerText(); clipboardData.setData("text/plain", text); - console.log(text); var data = this.toObject(); var json = JSON.stringify(data, null, "\t"); @@ -1021,4 +1020,4 @@ var LayoutEditor; LayoutEditor.registerFactory("Html", function(value) { return LayoutEditor.Html.from(value); }); })(jQuery, LayoutEditor || (LayoutEditor = {})); -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["Helpers.js","Editor.js","Element.js","Container.js","Canvas.js","Grid.js","Row.js","Column.js","Content.js","Html.js"],"names":[],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACzCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AChCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACjLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACpIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC5RA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACvIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACzDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"Models.js","sourcesContent":["var LayoutEditor;\n(function (LayoutEditor) {\n\n    Array.prototype.move = function (from, to) {\n        this.splice(to, 0, this.splice(from, 1)[0]);\n    };\n\n    LayoutEditor.childrenFrom = function(values) {\n        return _(values).map(function(value) {\n            return LayoutEditor.elementFrom(value);\n        });\n    };\n\n    var registerFactory = LayoutEditor.registerFactory = function(type, factory) {\n        var factories = LayoutEditor.factories = LayoutEditor.factories || {};\n        factories[type] = factory;\n    };\n\n    registerFactory(\"Grid\", function(value) { return LayoutEditor.Grid.from(value); });\n    registerFactory(\"Row\", function(value) { return LayoutEditor.Row.from(value); });\n    registerFactory(\"Column\", function(value) { return LayoutEditor.Column.from(value); });\n    registerFactory(\"Content\", function(value) { return LayoutEditor.Content.from(value); });\n\n    LayoutEditor.elementFrom = function (value) {\n        var factory = LayoutEditor.factories[value.type];\n\n        if (!factory)\n            throw new Error(\"No element with type \\\"\" + value.type + \"\\\" was found.\");\n\n        var element = factory(value);\n        return element;\n    };\n\n    LayoutEditor.setModel = function (elementSelector, model) {\n        $(elementSelector).scope().element = model;\n    };\n\n    LayoutEditor.getModel = function (elementSelector) {\n        return $(elementSelector).scope().element;\n    };\n\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\n(function (LayoutEditor) {\n\n    LayoutEditor.Editor = function (config, canvasData) {\n        this.config = config;\n        this.canvas = LayoutEditor.Canvas.from(canvasData);\n        this.initialState = JSON.stringify(this.canvas.toObject());\n        this.activeElement = null;\n        this.focusedElement = null;\n        this.dropTargetElement = null;\n        this.isDragging = false;\n        this.inlineEditingIsActive = false;\n        this.isResizing = false;\n\n        this.resetToolboxElements = function () {\n            this.toolboxElements = [\n                LayoutEditor.Row.from({\n                    children: []\n                })\n            ];\n        };\n\n        this.isDirty = function() {\n            var currentState = JSON.stringify(this.canvas.toObject());\n            return this.initialState != currentState;\n        };\n\n        this.resetToolboxElements();\n        this.canvas.setEditor(this);\n    };\n\n})(LayoutEditor || (LayoutEditor = {}));\n","var LayoutEditor;\n(function (LayoutEditor) {\n\n    LayoutEditor.Element = function (type, data, htmlId, htmlClass, htmlStyle, isTemplated) {\n        if (!type)\n            throw new Error(\"Parameter 'type' is required.\");\n\n        this.type = type;\n        this.data = data;\n        this.htmlId = htmlId;\n        this.htmlClass = htmlClass;\n        this.htmlStyle = htmlStyle;\n        this.isTemplated = isTemplated;\n\n        this.editor = null;\n        this.parent = null;\n        this.setIsFocusedEventHandlers = [];\n\n        this.setEditor = function (editor) {\n            this.editor = editor;\n            if (!!this.children && _.isArray(this.children)) {\n                _(this.children).each(function (child) {\n                    child.setEditor(editor);\n                });\n            }\n        };\n\n        this.setParent = function(parentElement) {\n            this.parent = parentElement;\n\n            if (!!this.parent.linkChild)\n                this.parent.linkChild(this);\n        };\n\n        this.setIsTemplated = function (value) {\n            this.isTemplated = value;\n            if (!!this.children && _.isArray(this.children)) {\n                _(this.children).each(function (child) {\n                    child.setIsTemplated(value);\n                });\n            }\n        };\n\n        this.getIsActive = function () {\n            if (!this.editor)\n                return false;\n            return this.editor.activeElement === this && !this.getIsFocused();\n        };\n\n        this.setIsActive = function (value) {\n            if (!this.editor)\n                return;\n            if (this.editor.isDragging || this.editor.inlineEditingIsActive || this.editor.isResizing)\n                return;\n\n            if (value)\n                this.editor.activeElement = this;\n            else\n                this.editor.activeElement = this.parent;\n        };\n\n        this.getIsFocused = function () {\n            if (!this.editor)\n                return false;\n            return this.editor.focusedElement === this;\n        };\n\n        this.setIsFocused = function () {\n            if (!this.editor)\n            \treturn;\n            if (this.isTemplated)\n            \treturn;\n            if (this.editor.isDragging || this.editor.inlineEditingIsActive || this.editor.isResizing)\n                return;\n\n            this.editor.focusedElement = this;\n            _(this.setIsFocusedEventHandlers).each(function (item) {\n                try {\n                    item();\n                }\n                catch (ex) {\n                    // Ignore.\n                }\n            });\n        };\n\n        this.getIsSelected = function () {\n            if (this.getIsFocused())\n                return true;\n\n            if (!!this.children && _.isArray(this.children)) {\n                return _(this.children).any(function(child) {\n                    return child.getIsSelected();\n                });\n            }\n\n            return false;\n        };\n\n        this.getIsDropTarget = function () {\n            if (!this.editor)\n                return false;\n            return this.editor.dropTargetElement === this;\n        }\n\n        this.setIsDropTarget = function (value) {\n            if (!this.editor)\n                return;\n            if (value)\n                this.editor.dropTargetElement = this;\n            else\n                this.editor.dropTargetElement = null;\n        };\n\n        this.delete = function () {\n            if (!!this.parent)\n                this.parent.deleteChild(this);\n        };\n\n        this.canMoveUp = function () {\n            if (!this.parent)\n                return false;\n            return this.parent.canMoveChildUp(this);\n        };\n\n        this.moveUp = function () {\n            if (!!this.parent)\n                this.parent.moveChildUp(this);\n        };\n\n        this.canMoveDown = function () {\n            if (!this.parent)\n                return false;\n            return this.parent.canMoveChildDown(this);\n        };\n\n        this.moveDown = function () {\n            if (!!this.parent)\n                this.parent.moveChildDown(this);\n        };\n\n        this.elementToObject = function () {\n            return {\n                type: this.type,\n                data: this.data,\n                htmlId: this.htmlId,\n                htmlClass: this.htmlClass,\n                htmlStyle: this.htmlStyle,\n                isTemplated: this.isTemplated\n            };\n        };\n\n        this.getEditorObject = function() {\n            return {};\n        };\n\n        this.copy = function (clipboardData) {\n            var text = this.getInnerText();\n            clipboardData.setData(\"text/plain\", text);\n            console.log(text);\n\n            var data = this.toObject();\n            var json = JSON.stringify(data, null, \"\\t\");\n            clipboardData.setData(\"text/json\", json);\n        };\n\n        this.cut = function (clipboardData) {\n            this.copy(clipboardData);\n            this.delete();\n        };\n\n        this.paste = function (clipboardData) {\n            if (!!this.parent)\n                this.parent.paste(clipboardData);\n        };\n    };\n\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\n(function (LayoutEditor) {\n\n    LayoutEditor.Container = function (allowedChildTypes, children) {\n\n        this.allowedChildTypes = allowedChildTypes;\n        this.children = children;\n        this.isContainer = true;\n\n        var _self = this;\n\n        this.setChildren = function (children) {\n            this.children = children;\n            _(this.children).each(function (child) {\n                child.parent = _self;\n            });\n        };\n\n        this.setChildren(children);\n\n        this.getIsSealed = function () {\n            return _(this.children).any(function (child) {\n                return child.isTemplated;\n            });\n        };\n\n        this.addChild = function (child) {\n            if (!_(this.children).contains(child) && (_(this.allowedChildTypes).contains(child.type) || child.isContainable))\n                this.children.push(child);\n            child.setEditor(this.editor);\n            child.setIsTemplated(false);\n            child.parent = this;\n        };\n\n        this.deleteChild = function (child) {\n            var index = _(this.children).indexOf(child);\n            if (index >= 0) {\n                this.children.splice(index, 1);\n                if (child.getIsActive())\n                    this.editor.activeElement = null;\n                if (child.getIsFocused()) {\n                    // If the deleted child was focused, try to set new focus to the most appropriate sibling or parent.\n                    if (this.children.length > index)\n                        this.children[index].setIsFocused();\n                    else if (index > 0)\n                        this.children[index - 1].setIsFocused();\n                    else\n                        this.setIsFocused();\n                }\n            }\n        };\n\n        this.moveFocusPrevChild = function (child) {\n            if (this.children.length < 2)\n                return;\n            var index = _(this.children).indexOf(child);\n            if (index > 0)\n                this.children[index - 1].setIsFocused();\n        };\n\n        this.moveFocusNextChild = function (child) {\n            if (this.children.length < 2)\n                return;\n            var index = _(this.children).indexOf(child);\n            if (index < this.children.length - 1)\n                this.children[index + 1].setIsFocused();\n        };\n\n        this.insertChild = function (child, afterChild) {\n            if (!_(this.children).contains(child)) {\n                var index = Math.max(_(this.children).indexOf(afterChild), 0);\n                this.children.splice(index + 1, 0, child);\n                child.setEditor(this.editor);\n                child.parent = this;\n            }\n        };\n\n        this.moveChildUp = function (child) {\n            if (!this.canMoveChildUp(child))\n                return;\n            var index = _(this.children).indexOf(child);\n            this.children.move(index, index - 1);\n        };\n\n        this.moveChildDown = function (child) {\n            if (!this.canMoveChildDown(child))\n                return;\n            var index = _(this.children).indexOf(child);\n            this.children.move(index, index + 1);\n        };\n\n        this.canMoveChildUp = function (child) {\n            var index = _(this.children).indexOf(child);\n            return index > 0;\n        };\n\n        this.canMoveChildDown = function (child) {\n            var index = _(this.children).indexOf(child);\n            return index < this.children.length - 1;\n        };\n\n        this.childrenToObject = function () {\n            return _(this.children).map(function (child) {\n                return child.toObject();\n            });\n        };\n\n        this.getInnerText = function () {\n            return _(this.children).reduce(function (memo, child) {\n                return memo + \"\\n\" + child.getInnerText();\n            }, \"\");\n        }\n\n        this.paste = function (clipboardData) {\n            var json = clipboardData.getData(\"text/json\");\n            if (!!json) {\n                var data = JSON.parse(json);\n                var child = LayoutEditor.elementFrom(data);\n                this.pasteChild(child);\n            }\n        };\n\n        this.pasteChild = function (child) {\n            if (_(this.allowedChildTypes).contains(child.type) || child.isContainable) {\n                this.addChild(child);\n                child.setIsFocused();\n            }\n            else if (!!this.parent)\n                this.parent.pasteChild(child);\n        }\n    };\n\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\n(function (LayoutEditor) {\n\n    LayoutEditor.Canvas = function (data, htmlId, htmlClass, htmlStyle, isTemplated, children) {\n        LayoutEditor.Element.call(this, \"Canvas\", data, htmlId, htmlClass, htmlStyle, isTemplated);\n        LayoutEditor.Container.call(this, [\"Grid\", \"Content\"], children);\n\n        this.toObject = function () {\n            var result = this.elementToObject();\n            result.children = this.childrenToObject();\n            return result;\n        };\n    };\n\n    LayoutEditor.Canvas.from = function (value) {\n        return new LayoutEditor.Canvas(\n            value.data,\n            value.htmlId,\n            value.htmlClass,\n            value.htmlStyle,\n            value.isTemplated,\n            LayoutEditor.childrenFrom(value.children));\n    };\n\n})(LayoutEditor || (LayoutEditor = {}));\n","var LayoutEditor;\n(function (LayoutEditor) {\n\n    LayoutEditor.Grid = function (data, htmlId, htmlClass, htmlStyle, isTemplated, children) {\n        LayoutEditor.Element.call(this, \"Grid\", data, htmlId, htmlClass, htmlStyle, isTemplated);\n        LayoutEditor.Container.call(this, [\"Row\"], children);\n\n        this.toObject = function () {\n            var result = this.elementToObject();\n            result.children = this.childrenToObject();\n            return result;\n        };\n    };\n\n    LayoutEditor.Grid.from = function (value) {\n        var result = new LayoutEditor.Grid(\n            value.data,\n            value.htmlId,\n            value.htmlClass,\n            value.htmlStyle,\n            value.isTemplated,\n            LayoutEditor.childrenFrom(value.children));\n        result.toolboxIcon = value.toolboxIcon;\n        result.toolboxLabel = value.toolboxLabel;\n        result.toolboxDescription = value.toolboxDescription;\n        return result;\n    };\n\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\n(function (LayoutEditor) {\n\n    LayoutEditor.Row = function (data, htmlId, htmlClass, htmlStyle, isTemplated, children) {\n        LayoutEditor.Element.call(this, \"Row\", data, htmlId, htmlClass, htmlStyle, isTemplated);\n        LayoutEditor.Container.call(this, [\"Column\"], children);\n\n        var _self = this;\n\n        function _getTotalColumnsWidth() {\n            return _(_self.children).reduce(function (memo, child) {\n                return memo + child.offset + child.width;\n            }, 0);\n        }\n\n        // Implements a simple algorithm to distribute space (either positive or negative)\n        // between the child columns of the row. Negative space is distributed when making\n        // room for a new column (e.c. clipboard paste or dropping from the toolbox) while\n        // positive space is distributed when filling the grap of a removed column.\n        function _distributeSpace(space) {\n            if (space == 0)\n                return true;\n             \n            var undistributedSpace = space;\n\n            if (undistributedSpace < 0) {\n                var vacantSpace = 12 - _getTotalColumnsWidth();\n                undistributedSpace += vacantSpace;\n                if (undistributedSpace > 0)\n                    undistributedSpace = 0;\n            }\n\n            // If space is negative, try to decrease offsets first.\n            while (undistributedSpace < 0 && _(_self.children).any(function (column) { return column.offset > 0; })) { // While there is still offset left to remove.\n                for (i = 0; i < _self.children.length && undistributedSpace < 0; i++) {\n                    var column = _self.children[i];\n                    if (column.offset > 0) {\n                        column.offset--;\n                        undistributedSpace++;\n                    }\n                }\n            }\n\n            function hasWidth(column) {\n                if (undistributedSpace > 0)\n                    return column.width < 12;\n                else if (undistributedSpace < 0)\n                    return column.width > 1;\n                return false;\n            }\n\n            // Try to distribute remaining space (could be negative or positive) using widths.\n            while (undistributedSpace != 0) {\n                // Any more column width available for distribution?\n                if (!_(_self.children).any(hasWidth))\n                    break;\n                for (i = 0; i < _self.children.length && undistributedSpace != 0; i++) {\n                    var column = _self.children[i % _self.children.length];\n                    if (hasWidth(column)) {\n                        var delta = undistributedSpace / Math.abs(undistributedSpace);\n                        column.width += delta;\n                        undistributedSpace -= delta;\n                    }\n                }                \n            }\n\n            return undistributedSpace == 0;\n        }\n\n        var _isAddingColumn = false;\n\n        this.canAddColumn = function () {\n            return this.children.length < 12;\n        };\n\n        this.beginAddColumn = function (newColumnWidth) {\n            if (!!_isAddingColumn)\n                throw new Error(\"Column add operation is already in progress.\")\n            _(this.children).each(function (column) {\n                column.beginChange();\n            });\n            if (_distributeSpace(-newColumnWidth)) {\n                _isAddingColumn = true;\n                return true;\n            }\n            _(this.children).each(function (column) {\n                column.rollbackChange();\n            });\n            return false;\n        };\n\n        this.commitAddColumn = function () {\n            if (!_isAddingColumn)\n                throw new Error(\"No column add operation in progress.\")\n            _(this.children).each(function (column) {\n                column.commitChange();\n            });\n            _isAddingColumn = false;\n        };\n\n        this.rollbackAddColumn = function () {\n            if (!_isAddingColumn)\n                throw new Error(\"No column add operation in progress.\")\n            _(this.children).each(function (column) {\n                column.rollbackChange();\n            });\n            _isAddingColumn = false;\n        };\n\n        var _baseDeleteChild = this.deleteChild;\n        this.deleteChild = function (column) { \n            var width = column.width;\n            _baseDeleteChild.call(this, column);\n            _distributeSpace(width);\n        };\n\n        this.canContractColumnRight = function (column, connectAdjacent) {\n            var index = _(this.children).indexOf(column);\n            if (index >= 0)\n                return column.width > 1;\n            return false;\n        };\n\n        this.contractColumnRight = function (column, connectAdjacent) {\n            if (!this.canContractColumnRight(column, connectAdjacent))\n                return;\n\n            var index = _(this.children).indexOf(column);\n            if (index >= 0) {\n                if (column.width > 1) {\n                    column.width--;\n                    if (this.children.length > index + 1) {\n                        var nextColumn = this.children[index + 1];\n                        if (connectAdjacent && nextColumn.offset == 0)\n                            nextColumn.width++;\n                        else\n                            nextColumn.offset++;\n                    }\n                }\n            }\n        };\n\n        this.canExpandColumnRight = function (column, connectAdjacent) {\n            var index = _(this.children).indexOf(column);\n            if (index >= 0) {\n                if (column.width >= 12)\n                    return false;\n                if (this.children.length > index + 1) {\n                    var nextColumn = this.children[index + 1];\n                    if (connectAdjacent && nextColumn.offset == 0)\n                        return nextColumn.width > 1;\n                    else\n                        return nextColumn.offset > 0;\n                }\n                return _getTotalColumnsWidth() < 12;\n            }\n            return false;\n        };\n\n        this.expandColumnRight = function (column, connectAdjacent) {\n            if (!this.canExpandColumnRight(column, connectAdjacent))\n                return;\n\n            var index = _(this.children).indexOf(column);\n            if (index >= 0) {\n                if (this.children.length > index + 1) {\n                    var nextColumn = this.children[index + 1];\n                    if (connectAdjacent && nextColumn.offset == 0)\n                        nextColumn.width--;\n                    else\n                        nextColumn.offset--;\n                }\n                column.width++;\n            }\n        };\n\n        this.canExpandColumnLeft = function (column, connectAdjacent) {\n            var index = _(this.children).indexOf(column);\n            if (index >= 0) {\n                if (column.width >= 12)\n                    return false;\n                if (index > 0) {\n                    var prevColumn = this.children[index - 1];\n                    if (connectAdjacent && column.offset == 0)\n                        return prevColumn.width > 1;\n                }\n                return column.offset > 0;\n            }\n            return false;\n        };\n\n        this.expandColumnLeft = function (column, connectAdjacent) {\n            if (!this.canExpandColumnLeft(column, connectAdjacent))\n                return;\n\n            var index = _(this.children).indexOf(column);\n            if (index >= 0) {\n                if (index > 0) {\n                    var prevColumn = this.children[index - 1];\n                    if (connectAdjacent && column.offset == 0)\n                        prevColumn.width--;\n                    else\n                        column.offset--;\n                }\n                else\n                    column.offset--;\n                column.width++;\n            }\n        };\n\n        this.canContractColumnLeft = function (column, connectAdjacent) {\n            var index = _(this.children).indexOf(column);\n            if (index >= 0)\n                return column.width > 1;\n            return false;\n        };\n\n        this.contractColumnLeft = function (column, connectAdjacent) {\n            if (!this.canContractColumnLeft(column, connectAdjacent))\n                return;\n\n            var index = _(this.children).indexOf(column);\n            if (index >= 0) {\n                if (index > 0) {\n                    var prevColumn = this.children[index - 1];\n                    if (connectAdjacent && column.offset == 0)\n                        prevColumn.width++;\n                    else\n                        column.offset++;\n                }\n                else\n                    column.offset++;\n                column.width--;\n            }\n        };\n\n        this.evenColumns = function () {\n            if (this.children.length == 0)\n                return;\n\n            var evenWidth = Math.floor(12 / this.children.length);\n            _(this.children).each(function (column) {\n                column.width = evenWidth;\n                column.offset = 0;\n            });\n\n            var rest = 12 % this.children.length;\n            if (rest > 0)\n                _distributeSpace(rest);\n        };\n\n        var _basePasteChild = this.pasteChild;\n        this.pasteChild = function (child) {\n            if (child.type == \"Column\") {\n                if (this.beginAddColumn(child.width)) {\n                    this.commitAddColumn();\n                    _basePasteChild.call(this, child)\n                }\n            }\n            else if (!!this.parent)\n                this.parent.pasteChild(child);\n        }\n\n        this.toObject = function () {\n            var result = this.elementToObject();\n            result.children = this.childrenToObject();\n            return result;\n        };\n    };\n\n    LayoutEditor.Row.from = function (value) {\n        var result = new LayoutEditor.Row(\n            value.data,\n            value.htmlId,\n            value.htmlClass,\n            value.htmlStyle,\n            value.isTemplated,\n            LayoutEditor.childrenFrom(value.children));\n        result.toolboxIcon = value.toolboxIcon;\n        result.toolboxLabel = value.toolboxLabel;\n        result.toolboxDescription = value.toolboxDescription;\n        return result;\n    };\n\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\n(function (LayoutEditor) {\n\n    LayoutEditor.Column = function (data, htmlId, htmlClass, htmlStyle, isTemplated, width, offset, children) {\n        LayoutEditor.Element.call(this, \"Column\", data, htmlId, htmlClass, htmlStyle, isTemplated);\n        LayoutEditor.Container.call(this, [\"Grid\", \"Content\"], children);\n\n        this.width = width;\n        this.offset = offset;\n\n        var _hasPendingChange = false;\n        var _origWidth = 0;\n        var _origOffset = 0;\n\n        this.beginChange = function () {\n            if (!!_hasPendingChange)\n                throw new Error(\"Column already has a pending change.\")\n            _hasPendingChange = true;\n            _origWidth = this.width;\n            _origOffset = this.offset;\n        };\n\n        this.commitChange = function () {\n            if (!_hasPendingChange)\n                throw new Error(\"Column has no pending change.\")\n            _origWidth = 0;\n            _origOffset = 0;\n            _hasPendingChange = false;\n        };\n\n        this.rollbackChange = function () {\n            if (!_hasPendingChange)\n                throw new Error(\"Column has no pending change.\")\n            this.width = _origWidth;\n            this.offset = _origOffset;\n            _origWidth = 0;\n            _origOffset = 0;\n            _hasPendingChange = false;\n        };\n\n        this.canSplit = function () {\n            return this.width > 1;\n        };\n\n        this.split = function () {\n            if (!this.canSplit())\n                return;\n\n            var newColumnWidth = Math.floor(this.width / 2);\n            var newColumn = LayoutEditor.Column.from({\n                data: null,\n                htmlId: null,\n                htmlClass: null,\n                htmlStyle: null,\n                width: newColumnWidth,\n                offset: 0,\n                children: []\n            });\n            \n            this.width = this.width - newColumnWidth;\n            this.parent.insertChild(newColumn, this);\n            newColumn.setIsFocused();\n        };\n\n        this.canContractRight = function (connectAdjacent) {\n            return this.parent.canContractColumnRight(this, connectAdjacent);\n        };\n\n        this.contractRight = function (connectAdjacent) {\n            this.parent.contractColumnRight(this, connectAdjacent);\n        };\n\n        this.canExpandRight = function (connectAdjacent) {\n            return this.parent.canExpandColumnRight(this, connectAdjacent);\n        };\n\n        this.expandRight = function (connectAdjacent) {\n            this.parent.expandColumnRight(this, connectAdjacent);\n        };\n\n        this.canExpandLeft = function (connectAdjacent) {\n            return this.parent.canExpandColumnLeft(this, connectAdjacent);\n        };\n\n        this.expandLeft = function (connectAdjacent) {\n            this.parent.expandColumnLeft(this, connectAdjacent);\n        };\n\n        this.canContractLeft = function (connectAdjacent) {\n            return this.parent.canContractColumnLeft(this, connectAdjacent);\n        };\n\n        this.contractLeft = function (connectAdjacent) {\n            this.parent.contractColumnLeft(this, connectAdjacent);\n        };\n\n        this.toObject = function () {\n            var result = this.elementToObject();\n            result.width = this.width;\n            result.offset = this.offset;\n            result.children = this.childrenToObject();\n            return result;\n        };\n    };\n\n    LayoutEditor.Column.from = function (value) {\n        var result = new LayoutEditor.Column(\n            value.data,\n            value.htmlId,\n            value.htmlClass,\n            value.htmlStyle,\n            value.isTemplated,\n            value.width,\n            value.offset,\n            LayoutEditor.childrenFrom(value.children));\n        result.toolboxIcon = value.toolboxIcon;\n        result.toolboxLabel = value.toolboxLabel;\n        result.toolboxDescription = value.toolboxDescription;\n        return result;\n    };\n\n    LayoutEditor.Column.times = function (value) {\n        return _.times(value, function (n) {\n            return LayoutEditor.Column.from({\n                data: null,\n                htmlId: null,\n                htmlClass: null,\n                isTemplated: false,\n                width: 12 / value,\n                offset: 0,\n                children: []\n            });\n        });\n    };\n\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\n(function (LayoutEditor) {\n\n    LayoutEditor.Content = function (data, htmlId, htmlClass, htmlStyle, isTemplated, contentType, contentTypeLabel, contentTypeClass, html, hasEditor) {\n        LayoutEditor.Element.call(this, \"Content\", data, htmlId, htmlClass, htmlStyle, isTemplated);\n\n        this.contentType = contentType;\n        this.contentTypeLabel = contentTypeLabel;\n        this.contentTypeClass = contentTypeClass;\n        this.html = html;\n        this.hasEditor = hasEditor;\n\n        this.getInnerText = function () {\n            return $($.parseHTML(\"<div>\" + this.html + \"</div>\")).text();\n        };\n\n        // This function will be overwritten by the Content directive.\n        this.setHtml = function (html) {\n            this.html = html;\n            this.htmlUnsafe = html;\n        }\n\n        this.toObject = function () {\n            return {\n                \"type\": \"Content\"\n            };\n        };\n\n        this.toObject = function () {\n            var result = this.elementToObject();\n            result.contentType = this.contentType;\n            result.contentTypeLabel = this.contentTypeLabel;\n            result.contentTypeClass = this.contentTypeClass;\n            result.html = this.html;\n            result.hasEditor = hasEditor;\n            return result;\n        };\n\n        this.setHtml(html);\n    };\n\n    LayoutEditor.Content.from = function (value) {\n        var result = new LayoutEditor.Content(\n            value.data,\n            value.htmlId,\n            value.htmlClass,\n            value.htmlStyle,\n            value.isTemplated,\n            value.contentType,\n            value.contentTypeLabel,\n            value.contentTypeClass,\n            value.html,\n            value.hasEditor);\n\n        return result;\n    };\n\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\n(function ($, LayoutEditor) {\n\n    LayoutEditor.Html = function (data, htmlId, htmlClass, htmlStyle, isTemplated, contentType, contentTypeLabel, contentTypeClass, html, hasEditor) {\n        LayoutEditor.Element.call(this, \"Html\", data, htmlId, htmlClass, htmlStyle, isTemplated);\n\n        this.contentType = contentType;\n        this.contentTypeLabel = contentTypeLabel;\n        this.contentTypeClass = contentTypeClass;\n        this.html = html;\n        this.hasEditor = hasEditor;\n        this.isContainable = true;\n\n        this.getInnerText = function () {\n            return $($.parseHTML(\"<div>\" + this.html + \"</div>\")).text();\n        };\n\n        // This function will be overwritten by the Content directive.\n        this.setHtml = function (html) {\n            this.html = html;\n            this.htmlUnsafe = html;\n        }\n\n        this.toObject = function () {\n            return {\n                \"type\": \"Html\"\n            };\n        };\n\n        this.toObject = function () {\n            var result = this.elementToObject();\n            result.contentType = this.contentType;\n            result.contentTypeLabel = this.contentTypeLabel;\n            result.contentTypeClass = this.contentTypeClass;\n            result.html = this.html;\n            result.hasEditor = hasEditor;\n            return result;\n        };\n\n        var getEditorObject = this.getEditorObject;\n        this.getEditorObject = function () {\n            var dto = getEditorObject();\n            return $.extend(dto, {\n                Content: this.html\n            });\n        }\n\n        this.setHtml(html);\n    };\n\n    LayoutEditor.Html.from = function (value) {\n        var result = new LayoutEditor.Html(\n            value.data,\n            value.htmlId,\n            value.htmlClass,\n            value.htmlStyle,\n            value.isTemplated,\n            value.contentType,\n            value.contentTypeLabel,\n            value.contentTypeClass,\n            value.html,\n            value.hasEditor);\n\n        return result;\n    };\n\n    LayoutEditor.registerFactory(\"Html\", function(value) { return LayoutEditor.Html.from(value); });\n\n})(jQuery, LayoutEditor || (LayoutEditor = {}));"],"sourceRoot":"/source/"} +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["Helpers.js","Editor.js","Element.js","Container.js","Canvas.js","Grid.js","Row.js","Column.js","Content.js","Html.js"],"names":[],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC1CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AChCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC1LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACpIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;ACtCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC7BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC7RA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC7IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AC1DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"Models.js","sourcesContent":["var LayoutEditor;\r\n(function (LayoutEditor) {\r\n\r\n    Array.prototype.move = function (from, to) {\r\n        this.splice(to, 0, this.splice(from, 1)[0]);\r\n    };\r\n\r\n    LayoutEditor.childrenFrom = function(values) {\r\n        return _(values).map(function(value) {\r\n            return LayoutEditor.elementFrom(value);\r\n        });\r\n    };\r\n\r\n    var registerFactory = LayoutEditor.registerFactory = function(type, factory) {\r\n        var factories = LayoutEditor.factories = LayoutEditor.factories || {};\r\n        factories[type] = factory;\r\n    };\r\n\r\n    registerFactory(\"Canvas\", function (value) { return LayoutEditor.Canvas.from(value); });\r\n    registerFactory(\"Grid\", function(value) { return LayoutEditor.Grid.from(value); });\r\n    registerFactory(\"Row\", function(value) { return LayoutEditor.Row.from(value); });\r\n    registerFactory(\"Column\", function(value) { return LayoutEditor.Column.from(value); });\r\n    registerFactory(\"Content\", function(value) { return LayoutEditor.Content.from(value); });\r\n\r\n    LayoutEditor.elementFrom = function (value) {\r\n        var factory = LayoutEditor.factories[value.type];\r\n\r\n        if (!factory)\r\n            throw new Error(\"No element with type \\\"\" + value.type + \"\\\" was found.\");\r\n\r\n        var element = factory(value);\r\n        return element;\r\n    };\r\n\r\n    LayoutEditor.setModel = function (elementSelector, model) {\r\n        $(elementSelector).scope().element = model;\r\n    };\r\n\r\n    LayoutEditor.getModel = function (elementSelector) {\r\n        return $(elementSelector).scope().element;\r\n    };\r\n\r\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\n(function (LayoutEditor) {\n\n    LayoutEditor.Editor = function (config, canvasData) {\n        this.config = config;\n        this.canvas = LayoutEditor.Canvas.from(canvasData);\n        this.initialState = JSON.stringify(this.canvas.toObject());\n        this.activeElement = null;\n        this.focusedElement = null;\n        this.dropTargetElement = null;\n        this.isDragging = false;\n        this.inlineEditingIsActive = false;\n        this.isResizing = false;\n\n        this.resetToolboxElements = function () {\n            this.toolboxElements = [\n                LayoutEditor.Row.from({\n                    children: []\n                })\n            ];\n        };\n\n        this.isDirty = function() {\n            var currentState = JSON.stringify(this.canvas.toObject());\n            return this.initialState != currentState;\n        };\n\n        this.resetToolboxElements();\n        this.canvas.setEditor(this);\n    };\n\n})(LayoutEditor || (LayoutEditor = {}));\n","var LayoutEditor;\r\n(function (LayoutEditor) {\r\n\r\n    LayoutEditor.Element = function (type, data, htmlId, htmlClass, htmlStyle, isTemplated, rule) {\r\n        if (!type)\r\n            throw new Error(\"Parameter 'type' is required.\");\r\n\r\n        this.type = type;\r\n        this.data = data;\r\n        this.htmlId = htmlId;\r\n        this.htmlClass = htmlClass;\r\n        this.htmlStyle = htmlStyle;\r\n        this.isTemplated = isTemplated;\r\n        this.rule = rule;\r\n\r\n        this.editor = null;\r\n        this.parent = null;\r\n        this.setIsFocusedEventHandlers = [];\r\n\r\n        this.setEditor = function (editor) {\r\n            this.editor = editor;\r\n            if (!!this.children && _.isArray(this.children)) {\r\n                _(this.children).each(function (child) {\r\n                    child.setEditor(editor);\r\n                });\r\n            }\r\n        };\r\n\r\n        this.setParent = function(parentElement) {\r\n            this.parent = parentElement;\r\n\r\n            if (!!this.parent.linkChild)\r\n                this.parent.linkChild(this);\r\n        };\r\n\r\n        this.setIsTemplated = function (value) {\r\n            this.isTemplated = value;\r\n            if (!!this.children && _.isArray(this.children)) {\r\n                _(this.children).each(function (child) {\r\n                    child.setIsTemplated(value);\r\n                });\r\n            }\r\n        };\r\n\r\n        this.getIsActive = function () {\r\n            if (!this.editor)\r\n                return false;\r\n            return this.editor.activeElement === this && !this.getIsFocused();\r\n        };\r\n\r\n        this.setIsActive = function (value) {\r\n            if (!this.editor)\r\n                return;\r\n            if (this.editor.isDragging || this.editor.inlineEditingIsActive || this.editor.isResizing)\r\n                return;\r\n\r\n            if (value)\r\n                this.editor.activeElement = this;\r\n            else\r\n                this.editor.activeElement = this.parent;\r\n        };\r\n\r\n        this.getIsFocused = function () {\r\n            if (!this.editor)\r\n                return false;\r\n            return this.editor.focusedElement === this;\r\n        };\r\n\r\n        this.allowSealedFocus = function() {\r\n            return false;\r\n        };\r\n\r\n        this.setIsFocused = function () {\r\n            if (!this.editor)\r\n                return;\r\n            if (this.isTemplated && !this.allowSealedFocus())\r\n                return;\r\n            if (this.editor.isDragging || this.editor.inlineEditingIsActive || this.editor.isResizing)\r\n                return;\r\n\r\n            this.editor.focusedElement = this;\r\n            _(this.setIsFocusedEventHandlers).each(function (item) {\r\n                try {\r\n                    item();\r\n                }\r\n                catch (ex) {\r\n                    // Ignore.\r\n                }\r\n            });\r\n        };\r\n\r\n        this.getIsSelected = function () {\r\n            if (this.getIsFocused())\r\n                return true;\r\n\r\n            if (!!this.children && _.isArray(this.children)) {\r\n                return _(this.children).any(function(child) {\r\n                    return child.getIsSelected();\r\n                });\r\n            }\r\n\r\n            return false;\r\n        };\r\n\r\n        this.getIsDropTarget = function () {\r\n            if (!this.editor)\r\n                return false;\r\n            return this.editor.dropTargetElement === this;\r\n        }\r\n\r\n        this.setIsDropTarget = function (value) {\r\n            if (!this.editor)\r\n                return;\r\n            if (value)\r\n                this.editor.dropTargetElement = this;\r\n            else\r\n                this.editor.dropTargetElement = null;\r\n        };\r\n\r\n        this.canDelete = function () {\r\n            return !!this.parent;\r\n        };\r\n\r\n        this.delete = function () {\r\n            if (!!this.parent)\r\n                this.parent.deleteChild(this);\r\n        };\r\n\r\n        this.canMoveUp = function () {\r\n            if (!this.parent)\r\n                return false;\r\n            return this.parent.canMoveChildUp(this);\r\n        };\r\n\r\n        this.moveUp = function () {\r\n            if (!!this.parent)\r\n                this.parent.moveChildUp(this);\r\n        };\r\n\r\n        this.canMoveDown = function () {\r\n            if (!this.parent)\r\n                return false;\r\n            return this.parent.canMoveChildDown(this);\r\n        };\r\n\r\n        this.moveDown = function () {\r\n            if (!!this.parent)\r\n                this.parent.moveChildDown(this);\r\n        };\r\n\r\n        this.elementToObject = function () {\r\n            return {\r\n                type: this.type,\r\n                data: this.data,\r\n                htmlId: this.htmlId,\r\n                htmlClass: this.htmlClass,\r\n                htmlStyle: this.htmlStyle,\r\n                isTemplated: this.isTemplated,\r\n                rule: this.rule\r\n            };\r\n        };\r\n\r\n        this.getEditorObject = function() {\r\n            return {};\r\n        };\r\n\r\n        this.copy = function (clipboardData) {\r\n            var text = this.getInnerText();\r\n            clipboardData.setData(\"text/plain\", text);\r\n\r\n            var data = this.toObject();\r\n            var json = JSON.stringify(data, null, \"\\t\");\r\n            clipboardData.setData(\"text/json\", json);\r\n        };\r\n\r\n        this.cut = function (clipboardData) {\r\n            this.copy(clipboardData);\r\n            this.delete();\r\n        };\r\n\r\n        this.paste = function (clipboardData) {\r\n            if (!!this.parent)\r\n                this.parent.paste(clipboardData);\r\n        };\r\n    };\r\n\r\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\n(function (LayoutEditor) {\n\n    LayoutEditor.Container = function (allowedChildTypes, children) {\n\n        this.allowedChildTypes = allowedChildTypes;\n        this.children = children;\n        this.isContainer = true;\n\n        var _self = this;\n\n        this.setChildren = function (children) {\n            this.children = children;\n            _(this.children).each(function (child) {\n                child.parent = _self;\n            });\n        };\n\n        this.setChildren(children);\n\n        this.getIsSealed = function () {\n            return _(this.children).any(function (child) {\n                return child.isTemplated;\n            });\n        };\n\n        this.addChild = function (child) {\n            if (!_(this.children).contains(child) && (_(this.allowedChildTypes).contains(child.type) || child.isContainable))\n                this.children.push(child);\n            child.setEditor(this.editor);\n            child.setIsTemplated(false);\n            child.parent = this;\n        };\n\n        this.deleteChild = function (child) {\n            var index = _(this.children).indexOf(child);\n            if (index >= 0) {\n                this.children.splice(index, 1);\n                if (child.getIsActive())\n                    this.editor.activeElement = null;\n                if (child.getIsFocused()) {\n                    // If the deleted child was focused, try to set new focus to the most appropriate sibling or parent.\n                    if (this.children.length > index)\n                        this.children[index].setIsFocused();\n                    else if (index > 0)\n                        this.children[index - 1].setIsFocused();\n                    else\n                        this.setIsFocused();\n                }\n            }\n        };\n\n        this.moveFocusPrevChild = function (child) {\n            if (this.children.length < 2)\n                return;\n            var index = _(this.children).indexOf(child);\n            if (index > 0)\n                this.children[index - 1].setIsFocused();\n        };\n\n        this.moveFocusNextChild = function (child) {\n            if (this.children.length < 2)\n                return;\n            var index = _(this.children).indexOf(child);\n            if (index < this.children.length - 1)\n                this.children[index + 1].setIsFocused();\n        };\n\n        this.insertChild = function (child, afterChild) {\n            if (!_(this.children).contains(child)) {\n                var index = Math.max(_(this.children).indexOf(afterChild), 0);\n                this.children.splice(index + 1, 0, child);\n                child.setEditor(this.editor);\n                child.parent = this;\n            }\n        };\n\n        this.moveChildUp = function (child) {\n            if (!this.canMoveChildUp(child))\n                return;\n            var index = _(this.children).indexOf(child);\n            this.children.move(index, index - 1);\n        };\n\n        this.moveChildDown = function (child) {\n            if (!this.canMoveChildDown(child))\n                return;\n            var index = _(this.children).indexOf(child);\n            this.children.move(index, index + 1);\n        };\n\n        this.canMoveChildUp = function (child) {\n            var index = _(this.children).indexOf(child);\n            return index > 0;\n        };\n\n        this.canMoveChildDown = function (child) {\n            var index = _(this.children).indexOf(child);\n            return index < this.children.length - 1;\n        };\n\n        this.childrenToObject = function () {\n            return _(this.children).map(function (child) {\n                return child.toObject();\n            });\n        };\n\n        this.getInnerText = function () {\n            return _(this.children).reduce(function (memo, child) {\n                return memo + \"\\n\" + child.getInnerText();\n            }, \"\");\n        }\n\n        this.paste = function (clipboardData) {\n            var json = clipboardData.getData(\"text/json\");\n            if (!!json) {\n                var data = JSON.parse(json);\n                var child = LayoutEditor.elementFrom(data);\n                this.pasteChild(child);\n            }\n        };\n\n        this.pasteChild = function (child) {\n            if (_(this.allowedChildTypes).contains(child.type) || child.isContainable) {\n                this.addChild(child);\n                child.setIsFocused();\n            }\n            else if (!!this.parent)\n                this.parent.pasteChild(child);\n        }\n    };\n\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\r\n(function (LayoutEditor) {\r\n\r\n    LayoutEditor.Canvas = function (data, htmlId, htmlClass, htmlStyle, isTemplated, rule, children) {\r\n        LayoutEditor.Element.call(this, \"Canvas\", data, htmlId, htmlClass, htmlStyle, isTemplated, rule);\r\n        LayoutEditor.Container.call(this, [\"Canvas\", \"Grid\", \"Content\"], children);\r\n\r\n        this.isContainable = true;\r\n\r\n        this.toObject = function () {\r\n            var result = this.elementToObject();\r\n            result.children = this.childrenToObject();\r\n            return result;\r\n        };\r\n\r\n        this.allowSealedFocus = function() {\r\n            return this.children.length === 0;\r\n        };\r\n    };\r\n\r\n    LayoutEditor.Canvas.from = function (value) {\r\n        var result = new LayoutEditor.Canvas(\r\n            value.data,\r\n            value.htmlId,\r\n            value.htmlClass,\r\n            value.htmlStyle,\r\n            value.isTemplated,\r\n            value.rule,\r\n            LayoutEditor.childrenFrom(value.children));\r\n\r\n        result.toolboxIcon = value.toolboxIcon;\r\n        result.toolboxLabel = value.toolboxLabel;\r\n        result.toolboxDescription = value.toolboxDescription;\r\n\r\n        return result;\r\n    };\r\n\r\n})(LayoutEditor || (LayoutEditor = {}));\r\n","var LayoutEditor;\r\n(function (LayoutEditor) {\r\n\r\n    LayoutEditor.Grid = function (data, htmlId, htmlClass, htmlStyle, isTemplated, rule, children) {\r\n        LayoutEditor.Element.call(this, \"Grid\", data, htmlId, htmlClass, htmlStyle, isTemplated, rule);\r\n        LayoutEditor.Container.call(this, [\"Row\"], children);\r\n\r\n        this.toObject = function () {\r\n            var result = this.elementToObject();\r\n            result.children = this.childrenToObject();\r\n            return result;\r\n        };\r\n    };\r\n\r\n    LayoutEditor.Grid.from = function (value) {\r\n        var result = new LayoutEditor.Grid(\r\n            value.data,\r\n            value.htmlId,\r\n            value.htmlClass,\r\n            value.htmlStyle,\r\n            value.isTemplated,\r\n            value.rule,\r\n            LayoutEditor.childrenFrom(value.children));\r\n        result.toolboxIcon = value.toolboxIcon;\r\n        result.toolboxLabel = value.toolboxLabel;\r\n        result.toolboxDescription = value.toolboxDescription;\r\n        return result;\r\n    };\r\n\r\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\r\n(function (LayoutEditor) {\r\n\r\n    LayoutEditor.Row = function (data, htmlId, htmlClass, htmlStyle, isTemplated, rule, children) {\r\n        LayoutEditor.Element.call(this, \"Row\", data, htmlId, htmlClass, htmlStyle, isTemplated, rule);\r\n        LayoutEditor.Container.call(this, [\"Column\"], children);\r\n\r\n        var _self = this;\r\n\r\n        function _getTotalColumnsWidth() {\r\n            return _(_self.children).reduce(function (memo, child) {\r\n                return memo + child.offset + child.width;\r\n            }, 0);\r\n        }\r\n\r\n        // Implements a simple algorithm to distribute space (either positive or negative)\r\n        // between the child columns of the row. Negative space is distributed when making\r\n        // room for a new column (e.c. clipboard paste or dropping from the toolbox) while\r\n        // positive space is distributed when filling the grap of a removed column.\r\n        function _distributeSpace(space) {\r\n            if (space == 0)\r\n                return true;\r\n             \r\n            var undistributedSpace = space;\r\n\r\n            if (undistributedSpace < 0) {\r\n                var vacantSpace = 12 - _getTotalColumnsWidth();\r\n                undistributedSpace += vacantSpace;\r\n                if (undistributedSpace > 0)\r\n                    undistributedSpace = 0;\r\n            }\r\n\r\n            // If space is negative, try to decrease offsets first.\r\n            while (undistributedSpace < 0 && _(_self.children).any(function (column) { return column.offset > 0; })) { // While there is still offset left to remove.\r\n                for (i = 0; i < _self.children.length && undistributedSpace < 0; i++) {\r\n                    var column = _self.children[i];\r\n                    if (column.offset > 0) {\r\n                        column.offset--;\r\n                        undistributedSpace++;\r\n                    }\r\n                }\r\n            }\r\n\r\n            function hasWidth(column) {\r\n                if (undistributedSpace > 0)\r\n                    return column.width < 12;\r\n                else if (undistributedSpace < 0)\r\n                    return column.width > 1;\r\n                return false;\r\n            }\r\n\r\n            // Try to distribute remaining space (could be negative or positive) using widths.\r\n            while (undistributedSpace != 0) {\r\n                // Any more column width available for distribution?\r\n                if (!_(_self.children).any(hasWidth))\r\n                    break;\r\n                for (i = 0; i < _self.children.length && undistributedSpace != 0; i++) {\r\n                    var column = _self.children[i % _self.children.length];\r\n                    if (hasWidth(column)) {\r\n                        var delta = undistributedSpace / Math.abs(undistributedSpace);\r\n                        column.width += delta;\r\n                        undistributedSpace -= delta;\r\n                    }\r\n                }                \r\n            }\r\n\r\n            return undistributedSpace == 0;\r\n        }\r\n\r\n        var _isAddingColumn = false;\r\n\r\n        this.canAddColumn = function () {\r\n            return this.children.length < 12;\r\n        };\r\n\r\n        this.beginAddColumn = function (newColumnWidth) {\r\n            if (!!_isAddingColumn)\r\n                throw new Error(\"Column add operation is already in progress.\")\r\n            _(this.children).each(function (column) {\r\n                column.beginChange();\r\n            });\r\n            if (_distributeSpace(-newColumnWidth)) {\r\n                _isAddingColumn = true;\r\n                return true;\r\n            }\r\n            _(this.children).each(function (column) {\r\n                column.rollbackChange();\r\n            });\r\n            return false;\r\n        };\r\n\r\n        this.commitAddColumn = function () {\r\n            if (!_isAddingColumn)\r\n                throw new Error(\"No column add operation in progress.\")\r\n            _(this.children).each(function (column) {\r\n                column.commitChange();\r\n            });\r\n            _isAddingColumn = false;\r\n        };\r\n\r\n        this.rollbackAddColumn = function () {\r\n            if (!_isAddingColumn)\r\n                throw new Error(\"No column add operation in progress.\")\r\n            _(this.children).each(function (column) {\r\n                column.rollbackChange();\r\n            });\r\n            _isAddingColumn = false;\r\n        };\r\n\r\n        var _baseDeleteChild = this.deleteChild;\r\n        this.deleteChild = function (column) { \r\n            var width = column.width;\r\n            _baseDeleteChild.call(this, column);\r\n            _distributeSpace(width);\r\n        };\r\n\r\n        this.canContractColumnRight = function (column, connectAdjacent) {\r\n            var index = _(this.children).indexOf(column);\r\n            if (index >= 0)\r\n                return column.width > 1;\r\n            return false;\r\n        };\r\n\r\n        this.contractColumnRight = function (column, connectAdjacent) {\r\n            if (!this.canContractColumnRight(column, connectAdjacent))\r\n                return;\r\n\r\n            var index = _(this.children).indexOf(column);\r\n            if (index >= 0) {\r\n                if (column.width > 1) {\r\n                    column.width--;\r\n                    if (this.children.length > index + 1) {\r\n                        var nextColumn = this.children[index + 1];\r\n                        if (connectAdjacent && nextColumn.offset == 0)\r\n                            nextColumn.width++;\r\n                        else\r\n                            nextColumn.offset++;\r\n                    }\r\n                }\r\n            }\r\n        };\r\n\r\n        this.canExpandColumnRight = function (column, connectAdjacent) {\r\n            var index = _(this.children).indexOf(column);\r\n            if (index >= 0) {\r\n                if (column.width >= 12)\r\n                    return false;\r\n                if (this.children.length > index + 1) {\r\n                    var nextColumn = this.children[index + 1];\r\n                    if (connectAdjacent && nextColumn.offset == 0)\r\n                        return nextColumn.width > 1;\r\n                    else\r\n                        return nextColumn.offset > 0;\r\n                }\r\n                return _getTotalColumnsWidth() < 12;\r\n            }\r\n            return false;\r\n        };\r\n\r\n        this.expandColumnRight = function (column, connectAdjacent) {\r\n            if (!this.canExpandColumnRight(column, connectAdjacent))\r\n                return;\r\n\r\n            var index = _(this.children).indexOf(column);\r\n            if (index >= 0) {\r\n                if (this.children.length > index + 1) {\r\n                    var nextColumn = this.children[index + 1];\r\n                    if (connectAdjacent && nextColumn.offset == 0)\r\n                        nextColumn.width--;\r\n                    else\r\n                        nextColumn.offset--;\r\n                }\r\n                column.width++;\r\n            }\r\n        };\r\n\r\n        this.canExpandColumnLeft = function (column, connectAdjacent) {\r\n            var index = _(this.children).indexOf(column);\r\n            if (index >= 0) {\r\n                if (column.width >= 12)\r\n                    return false;\r\n                if (index > 0) {\r\n                    var prevColumn = this.children[index - 1];\r\n                    if (connectAdjacent && column.offset == 0)\r\n                        return prevColumn.width > 1;\r\n                }\r\n                return column.offset > 0;\r\n            }\r\n            return false;\r\n        };\r\n\r\n        this.expandColumnLeft = function (column, connectAdjacent) {\r\n            if (!this.canExpandColumnLeft(column, connectAdjacent))\r\n                return;\r\n\r\n            var index = _(this.children).indexOf(column);\r\n            if (index >= 0) {\r\n                if (index > 0) {\r\n                    var prevColumn = this.children[index - 1];\r\n                    if (connectAdjacent && column.offset == 0)\r\n                        prevColumn.width--;\r\n                    else\r\n                        column.offset--;\r\n                }\r\n                else\r\n                    column.offset--;\r\n                column.width++;\r\n            }\r\n        };\r\n\r\n        this.canContractColumnLeft = function (column, connectAdjacent) {\r\n            var index = _(this.children).indexOf(column);\r\n            if (index >= 0)\r\n                return column.width > 1;\r\n            return false;\r\n        };\r\n\r\n        this.contractColumnLeft = function (column, connectAdjacent) {\r\n            if (!this.canContractColumnLeft(column, connectAdjacent))\r\n                return;\r\n\r\n            var index = _(this.children).indexOf(column);\r\n            if (index >= 0) {\r\n                if (index > 0) {\r\n                    var prevColumn = this.children[index - 1];\r\n                    if (connectAdjacent && column.offset == 0)\r\n                        prevColumn.width++;\r\n                    else\r\n                        column.offset++;\r\n                }\r\n                else\r\n                    column.offset++;\r\n                column.width--;\r\n            }\r\n        };\r\n\r\n        this.evenColumns = function () {\r\n            if (this.children.length == 0)\r\n                return;\r\n\r\n            var evenWidth = Math.floor(12 / this.children.length);\r\n            _(this.children).each(function (column) {\r\n                column.width = evenWidth;\r\n                column.offset = 0;\r\n            });\r\n\r\n            var rest = 12 % this.children.length;\r\n            if (rest > 0)\r\n                _distributeSpace(rest);\r\n        };\r\n\r\n        var _basePasteChild = this.pasteChild;\r\n        this.pasteChild = function (child) {\r\n            if (child.type == \"Column\") {\r\n                if (this.beginAddColumn(child.width)) {\r\n                    this.commitAddColumn();\r\n                    _basePasteChild.call(this, child)\r\n                }\r\n            }\r\n            else if (!!this.parent)\r\n                this.parent.pasteChild(child);\r\n        }\r\n\r\n        this.toObject = function () {\r\n            var result = this.elementToObject();\r\n            result.children = this.childrenToObject();\r\n            return result;\r\n        };\r\n    };\r\n\r\n    LayoutEditor.Row.from = function (value) {\r\n        var result = new LayoutEditor.Row(\r\n            value.data,\r\n            value.htmlId,\r\n            value.htmlClass,\r\n            value.htmlStyle,\r\n            value.isTemplated,\r\n            value.rule,\r\n            LayoutEditor.childrenFrom(value.children));\r\n        result.toolboxIcon = value.toolboxIcon;\r\n        result.toolboxLabel = value.toolboxLabel;\r\n        result.toolboxDescription = value.toolboxDescription;\r\n        return result;\r\n    };\r\n\r\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\r\n(function (LayoutEditor) {\r\n    LayoutEditor.Column = function (data, htmlId, htmlClass, htmlStyle, isTemplated, width, offset, collapsible, rule, children) {\r\n        LayoutEditor.Element.call(this, \"Column\", data, htmlId, htmlClass, htmlStyle, isTemplated, rule);\r\n        LayoutEditor.Container.call(this, [\"Grid\", \"Content\"], children);\r\n        this.width = width;\r\n        this.offset = offset;\r\n        this.collapsible = collapsible;\r\n\r\n        var _hasPendingChange = false;\r\n        var _origWidth = 0;\r\n        var _origOffset = 0;\r\n\r\n        this.allowSealedFocus = function () {\r\n            return this.children.length === 0;\r\n        };\r\n\r\n        this.beginChange = function () {\r\n            if (!!_hasPendingChange)\r\n                throw new Error(\"Column already has a pending change.\");\r\n            _hasPendingChange = true;\r\n            _origWidth = this.width;\r\n            _origOffset = this.offset;\r\n        };\r\n\r\n        this.commitChange = function () {\r\n            if (!_hasPendingChange)\r\n                throw new Error(\"Column has no pending change.\");\r\n            _origWidth = 0;\r\n            _origOffset = 0;\r\n            _hasPendingChange = false;\r\n        };\r\n\r\n        this.rollbackChange = function () {\r\n            if (!_hasPendingChange)\r\n                throw new Error(\"Column has no pending change.\");\r\n            this.width = _origWidth;\r\n            this.offset = _origOffset;\r\n            _origWidth = 0;\r\n            _origOffset = 0;\r\n            _hasPendingChange = false;\r\n        };\r\n\r\n        this.canSplit = function () {\r\n            return this.width > 1;\r\n        };\r\n\r\n        this.split = function () {\r\n            if (!this.canSplit())\r\n                return;\r\n\r\n            var newColumnWidth = Math.floor(this.width / 2);\r\n            var newColumn = LayoutEditor.Column.from({\r\n                data: null,\r\n                htmlId: null,\r\n                htmlClass: null,\r\n                htmlStyle: null,\r\n                width: newColumnWidth,\r\n                offset: 0,\r\n                children: []\r\n            });\r\n\r\n            this.width = this.width - newColumnWidth;\r\n            this.parent.insertChild(newColumn, this);\r\n            newColumn.setIsFocused();\r\n        };\r\n\r\n        this.canContractRight = function (connectAdjacent) {\r\n            return this.parent.canContractColumnRight(this, connectAdjacent);\r\n        };\r\n\r\n        this.contractRight = function (connectAdjacent) {\r\n            this.parent.contractColumnRight(this, connectAdjacent);\r\n        };\r\n\r\n        this.canExpandRight = function (connectAdjacent) {\r\n            return this.parent.canExpandColumnRight(this, connectAdjacent);\r\n        };\r\n\r\n        this.expandRight = function (connectAdjacent) {\r\n            this.parent.expandColumnRight(this, connectAdjacent);\r\n        };\r\n\r\n        this.canExpandLeft = function (connectAdjacent) {\r\n            return this.parent.canExpandColumnLeft(this, connectAdjacent);\r\n        };\r\n\r\n        this.expandLeft = function (connectAdjacent) {\r\n            this.parent.expandColumnLeft(this, connectAdjacent);\r\n        };\r\n\r\n        this.canContractLeft = function (connectAdjacent) {\r\n            return this.parent.canContractColumnLeft(this, connectAdjacent);\r\n        };\r\n\r\n        this.contractLeft = function (connectAdjacent) {\r\n            this.parent.contractColumnLeft(this, connectAdjacent);\r\n        };\r\n\r\n        this.toObject = function () {\r\n            var result = this.elementToObject();\r\n            result.width = this.width;\r\n            result.offset = this.offset;\r\n            result.collapsible = this.collapsible;\r\n            result.children = this.childrenToObject();\r\n            return result;\r\n        };\r\n    };\r\n\r\n    LayoutEditor.Column.from = function (value) {\r\n        var result = new LayoutEditor.Column(\r\n            value.data,\r\n            value.htmlId,\r\n            value.htmlClass,\r\n            value.htmlStyle,\r\n            value.isTemplated,\r\n            value.width,\r\n            value.offset,\r\n            value.collapsible,\r\n            value.rule,\r\n            LayoutEditor.childrenFrom(value.children));\r\n        result.toolboxIcon = value.toolboxIcon;\r\n        result.toolboxLabel = value.toolboxLabel;\r\n        result.toolboxDescription = value.toolboxDescription;\r\n        return result;\r\n    };\r\n\r\n    LayoutEditor.Column.times = function (value) {\r\n        return _.times(value, function (n) {\r\n            return LayoutEditor.Column.from({\r\n                data: null,\r\n                htmlId: null,\r\n                htmlClass: null,\r\n                isTemplated: false,\r\n                width: 12 / value,\r\n                offset: 0,\r\n                collapsible: null,\r\n                children: []\r\n            });\r\n        });\r\n    };\r\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\r\n(function (LayoutEditor) {\r\n\r\n    LayoutEditor.Content = function (data, htmlId, htmlClass, htmlStyle, isTemplated, contentType, contentTypeLabel, contentTypeClass, html, hasEditor, rule) {\r\n        LayoutEditor.Element.call(this, \"Content\", data, htmlId, htmlClass, htmlStyle, isTemplated, rule);\r\n\r\n        this.contentType = contentType;\r\n        this.contentTypeLabel = contentTypeLabel;\r\n        this.contentTypeClass = contentTypeClass;\r\n        this.html = html;\r\n        this.hasEditor = hasEditor;\r\n\r\n        this.getInnerText = function () {\r\n            return $($.parseHTML(\"<div>\" + this.html + \"</div>\")).text();\r\n        };\r\n\r\n        // This function will be overwritten by the Content directive.\r\n        this.setHtml = function (html) {\r\n            this.html = html;\r\n            this.htmlUnsafe = html;\r\n        }\r\n\r\n        this.toObject = function () {\r\n            return {\r\n                \"type\": \"Content\"\r\n            };\r\n        };\r\n\r\n        this.toObject = function () {\r\n            var result = this.elementToObject();\r\n            result.contentType = this.contentType;\r\n            result.contentTypeLabel = this.contentTypeLabel;\r\n            result.contentTypeClass = this.contentTypeClass;\r\n            result.html = this.html;\r\n            result.hasEditor = hasEditor;\r\n            return result;\r\n        };\r\n\r\n        this.setHtml(html);\r\n    };\r\n\r\n    LayoutEditor.Content.from = function (value) {\r\n        var result = new LayoutEditor.Content(\r\n            value.data,\r\n            value.htmlId,\r\n            value.htmlClass,\r\n            value.htmlStyle,\r\n            value.isTemplated,\r\n            value.contentType,\r\n            value.contentTypeLabel,\r\n            value.contentTypeClass,\r\n            value.html,\r\n            value.hasEditor,\r\n            value.rule);\r\n\r\n        return result;\r\n    };\r\n\r\n})(LayoutEditor || (LayoutEditor = {}));","var LayoutEditor;\r\n(function ($, LayoutEditor) {\r\n\r\n    LayoutEditor.Html = function (data, htmlId, htmlClass, htmlStyle, isTemplated, contentType, contentTypeLabel, contentTypeClass, html, hasEditor, rule) {\r\n        LayoutEditor.Element.call(this, \"Html\", data, htmlId, htmlClass, htmlStyle, isTemplated, rule);\r\n\r\n        this.contentType = contentType;\r\n        this.contentTypeLabel = contentTypeLabel;\r\n        this.contentTypeClass = contentTypeClass;\r\n        this.html = html;\r\n        this.hasEditor = hasEditor;\r\n        this.isContainable = true;\r\n\r\n        this.getInnerText = function () {\r\n            return $($.parseHTML(\"<div>\" + this.html + \"</div>\")).text();\r\n        };\r\n\r\n        // This function will be overwritten by the Content directive.\r\n        this.setHtml = function (html) {\r\n            this.html = html;\r\n            this.htmlUnsafe = html;\r\n        }\r\n\r\n        this.toObject = function () {\r\n            return {\r\n                \"type\": \"Html\"\r\n            };\r\n        };\r\n\r\n        this.toObject = function () {\r\n            var result = this.elementToObject();\r\n            result.contentType = this.contentType;\r\n            result.contentTypeLabel = this.contentTypeLabel;\r\n            result.contentTypeClass = this.contentTypeClass;\r\n            result.html = this.html;\r\n            result.hasEditor = hasEditor;\r\n            return result;\r\n        };\r\n\r\n        var getEditorObject = this.getEditorObject;\r\n        this.getEditorObject = function () {\r\n            var dto = getEditorObject();\r\n            return $.extend(dto, {\r\n                Content: this.html\r\n            });\r\n        }\r\n\r\n        this.setHtml(html);\r\n    };\r\n\r\n    LayoutEditor.Html.from = function (value) {\r\n        var result = new LayoutEditor.Html(\r\n            value.data,\r\n            value.htmlId,\r\n            value.htmlClass,\r\n            value.htmlStyle,\r\n            value.isTemplated,\r\n            value.contentType,\r\n            value.contentTypeLabel,\r\n            value.contentTypeClass,\r\n            value.html,\r\n            value.hasEditor,\r\n            value.rule);\r\n\r\n        return result;\r\n    };\r\n\r\n    LayoutEditor.registerFactory(\"Html\", function(value) { return LayoutEditor.Html.from(value); });\r\n\r\n})(jQuery, LayoutEditor || (LayoutEditor = {}));"],"sourceRoot":"/source/"} \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models.min.js b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models.min.js index c354fee03..846ddf3a7 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models.min.js +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models.min.js @@ -1 +1 @@ -var LayoutEditor;!function(t){Array.prototype.move=function(t,i){this.splice(i,0,this.splice(t,1)[0])},t.childrenFrom=function(i){return _(i).map(function(i){return t.elementFrom(i)})};var i=t.registerFactory=function(i,n){var e=t.factories=t.factories||{};e[i]=n};i("Grid",function(i){return t.Grid.from(i)}),i("Row",function(i){return t.Row.from(i)}),i("Column",function(i){return t.Column.from(i)}),i("Content",function(i){return t.Content.from(i)}),t.elementFrom=function(i){var n=t.factories[i.type];if(!n)throw new Error('No element with type "'+i.type+'" was found.');var e=n(i);return e},t.setModel=function(t,i){$(t).scope().element=i},t.getModel=function(t){return $(t).scope().element}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t){t.Editor=function(i,n){this.config=i,this.canvas=t.Canvas.from(n),this.initialState=JSON.stringify(this.canvas.toObject()),this.activeElement=null,this.focusedElement=null,this.dropTargetElement=null,this.isDragging=!1,this.inlineEditingIsActive=!1,this.isResizing=!1,this.resetToolboxElements=function(){this.toolboxElements=[t.Row.from({children:[]})]},this.isDirty=function(){var t=JSON.stringify(this.canvas.toObject());return this.initialState!=t},this.resetToolboxElements(),this.canvas.setEditor(this)}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t){t.Element=function(t,i,n,e,h,o){if(!t)throw new Error("Parameter 'type' is required.");this.type=t,this.data=i,this.htmlId=n,this.htmlClass=e,this.htmlStyle=h,this.isTemplated=o,this.editor=null,this.parent=null,this.setIsFocusedEventHandlers=[],this.setEditor=function(t){this.editor=t,this.children&&_.isArray(this.children)&&_(this.children).each(function(i){i.setEditor(t)})},this.setParent=function(t){this.parent=t,this.parent.linkChild&&this.parent.linkChild(this)},this.setIsTemplated=function(t){this.isTemplated=t,this.children&&_.isArray(this.children)&&_(this.children).each(function(i){i.setIsTemplated(t)})},this.getIsActive=function(){return this.editor?this.editor.activeElement===this&&!this.getIsFocused():!1},this.setIsActive=function(t){this.editor&&(this.editor.isDragging||this.editor.inlineEditingIsActive||this.editor.isResizing||(this.editor.activeElement=t?this:this.parent))},this.getIsFocused=function(){return this.editor?this.editor.focusedElement===this:!1},this.setIsFocused=function(){this.editor&&(this.isTemplated||this.editor.isDragging||this.editor.inlineEditingIsActive||this.editor.isResizing||(this.editor.focusedElement=this,_(this.setIsFocusedEventHandlers).each(function(t){try{t()}catch(i){}})))},this.getIsSelected=function(){return this.getIsFocused()?!0:this.children&&_.isArray(this.children)?_(this.children).any(function(t){return t.getIsSelected()}):!1},this.getIsDropTarget=function(){return this.editor?this.editor.dropTargetElement===this:!1},this.setIsDropTarget=function(t){this.editor&&(this.editor.dropTargetElement=t?this:null)},this["delete"]=function(){this.parent&&this.parent.deleteChild(this)},this.canMoveUp=function(){return this.parent?this.parent.canMoveChildUp(this):!1},this.moveUp=function(){this.parent&&this.parent.moveChildUp(this)},this.canMoveDown=function(){return this.parent?this.parent.canMoveChildDown(this):!1},this.moveDown=function(){this.parent&&this.parent.moveChildDown(this)},this.elementToObject=function(){return{type:this.type,data:this.data,htmlId:this.htmlId,htmlClass:this.htmlClass,htmlStyle:this.htmlStyle,isTemplated:this.isTemplated}},this.getEditorObject=function(){return{}},this.copy=function(t){var i=this.getInnerText();t.setData("text/plain",i),console.log(i);var n=this.toObject(),e=JSON.stringify(n,null," ");t.setData("text/json",e)},this.cut=function(t){this.copy(t),this["delete"]()},this.paste=function(t){this.parent&&this.parent.paste(t)}}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t){t.Container=function(i,n){this.allowedChildTypes=i,this.children=n,this.isContainer=!0;var e=this;this.setChildren=function(t){this.children=t,_(this.children).each(function(t){t.parent=e})},this.setChildren(n),this.getIsSealed=function(){return _(this.children).any(function(t){return t.isTemplated})},this.addChild=function(t){_(this.children).contains(t)||!_(this.allowedChildTypes).contains(t.type)&&!t.isContainable||this.children.push(t),t.setEditor(this.editor),t.setIsTemplated(!1),t.parent=this},this.deleteChild=function(t){var i=_(this.children).indexOf(t);i>=0&&(this.children.splice(i,1),t.getIsActive()&&(this.editor.activeElement=null),t.getIsFocused()&&(this.children.length>i?this.children[i].setIsFocused():i>0?this.children[i-1].setIsFocused():this.setIsFocused()))},this.moveFocusPrevChild=function(t){if(!(this.children.length<2)){var i=_(this.children).indexOf(t);i>0&&this.children[i-1].setIsFocused()}},this.moveFocusNextChild=function(t){if(!(this.children.length<2)){var i=_(this.children).indexOf(t);i0},this.canMoveChildDown=function(t){var i=_(this.children).indexOf(t);return i0?t.width<12:0>e?t.width>1:!1}if(0==t)return!0;var e=t;if(0>e){var h=12-l();e+=h,e>0&&(e=0)}for(;0>e&&_(a.children).any(function(t){return t.offset>0});)for(i=0;ie;i++){var o=a.children[i];o.offset>0&&(o.offset--,e++)}for(;0!=e&&_(a.children).any(n);)for(i=0;i=0?t.width>1:!1},this.contractColumnRight=function(t,i){if(this.canContractColumnRight(t,i)){var n=_(this.children).indexOf(t);if(n>=0&&t.width>1&&(t.width--,this.children.length>n+1)){var e=this.children[n+1];i&&0==e.offset?e.width++:e.offset++}}},this.canExpandColumnRight=function(t,i){var n=_(this.children).indexOf(t);if(n>=0){if(t.width>=12)return!1;if(this.children.length>n+1){var e=this.children[n+1];return i&&0==e.offset?e.width>1:e.offset>0}return l()<12}return!1},this.expandColumnRight=function(t,i){if(this.canExpandColumnRight(t,i)){var n=_(this.children).indexOf(t);if(n>=0){if(this.children.length>n+1){var e=this.children[n+1];i&&0==e.offset?e.width--:e.offset--}t.width++}}},this.canExpandColumnLeft=function(t,i){var n=_(this.children).indexOf(t);if(n>=0){if(t.width>=12)return!1;if(n>0){var e=this.children[n-1];if(i&&0==t.offset)return e.width>1}return t.offset>0}return!1},this.expandColumnLeft=function(t,i){if(this.canExpandColumnLeft(t,i)){var n=_(this.children).indexOf(t);if(n>=0){if(n>0){var e=this.children[n-1];i&&0==t.offset?e.width--:t.offset--}else t.offset--;t.width++}}},this.canContractColumnLeft=function(t,i){var n=_(this.children).indexOf(t);return n>=0?t.width>1:!1},this.contractColumnLeft=function(t,i){if(this.canContractColumnLeft(t,i)){var n=_(this.children).indexOf(t);if(n>=0){if(n>0){var e=this.children[n-1];i&&0==t.offset?e.width++:t.offset++}else t.offset++;t.width--}}},this.evenColumns=function(){if(0!=this.children.length){var t=Math.floor(12/this.children.length);_(this.children).each(function(i){i.width=t,i.offset=0});var i=12%this.children.length;i>0&&c(i)}};var f=this.pasteChild;this.pasteChild=function(t){"Column"==t.type?this.beginAddColumn(t.width)&&(this.commitAddColumn(),f.call(this,t)):this.parent&&this.parent.pasteChild(t)},this.toObject=function(){var t=this.elementToObject();return t.children=this.childrenToObject(),t}},t.Row.from=function(i){var n=new t.Row(i.data,i.htmlId,i.htmlClass,i.htmlStyle,i.isTemplated,t.childrenFrom(i.children));return n.toolboxIcon=i.toolboxIcon,n.toolboxLabel=i.toolboxLabel,n.toolboxDescription=i.toolboxDescription,n}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t){t.Column=function(i,n,e,h,o,s,r,l){t.Element.call(this,"Column",i,n,e,h,o),t.Container.call(this,["Grid","Content"],l),this.width=s,this.offset=r;var c=!1,a=0,d=0;this.beginChange=function(){if(c)throw new Error("Column already has a pending change.");c=!0,a=this.width,d=this.offset},this.commitChange=function(){if(!c)throw new Error("Column has no pending change.");a=0,d=0,c=!1},this.rollbackChange=function(){if(!c)throw new Error("Column has no pending change.");this.width=a,this.offset=d,a=0,d=0,c=!1},this.canSplit=function(){return this.width>1},this.split=function(){if(this.canSplit()){var i=Math.floor(this.width/2),n=t.Column.from({data:null,htmlId:null,htmlClass:null,htmlStyle:null,width:i,offset:0,children:[]});this.width=this.width-i,this.parent.insertChild(n,this),n.setIsFocused()}},this.canContractRight=function(t){return this.parent.canContractColumnRight(this,t)},this.contractRight=function(t){this.parent.contractColumnRight(this,t)},this.canExpandRight=function(t){return this.parent.canExpandColumnRight(this,t)},this.expandRight=function(t){this.parent.expandColumnRight(this,t)},this.canExpandLeft=function(t){return this.parent.canExpandColumnLeft(this,t)},this.expandLeft=function(t){this.parent.expandColumnLeft(this,t)},this.canContractLeft=function(t){return this.parent.canContractColumnLeft(this,t)},this.contractLeft=function(t){this.parent.contractColumnLeft(this,t)},this.toObject=function(){var t=this.elementToObject();return t.width=this.width,t.offset=this.offset,t.children=this.childrenToObject(),t}},t.Column.from=function(i){var n=new t.Column(i.data,i.htmlId,i.htmlClass,i.htmlStyle,i.isTemplated,i.width,i.offset,t.childrenFrom(i.children));return n.toolboxIcon=i.toolboxIcon,n.toolboxLabel=i.toolboxLabel,n.toolboxDescription=i.toolboxDescription,n},t.Column.times=function(i){return _.times(i,function(n){return t.Column.from({data:null,htmlId:null,htmlClass:null,isTemplated:!1,width:12/i,offset:0,children:[]})})}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t){t.Content=function(i,n,e,h,o,s,r,l,c,a){t.Element.call(this,"Content",i,n,e,h,o),this.contentType=s,this.contentTypeLabel=r,this.contentTypeClass=l,this.html=c,this.hasEditor=a,this.getInnerText=function(){return $($.parseHTML("
"+this.html+"
")).text()},this.setHtml=function(t){this.html=t,this.htmlUnsafe=t},this.toObject=function(){return{type:"Content"}},this.toObject=function(){var t=this.elementToObject();return t.contentType=this.contentType,t.contentTypeLabel=this.contentTypeLabel,t.contentTypeClass=this.contentTypeClass,t.html=this.html,t.hasEditor=a,t},this.setHtml(c)},t.Content.from=function(i){var n=new t.Content(i.data,i.htmlId,i.htmlClass,i.htmlStyle,i.isTemplated,i.contentType,i.contentTypeLabel,i.contentTypeClass,i.html,i.hasEditor);return n}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t,i){i.Html=function(n,e,h,o,s,r,l,c,a,d){i.Element.call(this,"Html",n,e,h,o,s),this.contentType=r,this.contentTypeLabel=l,this.contentTypeClass=c,this.html=a,this.hasEditor=d,this.isContainable=!0,this.getInnerText=function(){return t(t.parseHTML("
"+this.html+"
")).text()},this.setHtml=function(t){this.html=t,this.htmlUnsafe=t},this.toObject=function(){return{type:"Html"}},this.toObject=function(){var t=this.elementToObject();return t.contentType=this.contentType,t.contentTypeLabel=this.contentTypeLabel,t.contentTypeClass=this.contentTypeClass,t.html=this.html,t.hasEditor=d,t};var u=this.getEditorObject;this.getEditorObject=function(){var i=u();return t.extend(i,{Content:this.html})},this.setHtml(a)},i.Html.from=function(t){var n=new i.Html(t.data,t.htmlId,t.htmlClass,t.htmlStyle,t.isTemplated,t.contentType,t.contentTypeLabel,t.contentTypeClass,t.html,t.hasEditor);return n},i.registerFactory("Html",function(t){return i.Html.from(t)})}(jQuery,LayoutEditor||(LayoutEditor={})); \ No newline at end of file +var LayoutEditor;!function(t){Array.prototype.move=function(t,i){this.splice(i,0,this.splice(t,1)[0])},t.childrenFrom=function(i){return _(i).map(function(i){return t.elementFrom(i)})};var i=t.registerFactory=function(i,n){var e=t.factories=t.factories||{};e[i]=n};i("Canvas",function(i){return t.Canvas.from(i)}),i("Grid",function(i){return t.Grid.from(i)}),i("Row",function(i){return t.Row.from(i)}),i("Column",function(i){return t.Column.from(i)}),i("Content",function(i){return t.Content.from(i)}),t.elementFrom=function(i){var n=t.factories[i.type];if(!n)throw new Error('No element with type "'+i.type+'" was found.');var e=n(i);return e},t.setModel=function(t,i){$(t).scope().element=i},t.getModel=function(t){return $(t).scope().element}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t){t.Editor=function(i,n){this.config=i,this.canvas=t.Canvas.from(n),this.initialState=JSON.stringify(this.canvas.toObject()),this.activeElement=null,this.focusedElement=null,this.dropTargetElement=null,this.isDragging=!1,this.inlineEditingIsActive=!1,this.isResizing=!1,this.resetToolboxElements=function(){this.toolboxElements=[t.Row.from({children:[]})]},this.isDirty=function(){var t=JSON.stringify(this.canvas.toObject());return this.initialState!=t},this.resetToolboxElements(),this.canvas.setEditor(this)}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t){t.Element=function(t,i,n,e,o,h,s){if(!t)throw new Error("Parameter 'type' is required.");this.type=t,this.data=i,this.htmlId=n,this.htmlClass=e,this.htmlStyle=o,this.isTemplated=h,this.rule=s,this.editor=null,this.parent=null,this.setIsFocusedEventHandlers=[],this.setEditor=function(t){this.editor=t,this.children&&_.isArray(this.children)&&_(this.children).each(function(i){i.setEditor(t)})},this.setParent=function(t){this.parent=t,this.parent.linkChild&&this.parent.linkChild(this)},this.setIsTemplated=function(t){this.isTemplated=t,this.children&&_.isArray(this.children)&&_(this.children).each(function(i){i.setIsTemplated(t)})},this.getIsActive=function(){return this.editor?this.editor.activeElement===this&&!this.getIsFocused():!1},this.setIsActive=function(t){this.editor&&(this.editor.isDragging||this.editor.inlineEditingIsActive||this.editor.isResizing||(this.editor.activeElement=t?this:this.parent))},this.getIsFocused=function(){return this.editor?this.editor.focusedElement===this:!1},this.allowSealedFocus=function(){return!1},this.setIsFocused=function(){this.editor&&(!this.isTemplated||this.allowSealedFocus())&&(this.editor.isDragging||this.editor.inlineEditingIsActive||this.editor.isResizing||(this.editor.focusedElement=this,_(this.setIsFocusedEventHandlers).each(function(t){try{t()}catch(i){}})))},this.getIsSelected=function(){return this.getIsFocused()?!0:this.children&&_.isArray(this.children)?_(this.children).any(function(t){return t.getIsSelected()}):!1},this.getIsDropTarget=function(){return this.editor?this.editor.dropTargetElement===this:!1},this.setIsDropTarget=function(t){this.editor&&(this.editor.dropTargetElement=t?this:null)},this.canDelete=function(){return!!this.parent},this["delete"]=function(){this.parent&&this.parent.deleteChild(this)},this.canMoveUp=function(){return this.parent?this.parent.canMoveChildUp(this):!1},this.moveUp=function(){this.parent&&this.parent.moveChildUp(this)},this.canMoveDown=function(){return this.parent?this.parent.canMoveChildDown(this):!1},this.moveDown=function(){this.parent&&this.parent.moveChildDown(this)},this.elementToObject=function(){return{type:this.type,data:this.data,htmlId:this.htmlId,htmlClass:this.htmlClass,htmlStyle:this.htmlStyle,isTemplated:this.isTemplated,rule:this.rule}},this.getEditorObject=function(){return{}},this.copy=function(t){var i=this.getInnerText();t.setData("text/plain",i);var n=this.toObject(),e=JSON.stringify(n,null," ");t.setData("text/json",e)},this.cut=function(t){this.copy(t),this["delete"]()},this.paste=function(t){this.parent&&this.parent.paste(t)}}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t){t.Container=function(i,n){this.allowedChildTypes=i,this.children=n,this.isContainer=!0;var e=this;this.setChildren=function(t){this.children=t,_(this.children).each(function(t){t.parent=e})},this.setChildren(n),this.getIsSealed=function(){return _(this.children).any(function(t){return t.isTemplated})},this.addChild=function(t){_(this.children).contains(t)||!_(this.allowedChildTypes).contains(t.type)&&!t.isContainable||this.children.push(t),t.setEditor(this.editor),t.setIsTemplated(!1),t.parent=this},this.deleteChild=function(t){var i=_(this.children).indexOf(t);i>=0&&(this.children.splice(i,1),t.getIsActive()&&(this.editor.activeElement=null),t.getIsFocused()&&(this.children.length>i?this.children[i].setIsFocused():i>0?this.children[i-1].setIsFocused():this.setIsFocused()))},this.moveFocusPrevChild=function(t){if(!(this.children.length<2)){var i=_(this.children).indexOf(t);i>0&&this.children[i-1].setIsFocused()}},this.moveFocusNextChild=function(t){if(!(this.children.length<2)){var i=_(this.children).indexOf(t);i0},this.canMoveChildDown=function(t){var i=_(this.children).indexOf(t);return i0?t.width<12:0>e?t.width>1:!1}if(0==t)return!0;var e=t;if(0>e){var o=12-c();e+=o,e>0&&(e=0)}for(;0>e&&_(d.children).any(function(t){return t.offset>0});)for(i=0;ie;i++){var h=d.children[i];h.offset>0&&(h.offset--,e++)}for(;0!=e&&_(d.children).any(n);)for(i=0;i=0?t.width>1:!1},this.contractColumnRight=function(t,i){if(this.canContractColumnRight(t,i)){var n=_(this.children).indexOf(t);if(n>=0&&t.width>1&&(t.width--,this.children.length>n+1)){var e=this.children[n+1];i&&0==e.offset?e.width++:e.offset++}}},this.canExpandColumnRight=function(t,i){var n=_(this.children).indexOf(t);if(n>=0){if(t.width>=12)return!1;if(this.children.length>n+1){var e=this.children[n+1];return i&&0==e.offset?e.width>1:e.offset>0}return c()<12}return!1},this.expandColumnRight=function(t,i){if(this.canExpandColumnRight(t,i)){var n=_(this.children).indexOf(t);if(n>=0){if(this.children.length>n+1){var e=this.children[n+1];i&&0==e.offset?e.width--:e.offset--}t.width++}}},this.canExpandColumnLeft=function(t,i){var n=_(this.children).indexOf(t);if(n>=0){if(t.width>=12)return!1;if(n>0){var e=this.children[n-1];if(i&&0==t.offset)return e.width>1}return t.offset>0}return!1},this.expandColumnLeft=function(t,i){if(this.canExpandColumnLeft(t,i)){var n=_(this.children).indexOf(t);if(n>=0){if(n>0){var e=this.children[n-1];i&&0==t.offset?e.width--:t.offset--}else t.offset--;t.width++}}},this.canContractColumnLeft=function(t,i){var n=_(this.children).indexOf(t);return n>=0?t.width>1:!1},this.contractColumnLeft=function(t,i){if(this.canContractColumnLeft(t,i)){var n=_(this.children).indexOf(t);if(n>=0){if(n>0){var e=this.children[n-1];i&&0==t.offset?e.width++:t.offset++}else t.offset++;t.width--}}},this.evenColumns=function(){if(0!=this.children.length){var t=Math.floor(12/this.children.length);_(this.children).each(function(i){i.width=t,i.offset=0});var i=12%this.children.length;i>0&&a(i)}};var m=this.pasteChild;this.pasteChild=function(t){"Column"==t.type?this.beginAddColumn(t.width)&&(this.commitAddColumn(),m.call(this,t)):this.parent&&this.parent.pasteChild(t)},this.toObject=function(){var t=this.elementToObject();return t.children=this.childrenToObject(),t}},t.Row.from=function(i){var n=new t.Row(i.data,i.htmlId,i.htmlClass,i.htmlStyle,i.isTemplated,i.rule,t.childrenFrom(i.children));return n.toolboxIcon=i.toolboxIcon,n.toolboxLabel=i.toolboxLabel,n.toolboxDescription=i.toolboxDescription,n}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t){t.Column=function(i,n,e,o,h,s,r,l,c,a){t.Element.call(this,"Column",i,n,e,o,h,c),t.Container.call(this,["Grid","Content"],a),this.width=s,this.offset=r,this.collapsible=l;var d=!1,u=0,f=0;this.allowSealedFocus=function(){return 0===this.children.length},this.beginChange=function(){if(d)throw new Error("Column already has a pending change.");d=!0,u=this.width,f=this.offset},this.commitChange=function(){if(!d)throw new Error("Column has no pending change.");u=0,f=0,d=!1},this.rollbackChange=function(){if(!d)throw new Error("Column has no pending change.");this.width=u,this.offset=f,u=0,f=0,d=!1},this.canSplit=function(){return this.width>1},this.split=function(){if(this.canSplit()){var i=Math.floor(this.width/2),n=t.Column.from({data:null,htmlId:null,htmlClass:null,htmlStyle:null,width:i,offset:0,children:[]});this.width=this.width-i,this.parent.insertChild(n,this),n.setIsFocused()}},this.canContractRight=function(t){return this.parent.canContractColumnRight(this,t)},this.contractRight=function(t){this.parent.contractColumnRight(this,t)},this.canExpandRight=function(t){return this.parent.canExpandColumnRight(this,t)},this.expandRight=function(t){this.parent.expandColumnRight(this,t)},this.canExpandLeft=function(t){return this.parent.canExpandColumnLeft(this,t)},this.expandLeft=function(t){this.parent.expandColumnLeft(this,t)},this.canContractLeft=function(t){return this.parent.canContractColumnLeft(this,t)},this.contractLeft=function(t){this.parent.contractColumnLeft(this,t)},this.toObject=function(){var t=this.elementToObject();return t.width=this.width,t.offset=this.offset,t.collapsible=this.collapsible,t.children=this.childrenToObject(),t}},t.Column.from=function(i){var n=new t.Column(i.data,i.htmlId,i.htmlClass,i.htmlStyle,i.isTemplated,i.width,i.offset,i.collapsible,i.rule,t.childrenFrom(i.children));return n.toolboxIcon=i.toolboxIcon,n.toolboxLabel=i.toolboxLabel,n.toolboxDescription=i.toolboxDescription,n},t.Column.times=function(i){return _.times(i,function(n){return t.Column.from({data:null,htmlId:null,htmlClass:null,isTemplated:!1,width:12/i,offset:0,collapsible:null,children:[]})})}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t){t.Content=function(i,n,e,o,h,s,r,l,c,a,d){t.Element.call(this,"Content",i,n,e,o,h,d),this.contentType=s,this.contentTypeLabel=r,this.contentTypeClass=l,this.html=c,this.hasEditor=a,this.getInnerText=function(){return $($.parseHTML("
"+this.html+"
")).text()},this.setHtml=function(t){this.html=t,this.htmlUnsafe=t},this.toObject=function(){return{type:"Content"}},this.toObject=function(){var t=this.elementToObject();return t.contentType=this.contentType,t.contentTypeLabel=this.contentTypeLabel,t.contentTypeClass=this.contentTypeClass,t.html=this.html,t.hasEditor=a,t},this.setHtml(c)},t.Content.from=function(i){var n=new t.Content(i.data,i.htmlId,i.htmlClass,i.htmlStyle,i.isTemplated,i.contentType,i.contentTypeLabel,i.contentTypeClass,i.html,i.hasEditor,i.rule);return n}}(LayoutEditor||(LayoutEditor={}));var LayoutEditor;!function(t,i){i.Html=function(n,e,o,h,s,r,l,c,a,d,u){i.Element.call(this,"Html",n,e,o,h,s,u),this.contentType=r,this.contentTypeLabel=l,this.contentTypeClass=c,this.html=a,this.hasEditor=d,this.isContainable=!0,this.getInnerText=function(){return t(t.parseHTML("
"+this.html+"
")).text()},this.setHtml=function(t){this.html=t,this.htmlUnsafe=t},this.toObject=function(){return{type:"Html"}},this.toObject=function(){var t=this.elementToObject();return t.contentType=this.contentType,t.contentTypeLabel=this.contentTypeLabel,t.contentTypeClass=this.contentTypeClass,t.html=this.html,t.hasEditor=d,t};var f=this.getEditorObject;this.getEditorObject=function(){var i=f();return t.extend(i,{Content:this.html})},this.setHtml(a)},i.Html.from=function(t){var n=new i.Html(t.data,t.htmlId,t.htmlClass,t.htmlStyle,t.isTemplated,t.contentType,t.contentTypeLabel,t.contentTypeClass,t.html,t.hasEditor,t.rule);return n},i.registerFactory("Html",function(t){return i.Html.from(t)})}(jQuery,LayoutEditor||(LayoutEditor={})); \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models/Element.js b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models/Element.js index c5ae2c1a0..7da60a89d 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models/Element.js +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Scripts/Models/Element.js @@ -167,7 +167,6 @@ this.copy = function (clipboardData) { var text = this.getInnerText(); clipboardData.setData("text/plain", text); - console.log(text); var data = this.toObject(); var json = JSON.stringify(data, null, "\t"); diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor.css b/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor.css index 37f842572..989b5f8fa 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor.css +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor.css @@ -23,6 +23,11 @@ .layout-editor > .layout-canvas-wrapper > .layout-toolbar-container > .mce-panel { width: 100% !important; } +.layout-editor > .layout-canvas-wrapper .layout-content > .layout-element-wrapper .layout-content-markup > .layout-placeholder { + border: 1px dashed #ccc; + padding: 0.2em 0.4em; + background: #e8e8e8; +} .layout-editor .layout-element { position: relative; @@ -221,10 +226,12 @@ display: block; } -.layout-editor .layout-content { +.layout-editor .layout-content, +.layout-editor .layout-html { min-height: 1em; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup { padding: 2px; overflow-x: hidden; line-height: normal; @@ -261,96 +268,147 @@ table[rules=all i] > tfoot > tr > td, table[rules=all i] > tfoot > tr > th { border-color: black; }*/ } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup * { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup *, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup * { margin: 0; padding: 0; box-sizing: content-box; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup address, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup address, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup blockquote, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup blockquote, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup center, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup center, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup div, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup div, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup figure, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup figure, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup figcaption, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup figcaption, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup footer, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup footer, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup form, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup form, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup header, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup header, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup hr, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup hr, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup legend, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup legend, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup listing, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup listing, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup p, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup p, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup plaintext, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup plaintext, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup pre, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup xmp { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup pre, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup xmp, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup xmp { display: block; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup blockquote, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup blockquote, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup figure, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup figure, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup listing, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup listing, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup p, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup p, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup plaintext, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup plaintext, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup pre, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup xmp { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup pre, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup xmp, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup xmp { margin-top: 1em; margin-bottom: 1em; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup blockquote, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup figure { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup blockquote, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup figure, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup figure { margin-left: 40px; margin-right: 40px; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup address { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup address, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup address { font-style: italic; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup listing, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup listing, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup plaintext, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup plaintext, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup pre, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup xmp { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup pre, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup xmp, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup xmp { font-family: monospace; white-space: pre; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup cite, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup cite, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dfn, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dfn, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup em, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup em, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup i, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup var { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup i, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup var, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup var { font-style: italic; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup b, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup strong { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup b, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup strong, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup strong { font-weight: bolder; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup code, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup code, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup kbd, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup kbd, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup samp, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tt { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup samp, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tt, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tt { font-family: monospace; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup big { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup big, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup big { font-size: larger; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup small { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup small, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup small { font-size: smaller; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sub { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sub, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup sub { vertical-align: sub; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sup { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sup, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup sup { vertical-align: super; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sub, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sup { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup sub, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sup, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup sup { line-height: normal; font-size: smaller; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ruby { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ruby, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ruby { display: ruby; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rb { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rb, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rb { display: ruby-base; white-space: nowrap; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rt { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rt, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rt { display: ruby-text; white-space: nowrap; font-size: 50%; @@ -358,336 +416,510 @@ table[rules=all i] > tfoot > tr > td, table[rules=all i] > tfoot > tr > th { -webkit-text-emphasis: none; text-emphasis: none; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rbc { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rbc, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rbc { display: ruby-base-container; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rtc { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rtc, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rtc { display: ruby-text-container; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ruby, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ruby, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rb, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rb, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rt, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rt, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rbc, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rtc { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rbc, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rtc, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rtc { unicode-bidi: isolate; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :link { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :link, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup :link { color: #0000EE; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :visited { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :visited, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup :visited { color: #551A8B; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :link, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :visited { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup :link, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :visited, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup :visited { text-decoration: underline; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup a:link[rel~=help], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup a:link[rel~=help], .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup a:visited[rel~=help], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup a:visited[rel~=help], .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup area:link[rel~=help], -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup area:visited[rel~=help] { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup area:link[rel~=help], +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup area:visited[rel~=help], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup area:visited[rel~=help] { cursor: help; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :focus { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :focus, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup :focus { outline: auto; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup mark { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup mark, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup mark { background: yellow; color: black; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup abbr[title], -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup acronym[title] { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup abbr[title], +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup acronym[title], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup acronym[title] { text-decoration: dotted underline; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ins, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup u { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ins, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup u, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup u { text-decoration: underline; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup del, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup del, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup s, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup strike { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup s, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup strike, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup strike { text-decoration: line-through; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup blink { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup blink, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup blink { text-decoration: blink; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup q::before { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup q::before, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup q::before { content: open-quote; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup q::after { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup q::after, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup q::after { content: close-quote; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup br { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup br, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup br { content: '\A'; white-space: pre; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup nobr { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup nobr, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup nobr { white-space: nowrap; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup wbr { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup wbr, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup wbr { content: '\200B'; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup nobr wbr { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup nobr wbr, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup nobr wbr { white-space: normal; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup article, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup article, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup aside, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup aside, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h1, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h1, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h2, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h2, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h3, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h3, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h4, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h4, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h5, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h5, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h6, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h6, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup hgroup, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup hgroup, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup nav, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup section { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup nav, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup section, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup section { display: block; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h1 { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h1, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h1 { margin-top: 0.67em; margin-bottom: 0.67em; font-size: 2.00em; font-weight: bold; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h2 { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h2, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h2 { margin-top: 0.83em; margin-bottom: 0.83em; font-size: 1.50em; font-weight: bold; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h3 { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h3, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h3 { margin-top: 1.00em; margin-bottom: 1.00em; font-size: 1.17em; font-weight: bold; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h4 { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h4, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h4 { margin-top: 1.33em; margin-bottom: 1.33em; font-size: 1.00em; font-weight: bold; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h5 { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h5, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h5 { margin-top: 1.67em; margin-bottom: 1.67em; font-size: 0.83em; font-weight: bold; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h6 { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h6, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h6 { margin-top: 2.33em; margin-bottom: 2.33em; font-size: 0.67em; font-weight: bold; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dd, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dd, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dt, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dt, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul { display: block; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup li { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup li, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup li { display: list-item; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul { margin-top: 1em; margin-bottom: 1em; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dir, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir dir, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dl, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir dl, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ol, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ol, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ul, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ul, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl dir, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl dir, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl dl, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl dl, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl ol, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl ol, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl ul, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl ul, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dir, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol dir, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dl, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol dl, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ol, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ol, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ul, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ul, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dir, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul dir, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dl, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul dl, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ol, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ol, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ul { margin-top: 0; margin-bottom: 0; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dd { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dd, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dd { margin-left: 40px; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul { padding-left: 40px; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol { list-style-type: decimal; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul { list-style-type: disc; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dir, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir dir, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ul, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ul, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dir, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol dir, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ul, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ul, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dir, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul dir, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ul { list-style-type: circle; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dir dir, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir dir dir, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dir ul, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir dir ul, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ol dir, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ol dir, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ol ul, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ol ul, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ul dir, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ul dir, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ul ul, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ul ul, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dir dir, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol dir dir, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dir ul, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol dir ul, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ol dir, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ol dir, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ol ul, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ol ul, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ul dir, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ul dir, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ul ul, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ul ul, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dir dir, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul dir dir, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dir ul, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul dir ul, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ol dir, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ol dir, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ol ul, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ol ul, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul dir, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul ul { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ul dir, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul ul, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ul ul { list-style-type: square; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup table { display: table; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup caption { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup caption, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup caption { display: table-caption; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup colgroup, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup colgroup[hidden] { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup colgroup, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup colgroup[hidden], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup colgroup[hidden] { display: table-column-group; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup col, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup col[hidden] { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup col, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup col[hidden], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup col[hidden] { display: table-column; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead[hidden] { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup thead, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead[hidden], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup thead[hidden] { display: table-header-group; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody[hidden] { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tbody, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody[hidden], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tbody[hidden] { display: table-row-group; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot[hidden] { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tfoot, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot[hidden], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tfoot[hidden] { display: table-footer-group; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr[hidden] { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tr, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr[hidden], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tr[hidden] { display: table-row; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td[hidden], -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th[hidden] { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td[hidden], +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th[hidden], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th[hidden] { display: table-cell; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup colgroup[hidden], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup colgroup[hidden], .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup col[hidden], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup col[hidden], .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead[hidden], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup thead[hidden], .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody[hidden], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tbody[hidden], .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot[hidden], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tfoot[hidden], .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr[hidden], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tr[hidden], .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td[hidden], -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th[hidden] { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td[hidden], +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th[hidden], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th[hidden] { visibility: collapse; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup table { box-sizing: border-box; border-spacing: 2px; border-collapse: separate; text-indent: initial; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th { padding: 1px; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th { font-weight: bold; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup thead, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tbody, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table > tr { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tfoot, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table > tr, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup table > tr { vertical-align: middle; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tr, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th { vertical-align: inherit; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup table, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th { border-color: gray; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup thead, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tbody, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tfoot, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tr { border-color: inherit; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup select, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup select, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup option, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup option, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup optgroup, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup optgroup, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup button, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup button, .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup textarea, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup keygen { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup textarea, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup keygen, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup keygen { text-indent: initial; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup textarea { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup textarea, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup textarea { white-space: pre-wrap; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type="radio"], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type="radio"], .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type="checkbox"], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type="checkbox"], .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type="reset"], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type="reset"], .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type="button"], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type="button"], .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type="submit"], +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type="submit"], .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup select, -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup button { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup select, +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup button, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup button { box-sizing: border-box; } .layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type="button"], -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup button { +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type="button"], +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup button, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup button { padding: 0.3em 0.5em; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup hr { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup hr, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup hr { color: gray; border-style: inset; border-width: 1px; margin: 0.5em auto; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup fieldset { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup fieldset, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup fieldset { margin-left: 2px; margin-right: 2px; border: groove 2px ThreeDFace; padding: 0.35em 0.625em 0.75em; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup legend { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup legend, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup legend { padding-left: 2px; padding-right: 2px; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup > *:first-child { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup > *:first-child, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup > *:first-child { margin-top: 0 !important; } -.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup > *:last-child { +.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup > *:last-child, +.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup > *:last-child { margin-bottom: 0 !important; } .layout-editor .layout-content.layout-content-image > .layout-element-wrapper > .layout-content-markup > img, -.layout-editor .layout-content.layout-content-vector-image > .layout-element-wrapper > .layout-content-markup > img { +.layout-editor .layout-html.layout-content-image > .layout-element-wrapper > .layout-content-markup > img, +.layout-editor .layout-content.layout-content-vector-image > .layout-element-wrapper > .layout-content-markup > img, +.layout-editor .layout-html.layout-content-vector-image > .layout-element-wrapper > .layout-content-markup > img { display: block; width: 100%; max-width: 100%; @@ -719,6 +951,8 @@ table[rules=all i] > tfoot > tr > td, table[rules=all i] > tfoot > tr > th { .layout-editor > .layout-toolbox-wrapper > .layout-toolbox.sticky-top { position: fixed; top: 0; + max-height: 100%; + overflow-y: auto; } .layout-editor > .layout-toolbox-wrapper > .layout-toolbox.sticky-bottom { position: absolute; @@ -782,6 +1016,10 @@ table[rules=all i] > tfoot > tr > td, table[rules=all i] > tfoot > tr > th { cursor: default; white-space: nowrap; line-height: normal; + min-width: 300px; +} +.layout-editor .layout-popup.wide { + width: 600px; } .layout-editor .layout-popup .layout-popup-flex { display: -webkit-flex; @@ -806,9 +1044,13 @@ table[rules=all i] > tfoot > tr > td, table[rules=all i] > tfoot > tr > th { background-color: #f3f4f5; cursor: pointer; } +.layout-editor .layout-popup .layout-popup-input input[type='text'], +.layout-editor .layout-popup .layout-popup-input textarea { + width: 100%; +} .layout-editor .layout-popup .layout-popup-input > label { display: block; font-size: 0.9em; } -/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["Editor.less","LayoutEditor.css","Element.less","Container.less","Canvas.less","Row.less","Column.less","Content.less","Reset.less","Toolbox.less","Popup.less"],"names":[],"mappings":"AAEA;EACI,sBAAA;EAAA,qBAAA;EAAA,cAAA;EACA,gBAAA;EACA,gBAAA;EACA,6BAAA;MAAA,wBAAA;UAAA,qBAAA;CCDH;ADHD;EAOQ,qBAAA;MAAA,qBAAA;UAAA,aAAA;EACA,0BAAA;EACA,0BAAA;CCDP;ADRD;EAYY,cAAA;EACA,oBAAA;EACA,iBAAA;CCDX;ADbD;EAiBgB,uBAAA;CCDf;;AChBD;EAEQ,mBAAA;EACA,cAAA;EACA,gBAAA;EACA,iBAAA;EACA,WAAA;CDkBP;ACfO;EACI,eAAA;CDiBX;AC3BD;EAegB,cAAA;EACA,mBAAA;EACA,UAAA;EACA,YAAA;EACA,aAAA;EACA,eAAA;EACA,iBAAA;EACA,oBAAA;EACA,kBAAA;EACA,uBAAA;CDef;ACvCD;EA2BoB,sBAAA;EACA,aAAA;EACA,mBAAA;CDenB;AC5CD;EAiCoB,gBAAA;CDcnB;AC/CD;EAqCoB,cAAA;EACA,YAAA;EACA,gBAAA;EACA,mBAAA;CDanB;ACrDD;EA6CgB,WAAA;EACA,WAAA;CDWf;ACzDD;EAqDQ,iBAAA;CDOP;ACJG;;EAGQ,kBAAA;EACA,oBAAA;CDKX;ACTG;;EAOY,aAAA;CDMf;ACbG;EAcQ,uCAAA;CDEX;AChBG;EAiBY,eAAA;EACA,YAAA;EACA,2CAAA;CDEf;ACrBG;EA2BQ,sBAAA;CDHX;ACxBG;EA8BY,eAAA;EACA,0BAAA;EACA,eAAA;CDHf;AC7BG;EAmCgB,sBAAA;CDHnB;ACImB;EACI,0BAAA;CDFvB;ACKmB;EACI,gBAAA;EACA,gCAAA;CDHvB;ACKuB;EACI,0BAAA;CDH3B;ACOmB;EACI,eAAA;EACA,0BAAA;CDLvB;ACOuB;EACI,0BAAA;CDL3B;ACjDG;EA+DQ,2CAAA;CDXX;AC5GD;EA4HQ,cAAA;CDbP;AC/GD;EAiIQ,uDAAA;CDfP;AClHD;EAoIY,eAAA;EACA,+BAAA;EACA,iBAAA;EACA,sCAAA;EACA,2CAAA;CDfX;ACzHD;EA+IY,gBAAA;EACA,iBAAA;CDnBX;;AE7HD;EAMgB,cAAA;EACA,+BAAA;MAAA,2BAAA;UAAA,uBAAA;EACA,aAAA;EACA,iBAAA;EACA,4CAAA;EACA,mBAAA;EACA,cAAA;EACA,gCAAA;MAAA,sBAAA;UAAA,wBAAA;EACA,gBAAA;EACA,mBAAA;EACA,aAAA;EACA,mBAAA;CF2Hf;AE5ID;EAqBgB,cAAA;CF0Hf;AE/ID;EAyBoB,iBAAA;CFyHnB;AElJD;EA8BoB,cAAA;CFuHnB;AEnHW;EAEQ,sBAAA;EAAA,qBAAA;EAAA,cAAA;CFoHnB;AEtHW;EAMQ,mBAAA;EACA,OAAA;EACA,SAAA;EACA,UAAA;EACA,QAAA;CFmHnB;AE7GG;EAGY,4CAAA;CF6Gf;AEhHG;EAMgB,aAAA;CF6GnB;AEnHG;EAWY,cAAA;CF2Gf;AEtHG;EAcgB,cAAA;CF2GnB;;AG3KD;EAGY,cAAA;CH4KX;;AI7KO;EAEQ,2DAAA;CJ+Kf;AIjLO;EAIY,4BAAA;CJgLnB;AIpLO;EASQ,0BAAA;CJ8Kf;AIvLO;EAWY,0BAAA;CJ+KnB;;AK5LD;EAIgB,cAAA;EACA,mBAAA;EACA,YAAA;EACA,OAAA;EACA,YAAA;EACA,aAAA;EACA,mBAAA;CL4Lf;AKtMD;EAcgB,WAAA;CL2Lf;AKzMD;EAkBgB,YAAA;CL0Lf;AKtLO;EACI,eAAA;CLwLX;;AM/MD;EAEQ,gBAAA;CNiNP;AMnND;EAOgB,aAAA;EACA,mBAAA;EACA,oBAAA;EN+Md,yFAAyF;EACzF,qCAAqC;EACrC,qCAAqC;EACrC,uDAAuD;EACvD,wDAAwD;EACxD;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BC;CACF;AMxPD;ECDI,UAAA;EACA,WAAA;EACA,wBAAA;CP4PH;AM7PD;;;;;;;;;;;;;;;;ECMI,eAAA;CPyQH;AM/QD;;;;;;;ECUI,gBAAA;EACA,mBAAA;CP8QH;AMzRD;;ECeI,kBAAA;EACA,mBAAA;CP8QH;AM9RD;ECoBI,mBAAA;CP6QH;AMjSD;;;;ECwBI,uBAAA;EACA,iBAAA;CP+QH;AMxSD;;;;;EC6BI,mBAAA;CPkRH;AM/SD;;ECiCI,oBAAA;CPkRH;AMnTD;;;;ECqCI,uBAAA;CPoRH;AMzTD;ECyCI,kBAAA;CPmRH;AM5TD;EC6CI,mBAAA;CPkRH;AM/TD;ECiDI,oBAAA;CPiRH;AMlUD;ECqDI,sBAAA;CPgRH;AMrUD;;ECyDI,oBAAA;EACA,mBAAA;CPgRH;AM1UD;EC+DI,cAAA;CP8QH;AM7UD;ECmEI,mBAAA;EACA,oBAAA;CP6QH;AMjVD;ECwEI,mBAAA;EACA,oBAAA;EACA,eAAA;EACA,8BAAA;EACA,4BAAA;UAAA,oBAAA;CP4QH;AMxVD;ECgFI,6BAAA;CP2QH;AM3VD;ECoFI,6BAAA;CP0QH;AM9VD;;;;;ECwFI,sBAAA;CP6QH;AMrWD;EC6FI,eAAA;CP2QH;AMxWD;ECiGI,eAAA;CP0QH;AM3WD;;ECqGI,2BAAA;CP0QH;AM/WD;;;;EC0GI,aAAA;CP2QH;AMrXD;EC8GI,cAAA;CP0QH;AMxXD;ECkHI,mBAAA;EACA,aAAA;CPyQH;AM5XD;;ECuHI,kCAAA;CPyQH;AMhYD;;EC2HI,2BAAA;CPyQH;AMpYD;;;EC+HI,8BAAA;CP0QH;AMzYD;ECmII,uBAAA;CPyQH;AM5YD;ECuII,oBAAA;CPwQH;AM/YD;EC2II,qBAAA;CPuQH;AMlZD;EC+II,cAAA;EACA,iBAAA;CPsQH;AMtZD;ECoJI,oBAAA;CPqQH;AMzZD;ECwJI,iBAAA;CPoQH;AM5ZD;EC4JI,oBAAA;CPmQH;AM/ZD;;;;;;;;;;;ECgKI,eAAA;CP4QH;AM5aD;ECoKI,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CP2QH;AMlbD;EC2KI,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CP0QH;AMxbD;ECkLI,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CPyQH;AM9bD;ECyLI,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CPwQH;AMpcD;ECgMI,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CPuQH;AM1cD;ECuMI,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CPsQH;AMhdD;;;;;;EC8MI,eAAA;CP0QH;AMxdD;ECkNI,mBAAA;CPyQH;AM3dD;;;;ECsNI,gBAAA;EACA,mBAAA;CP2QH;AMleD;;;;;;;;;;;;;;;;EC8NQ,cAAA;EACA,iBAAA;CPsRP;AMrfD;ECmOI,kBAAA;CPqRH;AMxfD;;;ECwOI,mBAAA;CPqRH;AM7fD;EC6OI,yBAAA;CPmRH;AMhgBD;;ECiPI,sBAAA;CPmRH;AMpgBD;;;;;;ECuPQ,wBAAA;CPqRP;AM5gBD;;;;;;;;;;;;;;;;;;ECmQY,wBAAA;CP6RX;AMhiBD;ECuQI,eAAA;CP4RH;AMniBD;EC2QI,uBAAA;CP2RH;AMtiBD;;EC+QI,4BAAA;CP2RH;AM1iBD;;ECmRI,sBAAA;CP2RH;AM9iBD;;ECuRI,4BAAA;CP2RH;AMljBD;;EC2RI,yBAAA;CP2RH;AMtjBD;;EC+RI,4BAAA;CP2RH;AM1jBD;;ECmSI,mBAAA;CP2RH;AM9jBD;;;;ECuSI,oBAAA;CP6RH;AMpkBD;;;;;;;;EC4SQ,qBAAA;CPkSP;AM9kBD;ECgTI,uBAAA;EACA,oBAAA;EACA,0BAAA;EACA,qBAAA;CPiSH;AMplBD;;ECuTI,aAAA;CPiSH;AMxlBD;EC2TI,kBAAA;CPgSH;AM3lBD;;;;EC+TI,uBAAA;CPkSH;AMjmBD;;;ECmUI,wBAAA;CPmSH;AMtmBD;;;ECuUI,mBAAA;CPoSH;AM3mBD;;;;EC2UI,sBAAA;CPsSH;AMjnBD;;;;;;;EC2WI,qBAAA;CP+QH;AM1nBD;EC+WI,sBAAA;CP8QH;AM7nBD;;;;;;;ECoXI,uBAAA;CPkRH;AMtoBD;;ECwXI,qBAAA;CPkRH;AM1oBD;EC4XI,YAAA;EACA,oBAAA;EACA,kBAAA;EACA,mBAAA;CPiRH;AMhpBD;ECmYI,iBAAA;EACA,kBAAA;EACA,8BAAA;EACA,+BAAA;CPgRH;AMtpBD;EC0YI,kBAAA;EACA,mBAAA;CP+QH;AM1pBD;EAeoB,yBAAA;CN8oBnB;AM7pBD;EAmBoB,4BAAA;CN6oBnB;AMxoBO;;EAEQ,eAAA;EACA,YAAA;EACA,gBAAA;EACA,aAAA;CN0oBf;AMvqBD;;EAmCQ,eAAA;EACA,YAAA;EACA,gBAAA;EACA,aAAA;CNwoBP;;AQ9qBD;EAEQ,mBAAA;EACA,kBAAA;EACA,aAAA;EACA,uBAAA;MAAA,qBAAA;UAAA,eAAA;CRgrBP;AQrrBD;EAQY,0BAAA;EACA,aAAA;EACA,kBAAA;EACA,aAAA;EACA,0BAAA;CRgrBX;AQ9qBW;EACI,gBAAA;EACA,OAAA;CRgrBf;AQ7qBW;EACI,mBAAA;EACA,UAAA;CR+qBf;AQpsBD;EAyBgB,iBAAA;CR8qBf;AQvsBD;EA4BoB,eAAA;EACA,mBAAA;EACA,sBAAA;CR8qBnB;AQ5qBmB;EACI,sBAAA;EACA,YAAA;EACA,kBAAA;EACA,8CAAA;EACA,mBAAA;EACA,iBAAA;CR8qBvB;AQ1qBe;EAEQ,iBAAA;CR2qBvB;AQ7qBe;EAMQ,cAAA;CR0qBvB;AQ1tBD;EAqDoB,gBAAA;CRwqBnB;AQ7tBD;EAyDoB,0BAAA;EACA,uBAAA;EACA,kBAAA;EACA,gBAAA;CRuqBnB;AQnuBD;EA+DwB,sBAAA;EACA,YAAA;EACA,8CAAA;CRuqBvB;AQxuBD;EAqEwB,gBAAA;CRsqBvB;AQ3uBD;EA0EoB,gBAAA;CRoqBnB;;AS9uBD;EAEQ,cAAA;EACA,mBAAA;EACA,UAAA;EAGA,iDAAA;EACA,0BAAA;EACA,eAAA;EACA,0BAAA;EACA,iBAAA;EACA,YAAA;EACA,eAAA;EACA,iBAAA;EACA,gBAAA;EACA,oBAAA;EACA,oBAAA;CTgvBP;ASjwBD;EAoBY,sBAAA;EAAA,qBAAA;EAAA,cAAA;EACA,iBAAA;CTgvBX;ASrwBD;EAwBgB,iBAAA;EACA,iDAAA;EACA,kBAAA;CTgvBf;AS1wBD;EA+BY,iBAAA;CT8uBX;AS7wBD;EAmCY,iBAAA;EACA,kBAAA;EACA,eAAA;CT6uBX;ASlxBD;EAyCY,0BAAA;EACA,gBAAA;CT4uBX;AStxBD;EA+CgB,eAAA;EACA,iBAAA;CT0uBf","file":"LayoutEditor.css","sourcesContent":["@import \"Variables.less\";\n\n.layout-editor {\n    display: flex;\n    margin-top: 1em;\n    font-size: @font-size;\n    align-items: stretch;\n\n    > .layout-canvas-wrapper {\n        flex-grow: 1;\n        background-color: @gray-bg;\n        border: 1px solid @gray-border;\n\n        > .layout-toolbar-container {\n            display: none;\n            margin: @container-padding @container-padding 0;\n            min-height: 71px;\n\n            > .mce-panel {\n                width: 100% !important;\n            }\n        }\n    }\n}\n",".layout-editor {\n  display: flex;\n  margin-top: 1em;\n  font-size: 14px;\n  align-items: stretch;\n}\n.layout-editor > .layout-canvas-wrapper {\n  flex-grow: 1;\n  background-color: #f3f4f5;\n  border: 1px solid #e4e5e6;\n}\n.layout-editor > .layout-canvas-wrapper > .layout-toolbar-container {\n  display: none;\n  margin: 12px 12px 0;\n  min-height: 71px;\n}\n.layout-editor > .layout-canvas-wrapper > .layout-toolbar-container > .mce-panel {\n  width: 100% !important;\n}\n\n.layout-editor .layout-element {\n  position: relative;\n  margin-top: 0;\n  margin-right: 0;\n  margin-bottom: 0;\n  padding: 0;\n}\n.layout-editor .layout-element:not(.layout-column) {\n  margin-left: 0;\n}\n.layout-editor .layout-element > .layout-element-wrapper > .layout-panel {\n  display: none;\n  position: absolute;\n  margin: 0;\n  z-index: 20;\n  height: 25px;\n  padding: 0 6px;\n  list-style: none;\n  white-space: nowrap;\n  line-height: 25px;\n  vertical-align: middle;\n}\n.layout-editor .layout-element > .layout-element-wrapper > .layout-panel > .layout-panel-item {\n  display: inline-block;\n  height: 25px;\n  padding: 1px 6px 0;\n}\n.layout-editor .layout-element > .layout-element-wrapper > .layout-panel > .layout-panel-label {\n  font-size: 13px;\n}\n.layout-editor .layout-element > .layout-element-wrapper > .layout-panel > .layout-panel-action {\n  display: none;\n  width: 28px;\n  cursor: pointer;\n  text-align: center;\n}\n.layout-editor .layout-element > .layout-element-wrapper > .layout-panel-main {\n  top: -27px;\n  left: -2px;\n}\n.layout-editor li.layout-element {\n  list-style: none;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-active,\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused {\n  border-width: 2px;\n  border-style: solid;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-active > .layout-element-wrapper,\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper {\n  margin: -2px;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-active {\n  border-color: rgba(104, 104, 104, 0.1);\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-active > .layout-element-wrapper > .layout-panel-main {\n  display: block;\n  z-index: 30;\n  background-color: rgba(104, 104, 104, 0.1);\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused {\n  border-color: #648721;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel {\n  display: block;\n  background-color: #648721;\n  color: #fefefe;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action {\n  display: inline-block;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action:hover {\n  background-color: #82b02b;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action.disabled {\n  cursor: default;\n  color: rgba(254, 254, 254, 0.4);\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action.disabled:hover {\n  background-color: #648721;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action.active {\n  color: #deff42;\n  background-color: #739b26;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action.active:hover {\n  background-color: #82b02b;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-selected {\n  background-color: rgba(100, 135, 33, 0.08);\n}\n.layout-editor .ui-sortable-placeholder {\n  display: none;\n}\n.layout-editor .layout-element-droptarget {\n  box-shadow: inset 0 0 12px 6px rgba(100, 135, 33, 0.5);\n}\n.layout-editor .layout-element-droptarget .ui-sortable-placeholder {\n  display: block;\n  visibility: visible !important;\n  min-height: 78px;\n  border: 2px dashed #648721 !important;\n  background-color: rgba(100, 135, 33, 0.16);\n}\n.layout-editor .media-thumbnail img {\n  max-width: 100%;\n  max-height: 100%;\n}\n\n.layout-editor .layout-container > .layout-element-wrapper > .layout-container-children-placeholder {\n  display: none;\n  flex-direction: column;\n  margin: 11px;\n  min-height: 80px;\n  border: 1px dashed rgba(124, 124, 124, 0.4);\n  border-radius: 4px;\n  padding: 12px;\n  justify-content: center;\n  font-size: 13px;\n  font-style: italic;\n  opacity: 0.6;\n  text-align: center;\n}\n.layout-editor .layout-container > .layout-element-wrapper > .layout-children {\n  padding: 12px;\n}\n.layout-editor .layout-container > .layout-element-wrapper > .layout-children > .layout-element:not(.layout-container) + .layout-element:not(.layout-container) {\n  margin-top: 12px;\n}\n.layout-editor .layout-container > .layout-element-wrapper > .layout-children > .ui-sortable-helper:first-child + .layout-element:not(.layout-container) {\n  margin-top: 0;\n}\n.layout-editor .layout-container > .layout-element-wrapper.layout-container-empty > .layout-container-children-placeholder {\n  display: flex;\n}\n.layout-editor .layout-container > .layout-element-wrapper.layout-container-empty > .layout-children {\n  position: absolute;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused > .layout-element-wrapper > .layout-children > .layout-element:not(.layout-element-active) {\n  border: 1px dashed rgba(124, 124, 124, 0.6);\n}\n.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused > .layout-element-wrapper > .layout-children > .layout-element:not(.layout-element-active) > .layout-element-wrapper {\n  margin: -1px;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused > .layout-element-wrapper > .layout-children > .layout-container + .layout-container:not(.layout-element-active) {\n  border-top: 0;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused > .layout-element-wrapper > .layout-children > .layout-container + .layout-container:not(.layout-element-active) > .layout-element-wrapper {\n  margin-top: 0;\n}\n\n.layout-editor .layout-canvas #dummy {\n  display: none;\n}\n\n.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget) > .layout-element-wrapper > .layout-children > .layout-element:not(.layout-element-active) {\n  border-top: 1px dashed rgba(124, 124, 124, 0.6) !important;\n}\n.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget) > .layout-element-wrapper > .layout-children > .layout-element:not(.layout-element-active) > .layout-element-wrapper {\n  margin-top: -1px !important;\n}\n.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget) > .layout-element-wrapper > .layout-children > .layout-element + .layout-element:not(.layout-element-active) {\n  border-left: 0 !important;\n}\n.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget) > .layout-element-wrapper > .layout-children > .layout-element + .layout-element:not(.layout-element-active) > .layout-element-wrapper {\n  margin-left: 0 !important;\n}\n\n.layout-editor .layout-column > .layout-element-wrapper > .layout-column-resize-bar {\n  display: none;\n  position: absolute;\n  z-index: 30;\n  top: 0;\n  width: 16px;\n  height: 100%;\n  cursor: col-resize;\n}\n.layout-editor .layout-column > .layout-element-wrapper > .layout-column-resize-bar-left {\n  left: -6px;\n}\n.layout-editor .layout-column > .layout-element-wrapper > .layout-column-resize-bar-right {\n  right: -6px;\n}\n.layout-editor .layout-column.layout-element-focused > .layout-element-wrapper > .layout-column-resize-bar {\n  display: block;\n}\n\n.layout-editor .layout-content {\n  min-height: 1em;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup {\n  padding: 2px;\n  overflow-x: hidden;\n  line-height: normal;\n  /* this color is just a suggestion and can be changed based on implementation feedback */\n  /* this also has bidi implications */\n  /* this also has bidi implications */\n  /* LTR-specific: use 'margin-right' for rtl elements */\n  /* LTR-specific: use 'padding-right' for rtl elements */\n  /*table[rules=none i], table[rules=groups i], table[rules=rows i],\ntable[rules=cols i], table[rules=all i], table[frame=void i],\ntable[frame=above i], table[frame=below i], table[frame=hsides i],\ntable[frame=lhs i], table[frame=rhs i], table[frame=vsides i],\ntable[frame=box i], table[frame=border i],\ntable[rules=none i] > tr > td, table[rules=none i] > tr > th,\ntable[rules=groups i] > tr > td, table[rules=groups i] > tr > th,\ntable[rules=rows i] > tr > td, table[rules=rows i] > tr > th,\ntable[rules=cols i] > tr > td, table[rules=cols i] > tr > th,\ntable[rules=all i] > tr > td, table[rules=all i] > tr > th,\ntable[rules=none i] > thead > tr > td, table[rules=none i] > thead > tr > th,\ntable[rules=groups i] > thead > tr > td, table[rules=groups i] > thead > tr > th,\ntable[rules=rows i] > thead > tr > td, table[rules=rows i] > thead > tr > th,\ntable[rules=cols i] > thead > tr > td, table[rules=cols i] > thead > tr > th,\ntable[rules=all i] > thead > tr > td, table[rules=all i] > thead > tr > th,\ntable[rules=none i] > tbody > tr > td, table[rules=none i] > tbody > tr > th,\ntable[rules=groups i] > tbody > tr > td, table[rules=groups i] > tbody > tr > th,\ntable[rules=rows i] > tbody > tr > td, table[rules=rows i] > tbody > tr > th,\ntable[rules=cols i] > tbody > tr > td, table[rules=cols i] > tbody > tr > th,\ntable[rules=all i] > tbody > tr > td, table[rules=all i] > tbody > tr > th,\ntable[rules=none i] > tfoot > tr > td, table[rules=none i] > tfoot > tr > th,\ntable[rules=groups i] > tfoot > tr > td, table[rules=groups i] > tfoot > tr > th,\ntable[rules=rows i] > tfoot > tr > td, table[rules=rows i] > tfoot > tr > th,\ntable[rules=cols i] > tfoot > tr > td, table[rules=cols i] > tfoot > tr > th,\ntable[rules=all i] > tfoot > tr > td, table[rules=all i] > tfoot > tr > th {\n    border-color: black;\n}*/\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup * {\n  margin: 0;\n  padding: 0;\n  box-sizing: content-box;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup address,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup blockquote,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup center,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup div,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup figure,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup figcaption,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup footer,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup form,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup header,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup hr,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup legend,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup listing,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup p,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup plaintext,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup pre,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup xmp {\n  display: block;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup blockquote,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup figure,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup listing,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup p,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup plaintext,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup pre,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup xmp {\n  margin-top: 1em;\n  margin-bottom: 1em;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup blockquote,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup figure {\n  margin-left: 40px;\n  margin-right: 40px;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup address {\n  font-style: italic;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup listing,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup plaintext,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup pre,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup xmp {\n  font-family: monospace;\n  white-space: pre;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup cite,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dfn,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup em,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup i,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup var {\n  font-style: italic;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup b,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup strong {\n  font-weight: bolder;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup code,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup kbd,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup samp,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tt {\n  font-family: monospace;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup big {\n  font-size: larger;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup small {\n  font-size: smaller;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sub {\n  vertical-align: sub;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sup {\n  vertical-align: super;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sub,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sup {\n  line-height: normal;\n  font-size: smaller;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ruby {\n  display: ruby;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rb {\n  display: ruby-base;\n  white-space: nowrap;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rt {\n  display: ruby-text;\n  white-space: nowrap;\n  font-size: 50%;\n  font-variant-east-asian: ruby;\n  text-emphasis: none;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rbc {\n  display: ruby-base-container;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rtc {\n  display: ruby-text-container;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ruby,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rb,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rt,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rbc,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rtc {\n  unicode-bidi: isolate;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :link {\n  color: #0000EE;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :visited {\n  color: #551A8B;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :link,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :visited {\n  text-decoration: underline;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup a:link[rel~=help],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup a:visited[rel~=help],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup area:link[rel~=help],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup area:visited[rel~=help] {\n  cursor: help;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :focus {\n  outline: auto;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup mark {\n  background: yellow;\n  color: black;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup abbr[title],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup acronym[title] {\n  text-decoration: dotted underline;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ins,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup u {\n  text-decoration: underline;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup del,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup s,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup strike {\n  text-decoration: line-through;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup blink {\n  text-decoration: blink;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup q::before {\n  content: open-quote;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup q::after {\n  content: close-quote;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup br {\n  content: '\\A';\n  white-space: pre;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup nobr {\n  white-space: nowrap;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup wbr {\n  content: '\\200B';\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup nobr wbr {\n  white-space: normal;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup article,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup aside,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h1,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h2,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h3,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h4,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h5,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h6,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup hgroup,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup nav,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup section {\n  display: block;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h1 {\n  margin-top: 0.67em;\n  margin-bottom: 0.67em;\n  font-size: 2.00em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h2 {\n  margin-top: 0.83em;\n  margin-bottom: 0.83em;\n  font-size: 1.50em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h3 {\n  margin-top: 1.00em;\n  margin-bottom: 1.00em;\n  font-size: 1.17em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h4 {\n  margin-top: 1.33em;\n  margin-bottom: 1.33em;\n  font-size: 1.00em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h5 {\n  margin-top: 1.67em;\n  margin-bottom: 1.67em;\n  font-size: 0.83em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h6 {\n  margin-top: 2.33em;\n  margin-bottom: 2.33em;\n  font-size: 0.67em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dd,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dt,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul {\n  display: block;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup li {\n  display: list-item;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul {\n  margin-top: 1em;\n  margin-bottom: 1em;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul {\n  margin-top: 0;\n  margin-bottom: 0;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dd {\n  margin-left: 40px;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul {\n  padding-left: 40px;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol {\n  list-style-type: decimal;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul {\n  list-style-type: disc;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul {\n  list-style-type: circle;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dir dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dir ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ol dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ol ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ul dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ul ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dir dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dir ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ol dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ol ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ul dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ul ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dir dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dir ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ol dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ol ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul ul {\n  list-style-type: square;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table {\n  display: table;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup caption {\n  display: table-caption;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup colgroup,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup colgroup[hidden] {\n  display: table-column-group;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup col,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup col[hidden] {\n  display: table-column;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead[hidden] {\n  display: table-header-group;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody[hidden] {\n  display: table-row-group;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot[hidden] {\n  display: table-footer-group;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr[hidden] {\n  display: table-row;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th[hidden] {\n  display: table-cell;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup colgroup[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup col[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th[hidden] {\n  visibility: collapse;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table {\n  box-sizing: border-box;\n  border-spacing: 2px;\n  border-collapse: separate;\n  text-indent: initial;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th {\n  padding: 1px;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th {\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table > tr {\n  vertical-align: middle;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th {\n  vertical-align: inherit;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th {\n  border-color: gray;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr {\n  border-color: inherit;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup select,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup option,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup optgroup,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup button,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup textarea,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup keygen {\n  text-indent: initial;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup textarea {\n  white-space: pre-wrap;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"radio\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"checkbox\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"reset\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"button\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"submit\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup select,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup button {\n  box-sizing: border-box;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"button\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup button {\n  padding: 0.3em 0.5em;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup hr {\n  color: gray;\n  border-style: inset;\n  border-width: 1px;\n  margin: 0.5em auto;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup fieldset {\n  margin-left: 2px;\n  margin-right: 2px;\n  border: groove 2px ThreeDFace;\n  padding: 0.35em 0.625em 0.75em;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup legend {\n  padding-left: 2px;\n  padding-right: 2px;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup > *:first-child {\n  margin-top: 0 !important;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup > *:last-child {\n  margin-bottom: 0 !important;\n}\n.layout-editor .layout-content.layout-content-image > .layout-element-wrapper > .layout-content-markup > img,\n.layout-editor .layout-content.layout-content-vector-image > .layout-element-wrapper > .layout-content-markup > img {\n  display: block;\n  width: 100%;\n  max-width: 100%;\n  height: auto;\n}\n.layout-editor .img-responsive,\n.layout-editor .img-responsive img {\n  display: block;\n  width: 100%;\n  max-width: 100%;\n  height: auto;\n}\n\n.layout-editor > .layout-toolbox-wrapper {\n  position: relative;\n  margin-left: 12px;\n  width: 220px;\n  flex-shrink: 0;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox {\n  border: 1px solid #e4e5e6;\n  width: 220px;\n  min-height: 400px;\n  padding: 6px;\n  background-color: #f3f4f5;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox.sticky-top {\n  position: fixed;\n  top: 0;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox.sticky-bottom {\n  position: absolute;\n  bottom: 0;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group {\n  margin-top: 12px;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-group-heading {\n  display: block;\n  margin-bottom: 4px;\n  text-decoration: none;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-group-heading:before {\n  display: inline-block;\n  width: 10px;\n  margin-right: 4px;\n  font: normal normal normal 14px/1 FontAwesome;\n  text-align: center;\n  content: \"\\f0d7\";\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group.collapsed .layout-toolbox-group-heading:before {\n  content: \"\\f0da\";\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group.collapsed .layout-toolbox-items {\n  display: none;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-section + .layout-toolbox-section {\n  margin-top: 4px;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-item {\n  border: 1px solid #e4e5e6;\n  background-color: #fff;\n  padding: 9px 12px;\n  cursor: default;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-item i {\n  display: inline-block;\n  width: 16px;\n  font: normal normal normal 14px/1 FontAwesome;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-item + .layout-toolbox-item {\n  margin-top: 4px;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group + .layout-toolbox-group {\n  margin-top: 6px;\n}\n\n.layout-editor .layout-popup {\n  display: none;\n  position: absolute;\n  margin: 0;\n  -moz-box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\n  -webkit-box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\n  box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\n  border: 1px solid #e4e5e6;\n  padding: 2px 0;\n  background-color: #f7f7f7;\n  list-style: none;\n  z-index: 20;\n  color: #7c7c7c;\n  text-align: left;\n  cursor: default;\n  white-space: nowrap;\n  line-height: normal;\n}\n.layout-editor .layout-popup .layout-popup-flex {\n  display: flex;\n  padding: 2px 5px;\n}\n.layout-editor .layout-popup .layout-popup-flex .layout-popup-column + .layout-popup-column {\n  margin-left: 4px;\n  border-left: 1px solid rgba(128, 128, 128, 0.15);\n  padding-left: 4px;\n}\n.layout-editor .layout-popup .layout-popup-item {\n  padding: 4px 6px;\n}\n.layout-editor .layout-popup .layout-popup-label {\n  font-size: 0.9em;\n  font-weight: bold;\n  color: #7c7c7c;\n}\n.layout-editor .layout-popup .layout-popup-action:hover {\n  background-color: #f3f4f5;\n  cursor: pointer;\n}\n.layout-editor .layout-popup .layout-popup-input > label {\n  display: block;\n  font-size: 0.9em;\n}\n","@import \"Variables.less\";\n\n.layout-editor {\n    .layout-element {\n        position: relative;\n        margin-top: 0;\n        margin-right: 0;\n        margin-bottom: 0;\n        padding: 0;\n\n        // We don't fuck with the left margin of columns, because Bootstrap uses these to render column offsets.\n        &:not(.layout-column) {\n            margin-left: 0;\n        }\n\n        > .layout-element-wrapper {\n            > .layout-panel {\n                display: none; // Shown only in active or focused states.\n                position: absolute;\n                margin: 0;\n                z-index: 20;\n                height: 25px;\n                padding: 0 6px;\n                list-style: none;\n                white-space: nowrap;\n                line-height: 25px;\n                vertical-align: middle;\n\n                > .layout-panel-item {\n                    display: inline-block;\n                    height: 25px;\n                    padding: 1px 6px 0;\n                }\n\n                > .layout-panel-label {\n                    font-size: @font-size - 1;\n                }\n\n                > .layout-panel-action {\n                    display: none; // Shown only in focused state.\n                    width: 28px;\n                    cursor: pointer;\n                    text-align: center;\n                }\n            }\n\n            > .layout-panel-main {\n                top: -27px;\n                left: -2px;\n            }\n        }\n    }\n\n    // When dragging from toolbox, elements will be li rather than div.\n    li.layout-element {\n        list-style: none;\n    }\n\n    &:not(.layout-editor-dragging) {\n\n        .layout-element-active, .layout-element-focused {\n            border-width: 2px;\n            border-style: solid;\n\n            > .layout-element-wrapper {\n                margin: -2px;\n            }\n        }\n\n        .layout-element-active {\n            @active-highlight: fade(#686868, 10%);\n\n            border-color: @active-highlight;\n\n            > .layout-element-wrapper > .layout-panel-main {\n                display: block; // To reveal.\n                z-index: 30;\n                background-color: @active-highlight;\n            }\n        }\n\n        .layout-element-focused {\n            @focused-highlight: #648721;\n            @focused-text: #fefefe;\n\n            border-color: @focused-highlight;\n\n            > .layout-element-wrapper > .layout-panel {\n                display: block; // To reveal.\n                background-color: @focused-highlight;\n                color: @focused-text;\n\n                > .layout-panel-action {\n                    display: inline-block; // To reveal.\n                    &:hover {\n                        background-color: lighten(@focused-highlight, 10%);\n                    }\n\n                    &.disabled {\n                        cursor: default;\n                        color: fade(@focused-text, 40%);\n\n                        &:hover {\n                            background-color: @focused-highlight;\n                        }\n                    }\n\n                    &.active {\n                        color: lighten(saturate(spin(@focused-highlight, -10), 100%), 30%);\n                        background-color: lighten(@focused-highlight, 5%);\n\n                        &:hover {\n                            background-color: lighten(@focused-highlight, 10%);\n                        }\n                    }\n                }\n            }\n        }\n\n        .layout-element-selected {\n            @selected-highlight: #648721;\n            background-color: fade(@selected-highlight, 8%);\n        }\n    }\n\n    .ui-sortable-placeholder {\n        display: none;\n    }\n\n    .layout-element-droptarget {\n        @droptarget-highlight: #648721;\n        box-shadow: inset 0 0 12px 6px fade(@droptarget-highlight, 50%);\n\n        .ui-sortable-placeholder {\n            display: block; // To reveal.\n            visibility: visible !important;\n            min-height: @element-min-height - 2px;\n            border: 2px dashed @droptarget-highlight !important;\n            background-color: fade(@droptarget-highlight, 16%);\n        }\n    }\n\n    // A CSS fix for media item elements.\n    .media-thumbnail {\n        img {\n            max-width:100%;\n            max-height: 100%;\n        }\n    }\n}\n","@import \"Variables.less\";\n\n.layout-editor {\n    .layout-container {\n\n        > .layout-element-wrapper {\n\n            > .layout-container-children-placeholder {\n                display: none;\n                flex-direction: column;\n                margin: @container-padding - 1px;\n                min-height: @element-min-height;\n                border: 1px dashed fade(@gray-text, 40%);\n                border-radius: 4px;\n                padding: @container-padding;\n                justify-content: center;\n                font-size: @font-size - 1;\n                font-style: italic;\n                opacity: 0.6;\n                text-align: center;\n            }\n\n            > .layout-children {\n                padding: @container-padding;\n\n                // All adjacent non-container children need some space between...\n                > .layout-element:not(.layout-container) + .layout-element:not(.layout-container) {\n                    margin-top: @content-spacing;\n                }\n\n                // ... except when jQuery UI sortable helper is the first element (because that one is absolutely positioned and \"floating\").\n                > .ui-sortable-helper:first-child + .layout-element:not(.layout-container) {\n                    margin-top: 0;\n                }\n            }\n\n            &.layout-container-empty {\n                > .layout-container-children-placeholder {\n                    display: flex; // To reveal.\n                }\n\n                > .layout-children {\n                    position: absolute;\n                    top: 0;\n                    right: 0;\n                    bottom: 0;\n                    left: 0;\n                }\n            }\n        }\n    }\n\n    &:not(.layout-editor-dragging) {\n        .layout-container.layout-element-focused > .layout-element-wrapper > .layout-children {\n            > .layout-element:not(.layout-element-active) {\n                border: 1px dashed fade(@gray-text, 60%);\n\n                > .layout-element-wrapper {\n                    margin: -1px;\n                }\n            }\n\n            > .layout-container + .layout-container:not(.layout-element-active) {\n                border-top: 0;\n\n                > .layout-element-wrapper {\n                    margin-top: 0;\n                }\n            }\n        }\n    }\n}\n","@import \"Variables.less\";\n\n.layout-editor {\n    .layout-canvas {\n        #dummy { // Only added because WE doesn't compile if there are no rules.\n            display: none;\n        }\n    }\n}\n","@import \"Variables.less\";\n\n.layout-editor {\n    .layout-row {\n        &.layout-element-focused:not(.layout-element-droptarget) > .layout-element-wrapper > .layout-children {\n            > .layout-element:not(.layout-element-active) {\n                border-top: 1px dashed fade(@gray-text, 60%) !important;\n                > .layout-element-wrapper {\n                    margin-top: -1px !important;\n                }\n            }\n\n            > .layout-element + .layout-element:not(.layout-element-active) {\n                border-left: 0 !important;\n                > .layout-element-wrapper {\n                    margin-left: 0 !important;\n                }\n            }\n        }\n    }\n}","@import \"Variables.less\";\n\n.layout-editor {\n    .layout-column {\n        > .layout-element-wrapper {\n            > .layout-column-resize-bar {\n                display: none;\n                position: absolute;\n                z-index: 30;\n                top: 0;\n                width: 16px;\n                height: 100%;\n                cursor: col-resize;\n            }\n\n            > .layout-column-resize-bar-left {\n                left: -6px;\n            }\n\n            > .layout-column-resize-bar-right {\n                right: -6px;\n            }\n        }\n\n        &.layout-element-focused > .layout-element-wrapper > .layout-column-resize-bar {\n            display: block;\n        }\n    }\n}\n","@import \"Variables.less\";\n\n.layout-editor {\n    .layout-content {\n        min-height: 1em;\n\n        > .layout-element-wrapper {\n            .layout-content-markup {\n\n                padding: 2px;\n                overflow-x: hidden;\n                line-height: normal;\n\n                // Reset to HTML5 W3C standard default styling within content.\n                @import \"Reset.less\";\n\n                > *:first-child {\n                    margin-top: 0 !important; // Important because site.css of the admin theme styles heading margins with a very high specificity.\n                }\n\n                > *:last-child {\n                    margin-bottom: 0 !important;\n                }\n            }\n        }\n\n        &.layout-content-image, &.layout-content-vector-image {\n            > .layout-element-wrapper > .layout-content-markup > img {\n                display: block;\n                width: 100%;\n                max-width: 100%;\n                height: auto;\n            }\n        }\n    }\n\n    .img-responsive, .img-responsive img {\n        display: block;\n        width: 100%;\n        max-width: 100%;\n        height: auto;\n    }\n}\n","﻿* {\n    margin: 0;\n    padding: 0;\n    box-sizing: content-box;\n}\n\naddress, blockquote, center, div, figure, figcaption, footer, form,\nheader, hr, legend, listing, p, plaintext, pre, xmp {\n    display: block;\n}\n\nblockquote, figure, listing, p, plaintext, pre, xmp {\n    margin-top: 1em;\n    margin-bottom: 1em;\n}\n\nblockquote, figure {\n    margin-left: 40px;\n    margin-right: 40px;\n}\n\naddress {\n    font-style: italic;\n}\n\nlisting, plaintext, pre, xmp {\n    font-family: monospace;\n    white-space: pre;\n}\n\ncite, dfn, em, i, var {\n    font-style: italic;\n}\n\nb, strong {\n    font-weight: bolder;\n}\n\ncode, kbd, samp, tt {\n    font-family: monospace;\n}\n\nbig {\n    font-size: larger;\n}\n\nsmall {\n    font-size: smaller;\n}\n\nsub {\n    vertical-align: sub;\n}\n\nsup {\n    vertical-align: super;\n}\n\nsub, sup {\n    line-height: normal;\n    font-size: smaller;\n}\n\n\nruby {\n    display: ruby;\n}\n\nrb {\n    display: ruby-base;\n    white-space: nowrap;\n}\n\nrt {\n    display: ruby-text;\n    white-space: nowrap;\n    font-size: 50%;\n    font-variant-east-asian: ruby;\n    text-emphasis: none;\n}\n\nrbc {\n    display: ruby-base-container;\n}\n\nrtc {\n    display: ruby-text-container;\n}\n\nruby, rb, rt, rbc, rtc {\n    unicode-bidi: isolate;\n}\n\n\n:link {\n    color: #0000EE;\n}\n\n:visited {\n    color: #551A8B;\n}\n\n:link, :visited {\n    text-decoration: underline;\n}\n\na:link[rel~=help], a:visited[rel~=help],\narea:link[rel~=help], area:visited[rel~=help] {\n    cursor: help;\n}\n\n:focus {\n    outline: auto;\n}\n\nmark {\n    background: yellow;\n    color: black;\n}\n/* this color is just a suggestion and can be changed based on implementation feedback */\nabbr[title], acronym[title] {\n    text-decoration: dotted underline;\n}\n\nins, u {\n    text-decoration: underline;\n}\n\ndel, s, strike {\n    text-decoration: line-through;\n}\n\nblink {\n    text-decoration: blink;\n}\n\nq::before {\n    content: open-quote;\n}\n\nq::after {\n    content: close-quote;\n}\n\nbr {\n    content: '\\A';\n    white-space: pre;\n}\n/* this also has bidi implications */\nnobr {\n    white-space: nowrap;\n}\n\nwbr {\n    content: '\\200B';\n}\n/* this also has bidi implications */\nnobr wbr {\n    white-space: normal;\n}\n\narticle, aside, h1, h2, h3, h4, h5, h6, hgroup, nav, section {\n    display: block;\n}\n\nh1 {\n    margin-top: 0.67em;\n    margin-bottom: 0.67em;\n    font-size: 2.00em;\n    font-weight: bold;\n}\n\nh2 {\n    margin-top: 0.83em;\n    margin-bottom: 0.83em;\n    font-size: 1.50em;\n    font-weight: bold;\n}\n\nh3 {\n    margin-top: 1.00em;\n    margin-bottom: 1.00em;\n    font-size: 1.17em;\n    font-weight: bold;\n}\n\nh4 {\n    margin-top: 1.33em;\n    margin-bottom: 1.33em;\n    font-size: 1.00em;\n    font-weight: bold;\n}\n\nh5 {\n    margin-top: 1.67em;\n    margin-bottom: 1.67em;\n    font-size: 0.83em;\n    font-weight: bold;\n}\n\nh6 {\n    margin-top: 2.33em;\n    margin-bottom: 2.33em;\n    font-size: 0.67em;\n    font-weight: bold;\n}\n\ndir, dd, dl, dt, ol, ul {\n    display: block;\n}\n\nli {\n    display: list-item;\n}\n\ndir, dl, ol, ul {\n    margin-top: 1em;\n    margin-bottom: 1em;\n}\n\n    dir dir, dir dl, dir ol, dir ul,\n    dl dir, dl dl, dl ol, dl ul,\n    ol dir, ol dl, ol ol, ol ul,\n    ul dir, ul dl, ul ol, ul ul {\n        margin-top: 0;\n        margin-bottom: 0;\n    }\n\ndd {\n    margin-left: 40px;\n}\n\n/* LTR-specific: use 'margin-right' for rtl elements */\ndir, ol, ul {\n    padding-left: 40px;\n}\n\n/* LTR-specific: use 'padding-right' for rtl elements */\nol {\n    list-style-type: decimal;\n}\n\ndir, ul {\n    list-style-type: disc;\n}\n\n    dir dir, dir ul,\n    ol dir, ol ul,\n    ul dir, ul ul {\n        list-style-type: circle;\n    }\n\n        dir dir dir, dir dir ul,\n        dir ol dir, dir ol ul,\n        dir ul dir, dir ul ul,\n        ol dir dir, ol dir ul,\n        ol ol dir, ol ol ul,\n        ol ul dir, ol ul ul,\n        ul dir dir, ul dir ul,\n        ul ol dir, ul ol ul,\n        ul ul dir, ul ul ul {\n            list-style-type: square;\n        }\n\ntable {\n    display: table;\n}\n\ncaption {\n    display: table-caption;\n}\n\ncolgroup, colgroup[hidden] {\n    display: table-column-group;\n}\n\ncol, col[hidden] {\n    display: table-column;\n}\n\nthead, thead[hidden] {\n    display: table-header-group;\n}\n\ntbody, tbody[hidden] {\n    display: table-row-group;\n}\n\ntfoot, tfoot[hidden] {\n    display: table-footer-group;\n}\n\ntr, tr[hidden] {\n    display: table-row;\n}\n\ntd, th, td[hidden], th[hidden] {\n    display: table-cell;\n}\n\n    colgroup[hidden], col[hidden], thead[hidden], tbody[hidden],\n    tfoot[hidden], tr[hidden], td[hidden], th[hidden] {\n        visibility: collapse;\n    }\n\ntable {\n    box-sizing: border-box;\n    border-spacing: 2px;\n    border-collapse: separate;\n    text-indent: initial;\n}\n\ntd, th {\n    padding: 1px;\n}\n\nth {\n    font-weight: bold;\n}\n\nthead, tbody, tfoot, table > tr {\n    vertical-align: middle;\n}\n\ntr, td, th {\n    vertical-align: inherit;\n}\n\ntable, td, th {\n    border-color: gray;\n}\n\nthead, tbody, tfoot, tr {\n    border-color: inherit;\n}\n\n/*table[rules=none i], table[rules=groups i], table[rules=rows i],\ntable[rules=cols i], table[rules=all i], table[frame=void i],\ntable[frame=above i], table[frame=below i], table[frame=hsides i],\ntable[frame=lhs i], table[frame=rhs i], table[frame=vsides i],\ntable[frame=box i], table[frame=border i],\ntable[rules=none i] > tr > td, table[rules=none i] > tr > th,\ntable[rules=groups i] > tr > td, table[rules=groups i] > tr > th,\ntable[rules=rows i] > tr > td, table[rules=rows i] > tr > th,\ntable[rules=cols i] > tr > td, table[rules=cols i] > tr > th,\ntable[rules=all i] > tr > td, table[rules=all i] > tr > th,\ntable[rules=none i] > thead > tr > td, table[rules=none i] > thead > tr > th,\ntable[rules=groups i] > thead > tr > td, table[rules=groups i] > thead > tr > th,\ntable[rules=rows i] > thead > tr > td, table[rules=rows i] > thead > tr > th,\ntable[rules=cols i] > thead > tr > td, table[rules=cols i] > thead > tr > th,\ntable[rules=all i] > thead > tr > td, table[rules=all i] > thead > tr > th,\ntable[rules=none i] > tbody > tr > td, table[rules=none i] > tbody > tr > th,\ntable[rules=groups i] > tbody > tr > td, table[rules=groups i] > tbody > tr > th,\ntable[rules=rows i] > tbody > tr > td, table[rules=rows i] > tbody > tr > th,\ntable[rules=cols i] > tbody > tr > td, table[rules=cols i] > tbody > tr > th,\ntable[rules=all i] > tbody > tr > td, table[rules=all i] > tbody > tr > th,\ntable[rules=none i] > tfoot > tr > td, table[rules=none i] > tfoot > tr > th,\ntable[rules=groups i] > tfoot > tr > td, table[rules=groups i] > tfoot > tr > th,\ntable[rules=rows i] > tfoot > tr > td, table[rules=rows i] > tfoot > tr > th,\ntable[rules=cols i] > tfoot > tr > td, table[rules=cols i] > tfoot > tr > th,\ntable[rules=all i] > tfoot > tr > td, table[rules=all i] > tfoot > tr > th {\n    border-color: black;\n}*/\n\ninput, select, option, optgroup, button, textarea, keygen {\n    text-indent: initial;\n}\n\ntextarea {\n    white-space: pre-wrap;\n}\n\ninput[type=\"radio\"], input[type=\"checkbox\"], input[type=\"reset\"], input[type=\"button\"],\ninput[type=\"submit\"], select, button {\n    box-sizing: border-box;\n}\n\ninput[type=\"button\"], button {\n    padding: 0.3em 0.5em;\n}\n\nhr {\n    color: gray;\n    border-style: inset;\n    border-width: 1px;\n    margin: 0.5em auto;\n}\n\nfieldset {\n    margin-left: 2px;\n    margin-right: 2px;\n    border: groove 2px ThreeDFace;\n    padding: 0.35em 0.625em 0.75em;\n}\n\nlegend {\n    padding-left: 2px;\n    padding-right: 2px;\n}\n","@import \"Variables.less\";\n\n.layout-editor {\n    > .layout-toolbox-wrapper {\n        position: relative;\n        margin-left: @container-padding;\n        width: 220px;\n        flex-shrink: 0;\n\n        > .layout-toolbox {\n            border: 1px solid @gray-border;\n            width: 220px;\r\n            min-height: 400px;\n            padding: @container-padding / 2;\n            background-color: @gray-bg;\n\n            &.sticky-top {\r\n                position: fixed;\r\n                top: 0;\r\n            }\n\n            &.sticky-bottom {\r\n                position: absolute;\r\n                bottom: 0;\r\n            }\n\n            .layout-toolbox-group {\n                margin-top: @container-padding;\n\n                .layout-toolbox-group-heading {\n                    display: block;\n                    margin-bottom: @container-padding / 3;\n                    text-decoration: none;\n                \n                    &:before {\n                        display: inline-block;\n                        width: 10px;\n                        margin-right: @container-padding / 3;\n                        font: normal normal normal 14px/1 FontAwesome;\n                        text-align: center;\n                        content: \"\\f0d7\";\n                    }\n                }\n            \n                &.collapsed {\n                    .layout-toolbox-group-heading:before {\n                        content: \"\\f0da\";\n                    }\n\n                    .layout-toolbox-items {\n                        display: none;\n                    }\n                }\n\n                .layout-toolbox-section + .layout-toolbox-section {\n                    margin-top: @container-padding / 3;\n                }\n\n                .layout-toolbox-item {\n                    border: 1px solid @gray-border;\n                    background-color: #fff;\n                    padding: (@container-padding - 3) @container-padding;\n                    cursor: default;\n\n                    i {\n                        display: inline-block;\n                        width: 16px;\n                        font: normal normal normal 14px/1 FontAwesome;\n                    }\n\n                    + .layout-toolbox-item {\n                        margin-top: @container-padding / 3;\n                    }\n                }\n\n                + .layout-toolbox-group {\n                    margin-top: @container-padding / 2;\n                }\n            }\n        }\n    }\n}\n","@import \"Variables.less\";\n\n.layout-editor {\n    .layout-popup {\n        display: none; // Shown only in active or focused states.\n        position: absolute;\n        margin: 0;\n        -moz-box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\n        -webkit-box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\n        box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\n        border: 1px solid @gray-border;\n        padding: 2px 0;\n        background-color: #f7f7f7;\n        list-style: none;\n        z-index: 20;\n        color: @gray-text;\n        text-align: left;\n        cursor: default;\n        white-space: nowrap;\n        line-height: normal;\n\n        .layout-popup-flex {\n            display: flex;\n            padding: 2px 5px;\n\n            .layout-popup-column + .layout-popup-column {\n                margin-left: 4px;\n                border-left: 1px solid fade(gray, 15%);\n                padding-left: 4px;\n            }\n        }\n\n        .layout-popup-item {\n            padding: 4px 6px;\n        }\n\n        .layout-popup-label {\n            font-size: 0.9em;\n            font-weight: bold;\n            color: @gray-text;\n        }\n\n        .layout-popup-action:hover {\n            background-color: @gray-bg;\n            cursor: pointer;\n        }\n\n        .layout-popup-input {\n            > label {\n                display: block;\n                font-size: 0.9em;\n            }\n        }\n    }\n}\n"],"sourceRoot":"/source/"} */ \ No newline at end of file +/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["Editor.less","LayoutEditor.css","Element.less","Container.less","Canvas.less","Row.less","Column.less","Content.less","Reset.less","Toolbox.less","Popup.less"],"names":[],"mappings":"AAEA;EACI,sBAAA;EAAA,qBAAA;EAAA,cAAA;EACA,gBAAA;EACA,gBAAA;EACA,6BAAA;MAAA,wBAAA;UAAA,qBAAA;CCDH;ADHD;EAOQ,qBAAA;MAAA,qBAAA;UAAA,aAAA;EACA,0BAAA;EACA,0BAAA;CCDP;ADRD;EAYY,cAAA;EACA,oBAAA;EACA,iBAAA;CCDX;ADbD;EAiBgB,uBAAA;CCDf;ADhBD;EAsBY,wBAAA;EACA,qBAAA;EACA,oBAAA;CCHX;;ACrBD;EAEQ,mBAAA;EACA,cAAA;EACA,gBAAA;EACA,iBAAA;EACA,WAAA;CDuBP;ACpBO;EACI,eAAA;CDsBX;AChCD;EAegB,cAAA;EACA,mBAAA;EACA,UAAA;EACA,YAAA;EACA,aAAA;EACA,eAAA;EACA,iBAAA;EACA,oBAAA;EACA,kBAAA;EACA,uBAAA;CDoBf;AC5CD;EA2BoB,sBAAA;EACA,aAAA;EACA,mBAAA;CDoBnB;ACjDD;EAiCoB,gBAAA;CDmBnB;ACpDD;EAqCoB,cAAA;EACA,YAAA;EACA,gBAAA;EACA,mBAAA;CDkBnB;AC1DD;EA6CgB,WAAA;EACA,WAAA;CDgBf;AC9DD;EAqDQ,iBAAA;CDYP;ACTG;;EAGQ,kBAAA;EACA,oBAAA;CDUX;ACdG;;EAOY,aAAA;CDWf;AClBG;EAcQ,uCAAA;CDOX;ACrBG;EAiBY,eAAA;EACA,YAAA;EACA,2CAAA;CDOf;AC1BG;EA2BQ,sBAAA;CDEX;AC7BG;EA8BY,eAAA;EACA,0BAAA;EACA,eAAA;CDEf;AClCG;EAmCgB,sBAAA;CDEnB;ACDmB;EACI,0BAAA;CDGvB;ACAmB;EACI,gBAAA;EACA,gCAAA;CDEvB;ACAuB;EACI,0BAAA;CDE3B;ACEmB;EACI,eAAA;EACA,0BAAA;CDAvB;ACEuB;EACI,0BAAA;CDA3B;ACtDG;EA+DQ,2CAAA;CDNX;ACjHD;EA4HQ,cAAA;CDRP;ACpHD;EAiIQ,uDAAA;CDVP;ACvHD;EAoIY,eAAA;EACA,+BAAA;EACA,iBAAA;EACA,sCAAA;EACA,2CAAA;CDVX;AC9HD;EA+IY,gBAAA;EACA,iBAAA;CDdX;;AElID;EAMgB,cAAA;EACA,+BAAA;MAAA,2BAAA;UAAA,uBAAA;EACA,aAAA;EACA,iBAAA;EACA,4CAAA;EACA,mBAAA;EACA,cAAA;EACA,gCAAA;MAAA,sBAAA;UAAA,wBAAA;EACA,gBAAA;EACA,mBAAA;EACA,aAAA;EACA,mBAAA;CFgIf;AEjJD;EAqBgB,cAAA;CF+Hf;AEpJD;EAyBoB,iBAAA;CF8HnB;AEvJD;EA8BoB,cAAA;CF4HnB;AExHW;EAEQ,sBAAA;EAAA,qBAAA;EAAA,cAAA;CFyHnB;AE3HW;EAMQ,mBAAA;EACA,OAAA;EACA,SAAA;EACA,UAAA;EACA,QAAA;CFwHnB;AElHG;EAGY,4CAAA;CFkHf;AErHG;EAMgB,aAAA;CFkHnB;AExHG;EAWY,cAAA;CFgHf;AE3HG;EAcgB,cAAA;CFgHnB;;AGhLD;EAGY,cAAA;CHiLX;;AIlLO;EAEQ,2DAAA;CJoLf;AItLO;EAIY,4BAAA;CJqLnB;AIzLO;EASQ,0BAAA;CJmLf;AI5LO;EAWY,0BAAA;CJoLnB;;AKjMD;EAIgB,cAAA;EACA,mBAAA;EACA,YAAA;EACA,OAAA;EACA,YAAA;EACA,aAAA;EACA,mBAAA;CLiMf;AK3MD;EAcgB,WAAA;CLgMf;AK9MD;EAkBgB,YAAA;CL+Lf;AK3LO;EACI,eAAA;CL6LX;;AMnND;;EAEQ,gBAAA;CNsNP;AMxND;;EAOgB,aAAA;EACA,mBAAA;EACA,oBAAA;ENqNd,yFAAyF;EACzF,qCAAqC;EACrC,qCAAqC;EACrC,uDAAuD;EACvD,wDAAwD;EACxD;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BC;CACF;AM9PD;;ECAQ,UAAA;EACA,WAAA;EACA,wBAAA;CPkQP;AMpQD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ECOQ,eAAA;CP+RP;AMtSD;;;;;;;;;;;;;;ECWQ,gBAAA;EACA,mBAAA;CP2SP;AMvTD;;;;ECgBQ,kBAAA;EACA,mBAAA;CP6SP;AM9TD;;ECqBQ,mBAAA;CP6SP;AMlUD;;;;;;;;ECyBQ,uBAAA;EACA,iBAAA;CPmTP;AM7UD;;;;;;;;;;EC8BQ,mBAAA;CP2TP;AMzVD;;;;ECkCQ,oBAAA;CP6TP;AM/VD;;;;;;;;ECsCQ,uBAAA;CPmUP;AMzWD;;EC0CQ,kBAAA;CPmUP;AM7WD;;EC8CQ,mBAAA;CPmUP;AMjXD;;ECkDQ,oBAAA;CPmUP;AMrXD;;ECsDQ,sBAAA;CPmUP;AMzXD;;;;EC0DQ,oBAAA;EACA,mBAAA;CPqUP;AMhYD;;ECgEQ,cAAA;CPoUP;AMpYD;;ECoEQ,mBAAA;EACA,oBAAA;CPoUP;AMzYD;;ECyEQ,mBAAA;EACA,oBAAA;EACA,eAAA;EACA,8BAAA;EACA,4BAAA;UAAA,oBAAA;CPoUP;AMjZD;;ECiFQ,6BAAA;CPoUP;AMrZD;;ECqFQ,6BAAA;CPoUP;AMzZD;;;;;;;;;;ECyFQ,sBAAA;CP4UP;AMraD;;EC8FQ,eAAA;CP2UP;AMzaD;;ECkGQ,eAAA;CP2UP;AM7aD;;;;ECsGQ,2BAAA;CP6UP;AMnbD;;;;;;;;EC2GQ,aAAA;CPkVP;AM7bD;;EC+GQ,cAAA;CPkVP;AMjcD;;ECmHQ,mBAAA;EACA,aAAA;CPkVP;AMtcD;;;;ECwHQ,kCAAA;CPoVP;AM5cD;;;;EC4HQ,2BAAA;CPsVP;AMldD;;;;;;ECgIQ,8BAAA;CP0VP;AM1dD;;ECoIQ,uBAAA;CP0VP;AM9dD;;ECwIQ,oBAAA;CP0VP;AMleD;;EC4IQ,qBAAA;CP0VP;AMteD;;ECgJQ,cAAA;EACA,iBAAA;CP0VP;AM3eD;;ECqJQ,oBAAA;CP0VP;AM/eD;;ECyJQ,iBAAA;CP0VP;AMnfD;;EC6JQ,oBAAA;CP0VP;AMvfD;;;;;;;;;;;;;;;;;;;;;;ECiKQ,eAAA;CP8WP;AM/gBD;;ECqKQ,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CP8WP;AMthBD;;EC4KQ,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CP8WP;AM7hBD;;ECmLQ,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CP8WP;AMpiBD;;EC0LQ,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CP8WP;AM3iBD;;ECiMQ,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CP8WP;AMljBD;;ECwMQ,mBAAA;EACA,sBAAA;EACA,kBAAA;EACA,kBAAA;CP8WP;AMzjBD;;;;;;;;;;;;EC+MQ,eAAA;CPwXP;AMvkBD;;ECmNQ,mBAAA;CPwXP;AM3kBD;;;;;;;;ECuNQ,gBAAA;EACA,mBAAA;CP8XP;AMtlBD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EC+NY,cAAA;EACA,iBAAA;CPyZX;AMznBD;;ECoOQ,kBAAA;CPyZP;AM7nBD;;;;;;ECwOQ,mBAAA;CP6ZP;AMroBD;;EC4OQ,yBAAA;CP6ZP;AMzoBD;;;;ECgPQ,sBAAA;CP+ZP;AM/oBD;;;;;;;;;;;;ECsPY,wBAAA;CPuaX;AM7pBD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ECkQgB,wBAAA;CPicf;AMnsBD;;ECsQQ,eAAA;CPicP;AMvsBD;;EC0QQ,uBAAA;CPicP;AM3sBD;;;;EC8QQ,4BAAA;CPmcP;AMjtBD;;;;ECkRQ,sBAAA;CPqcP;AMvtBD;;;;ECsRQ,4BAAA;CPucP;AM7tBD;;;;EC0RQ,yBAAA;CPycP;AMnuBD;;;;EC8RQ,4BAAA;CP2cP;AMzuBD;;;;ECkSQ,mBAAA;CP6cP;AM/uBD;;;;;;;;ECsSQ,oBAAA;CPmdP;AMzvBD;;;;;;;;;;;;;;;;EC2SY,qBAAA;CPgeX;AM3wBD;;EC+SQ,uBAAA;EACA,oBAAA;EACA,0BAAA;EACA,qBAAA;CPgeP;AMlxBD;;;;ECsTQ,aAAA;CPkeP;AMxxBD;;EC0TQ,kBAAA;CPkeP;AM5xBD;;;;;;;;EC8TQ,uBAAA;CPweP;AMtyBD;;;;;;ECkUQ,wBAAA;CP4eP;AM9yBD;;;;;;ECsUQ,mBAAA;CPgfP;AMtzBD;;;;;;;;EC0UQ,sBAAA;CPsfP;AMh0BD;;;;;;;;;;;;;;ECwWQ,qBAAA;CPweP;AMh1BD;;EC4WQ,sBAAA;CPweP;AMp1BD;;;;;;;;;;;;;;ECiXQ,uBAAA;CPmfP;AMp2BD;;;;ECqXQ,qBAAA;CPqfP;AM12BD;;ECyXQ,YAAA;EACA,oBAAA;EACA,kBAAA;EACA,mBAAA;CPqfP;AMj3BD;;ECgYQ,iBAAA;EACA,kBAAA;EACA,8BAAA;EACA,+BAAA;CPqfP;AMx3BD;;ECuYQ,kBAAA;EACA,mBAAA;CPqfP;AM73BD;;EAeoB,yBAAA;CNk3BnB;AMj4BD;;EAmBoB,4BAAA;CNk3BnB;AM72BO;;;;EAEQ,eAAA;EACA,YAAA;EACA,gBAAA;EACA,aAAA;CNi3Bf;AM94BD;;EAmCQ,eAAA;EACA,YAAA;EACA,gBAAA;EACA,aAAA;CN+2BP;;AQt5BD;EAEQ,mBAAA;EACA,kBAAA;EACA,aAAA;EACA,uBAAA;MAAA,qBAAA;UAAA,eAAA;CRw5BP;AQ75BD;EAQY,0BAAA;EACA,aAAA;EACA,kBAAA;EACA,aAAA;EACA,0BAAA;CRw5BX;AQt5BW;EACI,gBAAA;EACA,OAAA;EACA,iBAAA;EACA,iBAAA;CRw5Bf;AQr5BW;EACI,mBAAA;EACA,UAAA;CRu5Bf;AQ96BD;EA2BgB,iBAAA;CRs5Bf;AQj7BD;EA8BoB,eAAA;EACA,mBAAA;EACA,sBAAA;CRs5BnB;AQp5BmB;EACI,sBAAA;EACA,YAAA;EACA,kBAAA;EACA,8CAAA;EACA,mBAAA;EACA,iBAAA;CRs5BvB;AQl5Be;EAEQ,iBAAA;CRm5BvB;AQr5Be;EAMQ,cAAA;CRk5BvB;AQp8BD;EAuDoB,gBAAA;CRg5BnB;AQv8BD;EA2DoB,0BAAA;EACA,uBAAA;EACA,kBAAA;EACA,gBAAA;CR+4BnB;AQ78BD;EAiEwB,sBAAA;EACA,YAAA;EACA,8CAAA;CR+4BvB;AQl9BD;EAuEwB,gBAAA;CR84BvB;AQr9BD;EA4EoB,gBAAA;CR44BnB;;ASx9BD;EAEQ,cAAA;EACA,mBAAA;EACA,UAAA;EAGA,iDAAA;EACA,0BAAA;EACA,eAAA;EACA,0BAAA;EACA,iBAAA;EACA,YAAA;EACA,eAAA;EACA,iBAAA;EACA,gBAAA;EACA,oBAAA;EACA,oBAAA;EACA,iBAAA;CT09BP;ASx9BO;EACI,aAAA;CT09BX;AS/+BD;EAyBY,sBAAA;EAAA,qBAAA;EAAA,cAAA;EACA,iBAAA;CTy9BX;ASn/BD;EA6BgB,iBAAA;EACA,iDAAA;EACA,kBAAA;CTy9Bf;ASx/BD;EAoCY,iBAAA;CTu9BX;AS3/BD;EAwCY,iBAAA;EACA,kBAAA;EACA,eAAA;CTs9BX;AShgCD;EA8CY,0BAAA;EACA,gBAAA;CTq9BX;ASpgCD;;EAoDgB,YAAA;CTo9Bf;ASxgCD;EAwDgB,eAAA;EACA,iBAAA;CTm9Bf","file":"LayoutEditor.css","sourcesContent":["@import \"Variables.less\";\r\n\r\n.layout-editor {\r\n    display: flex;\r\n    margin-top: 1em;\r\n    font-size: @font-size;\r\n    align-items: stretch;\r\n\r\n    > .layout-canvas-wrapper {\r\n        flex-grow: 1;\r\n        background-color: @gray-bg;\r\n        border: 1px solid @gray-border;\r\n\r\n        > .layout-toolbar-container {\r\n            display: none;\r\n            margin: @container-padding @container-padding 0;\r\n            min-height: 71px;\r\n\r\n            > .mce-panel {\r\n                width: 100% !important;\r\n            }\r\n        }\r\n\r\n        .layout-content > .layout-element-wrapper .layout-content-markup > .layout-placeholder {\r\n            border: 1px dashed #ccc;\r\n            padding: 0.2em 0.4em;\r\n            background: #e8e8e8;\r\n        }\r\n    }\r\n}\r\n",".layout-editor {\n  display: flex;\n  margin-top: 1em;\n  font-size: 14px;\n  align-items: stretch;\n}\n.layout-editor > .layout-canvas-wrapper {\n  flex-grow: 1;\n  background-color: #f3f4f5;\n  border: 1px solid #e4e5e6;\n}\n.layout-editor > .layout-canvas-wrapper > .layout-toolbar-container {\n  display: none;\n  margin: 12px 12px 0;\n  min-height: 71px;\n}\n.layout-editor > .layout-canvas-wrapper > .layout-toolbar-container > .mce-panel {\n  width: 100% !important;\n}\n.layout-editor > .layout-canvas-wrapper .layout-content > .layout-element-wrapper .layout-content-markup > .layout-placeholder {\n  border: 1px dashed #ccc;\n  padding: 0.2em 0.4em;\n  background: #e8e8e8;\n}\n\n.layout-editor .layout-element {\n  position: relative;\n  margin-top: 0;\n  margin-right: 0;\n  margin-bottom: 0;\n  padding: 0;\n}\n.layout-editor .layout-element:not(.layout-column) {\n  margin-left: 0;\n}\n.layout-editor .layout-element > .layout-element-wrapper > .layout-panel {\n  display: none;\n  position: absolute;\n  margin: 0;\n  z-index: 20;\n  height: 25px;\n  padding: 0 6px;\n  list-style: none;\n  white-space: nowrap;\n  line-height: 25px;\n  vertical-align: middle;\n}\n.layout-editor .layout-element > .layout-element-wrapper > .layout-panel > .layout-panel-item {\n  display: inline-block;\n  height: 25px;\n  padding: 1px 6px 0;\n}\n.layout-editor .layout-element > .layout-element-wrapper > .layout-panel > .layout-panel-label {\n  font-size: 13px;\n}\n.layout-editor .layout-element > .layout-element-wrapper > .layout-panel > .layout-panel-action {\n  display: none;\n  width: 28px;\n  cursor: pointer;\n  text-align: center;\n}\n.layout-editor .layout-element > .layout-element-wrapper > .layout-panel-main {\n  top: -27px;\n  left: -2px;\n}\n.layout-editor li.layout-element {\n  list-style: none;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-active,\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused {\n  border-width: 2px;\n  border-style: solid;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-active > .layout-element-wrapper,\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper {\n  margin: -2px;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-active {\n  border-color: rgba(104, 104, 104, 0.1);\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-active > .layout-element-wrapper > .layout-panel-main {\n  display: block;\n  z-index: 30;\n  background-color: rgba(104, 104, 104, 0.1);\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused {\n  border-color: #648721;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel {\n  display: block;\n  background-color: #648721;\n  color: #fefefe;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action {\n  display: inline-block;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action:hover {\n  background-color: #82b02b;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action.disabled {\n  cursor: default;\n  color: rgba(254, 254, 254, 0.4);\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action.disabled:hover {\n  background-color: #648721;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action.active {\n  color: #deff42;\n  background-color: #739b26;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-focused > .layout-element-wrapper > .layout-panel > .layout-panel-action.active:hover {\n  background-color: #82b02b;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-element-selected {\n  background-color: rgba(100, 135, 33, 0.08);\n}\n.layout-editor .ui-sortable-placeholder {\n  display: none;\n}\n.layout-editor .layout-element-droptarget {\n  box-shadow: inset 0 0 12px 6px rgba(100, 135, 33, 0.5);\n}\n.layout-editor .layout-element-droptarget .ui-sortable-placeholder {\n  display: block;\n  visibility: visible !important;\n  min-height: 78px;\n  border: 2px dashed #648721 !important;\n  background-color: rgba(100, 135, 33, 0.16);\n}\n.layout-editor .media-thumbnail img {\n  max-width: 100%;\n  max-height: 100%;\n}\n\n.layout-editor .layout-container > .layout-element-wrapper > .layout-container-children-placeholder {\n  display: none;\n  flex-direction: column;\n  margin: 11px;\n  min-height: 80px;\n  border: 1px dashed rgba(124, 124, 124, 0.4);\n  border-radius: 4px;\n  padding: 12px;\n  justify-content: center;\n  font-size: 13px;\n  font-style: italic;\n  opacity: 0.6;\n  text-align: center;\n}\n.layout-editor .layout-container > .layout-element-wrapper > .layout-children {\n  padding: 12px;\n}\n.layout-editor .layout-container > .layout-element-wrapper > .layout-children > .layout-element:not(.layout-container) + .layout-element:not(.layout-container) {\n  margin-top: 12px;\n}\n.layout-editor .layout-container > .layout-element-wrapper > .layout-children > .ui-sortable-helper:first-child + .layout-element:not(.layout-container) {\n  margin-top: 0;\n}\n.layout-editor .layout-container > .layout-element-wrapper.layout-container-empty > .layout-container-children-placeholder {\n  display: flex;\n}\n.layout-editor .layout-container > .layout-element-wrapper.layout-container-empty > .layout-children {\n  position: absolute;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused > .layout-element-wrapper > .layout-children > .layout-element:not(.layout-element-active) {\n  border: 1px dashed rgba(124, 124, 124, 0.6);\n}\n.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused > .layout-element-wrapper > .layout-children > .layout-element:not(.layout-element-active) > .layout-element-wrapper {\n  margin: -1px;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused > .layout-element-wrapper > .layout-children > .layout-container + .layout-container:not(.layout-element-active) {\n  border-top: 0;\n}\n.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused > .layout-element-wrapper > .layout-children > .layout-container + .layout-container:not(.layout-element-active) > .layout-element-wrapper {\n  margin-top: 0;\n}\n\n.layout-editor .layout-canvas #dummy {\n  display: none;\n}\n\n.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget) > .layout-element-wrapper > .layout-children > .layout-element:not(.layout-element-active) {\n  border-top: 1px dashed rgba(124, 124, 124, 0.6) !important;\n}\n.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget) > .layout-element-wrapper > .layout-children > .layout-element:not(.layout-element-active) > .layout-element-wrapper {\n  margin-top: -1px !important;\n}\n.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget) > .layout-element-wrapper > .layout-children > .layout-element + .layout-element:not(.layout-element-active) {\n  border-left: 0 !important;\n}\n.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget) > .layout-element-wrapper > .layout-children > .layout-element + .layout-element:not(.layout-element-active) > .layout-element-wrapper {\n  margin-left: 0 !important;\n}\n\n.layout-editor .layout-column > .layout-element-wrapper > .layout-column-resize-bar {\n  display: none;\n  position: absolute;\n  z-index: 30;\n  top: 0;\n  width: 16px;\n  height: 100%;\n  cursor: col-resize;\n}\n.layout-editor .layout-column > .layout-element-wrapper > .layout-column-resize-bar-left {\n  left: -6px;\n}\n.layout-editor .layout-column > .layout-element-wrapper > .layout-column-resize-bar-right {\n  right: -6px;\n}\n.layout-editor .layout-column.layout-element-focused > .layout-element-wrapper > .layout-column-resize-bar {\n  display: block;\n}\n\n.layout-editor .layout-content,\n.layout-editor .layout-html {\n  min-height: 1em;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup {\n  padding: 2px;\n  overflow-x: hidden;\n  line-height: normal;\n  /* this color is just a suggestion and can be changed based on implementation feedback */\n  /* this also has bidi implications */\n  /* this also has bidi implications */\n  /* LTR-specific: use 'margin-right' for rtl elements */\n  /* LTR-specific: use 'padding-right' for rtl elements */\n  /*table[rules=none i], table[rules=groups i], table[rules=rows i],\ntable[rules=cols i], table[rules=all i], table[frame=void i],\ntable[frame=above i], table[frame=below i], table[frame=hsides i],\ntable[frame=lhs i], table[frame=rhs i], table[frame=vsides i],\ntable[frame=box i], table[frame=border i],\ntable[rules=none i] > tr > td, table[rules=none i] > tr > th,\ntable[rules=groups i] > tr > td, table[rules=groups i] > tr > th,\ntable[rules=rows i] > tr > td, table[rules=rows i] > tr > th,\ntable[rules=cols i] > tr > td, table[rules=cols i] > tr > th,\ntable[rules=all i] > tr > td, table[rules=all i] > tr > th,\ntable[rules=none i] > thead > tr > td, table[rules=none i] > thead > tr > th,\ntable[rules=groups i] > thead > tr > td, table[rules=groups i] > thead > tr > th,\ntable[rules=rows i] > thead > tr > td, table[rules=rows i] > thead > tr > th,\ntable[rules=cols i] > thead > tr > td, table[rules=cols i] > thead > tr > th,\ntable[rules=all i] > thead > tr > td, table[rules=all i] > thead > tr > th,\ntable[rules=none i] > tbody > tr > td, table[rules=none i] > tbody > tr > th,\ntable[rules=groups i] > tbody > tr > td, table[rules=groups i] > tbody > tr > th,\ntable[rules=rows i] > tbody > tr > td, table[rules=rows i] > tbody > tr > th,\ntable[rules=cols i] > tbody > tr > td, table[rules=cols i] > tbody > tr > th,\ntable[rules=all i] > tbody > tr > td, table[rules=all i] > tbody > tr > th,\ntable[rules=none i] > tfoot > tr > td, table[rules=none i] > tfoot > tr > th,\ntable[rules=groups i] > tfoot > tr > td, table[rules=groups i] > tfoot > tr > th,\ntable[rules=rows i] > tfoot > tr > td, table[rules=rows i] > tfoot > tr > th,\ntable[rules=cols i] > tfoot > tr > td, table[rules=cols i] > tfoot > tr > th,\ntable[rules=all i] > tfoot > tr > td, table[rules=all i] > tfoot > tr > th {\n    border-color: black;\n}*/\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup *,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup * {\n  margin: 0;\n  padding: 0;\n  box-sizing: content-box;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup address,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup address,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup blockquote,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup blockquote,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup center,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup center,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup div,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup div,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup figure,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup figure,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup figcaption,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup figcaption,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup footer,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup footer,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup form,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup form,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup header,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup header,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup hr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup hr,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup legend,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup legend,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup listing,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup listing,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup p,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup p,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup plaintext,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup plaintext,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup pre,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup pre,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup xmp,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup xmp {\n  display: block;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup blockquote,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup blockquote,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup figure,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup figure,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup listing,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup listing,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup p,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup p,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup plaintext,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup plaintext,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup pre,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup pre,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup xmp,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup xmp {\n  margin-top: 1em;\n  margin-bottom: 1em;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup blockquote,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup blockquote,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup figure,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup figure {\n  margin-left: 40px;\n  margin-right: 40px;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup address,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup address {\n  font-style: italic;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup listing,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup listing,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup plaintext,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup plaintext,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup pre,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup pre,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup xmp,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup xmp {\n  font-family: monospace;\n  white-space: pre;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup cite,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup cite,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dfn,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dfn,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup em,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup em,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup i,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup i,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup var,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup var {\n  font-style: italic;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup b,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup b,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup strong,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup strong {\n  font-weight: bolder;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup code,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup code,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup kbd,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup kbd,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup samp,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup samp,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tt,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tt {\n  font-family: monospace;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup big,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup big {\n  font-size: larger;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup small,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup small {\n  font-size: smaller;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sub,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup sub {\n  vertical-align: sub;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sup,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup sup {\n  vertical-align: super;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sub,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup sub,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup sup,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup sup {\n  line-height: normal;\n  font-size: smaller;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ruby,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ruby {\n  display: ruby;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rb,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rb {\n  display: ruby-base;\n  white-space: nowrap;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rt,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rt {\n  display: ruby-text;\n  white-space: nowrap;\n  font-size: 50%;\n  font-variant-east-asian: ruby;\n  text-emphasis: none;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rbc,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rbc {\n  display: ruby-base-container;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rtc,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rtc {\n  display: ruby-text-container;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ruby,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ruby,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rb,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rb,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rt,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rt,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rbc,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rbc,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup rtc,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup rtc {\n  unicode-bidi: isolate;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :link,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup :link {\n  color: #0000EE;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :visited,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup :visited {\n  color: #551A8B;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :link,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup :link,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :visited,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup :visited {\n  text-decoration: underline;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup a:link[rel~=help],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup a:link[rel~=help],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup a:visited[rel~=help],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup a:visited[rel~=help],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup area:link[rel~=help],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup area:link[rel~=help],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup area:visited[rel~=help],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup area:visited[rel~=help] {\n  cursor: help;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup :focus,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup :focus {\n  outline: auto;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup mark,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup mark {\n  background: yellow;\n  color: black;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup abbr[title],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup abbr[title],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup acronym[title],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup acronym[title] {\n  text-decoration: dotted underline;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ins,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ins,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup u,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup u {\n  text-decoration: underline;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup del,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup del,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup s,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup s,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup strike,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup strike {\n  text-decoration: line-through;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup blink,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup blink {\n  text-decoration: blink;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup q::before,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup q::before {\n  content: open-quote;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup q::after,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup q::after {\n  content: close-quote;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup br,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup br {\n  content: '\\A';\n  white-space: pre;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup nobr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup nobr {\n  white-space: nowrap;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup wbr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup wbr {\n  content: '\\200B';\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup nobr wbr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup nobr wbr {\n  white-space: normal;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup article,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup article,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup aside,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup aside,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h1,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h1,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h2,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h2,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h3,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h3,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h4,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h4,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h5,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h5,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h6,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h6,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup hgroup,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup hgroup,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup nav,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup nav,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup section,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup section {\n  display: block;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h1,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h1 {\n  margin-top: 0.67em;\n  margin-bottom: 0.67em;\n  font-size: 2.00em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h2,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h2 {\n  margin-top: 0.83em;\n  margin-bottom: 0.83em;\n  font-size: 1.50em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h3,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h3 {\n  margin-top: 1.00em;\n  margin-bottom: 1.00em;\n  font-size: 1.17em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h4,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h4 {\n  margin-top: 1.33em;\n  margin-bottom: 1.33em;\n  font-size: 1.00em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h5,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h5 {\n  margin-top: 1.67em;\n  margin-bottom: 1.67em;\n  font-size: 0.83em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup h6,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup h6 {\n  margin-top: 2.33em;\n  margin-bottom: 2.33em;\n  font-size: 0.67em;\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dd,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dd,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dt,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dt,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul {\n  display: block;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup li,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup li {\n  display: list-item;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul {\n  margin-top: 1em;\n  margin-bottom: 1em;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dl,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl dl,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dl ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dl ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dl,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dl,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul dl,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ul {\n  margin-top: 0;\n  margin-bottom: 0;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dd,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dd {\n  margin-left: 40px;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul {\n  padding-left: 40px;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol {\n  list-style-type: decimal;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul {\n  list-style-type: disc;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ul {\n  list-style-type: circle;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dir dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir dir dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir dir ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir dir ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ol dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ol dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ol ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ol ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ul dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ul dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup dir ul ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup dir ul ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dir dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol dir dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol dir ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol dir ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ol dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ol dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ol ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ol ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ul dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ul dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ol ul ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ol ul ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dir dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul dir dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul dir ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul dir ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ol dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ol dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ol ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ol ul,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul dir,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ul dir,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup ul ul ul,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup ul ul ul {\n  list-style-type: square;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup table {\n  display: table;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup caption,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup caption {\n  display: table-caption;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup colgroup,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup colgroup,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup colgroup[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup colgroup[hidden] {\n  display: table-column-group;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup col,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup col,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup col[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup col[hidden] {\n  display: table-column;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup thead,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup thead[hidden] {\n  display: table-header-group;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tbody,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tbody[hidden] {\n  display: table-row-group;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tfoot,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tfoot[hidden] {\n  display: table-footer-group;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tr,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tr[hidden] {\n  display: table-row;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th[hidden] {\n  display: table-cell;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup colgroup[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup colgroup[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup col[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup col[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup thead[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tbody[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tfoot[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tr[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td[hidden],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th[hidden],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th[hidden] {\n  visibility: collapse;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup table {\n  box-sizing: border-box;\n  border-spacing: 2px;\n  border-collapse: separate;\n  text-indent: initial;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th {\n  padding: 1px;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th {\n  font-weight: bold;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup thead,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tbody,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tfoot,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table > tr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup table > tr {\n  vertical-align: middle;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tr,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th {\n  vertical-align: inherit;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup table,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup table,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup td,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup th,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup th {\n  border-color: gray;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup thead,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup thead,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tbody,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tbody,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tfoot,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tfoot,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup tr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup tr {\n  border-color: inherit;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup select,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup select,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup option,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup option,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup optgroup,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup optgroup,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup button,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup button,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup textarea,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup textarea,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup keygen,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup keygen {\n  text-indent: initial;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup textarea,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup textarea {\n  white-space: pre-wrap;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"radio\"],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type=\"radio\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"checkbox\"],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type=\"checkbox\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"reset\"],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type=\"reset\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"button\"],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type=\"button\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"submit\"],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type=\"submit\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup select,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup select,\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup button,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup button {\n  box-sizing: border-box;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup input[type=\"button\"],\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup input[type=\"button\"],\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup button,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup button {\n  padding: 0.3em 0.5em;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup hr,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup hr {\n  color: gray;\n  border-style: inset;\n  border-width: 1px;\n  margin: 0.5em auto;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup fieldset,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup fieldset {\n  margin-left: 2px;\n  margin-right: 2px;\n  border: groove 2px ThreeDFace;\n  padding: 0.35em 0.625em 0.75em;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup legend,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup legend {\n  padding-left: 2px;\n  padding-right: 2px;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup > *:first-child,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup > *:first-child {\n  margin-top: 0 !important;\n}\n.layout-editor .layout-content > .layout-element-wrapper .layout-content-markup > *:last-child,\n.layout-editor .layout-html > .layout-element-wrapper .layout-content-markup > *:last-child {\n  margin-bottom: 0 !important;\n}\n.layout-editor .layout-content.layout-content-image > .layout-element-wrapper > .layout-content-markup > img,\n.layout-editor .layout-html.layout-content-image > .layout-element-wrapper > .layout-content-markup > img,\n.layout-editor .layout-content.layout-content-vector-image > .layout-element-wrapper > .layout-content-markup > img,\n.layout-editor .layout-html.layout-content-vector-image > .layout-element-wrapper > .layout-content-markup > img {\n  display: block;\n  width: 100%;\n  max-width: 100%;\n  height: auto;\n}\n.layout-editor .img-responsive,\n.layout-editor .img-responsive img {\n  display: block;\n  width: 100%;\n  max-width: 100%;\n  height: auto;\n}\n\n.layout-editor > .layout-toolbox-wrapper {\n  position: relative;\n  margin-left: 12px;\n  width: 220px;\n  flex-shrink: 0;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox {\n  border: 1px solid #e4e5e6;\n  width: 220px;\n  min-height: 400px;\n  padding: 6px;\n  background-color: #f3f4f5;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox.sticky-top {\n  position: fixed;\n  top: 0;\n  max-height: 100%;\n  overflow-y: auto;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox.sticky-bottom {\n  position: absolute;\n  bottom: 0;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group {\n  margin-top: 12px;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-group-heading {\n  display: block;\n  margin-bottom: 4px;\n  text-decoration: none;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-group-heading:before {\n  display: inline-block;\n  width: 10px;\n  margin-right: 4px;\n  font: normal normal normal 14px/1 FontAwesome;\n  text-align: center;\n  content: \"\\f0d7\";\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group.collapsed .layout-toolbox-group-heading:before {\n  content: \"\\f0da\";\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group.collapsed .layout-toolbox-items {\n  display: none;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-section + .layout-toolbox-section {\n  margin-top: 4px;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-item {\n  border: 1px solid #e4e5e6;\n  background-color: #fff;\n  padding: 9px 12px;\n  cursor: default;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-item i {\n  display: inline-block;\n  width: 16px;\n  font: normal normal normal 14px/1 FontAwesome;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group .layout-toolbox-item + .layout-toolbox-item {\n  margin-top: 4px;\n}\n.layout-editor > .layout-toolbox-wrapper > .layout-toolbox .layout-toolbox-group + .layout-toolbox-group {\n  margin-top: 6px;\n}\n\n.layout-editor .layout-popup {\n  display: none;\n  position: absolute;\n  margin: 0;\n  -moz-box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\n  -webkit-box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\n  box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\n  border: 1px solid #e4e5e6;\n  padding: 2px 0;\n  background-color: #f7f7f7;\n  list-style: none;\n  z-index: 20;\n  color: #7c7c7c;\n  text-align: left;\n  cursor: default;\n  white-space: nowrap;\n  line-height: normal;\n  min-width: 300px;\n}\n.layout-editor .layout-popup.wide {\n  width: 600px;\n}\n.layout-editor .layout-popup .layout-popup-flex {\n  display: flex;\n  padding: 2px 5px;\n}\n.layout-editor .layout-popup .layout-popup-flex .layout-popup-column + .layout-popup-column {\n  margin-left: 4px;\n  border-left: 1px solid rgba(128, 128, 128, 0.15);\n  padding-left: 4px;\n}\n.layout-editor .layout-popup .layout-popup-item {\n  padding: 4px 6px;\n}\n.layout-editor .layout-popup .layout-popup-label {\n  font-size: 0.9em;\n  font-weight: bold;\n  color: #7c7c7c;\n}\n.layout-editor .layout-popup .layout-popup-action:hover {\n  background-color: #f3f4f5;\n  cursor: pointer;\n}\n.layout-editor .layout-popup .layout-popup-input input[type='text'],\n.layout-editor .layout-popup .layout-popup-input textarea {\n  width: 100%;\n}\n.layout-editor .layout-popup .layout-popup-input > label {\n  display: block;\n  font-size: 0.9em;\n}\n","@import \"Variables.less\";\n\n.layout-editor {\n    .layout-element {\n        position: relative;\n        margin-top: 0;\n        margin-right: 0;\n        margin-bottom: 0;\n        padding: 0;\n\n        // We don't fuck with the left margin of columns, because Bootstrap uses these to render column offsets.\n        &:not(.layout-column) {\n            margin-left: 0;\n        }\n\n        > .layout-element-wrapper {\n            > .layout-panel {\n                display: none; // Shown only in active or focused states.\n                position: absolute;\n                margin: 0;\n                z-index: 20;\n                height: 25px;\n                padding: 0 6px;\n                list-style: none;\n                white-space: nowrap;\n                line-height: 25px;\n                vertical-align: middle;\n\n                > .layout-panel-item {\n                    display: inline-block;\n                    height: 25px;\n                    padding: 1px 6px 0;\n                }\n\n                > .layout-panel-label {\n                    font-size: @font-size - 1;\n                }\n\n                > .layout-panel-action {\n                    display: none; // Shown only in focused state.\n                    width: 28px;\n                    cursor: pointer;\n                    text-align: center;\n                }\n            }\n\n            > .layout-panel-main {\n                top: -27px;\n                left: -2px;\n            }\n        }\n    }\n\n    // When dragging from toolbox, elements will be li rather than div.\n    li.layout-element {\n        list-style: none;\n    }\n\n    &:not(.layout-editor-dragging) {\n\n        .layout-element-active, .layout-element-focused {\n            border-width: 2px;\n            border-style: solid;\n\n            > .layout-element-wrapper {\n                margin: -2px;\n            }\n        }\n\n        .layout-element-active {\n            @active-highlight: fade(#686868, 10%);\n\n            border-color: @active-highlight;\n\n            > .layout-element-wrapper > .layout-panel-main {\n                display: block; // To reveal.\n                z-index: 30;\n                background-color: @active-highlight;\n            }\n        }\n\n        .layout-element-focused {\n            @focused-highlight: #648721;\n            @focused-text: #fefefe;\n\n            border-color: @focused-highlight;\n\n            > .layout-element-wrapper > .layout-panel {\n                display: block; // To reveal.\n                background-color: @focused-highlight;\n                color: @focused-text;\n\n                > .layout-panel-action {\n                    display: inline-block; // To reveal.\n                    &:hover {\n                        background-color: lighten(@focused-highlight, 10%);\n                    }\n\n                    &.disabled {\n                        cursor: default;\n                        color: fade(@focused-text, 40%);\n\n                        &:hover {\n                            background-color: @focused-highlight;\n                        }\n                    }\n\n                    &.active {\n                        color: lighten(saturate(spin(@focused-highlight, -10), 100%), 30%);\n                        background-color: lighten(@focused-highlight, 5%);\n\n                        &:hover {\n                            background-color: lighten(@focused-highlight, 10%);\n                        }\n                    }\n                }\n            }\n        }\n\n        .layout-element-selected {\n            @selected-highlight: #648721;\n            background-color: fade(@selected-highlight, 8%);\n        }\n    }\n\n    .ui-sortable-placeholder {\n        display: none;\n    }\n\n    .layout-element-droptarget {\n        @droptarget-highlight: #648721;\n        box-shadow: inset 0 0 12px 6px fade(@droptarget-highlight, 50%);\n\n        .ui-sortable-placeholder {\n            display: block; // To reveal.\n            visibility: visible !important;\n            min-height: @element-min-height - 2px;\n            border: 2px dashed @droptarget-highlight !important;\n            background-color: fade(@droptarget-highlight, 16%);\n        }\n    }\n\n    // A CSS fix for media item elements.\n    .media-thumbnail {\n        img {\n            max-width:100%;\n            max-height: 100%;\n        }\n    }\n}\n","@import \"Variables.less\";\n\n.layout-editor {\n    .layout-container {\n\n        > .layout-element-wrapper {\n\n            > .layout-container-children-placeholder {\n                display: none;\n                flex-direction: column;\n                margin: @container-padding - 1px;\n                min-height: @element-min-height;\n                border: 1px dashed fade(@gray-text, 40%);\n                border-radius: 4px;\n                padding: @container-padding;\n                justify-content: center;\n                font-size: @font-size - 1;\n                font-style: italic;\n                opacity: 0.6;\n                text-align: center;\n            }\n\n            > .layout-children {\n                padding: @container-padding;\n\n                // All adjacent non-container children need some space between...\n                > .layout-element:not(.layout-container) + .layout-element:not(.layout-container) {\n                    margin-top: @content-spacing;\n                }\n\n                // ... except when jQuery UI sortable helper is the first element (because that one is absolutely positioned and \"floating\").\n                > .ui-sortable-helper:first-child + .layout-element:not(.layout-container) {\n                    margin-top: 0;\n                }\n            }\n\n            &.layout-container-empty {\n                > .layout-container-children-placeholder {\n                    display: flex; // To reveal.\n                }\n\n                > .layout-children {\n                    position: absolute;\n                    top: 0;\n                    right: 0;\n                    bottom: 0;\n                    left: 0;\n                }\n            }\n        }\n    }\n\n    &:not(.layout-editor-dragging) {\n        .layout-container.layout-element-focused > .layout-element-wrapper > .layout-children {\n            > .layout-element:not(.layout-element-active) {\n                border: 1px dashed fade(@gray-text, 60%);\n\n                > .layout-element-wrapper {\n                    margin: -1px;\n                }\n            }\n\n            > .layout-container + .layout-container:not(.layout-element-active) {\n                border-top: 0;\n\n                > .layout-element-wrapper {\n                    margin-top: 0;\n                }\n            }\n        }\n    }\n}\n","@import \"Variables.less\";\n\n.layout-editor {\n    .layout-canvas {\n        #dummy { // Only added because WE doesn't compile if there are no rules.\n            display: none;\n        }\n    }\n}\n","@import \"Variables.less\";\n\n.layout-editor {\n    .layout-row {\n        &.layout-element-focused:not(.layout-element-droptarget) > .layout-element-wrapper > .layout-children {\n            > .layout-element:not(.layout-element-active) {\n                border-top: 1px dashed fade(@gray-text, 60%) !important;\n                > .layout-element-wrapper {\n                    margin-top: -1px !important;\n                }\n            }\n\n            > .layout-element + .layout-element:not(.layout-element-active) {\n                border-left: 0 !important;\n                > .layout-element-wrapper {\n                    margin-left: 0 !important;\n                }\n            }\n        }\n    }\n}","@import \"Variables.less\";\n\n.layout-editor {\n    .layout-column {\n        > .layout-element-wrapper {\n            > .layout-column-resize-bar {\n                display: none;\n                position: absolute;\n                z-index: 30;\n                top: 0;\n                width: 16px;\n                height: 100%;\n                cursor: col-resize;\n            }\n\n            > .layout-column-resize-bar-left {\n                left: -6px;\n            }\n\n            > .layout-column-resize-bar-right {\n                right: -6px;\n            }\n        }\n\n        &.layout-element-focused > .layout-element-wrapper > .layout-column-resize-bar {\n            display: block;\n        }\n    }\n}\n","@import \"Variables.less\";\r\n@import \"Reset.less\";\r\n\r\n.layout-editor {\r\n    .layout-content, .layout-html {\r\n        min-height: 1em;\r\n\r\n        > .layout-element-wrapper {\r\n            .layout-content-markup {\r\n\r\n                padding: 2px;\r\n                overflow-x: hidden;\r\n                line-height: normal;\r\n\r\n                // Reset to HTML5 W3C standard default styling within content.\r\n                .reset();\r\n\r\n                > *:first-child {\r\n                    margin-top: 0 !important; // Important because site.css of the admin theme styles heading margins with a very high specificity.\r\n                }\r\n\r\n                > *:last-child {\r\n                    margin-bottom: 0 !important;\r\n                }\r\n            }\r\n        }\r\n\r\n        &.layout-content-image, &.layout-content-vector-image {\r\n            > .layout-element-wrapper > .layout-content-markup > img {\r\n                display: block;\r\n                width: 100%;\r\n                max-width: 100%;\r\n                height: auto;\r\n            }\r\n        }\r\n    }\r\n\r\n    .img-responsive, .img-responsive img {\r\n        display: block;\r\n        width: 100%;\r\n        max-width: 100%;\r\n        height: auto;\r\n    }\r\n}\r\n","﻿.reset() {\r\n\r\n    * {\r\n        margin: 0;\r\n        padding: 0;\r\n        box-sizing: content-box;\r\n    }\r\n\r\n    address, blockquote, center, div, figure, figcaption, footer, form,\r\n    header, hr, legend, listing, p, plaintext, pre, xmp {\r\n        display: block;\r\n    }\r\n\r\n    blockquote, figure, listing, p, plaintext, pre, xmp {\r\n        margin-top: 1em;\r\n        margin-bottom: 1em;\r\n    }\r\n\r\n    blockquote, figure {\r\n        margin-left: 40px;\r\n        margin-right: 40px;\r\n    }\r\n\r\n    address {\r\n        font-style: italic;\r\n    }\r\n\r\n    listing, plaintext, pre, xmp {\r\n        font-family: monospace;\r\n        white-space: pre;\r\n    }\r\n\r\n    cite, dfn, em, i, var {\r\n        font-style: italic;\r\n    }\r\n\r\n    b, strong {\r\n        font-weight: bolder;\r\n    }\r\n\r\n    code, kbd, samp, tt {\r\n        font-family: monospace;\r\n    }\r\n\r\n    big {\r\n        font-size: larger;\r\n    }\r\n\r\n    small {\r\n        font-size: smaller;\r\n    }\r\n\r\n    sub {\r\n        vertical-align: sub;\r\n    }\r\n\r\n    sup {\r\n        vertical-align: super;\r\n    }\r\n\r\n    sub, sup {\r\n        line-height: normal;\r\n        font-size: smaller;\r\n    }\r\n\r\n\r\n    ruby {\r\n        display: ruby;\r\n    }\r\n\r\n    rb {\r\n        display: ruby-base;\r\n        white-space: nowrap;\r\n    }\r\n\r\n    rt {\r\n        display: ruby-text;\r\n        white-space: nowrap;\r\n        font-size: 50%;\r\n        font-variant-east-asian: ruby;\r\n        text-emphasis: none;\r\n    }\r\n\r\n    rbc {\r\n        display: ruby-base-container;\r\n    }\r\n\r\n    rtc {\r\n        display: ruby-text-container;\r\n    }\r\n\r\n    ruby, rb, rt, rbc, rtc {\r\n        unicode-bidi: isolate;\r\n    }\r\n\r\n\r\n    :link {\r\n        color: #0000EE;\r\n    }\r\n\r\n    :visited {\r\n        color: #551A8B;\r\n    }\r\n\r\n    :link, :visited {\r\n        text-decoration: underline;\r\n    }\r\n\r\n    a:link[rel~=help], a:visited[rel~=help],\r\n    area:link[rel~=help], area:visited[rel~=help] {\r\n        cursor: help;\r\n    }\r\n\r\n    :focus {\r\n        outline: auto;\r\n    }\r\n\r\n    mark {\r\n        background: yellow;\r\n        color: black;\r\n    }\r\n    /* this color is just a suggestion and can be changed based on implementation feedback */\r\n    abbr[title], acronym[title] {\r\n        text-decoration: dotted underline;\r\n    }\r\n\r\n    ins, u {\r\n        text-decoration: underline;\r\n    }\r\n\r\n    del, s, strike {\r\n        text-decoration: line-through;\r\n    }\r\n\r\n    blink {\r\n        text-decoration: blink;\r\n    }\r\n\r\n    q::before {\r\n        content: open-quote;\r\n    }\r\n\r\n    q::after {\r\n        content: close-quote;\r\n    }\r\n\r\n    br {\r\n        content: '\\A';\r\n        white-space: pre;\r\n    }\r\n    /* this also has bidi implications */\r\n    nobr {\r\n        white-space: nowrap;\r\n    }\r\n\r\n    wbr {\r\n        content: '\\200B';\r\n    }\r\n    /* this also has bidi implications */\r\n    nobr wbr {\r\n        white-space: normal;\r\n    }\r\n\r\n    article, aside, h1, h2, h3, h4, h5, h6, hgroup, nav, section {\r\n        display: block;\r\n    }\r\n\r\n    h1 {\r\n        margin-top: 0.67em;\r\n        margin-bottom: 0.67em;\r\n        font-size: 2.00em;\r\n        font-weight: bold;\r\n    }\r\n\r\n    h2 {\r\n        margin-top: 0.83em;\r\n        margin-bottom: 0.83em;\r\n        font-size: 1.50em;\r\n        font-weight: bold;\r\n    }\r\n\r\n    h3 {\r\n        margin-top: 1.00em;\r\n        margin-bottom: 1.00em;\r\n        font-size: 1.17em;\r\n        font-weight: bold;\r\n    }\r\n\r\n    h4 {\r\n        margin-top: 1.33em;\r\n        margin-bottom: 1.33em;\r\n        font-size: 1.00em;\r\n        font-weight: bold;\r\n    }\r\n\r\n    h5 {\r\n        margin-top: 1.67em;\r\n        margin-bottom: 1.67em;\r\n        font-size: 0.83em;\r\n        font-weight: bold;\r\n    }\r\n\r\n    h6 {\r\n        margin-top: 2.33em;\r\n        margin-bottom: 2.33em;\r\n        font-size: 0.67em;\r\n        font-weight: bold;\r\n    }\r\n\r\n    dir, dd, dl, dt, ol, ul {\r\n        display: block;\r\n    }\r\n\r\n    li {\r\n        display: list-item;\r\n    }\r\n\r\n    dir, dl, ol, ul {\r\n        margin-top: 1em;\r\n        margin-bottom: 1em;\r\n    }\r\n\r\n        dir dir, dir dl, dir ol, dir ul,\r\n        dl dir, dl dl, dl ol, dl ul,\r\n        ol dir, ol dl, ol ol, ol ul,\r\n        ul dir, ul dl, ul ol, ul ul {\r\n            margin-top: 0;\r\n            margin-bottom: 0;\r\n        }\r\n\r\n    dd {\r\n        margin-left: 40px;\r\n    }\r\n    /* LTR-specific: use 'margin-right' for rtl elements */\r\n    dir, ol, ul {\r\n        padding-left: 40px;\r\n    }\r\n    /* LTR-specific: use 'padding-right' for rtl elements */\r\n    ol {\r\n        list-style-type: decimal;\r\n    }\r\n\r\n    dir, ul {\r\n        list-style-type: disc;\r\n    }\r\n\r\n        dir dir, dir ul,\r\n        ol dir, ol ul,\r\n        ul dir, ul ul {\r\n            list-style-type: circle;\r\n        }\r\n\r\n            dir dir dir, dir dir ul,\r\n            dir ol dir, dir ol ul,\r\n            dir ul dir, dir ul ul,\r\n            ol dir dir, ol dir ul,\r\n            ol ol dir, ol ol ul,\r\n            ol ul dir, ol ul ul,\r\n            ul dir dir, ul dir ul,\r\n            ul ol dir, ul ol ul,\r\n            ul ul dir, ul ul ul {\r\n                list-style-type: square;\r\n            }\r\n\r\n    table {\r\n        display: table;\r\n    }\r\n\r\n    caption {\r\n        display: table-caption;\r\n    }\r\n\r\n    colgroup, colgroup[hidden] {\r\n        display: table-column-group;\r\n    }\r\n\r\n    col, col[hidden] {\r\n        display: table-column;\r\n    }\r\n\r\n    thead, thead[hidden] {\r\n        display: table-header-group;\r\n    }\r\n\r\n    tbody, tbody[hidden] {\r\n        display: table-row-group;\r\n    }\r\n\r\n    tfoot, tfoot[hidden] {\r\n        display: table-footer-group;\r\n    }\r\n\r\n    tr, tr[hidden] {\r\n        display: table-row;\r\n    }\r\n\r\n    td, th, td[hidden], th[hidden] {\r\n        display: table-cell;\r\n    }\r\n\r\n        colgroup[hidden], col[hidden], thead[hidden], tbody[hidden],\r\n        tfoot[hidden], tr[hidden], td[hidden], th[hidden] {\r\n            visibility: collapse;\r\n        }\r\n\r\n    table {\r\n        box-sizing: border-box;\r\n        border-spacing: 2px;\r\n        border-collapse: separate;\r\n        text-indent: initial;\r\n    }\r\n\r\n    td, th {\r\n        padding: 1px;\r\n    }\r\n\r\n    th {\r\n        font-weight: bold;\r\n    }\r\n\r\n    thead, tbody, tfoot, table > tr {\r\n        vertical-align: middle;\r\n    }\r\n\r\n    tr, td, th {\r\n        vertical-align: inherit;\r\n    }\r\n\r\n    table, td, th {\r\n        border-color: gray;\r\n    }\r\n\r\n    thead, tbody, tfoot, tr {\r\n        border-color: inherit;\r\n    }\r\n    /*table[rules=none i], table[rules=groups i], table[rules=rows i],\r\ntable[rules=cols i], table[rules=all i], table[frame=void i],\r\ntable[frame=above i], table[frame=below i], table[frame=hsides i],\r\ntable[frame=lhs i], table[frame=rhs i], table[frame=vsides i],\r\ntable[frame=box i], table[frame=border i],\r\ntable[rules=none i] > tr > td, table[rules=none i] > tr > th,\r\ntable[rules=groups i] > tr > td, table[rules=groups i] > tr > th,\r\ntable[rules=rows i] > tr > td, table[rules=rows i] > tr > th,\r\ntable[rules=cols i] > tr > td, table[rules=cols i] > tr > th,\r\ntable[rules=all i] > tr > td, table[rules=all i] > tr > th,\r\ntable[rules=none i] > thead > tr > td, table[rules=none i] > thead > tr > th,\r\ntable[rules=groups i] > thead > tr > td, table[rules=groups i] > thead > tr > th,\r\ntable[rules=rows i] > thead > tr > td, table[rules=rows i] > thead > tr > th,\r\ntable[rules=cols i] > thead > tr > td, table[rules=cols i] > thead > tr > th,\r\ntable[rules=all i] > thead > tr > td, table[rules=all i] > thead > tr > th,\r\ntable[rules=none i] > tbody > tr > td, table[rules=none i] > tbody > tr > th,\r\ntable[rules=groups i] > tbody > tr > td, table[rules=groups i] > tbody > tr > th,\r\ntable[rules=rows i] > tbody > tr > td, table[rules=rows i] > tbody > tr > th,\r\ntable[rules=cols i] > tbody > tr > td, table[rules=cols i] > tbody > tr > th,\r\ntable[rules=all i] > tbody > tr > td, table[rules=all i] > tbody > tr > th,\r\ntable[rules=none i] > tfoot > tr > td, table[rules=none i] > tfoot > tr > th,\r\ntable[rules=groups i] > tfoot > tr > td, table[rules=groups i] > tfoot > tr > th,\r\ntable[rules=rows i] > tfoot > tr > td, table[rules=rows i] > tfoot > tr > th,\r\ntable[rules=cols i] > tfoot > tr > td, table[rules=cols i] > tfoot > tr > th,\r\ntable[rules=all i] > tfoot > tr > td, table[rules=all i] > tfoot > tr > th {\r\n    border-color: black;\r\n}*/\r\n    input, select, option, optgroup, button, textarea, keygen {\r\n        text-indent: initial;\r\n    }\r\n\r\n    textarea {\r\n        white-space: pre-wrap;\r\n    }\r\n\r\n    input[type=\"radio\"], input[type=\"checkbox\"], input[type=\"reset\"], input[type=\"button\"],\r\n    input[type=\"submit\"], select, button {\r\n        box-sizing: border-box;\r\n    }\r\n\r\n    input[type=\"button\"], button {\r\n        padding: 0.3em 0.5em;\r\n    }\r\n\r\n    hr {\r\n        color: gray;\r\n        border-style: inset;\r\n        border-width: 1px;\r\n        margin: 0.5em auto;\r\n    }\r\n\r\n    fieldset {\r\n        margin-left: 2px;\r\n        margin-right: 2px;\r\n        border: groove 2px ThreeDFace;\r\n        padding: 0.35em 0.625em 0.75em;\r\n    }\r\n\r\n    legend {\r\n        padding-left: 2px;\r\n        padding-right: 2px;\r\n    }\r\n}\r\n","@import \"Variables.less\";\r\n\r\n.layout-editor {\r\n    > .layout-toolbox-wrapper {\r\n        position: relative;\r\n        margin-left: @container-padding;\r\n        width: 220px;\r\n        flex-shrink: 0;\r\n\r\n        > .layout-toolbox {\r\n            border: 1px solid @gray-border;\r\n            width: 220px;\r\n            min-height: 400px;\r\n            padding: @container-padding / 2;\r\n            background-color: @gray-bg;\r\n\r\n            &.sticky-top {\r\n                position: fixed;\r\n                top: 0;\r\n                max-height: 100%;\r\n                overflow-y: auto;\r\n            }\r\n\r\n            &.sticky-bottom {\r\n                position: absolute;\r\n                bottom: 0;\r\n            }\r\n\r\n            .layout-toolbox-group {\r\n                margin-top: @container-padding;\r\n\r\n                .layout-toolbox-group-heading {\r\n                    display: block;\r\n                    margin-bottom: @container-padding / 3;\r\n                    text-decoration: none;\r\n                \r\n                    &:before {\r\n                        display: inline-block;\r\n                        width: 10px;\r\n                        margin-right: @container-padding / 3;\r\n                        font: normal normal normal 14px/1 FontAwesome;\r\n                        text-align: center;\r\n                        content: \"\\f0d7\";\r\n                    }\r\n                }\r\n            \r\n                &.collapsed {\r\n                    .layout-toolbox-group-heading:before {\r\n                        content: \"\\f0da\";\r\n                    }\r\n\r\n                    .layout-toolbox-items {\r\n                        display: none;\r\n                    }\r\n                }\r\n\r\n                .layout-toolbox-section + .layout-toolbox-section {\r\n                    margin-top: @container-padding / 3;\r\n                }\r\n\r\n                .layout-toolbox-item {\r\n                    border: 1px solid @gray-border;\r\n                    background-color: #fff;\r\n                    padding: (@container-padding - 3) @container-padding;\r\n                    cursor: default;\r\n\r\n                    i {\r\n                        display: inline-block;\r\n                        width: 16px;\r\n                        font: normal normal normal 14px/1 FontAwesome;\r\n                    }\r\n\r\n                    + .layout-toolbox-item {\r\n                        margin-top: @container-padding / 3;\r\n                    }\r\n                }\r\n\r\n                + .layout-toolbox-group {\r\n                    margin-top: @container-padding / 2;\r\n                }\r\n            }\r\n        }\r\n    }\r\n}\r\n","@import \"Variables.less\";\r\n\r\n.layout-editor {\r\n    .layout-popup {\r\n        display: none; // Shown only in active or focused states.\r\n        position: absolute;\r\n        margin: 0;\r\n        -moz-box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\r\n        -webkit-box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\r\n        box-shadow: 3px 3px 11px 0 rgba(50, 50, 50, 0.5);\r\n        border: 1px solid @gray-border;\r\n        padding: 2px 0;\r\n        background-color: #f7f7f7;\r\n        list-style: none;\r\n        z-index: 20;\r\n        color: @gray-text;\r\n        text-align: left;\r\n        cursor: default;\r\n        white-space: nowrap;\r\n        line-height: normal;\r\n        min-width: 300px;\r\n\r\n        &.wide {\r\n            width: 600px;\r\n        }\r\n\r\n        .layout-popup-flex {\r\n            display: flex;\r\n            padding: 2px 5px;\r\n\r\n            .layout-popup-column + .layout-popup-column {\r\n                margin-left: 4px;\r\n                border-left: 1px solid fade(gray, 15%);\r\n                padding-left: 4px;\r\n            }\r\n        }\r\n\r\n        .layout-popup-item {\r\n            padding: 4px 6px;\r\n        }\r\n\r\n        .layout-popup-label {\r\n            font-size: 0.9em;\r\n            font-weight: bold;\r\n            color: @gray-text;\r\n        }\r\n\r\n        .layout-popup-action:hover {\r\n            background-color: @gray-bg;\r\n            cursor: pointer;\r\n        }\r\n\r\n        .layout-popup-input {\r\n            input[type='text'], textarea {\r\n                width: 100%;\r\n            }\r\n\r\n            > label {\r\n                display: block;\r\n                font-size: 0.9em;\r\n            }\r\n        }\r\n    }\r\n}\r\n"],"sourceRoot":"/source/"} */ \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor.min.css b/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor.min.css index aa62a278a..105fc2fa5 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor.min.css +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor.min.css @@ -1 +1 @@ -.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup address,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup cite,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dfn,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup em,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup i,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup var{font-style:italic}.layout-editor{display:-webkit-flex;display:-ms-flexbox;display:flex;margin-top:1em;font-size:14px;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.layout-editor>.layout-canvas-wrapper{-webkit-flex-grow:1;-ms-flex-positive:1;flex-grow:1;background-color:#f3f4f5;border:1px solid #e4e5e6}.layout-editor>.layout-canvas-wrapper>.layout-toolbar-container{display:none;margin:12px 12px 0;min-height:71px}.layout-editor>.layout-canvas-wrapper>.layout-toolbar-container>.mce-panel{width:100%!important}.layout-editor .layout-element{position:relative;margin-top:0;margin-right:0;margin-bottom:0;padding:0}.layout-editor .layout-element:not(.layout-column){margin-left:0}.layout-editor .layout-element>.layout-element-wrapper>.layout-panel{display:none;position:absolute;margin:0;z-index:20;height:25px;padding:0 6px;list-style:none;white-space:nowrap;line-height:25px;vertical-align:middle}.layout-editor .layout-element>.layout-element-wrapper>.layout-panel>.layout-panel-item{display:inline-block;height:25px;padding:1px 6px 0}.layout-editor .layout-element>.layout-element-wrapper>.layout-panel>.layout-panel-label{font-size:13px}.layout-editor .layout-element>.layout-element-wrapper>.layout-panel>.layout-panel-action{display:none;width:28px;cursor:pointer;text-align:center}.layout-editor .layout-element>.layout-element-wrapper>.layout-panel-main{top:-27px;left:-2px}.layout-editor li.layout-element{list-style:none}.layout-editor:not(.layout-editor-dragging) .layout-element-active,.layout-editor:not(.layout-editor-dragging) .layout-element-focused{border-width:2px;border-style:solid}.layout-editor:not(.layout-editor-dragging) .layout-element-active>.layout-element-wrapper,.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper{margin:-2px}.layout-editor:not(.layout-editor-dragging) .layout-element-active{border-color:rgba(104,104,104,.1)}.layout-editor:not(.layout-editor-dragging) .layout-element-active>.layout-element-wrapper>.layout-panel-main{display:block;z-index:30;background-color:rgba(104,104,104,.1)}.layout-editor:not(.layout-editor-dragging) .layout-element-focused{border-color:#648721}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel{display:block;background-color:#648721;color:#fefefe}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action{display:inline-block}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action:hover{background-color:#82b02b}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action.disabled{cursor:default;color:rgba(254,254,254,.4)}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action.disabled:hover{background-color:#648721}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action.active{color:#deff42;background-color:#739b26}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action.active:hover{background-color:#82b02b}.layout-editor:not(.layout-editor-dragging) .layout-element-selected{background-color:rgba(100,135,33,.08)}.layout-editor .ui-sortable-placeholder{display:none}.layout-editor .layout-element-droptarget{box-shadow:inset 0 0 12px 6px rgba(100,135,33,.5)}.layout-editor .layout-element-droptarget .ui-sortable-placeholder{display:block;visibility:visible!important;min-height:78px;border:2px dashed #648721!important;background-color:rgba(100,135,33,.16)}.layout-editor .media-thumbnail img{max-width:100%;max-height:100%}.layout-editor .layout-container>.layout-element-wrapper>.layout-container-children-placeholder{display:none;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;margin:11px;min-height:80px;border:1px dashed rgba(124,124,124,.4);border-radius:4px;padding:12px;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;font-size:13px;font-style:italic;opacity:.6;text-align:center}.layout-editor .layout-container>.layout-element-wrapper>.layout-children{padding:12px}.layout-editor .layout-container>.layout-element-wrapper>.layout-children>.layout-element:not(.layout-container)+.layout-element:not(.layout-container){margin-top:12px}.layout-editor .layout-container>.layout-element-wrapper>.layout-children>.ui-sortable-helper:first-child+.layout-element:not(.layout-container){margin-top:0}.layout-editor .layout-container>.layout-element-wrapper.layout-container-empty>.layout-container-children-placeholder{display:-webkit-flex;display:-ms-flexbox;display:flex}.layout-editor .layout-container>.layout-element-wrapper.layout-container-empty>.layout-children{position:absolute;top:0;right:0;bottom:0;left:0}.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused>.layout-element-wrapper>.layout-children>.layout-element:not(.layout-element-active){border:1px dashed rgba(124,124,124,.6)}.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused>.layout-element-wrapper>.layout-children>.layout-element:not(.layout-element-active)>.layout-element-wrapper{margin:-1px}.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused>.layout-element-wrapper>.layout-children>.layout-container+.layout-container:not(.layout-element-active){border-top:0}.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused>.layout-element-wrapper>.layout-children>.layout-container+.layout-container:not(.layout-element-active)>.layout-element-wrapper{margin-top:0}.layout-editor .layout-canvas #dummy{display:none}.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget)>.layout-element-wrapper>.layout-children>.layout-element:not(.layout-element-active){border-top:1px dashed rgba(124,124,124,.6)!important}.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget)>.layout-element-wrapper>.layout-children>.layout-element:not(.layout-element-active)>.layout-element-wrapper{margin-top:-1px!important}.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget)>.layout-element-wrapper>.layout-children>.layout-element+.layout-element:not(.layout-element-active){border-left:0!important}.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget)>.layout-element-wrapper>.layout-children>.layout-element+.layout-element:not(.layout-element-active)>.layout-element-wrapper{margin-left:0!important}.layout-editor .layout-column>.layout-element-wrapper>.layout-column-resize-bar{display:none;position:absolute;z-index:30;top:0;width:16px;height:100%;cursor:col-resize}.layout-editor .layout-column.layout-element-focused>.layout-element-wrapper>.layout-column-resize-bar,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup address,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup blockquote,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup center,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup div,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup figcaption,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup figure,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup footer,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup form,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup header,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup hr,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup legend,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup listing,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup p,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup plaintext,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup pre,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup xmp{display:block}.layout-editor .layout-column>.layout-element-wrapper>.layout-column-resize-bar-left{left:-6px}.layout-editor .layout-column>.layout-element-wrapper>.layout-column-resize-bar-right{right:-6px}.layout-editor .layout-content{min-height:1em}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup{padding:2px;overflow-x:hidden;line-height:normal}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup *{margin:0;padding:0;box-sizing:content-box}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup blockquote,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup figure,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup listing,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup p,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup plaintext,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup pre,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup xmp{margin-top:1em;margin-bottom:1em}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup blockquote,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup figure{margin-left:40px;margin-right:40px}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup listing,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup plaintext,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup pre,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup xmp{font-family:monospace;white-space:pre}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup b,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup strong{font-weight:bolder}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup code,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup kbd,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup samp,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tt{font-family:monospace}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup big{font-size:larger}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup small{font-size:smaller}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup sub{vertical-align:sub}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup sup{vertical-align:super}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup sub,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup sup{line-height:normal;font-size:smaller}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ruby{display:ruby}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rb{display:ruby-base;white-space:nowrap}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rt{display:ruby-text;white-space:nowrap;font-size:50%;font-variant-east-asian:ruby;-webkit-text-emphasis:none;text-emphasis:none}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rbc{display:ruby-base-container}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rtc{display:ruby-text-container}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup article,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup aside,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dd,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dt,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h1,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h2,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h3,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h4,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h5,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h6,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup hgroup,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup nav,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup section,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul{display:block}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rb,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rbc,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rt,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rtc,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ruby{unicode-bidi:isolate}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup :link{color:#00E}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup :visited{color:#551A8B}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup :link,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup :visited{text-decoration:underline}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup a:link[rel~=help],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup a:visited[rel~=help],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup area:link[rel~=help],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup area:visited[rel~=help]{cursor:help}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup :focus{outline:auto}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup mark{background:#ff0;color:#000}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup abbr[title],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup acronym[title]{text-decoration:dotted underline}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ins,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup u{text-decoration:underline}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup del,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup s,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup strike{text-decoration:line-through}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup blink{text-decoration:blink}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup q::before{content:open-quote}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup q::after{content:close-quote}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup br{content:'\A';white-space:pre}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup nobr{white-space:nowrap}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup wbr{content:'\200B'}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup nobr wbr{white-space:normal}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h1{margin-top:.67em;margin-bottom:.67em;font-size:2em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h2{margin-top:.83em;margin-bottom:.83em;font-size:1.5em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h3{margin-top:1em;margin-bottom:1em;font-size:1.17em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h4{margin-top:1.33em;margin-bottom:1.33em;font-size:1em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h5{margin-top:1.67em;margin-bottom:1.67em;font-size:.83em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h6{margin-top:2.33em;margin-bottom:2.33em;font-size:.67em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup li{display:list-item}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul{margin-top:1em;margin-bottom:1em}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ul{margin-top:0;margin-bottom:0}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dd{margin-left:40px}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul{padding-left:40px}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol{list-style-type:decimal}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul{list-style-type:disc}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ul{list-style-type:circle}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir dir dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir dir ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ol dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ol ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ul dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ul ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol dir dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol dir ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ol dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ol ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ul dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ul ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul dir dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul dir ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ol dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ol ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ul dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ul ul{list-style-type:square}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup table{display:table;box-sizing:border-box;border-spacing:2px;border-collapse:separate;text-indent:initial}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup caption{display:table-caption}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup colgroup,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup colgroup[hidden]{display:table-column-group}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup col,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup col[hidden]{display:table-column}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup thead,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup thead[hidden]{display:table-header-group}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tbody,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tbody[hidden]{display:table-row-group}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tfoot,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tfoot[hidden]{display:table-footer-group}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tr,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tr[hidden]{display:table-row}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th[hidden]{display:table-cell}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup col[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup colgroup[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tbody[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tfoot[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup thead[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tr[hidden]{visibility:collapse}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th{padding:1px}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th{font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup table>tr,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tbody,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tfoot,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup thead{vertical-align:middle}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tr{vertical-align:inherit}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup table,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th{border-color:gray}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tbody,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tfoot,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup thead,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tr{border-color:inherit}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup button,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup keygen,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup optgroup,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup option,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup select,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup textarea{text-indent:initial}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup textarea{white-space:pre-wrap}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup button,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=radio],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=checkbox],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=reset],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=button],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=submit],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup select{box-sizing:border-box}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup button,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=button]{padding:.3em .5em}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup hr{color:gray;border-style:inset;border-width:1px;margin:.5em auto}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup fieldset{margin-left:2px;margin-right:2px;border:2px groove ThreeDFace;padding:.35em .625em .75em}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup legend{padding-left:2px;padding-right:2px}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>:first-child{margin-top:0!important}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>:last-child{margin-bottom:0!important}.layout-editor .img-responsive,.layout-editor .img-responsive img,.layout-editor .layout-content.layout-content-image>.layout-element-wrapper>.layout-content-markup>img,.layout-editor .layout-content.layout-content-vector-image>.layout-element-wrapper>.layout-content-markup>img{display:block;width:100%;max-width:100%;height:auto}.layout-editor>.layout-toolbox-wrapper{position:relative;margin-left:12px;width:220px;-webkit-flex-shrink:0;-ms-flex-negative:0;flex-shrink:0}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox{border:1px solid #e4e5e6;width:220px;min-height:400px;padding:6px;background-color:#f3f4f5}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox.sticky-top{position:fixed;top:0}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox.sticky-bottom{position:absolute;bottom:0}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group{margin-top:12px}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-item+.layout-toolbox-item,.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-section+.layout-toolbox-section{margin-top:4px}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-group-heading{display:block;margin-bottom:4px;text-decoration:none}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-group-heading:before{display:inline-block;width:10px;margin-right:4px;font:normal normal normal 14px/1 FontAwesome;text-align:center;content:"\f0d7"}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group.collapsed .layout-toolbox-group-heading:before{content:"\f0da"}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group.collapsed .layout-toolbox-items{display:none}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-item{border:1px solid #e4e5e6;background-color:#fff;padding:9px 12px;cursor:default}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-item i{display:inline-block;width:16px;font:normal normal normal 14px/1 FontAwesome}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group+.layout-toolbox-group{margin-top:6px}.layout-editor .layout-popup{display:none;position:absolute;margin:0;box-shadow:3px 3px 11px 0 rgba(50,50,50,.5);border:1px solid #e4e5e6;padding:2px 0;background-color:#f7f7f7;list-style:none;z-index:20;color:#7c7c7c;text-align:left;cursor:default;white-space:nowrap;line-height:normal}.layout-editor .layout-popup .layout-popup-flex{display:-webkit-flex;display:-ms-flexbox;display:flex;padding:2px 5px}.layout-editor .layout-popup .layout-popup-flex .layout-popup-column+.layout-popup-column{margin-left:4px;border-left:1px solid rgba(128,128,128,.15);padding-left:4px}.layout-editor .layout-popup .layout-popup-item{padding:4px 6px}.layout-editor .layout-popup .layout-popup-label{font-size:.9em;font-weight:700;color:#7c7c7c}.layout-editor .layout-popup .layout-popup-action:hover{background-color:#f3f4f5;cursor:pointer}.layout-editor .layout-popup .layout-popup-input>label{display:block;font-size:.9em} \ No newline at end of file +.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup address,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup cite,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dfn,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup em,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup i,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup var,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup address,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup cite,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dfn,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup em,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup i,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup var{font-style:italic}.layout-editor{display:-webkit-flex;display:-ms-flexbox;display:flex;margin-top:1em;font-size:14px;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.layout-editor>.layout-canvas-wrapper{-webkit-flex-grow:1;-ms-flex-positive:1;flex-grow:1;background-color:#f3f4f5;border:1px solid #e4e5e6}.layout-editor>.layout-canvas-wrapper>.layout-toolbar-container{display:none;margin:12px 12px 0;min-height:71px}.layout-editor>.layout-canvas-wrapper>.layout-toolbar-container>.mce-panel{width:100%!important}.layout-editor>.layout-canvas-wrapper .layout-content>.layout-element-wrapper .layout-content-markup>.layout-placeholder{border:1px dashed #ccc;padding:.2em .4em;background:#e8e8e8}.layout-editor .layout-element{position:relative;margin-top:0;margin-right:0;margin-bottom:0;padding:0}.layout-editor .layout-element:not(.layout-column){margin-left:0}.layout-editor .layout-element>.layout-element-wrapper>.layout-panel{display:none;position:absolute;margin:0;z-index:20;height:25px;padding:0 6px;list-style:none;white-space:nowrap;line-height:25px;vertical-align:middle}.layout-editor .layout-element>.layout-element-wrapper>.layout-panel>.layout-panel-item{display:inline-block;height:25px;padding:1px 6px 0}.layout-editor .layout-element>.layout-element-wrapper>.layout-panel>.layout-panel-label{font-size:13px}.layout-editor .layout-element>.layout-element-wrapper>.layout-panel>.layout-panel-action{display:none;width:28px;cursor:pointer;text-align:center}.layout-editor .layout-element>.layout-element-wrapper>.layout-panel-main{top:-27px;left:-2px}.layout-editor li.layout-element{list-style:none}.layout-editor:not(.layout-editor-dragging) .layout-element-active,.layout-editor:not(.layout-editor-dragging) .layout-element-focused{border-width:2px;border-style:solid}.layout-editor:not(.layout-editor-dragging) .layout-element-active>.layout-element-wrapper,.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper{margin:-2px}.layout-editor:not(.layout-editor-dragging) .layout-element-active{border-color:rgba(104,104,104,.1)}.layout-editor:not(.layout-editor-dragging) .layout-element-active>.layout-element-wrapper>.layout-panel-main{display:block;z-index:30;background-color:rgba(104,104,104,.1)}.layout-editor:not(.layout-editor-dragging) .layout-element-focused{border-color:#648721}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel{display:block;background-color:#648721;color:#fefefe}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action{display:inline-block}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action:hover{background-color:#82b02b}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action.disabled{cursor:default;color:rgba(254,254,254,.4)}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action.disabled:hover{background-color:#648721}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action.active{color:#deff42;background-color:#739b26}.layout-editor:not(.layout-editor-dragging) .layout-element-focused>.layout-element-wrapper>.layout-panel>.layout-panel-action.active:hover{background-color:#82b02b}.layout-editor:not(.layout-editor-dragging) .layout-element-selected{background-color:rgba(100,135,33,.08)}.layout-editor .ui-sortable-placeholder{display:none}.layout-editor .layout-element-droptarget{box-shadow:inset 0 0 12px 6px rgba(100,135,33,.5)}.layout-editor .layout-element-droptarget .ui-sortable-placeholder{display:block;visibility:visible!important;min-height:78px;border:2px dashed #648721!important;background-color:rgba(100,135,33,.16)}.layout-editor .media-thumbnail img{max-width:100%;max-height:100%}.layout-editor .layout-container>.layout-element-wrapper>.layout-container-children-placeholder{display:none;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;margin:11px;min-height:80px;border:1px dashed rgba(124,124,124,.4);border-radius:4px;padding:12px;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;font-size:13px;font-style:italic;opacity:.6;text-align:center}.layout-editor .layout-container>.layout-element-wrapper>.layout-children{padding:12px}.layout-editor .layout-container>.layout-element-wrapper>.layout-children>.layout-element:not(.layout-container)+.layout-element:not(.layout-container){margin-top:12px}.layout-editor .layout-container>.layout-element-wrapper>.layout-children>.ui-sortable-helper:first-child+.layout-element:not(.layout-container){margin-top:0}.layout-editor .layout-container>.layout-element-wrapper.layout-container-empty>.layout-container-children-placeholder{display:-webkit-flex;display:-ms-flexbox;display:flex}.layout-editor .layout-container>.layout-element-wrapper.layout-container-empty>.layout-children{position:absolute;top:0;right:0;bottom:0;left:0}.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused>.layout-element-wrapper>.layout-children>.layout-element:not(.layout-element-active){border:1px dashed rgba(124,124,124,.6)}.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused>.layout-element-wrapper>.layout-children>.layout-element:not(.layout-element-active)>.layout-element-wrapper{margin:-1px}.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused>.layout-element-wrapper>.layout-children>.layout-container+.layout-container:not(.layout-element-active){border-top:0}.layout-editor:not(.layout-editor-dragging) .layout-container.layout-element-focused>.layout-element-wrapper>.layout-children>.layout-container+.layout-container:not(.layout-element-active)>.layout-element-wrapper{margin-top:0}.layout-editor .layout-canvas #dummy{display:none}.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget)>.layout-element-wrapper>.layout-children>.layout-element:not(.layout-element-active){border-top:1px dashed rgba(124,124,124,.6)!important}.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget)>.layout-element-wrapper>.layout-children>.layout-element:not(.layout-element-active)>.layout-element-wrapper{margin-top:-1px!important}.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget)>.layout-element-wrapper>.layout-children>.layout-element+.layout-element:not(.layout-element-active){border-left:0!important}.layout-editor .layout-row.layout-element-focused:not(.layout-element-droptarget)>.layout-element-wrapper>.layout-children>.layout-element+.layout-element:not(.layout-element-active)>.layout-element-wrapper{margin-left:0!important}.layout-editor .layout-column>.layout-element-wrapper>.layout-column-resize-bar{display:none;position:absolute;z-index:30;top:0;width:16px;height:100%;cursor:col-resize}.layout-editor .layout-column.layout-element-focused>.layout-element-wrapper>.layout-column-resize-bar,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup address,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup blockquote,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup center,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup div,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup figcaption,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup figure,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup footer,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup form,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup header,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup hr,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup legend,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup listing,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup p,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup plaintext,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup pre,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup xmp,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup address,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup blockquote,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup center,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup div,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup figcaption,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup figure,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup footer,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup form,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup header,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup hr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup legend,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup listing,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup p,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup plaintext,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup pre,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup xmp{display:block}.layout-editor .layout-column>.layout-element-wrapper>.layout-column-resize-bar-left{left:-6px}.layout-editor .layout-column>.layout-element-wrapper>.layout-column-resize-bar-right{right:-6px}.layout-editor .layout-content,.layout-editor .layout-html{min-height:1em}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup{padding:2px;overflow-x:hidden;line-height:normal}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup *,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup *{margin:0;padding:0;box-sizing:content-box}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup blockquote,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup figure,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup listing,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup p,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup plaintext,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup pre,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup xmp,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup blockquote,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup figure,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup listing,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup p,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup plaintext,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup pre,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup xmp{margin-top:1em;margin-bottom:1em}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup blockquote,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup figure,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup blockquote,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup figure{margin-left:40px;margin-right:40px}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup listing,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup plaintext,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup pre,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup xmp,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup listing,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup plaintext,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup pre,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup xmp{font-family:monospace;white-space:pre}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup b,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup strong,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup b,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup strong{font-weight:bolder}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup code,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup kbd,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup samp,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tt,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup code,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup kbd,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup samp,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tt{font-family:monospace}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup big,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup big{font-size:larger}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup small,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup small{font-size:smaller}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup sub,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup sub{vertical-align:sub}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup sup,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup sup{vertical-align:super}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup sub,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup sup,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup sub,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup sup{line-height:normal;font-size:smaller}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ruby,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ruby{display:ruby}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rb,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rb{display:ruby-base;white-space:nowrap}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rt,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rt{display:ruby-text;white-space:nowrap;font-size:50%;font-variant-east-asian:ruby;-webkit-text-emphasis:none;text-emphasis:none}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rbc,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rbc{display:ruby-base-container}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rtc,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rtc{display:ruby-text-container}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup article,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup aside,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dd,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dt,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h1,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h2,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h3,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h4,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h5,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h6,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup hgroup,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup nav,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup section,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup article,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup aside,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dd,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dl,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dt,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h1,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h2,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h3,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h4,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h5,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h6,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup hgroup,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup nav,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup section,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul{display:block}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rb,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rbc,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rt,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup rtc,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ruby,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rb,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rbc,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rt,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup rtc,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ruby{unicode-bidi:isolate}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup :link,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup :link{color:#00E}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup :visited,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup :visited{color:#551A8B}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup :link,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup :visited,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup :link,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup :visited{text-decoration:underline}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup a:link[rel~=help],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup a:visited[rel~=help],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup area:link[rel~=help],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup area:visited[rel~=help],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup a:link[rel~=help],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup a:visited[rel~=help],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup area:link[rel~=help],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup area:visited[rel~=help]{cursor:help}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup :focus,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup :focus{outline:auto}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup mark,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup mark{background:#ff0;color:#000}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup abbr[title],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup acronym[title],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup abbr[title],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup acronym[title]{text-decoration:dotted underline}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ins,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup u,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ins,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup u{text-decoration:underline}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup del,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup s,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup strike,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup del,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup s,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup strike{text-decoration:line-through}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup blink,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup blink{text-decoration:blink}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup q::before,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup q::before{content:open-quote}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup q::after,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup q::after{content:close-quote}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup br,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup br{content:'\A';white-space:pre}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup nobr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup nobr{white-space:nowrap}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup wbr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup wbr{content:'\200B'}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup nobr wbr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup nobr wbr{white-space:normal}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h1,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h1{margin-top:.67em;margin-bottom:.67em;font-size:2em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h2,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h2{margin-top:.83em;margin-bottom:.83em;font-size:1.5em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h3,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h3{margin-top:1em;margin-bottom:1em;font-size:1.17em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h4,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h4{margin-top:1.33em;margin-bottom:1.33em;font-size:1em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h5,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h5{margin-top:1.67em;margin-bottom:1.67em;font-size:.83em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup h6,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup h6{margin-top:2.33em;margin-bottom:2.33em;font-size:.67em;font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup li,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup li{display:list-item}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dl,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul{margin-top:1em;margin-bottom:1em}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dl ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul dl,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir dl,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dl dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dl dl,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dl ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dl ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol dl,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul dl,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul ul{margin-top:0;margin-bottom:0}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dd,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dd{margin-left:40px}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul{padding-left:40px}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol{list-style-type:decimal}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul{list-style-type:disc}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul ul{list-style-type:circle}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir dir dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir dir ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ol dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ol ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ul dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup dir ul ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol dir dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol dir ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ol dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ol ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ul dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ol ul ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul dir dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul dir ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ol dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ol ul,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ul dir,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup ul ul ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir dir dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir dir ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir ol dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir ol ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir ul dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup dir ul ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol dir dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol dir ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol ol dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol ol ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol ul dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ol ul ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul dir dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul dir ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul ol dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul ol ul,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul ul dir,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup ul ul ul{list-style-type:square}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup table,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup table{display:table;box-sizing:border-box;border-spacing:2px;border-collapse:separate;text-indent:initial}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup caption,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup caption{display:table-caption}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup colgroup,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup colgroup[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup colgroup,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup colgroup[hidden]{display:table-column-group}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup col,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup col[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup col,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup col[hidden]{display:table-column}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup thead,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup thead[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup thead,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup thead[hidden]{display:table-header-group}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tbody,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tbody[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tbody,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tbody[hidden]{display:table-row-group}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tfoot,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tfoot[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tfoot,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tfoot[hidden]{display:table-footer-group}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tr,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tr[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tr[hidden]{display:table-row}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup td[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup th[hidden]{display:table-cell}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup col[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup colgroup[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tbody[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tfoot[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup thead[hidden],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tr[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup col[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup colgroup[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tbody[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup td[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tfoot[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup th[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup thead[hidden],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tr[hidden]{visibility:collapse}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup th{padding:1px}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup th{font-weight:700}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup table>tr,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tbody,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tfoot,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup thead,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup table>tr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tbody,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tfoot,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup thead{vertical-align:middle}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tr{vertical-align:inherit}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup table,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup th,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup table,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup td,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup th{border-color:gray}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tbody,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tfoot,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup thead,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup tr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tbody,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tfoot,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup thead,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup tr{border-color:inherit}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup button,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup keygen,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup optgroup,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup option,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup select,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup textarea,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup button,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup input,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup keygen,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup optgroup,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup option,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup select,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup textarea{text-indent:initial}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup textarea,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup textarea{white-space:pre-wrap}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup button,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=radio],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=checkbox],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=reset],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=button],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=submit],.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup select,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup button,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup input[type=radio],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup input[type=checkbox],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup input[type=reset],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup input[type=button],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup input[type=submit],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup select{box-sizing:border-box}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup button,.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup input[type=button],.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup button,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup input[type=button]{padding:.3em .5em}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup hr,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup hr{color:gray;border-style:inset;border-width:1px;margin:.5em auto}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup fieldset,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup fieldset{margin-left:2px;margin-right:2px;border:2px groove ThreeDFace;padding:.35em .625em .75em}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup legend,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup legend{padding-left:2px;padding-right:2px}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>:first-child,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup>:first-child{margin-top:0!important}.layout-editor .layout-content>.layout-element-wrapper .layout-content-markup>:last-child,.layout-editor .layout-html>.layout-element-wrapper .layout-content-markup>:last-child{margin-bottom:0!important}.layout-editor .img-responsive,.layout-editor .img-responsive img,.layout-editor .layout-content.layout-content-image>.layout-element-wrapper>.layout-content-markup>img,.layout-editor .layout-content.layout-content-vector-image>.layout-element-wrapper>.layout-content-markup>img,.layout-editor .layout-html.layout-content-image>.layout-element-wrapper>.layout-content-markup>img,.layout-editor .layout-html.layout-content-vector-image>.layout-element-wrapper>.layout-content-markup>img{display:block;width:100%;max-width:100%;height:auto}.layout-editor>.layout-toolbox-wrapper{position:relative;margin-left:12px;width:220px;-webkit-flex-shrink:0;-ms-flex-negative:0;flex-shrink:0}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox{border:1px solid #e4e5e6;width:220px;min-height:400px;padding:6px;background-color:#f3f4f5}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox.sticky-top{position:fixed;top:0;max-height:100%;overflow-y:auto}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox.sticky-bottom{position:absolute;bottom:0}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group{margin-top:12px}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-item+.layout-toolbox-item,.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-section+.layout-toolbox-section{margin-top:4px}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-group-heading{display:block;margin-bottom:4px;text-decoration:none}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-group-heading:before{display:inline-block;width:10px;margin-right:4px;font:normal normal normal 14px/1 FontAwesome;text-align:center;content:"\f0d7"}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group.collapsed .layout-toolbox-group-heading:before{content:"\f0da"}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group.collapsed .layout-toolbox-items{display:none}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-item{border:1px solid #e4e5e6;background-color:#fff;padding:9px 12px;cursor:default}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group .layout-toolbox-item i{display:inline-block;width:16px;font:normal normal normal 14px/1 FontAwesome}.layout-editor>.layout-toolbox-wrapper>.layout-toolbox .layout-toolbox-group+.layout-toolbox-group{margin-top:6px}.layout-editor .layout-popup{display:none;position:absolute;margin:0;box-shadow:3px 3px 11px 0 rgba(50,50,50,.5);border:1px solid #e4e5e6;padding:2px 0;background-color:#f7f7f7;list-style:none;z-index:20;color:#7c7c7c;text-align:left;cursor:default;white-space:nowrap;line-height:normal;min-width:300px}.layout-editor .layout-popup.wide{width:600px}.layout-editor .layout-popup .layout-popup-flex{display:-webkit-flex;display:-ms-flexbox;display:flex;padding:2px 5px}.layout-editor .layout-popup .layout-popup-flex .layout-popup-column+.layout-popup-column{margin-left:4px;border-left:1px solid rgba(128,128,128,.15);padding-left:4px}.layout-editor .layout-popup .layout-popup-item{padding:4px 6px}.layout-editor .layout-popup .layout-popup-label{font-size:.9em;font-weight:700;color:#7c7c7c}.layout-editor .layout-popup .layout-popup-action:hover{background-color:#f3f4f5;cursor:pointer}.layout-editor .layout-popup .layout-popup-input input[type=text],.layout-editor .layout-popup .layout-popup-input textarea{width:100%}.layout-editor .layout-popup .layout-popup-input>label{display:block;font-size:.9em} \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor/Content.less b/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor/Content.less index c9e0c8aae..87e32df79 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor/Content.less +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor/Content.less @@ -1,7 +1,8 @@ @import "Variables.less"; +@import "Reset.less"; .layout-editor { - .layout-content { + .layout-content, .layout-html { min-height: 1em; > .layout-element-wrapper { @@ -12,7 +13,7 @@ line-height: normal; // Reset to HTML5 W3C standard default styling within content. - @import "Reset.less"; + .reset(); > *:first-child { margin-top: 0 !important; // Important because site.css of the admin theme styles heading margins with a very high specificity. diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor/Reset.less b/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor/Reset.less index 27df93cd8..9e356cd3a 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor/Reset.less +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor/Reset.less @@ -1,340 +1,339 @@ -* { - margin: 0; - padding: 0; - box-sizing: content-box; -} +.reset() { -address, blockquote, center, div, figure, figcaption, footer, form, -header, hr, legend, listing, p, plaintext, pre, xmp { - display: block; -} - -blockquote, figure, listing, p, plaintext, pre, xmp { - margin-top: 1em; - margin-bottom: 1em; -} - -blockquote, figure { - margin-left: 40px; - margin-right: 40px; -} - -address { - font-style: italic; -} - -listing, plaintext, pre, xmp { - font-family: monospace; - white-space: pre; -} - -cite, dfn, em, i, var { - font-style: italic; -} - -b, strong { - font-weight: bolder; -} - -code, kbd, samp, tt { - font-family: monospace; -} - -big { - font-size: larger; -} - -small { - font-size: smaller; -} - -sub { - vertical-align: sub; -} - -sup { - vertical-align: super; -} - -sub, sup { - line-height: normal; - font-size: smaller; -} - - -ruby { - display: ruby; -} - -rb { - display: ruby-base; - white-space: nowrap; -} - -rt { - display: ruby-text; - white-space: nowrap; - font-size: 50%; - font-variant-east-asian: ruby; - text-emphasis: none; -} - -rbc { - display: ruby-base-container; -} - -rtc { - display: ruby-text-container; -} - -ruby, rb, rt, rbc, rtc { - unicode-bidi: isolate; -} - - -:link { - color: #0000EE; -} - -:visited { - color: #551A8B; -} - -:link, :visited { - text-decoration: underline; -} - -a:link[rel~=help], a:visited[rel~=help], -area:link[rel~=help], area:visited[rel~=help] { - cursor: help; -} - -:focus { - outline: auto; -} - -mark { - background: yellow; - color: black; -} -/* this color is just a suggestion and can be changed based on implementation feedback */ -abbr[title], acronym[title] { - text-decoration: dotted underline; -} - -ins, u { - text-decoration: underline; -} - -del, s, strike { - text-decoration: line-through; -} - -blink { - text-decoration: blink; -} - -q::before { - content: open-quote; -} - -q::after { - content: close-quote; -} - -br { - content: '\A'; - white-space: pre; -} -/* this also has bidi implications */ -nobr { - white-space: nowrap; -} - -wbr { - content: '\200B'; -} -/* this also has bidi implications */ -nobr wbr { - white-space: normal; -} - -article, aside, h1, h2, h3, h4, h5, h6, hgroup, nav, section { - display: block; -} - -h1 { - margin-top: 0.67em; - margin-bottom: 0.67em; - font-size: 2.00em; - font-weight: bold; -} - -h2 { - margin-top: 0.83em; - margin-bottom: 0.83em; - font-size: 1.50em; - font-weight: bold; -} - -h3 { - margin-top: 1.00em; - margin-bottom: 1.00em; - font-size: 1.17em; - font-weight: bold; -} - -h4 { - margin-top: 1.33em; - margin-bottom: 1.33em; - font-size: 1.00em; - font-weight: bold; -} - -h5 { - margin-top: 1.67em; - margin-bottom: 1.67em; - font-size: 0.83em; - font-weight: bold; -} - -h6 { - margin-top: 2.33em; - margin-bottom: 2.33em; - font-size: 0.67em; - font-weight: bold; -} - -dir, dd, dl, dt, ol, ul { - display: block; -} - -li { - display: list-item; -} - -dir, dl, ol, ul { - margin-top: 1em; - margin-bottom: 1em; -} - - dir dir, dir dl, dir ol, dir ul, - dl dir, dl dl, dl ol, dl ul, - ol dir, ol dl, ol ol, ol ul, - ul dir, ul dl, ul ol, ul ul { - margin-top: 0; - margin-bottom: 0; + * { + margin: 0; + padding: 0; + box-sizing: content-box; } -dd { - margin-left: 40px; -} - -/* LTR-specific: use 'margin-right' for rtl elements */ -dir, ol, ul { - padding-left: 40px; -} - -/* LTR-specific: use 'padding-right' for rtl elements */ -ol { - list-style-type: decimal; -} - -dir, ul { - list-style-type: disc; -} - - dir dir, dir ul, - ol dir, ol ul, - ul dir, ul ul { - list-style-type: circle; + address, blockquote, center, div, figure, figcaption, footer, form, + header, hr, legend, listing, p, plaintext, pre, xmp { + display: block; } - dir dir dir, dir dir ul, - dir ol dir, dir ol ul, - dir ul dir, dir ul ul, - ol dir dir, ol dir ul, - ol ol dir, ol ol ul, - ol ul dir, ol ul ul, - ul dir dir, ul dir ul, - ul ol dir, ul ol ul, - ul ul dir, ul ul ul { - list-style-type: square; + blockquote, figure, listing, p, plaintext, pre, xmp { + margin-top: 1em; + margin-bottom: 1em; + } + + blockquote, figure { + margin-left: 40px; + margin-right: 40px; + } + + address { + font-style: italic; + } + + listing, plaintext, pre, xmp { + font-family: monospace; + white-space: pre; + } + + cite, dfn, em, i, var { + font-style: italic; + } + + b, strong { + font-weight: bolder; + } + + code, kbd, samp, tt { + font-family: monospace; + } + + big { + font-size: larger; + } + + small { + font-size: smaller; + } + + sub { + vertical-align: sub; + } + + sup { + vertical-align: super; + } + + sub, sup { + line-height: normal; + font-size: smaller; + } + + + ruby { + display: ruby; + } + + rb { + display: ruby-base; + white-space: nowrap; + } + + rt { + display: ruby-text; + white-space: nowrap; + font-size: 50%; + font-variant-east-asian: ruby; + text-emphasis: none; + } + + rbc { + display: ruby-base-container; + } + + rtc { + display: ruby-text-container; + } + + ruby, rb, rt, rbc, rtc { + unicode-bidi: isolate; + } + + + :link { + color: #0000EE; + } + + :visited { + color: #551A8B; + } + + :link, :visited { + text-decoration: underline; + } + + a:link[rel~=help], a:visited[rel~=help], + area:link[rel~=help], area:visited[rel~=help] { + cursor: help; + } + + :focus { + outline: auto; + } + + mark { + background: yellow; + color: black; + } + /* this color is just a suggestion and can be changed based on implementation feedback */ + abbr[title], acronym[title] { + text-decoration: dotted underline; + } + + ins, u { + text-decoration: underline; + } + + del, s, strike { + text-decoration: line-through; + } + + blink { + text-decoration: blink; + } + + q::before { + content: open-quote; + } + + q::after { + content: close-quote; + } + + br { + content: '\A'; + white-space: pre; + } + /* this also has bidi implications */ + nobr { + white-space: nowrap; + } + + wbr { + content: '\200B'; + } + /* this also has bidi implications */ + nobr wbr { + white-space: normal; + } + + article, aside, h1, h2, h3, h4, h5, h6, hgroup, nav, section { + display: block; + } + + h1 { + margin-top: 0.67em; + margin-bottom: 0.67em; + font-size: 2.00em; + font-weight: bold; + } + + h2 { + margin-top: 0.83em; + margin-bottom: 0.83em; + font-size: 1.50em; + font-weight: bold; + } + + h3 { + margin-top: 1.00em; + margin-bottom: 1.00em; + font-size: 1.17em; + font-weight: bold; + } + + h4 { + margin-top: 1.33em; + margin-bottom: 1.33em; + font-size: 1.00em; + font-weight: bold; + } + + h5 { + margin-top: 1.67em; + margin-bottom: 1.67em; + font-size: 0.83em; + font-weight: bold; + } + + h6 { + margin-top: 2.33em; + margin-bottom: 2.33em; + font-size: 0.67em; + font-weight: bold; + } + + dir, dd, dl, dt, ol, ul { + display: block; + } + + li { + display: list-item; + } + + dir, dl, ol, ul { + margin-top: 1em; + margin-bottom: 1em; + } + + dir dir, dir dl, dir ol, dir ul, + dl dir, dl dl, dl ol, dl ul, + ol dir, ol dl, ol ol, ol ul, + ul dir, ul dl, ul ol, ul ul { + margin-top: 0; + margin-bottom: 0; } -table { - display: table; -} - -caption { - display: table-caption; -} - -colgroup, colgroup[hidden] { - display: table-column-group; -} - -col, col[hidden] { - display: table-column; -} - -thead, thead[hidden] { - display: table-header-group; -} - -tbody, tbody[hidden] { - display: table-row-group; -} - -tfoot, tfoot[hidden] { - display: table-footer-group; -} - -tr, tr[hidden] { - display: table-row; -} - -td, th, td[hidden], th[hidden] { - display: table-cell; -} - - colgroup[hidden], col[hidden], thead[hidden], tbody[hidden], - tfoot[hidden], tr[hidden], td[hidden], th[hidden] { - visibility: collapse; + dd { + margin-left: 40px; + } + /* LTR-specific: use 'margin-right' for rtl elements */ + dir, ol, ul { + padding-left: 40px; + } + /* LTR-specific: use 'padding-right' for rtl elements */ + ol { + list-style-type: decimal; } -table { - box-sizing: border-box; - border-spacing: 2px; - border-collapse: separate; - text-indent: initial; -} + dir, ul { + list-style-type: disc; + } -td, th { - padding: 1px; -} + dir dir, dir ul, + ol dir, ol ul, + ul dir, ul ul { + list-style-type: circle; + } -th { - font-weight: bold; -} + dir dir dir, dir dir ul, + dir ol dir, dir ol ul, + dir ul dir, dir ul ul, + ol dir dir, ol dir ul, + ol ol dir, ol ol ul, + ol ul dir, ol ul ul, + ul dir dir, ul dir ul, + ul ol dir, ul ol ul, + ul ul dir, ul ul ul { + list-style-type: square; + } -thead, tbody, tfoot, table > tr { - vertical-align: middle; -} + table { + display: table; + } -tr, td, th { - vertical-align: inherit; -} + caption { + display: table-caption; + } -table, td, th { - border-color: gray; -} + colgroup, colgroup[hidden] { + display: table-column-group; + } -thead, tbody, tfoot, tr { - border-color: inherit; -} + col, col[hidden] { + display: table-column; + } -/*table[rules=none i], table[rules=groups i], table[rules=rows i], + thead, thead[hidden] { + display: table-header-group; + } + + tbody, tbody[hidden] { + display: table-row-group; + } + + tfoot, tfoot[hidden] { + display: table-footer-group; + } + + tr, tr[hidden] { + display: table-row; + } + + td, th, td[hidden], th[hidden] { + display: table-cell; + } + + colgroup[hidden], col[hidden], thead[hidden], tbody[hidden], + tfoot[hidden], tr[hidden], td[hidden], th[hidden] { + visibility: collapse; + } + + table { + box-sizing: border-box; + border-spacing: 2px; + border-collapse: separate; + text-indent: initial; + } + + td, th { + padding: 1px; + } + + th { + font-weight: bold; + } + + thead, tbody, tfoot, table > tr { + vertical-align: middle; + } + + tr, td, th { + vertical-align: inherit; + } + + table, td, th { + border-color: gray; + } + + thead, tbody, tfoot, tr { + border-color: inherit; + } + /*table[rules=none i], table[rules=groups i], table[rules=rows i], table[rules=cols i], table[rules=all i], table[frame=void i], table[frame=above i], table[frame=below i], table[frame=hsides i], table[frame=lhs i], table[frame=rhs i], table[frame=vsides i], @@ -361,39 +360,39 @@ table[rules=cols i] > tfoot > tr > td, table[rules=cols i] > tfoot > tr > th, table[rules=all i] > tfoot > tr > td, table[rules=all i] > tfoot > tr > th { border-color: black; }*/ + input, select, option, optgroup, button, textarea, keygen { + text-indent: initial; + } -input, select, option, optgroup, button, textarea, keygen { - text-indent: initial; -} + textarea { + white-space: pre-wrap; + } -textarea { - white-space: pre-wrap; -} + input[type="radio"], input[type="checkbox"], input[type="reset"], input[type="button"], + input[type="submit"], select, button { + box-sizing: border-box; + } -input[type="radio"], input[type="checkbox"], input[type="reset"], input[type="button"], -input[type="submit"], select, button { - box-sizing: border-box; -} + input[type="button"], button { + padding: 0.3em 0.5em; + } -input[type="button"], button { - padding: 0.3em 0.5em; -} + hr { + color: gray; + border-style: inset; + border-width: 1px; + margin: 0.5em auto; + } -hr { - color: gray; - border-style: inset; - border-width: 1px; - margin: 0.5em auto; -} + fieldset { + margin-left: 2px; + margin-right: 2px; + border: groove 2px ThreeDFace; + padding: 0.35em 0.625em 0.75em; + } -fieldset { - margin-left: 2px; - margin-right: 2px; - border: groove 2px ThreeDFace; - padding: 0.35em 0.625em 0.75em; -} - -legend { - padding-left: 2px; - padding-right: 2px; + legend { + padding-left: 2px; + padding-right: 2px; + } } diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor/Toolbox.less b/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor/Toolbox.less index 4095f6aef..931abb59e 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor/Toolbox.less +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Styles/LayoutEditor/Toolbox.less @@ -17,6 +17,8 @@ &.sticky-top { position: fixed; top: 0; + max-height: 100%; + overflow-y: auto; } &.sticky-bottom { diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Styles/Lib.css b/src/Orchard.Web/Modules/Orchard.Layouts/Styles/Lib.css index 9c2210d11..91e68ed56 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Styles/Lib.css +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Styles/Lib.css @@ -2609,4 +2609,4 @@ content: "\f23a"; } -/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["bootstrap.less","mixins/vendor-prefixes.less","Lib.css","scaffolding.less","mixins/tab-focus.less","mixins/image.less","mixins/grid.less","grid.less","mixins/grid-framework.less","mixins/clearfix.less","utilities.less","mixins/center-block.less","mixins/hide-text.less","path.less","core.less","larger.less","fixed-width.less","list.less","bordered-pulled.less","animated.less","rotated-flipped.less","mixins.less","stacked.less","icons.less"],"names":[],"mappings":"AAKA;ECuEU,uBAAA;CCxET;AFCD;;ECuEU,uBAAA;CClET;AFLD;EGiBE,gBAAA;EACA,8CAAA;CDTD;AFTD;EGsBE,4DAAA;EACA,gBAAA;EACA,wBAAA;EACA,eAAA;EACA,0BAAA;CDVD;AFhBD;;;;EGkCE,qBAAA;EACA,mBAAA;EACA,qBAAA;CDZD;AFxBD;EG2CE,eAAA;EACA,sBAAA;CDhBD;ACkBC;;EAEE,eAAA;EACA,2BAAA;CDhBH;ACmBC;ECrDA,qBAAA;EAEA,2CAAA;EACA,qBAAA;CFoCD;AFtCD;EGgEE,UAAA;CDvBD;AFzCD;EGuEE,uBAAA;CD3BD;AF5CD;EKIE,eAAA;EACA,gBAAA;EACA,aAAA;CH2CD;AFjDD;EGiFE,mBAAA;CD7BD;AFpDD;EGwFE,aAAA;EACA,wBAAA;EACA,0BAAA;EACA,0BAAA;EACA,mBAAA;EF+FQ,iCAAA;EIvLR,sBAAA;EACA,gBAAA;EACA,aAAA;CH2DD;AFjED;EGqGE,mBAAA;CDjCD;AFpED;EG4GE,iBAAA;EACA,oBAAA;EACA,UAAA;EACA,8BAAA;CDrCD;AF1ED;EGwHE,mBAAA;EACA,WAAA;EACA,YAAA;EACA,aAAA;EACA,WAAA;EACA,iBAAA;EACA,uBAAA;EACA,UAAA;CD3CD;ACmDC;;EAEE,iBAAA;EACA,YAAA;EACA,aAAA;EACA,UAAA;EACA,kBAAA;EACA,WAAA;CDjDH;AF7FD;EMCE,mBAAA;EACA,kBAAA;EACA,mBAAA;EACA,oBAAA;CJ+FD;AKzFC;EAqEF;IAvEI,aAAA;GL+FD;CACF;AK3FC;EAkEF;IApEI,aAAA;GLiGD;CACF;AK7FD;EA+DA;IAjEI,cAAA;GLmGD;CACF;AFlHD;EMCE,mBAAA;EACA,kBAAA;EACA,mBAAA;EACA,oBAAA;CJoHD;AFxHD;EMUE,mBAAA;EACA,oBAAA;CJiHD;AF5HD;EQYM,mBAAA;EAEA,gBAAA;EAEA,mBAAA;EACA,oBAAA;CNiHL;AFlID;EQkCM,YAAA;CNmGL;AFrID;EQ0CI,YAAA;CN8FH;AFxID;EQ0CI,oBAAA;CNiGH;AF3ID;EQ0CI,oBAAA;CNoGH;AF9ID;EQ0CI,WAAA;CNuGH;AFjJD;EQ0CI,oBAAA;CN0GH;AFpJD;EQ0CI,oBAAA;CN6GH;AFvJD;EQ0CI,WAAA;CNgHH;AF1JD;EQ0CI,oBAAA;CNmHH;AF7JD;EQ0CI,oBAAA;CNsHH;AFhKD;EQ0CI,WAAA;CNyHH;AFnKD;EQ0CI,oBAAA;CN4HH;AFtKD;EQ0CI,mBAAA;CN+HH;AFzKD;EQyDI,YAAA;CNmHH;AF5KD;EQyDI,oBAAA;CNsHH;AF/KD;EQyDI,oBAAA;CNyHH;AFlLD;EQyDI,WAAA;CN4HH;AFrLD;EQyDI,oBAAA;CN+HH;AFxLD;EQyDI,oBAAA;CNkIH;AF3LD;EQyDI,WAAA;CNqIH;AF9LD;EQyDI,oBAAA;CNwIH;AFjMD;EQyDI,oBAAA;CN2IH;AFpMD;EQyDI,WAAA;CN8IH;AFvMD;EQyDI,oBAAA;CNiJH;AF1MD;EQyDI,mBAAA;CNoJH;AF7MD;EQ8DI,YAAA;CNkJH;AFhND;EQ+CI,WAAA;CNoKH;AFnND;EQ+CI,mBAAA;CNuKH;AFtND;EQ+CI,mBAAA;CN0KH;AFzND;EQ+CI,UAAA;CN6KH;AF5ND;EQ+CI,mBAAA;CNgLH;AF/ND;EQ+CI,mBAAA;CNmLH;AFlOD;EQ+CI,UAAA;CNsLH;AFrOD;EQ+CI,mBAAA;CNyLH;AFxOD;EQ+CI,mBAAA;CN4LH;AF3OD;EQ+CI,UAAA;CN+LH;AF9OD;EQ+CI,mBAAA;CNkMH;AFjPD;EQ+CI,kBAAA;CNqMH;AFpPD;EQoDI,WAAA;CNmMH;AFvPD;EQmEI,kBAAA;CNuLH;AF1PD;EQmEI,0BAAA;CN0LH;AF7PD;EQmEI,0BAAA;CN6LH;AFhQD;EQmEI,iBAAA;CNgMH;AFnQD;EQmEI,0BAAA;CNmMH;AFtQD;EQmEI,0BAAA;CNsMH;AFzQD;EQmEI,iBAAA;CNyMH;AF5QD;EQmEI,0BAAA;CN4MH;AF/QD;EQmEI,0BAAA;CN+MH;AFlRD;EQmEI,iBAAA;CNkNH;AFrRD;EQmEI,0BAAA;CNqNH;AFxRD;EQmEI,yBAAA;CNwNH;AF3RD;EQmEI,gBAAA;CN2NH;AK3ND;EAYA;IC7CM,YAAA;GNgQH;EKnNH;ICrCI,YAAA;GN2PD;EKtNH;ICrCI,oBAAA;GN8PD;EKzNH;ICrCI,oBAAA;GNiQD;EK5NH;ICrCI,WAAA;GNoQD;EK/NH;ICrCI,oBAAA;GNuQD;EKlOH;ICrCI,oBAAA;GN0QD;EKrOH;ICrCI,WAAA;GN6QD;EKxOH;ICrCI,oBAAA;GNgRD;EK3OH;ICrCI,oBAAA;GNmRD;EK9OH;ICrCI,WAAA;GNsRD;EKjPH;ICrCI,oBAAA;GNyRD;EKpPH;ICrCI,mBAAA;GN4RD;EKvPH;ICtBI,YAAA;GNgRD;EK1PH;ICtBI,oBAAA;GNmRD;EK7PH;ICtBI,oBAAA;GNsRD;EKhQH;ICtBI,WAAA;GNyRD;EKnQH;ICtBI,oBAAA;GN4RD;EKtQH;ICtBI,oBAAA;GN+RD;EKzQH;ICtBI,WAAA;GNkSD;EK5QH;ICtBI,oBAAA;GNqSD;EK/QH;ICtBI,oBAAA;GNwSD;EKlRH;ICtBI,WAAA;GN2SD;EKrRH;ICtBI,oBAAA;GN8SD;EKxRH;ICtBI,mBAAA;GNiTD;EK3RH;ICjBI,YAAA;GN+SD;EK9RH;IChCI,WAAA;GNiUD;EKjSH;IChCI,mBAAA;GNoUD;EKpSH;IChCI,mBAAA;GNuUD;EKvSH;IChCI,UAAA;GN0UD;EK1SH;IChCI,mBAAA;GN6UD;EK7SH;IChCI,mBAAA;GNgVD;EKhTH;IChCI,UAAA;GNmVD;EKnTH;IChCI,mBAAA;GNsVD;EKtTH;IChCI,mBAAA;GNyVD;EKzTH;IChCI,UAAA;GN4VD;EK5TH;IChCI,mBAAA;GN+VD;EK/TH;IChCI,kBAAA;GNkWD;EKlUH;IC3BI,WAAA;GNgWD;EKrUH;ICZI,kBAAA;GNoVD;EKxUH;ICZI,0BAAA;GNuVD;EK3UH;ICZI,0BAAA;GN0VD;EK9UH;ICZI,iBAAA;GN6VD;EKjVH;ICZI,0BAAA;GNgWD;EKpVH;ICZI,0BAAA;GNmWD;EKvVH;ICZI,iBAAA;GNsWD;EK1VH;ICZI,0BAAA;GNyWD;EK7VH;ICZI,0BAAA;GN4WD;EKhWH;ICZI,iBAAA;GN+WD;EKnWH;ICZI,0BAAA;GNkXD;EKtWH;ICZI,yBAAA;GNqXD;EKzWH;ICZI,gBAAA;GNwXD;CACF;AKhXD;EAGA;IC7CM,YAAA;GN8ZH;EKjXH;ICrCI,YAAA;GNyZD;EKpXH;ICrCI,oBAAA;GN4ZD;EKvXH;ICrCI,oBAAA;GN+ZD;EK1XH;ICrCI,WAAA;GNkaD;EK7XH;ICrCI,oBAAA;GNqaD;EKhYH;ICrCI,oBAAA;GNwaD;EKnYH;ICrCI,WAAA;GN2aD;EKtYH;ICrCI,oBAAA;GN8aD;EKzYH;ICrCI,oBAAA;GNibD;EK5YH;ICrCI,WAAA;GNobD;EK/YH;ICrCI,oBAAA;GNubD;EKlZH;ICrCI,mBAAA;GN0bD;EKrZH;ICtBI,YAAA;GN8aD;EKxZH;ICtBI,oBAAA;GNibD;EK3ZH;ICtBI,oBAAA;GNobD;EK9ZH;ICtBI,WAAA;GNubD;EKjaH;ICtBI,oBAAA;GN0bD;EKpaH;ICtBI,oBAAA;GN6bD;EKvaH;ICtBI,WAAA;GNgcD;EK1aH;ICtBI,oBAAA;GNmcD;EK7aH;ICtBI,oBAAA;GNscD;EKhbH;ICtBI,WAAA;GNycD;EKnbH;ICtBI,oBAAA;GN4cD;EKtbH;ICtBI,mBAAA;GN+cD;EKzbH;ICjBI,YAAA;GN6cD;EK5bH;IChCI,WAAA;GN+dD;EK/bH;IChCI,mBAAA;GNkeD;EKlcH;IChCI,mBAAA;GNqeD;EKrcH;IChCI,UAAA;GNweD;EKxcH;IChCI,mBAAA;GN2eD;EK3cH;IChCI,mBAAA;GN8eD;EK9cH;IChCI,UAAA;GNifD;EKjdH;IChCI,mBAAA;GNofD;EKpdH;IChCI,mBAAA;GNufD;EKvdH;IChCI,UAAA;GN0fD;EK1dH;IChCI,mBAAA;GN6fD;EK7dH;IChCI,kBAAA;GNggBD;EKheH;IC3BI,WAAA;GN8fD;EKneH;ICZI,kBAAA;GNkfD;EKteH;ICZI,0BAAA;GNqfD;EKzeH;ICZI,0BAAA;GNwfD;EK5eH;ICZI,iBAAA;GN2fD;EK/eH;ICZI,0BAAA;GN8fD;EKlfH;ICZI,0BAAA;GNigBD;EKrfH;ICZI,iBAAA;GNogBD;EKxfH;ICZI,0BAAA;GNugBD;EK3fH;ICZI,0BAAA;GN0gBD;EK9fH;ICZI,iBAAA;GN6gBD;EKjgBH;ICZI,0BAAA;GNghBD;EKpgBH;ICZI,yBAAA;GNmhBD;EKvgBH;ICZI,gBAAA;GNshBD;CACF;AK3gBD;EAAA;IC7CM,YAAA;GN4jBH;EK/gBH;ICrCI,YAAA;GNujBD;EKlhBH;ICrCI,oBAAA;GN0jBD;EKrhBH;ICrCI,oBAAA;GN6jBD;EKxhBH;ICrCI,WAAA;GNgkBD;EK3hBH;ICrCI,oBAAA;GNmkBD;EK9hBH;ICrCI,oBAAA;GNskBD;EKjiBH;ICrCI,WAAA;GNykBD;EKpiBH;ICrCI,oBAAA;GN4kBD;EKviBH;ICrCI,oBAAA;GN+kBD;EK1iBH;ICrCI,WAAA;GNklBD;EK7iBH;ICrCI,oBAAA;GNqlBD;EKhjBH;ICrCI,mBAAA;GNwlBD;EKnjBH;ICtBI,YAAA;GN4kBD;EKtjBH;ICtBI,oBAAA;GN+kBD;EKzjBH;ICtBI,oBAAA;GNklBD;EK5jBH;ICtBI,WAAA;GNqlBD;EK/jBH;ICtBI,oBAAA;GNwlBD;EKlkBH;ICtBI,oBAAA;GN2lBD;EKrkBH;ICtBI,WAAA;GN8lBD;EKxkBH;ICtBI,oBAAA;GNimBD;EK3kBH;ICtBI,oBAAA;GNomBD;EK9kBH;ICtBI,WAAA;GNumBD;EKjlBH;ICtBI,oBAAA;GN0mBD;EKplBH;ICtBI,mBAAA;GN6mBD;EKvlBH;ICjBI,YAAA;GN2mBD;EK1lBH;IChCI,WAAA;GN6nBD;EK7lBH;IChCI,mBAAA;GNgoBD;EKhmBH;IChCI,mBAAA;GNmoBD;EKnmBH;IChCI,UAAA;GNsoBD;EKtmBH;IChCI,mBAAA;GNyoBD;EKzmBH;IChCI,mBAAA;GN4oBD;EK5mBH;IChCI,UAAA;GN+oBD;EK/mBH;IChCI,mBAAA;GNkpBD;EKlnBH;IChCI,mBAAA;GNqpBD;EKrnBH;IChCI,UAAA;GNwpBD;EKxnBH;IChCI,mBAAA;GN2pBD;EK3nBH;IChCI,kBAAA;GN8pBD;EK9nBH;IC3BI,WAAA;GN4pBD;EKjoBH;ICZI,kBAAA;GNgpBD;EKpoBH;ICZI,0BAAA;GNmpBD;EKvoBH;ICZI,0BAAA;GNspBD;EK1oBH;ICZI,iBAAA;GNypBD;EK7oBH;ICZI,0BAAA;GN4pBD;EKhpBH;ICZI,0BAAA;GN+pBD;EKnpBH;ICZI,iBAAA;GNkqBD;EKtpBH;ICZI,0BAAA;GNqqBD;EKzpBH;ICZI,0BAAA;GNwqBD;EK5pBH;ICZI,iBAAA;GN2qBD;EK/pBH;ICZI,0BAAA;GN8qBD;EKlqBH;ICZI,yBAAA;GNirBD;EKrqBH;ICZI,gBAAA;GNorBD;CACF;AOhvBC;;;;;;;;EAEE,aAAA;EACA,eAAA;CPwvBH;AOtvBC;;;;EACE,YAAA;CP2vBH;AQnwBD;ECRE,eAAA;EACA,kBAAA;EACA,mBAAA;CT8wBD;AQrwBD;EACE,wBAAA;CRuwBD;AQrwBD;EACE,uBAAA;CRuwBD;AQ/vBD;EACE,yBAAA;CRiwBD;AQ/vBD;EACE,0BAAA;CRiwBD;AQ/vBD;EACE,mBAAA;CRiwBD;AQ/vBD;EEzBE,YAAA;EACA,mBAAA;EACA,kBAAA;EACA,8BAAA;EACA,UAAA;CV2xBD;AQ7vBD;EACE,yBAAA;EACA,8BAAA;CR+vBD;AQxvBD;EACE,gBAAA;CR0vBD;;AAED;;;GAGG;AACH;gCACgC;AWpzBhC;EACE,2BAAA;EACA,kEAAA;EACA,mbAAA;EAMA,oBAAA;EACA,mBAAA;CXizBD;AY3zBD;EACE,sBAAA;EACA,8CAAA;EACA,mBAAA;EACA,qBAAA;EACA,oCAAA;EACA,mCAAA;EACA,mCAAA;UAAA,2BAAA;CZ6zBD;AACD,8DAA8D;Aap0B9D;EACE,wBAAA;EACA,oBAAA;EACA,qBAAA;Cbs0BD;Aap0BD;EAAuB,eAAA;Cbu0BtB;Aat0BD;EAAuB,eAAA;Cby0BtB;Aax0BD;EAAuB,eAAA;Cb20BtB;Aa10BD;EAAuB,eAAA;Cb60BtB;Acv1BD;EACE,oBAAA;EACA,mBAAA;Cdy1BD;Ae11BD;EACE,gBAAA;EACA,0BAAA;EACA,sBAAA;Cf41BD;Ae/1BD;EAIS,mBAAA;Cf81BR;Ae51BD;EACE,mBAAA;EACA,oBAAA;EACA,oBAAA;EACA,kBAAA;EACA,mBAAA;Cf81BD;Ae71BC;EACE,oBAAA;Cf+1BH;AgB52BD;EACE,0BAAA;EACA,6BAAA;EACA,oBAAA;ChB82BD;AgB32BD;EAAc,aAAA;ChB82Bb;AgB72BD;EAAa,YAAA;ChBg3BZ;AgB72BC;EAAc,mBAAA;ChBg3Bf;AgB/2BC;EAAe,kBAAA;ChBk3BhB;AiB73BD;EACE,8CAAA;EACQ,sCAAA;CjB+3BT;AiB53BD;EACE,gDAAA;EACQ,wCAAA;CjB83BT;AiB33BD;EACE;IACE,gCAAA;IACQ,wBAAA;GjB63BT;EiB33BD;IACE,kCAAA;IACQ,0BAAA;GjB63BT;CACF;AiB13BD;EACE;IACE,gCAAA;IACQ,wBAAA;GjB43BT;EiB13BD;IACE,kCAAA;IACQ,0BAAA;GjB43BT;CACF;AkBz5BD;ECYE,iEAAA;EACA,iCAAA;EAEQ,yBAAA;CnBg5BT;AkB95BD;ECWE,iEAAA;EACA,kCAAA;EAEQ,0BAAA;CnBs5BT;AkBn6BD;ECUE,iEAAA;EACA,kCAAA;EAEQ,0BAAA;CnB45BT;AkBv6BD;ECeE,2EAAA;EACA,gCAAA;EAEQ,wBAAA;CnB25BT;AkB56BD;ECcE,2EAAA;EACA,gCAAA;EAEQ,wBAAA;CnBi6BT;AkB76BD;;;;;EAKE,qBAAA;UAAA,aAAA;ClB+6BD;AoB97BD;EACE,mBAAA;EACA,sBAAA;EACA,WAAA;EACA,YAAA;EACA,iBAAA;EACA,uBAAA;CpBg8BD;AoB97BD;;EACE,mBAAA;EACA,QAAA;EACA,YAAA;EACA,mBAAA;CpBi8BD;AoB/7BD;EAA6B,qBAAA;CpBk8B5B;AoBj8BD;EAA6B,eAAA;CpBo8B5B;AoBn8BD;EAA4B,eAAA;CpBs8B3B;AACD;oEACoE;AqBx9BpE;EAAiC,iBAAA;CrB29BhC;AqB19BD;EAAiC,iBAAA;CrB69BhC;AqB59BD;EAAkC,iBAAA;CrB+9BjC;AqB99BD;EAAsC,iBAAA;CrBi+BrC;AqBh+BD;EAAiC,iBAAA;CrBm+BhC;AqBl+BD;EAAgC,iBAAA;CrBq+B/B;AqBp+BD;EAAkC,iBAAA;CrBu+BjC;AqBt+BD;EAAgC,iBAAA;CrBy+B/B;AqBx+BD;EAAgC,iBAAA;CrB2+B/B;AqB1+BD;EAAoC,iBAAA;CrB6+BnC;AqB5+BD;EAA8B,iBAAA;CrB++B7B;AqB9+BD;EAAmC,iBAAA;CrBi/BlC;AqBh/BD;EAAiC,iBAAA;CrBm/BhC;AqBl/BD;;;EAEiC,iBAAA;CrBq/BhC;AqBp/BD;EAAuC,iBAAA;CrBu/BtC;AqBt/BD;EAAwC,iBAAA;CrBy/BvC;AqBx/BD;EAAqC,iBAAA;CrB2/BpC;AqB1/BD;EAAkC,iBAAA;CrB6/BjC;AqB5/BD;;EAC+B,iBAAA;CrB+/B9B;AqB9/BD;EAAmC,iBAAA;CrBigClC;AqBhgCD;EAAgC,iBAAA;CrBmgC/B;AqBlgCD;EAAkC,iBAAA;CrBqgCjC;AqBpgCD;EAAmC,iBAAA;CrBugClC;AqBtgCD;EAAgC,iBAAA;CrBygC/B;AqBxgCD;EAAoC,iBAAA;CrB2gCnC;AqB1gCD;EAA+C,iBAAA;CrB6gC9C;AqB5gCD;EAA6C,iBAAA;CrB+gC5C;AqB9gCD;EAAiC,iBAAA;CrBihChC;AqBhhCD;EAAyC,iBAAA;CrBmhCxC;AqBlhCD;;EACkC,iBAAA;CrBqhCjC;AqBphCD;EAAmC,iBAAA;CrBuhClC;AqBthCD;EAAoC,iBAAA;CrByhCnC;AqBxhCD;EAAgC,iBAAA;CrB2hC/B;AqB1hCD;EAAgC,iBAAA;CrB6hC/B;AqB5hCD;EAAsC,iBAAA;CrB+hCrC;AqB9hCD;EAAsC,iBAAA;CrBiiCrC;AqBhiCD;EAAuC,iBAAA;CrBmiCtC;AqBliCD;EAAqC,iBAAA;CrBqiCpC;AqBpiCD;EAAkC,iBAAA;CrBuiCjC;AqBtiCD;EAAmC,iBAAA;CrByiClC;AqBxiCD;EAA+B,iBAAA;CrB2iC9B;AqB1iCD;EAAgC,iBAAA;CrB6iC/B;AqB5iCD;EAAgC,iBAAA;CrB+iC/B;AqB9iCD;EAAoC,iBAAA;CrBijCnC;AqBhjCD;EAAiC,iBAAA;CrBmjChC;AqBljCD;EAAkC,iBAAA;CrBqjCjC;AqBpjCD;EAAgC,iBAAA;CrBujC/B;AqBtjCD;EAAgC,iBAAA;CrByjC/B;AqBxjCD;EAAkC,iBAAA;CrB2jCjC;AqB1jCD;EAAuC,iBAAA;CrB6jCtC;AqB5jCD;EAAsC,iBAAA;CrB+jCrC;AqB9jCD;EAAsC,iBAAA;CrBikCrC;AqBhkCD;EAAwC,iBAAA;CrBmkCvC;AqBlkCD;EAAuC,iBAAA;CrBqkCtC;AqBpkCD;EAAyC,iBAAA;CrBukCxC;AqBtkCD;EAAgC,iBAAA;CrBykC/B;AqBxkCD;;EACmC,iBAAA;CrB2kClC;AqB1kCD;EAAkC,iBAAA;CrB6kCjC;AqB5kCD;EAAwC,iBAAA;CrB+kCvC;AqB9kCD;;;EAEqC,iBAAA;CrBilCpC;AqBhlCD;EAAkC,iBAAA;CrBmlCjC;AqBllCD;EAAsC,iBAAA;CrBqlCrC;AqBplCD;EAAkC,iBAAA;CrBulCjC;AqBtlCD;EAAgC,iBAAA;CrBylC/B;AqBxlCD;;EAC2C,iBAAA;CrB2lC1C;AqB1lCD;EAA0C,iBAAA;CrB6lCzC;AqB5lCD;EAA0C,iBAAA;CrB+lCzC;AqB9lCD;EAAkC,iBAAA;CrBimCjC;AqBhmCD;EAAyC,iBAAA;CrBmmCxC;AqBlmCD;EAAyC,iBAAA;CrBqmCxC;AqBpmCD;EAAoC,iBAAA;CrBumCnC;AqBtmCD;EAAgC,iBAAA;CrBymC/B;AqBxmCD;EAAiC,iBAAA;CrB2mChC;AqB1mCD;EAAgC,iBAAA;CrB6mC/B;AqB5mCD;EAAmC,iBAAA;CrB+mClC;AqB9mCD;EAAwC,iBAAA;CrBinCvC;AqBhnCD;EAAwC,iBAAA;CrBmnCvC;AqBlnCD;EAAiC,iBAAA;CrBqnChC;AqBpnCD;EAAwC,iBAAA;CrBunCvC;AqBtnCD;EAAyC,iBAAA;CrBynCxC;AqBxnCD;EAAuC,iBAAA;CrB2nCtC;AqB1nCD;EAAwC,iBAAA;CrB6nCvC;AqB5nCD;EAAwC,iBAAA;CrB+nCvC;AqB9nCD;EAAwC,iBAAA;CrBioCvC;AqBhoCD;EAA2C,iBAAA;CrBmoC1C;AqBloCD;EAAuC,iBAAA;CrBqoCtC;AqBpoCD;EAAsC,iBAAA;CrBuoCrC;AqBtoCD;EAA0C,iBAAA;CrByoCzC;AqBxoCD;EAA0C,iBAAA;CrB2oCzC;AqB1oCD;EAA+B,iBAAA;CrB6oC9B;AqB5oCD;EAAsC,iBAAA;CrB+oCrC;AqB9oCD;EAAuC,iBAAA;CrBipCtC;AqBhpCD;EAAoC,iBAAA;CrBmpCnC;AqBlpCD;EAAsC,iBAAA;CrBqpCrC;AqBppCD;;EACiC,iBAAA;CrBupChC;AqBtpCD;EAAkC,iBAAA;CrBypCjC;AqBxpCD;EAAoC,iBAAA;CrB2pCnC;AqB1pCD;EAAgC,iBAAA;CrB6pC/B;AqB5pCD;EAAiC,iBAAA;CrB+pChC;AqB9pCD;EAAoC,iBAAA;CrBiqCnC;AqBhqCD;EAA8C,iBAAA;CrBmqC7C;AqBlqCD;EAAgC,iBAAA;CrBqqC/B;AqBpqCD;EAAgC,iBAAA;CrBuqC/B;AqBtqCD;EAAgC,iBAAA;CrByqC/B;AqBxqCD;EAA+B,iBAAA;CrB2qC9B;AqB1qCD;EAAqC,iBAAA;CrB6qCpC;AqB5qCD;;EACgD,iBAAA;CrB+qC/C;AqB9qCD;EAAiC,iBAAA;CrBirChC;AqBhrCD;EAAoC,iBAAA;CrBmrCnC;AqBlrCD;EAAkC,iBAAA;CrBqrCjC;AqBprCD;EAAmC,iBAAA;CrBurClC;AqBtrCD;EAAkC,iBAAA;CrByrCjC;AqBxrCD;EAAsC,iBAAA;CrB2rCrC;AqB1rCD;EAAwC,iBAAA;CrB6rCvC;AqB5rCD;EAAmC,iBAAA;CrB+rClC;AqB9rCD;EAAyC,iBAAA;CrBisCxC;AqBhsCD;EAAkC,iBAAA;CrBmsCjC;AqBlsCD;EAAuC,iBAAA;CrBqsCtC;AqBpsCD;EAAoC,iBAAA;CrBusCnC;AqBtsCD;EAAoC,iBAAA;CrBysCnC;AqBxsCD;;EACqC,iBAAA;CrB2sCpC;AqB1sCD;EAA0C,iBAAA;CrB6sCzC;AqB5sCD;EAA2C,iBAAA;CrB+sC1C;AqB9sCD;EAAwC,iBAAA;CrBitCvC;AqBhtCD;EAA+B,iBAAA;CrBmtC9B;AqBltCD;;EACgC,iBAAA;CrBqtC/B;AqBptCD;EAAoC,iBAAA;CrButCnC;AqBttCD;EAAuC,iBAAA;CrBytCtC;AqBxtCD;EAAyC,iBAAA;CrB2tCxC;AqB1tCD;EAAqC,iBAAA;CrB6tCpC;AqB5tCD;EAAmC,iBAAA;CrB+tClC;AqB9tCD;EAAoC,iBAAA;CrBiuCnC;AqBhuCD;EAA2C,iBAAA;CrBmuC1C;AqBluCD;EAAsC,iBAAA;CrBquCrC;AqBpuCD;EAAyC,iBAAA;CrBuuCxC;AqBtuCD;EAAmC,iBAAA;CrByuClC;AqBxuCD;EAAkC,iBAAA;CrB2uCjC;AqB1uCD;EAAyC,iBAAA;CrB6uCxC;AqB5uCD;EAAkC,iBAAA;CrB+uCjC;AqB9uCD;EAAmC,iBAAA;CrBivClC;AqBhvCD;EAAiC,iBAAA;CrBmvChC;AqBlvCD;EAAoC,iBAAA;CrBqvCnC;AqBpvCD;EAAsC,iBAAA;CrBuvCrC;AqBtvCD;EAAwC,iBAAA;CrByvCvC;AqBxvCD;EAAmC,iBAAA;CrB2vClC;AqB1vCD;;EACoC,iBAAA;CrB6vCnC;AqB5vCD;EAAkC,iBAAA;CrB+vCjC;AqB9vCD;EAAkC,iBAAA;CrBiwCjC;AqBhwCD;EAAuC,iBAAA;CrBmwCtC;AqBlwCD;EAA+B,iBAAA;CrBqwC9B;AqBpwCD;EAAiC,iBAAA;CrBuwChC;AqBtwCD;EAAoC,iBAAA;CrBywCnC;AqBxwCD;EAAgC,iBAAA;CrB2wC/B;AqB1wCD;EAAuC,iBAAA;CrB6wCtC;AqB5wCD;EAAwC,iBAAA;CrB+wCvC;AqB9wCD;EAAuC,iBAAA;CrBixCtC;AqBhxCD;EAAqC,iBAAA;CrBmxCpC;AqBlxCD;EAAuC,iBAAA;CrBqxCtC;AqBpxCD;EAA6C,iBAAA;CrBuxC5C;AqBtxCD;EAA8C,iBAAA;CrByxC7C;AqBxxCD;EAA2C,iBAAA;CrB2xC1C;AqB1xCD;EAA6C,iBAAA;CrB6xC5C;AqB5xCD;EAAiC,iBAAA;CrB+xChC;AqB9xCD;EAAkC,iBAAA;CrBiyCjC;AqBhyCD;EAAiC,iBAAA;CrBmyChC;AqBlyCD;EAAkC,iBAAA;CrBqyCjC;AqBpyCD;EAAqC,iBAAA;CrBuyCpC;AqBtyCD;EAAsC,iBAAA;CrByyCrC;AqBxyCD;;EACiC,iBAAA;CrB2yChC;AqB1yCD;;EACgC,iBAAA;CrB6yC/B;AqB5yCD;EAAiC,iBAAA;CrB+yChC;AqB9yCD;EAAiC,iBAAA;CrBizChC;AqBhzCD;;EACoC,iBAAA;CrBmzCnC;AqBlzCD;;EACmC,iBAAA;CrBqzClC;AqBpzCD;EAAqC,iBAAA;CrBuzCpC;AqBtzCD;;EACoC,iBAAA;CrByzCnC;AqBxzCD;EAAkC,iBAAA;CrB2zCjC;AqB1zCD;;;EAEgC,iBAAA;CrB6zC/B;AqB5zCD;EAAmC,iBAAA;CrB+zClC;AqB9zCD;EAAmC,iBAAA;CrBi0ClC;AqBh0CD;EAAyC,iBAAA;CrBm0CxC;AqBl0CD;EAAqC,iBAAA;CrBq0CpC;AqBp0CD;EAAiC,iBAAA;CrBu0ChC;AqBt0CD;EAAiC,iBAAA;CrBy0ChC;AqBx0CD;EAAiC,iBAAA;CrB20ChC;AqB10CD;EAAqC,iBAAA;CrB60CpC;AqB50CD;EAA4C,iBAAA;CrB+0C3C;AqB90CD;EAA8C,iBAAA;CrBi1C7C;AqBh1CD;EAAuC,iBAAA;CrBm1CtC;AqBl1CD;EAAiC,iBAAA;CrBq1ChC;AqBp1CD;EAAsC,iBAAA;CrBu1CrC;AqBt1CD;EAAoC,iBAAA;CrBy1CnC;AqBx1CD;EAAsC,iBAAA;CrB21CrC;AqB11CD;EAAuC,iBAAA;CrB61CtC;AqB51CD;EAAmC,iBAAA;CrB+1ClC;AqB91CD;;EACgC,iBAAA;CrBi2C/B;AqBh2CD;;EACqC,iBAAA;CrBm2CpC;AqBl2CD;;EACoC,iBAAA;CrBq2CnC;AqBp2CD;EAAoC,iBAAA;CrBu2CnC;AqBt2CD;EAAoC,iBAAA;CrBy2CnC;AqBx2CD;;EACgC,iBAAA;CrB22C/B;AqB12CD;;EACiC,iBAAA;CrB62ChC;AqB52CD;;EACsC,iBAAA;CrB+2CrC;AqB92CD;EAAqC,iBAAA;CrBi3CpC;AqBh3CD;EAAsC,iBAAA;CrBm3CrC;AqBl3CD;;EACgC,iBAAA;CrBq3C/B;AqBp3CD;EAAmC,iBAAA;CrBu3ClC;AqBt3CD;EAAoC,iBAAA;CrBy3CnC;AqBx3CD;;EACqC,iBAAA;CrB23CpC;AqB13CD;EAAuC,iBAAA;CrB63CtC;AqB53CD;EAAoC,iBAAA;CrB+3CnC;AqB93CD;EAA0C,iBAAA;CrBi4CzC;AqBh4CD;EAAwC,iBAAA;CrBm4CvC;AqBl4CD;EAAmC,iBAAA;CrBq4ClC;AqBp4CD;EAAuC,iBAAA;CrBu4CtC;AqBt4CD;EAAoC,iBAAA;CrBy4CnC;AqBx4CD;EAAkC,iBAAA;CrB24CjC;AqB14CD;EAAkC,iBAAA;CrB64CjC;AqB54CD;EAAmC,iBAAA;CrB+4ClC;AqB94CD;EAAuC,iBAAA;CrBi5CtC;AqBh5CD;EAAsC,iBAAA;CrBm5CrC;AqBl5CD;EAAsC,iBAAA;CrBq5CrC;AqBp5CD;EAAqC,iBAAA;CrBu5CpC;AqBt5CD;EAAkC,iBAAA;CrBy5CjC;AqBx5CD;EAAuC,iBAAA;CrB25CtC;AqB15CD;EAAgC,iBAAA;CrB65C/B;AqB55CD;EAAoC,iBAAA;CrB+5CnC;AqB95CD;EAAuC,iBAAA;CrBi6CtC;AqBh6CD;EAA6C,iBAAA;CrBm6C5C;AqBl6CD;EAA8C,iBAAA;CrBq6C7C;AqBp6CD;EAA2C,iBAAA;CrBu6C1C;AqBt6CD;EAA6C,iBAAA;CrBy6C5C;AqBx6CD;EAAsC,iBAAA;CrB26CrC;AqB16CD;EAAuC,iBAAA;CrB66CtC;AqB56CD;EAAoC,iBAAA;CrB+6CnC;AqB96CD;EAAsC,iBAAA;CrBi7CrC;AqBh7CD;EAAmC,iBAAA;CrBm7ClC;AqBl7CD;EAAkC,iBAAA;CrBq7CjC;AqBp7CD;EAAkC,iBAAA;CrBu7CjC;AqBt7CD;;EACkC,iBAAA;CrBy7CjC;AqBx7CD;EAAoC,iBAAA;CrB27CnC;AqB17CD;EAAsC,iBAAA;CrB67CrC;AqB57CD;EAAuC,iBAAA;CrB+7CtC;AqB97CD;EAAmC,iBAAA;CrBi8ClC;AqBh8CD;EAAkC,iBAAA;CrBm8CjC;AqBl8CD;;EACiC,iBAAA;CrBq8ChC;AqBp8CD;EAAsC,iBAAA;CrBu8CrC;AqBt8CD;EAAoC,iBAAA;CrBy8CnC;AqBx8CD;EAAyC,iBAAA;CrB28CxC;AqB18CD;EAAmC,iBAAA;CrB68ClC;AqB58CD;EAAmC,iBAAA;CrB+8ClC;AqB98CD;EAAiC,iBAAA;CrBi9ChC;AqBh9CD;EAAmC,iBAAA;CrBm9ClC;AqBl9CD;EAAsC,iBAAA;CrBq9CrC;AqBp9CD;EAAkC,iBAAA;CrBu9CjC;AqBt9CD;EAA0C,iBAAA;CrBy9CzC;AqBx9CD;EAAoC,iBAAA;CrB29CnC;AqB19CD;EAAgC,iBAAA;CrB69C/B;AqB59CD;;EACqC,iBAAA;CrB+9CpC;AqB99CD;;;EAEuC,iBAAA;CrBi+CtC;AqBh+CD;EAA0C,iBAAA;CrBm+CzC;AqBl+CD;EAAgC,iBAAA;CrBq+C/B;AqBp+CD;EAAqC,iBAAA;CrBu+CpC;AqBt+CD;;EACwC,iBAAA;CrBy+CvC;AqBx+CD;EAAoC,iBAAA;CrB2+CnC;AqB1+CD;EAAgC,iBAAA;CrB6+C/B;AqB5+CD;EAAuC,iBAAA;CrB++CtC;AqB9+CD;EAAuC,iBAAA;CrBi/CtC;AqBh/CD;EAAqC,iBAAA;CrBm/CpC;AqBl/CD;EAAkC,iBAAA;CrBq/CjC;AqBp/CD;EAAwC,iBAAA;CrBu/CvC;AqBt/CD;EAAsC,iBAAA;CrBy/CrC;AqBx/CD;EAA4C,iBAAA;CrB2/C3C;AqB1/CD;EAAkC,iBAAA;CrB6/CjC;AqB5/CD;EAAsC,iBAAA;CrB+/CrC;AqB9/CD;EAA6C,iBAAA;CrBigD5C;AqBhgDD;EAAkC,iBAAA;CrBmgDjC;AqBlgDD;EAAkC,iBAAA;CrBqgDjC;AqBpgDD;EAA+C,iBAAA;CrBugD9C;AqBtgDD;EAAgD,iBAAA;CrBygD/C;AqBxgDD;EAA6C,iBAAA;CrB2gD5C;AqB1gDD;EAA+C,iBAAA;CrB6gD9C;AqB5gDD;EAAiC,iBAAA;CrB+gDhC;AqB9gDD;EAAgC,iBAAA;CrBihD/B;AqBhhDD;EAAkC,iBAAA;CrBmhDjC;AqBlhDD;EAAsC,iBAAA;CrBqhDrC;AqBphDD;EAAoC,iBAAA;CrBuhDnC;AqBthDD;EAAsC,iBAAA;CrByhDrC;AqBxhDD;EAAsC,iBAAA;CrB2hDrC;AqB1hDD;EAAsC,iBAAA;CrB6hDrC;AqB5hDD;EAAuC,iBAAA;CrB+hDtC;AqB9hDD;EAAkC,iBAAA;CrBiiDjC;AqBhiDD;EAAwC,iBAAA;CrBmiDvC;AqBliDD;EAA0C,iBAAA;CrBqiDzC;AqBpiDD;EAAoC,iBAAA;CrBuiDnC;AqBtiDD;EAAsC,iBAAA;CrByiDrC;AqBxiDD;EAAwC,iBAAA;CrB2iDvC;AqB1iDD;EAAyC,iBAAA;CrB6iDxC;AqB5iDD;EAAgD,iBAAA;CrB+iD/C;AqB9iDD;EAAwC,iBAAA;CrBijDvC;AqBhjDD;EAAmC,iBAAA;CrBmjDlC;AqBljDD;;EAC+C,iBAAA;CrBqjD9C;AqBpjDD;;EAC6C,iBAAA;CrBujD5C;AqBtjDD;;EACgD,iBAAA;CrByjD/C;AqBxjDD;;EAC+B,iBAAA;CrB2jD9B;AqB1jDD;EAA+B,iBAAA;CrB6jD9B;AqB5jDD;;EAC+B,iBAAA;CrB+jD9B;AqB9jDD;;EAC+B,iBAAA;CrBikD9B;AqBhkDD;;;;EAG+B,iBAAA;CrBmkD9B;AqBlkDD;;;EAE+B,iBAAA;CrBqkD9B;AqBpkDD;;EAC+B,iBAAA;CrBukD9B;AqBtkDD;;EAC+B,iBAAA;CrBykD9B;AqBxkDD;EAAgC,iBAAA;CrB2kD/B;AqB1kDD;EAAqC,iBAAA;CrB6kDpC;AqB5kDD;EAA0C,iBAAA;CrB+kDzC;AqB9kDD;EAA2C,iBAAA;CrBilD1C;AqBhlDD;EAA2C,iBAAA;CrBmlD1C;AqBllDD;EAA4C,iBAAA;CrBqlD3C;AqBplDD;EAA4C,iBAAA;CrBulD3C;AqBtlDD;EAA6C,iBAAA;CrBylD5C;AqBxlDD;EAAqC,iBAAA;CrB2lDpC;AqB1lDD;EAAuC,iBAAA;CrB6lDtC;AqB5lDD;EAA0C,iBAAA;CrB+lDzC;AqB9lDD;EAAmC,iBAAA;CrBimDlC;AqBhmDD;EAAgC,iBAAA;CrBmmD/B;AqBlmDD;EAAuC,iBAAA;CrBqmDtC;AqBpmDD;EAAwC,iBAAA;CrBumDvC;AqBtmDD;EAAmC,iBAAA;CrBymDlC;AqBxmDD;EAA0C,iBAAA;CrB2mDzC;AqB1mDD;EAAqC,iBAAA;CrB6mDpC;AqB5mDD;EAAkC,iBAAA;CrB+mDjC;AqB9mDD;EAA+B,iBAAA;CrBinD9B;AqBhnDD;EAAqC,iBAAA;CrBmnDpC;AqBlnDD;EAA4C,iBAAA;CrBqnD3C;AqBpnDD;EAAkC,iBAAA;CrBunDjC;AqBtnDD;EAAyC,iBAAA;CrBynDxC;AqBxnDD;EAA2C,iBAAA;CrB2nD1C;AqB1nDD;EAAyC,iBAAA;CrB6nDxC;AqB5nDD;EAA2C,iBAAA;CrB+nD1C;AqB9nDD;EAA4C,iBAAA;CrBioD3C;AqBhoDD;EAAiC,iBAAA;CrBmoDhC;AqBloDD;EAAmC,iBAAA;CrBqoDlC;AqBpoDD;EAAmC,iBAAA;CrBuoDlC;AqBtoDD;EAAiC,iBAAA;CrByoDhC;AqBxoDD;EAAoC,iBAAA;CrB2oDnC;AqB1oDD;EAAiC,iBAAA;CrB6oDhC;AqB5oDD;EAAsC,iBAAA;CrB+oDrC;AqB9oDD;EAAkC,iBAAA;CrBipDjC;AqBhpDD;EAAkC,iBAAA;CrBmpDjC;AqBlpDD;EAAgC,iBAAA;CrBqpD/B;AqBppDD;;EACoC,iBAAA;CrBupDnC;AqBtpDD;EAAiC,iBAAA;CrBypDhC;AqBxpDD;EAAkC,iBAAA;CrB2pDjC;AqB1pDD;EAAmC,iBAAA;CrB6pDlC;AqB5pDD;EAA+B,iBAAA;CrB+pD9B;AqB9pDD;EAA8B,iBAAA;CrBiqD7B;AqBhqDD;EAAiC,iBAAA;CrBmqDhC;AqBlqDD;EAAkC,iBAAA;CrBqqDjC;AqBpqDD;EAAqC,iBAAA;CrBuqDpC;AqBtqDD;EAA0C,iBAAA;CrByqDzC;AqBxqDD;EAAgD,iBAAA;CrB2qD/C;AqB1qDD;EAA+C,iBAAA;CrB6qD9C;AqB5qDD;;EAC+C,iBAAA;CrB+qD9C;AqB9qDD;EAAwC,iBAAA;CrBirDvC;AqBhrDD;EAAsC,iBAAA;CrBmrDrC;AqBlrDD;EAAwC,iBAAA;CrBqrDvC;AqBprDD;;EAC+B,iBAAA;CrBurD9B;AqBtrDD;EAAyC,iBAAA;CrByrDxC;AqBxrDD;EAAyC,iBAAA;CrB2rDxC;AqB1rDD;EAAiC,iBAAA;CrB6rDhC;AqB5rDD;EAA2C,iBAAA;CrB+rD1C;AqB9rDD;EAAqC,iBAAA;CrBisDpC;AqBhsDD;EAAkC,iBAAA;CrBmsDjC;AqBlsDD;;;EAEsC,iBAAA;CrBqsDrC;AqBpsDD;;EAC0C,iBAAA;CrBusDzC;AqBtsDD;EAAiC,iBAAA;CrBysDhC;AqBxsDD;EAAkC,iBAAA;CrB2sDjC;AqB1sDD;EAAkC,iBAAA;CrB6sDjC;AqB5sDD;EAAyC,iBAAA;CrB+sDxC;AqB9sDD;EAA8C,iBAAA;CrBitD7C;AqBhtDD;EAAuC,iBAAA;CrBmtDtC;AqBltDD;EAAqC,iBAAA;CrBqtDpC;AqBptDD;EAAgC,iBAAA;CrButD/B;AqBttDD;EAAsC,iBAAA;CrBytDrC;AqBxtDD;EAA0C,iBAAA;CrB2tDzC;AqB1tDD;EAAkC,iBAAA;CrB6tDjC;AqB5tDD;EAAkC,iBAAA;CrB+tDjC;AqB9tDD;EAAoC,iBAAA;CrBiuDnC;AqBhuDD;EAA+B,iBAAA;CrBmuD9B;AqBluDD;EAAoC,iBAAA;CrBquDnC;AqBpuDD;EAAiC,iBAAA;CrBuuDhC;AqBtuDD;EAA+B,iBAAA;CrByuD9B;AqBxuDD;EAAiC,iBAAA;CrB2uDhC;AqB1uDD;EAAgC,iBAAA;CrB6uD/B;AqB5uDD;EAAiC,iBAAA;CrB+uDhC;AqB9uDD;EAAmC,iBAAA;CrBivDlC;AqBhvDD;EAA0C,iBAAA;CrBmvDzC;AqBlvDD;EAAiC,iBAAA;CrBqvDhC;AqBpvDD;EAAwC,iBAAA;CrBuvDvC;AqBtvDD;EAAmC,iBAAA;CrByvDlC;AqBxvDD;;EAC+B,iBAAA;CrB2vD9B;AqB1vDD;;EACgC,iBAAA;CrB6vD/B;AqB5vDD;EAAgC,iBAAA;CrB+vD/B;AqB9vDD;EAAmC,iBAAA;CrBiwDlC;AqBhwDD;EAAsC,iBAAA;CrBmwDrC;AqBlwDD;EAAsC,iBAAA;CrBqwDrC;AqBpwDD;EAAoC,iBAAA;CrBuwDnC;AqBtwDD;EAAsC,iBAAA;CrBywDrC;AqBxwDD;EAAuC,iBAAA;CrB2wDtC;AqB1wDD;EAAwC,iBAAA;CrB6wDvC;AqB5wDD;EAA6C,iBAAA;CrB+wD5C;AqB9wDD;;;EAEwC,iBAAA;CrBixDvC;AqBhxDD;;EAC0C,iBAAA;CrBmxDzC;AqBlxDD;;EACwC,iBAAA;CrBqxDvC;AqBpxDD;;EACwC,iBAAA;CrBuxDvC;AqBtxDD;EAAuC,iBAAA;CrByxDtC;AqBxxDD;EAAgC,iBAAA;CrB2xD/B;AqB1xDD;EAAmC,iBAAA;CrB6xDlC;AqB5xDD;EAAoC,iBAAA;CrB+xDnC;AqB9xDD;;;;;EAIqC,iBAAA;CrBiyDpC;AqBhyDD;EAA0C,iBAAA;CrBmyDzC;AqBlyDD;;EACiC,iBAAA;CrBqyDhC;AqBpyDD;;EACkC,iBAAA;CrBuyDjC;AqBtyDD;EAAsC,iBAAA;CrByyDrC;AqBxyDD;EAA+B,iBAAA;CrB2yD9B;AqB1yDD;EAAuC,iBAAA;CrB6yDtC;AqB5yDD;EAAyC,iBAAA;CrB+yDxC;AqB9yDD;EAA8B,iBAAA;CrBizD7B;AqBhzDD;;EACkC,iBAAA;CrBmzDjC;AqBlzDD;;EACuC,iBAAA;CrBqzDtC;AqBpzDD;;EACyC,iBAAA;CrBuzDxC;AqBtzDD;EAAmC,iBAAA;CrByzDlC;AqBxzDD;;EACuC,iBAAA;CrB2zDtC;AqB1zDD;EAAkC,iBAAA;CrB6zDjC;AqB5zDD;EAAqC,iBAAA;CrB+zDpC;AqB9zDD;EAAmC,iBAAA;CrBi0DlC;AqBh0DD;EAAqC,iBAAA;CrBm0DpC;AqBl0DD;EAA4C,iBAAA;CrBq0D3C;AqBp0DD;EAAgC,iBAAA;CrBu0D/B;AqBt0DD;;EACoC,iBAAA;CrBy0DnC;AqBx0DD;EAA+B,iBAAA;CrB20D9B;AqB10DD;EAAsC,iBAAA;CrB60DrC;AqB50DD;EAAgC,iBAAA;CrB+0D/B;AqB90DD;EAAsC,iBAAA;CrBi1DrC;AqBh1DD;EAAkC,iBAAA;CrBm1DjC;AqBl1DD;EAAgC,iBAAA;CrBq1D/B;AqBp1DD;EAAuC,iBAAA;CrBu1DtC;AqBt1DD;EAAgC,iBAAA;CrBy1D/B;AqBx1DD;EAAsC,iBAAA;CrB21DrC;AqB11DD;EAAkC,iBAAA;CrB61DjC;AqB51DD;EAAyC,iBAAA;CrB+1DxC;AqB91DD;EAAmC,iBAAA;CrBi2DlC;AqBh2DD;EAAyC,iBAAA;CrBm2DxC;AqBl2DD;EAAuC,iBAAA;CrBq2DtC;AqBp2DD;EAAmC,iBAAA;CrBu2DlC;AqBt2DD;EAAqC,iBAAA;CrBy2DpC;AqBx2DD;EAAqC,iBAAA;CrB22DpC;AqB12DD;EAAsC,iBAAA;CrB62DrC;AqB52DD;EAAwC,iBAAA;CrB+2DvC;AqB92DD;EAAiC,iBAAA;CrBi3DhC;AqBh3DD;EAAqC,iBAAA;CrBm3DpC;AqBl3DD;EAA8B,iBAAA;CrBq3D7B;AqBp3DD;EAAsC,iBAAA;CrBu3DrC;AqBt3DD;EAAuC,iBAAA;CrBy3DtC;AqBx3DD;EAAyC,iBAAA;CrB23DxC;AqB13DD;EAAsC,iBAAA;CrB63DrC;AqB53DD;EAAqC,iBAAA;CrB+3DpC;AqB93DD;EAAsC,iBAAA;CrBi4DrC;AqBh4DD;EAAkC,iBAAA;CrBm4DjC;AqBl4DD;EAAyC,iBAAA;CrBq4DxC;AqBp4DD;EAAsC,iBAAA;CrBu4DrC;AqBt4DD;EAAqC,iBAAA;CrBy4DpC;AqBx4DD;EAAmC,iBAAA;CrB24DlC;AqB14DD;EAA+B,iBAAA;CrB64D9B;AqB54DD;EAAmC,iBAAA;CrB+4DlC;AqB94DD;EAAqC,iBAAA;CrBi5DpC;AqBh5DD;EAA8B,iBAAA;CrBm5D7B;AqBl5DD;;;EAE+B,iBAAA;CrBq5D9B;AqBp5DD;EAAoC,iBAAA;CrBu5DnC;AqBt5DD;EAAsC,iBAAA;CrBy5DrC;AqBx5DD;EAA0C,iBAAA;CrB25DzC;AqB15DD;EAAoC,iBAAA;CrB65DnC;AqB55DD;EAAoC,iBAAA;CrB+5DnC;AqB95DD;EAAmC,iBAAA;CrBi6DlC;AqBh6DD;EAAkC,iBAAA;CrBm6DjC;AqBl6DD;EAAwC,iBAAA;CrBq6DvC;AqBp6DD;EAAuC,iBAAA;CrBu6DtC;AqBt6DD;EAAoC,iBAAA;CrBy6DnC;AqBx6DD;EAAqC,iBAAA;CrB26DpC;AqB16DD;EAA2C,iBAAA;CrB66D1C;AqB56DD;EAAmC,iBAAA;CrB+6DlC;AqB96DD;EAAgC,iBAAA;CrBi7D/B;AqBh7DD;EAAuC,iBAAA;CrBm7DtC;AqBl7DD;EAAsC,iBAAA;CrBq7DrC;AqBp7DD;EAAuC,iBAAA;CrBu7DtC;AqBt7DD;EAAqC,iBAAA;CrBy7DpC;AqBx7DD;EAAiC,iBAAA;CrB27DhC;AqB17DD;EAAgC,iBAAA;CrB67D/B;AqB57DD;EAAmC,iBAAA;CrB+7DlC;AqB97DD;EAAuC,iBAAA;CrBi8DtC;AqBh8DD;EAA2C,iBAAA;CrBm8D1C;AqBl8DD;EAAwC,iBAAA;CrBq8DvC;AqBp8DD;EAAuC,iBAAA;CrBu8DtC;AqBt8DD;EAAsC,iBAAA;CrBy8DrC;AqBx8DD;EAAuC,iBAAA;CrB28DtC;AqB18DD;EAAyC,iBAAA;CrB68DxC;AqB58DD;EAAyC,iBAAA;CrB+8DxC;AqB98DD;EAAkC,iBAAA;CrBi9DjC;AqBh9DD;EAA6C,iBAAA;CrBm9D5C;AqBl9DD;EAAuC,iBAAA;CrBq9DtC;AqBp9DD;EAAoC,iBAAA;CrBu9DnC;AqBt9DD;EAAkC,iBAAA;CrBy9DjC;AqBx9DD;EAAqC,iBAAA;CrB29DpC;AqB19DD;EAAsC,iBAAA;CrB69DrC;AqB59DD;;EAC+B,iBAAA;CrB+9D9B;AqB99DD;EAAmC,iBAAA;CrBi+DlC;AqBh+DD;EAAiC,iBAAA;CrBm+DhC;AqBl+DD;EAAkC,iBAAA;CrBq+DjC;AqBp+DD;EAAkC,iBAAA;CrBu+DjC","file":"Lib.css","sourcesContent":["// Core variables and mixins\n@import \"variables.less\";\n@import \"mixins.less\";\n\n// Core CSS\n.layout-editor {\n    @import \"scaffolding.less\";\n    @import \"grid.less\";\n}\n \n// Utility classes\n@import \"utilities.less\";\n","// Vendor Prefixes\n//\n// All vendor mixins are deprecated as of v3.2.0 due to the introduction of\n// Autoprefixer in our Gruntfile. They will be removed in v4.\n\n// - Animations\n// - Backface visibility\n// - Box shadow\n// - Box sizing\n// - Content columns\n// - Hyphens\n// - Placeholder text\n// - Transformations\n// - Transitions\n// - User Select\n\n\n// Animations\n.animation(@animation) {\n  -webkit-animation: @animation;\n       -o-animation: @animation;\n          animation: @animation;\n}\n.animation-name(@name) {\n  -webkit-animation-name: @name;\n          animation-name: @name;\n}\n.animation-duration(@duration) {\n  -webkit-animation-duration: @duration;\n          animation-duration: @duration;\n}\n.animation-timing-function(@timing-function) {\n  -webkit-animation-timing-function: @timing-function;\n          animation-timing-function: @timing-function;\n}\n.animation-delay(@delay) {\n  -webkit-animation-delay: @delay;\n          animation-delay: @delay;\n}\n.animation-iteration-count(@iteration-count) {\n  -webkit-animation-iteration-count: @iteration-count;\n          animation-iteration-count: @iteration-count;\n}\n.animation-direction(@direction) {\n  -webkit-animation-direction: @direction;\n          animation-direction: @direction;\n}\n.animation-fill-mode(@fill-mode) {\n  -webkit-animation-fill-mode: @fill-mode;\n          animation-fill-mode: @fill-mode;\n}\n\n// Backface visibility\n// Prevent browsers from flickering when using CSS 3D transforms.\n// Default value is `visible`, but can be changed to `hidden`\n\n.backface-visibility(@visibility){\n  -webkit-backface-visibility: @visibility;\n     -moz-backface-visibility: @visibility;\n          backface-visibility: @visibility;\n}\n\n// Drop shadows\n//\n// Note: Deprecated `.box-shadow()` as of v3.1.0 since all of Bootstrap's\n// supported browsers that have box shadow capabilities now support it.\n\n.box-shadow(@shadow) {\n  -webkit-box-shadow: @shadow; // iOS <4.3 & Android <4.1\n          box-shadow: @shadow;\n}\n\n// Box sizing\n.box-sizing(@boxmodel) {\n  -webkit-box-sizing: @boxmodel;\n     -moz-box-sizing: @boxmodel;\n          box-sizing: @boxmodel;\n}\n\n// CSS3 Content Columns\n.content-columns(@column-count; @column-gap: @grid-gutter-width) {\n  -webkit-column-count: @column-count;\n     -moz-column-count: @column-count;\n          column-count: @column-count;\n  -webkit-column-gap: @column-gap;\n     -moz-column-gap: @column-gap;\n          column-gap: @column-gap;\n}\n\n// Optional hyphenation\n.hyphens(@mode: auto) {\n  word-wrap: break-word;\n  -webkit-hyphens: @mode;\n     -moz-hyphens: @mode;\n      -ms-hyphens: @mode; // IE10+\n       -o-hyphens: @mode;\n          hyphens: @mode;\n}\n\n// Placeholder text\n.placeholder(@color: @input-color-placeholder) {\n  // Firefox\n  &::-moz-placeholder {\n    color: @color;\n    opacity: 1; // See https://github.com/twbs/bootstrap/pull/11526\n  }\n  &:-ms-input-placeholder { color: @color; } // Internet Explorer 10+\n  &::-webkit-input-placeholder  { color: @color; } // Safari and Chrome\n}\n\n// Transformations\n.scale(@ratio) {\n  -webkit-transform: scale(@ratio);\n      -ms-transform: scale(@ratio); // IE9 only\n       -o-transform: scale(@ratio);\n          transform: scale(@ratio);\n}\n.scale(@ratioX; @ratioY) {\n  -webkit-transform: scale(@ratioX, @ratioY);\n      -ms-transform: scale(@ratioX, @ratioY); // IE9 only\n       -o-transform: scale(@ratioX, @ratioY);\n          transform: scale(@ratioX, @ratioY);\n}\n.scaleX(@ratio) {\n  -webkit-transform: scaleX(@ratio);\n      -ms-transform: scaleX(@ratio); // IE9 only\n       -o-transform: scaleX(@ratio);\n          transform: scaleX(@ratio);\n}\n.scaleY(@ratio) {\n  -webkit-transform: scaleY(@ratio);\n      -ms-transform: scaleY(@ratio); // IE9 only\n       -o-transform: scaleY(@ratio);\n          transform: scaleY(@ratio);\n}\n.skew(@x; @y) {\n  -webkit-transform: skewX(@x) skewY(@y);\n      -ms-transform: skewX(@x) skewY(@y); // See https://github.com/twbs/bootstrap/issues/4885; IE9+\n       -o-transform: skewX(@x) skewY(@y);\n          transform: skewX(@x) skewY(@y);\n}\n.translate(@x; @y) {\n  -webkit-transform: translate(@x, @y);\n      -ms-transform: translate(@x, @y); // IE9 only\n       -o-transform: translate(@x, @y);\n          transform: translate(@x, @y);\n}\n.translate3d(@x; @y; @z) {\n  -webkit-transform: translate3d(@x, @y, @z);\n          transform: translate3d(@x, @y, @z);\n}\n.rotate(@degrees) {\n  -webkit-transform: rotate(@degrees);\n      -ms-transform: rotate(@degrees); // IE9 only\n       -o-transform: rotate(@degrees);\n          transform: rotate(@degrees);\n}\n.rotateX(@degrees) {\n  -webkit-transform: rotateX(@degrees);\n      -ms-transform: rotateX(@degrees); // IE9 only\n       -o-transform: rotateX(@degrees);\n          transform: rotateX(@degrees);\n}\n.rotateY(@degrees) {\n  -webkit-transform: rotateY(@degrees);\n      -ms-transform: rotateY(@degrees); // IE9 only\n       -o-transform: rotateY(@degrees);\n          transform: rotateY(@degrees);\n}\n.perspective(@perspective) {\n  -webkit-perspective: @perspective;\n     -moz-perspective: @perspective;\n          perspective: @perspective;\n}\n.perspective-origin(@perspective) {\n  -webkit-perspective-origin: @perspective;\n     -moz-perspective-origin: @perspective;\n          perspective-origin: @perspective;\n}\n.transform-origin(@origin) {\n  -webkit-transform-origin: @origin;\n     -moz-transform-origin: @origin;\n      -ms-transform-origin: @origin; // IE9 only\n          transform-origin: @origin;\n}\n\n\n// Transitions\n\n.transition(@transition) {\n  -webkit-transition: @transition;\n       -o-transition: @transition;\n          transition: @transition;\n}\n.transition-property(@transition-property) {\n  -webkit-transition-property: @transition-property;\n          transition-property: @transition-property;\n}\n.transition-delay(@transition-delay) {\n  -webkit-transition-delay: @transition-delay;\n          transition-delay: @transition-delay;\n}\n.transition-duration(@transition-duration) {\n  -webkit-transition-duration: @transition-duration;\n          transition-duration: @transition-duration;\n}\n.transition-timing-function(@timing-function) {\n  -webkit-transition-timing-function: @timing-function;\n          transition-timing-function: @timing-function;\n}\n.transition-transform(@transition) {\n  -webkit-transition: -webkit-transform @transition;\n     -moz-transition: -moz-transform @transition;\n       -o-transition: -o-transform @transition;\n          transition: transform @transition;\n}\n\n\n// User select\n// For selecting text on the page\n\n.user-select(@select) {\n  -webkit-user-select: @select;\n     -moz-user-select: @select;\n      -ms-user-select: @select; // IE10+\n          user-select: @select;\n}\n",".layout-editor * {\n  -webkit-box-sizing: border-box;\n  -moz-box-sizing: border-box;\n  box-sizing: border-box;\n}\n.layout-editor *:before,\n.layout-editor *:after {\n  -webkit-box-sizing: border-box;\n  -moz-box-sizing: border-box;\n  box-sizing: border-box;\n}\n.layout-editor html {\n  font-size: 10px;\n  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);\n}\n.layout-editor body {\n  font-family: \"Helvetica Neue\", Helvetica, Arial, sans-serif;\n  font-size: 14px;\n  line-height: 1.42857143;\n  color: #333333;\n  background-color: #ffffff;\n}\n.layout-editor input,\n.layout-editor button,\n.layout-editor select,\n.layout-editor textarea {\n  font-family: inherit;\n  font-size: inherit;\n  line-height: inherit;\n}\n.layout-editor a {\n  color: #337ab7;\n  text-decoration: none;\n}\n.layout-editor a:hover,\n.layout-editor a:focus {\n  color: #23527c;\n  text-decoration: underline;\n}\n.layout-editor a:focus {\n  outline: thin dotted;\n  outline: 5px auto -webkit-focus-ring-color;\n  outline-offset: -2px;\n}\n.layout-editor figure {\n  margin: 0;\n}\n.layout-editor img {\n  vertical-align: middle;\n}\n.layout-editor .img-responsive {\n  display: block;\n  max-width: 100%;\n  height: auto;\n}\n.layout-editor .img-rounded {\n  border-radius: 6px;\n}\n.layout-editor .img-thumbnail {\n  padding: 4px;\n  line-height: 1.42857143;\n  background-color: #ffffff;\n  border: 1px solid #dddddd;\n  border-radius: 4px;\n  -webkit-transition: all 0.2s ease-in-out;\n  -o-transition: all 0.2s ease-in-out;\n  transition: all 0.2s ease-in-out;\n  display: inline-block;\n  max-width: 100%;\n  height: auto;\n}\n.layout-editor .img-circle {\n  border-radius: 50%;\n}\n.layout-editor hr {\n  margin-top: 20px;\n  margin-bottom: 20px;\n  border: 0;\n  border-top: 1px solid #eeeeee;\n}\n.layout-editor .sr-only {\n  position: absolute;\n  width: 1px;\n  height: 1px;\n  margin: -1px;\n  padding: 0;\n  overflow: hidden;\n  clip: rect(0, 0, 0, 0);\n  border: 0;\n}\n.layout-editor .sr-only-focusable:active,\n.layout-editor .sr-only-focusable:focus {\n  position: static;\n  width: auto;\n  height: auto;\n  margin: 0;\n  overflow: visible;\n  clip: auto;\n}\n.layout-editor .container {\n  margin-right: auto;\n  margin-left: auto;\n  padding-left: 15px;\n  padding-right: 15px;\n}\n@media (min-width: 768px) {\n  .layout-editor .container {\n    width: 750px;\n  }\n}\n@media (min-width: 992px) {\n  .layout-editor .container {\n    width: 970px;\n  }\n}\n@media (min-width: 1200px) {\n  .layout-editor .container {\n    width: 1170px;\n  }\n}\n.layout-editor .container-fluid {\n  margin-right: auto;\n  margin-left: auto;\n  padding-left: 15px;\n  padding-right: 15px;\n}\n.layout-editor .row {\n  margin-left: -15px;\n  margin-right: -15px;\n}\n.layout-editor .col-xs-1, .col-sm-1, .col-md-1, .col-lg-1, .col-xs-2, .col-sm-2, .col-md-2, .col-lg-2, .col-xs-3, .col-sm-3, .col-md-3, .col-lg-3, .col-xs-4, .col-sm-4, .col-md-4, .col-lg-4, .col-xs-5, .col-sm-5, .col-md-5, .col-lg-5, .col-xs-6, .col-sm-6, .col-md-6, .col-lg-6, .col-xs-7, .col-sm-7, .col-md-7, .col-lg-7, .col-xs-8, .col-sm-8, .col-md-8, .col-lg-8, .col-xs-9, .col-sm-9, .col-md-9, .col-lg-9, .col-xs-10, .col-sm-10, .col-md-10, .col-lg-10, .col-xs-11, .col-sm-11, .col-md-11, .col-lg-11, .col-xs-12, .col-sm-12, .col-md-12, .col-lg-12 {\n  position: relative;\n  min-height: 1px;\n  padding-left: 15px;\n  padding-right: 15px;\n}\n.layout-editor .col-xs-1, .col-xs-2, .col-xs-3, .col-xs-4, .col-xs-5, .col-xs-6, .col-xs-7, .col-xs-8, .col-xs-9, .col-xs-10, .col-xs-11, .col-xs-12 {\n  float: left;\n}\n.layout-editor .col-xs-12 {\n  width: 100%;\n}\n.layout-editor .col-xs-11 {\n  width: 91.66666667%;\n}\n.layout-editor .col-xs-10 {\n  width: 83.33333333%;\n}\n.layout-editor .col-xs-9 {\n  width: 75%;\n}\n.layout-editor .col-xs-8 {\n  width: 66.66666667%;\n}\n.layout-editor .col-xs-7 {\n  width: 58.33333333%;\n}\n.layout-editor .col-xs-6 {\n  width: 50%;\n}\n.layout-editor .col-xs-5 {\n  width: 41.66666667%;\n}\n.layout-editor .col-xs-4 {\n  width: 33.33333333%;\n}\n.layout-editor .col-xs-3 {\n  width: 25%;\n}\n.layout-editor .col-xs-2 {\n  width: 16.66666667%;\n}\n.layout-editor .col-xs-1 {\n  width: 8.33333333%;\n}\n.layout-editor .col-xs-pull-12 {\n  right: 100%;\n}\n.layout-editor .col-xs-pull-11 {\n  right: 91.66666667%;\n}\n.layout-editor .col-xs-pull-10 {\n  right: 83.33333333%;\n}\n.layout-editor .col-xs-pull-9 {\n  right: 75%;\n}\n.layout-editor .col-xs-pull-8 {\n  right: 66.66666667%;\n}\n.layout-editor .col-xs-pull-7 {\n  right: 58.33333333%;\n}\n.layout-editor .col-xs-pull-6 {\n  right: 50%;\n}\n.layout-editor .col-xs-pull-5 {\n  right: 41.66666667%;\n}\n.layout-editor .col-xs-pull-4 {\n  right: 33.33333333%;\n}\n.layout-editor .col-xs-pull-3 {\n  right: 25%;\n}\n.layout-editor .col-xs-pull-2 {\n  right: 16.66666667%;\n}\n.layout-editor .col-xs-pull-1 {\n  right: 8.33333333%;\n}\n.layout-editor .col-xs-pull-0 {\n  right: auto;\n}\n.layout-editor .col-xs-push-12 {\n  left: 100%;\n}\n.layout-editor .col-xs-push-11 {\n  left: 91.66666667%;\n}\n.layout-editor .col-xs-push-10 {\n  left: 83.33333333%;\n}\n.layout-editor .col-xs-push-9 {\n  left: 75%;\n}\n.layout-editor .col-xs-push-8 {\n  left: 66.66666667%;\n}\n.layout-editor .col-xs-push-7 {\n  left: 58.33333333%;\n}\n.layout-editor .col-xs-push-6 {\n  left: 50%;\n}\n.layout-editor .col-xs-push-5 {\n  left: 41.66666667%;\n}\n.layout-editor .col-xs-push-4 {\n  left: 33.33333333%;\n}\n.layout-editor .col-xs-push-3 {\n  left: 25%;\n}\n.layout-editor .col-xs-push-2 {\n  left: 16.66666667%;\n}\n.layout-editor .col-xs-push-1 {\n  left: 8.33333333%;\n}\n.layout-editor .col-xs-push-0 {\n  left: auto;\n}\n.layout-editor .col-xs-offset-12 {\n  margin-left: 100%;\n}\n.layout-editor .col-xs-offset-11 {\n  margin-left: 91.66666667%;\n}\n.layout-editor .col-xs-offset-10 {\n  margin-left: 83.33333333%;\n}\n.layout-editor .col-xs-offset-9 {\n  margin-left: 75%;\n}\n.layout-editor .col-xs-offset-8 {\n  margin-left: 66.66666667%;\n}\n.layout-editor .col-xs-offset-7 {\n  margin-left: 58.33333333%;\n}\n.layout-editor .col-xs-offset-6 {\n  margin-left: 50%;\n}\n.layout-editor .col-xs-offset-5 {\n  margin-left: 41.66666667%;\n}\n.layout-editor .col-xs-offset-4 {\n  margin-left: 33.33333333%;\n}\n.layout-editor .col-xs-offset-3 {\n  margin-left: 25%;\n}\n.layout-editor .col-xs-offset-2 {\n  margin-left: 16.66666667%;\n}\n.layout-editor .col-xs-offset-1 {\n  margin-left: 8.33333333%;\n}\n.layout-editor .col-xs-offset-0 {\n  margin-left: 0%;\n}\n@media (min-width: 768px) {\n  .layout-editor .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12 {\n    float: left;\n  }\n  .layout-editor .col-sm-12 {\n    width: 100%;\n  }\n  .layout-editor .col-sm-11 {\n    width: 91.66666667%;\n  }\n  .layout-editor .col-sm-10 {\n    width: 83.33333333%;\n  }\n  .layout-editor .col-sm-9 {\n    width: 75%;\n  }\n  .layout-editor .col-sm-8 {\n    width: 66.66666667%;\n  }\n  .layout-editor .col-sm-7 {\n    width: 58.33333333%;\n  }\n  .layout-editor .col-sm-6 {\n    width: 50%;\n  }\n  .layout-editor .col-sm-5 {\n    width: 41.66666667%;\n  }\n  .layout-editor .col-sm-4 {\n    width: 33.33333333%;\n  }\n  .layout-editor .col-sm-3 {\n    width: 25%;\n  }\n  .layout-editor .col-sm-2 {\n    width: 16.66666667%;\n  }\n  .layout-editor .col-sm-1 {\n    width: 8.33333333%;\n  }\n  .layout-editor .col-sm-pull-12 {\n    right: 100%;\n  }\n  .layout-editor .col-sm-pull-11 {\n    right: 91.66666667%;\n  }\n  .layout-editor .col-sm-pull-10 {\n    right: 83.33333333%;\n  }\n  .layout-editor .col-sm-pull-9 {\n    right: 75%;\n  }\n  .layout-editor .col-sm-pull-8 {\n    right: 66.66666667%;\n  }\n  .layout-editor .col-sm-pull-7 {\n    right: 58.33333333%;\n  }\n  .layout-editor .col-sm-pull-6 {\n    right: 50%;\n  }\n  .layout-editor .col-sm-pull-5 {\n    right: 41.66666667%;\n  }\n  .layout-editor .col-sm-pull-4 {\n    right: 33.33333333%;\n  }\n  .layout-editor .col-sm-pull-3 {\n    right: 25%;\n  }\n  .layout-editor .col-sm-pull-2 {\n    right: 16.66666667%;\n  }\n  .layout-editor .col-sm-pull-1 {\n    right: 8.33333333%;\n  }\n  .layout-editor .col-sm-pull-0 {\n    right: auto;\n  }\n  .layout-editor .col-sm-push-12 {\n    left: 100%;\n  }\n  .layout-editor .col-sm-push-11 {\n    left: 91.66666667%;\n  }\n  .layout-editor .col-sm-push-10 {\n    left: 83.33333333%;\n  }\n  .layout-editor .col-sm-push-9 {\n    left: 75%;\n  }\n  .layout-editor .col-sm-push-8 {\n    left: 66.66666667%;\n  }\n  .layout-editor .col-sm-push-7 {\n    left: 58.33333333%;\n  }\n  .layout-editor .col-sm-push-6 {\n    left: 50%;\n  }\n  .layout-editor .col-sm-push-5 {\n    left: 41.66666667%;\n  }\n  .layout-editor .col-sm-push-4 {\n    left: 33.33333333%;\n  }\n  .layout-editor .col-sm-push-3 {\n    left: 25%;\n  }\n  .layout-editor .col-sm-push-2 {\n    left: 16.66666667%;\n  }\n  .layout-editor .col-sm-push-1 {\n    left: 8.33333333%;\n  }\n  .layout-editor .col-sm-push-0 {\n    left: auto;\n  }\n  .layout-editor .col-sm-offset-12 {\n    margin-left: 100%;\n  }\n  .layout-editor .col-sm-offset-11 {\n    margin-left: 91.66666667%;\n  }\n  .layout-editor .col-sm-offset-10 {\n    margin-left: 83.33333333%;\n  }\n  .layout-editor .col-sm-offset-9 {\n    margin-left: 75%;\n  }\n  .layout-editor .col-sm-offset-8 {\n    margin-left: 66.66666667%;\n  }\n  .layout-editor .col-sm-offset-7 {\n    margin-left: 58.33333333%;\n  }\n  .layout-editor .col-sm-offset-6 {\n    margin-left: 50%;\n  }\n  .layout-editor .col-sm-offset-5 {\n    margin-left: 41.66666667%;\n  }\n  .layout-editor .col-sm-offset-4 {\n    margin-left: 33.33333333%;\n  }\n  .layout-editor .col-sm-offset-3 {\n    margin-left: 25%;\n  }\n  .layout-editor .col-sm-offset-2 {\n    margin-left: 16.66666667%;\n  }\n  .layout-editor .col-sm-offset-1 {\n    margin-left: 8.33333333%;\n  }\n  .layout-editor .col-sm-offset-0 {\n    margin-left: 0%;\n  }\n}\n@media (min-width: 992px) {\n  .layout-editor .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12 {\n    float: left;\n  }\n  .layout-editor .col-md-12 {\n    width: 100%;\n  }\n  .layout-editor .col-md-11 {\n    width: 91.66666667%;\n  }\n  .layout-editor .col-md-10 {\n    width: 83.33333333%;\n  }\n  .layout-editor .col-md-9 {\n    width: 75%;\n  }\n  .layout-editor .col-md-8 {\n    width: 66.66666667%;\n  }\n  .layout-editor .col-md-7 {\n    width: 58.33333333%;\n  }\n  .layout-editor .col-md-6 {\n    width: 50%;\n  }\n  .layout-editor .col-md-5 {\n    width: 41.66666667%;\n  }\n  .layout-editor .col-md-4 {\n    width: 33.33333333%;\n  }\n  .layout-editor .col-md-3 {\n    width: 25%;\n  }\n  .layout-editor .col-md-2 {\n    width: 16.66666667%;\n  }\n  .layout-editor .col-md-1 {\n    width: 8.33333333%;\n  }\n  .layout-editor .col-md-pull-12 {\n    right: 100%;\n  }\n  .layout-editor .col-md-pull-11 {\n    right: 91.66666667%;\n  }\n  .layout-editor .col-md-pull-10 {\n    right: 83.33333333%;\n  }\n  .layout-editor .col-md-pull-9 {\n    right: 75%;\n  }\n  .layout-editor .col-md-pull-8 {\n    right: 66.66666667%;\n  }\n  .layout-editor .col-md-pull-7 {\n    right: 58.33333333%;\n  }\n  .layout-editor .col-md-pull-6 {\n    right: 50%;\n  }\n  .layout-editor .col-md-pull-5 {\n    right: 41.66666667%;\n  }\n  .layout-editor .col-md-pull-4 {\n    right: 33.33333333%;\n  }\n  .layout-editor .col-md-pull-3 {\n    right: 25%;\n  }\n  .layout-editor .col-md-pull-2 {\n    right: 16.66666667%;\n  }\n  .layout-editor .col-md-pull-1 {\n    right: 8.33333333%;\n  }\n  .layout-editor .col-md-pull-0 {\n    right: auto;\n  }\n  .layout-editor .col-md-push-12 {\n    left: 100%;\n  }\n  .layout-editor .col-md-push-11 {\n    left: 91.66666667%;\n  }\n  .layout-editor .col-md-push-10 {\n    left: 83.33333333%;\n  }\n  .layout-editor .col-md-push-9 {\n    left: 75%;\n  }\n  .layout-editor .col-md-push-8 {\n    left: 66.66666667%;\n  }\n  .layout-editor .col-md-push-7 {\n    left: 58.33333333%;\n  }\n  .layout-editor .col-md-push-6 {\n    left: 50%;\n  }\n  .layout-editor .col-md-push-5 {\n    left: 41.66666667%;\n  }\n  .layout-editor .col-md-push-4 {\n    left: 33.33333333%;\n  }\n  .layout-editor .col-md-push-3 {\n    left: 25%;\n  }\n  .layout-editor .col-md-push-2 {\n    left: 16.66666667%;\n  }\n  .layout-editor .col-md-push-1 {\n    left: 8.33333333%;\n  }\n  .layout-editor .col-md-push-0 {\n    left: auto;\n  }\n  .layout-editor .col-md-offset-12 {\n    margin-left: 100%;\n  }\n  .layout-editor .col-md-offset-11 {\n    margin-left: 91.66666667%;\n  }\n  .layout-editor .col-md-offset-10 {\n    margin-left: 83.33333333%;\n  }\n  .layout-editor .col-md-offset-9 {\n    margin-left: 75%;\n  }\n  .layout-editor .col-md-offset-8 {\n    margin-left: 66.66666667%;\n  }\n  .layout-editor .col-md-offset-7 {\n    margin-left: 58.33333333%;\n  }\n  .layout-editor .col-md-offset-6 {\n    margin-left: 50%;\n  }\n  .layout-editor .col-md-offset-5 {\n    margin-left: 41.66666667%;\n  }\n  .layout-editor .col-md-offset-4 {\n    margin-left: 33.33333333%;\n  }\n  .layout-editor .col-md-offset-3 {\n    margin-left: 25%;\n  }\n  .layout-editor .col-md-offset-2 {\n    margin-left: 16.66666667%;\n  }\n  .layout-editor .col-md-offset-1 {\n    margin-left: 8.33333333%;\n  }\n  .layout-editor .col-md-offset-0 {\n    margin-left: 0%;\n  }\n}\n@media (min-width: 1200px) {\n  .layout-editor .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12 {\n    float: left;\n  }\n  .layout-editor .col-lg-12 {\n    width: 100%;\n  }\n  .layout-editor .col-lg-11 {\n    width: 91.66666667%;\n  }\n  .layout-editor .col-lg-10 {\n    width: 83.33333333%;\n  }\n  .layout-editor .col-lg-9 {\n    width: 75%;\n  }\n  .layout-editor .col-lg-8 {\n    width: 66.66666667%;\n  }\n  .layout-editor .col-lg-7 {\n    width: 58.33333333%;\n  }\n  .layout-editor .col-lg-6 {\n    width: 50%;\n  }\n  .layout-editor .col-lg-5 {\n    width: 41.66666667%;\n  }\n  .layout-editor .col-lg-4 {\n    width: 33.33333333%;\n  }\n  .layout-editor .col-lg-3 {\n    width: 25%;\n  }\n  .layout-editor .col-lg-2 {\n    width: 16.66666667%;\n  }\n  .layout-editor .col-lg-1 {\n    width: 8.33333333%;\n  }\n  .layout-editor .col-lg-pull-12 {\n    right: 100%;\n  }\n  .layout-editor .col-lg-pull-11 {\n    right: 91.66666667%;\n  }\n  .layout-editor .col-lg-pull-10 {\n    right: 83.33333333%;\n  }\n  .layout-editor .col-lg-pull-9 {\n    right: 75%;\n  }\n  .layout-editor .col-lg-pull-8 {\n    right: 66.66666667%;\n  }\n  .layout-editor .col-lg-pull-7 {\n    right: 58.33333333%;\n  }\n  .layout-editor .col-lg-pull-6 {\n    right: 50%;\n  }\n  .layout-editor .col-lg-pull-5 {\n    right: 41.66666667%;\n  }\n  .layout-editor .col-lg-pull-4 {\n    right: 33.33333333%;\n  }\n  .layout-editor .col-lg-pull-3 {\n    right: 25%;\n  }\n  .layout-editor .col-lg-pull-2 {\n    right: 16.66666667%;\n  }\n  .layout-editor .col-lg-pull-1 {\n    right: 8.33333333%;\n  }\n  .layout-editor .col-lg-pull-0 {\n    right: auto;\n  }\n  .layout-editor .col-lg-push-12 {\n    left: 100%;\n  }\n  .layout-editor .col-lg-push-11 {\n    left: 91.66666667%;\n  }\n  .layout-editor .col-lg-push-10 {\n    left: 83.33333333%;\n  }\n  .layout-editor .col-lg-push-9 {\n    left: 75%;\n  }\n  .layout-editor .col-lg-push-8 {\n    left: 66.66666667%;\n  }\n  .layout-editor .col-lg-push-7 {\n    left: 58.33333333%;\n  }\n  .layout-editor .col-lg-push-6 {\n    left: 50%;\n  }\n  .layout-editor .col-lg-push-5 {\n    left: 41.66666667%;\n  }\n  .layout-editor .col-lg-push-4 {\n    left: 33.33333333%;\n  }\n  .layout-editor .col-lg-push-3 {\n    left: 25%;\n  }\n  .layout-editor .col-lg-push-2 {\n    left: 16.66666667%;\n  }\n  .layout-editor .col-lg-push-1 {\n    left: 8.33333333%;\n  }\n  .layout-editor .col-lg-push-0 {\n    left: auto;\n  }\n  .layout-editor .col-lg-offset-12 {\n    margin-left: 100%;\n  }\n  .layout-editor .col-lg-offset-11 {\n    margin-left: 91.66666667%;\n  }\n  .layout-editor .col-lg-offset-10 {\n    margin-left: 83.33333333%;\n  }\n  .layout-editor .col-lg-offset-9 {\n    margin-left: 75%;\n  }\n  .layout-editor .col-lg-offset-8 {\n    margin-left: 66.66666667%;\n  }\n  .layout-editor .col-lg-offset-7 {\n    margin-left: 58.33333333%;\n  }\n  .layout-editor .col-lg-offset-6 {\n    margin-left: 50%;\n  }\n  .layout-editor .col-lg-offset-5 {\n    margin-left: 41.66666667%;\n  }\n  .layout-editor .col-lg-offset-4 {\n    margin-left: 33.33333333%;\n  }\n  .layout-editor .col-lg-offset-3 {\n    margin-left: 25%;\n  }\n  .layout-editor .col-lg-offset-2 {\n    margin-left: 16.66666667%;\n  }\n  .layout-editor .col-lg-offset-1 {\n    margin-left: 8.33333333%;\n  }\n  .layout-editor .col-lg-offset-0 {\n    margin-left: 0%;\n  }\n}\n.clearfix:before,\n.clearfix:after,\n.layout-editor .container:before,\n.layout-editor .container:after,\n.layout-editor .container-fluid:before,\n.layout-editor .container-fluid:after,\n.layout-editor .row:before,\n.layout-editor .row:after {\n  content: \" \";\n  display: table;\n}\n.clearfix:after,\n.layout-editor .container:after,\n.layout-editor .container-fluid:after,\n.layout-editor .row:after {\n  clear: both;\n}\n.center-block {\n  display: block;\n  margin-left: auto;\n  margin-right: auto;\n}\n.pull-right {\n  float: right !important;\n}\n.pull-left {\n  float: left !important;\n}\n.hide {\n  display: none !important;\n}\n.show {\n  display: block !important;\n}\n.invisible {\n  visibility: hidden;\n}\n.text-hide {\n  font: 0/0 a;\n  color: transparent;\n  text-shadow: none;\n  background-color: transparent;\n  border: 0;\n}\n.hidden {\n  display: none !important;\n  visibility: hidden !important;\n}\n.affix {\n  position: fixed;\n}\n\n/*!\n *  Font Awesome 4.3.0 by @davegandy - http://fontawesome.io - @fontawesome\n *  License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License)\n */\n/* FONT PATH\n * -------------------------- */\n@font-face {\n  font-family: 'FontAwesome';\n  src: url('Lib/FontAwesome/Fonts/fontawesome-webfont.eot?v=4.3.0');\n  src: url('Lib/FontAwesome/Fonts/fontawesome-webfont.eot?#iefix&v=4.3.0') format('embedded-opentype'), url('Lib/FontAwesome/Fonts/fontawesome-webfont.woff2?v=4.3.0') format('woff2'), url('Lib/FontAwesome/Fonts/fontawesome-webfont.woff?v=4.3.0') format('woff'), url('Lib/FontAwesome/Fonts/fontawesome-webfont.ttf?v=4.3.0') format('truetype'), url('Lib/FontAwesome/Fonts/fontawesome-webfont.svg?v=4.3.0#fontawesomeregular') format('svg');\n  font-weight: normal;\n  font-style: normal;\n}\n.fa {\n  display: inline-block;\n  font: normal normal normal 14px/1 FontAwesome;\n  font-size: inherit;\n  text-rendering: auto;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n  transform: translate(0, 0);\n}\n/* makes the font 33% larger relative to the icon container */\n.fa-lg {\n  font-size: 1.33333333em;\n  line-height: 0.75em;\n  vertical-align: -15%;\n}\n.fa-2x {\n  font-size: 2em;\n}\n.fa-3x {\n  font-size: 3em;\n}\n.fa-4x {\n  font-size: 4em;\n}\n.fa-5x {\n  font-size: 5em;\n}\n.fa-fw {\n  width: 1.28571429em;\n  text-align: center;\n}\n.fa-ul {\n  padding-left: 0;\n  margin-left: 2.14285714em;\n  list-style-type: none;\n}\n.fa-ul > li {\n  position: relative;\n}\n.fa-li {\n  position: absolute;\n  left: -2.14285714em;\n  width: 2.14285714em;\n  top: 0.14285714em;\n  text-align: center;\n}\n.fa-li.fa-lg {\n  left: -1.85714286em;\n}\n.fa-border {\n  padding: .2em .25em .15em;\n  border: solid 0.08em #eeeeee;\n  border-radius: .1em;\n}\n.pull-right {\n  float: right;\n}\n.pull-left {\n  float: left;\n}\n.fa.pull-left {\n  margin-right: .3em;\n}\n.fa.pull-right {\n  margin-left: .3em;\n}\n.fa-spin {\n  -webkit-animation: fa-spin 2s infinite linear;\n  animation: fa-spin 2s infinite linear;\n}\n.fa-pulse {\n  -webkit-animation: fa-spin 1s infinite steps(8);\n  animation: fa-spin 1s infinite steps(8);\n}\n@-webkit-keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n    transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n    transform: rotate(359deg);\n  }\n}\n@keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n    transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n    transform: rotate(359deg);\n  }\n}\n.fa-rotate-90 {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=1);\n  -webkit-transform: rotate(90deg);\n  -ms-transform: rotate(90deg);\n  transform: rotate(90deg);\n}\n.fa-rotate-180 {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=2);\n  -webkit-transform: rotate(180deg);\n  -ms-transform: rotate(180deg);\n  transform: rotate(180deg);\n}\n.fa-rotate-270 {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=3);\n  -webkit-transform: rotate(270deg);\n  -ms-transform: rotate(270deg);\n  transform: rotate(270deg);\n}\n.fa-flip-horizontal {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=0, mirror=1);\n  -webkit-transform: scale(-1, 1);\n  -ms-transform: scale(-1, 1);\n  transform: scale(-1, 1);\n}\n.fa-flip-vertical {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=2, mirror=1);\n  -webkit-transform: scale(1, -1);\n  -ms-transform: scale(1, -1);\n  transform: scale(1, -1);\n}\n:root .fa-rotate-90,\n:root .fa-rotate-180,\n:root .fa-rotate-270,\n:root .fa-flip-horizontal,\n:root .fa-flip-vertical {\n  filter: none;\n}\n.fa-stack {\n  position: relative;\n  display: inline-block;\n  width: 2em;\n  height: 2em;\n  line-height: 2em;\n  vertical-align: middle;\n}\n.fa-stack-1x,\n.fa-stack-2x {\n  position: absolute;\n  left: 0;\n  width: 100%;\n  text-align: center;\n}\n.fa-stack-1x {\n  line-height: inherit;\n}\n.fa-stack-2x {\n  font-size: 2em;\n}\n.fa-inverse {\n  color: #ffffff;\n}\n/* Font Awesome uses the Unicode Private Use Area (PUA) to ensure screen\n   readers do not read off random characters that represent icons */\n.fa-glass:before {\n  content: \"\\f000\";\n}\n.fa-music:before {\n  content: \"\\f001\";\n}\n.fa-search:before {\n  content: \"\\f002\";\n}\n.fa-envelope-o:before {\n  content: \"\\f003\";\n}\n.fa-heart:before {\n  content: \"\\f004\";\n}\n.fa-star:before {\n  content: \"\\f005\";\n}\n.fa-star-o:before {\n  content: \"\\f006\";\n}\n.fa-user:before {\n  content: \"\\f007\";\n}\n.fa-film:before {\n  content: \"\\f008\";\n}\n.fa-th-large:before {\n  content: \"\\f009\";\n}\n.fa-th:before {\n  content: \"\\f00a\";\n}\n.fa-th-list:before {\n  content: \"\\f00b\";\n}\n.fa-check:before {\n  content: \"\\f00c\";\n}\n.fa-remove:before,\n.fa-close:before,\n.fa-times:before {\n  content: \"\\f00d\";\n}\n.fa-search-plus:before {\n  content: \"\\f00e\";\n}\n.fa-search-minus:before {\n  content: \"\\f010\";\n}\n.fa-power-off:before {\n  content: \"\\f011\";\n}\n.fa-signal:before {\n  content: \"\\f012\";\n}\n.fa-gear:before,\n.fa-cog:before {\n  content: \"\\f013\";\n}\n.fa-trash-o:before {\n  content: \"\\f014\";\n}\n.fa-home:before {\n  content: \"\\f015\";\n}\n.fa-file-o:before {\n  content: \"\\f016\";\n}\n.fa-clock-o:before {\n  content: \"\\f017\";\n}\n.fa-road:before {\n  content: \"\\f018\";\n}\n.fa-download:before {\n  content: \"\\f019\";\n}\n.fa-arrow-circle-o-down:before {\n  content: \"\\f01a\";\n}\n.fa-arrow-circle-o-up:before {\n  content: \"\\f01b\";\n}\n.fa-inbox:before {\n  content: \"\\f01c\";\n}\n.fa-play-circle-o:before {\n  content: \"\\f01d\";\n}\n.fa-rotate-right:before,\n.fa-repeat:before {\n  content: \"\\f01e\";\n}\n.fa-refresh:before {\n  content: \"\\f021\";\n}\n.fa-list-alt:before {\n  content: \"\\f022\";\n}\n.fa-lock:before {\n  content: \"\\f023\";\n}\n.fa-flag:before {\n  content: \"\\f024\";\n}\n.fa-headphones:before {\n  content: \"\\f025\";\n}\n.fa-volume-off:before {\n  content: \"\\f026\";\n}\n.fa-volume-down:before {\n  content: \"\\f027\";\n}\n.fa-volume-up:before {\n  content: \"\\f028\";\n}\n.fa-qrcode:before {\n  content: \"\\f029\";\n}\n.fa-barcode:before {\n  content: \"\\f02a\";\n}\n.fa-tag:before {\n  content: \"\\f02b\";\n}\n.fa-tags:before {\n  content: \"\\f02c\";\n}\n.fa-book:before {\n  content: \"\\f02d\";\n}\n.fa-bookmark:before {\n  content: \"\\f02e\";\n}\n.fa-print:before {\n  content: \"\\f02f\";\n}\n.fa-camera:before {\n  content: \"\\f030\";\n}\n.fa-font:before {\n  content: \"\\f031\";\n}\n.fa-bold:before {\n  content: \"\\f032\";\n}\n.fa-italic:before {\n  content: \"\\f033\";\n}\n.fa-text-height:before {\n  content: \"\\f034\";\n}\n.fa-text-width:before {\n  content: \"\\f035\";\n}\n.fa-align-left:before {\n  content: \"\\f036\";\n}\n.fa-align-center:before {\n  content: \"\\f037\";\n}\n.fa-align-right:before {\n  content: \"\\f038\";\n}\n.fa-align-justify:before {\n  content: \"\\f039\";\n}\n.fa-list:before {\n  content: \"\\f03a\";\n}\n.fa-dedent:before,\n.fa-outdent:before {\n  content: \"\\f03b\";\n}\n.fa-indent:before {\n  content: \"\\f03c\";\n}\n.fa-video-camera:before {\n  content: \"\\f03d\";\n}\n.fa-photo:before,\n.fa-image:before,\n.fa-picture-o:before {\n  content: \"\\f03e\";\n}\n.fa-pencil:before {\n  content: \"\\f040\";\n}\n.fa-map-marker:before {\n  content: \"\\f041\";\n}\n.fa-adjust:before {\n  content: \"\\f042\";\n}\n.fa-tint:before {\n  content: \"\\f043\";\n}\n.fa-edit:before,\n.fa-pencil-square-o:before {\n  content: \"\\f044\";\n}\n.fa-share-square-o:before {\n  content: \"\\f045\";\n}\n.fa-check-square-o:before {\n  content: \"\\f046\";\n}\n.fa-arrows:before {\n  content: \"\\f047\";\n}\n.fa-step-backward:before {\n  content: \"\\f048\";\n}\n.fa-fast-backward:before {\n  content: \"\\f049\";\n}\n.fa-backward:before {\n  content: \"\\f04a\";\n}\n.fa-play:before {\n  content: \"\\f04b\";\n}\n.fa-pause:before {\n  content: \"\\f04c\";\n}\n.fa-stop:before {\n  content: \"\\f04d\";\n}\n.fa-forward:before {\n  content: \"\\f04e\";\n}\n.fa-fast-forward:before {\n  content: \"\\f050\";\n}\n.fa-step-forward:before {\n  content: \"\\f051\";\n}\n.fa-eject:before {\n  content: \"\\f052\";\n}\n.fa-chevron-left:before {\n  content: \"\\f053\";\n}\n.fa-chevron-right:before {\n  content: \"\\f054\";\n}\n.fa-plus-circle:before {\n  content: \"\\f055\";\n}\n.fa-minus-circle:before {\n  content: \"\\f056\";\n}\n.fa-times-circle:before {\n  content: \"\\f057\";\n}\n.fa-check-circle:before {\n  content: \"\\f058\";\n}\n.fa-question-circle:before {\n  content: \"\\f059\";\n}\n.fa-info-circle:before {\n  content: \"\\f05a\";\n}\n.fa-crosshairs:before {\n  content: \"\\f05b\";\n}\n.fa-times-circle-o:before {\n  content: \"\\f05c\";\n}\n.fa-check-circle-o:before {\n  content: \"\\f05d\";\n}\n.fa-ban:before {\n  content: \"\\f05e\";\n}\n.fa-arrow-left:before {\n  content: \"\\f060\";\n}\n.fa-arrow-right:before {\n  content: \"\\f061\";\n}\n.fa-arrow-up:before {\n  content: \"\\f062\";\n}\n.fa-arrow-down:before {\n  content: \"\\f063\";\n}\n.fa-mail-forward:before,\n.fa-share:before {\n  content: \"\\f064\";\n}\n.fa-expand:before {\n  content: \"\\f065\";\n}\n.fa-compress:before {\n  content: \"\\f066\";\n}\n.fa-plus:before {\n  content: \"\\f067\";\n}\n.fa-minus:before {\n  content: \"\\f068\";\n}\n.fa-asterisk:before {\n  content: \"\\f069\";\n}\n.fa-exclamation-circle:before {\n  content: \"\\f06a\";\n}\n.fa-gift:before {\n  content: \"\\f06b\";\n}\n.fa-leaf:before {\n  content: \"\\f06c\";\n}\n.fa-fire:before {\n  content: \"\\f06d\";\n}\n.fa-eye:before {\n  content: \"\\f06e\";\n}\n.fa-eye-slash:before {\n  content: \"\\f070\";\n}\n.fa-warning:before,\n.fa-exclamation-triangle:before {\n  content: \"\\f071\";\n}\n.fa-plane:before {\n  content: \"\\f072\";\n}\n.fa-calendar:before {\n  content: \"\\f073\";\n}\n.fa-random:before {\n  content: \"\\f074\";\n}\n.fa-comment:before {\n  content: \"\\f075\";\n}\n.fa-magnet:before {\n  content: \"\\f076\";\n}\n.fa-chevron-up:before {\n  content: \"\\f077\";\n}\n.fa-chevron-down:before {\n  content: \"\\f078\";\n}\n.fa-retweet:before {\n  content: \"\\f079\";\n}\n.fa-shopping-cart:before {\n  content: \"\\f07a\";\n}\n.fa-folder:before {\n  content: \"\\f07b\";\n}\n.fa-folder-open:before {\n  content: \"\\f07c\";\n}\n.fa-arrows-v:before {\n  content: \"\\f07d\";\n}\n.fa-arrows-h:before {\n  content: \"\\f07e\";\n}\n.fa-bar-chart-o:before,\n.fa-bar-chart:before {\n  content: \"\\f080\";\n}\n.fa-twitter-square:before {\n  content: \"\\f081\";\n}\n.fa-facebook-square:before {\n  content: \"\\f082\";\n}\n.fa-camera-retro:before {\n  content: \"\\f083\";\n}\n.fa-key:before {\n  content: \"\\f084\";\n}\n.fa-gears:before,\n.fa-cogs:before {\n  content: \"\\f085\";\n}\n.fa-comments:before {\n  content: \"\\f086\";\n}\n.fa-thumbs-o-up:before {\n  content: \"\\f087\";\n}\n.fa-thumbs-o-down:before {\n  content: \"\\f088\";\n}\n.fa-star-half:before {\n  content: \"\\f089\";\n}\n.fa-heart-o:before {\n  content: \"\\f08a\";\n}\n.fa-sign-out:before {\n  content: \"\\f08b\";\n}\n.fa-linkedin-square:before {\n  content: \"\\f08c\";\n}\n.fa-thumb-tack:before {\n  content: \"\\f08d\";\n}\n.fa-external-link:before {\n  content: \"\\f08e\";\n}\n.fa-sign-in:before {\n  content: \"\\f090\";\n}\n.fa-trophy:before {\n  content: \"\\f091\";\n}\n.fa-github-square:before {\n  content: \"\\f092\";\n}\n.fa-upload:before {\n  content: \"\\f093\";\n}\n.fa-lemon-o:before {\n  content: \"\\f094\";\n}\n.fa-phone:before {\n  content: \"\\f095\";\n}\n.fa-square-o:before {\n  content: \"\\f096\";\n}\n.fa-bookmark-o:before {\n  content: \"\\f097\";\n}\n.fa-phone-square:before {\n  content: \"\\f098\";\n}\n.fa-twitter:before {\n  content: \"\\f099\";\n}\n.fa-facebook-f:before,\n.fa-facebook:before {\n  content: \"\\f09a\";\n}\n.fa-github:before {\n  content: \"\\f09b\";\n}\n.fa-unlock:before {\n  content: \"\\f09c\";\n}\n.fa-credit-card:before {\n  content: \"\\f09d\";\n}\n.fa-rss:before {\n  content: \"\\f09e\";\n}\n.fa-hdd-o:before {\n  content: \"\\f0a0\";\n}\n.fa-bullhorn:before {\n  content: \"\\f0a1\";\n}\n.fa-bell:before {\n  content: \"\\f0f3\";\n}\n.fa-certificate:before {\n  content: \"\\f0a3\";\n}\n.fa-hand-o-right:before {\n  content: \"\\f0a4\";\n}\n.fa-hand-o-left:before {\n  content: \"\\f0a5\";\n}\n.fa-hand-o-up:before {\n  content: \"\\f0a6\";\n}\n.fa-hand-o-down:before {\n  content: \"\\f0a7\";\n}\n.fa-arrow-circle-left:before {\n  content: \"\\f0a8\";\n}\n.fa-arrow-circle-right:before {\n  content: \"\\f0a9\";\n}\n.fa-arrow-circle-up:before {\n  content: \"\\f0aa\";\n}\n.fa-arrow-circle-down:before {\n  content: \"\\f0ab\";\n}\n.fa-globe:before {\n  content: \"\\f0ac\";\n}\n.fa-wrench:before {\n  content: \"\\f0ad\";\n}\n.fa-tasks:before {\n  content: \"\\f0ae\";\n}\n.fa-filter:before {\n  content: \"\\f0b0\";\n}\n.fa-briefcase:before {\n  content: \"\\f0b1\";\n}\n.fa-arrows-alt:before {\n  content: \"\\f0b2\";\n}\n.fa-group:before,\n.fa-users:before {\n  content: \"\\f0c0\";\n}\n.fa-chain:before,\n.fa-link:before {\n  content: \"\\f0c1\";\n}\n.fa-cloud:before {\n  content: \"\\f0c2\";\n}\n.fa-flask:before {\n  content: \"\\f0c3\";\n}\n.fa-cut:before,\n.fa-scissors:before {\n  content: \"\\f0c4\";\n}\n.fa-copy:before,\n.fa-files-o:before {\n  content: \"\\f0c5\";\n}\n.fa-paperclip:before {\n  content: \"\\f0c6\";\n}\n.fa-save:before,\n.fa-floppy-o:before {\n  content: \"\\f0c7\";\n}\n.fa-square:before {\n  content: \"\\f0c8\";\n}\n.fa-navicon:before,\n.fa-reorder:before,\n.fa-bars:before {\n  content: \"\\f0c9\";\n}\n.fa-list-ul:before {\n  content: \"\\f0ca\";\n}\n.fa-list-ol:before {\n  content: \"\\f0cb\";\n}\n.fa-strikethrough:before {\n  content: \"\\f0cc\";\n}\n.fa-underline:before {\n  content: \"\\f0cd\";\n}\n.fa-table:before {\n  content: \"\\f0ce\";\n}\n.fa-magic:before {\n  content: \"\\f0d0\";\n}\n.fa-truck:before {\n  content: \"\\f0d1\";\n}\n.fa-pinterest:before {\n  content: \"\\f0d2\";\n}\n.fa-pinterest-square:before {\n  content: \"\\f0d3\";\n}\n.fa-google-plus-square:before {\n  content: \"\\f0d4\";\n}\n.fa-google-plus:before {\n  content: \"\\f0d5\";\n}\n.fa-money:before {\n  content: \"\\f0d6\";\n}\n.fa-caret-down:before {\n  content: \"\\f0d7\";\n}\n.fa-caret-up:before {\n  content: \"\\f0d8\";\n}\n.fa-caret-left:before {\n  content: \"\\f0d9\";\n}\n.fa-caret-right:before {\n  content: \"\\f0da\";\n}\n.fa-columns:before {\n  content: \"\\f0db\";\n}\n.fa-unsorted:before,\n.fa-sort:before {\n  content: \"\\f0dc\";\n}\n.fa-sort-down:before,\n.fa-sort-desc:before {\n  content: \"\\f0dd\";\n}\n.fa-sort-up:before,\n.fa-sort-asc:before {\n  content: \"\\f0de\";\n}\n.fa-envelope:before {\n  content: \"\\f0e0\";\n}\n.fa-linkedin:before {\n  content: \"\\f0e1\";\n}\n.fa-rotate-left:before,\n.fa-undo:before {\n  content: \"\\f0e2\";\n}\n.fa-legal:before,\n.fa-gavel:before {\n  content: \"\\f0e3\";\n}\n.fa-dashboard:before,\n.fa-tachometer:before {\n  content: \"\\f0e4\";\n}\n.fa-comment-o:before {\n  content: \"\\f0e5\";\n}\n.fa-comments-o:before {\n  content: \"\\f0e6\";\n}\n.fa-flash:before,\n.fa-bolt:before {\n  content: \"\\f0e7\";\n}\n.fa-sitemap:before {\n  content: \"\\f0e8\";\n}\n.fa-umbrella:before {\n  content: \"\\f0e9\";\n}\n.fa-paste:before,\n.fa-clipboard:before {\n  content: \"\\f0ea\";\n}\n.fa-lightbulb-o:before {\n  content: \"\\f0eb\";\n}\n.fa-exchange:before {\n  content: \"\\f0ec\";\n}\n.fa-cloud-download:before {\n  content: \"\\f0ed\";\n}\n.fa-cloud-upload:before {\n  content: \"\\f0ee\";\n}\n.fa-user-md:before {\n  content: \"\\f0f0\";\n}\n.fa-stethoscope:before {\n  content: \"\\f0f1\";\n}\n.fa-suitcase:before {\n  content: \"\\f0f2\";\n}\n.fa-bell-o:before {\n  content: \"\\f0a2\";\n}\n.fa-coffee:before {\n  content: \"\\f0f4\";\n}\n.fa-cutlery:before {\n  content: \"\\f0f5\";\n}\n.fa-file-text-o:before {\n  content: \"\\f0f6\";\n}\n.fa-building-o:before {\n  content: \"\\f0f7\";\n}\n.fa-hospital-o:before {\n  content: \"\\f0f8\";\n}\n.fa-ambulance:before {\n  content: \"\\f0f9\";\n}\n.fa-medkit:before {\n  content: \"\\f0fa\";\n}\n.fa-fighter-jet:before {\n  content: \"\\f0fb\";\n}\n.fa-beer:before {\n  content: \"\\f0fc\";\n}\n.fa-h-square:before {\n  content: \"\\f0fd\";\n}\n.fa-plus-square:before {\n  content: \"\\f0fe\";\n}\n.fa-angle-double-left:before {\n  content: \"\\f100\";\n}\n.fa-angle-double-right:before {\n  content: \"\\f101\";\n}\n.fa-angle-double-up:before {\n  content: \"\\f102\";\n}\n.fa-angle-double-down:before {\n  content: \"\\f103\";\n}\n.fa-angle-left:before {\n  content: \"\\f104\";\n}\n.fa-angle-right:before {\n  content: \"\\f105\";\n}\n.fa-angle-up:before {\n  content: \"\\f106\";\n}\n.fa-angle-down:before {\n  content: \"\\f107\";\n}\n.fa-desktop:before {\n  content: \"\\f108\";\n}\n.fa-laptop:before {\n  content: \"\\f109\";\n}\n.fa-tablet:before {\n  content: \"\\f10a\";\n}\n.fa-mobile-phone:before,\n.fa-mobile:before {\n  content: \"\\f10b\";\n}\n.fa-circle-o:before {\n  content: \"\\f10c\";\n}\n.fa-quote-left:before {\n  content: \"\\f10d\";\n}\n.fa-quote-right:before {\n  content: \"\\f10e\";\n}\n.fa-spinner:before {\n  content: \"\\f110\";\n}\n.fa-circle:before {\n  content: \"\\f111\";\n}\n.fa-mail-reply:before,\n.fa-reply:before {\n  content: \"\\f112\";\n}\n.fa-github-alt:before {\n  content: \"\\f113\";\n}\n.fa-folder-o:before {\n  content: \"\\f114\";\n}\n.fa-folder-open-o:before {\n  content: \"\\f115\";\n}\n.fa-smile-o:before {\n  content: \"\\f118\";\n}\n.fa-frown-o:before {\n  content: \"\\f119\";\n}\n.fa-meh-o:before {\n  content: \"\\f11a\";\n}\n.fa-gamepad:before {\n  content: \"\\f11b\";\n}\n.fa-keyboard-o:before {\n  content: \"\\f11c\";\n}\n.fa-flag-o:before {\n  content: \"\\f11d\";\n}\n.fa-flag-checkered:before {\n  content: \"\\f11e\";\n}\n.fa-terminal:before {\n  content: \"\\f120\";\n}\n.fa-code:before {\n  content: \"\\f121\";\n}\n.fa-mail-reply-all:before,\n.fa-reply-all:before {\n  content: \"\\f122\";\n}\n.fa-star-half-empty:before,\n.fa-star-half-full:before,\n.fa-star-half-o:before {\n  content: \"\\f123\";\n}\n.fa-location-arrow:before {\n  content: \"\\f124\";\n}\n.fa-crop:before {\n  content: \"\\f125\";\n}\n.fa-code-fork:before {\n  content: \"\\f126\";\n}\n.fa-unlink:before,\n.fa-chain-broken:before {\n  content: \"\\f127\";\n}\n.fa-question:before {\n  content: \"\\f128\";\n}\n.fa-info:before {\n  content: \"\\f129\";\n}\n.fa-exclamation:before {\n  content: \"\\f12a\";\n}\n.fa-superscript:before {\n  content: \"\\f12b\";\n}\n.fa-subscript:before {\n  content: \"\\f12c\";\n}\n.fa-eraser:before {\n  content: \"\\f12d\";\n}\n.fa-puzzle-piece:before {\n  content: \"\\f12e\";\n}\n.fa-microphone:before {\n  content: \"\\f130\";\n}\n.fa-microphone-slash:before {\n  content: \"\\f131\";\n}\n.fa-shield:before {\n  content: \"\\f132\";\n}\n.fa-calendar-o:before {\n  content: \"\\f133\";\n}\n.fa-fire-extinguisher:before {\n  content: \"\\f134\";\n}\n.fa-rocket:before {\n  content: \"\\f135\";\n}\n.fa-maxcdn:before {\n  content: \"\\f136\";\n}\n.fa-chevron-circle-left:before {\n  content: \"\\f137\";\n}\n.fa-chevron-circle-right:before {\n  content: \"\\f138\";\n}\n.fa-chevron-circle-up:before {\n  content: \"\\f139\";\n}\n.fa-chevron-circle-down:before {\n  content: \"\\f13a\";\n}\n.fa-html5:before {\n  content: \"\\f13b\";\n}\n.fa-css3:before {\n  content: \"\\f13c\";\n}\n.fa-anchor:before {\n  content: \"\\f13d\";\n}\n.fa-unlock-alt:before {\n  content: \"\\f13e\";\n}\n.fa-bullseye:before {\n  content: \"\\f140\";\n}\n.fa-ellipsis-h:before {\n  content: \"\\f141\";\n}\n.fa-ellipsis-v:before {\n  content: \"\\f142\";\n}\n.fa-rss-square:before {\n  content: \"\\f143\";\n}\n.fa-play-circle:before {\n  content: \"\\f144\";\n}\n.fa-ticket:before {\n  content: \"\\f145\";\n}\n.fa-minus-square:before {\n  content: \"\\f146\";\n}\n.fa-minus-square-o:before {\n  content: \"\\f147\";\n}\n.fa-level-up:before {\n  content: \"\\f148\";\n}\n.fa-level-down:before {\n  content: \"\\f149\";\n}\n.fa-check-square:before {\n  content: \"\\f14a\";\n}\n.fa-pencil-square:before {\n  content: \"\\f14b\";\n}\n.fa-external-link-square:before {\n  content: \"\\f14c\";\n}\n.fa-share-square:before {\n  content: \"\\f14d\";\n}\n.fa-compass:before {\n  content: \"\\f14e\";\n}\n.fa-toggle-down:before,\n.fa-caret-square-o-down:before {\n  content: \"\\f150\";\n}\n.fa-toggle-up:before,\n.fa-caret-square-o-up:before {\n  content: \"\\f151\";\n}\n.fa-toggle-right:before,\n.fa-caret-square-o-right:before {\n  content: \"\\f152\";\n}\n.fa-euro:before,\n.fa-eur:before {\n  content: \"\\f153\";\n}\n.fa-gbp:before {\n  content: \"\\f154\";\n}\n.fa-dollar:before,\n.fa-usd:before {\n  content: \"\\f155\";\n}\n.fa-rupee:before,\n.fa-inr:before {\n  content: \"\\f156\";\n}\n.fa-cny:before,\n.fa-rmb:before,\n.fa-yen:before,\n.fa-jpy:before {\n  content: \"\\f157\";\n}\n.fa-ruble:before,\n.fa-rouble:before,\n.fa-rub:before {\n  content: \"\\f158\";\n}\n.fa-won:before,\n.fa-krw:before {\n  content: \"\\f159\";\n}\n.fa-bitcoin:before,\n.fa-btc:before {\n  content: \"\\f15a\";\n}\n.fa-file:before {\n  content: \"\\f15b\";\n}\n.fa-file-text:before {\n  content: \"\\f15c\";\n}\n.fa-sort-alpha-asc:before {\n  content: \"\\f15d\";\n}\n.fa-sort-alpha-desc:before {\n  content: \"\\f15e\";\n}\n.fa-sort-amount-asc:before {\n  content: \"\\f160\";\n}\n.fa-sort-amount-desc:before {\n  content: \"\\f161\";\n}\n.fa-sort-numeric-asc:before {\n  content: \"\\f162\";\n}\n.fa-sort-numeric-desc:before {\n  content: \"\\f163\";\n}\n.fa-thumbs-up:before {\n  content: \"\\f164\";\n}\n.fa-thumbs-down:before {\n  content: \"\\f165\";\n}\n.fa-youtube-square:before {\n  content: \"\\f166\";\n}\n.fa-youtube:before {\n  content: \"\\f167\";\n}\n.fa-xing:before {\n  content: \"\\f168\";\n}\n.fa-xing-square:before {\n  content: \"\\f169\";\n}\n.fa-youtube-play:before {\n  content: \"\\f16a\";\n}\n.fa-dropbox:before {\n  content: \"\\f16b\";\n}\n.fa-stack-overflow:before {\n  content: \"\\f16c\";\n}\n.fa-instagram:before {\n  content: \"\\f16d\";\n}\n.fa-flickr:before {\n  content: \"\\f16e\";\n}\n.fa-adn:before {\n  content: \"\\f170\";\n}\n.fa-bitbucket:before {\n  content: \"\\f171\";\n}\n.fa-bitbucket-square:before {\n  content: \"\\f172\";\n}\n.fa-tumblr:before {\n  content: \"\\f173\";\n}\n.fa-tumblr-square:before {\n  content: \"\\f174\";\n}\n.fa-long-arrow-down:before {\n  content: \"\\f175\";\n}\n.fa-long-arrow-up:before {\n  content: \"\\f176\";\n}\n.fa-long-arrow-left:before {\n  content: \"\\f177\";\n}\n.fa-long-arrow-right:before {\n  content: \"\\f178\";\n}\n.fa-apple:before {\n  content: \"\\f179\";\n}\n.fa-windows:before {\n  content: \"\\f17a\";\n}\n.fa-android:before {\n  content: \"\\f17b\";\n}\n.fa-linux:before {\n  content: \"\\f17c\";\n}\n.fa-dribbble:before {\n  content: \"\\f17d\";\n}\n.fa-skype:before {\n  content: \"\\f17e\";\n}\n.fa-foursquare:before {\n  content: \"\\f180\";\n}\n.fa-trello:before {\n  content: \"\\f181\";\n}\n.fa-female:before {\n  content: \"\\f182\";\n}\n.fa-male:before {\n  content: \"\\f183\";\n}\n.fa-gittip:before,\n.fa-gratipay:before {\n  content: \"\\f184\";\n}\n.fa-sun-o:before {\n  content: \"\\f185\";\n}\n.fa-moon-o:before {\n  content: \"\\f186\";\n}\n.fa-archive:before {\n  content: \"\\f187\";\n}\n.fa-bug:before {\n  content: \"\\f188\";\n}\n.fa-vk:before {\n  content: \"\\f189\";\n}\n.fa-weibo:before {\n  content: \"\\f18a\";\n}\n.fa-renren:before {\n  content: \"\\f18b\";\n}\n.fa-pagelines:before {\n  content: \"\\f18c\";\n}\n.fa-stack-exchange:before {\n  content: \"\\f18d\";\n}\n.fa-arrow-circle-o-right:before {\n  content: \"\\f18e\";\n}\n.fa-arrow-circle-o-left:before {\n  content: \"\\f190\";\n}\n.fa-toggle-left:before,\n.fa-caret-square-o-left:before {\n  content: \"\\f191\";\n}\n.fa-dot-circle-o:before {\n  content: \"\\f192\";\n}\n.fa-wheelchair:before {\n  content: \"\\f193\";\n}\n.fa-vimeo-square:before {\n  content: \"\\f194\";\n}\n.fa-turkish-lira:before,\n.fa-try:before {\n  content: \"\\f195\";\n}\n.fa-plus-square-o:before {\n  content: \"\\f196\";\n}\n.fa-space-shuttle:before {\n  content: \"\\f197\";\n}\n.fa-slack:before {\n  content: \"\\f198\";\n}\n.fa-envelope-square:before {\n  content: \"\\f199\";\n}\n.fa-wordpress:before {\n  content: \"\\f19a\";\n}\n.fa-openid:before {\n  content: \"\\f19b\";\n}\n.fa-institution:before,\n.fa-bank:before,\n.fa-university:before {\n  content: \"\\f19c\";\n}\n.fa-mortar-board:before,\n.fa-graduation-cap:before {\n  content: \"\\f19d\";\n}\n.fa-yahoo:before {\n  content: \"\\f19e\";\n}\n.fa-google:before {\n  content: \"\\f1a0\";\n}\n.fa-reddit:before {\n  content: \"\\f1a1\";\n}\n.fa-reddit-square:before {\n  content: \"\\f1a2\";\n}\n.fa-stumbleupon-circle:before {\n  content: \"\\f1a3\";\n}\n.fa-stumbleupon:before {\n  content: \"\\f1a4\";\n}\n.fa-delicious:before {\n  content: \"\\f1a5\";\n}\n.fa-digg:before {\n  content: \"\\f1a6\";\n}\n.fa-pied-piper:before {\n  content: \"\\f1a7\";\n}\n.fa-pied-piper-alt:before {\n  content: \"\\f1a8\";\n}\n.fa-drupal:before {\n  content: \"\\f1a9\";\n}\n.fa-joomla:before {\n  content: \"\\f1aa\";\n}\n.fa-language:before {\n  content: \"\\f1ab\";\n}\n.fa-fax:before {\n  content: \"\\f1ac\";\n}\n.fa-building:before {\n  content: \"\\f1ad\";\n}\n.fa-child:before {\n  content: \"\\f1ae\";\n}\n.fa-paw:before {\n  content: \"\\f1b0\";\n}\n.fa-spoon:before {\n  content: \"\\f1b1\";\n}\n.fa-cube:before {\n  content: \"\\f1b2\";\n}\n.fa-cubes:before {\n  content: \"\\f1b3\";\n}\n.fa-behance:before {\n  content: \"\\f1b4\";\n}\n.fa-behance-square:before {\n  content: \"\\f1b5\";\n}\n.fa-steam:before {\n  content: \"\\f1b6\";\n}\n.fa-steam-square:before {\n  content: \"\\f1b7\";\n}\n.fa-recycle:before {\n  content: \"\\f1b8\";\n}\n.fa-automobile:before,\n.fa-car:before {\n  content: \"\\f1b9\";\n}\n.fa-cab:before,\n.fa-taxi:before {\n  content: \"\\f1ba\";\n}\n.fa-tree:before {\n  content: \"\\f1bb\";\n}\n.fa-spotify:before {\n  content: \"\\f1bc\";\n}\n.fa-deviantart:before {\n  content: \"\\f1bd\";\n}\n.fa-soundcloud:before {\n  content: \"\\f1be\";\n}\n.fa-database:before {\n  content: \"\\f1c0\";\n}\n.fa-file-pdf-o:before {\n  content: \"\\f1c1\";\n}\n.fa-file-word-o:before {\n  content: \"\\f1c2\";\n}\n.fa-file-excel-o:before {\n  content: \"\\f1c3\";\n}\n.fa-file-powerpoint-o:before {\n  content: \"\\f1c4\";\n}\n.fa-file-photo-o:before,\n.fa-file-picture-o:before,\n.fa-file-image-o:before {\n  content: \"\\f1c5\";\n}\n.fa-file-zip-o:before,\n.fa-file-archive-o:before {\n  content: \"\\f1c6\";\n}\n.fa-file-sound-o:before,\n.fa-file-audio-o:before {\n  content: \"\\f1c7\";\n}\n.fa-file-movie-o:before,\n.fa-file-video-o:before {\n  content: \"\\f1c8\";\n}\n.fa-file-code-o:before {\n  content: \"\\f1c9\";\n}\n.fa-vine:before {\n  content: \"\\f1ca\";\n}\n.fa-codepen:before {\n  content: \"\\f1cb\";\n}\n.fa-jsfiddle:before {\n  content: \"\\f1cc\";\n}\n.fa-life-bouy:before,\n.fa-life-buoy:before,\n.fa-life-saver:before,\n.fa-support:before,\n.fa-life-ring:before {\n  content: \"\\f1cd\";\n}\n.fa-circle-o-notch:before {\n  content: \"\\f1ce\";\n}\n.fa-ra:before,\n.fa-rebel:before {\n  content: \"\\f1d0\";\n}\n.fa-ge:before,\n.fa-empire:before {\n  content: \"\\f1d1\";\n}\n.fa-git-square:before {\n  content: \"\\f1d2\";\n}\n.fa-git:before {\n  content: \"\\f1d3\";\n}\n.fa-hacker-news:before {\n  content: \"\\f1d4\";\n}\n.fa-tencent-weibo:before {\n  content: \"\\f1d5\";\n}\n.fa-qq:before {\n  content: \"\\f1d6\";\n}\n.fa-wechat:before,\n.fa-weixin:before {\n  content: \"\\f1d7\";\n}\n.fa-send:before,\n.fa-paper-plane:before {\n  content: \"\\f1d8\";\n}\n.fa-send-o:before,\n.fa-paper-plane-o:before {\n  content: \"\\f1d9\";\n}\n.fa-history:before {\n  content: \"\\f1da\";\n}\n.fa-genderless:before,\n.fa-circle-thin:before {\n  content: \"\\f1db\";\n}\n.fa-header:before {\n  content: \"\\f1dc\";\n}\n.fa-paragraph:before {\n  content: \"\\f1dd\";\n}\n.fa-sliders:before {\n  content: \"\\f1de\";\n}\n.fa-share-alt:before {\n  content: \"\\f1e0\";\n}\n.fa-share-alt-square:before {\n  content: \"\\f1e1\";\n}\n.fa-bomb:before {\n  content: \"\\f1e2\";\n}\n.fa-soccer-ball-o:before,\n.fa-futbol-o:before {\n  content: \"\\f1e3\";\n}\n.fa-tty:before {\n  content: \"\\f1e4\";\n}\n.fa-binoculars:before {\n  content: \"\\f1e5\";\n}\n.fa-plug:before {\n  content: \"\\f1e6\";\n}\n.fa-slideshare:before {\n  content: \"\\f1e7\";\n}\n.fa-twitch:before {\n  content: \"\\f1e8\";\n}\n.fa-yelp:before {\n  content: \"\\f1e9\";\n}\n.fa-newspaper-o:before {\n  content: \"\\f1ea\";\n}\n.fa-wifi:before {\n  content: \"\\f1eb\";\n}\n.fa-calculator:before {\n  content: \"\\f1ec\";\n}\n.fa-paypal:before {\n  content: \"\\f1ed\";\n}\n.fa-google-wallet:before {\n  content: \"\\f1ee\";\n}\n.fa-cc-visa:before {\n  content: \"\\f1f0\";\n}\n.fa-cc-mastercard:before {\n  content: \"\\f1f1\";\n}\n.fa-cc-discover:before {\n  content: \"\\f1f2\";\n}\n.fa-cc-amex:before {\n  content: \"\\f1f3\";\n}\n.fa-cc-paypal:before {\n  content: \"\\f1f4\";\n}\n.fa-cc-stripe:before {\n  content: \"\\f1f5\";\n}\n.fa-bell-slash:before {\n  content: \"\\f1f6\";\n}\n.fa-bell-slash-o:before {\n  content: \"\\f1f7\";\n}\n.fa-trash:before {\n  content: \"\\f1f8\";\n}\n.fa-copyright:before {\n  content: \"\\f1f9\";\n}\n.fa-at:before {\n  content: \"\\f1fa\";\n}\n.fa-eyedropper:before {\n  content: \"\\f1fb\";\n}\n.fa-paint-brush:before {\n  content: \"\\f1fc\";\n}\n.fa-birthday-cake:before {\n  content: \"\\f1fd\";\n}\n.fa-area-chart:before {\n  content: \"\\f1fe\";\n}\n.fa-pie-chart:before {\n  content: \"\\f200\";\n}\n.fa-line-chart:before {\n  content: \"\\f201\";\n}\n.fa-lastfm:before {\n  content: \"\\f202\";\n}\n.fa-lastfm-square:before {\n  content: \"\\f203\";\n}\n.fa-toggle-off:before {\n  content: \"\\f204\";\n}\n.fa-toggle-on:before {\n  content: \"\\f205\";\n}\n.fa-bicycle:before {\n  content: \"\\f206\";\n}\n.fa-bus:before {\n  content: \"\\f207\";\n}\n.fa-ioxhost:before {\n  content: \"\\f208\";\n}\n.fa-angellist:before {\n  content: \"\\f209\";\n}\n.fa-cc:before {\n  content: \"\\f20a\";\n}\n.fa-shekel:before,\n.fa-sheqel:before,\n.fa-ils:before {\n  content: \"\\f20b\";\n}\n.fa-meanpath:before {\n  content: \"\\f20c\";\n}\n.fa-buysellads:before {\n  content: \"\\f20d\";\n}\n.fa-connectdevelop:before {\n  content: \"\\f20e\";\n}\n.fa-dashcube:before {\n  content: \"\\f210\";\n}\n.fa-forumbee:before {\n  content: \"\\f211\";\n}\n.fa-leanpub:before {\n  content: \"\\f212\";\n}\n.fa-sellsy:before {\n  content: \"\\f213\";\n}\n.fa-shirtsinbulk:before {\n  content: \"\\f214\";\n}\n.fa-simplybuilt:before {\n  content: \"\\f215\";\n}\n.fa-skyatlas:before {\n  content: \"\\f216\";\n}\n.fa-cart-plus:before {\n  content: \"\\f217\";\n}\n.fa-cart-arrow-down:before {\n  content: \"\\f218\";\n}\n.fa-diamond:before {\n  content: \"\\f219\";\n}\n.fa-ship:before {\n  content: \"\\f21a\";\n}\n.fa-user-secret:before {\n  content: \"\\f21b\";\n}\n.fa-motorcycle:before {\n  content: \"\\f21c\";\n}\n.fa-street-view:before {\n  content: \"\\f21d\";\n}\n.fa-heartbeat:before {\n  content: \"\\f21e\";\n}\n.fa-venus:before {\n  content: \"\\f221\";\n}\n.fa-mars:before {\n  content: \"\\f222\";\n}\n.fa-mercury:before {\n  content: \"\\f223\";\n}\n.fa-transgender:before {\n  content: \"\\f224\";\n}\n.fa-transgender-alt:before {\n  content: \"\\f225\";\n}\n.fa-venus-double:before {\n  content: \"\\f226\";\n}\n.fa-mars-double:before {\n  content: \"\\f227\";\n}\n.fa-venus-mars:before {\n  content: \"\\f228\";\n}\n.fa-mars-stroke:before {\n  content: \"\\f229\";\n}\n.fa-mars-stroke-v:before {\n  content: \"\\f22a\";\n}\n.fa-mars-stroke-h:before {\n  content: \"\\f22b\";\n}\n.fa-neuter:before {\n  content: \"\\f22c\";\n}\n.fa-facebook-official:before {\n  content: \"\\f230\";\n}\n.fa-pinterest-p:before {\n  content: \"\\f231\";\n}\n.fa-whatsapp:before {\n  content: \"\\f232\";\n}\n.fa-server:before {\n  content: \"\\f233\";\n}\n.fa-user-plus:before {\n  content: \"\\f234\";\n}\n.fa-user-times:before {\n  content: \"\\f235\";\n}\n.fa-hotel:before,\n.fa-bed:before {\n  content: \"\\f236\";\n}\n.fa-viacoin:before {\n  content: \"\\f237\";\n}\n.fa-train:before {\n  content: \"\\f238\";\n}\n.fa-subway:before {\n  content: \"\\f239\";\n}\n.fa-medium:before {\n  content: \"\\f23a\";\n}\n","//\n// Scaffolding\n// --------------------------------------------------\n\n\n// Reset the box-sizing\n//\n// Heads up! This reset may cause conflicts with some third-party widgets.\n// For recommendations on resolving such conflicts, see\n// http://getbootstrap.com/getting-started/#third-box-sizing\n* {\n  .box-sizing(border-box);\n}\n*:before,\n*:after {\n  .box-sizing(border-box);\n}\n\n\n// Body reset\n\nhtml {\n  font-size: 10px;\n  -webkit-tap-highlight-color: rgba(0,0,0,0);\n}\n\nbody {\n  font-family: @font-family-base;\n  font-size: @font-size-base;\n  line-height: @line-height-base;\n  color: @text-color;\n  background-color: @body-bg;\n}\n\n// Reset fonts for relevant elements\ninput,\nbutton,\nselect,\ntextarea {\n  font-family: inherit;\n  font-size: inherit;\n  line-height: inherit;\n}\n\n\n// Links\n\na {\n  color: @link-color;\n  text-decoration: none;\n\n  &:hover,\n  &:focus {\n    color: @link-hover-color;\n    text-decoration: @link-hover-decoration;\n  }\n\n  &:focus {\n    .tab-focus();\n  }\n}\n\n\n// Figures\n//\n// We reset this here because previously Normalize had no `figure` margins. This\n// ensures we don't break anyone's use of the element.\n\nfigure {\n  margin: 0;\n}\n\n\n// Images\n\nimg {\n  vertical-align: middle;\n}\n\n// Responsive images (ensure images don't scale beyond their parents)\n.img-responsive {\n  .img-responsive();\n}\n\n// Rounded corners\n.img-rounded {\n  border-radius: @border-radius-large;\n}\n\n// Image thumbnails\n//\n// Heads up! This is mixin-ed into thumbnails.less for `.thumbnail`.\n.img-thumbnail {\n  padding: @thumbnail-padding;\n  line-height: @line-height-base;\n  background-color: @thumbnail-bg;\n  border: 1px solid @thumbnail-border;\n  border-radius: @thumbnail-border-radius;\n  .transition(all .2s ease-in-out);\n\n  // Keep them at most 100% wide\n  .img-responsive(inline-block);\n}\n\n// Perfect circle\n.img-circle {\n  border-radius: 50%; // set radius in percents\n}\n\n\n// Horizontal rules\n\nhr {\n  margin-top:    @line-height-computed;\n  margin-bottom: @line-height-computed;\n  border: 0;\n  border-top: 1px solid @hr-border;\n}\n\n\n// Only display content to screen readers\n//\n// See: http://a11yproject.com/posts/how-to-hide-content/\n\n.sr-only {\n  position: absolute;\n  width: 1px;\n  height: 1px;\n  margin: -1px;\n  padding: 0;\n  overflow: hidden;\n  clip: rect(0,0,0,0);\n  border: 0;\n}\n\n// Use in conjunction with .sr-only to only display content when it's focused.\n// Useful for \"Skip to main content\" links; see http://www.w3.org/TR/2013/NOTE-WCAG20-TECHS-20130905/G1\n// Credit: HTML5 Boilerplate\n\n.sr-only-focusable {\n  &:active,\n  &:focus {\n    position: static;\n    width: auto;\n    height: auto;\n    margin: 0;\n    overflow: visible;\n    clip: auto;\n  }\n}\n","// WebKit-style focus\n\n.tab-focus() {\n  // Default\n  outline: thin dotted;\n  // WebKit\n  outline: 5px auto -webkit-focus-ring-color;\n  outline-offset: -2px;\n}\n","// Image Mixins\n// - Responsive image\n// - Retina image\n\n\n// Responsive image\n//\n// Keep images from scaling beyond the width of their parents.\n.img-responsive(@display: block) {\n  display: @display;\n  max-width: 100%; // Part 1: Set a maximum relative to the parent\n  height: auto; // Part 2: Scale the height according to the width, otherwise you get stretching\n}\n\n\n// Retina image\n//\n// Short retina mixin for setting background-image and -size. Note that the\n// spelling of `min--moz-device-pixel-ratio` is intentional.\n.img-retina(@file-1x; @file-2x; @width-1x; @height-1x) {\n  background-image: url(\"@{file-1x}\");\n\n  @media\n  only screen and (-webkit-min-device-pixel-ratio: 2),\n  only screen and (   min--moz-device-pixel-ratio: 2),\n  only screen and (     -o-min-device-pixel-ratio: 2/1),\n  only screen and (        min-device-pixel-ratio: 2),\n  only screen and (                min-resolution: 192dpi),\n  only screen and (                min-resolution: 2dppx) {\n    background-image: url(\"@{file-2x}\");\n    background-size: @width-1x @height-1x;\n  }\n}\n","// Grid system\n//\n// Generate semantic grid columns with these mixins.\n\n// Centered container element\n.container-fixed(@gutter: @grid-gutter-width) {\n  margin-right: auto;\n  margin-left: auto;\n  padding-left:  (@gutter / 2);\n  padding-right: (@gutter / 2);\n  &:extend(.clearfix all);\n}\n\n// Creates a wrapper for a series of columns\n.make-row(@gutter: @grid-gutter-width) {\n  margin-left:  (@gutter / -2);\n  margin-right: (@gutter / -2);\n  &:extend(.clearfix all);\n}\n\n// Generate the extra small columns\n.make-xs-column(@columns; @gutter: @grid-gutter-width) {\n  position: relative;\n  float: left;\n  width: percentage((@columns / @grid-columns));\n  min-height: 1px;\n  padding-left:  (@gutter / 2);\n  padding-right: (@gutter / 2);\n}\n.make-xs-column-offset(@columns) {\n  margin-left: percentage((@columns / @grid-columns));\n}\n.make-xs-column-push(@columns) {\n  left: percentage((@columns / @grid-columns));\n}\n.make-xs-column-pull(@columns) {\n  right: percentage((@columns / @grid-columns));\n}\n\n// Generate the small columns\n.make-sm-column(@columns; @gutter: @grid-gutter-width) {\n  position: relative;\n  min-height: 1px;\n  padding-left:  (@gutter / 2);\n  padding-right: (@gutter / 2);\n\n  @media (min-width: @screen-sm-min) {\n    float: left;\n    width: percentage((@columns / @grid-columns));\n  }\n}\n.make-sm-column-offset(@columns) {\n  @media (min-width: @screen-sm-min) {\n    margin-left: percentage((@columns / @grid-columns));\n  }\n}\n.make-sm-column-push(@columns) {\n  @media (min-width: @screen-sm-min) {\n    left: percentage((@columns / @grid-columns));\n  }\n}\n.make-sm-column-pull(@columns) {\n  @media (min-width: @screen-sm-min) {\n    right: percentage((@columns / @grid-columns));\n  }\n}\n\n// Generate the medium columns\n.make-md-column(@columns; @gutter: @grid-gutter-width) {\n  position: relative;\n  min-height: 1px;\n  padding-left:  (@gutter / 2);\n  padding-right: (@gutter / 2);\n\n  @media (min-width: @screen-md-min) {\n    float: left;\n    width: percentage((@columns / @grid-columns));\n  }\n}\n.make-md-column-offset(@columns) {\n  @media (min-width: @screen-md-min) {\n    margin-left: percentage((@columns / @grid-columns));\n  }\n}\n.make-md-column-push(@columns) {\n  @media (min-width: @screen-md-min) {\n    left: percentage((@columns / @grid-columns));\n  }\n}\n.make-md-column-pull(@columns) {\n  @media (min-width: @screen-md-min) {\n    right: percentage((@columns / @grid-columns));\n  }\n}\n\n// Generate the large columns\n.make-lg-column(@columns; @gutter: @grid-gutter-width) {\n  position: relative;\n  min-height: 1px;\n  padding-left:  (@gutter / 2);\n  padding-right: (@gutter / 2);\n\n  @media (min-width: @screen-lg-min) {\n    float: left;\n    width: percentage((@columns / @grid-columns));\n  }\n}\n.make-lg-column-offset(@columns) {\n  @media (min-width: @screen-lg-min) {\n    margin-left: percentage((@columns / @grid-columns));\n  }\n}\n.make-lg-column-push(@columns) {\n  @media (min-width: @screen-lg-min) {\n    left: percentage((@columns / @grid-columns));\n  }\n}\n.make-lg-column-pull(@columns) {\n  @media (min-width: @screen-lg-min) {\n    right: percentage((@columns / @grid-columns));\n  }\n}\n","//\n// Grid system\n// --------------------------------------------------\n\n\n// Container widths\n//\n// Set the container width, and override it for fixed navbars in media queries.\n\n.container {\n  .container-fixed();\n\n  @media (min-width: @screen-sm-min) {\n    width: @container-sm;\n  }\n  @media (min-width: @screen-md-min) {\n    width: @container-md;\n  }\n  @media (min-width: @screen-lg-min) {\n    width: @container-lg;\n  }\n}\n\n\n// Fluid container\n//\n// Utilizes the mixin meant for fixed width containers, but without any defined\n// width for fluid, full width layouts.\n\n.container-fluid {\n  .container-fixed();\n}\n\n\n// Row\n//\n// Rows contain and clear the floats of your columns.\n\n.row {\n  .make-row();\n}\n\n\n// Columns\n//\n// Common styles for small and large grid columns\n\n.make-grid-columns();\n\n\n// Extra small grid\n//\n// Columns, offsets, pushes, and pulls for extra small devices like\n// smartphones.\n\n.make-grid(xs);\n\n\n// Small grid\n//\n// Columns, offsets, pushes, and pulls for the small device range, from phones\n// to tablets.\n\n@media (min-width: @screen-sm-min) {\n  .make-grid(sm);\n}\n\n\n// Medium grid\n//\n// Columns, offsets, pushes, and pulls for the desktop device range.\n\n@media (min-width: @screen-md-min) {\n  .make-grid(md);\n}\n\n\n// Large grid\n//\n// Columns, offsets, pushes, and pulls for the large desktop device range.\n\n@media (min-width: @screen-lg-min) {\n  .make-grid(lg);\n}\n","// Framework grid generation\n//\n// Used only by Bootstrap to generate the correct number of grid classes given\n// any value of `@grid-columns`.\n\n.make-grid-columns() {\n  // Common styles for all sizes of grid columns, widths 1-12\n  .col(@index) { // initial\n    @item: ~\".col-xs-@{index}, .col-sm-@{index}, .col-md-@{index}, .col-lg-@{index}\";\n    .col((@index + 1), @item);\n  }\n  .col(@index, @list) when (@index =< @grid-columns) { // general; \"=<\" isn't a typo\n    @item: ~\".col-xs-@{index}, .col-sm-@{index}, .col-md-@{index}, .col-lg-@{index}\";\n    .col((@index + 1), ~\"@{list}, @{item}\");\n  }\n  .col(@index, @list) when (@index > @grid-columns) { // terminal\n    @{list} {\n      position: relative;\n      // Prevent columns from collapsing when empty\n      min-height: 1px;\n      // Inner gutter via padding\n      padding-left:  (@grid-gutter-width / 2);\n      padding-right: (@grid-gutter-width / 2);\n    }\n  }\n  .col(1); // kickstart it\n}\n\n.float-grid-columns(@class) {\n  .col(@index) { // initial\n    @item: ~\".col-@{class}-@{index}\";\n    .col((@index + 1), @item);\n  }\n  .col(@index, @list) when (@index =< @grid-columns) { // general\n    @item: ~\".col-@{class}-@{index}\";\n    .col((@index + 1), ~\"@{list}, @{item}\");\n  }\n  .col(@index, @list) when (@index > @grid-columns) { // terminal\n    @{list} {\n      float: left;\n    }\n  }\n  .col(1); // kickstart it\n}\n\n.calc-grid-column(@index, @class, @type) when (@type = width) and (@index > 0) {\n  .col-@{class}-@{index} {\n    width: percentage((@index / @grid-columns));\n  }\n}\n.calc-grid-column(@index, @class, @type) when (@type = push) and (@index > 0) {\n  .col-@{class}-push-@{index} {\n    left: percentage((@index / @grid-columns));\n  }\n}\n.calc-grid-column(@index, @class, @type) when (@type = push) and (@index = 0) {\n  .col-@{class}-push-0 {\n    left: auto;\n  }\n}\n.calc-grid-column(@index, @class, @type) when (@type = pull) and (@index > 0) {\n  .col-@{class}-pull-@{index} {\n    right: percentage((@index / @grid-columns));\n  }\n}\n.calc-grid-column(@index, @class, @type) when (@type = pull) and (@index = 0) {\n  .col-@{class}-pull-0 {\n    right: auto;\n  }\n}\n.calc-grid-column(@index, @class, @type) when (@type = offset) {\n  .col-@{class}-offset-@{index} {\n    margin-left: percentage((@index / @grid-columns));\n  }\n}\n\n// Basic looping in LESS\n.loop-grid-columns(@index, @class, @type) when (@index >= 0) {\n  .calc-grid-column(@index, @class, @type);\n  // next iteration\n  .loop-grid-columns((@index - 1), @class, @type);\n}\n\n// Create grid for specific class\n.make-grid(@class) {\n  .float-grid-columns(@class);\n  .loop-grid-columns(@grid-columns, @class, width);\n  .loop-grid-columns(@grid-columns, @class, pull);\n  .loop-grid-columns(@grid-columns, @class, push);\n  .loop-grid-columns(@grid-columns, @class, offset);\n}\n","// Clearfix\n//\n// For modern browsers\n// 1. The space content is one way to avoid an Opera bug when the\n//    contenteditable attribute is included anywhere else in the document.\n//    Otherwise it causes space to appear at the top and bottom of elements\n//    that are clearfixed.\n// 2. The use of `table` rather than `block` is only necessary if using\n//    `:before` to contain the top-margins of child elements.\n//\n// Source: http://nicolasgallagher.com/micro-clearfix-hack/\n\n.clearfix() {\n  &:before,\n  &:after {\n    content: \" \"; // 1\n    display: table; // 2\n  }\n  &:after {\n    clear: both;\n  }\n}\n","//\n// Utility classes\n// --------------------------------------------------\n\n\n// Floats\n// -------------------------\n\n.clearfix {\n  .clearfix();\n}\n.center-block {\n  .center-block();\n}\n.pull-right {\n  float: right !important;\n}\n.pull-left {\n  float: left !important;\n}\n\n\n// Toggling content\n// -------------------------\n\n// Note: Deprecated .hide in favor of .hidden or .sr-only (as appropriate) in v3.0.1\n.hide {\n  display: none !important;\n}\n.show {\n  display: block !important;\n}\n.invisible {\n  visibility: hidden;\n}\n.text-hide {\n  .text-hide();\n}\n\n\n// Hide from screenreaders and browsers\n//\n// Credit: HTML5 Boilerplate\n\n.hidden {\n  display: none !important;\n  visibility: hidden !important;\n}\n\n\n// For Affix plugin\n// -------------------------\n\n.affix {\n  position: fixed;\n}\n","// Center-align a block level element\n\n.center-block() {\n  display: block;\n  margin-left: auto;\n  margin-right: auto;\n}\n","// CSS image replacement\n//\n// Heads up! v3 launched with with only `.hide-text()`, but per our pattern for\n// mixins being reused as classes with the same name, this doesn't hold up. As\n// of v3.0.1 we have added `.text-hide()` and deprecated `.hide-text()`.\n//\n// Source: https://github.com/h5bp/html5-boilerplate/commit/aa0396eae757\n\n// Deprecated as of v3.0.1 (will be removed in v4)\n.hide-text() {\n  font: ~\"0/0\" a;\n  color: transparent;\n  text-shadow: none;\n  background-color: transparent;\n  border: 0;\n}\n\n// New mixin to use as of v3.0.1\n.text-hide() {\n  .hide-text();\n}\n","/* FONT PATH\n * -------------------------- */\n\n@font-face {\n  font-family: 'FontAwesome';\n  src: url('@{fa-font-path}/fontawesome-webfont.eot?v=@{fa-version}');\n  src: url('@{fa-font-path}/fontawesome-webfont.eot?#iefix&v=@{fa-version}') format('embedded-opentype'),\n    url('@{fa-font-path}/fontawesome-webfont.woff2?v=@{fa-version}') format('woff2'),\n    url('@{fa-font-path}/fontawesome-webfont.woff?v=@{fa-version}') format('woff'),\n    url('@{fa-font-path}/fontawesome-webfont.ttf?v=@{fa-version}') format('truetype'),\n    url('@{fa-font-path}/fontawesome-webfont.svg?v=@{fa-version}#fontawesomeregular') format('svg');\n//  src: url('@{fa-font-path}/FontAwesome.otf') format('opentype'); // used when developing fonts\n  font-weight: normal;\n  font-style: normal;\n}\n","// Base Class Definition\n// -------------------------\n\n.@{fa-css-prefix} {\n  display: inline-block;\n  font: normal normal normal @fa-font-size-base/1 FontAwesome; // shortening font declaration\n  font-size: inherit; // can't have font-size inherit on line above, so need to override\n  text-rendering: auto; // optimizelegibility throws things off #1094\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n  transform: translate(0, 0); // ensures no half-pixel rendering in firefox\n\n}\n","// Icon Sizes\n// -------------------------\n\n/* makes the font 33% larger relative to the icon container */\n.@{fa-css-prefix}-lg {\n  font-size: (4em / 3);\n  line-height: (3em / 4);\n  vertical-align: -15%;\n}\n.@{fa-css-prefix}-2x { font-size: 2em; }\n.@{fa-css-prefix}-3x { font-size: 3em; }\n.@{fa-css-prefix}-4x { font-size: 4em; }\n.@{fa-css-prefix}-5x { font-size: 5em; }\n","// Fixed Width Icons\n// -------------------------\n.@{fa-css-prefix}-fw {\n  width: (18em / 14);\n  text-align: center;\n}\n","// List Icons\n// -------------------------\n\n.@{fa-css-prefix}-ul {\n  padding-left: 0;\n  margin-left: @fa-li-width;\n  list-style-type: none;\n  > li { position: relative; }\n}\n.@{fa-css-prefix}-li {\n  position: absolute;\n  left: -@fa-li-width;\n  width: @fa-li-width;\n  top: (2em / 14);\n  text-align: center;\n  &.@{fa-css-prefix}-lg {\n    left: (-@fa-li-width + (4em / 14));\n  }\n}\n","// Bordered & Pulled\n// -------------------------\n\n.@{fa-css-prefix}-border {\n  padding: .2em .25em .15em;\n  border: solid .08em @fa-border-color;\n  border-radius: .1em;\n}\n\n.pull-right { float: right; }\n.pull-left { float: left; }\n\n.@{fa-css-prefix} {\n  &.pull-left { margin-right: .3em; }\n  &.pull-right { margin-left: .3em; }\n}\n","// Animated Icons\n// --------------------------\n\n.@{fa-css-prefix}-spin {\n  -webkit-animation: fa-spin 2s infinite linear;\n          animation: fa-spin 2s infinite linear;\n}\n\n.@{fa-css-prefix}-pulse {\n  -webkit-animation: fa-spin 1s infinite steps(8);\n          animation: fa-spin 1s infinite steps(8);\n}\n\n@-webkit-keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n            transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n            transform: rotate(359deg);\n  }\n}\n\n@keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n            transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n            transform: rotate(359deg);\n  }\n}\n","// Rotated & Flipped Icons\n// -------------------------\n\n.@{fa-css-prefix}-rotate-90  { .fa-icon-rotate(90deg, 1);  }\n.@{fa-css-prefix}-rotate-180 { .fa-icon-rotate(180deg, 2); }\n.@{fa-css-prefix}-rotate-270 { .fa-icon-rotate(270deg, 3); }\n\n.@{fa-css-prefix}-flip-horizontal { .fa-icon-flip(-1, 1, 0); }\n.@{fa-css-prefix}-flip-vertical   { .fa-icon-flip(1, -1, 2); }\n\n// Hook for IE8-9\n// -------------------------\n\n:root .@{fa-css-prefix}-rotate-90,\n:root .@{fa-css-prefix}-rotate-180,\n:root .@{fa-css-prefix}-rotate-270,\n:root .@{fa-css-prefix}-flip-horizontal,\n:root .@{fa-css-prefix}-flip-vertical {\n  filter: none;\n}\n","// Mixins\n// --------------------------\n\n.fa-icon() {\n  display: inline-block;\n  font: normal normal normal @fa-font-size-base/1 FontAwesome; // shortening font declaration\n  font-size: inherit; // can't have font-size inherit on line above, so need to override\n  text-rendering: auto; // optimizelegibility throws things off #1094\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n  transform: translate(0, 0); // ensures no half-pixel rendering in firefox\n\n}\n\n.fa-icon-rotate(@degrees, @rotation) {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=@rotation);\n  -webkit-transform: rotate(@degrees);\n      -ms-transform: rotate(@degrees);\n          transform: rotate(@degrees);\n}\n\n.fa-icon-flip(@horiz, @vert, @rotation) {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=@rotation, mirror=1);\n  -webkit-transform: scale(@horiz, @vert);\n      -ms-transform: scale(@horiz, @vert);\n          transform: scale(@horiz, @vert);\n}\n","// Stacked Icons\n// -------------------------\n\n.@{fa-css-prefix}-stack {\n  position: relative;\n  display: inline-block;\n  width: 2em;\n  height: 2em;\n  line-height: 2em;\n  vertical-align: middle;\n}\n.@{fa-css-prefix}-stack-1x, .@{fa-css-prefix}-stack-2x {\n  position: absolute;\n  left: 0;\n  width: 100%;\n  text-align: center;\n}\n.@{fa-css-prefix}-stack-1x { line-height: inherit; }\n.@{fa-css-prefix}-stack-2x { font-size: 2em; }\n.@{fa-css-prefix}-inverse { color: @fa-inverse; }\n","/* Font Awesome uses the Unicode Private Use Area (PUA) to ensure screen\n   readers do not read off random characters that represent icons */\n\n.@{fa-css-prefix}-glass:before { content: @fa-var-glass; }\n.@{fa-css-prefix}-music:before { content: @fa-var-music; }\n.@{fa-css-prefix}-search:before { content: @fa-var-search; }\n.@{fa-css-prefix}-envelope-o:before { content: @fa-var-envelope-o; }\n.@{fa-css-prefix}-heart:before { content: @fa-var-heart; }\n.@{fa-css-prefix}-star:before { content: @fa-var-star; }\n.@{fa-css-prefix}-star-o:before { content: @fa-var-star-o; }\n.@{fa-css-prefix}-user:before { content: @fa-var-user; }\n.@{fa-css-prefix}-film:before { content: @fa-var-film; }\n.@{fa-css-prefix}-th-large:before { content: @fa-var-th-large; }\n.@{fa-css-prefix}-th:before { content: @fa-var-th; }\n.@{fa-css-prefix}-th-list:before { content: @fa-var-th-list; }\n.@{fa-css-prefix}-check:before { content: @fa-var-check; }\n.@{fa-css-prefix}-remove:before,\n.@{fa-css-prefix}-close:before,\n.@{fa-css-prefix}-times:before { content: @fa-var-times; }\n.@{fa-css-prefix}-search-plus:before { content: @fa-var-search-plus; }\n.@{fa-css-prefix}-search-minus:before { content: @fa-var-search-minus; }\n.@{fa-css-prefix}-power-off:before { content: @fa-var-power-off; }\n.@{fa-css-prefix}-signal:before { content: @fa-var-signal; }\n.@{fa-css-prefix}-gear:before,\n.@{fa-css-prefix}-cog:before { content: @fa-var-cog; }\n.@{fa-css-prefix}-trash-o:before { content: @fa-var-trash-o; }\n.@{fa-css-prefix}-home:before { content: @fa-var-home; }\n.@{fa-css-prefix}-file-o:before { content: @fa-var-file-o; }\n.@{fa-css-prefix}-clock-o:before { content: @fa-var-clock-o; }\n.@{fa-css-prefix}-road:before { content: @fa-var-road; }\n.@{fa-css-prefix}-download:before { content: @fa-var-download; }\n.@{fa-css-prefix}-arrow-circle-o-down:before { content: @fa-var-arrow-circle-o-down; }\n.@{fa-css-prefix}-arrow-circle-o-up:before { content: @fa-var-arrow-circle-o-up; }\n.@{fa-css-prefix}-inbox:before { content: @fa-var-inbox; }\n.@{fa-css-prefix}-play-circle-o:before { content: @fa-var-play-circle-o; }\n.@{fa-css-prefix}-rotate-right:before,\n.@{fa-css-prefix}-repeat:before { content: @fa-var-repeat; }\n.@{fa-css-prefix}-refresh:before { content: @fa-var-refresh; }\n.@{fa-css-prefix}-list-alt:before { content: @fa-var-list-alt; }\n.@{fa-css-prefix}-lock:before { content: @fa-var-lock; }\n.@{fa-css-prefix}-flag:before { content: @fa-var-flag; }\n.@{fa-css-prefix}-headphones:before { content: @fa-var-headphones; }\n.@{fa-css-prefix}-volume-off:before { content: @fa-var-volume-off; }\n.@{fa-css-prefix}-volume-down:before { content: @fa-var-volume-down; }\n.@{fa-css-prefix}-volume-up:before { content: @fa-var-volume-up; }\n.@{fa-css-prefix}-qrcode:before { content: @fa-var-qrcode; }\n.@{fa-css-prefix}-barcode:before { content: @fa-var-barcode; }\n.@{fa-css-prefix}-tag:before { content: @fa-var-tag; }\n.@{fa-css-prefix}-tags:before { content: @fa-var-tags; }\n.@{fa-css-prefix}-book:before { content: @fa-var-book; }\n.@{fa-css-prefix}-bookmark:before { content: @fa-var-bookmark; }\n.@{fa-css-prefix}-print:before { content: @fa-var-print; }\n.@{fa-css-prefix}-camera:before { content: @fa-var-camera; }\n.@{fa-css-prefix}-font:before { content: @fa-var-font; }\n.@{fa-css-prefix}-bold:before { content: @fa-var-bold; }\n.@{fa-css-prefix}-italic:before { content: @fa-var-italic; }\n.@{fa-css-prefix}-text-height:before { content: @fa-var-text-height; }\n.@{fa-css-prefix}-text-width:before { content: @fa-var-text-width; }\n.@{fa-css-prefix}-align-left:before { content: @fa-var-align-left; }\n.@{fa-css-prefix}-align-center:before { content: @fa-var-align-center; }\n.@{fa-css-prefix}-align-right:before { content: @fa-var-align-right; }\n.@{fa-css-prefix}-align-justify:before { content: @fa-var-align-justify; }\n.@{fa-css-prefix}-list:before { content: @fa-var-list; }\n.@{fa-css-prefix}-dedent:before,\n.@{fa-css-prefix}-outdent:before { content: @fa-var-outdent; }\n.@{fa-css-prefix}-indent:before { content: @fa-var-indent; }\n.@{fa-css-prefix}-video-camera:before { content: @fa-var-video-camera; }\n.@{fa-css-prefix}-photo:before,\n.@{fa-css-prefix}-image:before,\n.@{fa-css-prefix}-picture-o:before { content: @fa-var-picture-o; }\n.@{fa-css-prefix}-pencil:before { content: @fa-var-pencil; }\n.@{fa-css-prefix}-map-marker:before { content: @fa-var-map-marker; }\n.@{fa-css-prefix}-adjust:before { content: @fa-var-adjust; }\n.@{fa-css-prefix}-tint:before { content: @fa-var-tint; }\n.@{fa-css-prefix}-edit:before,\n.@{fa-css-prefix}-pencil-square-o:before { content: @fa-var-pencil-square-o; }\n.@{fa-css-prefix}-share-square-o:before { content: @fa-var-share-square-o; }\n.@{fa-css-prefix}-check-square-o:before { content: @fa-var-check-square-o; }\n.@{fa-css-prefix}-arrows:before { content: @fa-var-arrows; }\n.@{fa-css-prefix}-step-backward:before { content: @fa-var-step-backward; }\n.@{fa-css-prefix}-fast-backward:before { content: @fa-var-fast-backward; }\n.@{fa-css-prefix}-backward:before { content: @fa-var-backward; }\n.@{fa-css-prefix}-play:before { content: @fa-var-play; }\n.@{fa-css-prefix}-pause:before { content: @fa-var-pause; }\n.@{fa-css-prefix}-stop:before { content: @fa-var-stop; }\n.@{fa-css-prefix}-forward:before { content: @fa-var-forward; }\n.@{fa-css-prefix}-fast-forward:before { content: @fa-var-fast-forward; }\n.@{fa-css-prefix}-step-forward:before { content: @fa-var-step-forward; }\n.@{fa-css-prefix}-eject:before { content: @fa-var-eject; }\n.@{fa-css-prefix}-chevron-left:before { content: @fa-var-chevron-left; }\n.@{fa-css-prefix}-chevron-right:before { content: @fa-var-chevron-right; }\n.@{fa-css-prefix}-plus-circle:before { content: @fa-var-plus-circle; }\n.@{fa-css-prefix}-minus-circle:before { content: @fa-var-minus-circle; }\n.@{fa-css-prefix}-times-circle:before { content: @fa-var-times-circle; }\n.@{fa-css-prefix}-check-circle:before { content: @fa-var-check-circle; }\n.@{fa-css-prefix}-question-circle:before { content: @fa-var-question-circle; }\n.@{fa-css-prefix}-info-circle:before { content: @fa-var-info-circle; }\n.@{fa-css-prefix}-crosshairs:before { content: @fa-var-crosshairs; }\n.@{fa-css-prefix}-times-circle-o:before { content: @fa-var-times-circle-o; }\n.@{fa-css-prefix}-check-circle-o:before { content: @fa-var-check-circle-o; }\n.@{fa-css-prefix}-ban:before { content: @fa-var-ban; }\n.@{fa-css-prefix}-arrow-left:before { content: @fa-var-arrow-left; }\n.@{fa-css-prefix}-arrow-right:before { content: @fa-var-arrow-right; }\n.@{fa-css-prefix}-arrow-up:before { content: @fa-var-arrow-up; }\n.@{fa-css-prefix}-arrow-down:before { content: @fa-var-arrow-down; }\n.@{fa-css-prefix}-mail-forward:before,\n.@{fa-css-prefix}-share:before { content: @fa-var-share; }\n.@{fa-css-prefix}-expand:before { content: @fa-var-expand; }\n.@{fa-css-prefix}-compress:before { content: @fa-var-compress; }\n.@{fa-css-prefix}-plus:before { content: @fa-var-plus; }\n.@{fa-css-prefix}-minus:before { content: @fa-var-minus; }\n.@{fa-css-prefix}-asterisk:before { content: @fa-var-asterisk; }\n.@{fa-css-prefix}-exclamation-circle:before { content: @fa-var-exclamation-circle; }\n.@{fa-css-prefix}-gift:before { content: @fa-var-gift; }\n.@{fa-css-prefix}-leaf:before { content: @fa-var-leaf; }\n.@{fa-css-prefix}-fire:before { content: @fa-var-fire; }\n.@{fa-css-prefix}-eye:before { content: @fa-var-eye; }\n.@{fa-css-prefix}-eye-slash:before { content: @fa-var-eye-slash; }\n.@{fa-css-prefix}-warning:before,\n.@{fa-css-prefix}-exclamation-triangle:before { content: @fa-var-exclamation-triangle; }\n.@{fa-css-prefix}-plane:before { content: @fa-var-plane; }\n.@{fa-css-prefix}-calendar:before { content: @fa-var-calendar; }\n.@{fa-css-prefix}-random:before { content: @fa-var-random; }\n.@{fa-css-prefix}-comment:before { content: @fa-var-comment; }\n.@{fa-css-prefix}-magnet:before { content: @fa-var-magnet; }\n.@{fa-css-prefix}-chevron-up:before { content: @fa-var-chevron-up; }\n.@{fa-css-prefix}-chevron-down:before { content: @fa-var-chevron-down; }\n.@{fa-css-prefix}-retweet:before { content: @fa-var-retweet; }\n.@{fa-css-prefix}-shopping-cart:before { content: @fa-var-shopping-cart; }\n.@{fa-css-prefix}-folder:before { content: @fa-var-folder; }\n.@{fa-css-prefix}-folder-open:before { content: @fa-var-folder-open; }\n.@{fa-css-prefix}-arrows-v:before { content: @fa-var-arrows-v; }\n.@{fa-css-prefix}-arrows-h:before { content: @fa-var-arrows-h; }\n.@{fa-css-prefix}-bar-chart-o:before,\n.@{fa-css-prefix}-bar-chart:before { content: @fa-var-bar-chart; }\n.@{fa-css-prefix}-twitter-square:before { content: @fa-var-twitter-square; }\n.@{fa-css-prefix}-facebook-square:before { content: @fa-var-facebook-square; }\n.@{fa-css-prefix}-camera-retro:before { content: @fa-var-camera-retro; }\n.@{fa-css-prefix}-key:before { content: @fa-var-key; }\n.@{fa-css-prefix}-gears:before,\n.@{fa-css-prefix}-cogs:before { content: @fa-var-cogs; }\n.@{fa-css-prefix}-comments:before { content: @fa-var-comments; }\n.@{fa-css-prefix}-thumbs-o-up:before { content: @fa-var-thumbs-o-up; }\n.@{fa-css-prefix}-thumbs-o-down:before { content: @fa-var-thumbs-o-down; }\n.@{fa-css-prefix}-star-half:before { content: @fa-var-star-half; }\n.@{fa-css-prefix}-heart-o:before { content: @fa-var-heart-o; }\n.@{fa-css-prefix}-sign-out:before { content: @fa-var-sign-out; }\n.@{fa-css-prefix}-linkedin-square:before { content: @fa-var-linkedin-square; }\n.@{fa-css-prefix}-thumb-tack:before { content: @fa-var-thumb-tack; }\n.@{fa-css-prefix}-external-link:before { content: @fa-var-external-link; }\n.@{fa-css-prefix}-sign-in:before { content: @fa-var-sign-in; }\n.@{fa-css-prefix}-trophy:before { content: @fa-var-trophy; }\n.@{fa-css-prefix}-github-square:before { content: @fa-var-github-square; }\n.@{fa-css-prefix}-upload:before { content: @fa-var-upload; }\n.@{fa-css-prefix}-lemon-o:before { content: @fa-var-lemon-o; }\n.@{fa-css-prefix}-phone:before { content: @fa-var-phone; }\n.@{fa-css-prefix}-square-o:before { content: @fa-var-square-o; }\n.@{fa-css-prefix}-bookmark-o:before { content: @fa-var-bookmark-o; }\n.@{fa-css-prefix}-phone-square:before { content: @fa-var-phone-square; }\n.@{fa-css-prefix}-twitter:before { content: @fa-var-twitter; }\n.@{fa-css-prefix}-facebook-f:before,\n.@{fa-css-prefix}-facebook:before { content: @fa-var-facebook; }\n.@{fa-css-prefix}-github:before { content: @fa-var-github; }\n.@{fa-css-prefix}-unlock:before { content: @fa-var-unlock; }\n.@{fa-css-prefix}-credit-card:before { content: @fa-var-credit-card; }\n.@{fa-css-prefix}-rss:before { content: @fa-var-rss; }\n.@{fa-css-prefix}-hdd-o:before { content: @fa-var-hdd-o; }\n.@{fa-css-prefix}-bullhorn:before { content: @fa-var-bullhorn; }\n.@{fa-css-prefix}-bell:before { content: @fa-var-bell; }\n.@{fa-css-prefix}-certificate:before { content: @fa-var-certificate; }\n.@{fa-css-prefix}-hand-o-right:before { content: @fa-var-hand-o-right; }\n.@{fa-css-prefix}-hand-o-left:before { content: @fa-var-hand-o-left; }\n.@{fa-css-prefix}-hand-o-up:before { content: @fa-var-hand-o-up; }\n.@{fa-css-prefix}-hand-o-down:before { content: @fa-var-hand-o-down; }\n.@{fa-css-prefix}-arrow-circle-left:before { content: @fa-var-arrow-circle-left; }\n.@{fa-css-prefix}-arrow-circle-right:before { content: @fa-var-arrow-circle-right; }\n.@{fa-css-prefix}-arrow-circle-up:before { content: @fa-var-arrow-circle-up; }\n.@{fa-css-prefix}-arrow-circle-down:before { content: @fa-var-arrow-circle-down; }\n.@{fa-css-prefix}-globe:before { content: @fa-var-globe; }\n.@{fa-css-prefix}-wrench:before { content: @fa-var-wrench; }\n.@{fa-css-prefix}-tasks:before { content: @fa-var-tasks; }\n.@{fa-css-prefix}-filter:before { content: @fa-var-filter; }\n.@{fa-css-prefix}-briefcase:before { content: @fa-var-briefcase; }\n.@{fa-css-prefix}-arrows-alt:before { content: @fa-var-arrows-alt; }\n.@{fa-css-prefix}-group:before,\n.@{fa-css-prefix}-users:before { content: @fa-var-users; }\n.@{fa-css-prefix}-chain:before,\n.@{fa-css-prefix}-link:before { content: @fa-var-link; }\n.@{fa-css-prefix}-cloud:before { content: @fa-var-cloud; }\n.@{fa-css-prefix}-flask:before { content: @fa-var-flask; }\n.@{fa-css-prefix}-cut:before,\n.@{fa-css-prefix}-scissors:before { content: @fa-var-scissors; }\n.@{fa-css-prefix}-copy:before,\n.@{fa-css-prefix}-files-o:before { content: @fa-var-files-o; }\n.@{fa-css-prefix}-paperclip:before { content: @fa-var-paperclip; }\n.@{fa-css-prefix}-save:before,\n.@{fa-css-prefix}-floppy-o:before { content: @fa-var-floppy-o; }\n.@{fa-css-prefix}-square:before { content: @fa-var-square; }\n.@{fa-css-prefix}-navicon:before,\n.@{fa-css-prefix}-reorder:before,\n.@{fa-css-prefix}-bars:before { content: @fa-var-bars; }\n.@{fa-css-prefix}-list-ul:before { content: @fa-var-list-ul; }\n.@{fa-css-prefix}-list-ol:before { content: @fa-var-list-ol; }\n.@{fa-css-prefix}-strikethrough:before { content: @fa-var-strikethrough; }\n.@{fa-css-prefix}-underline:before { content: @fa-var-underline; }\n.@{fa-css-prefix}-table:before { content: @fa-var-table; }\n.@{fa-css-prefix}-magic:before { content: @fa-var-magic; }\n.@{fa-css-prefix}-truck:before { content: @fa-var-truck; }\n.@{fa-css-prefix}-pinterest:before { content: @fa-var-pinterest; }\n.@{fa-css-prefix}-pinterest-square:before { content: @fa-var-pinterest-square; }\n.@{fa-css-prefix}-google-plus-square:before { content: @fa-var-google-plus-square; }\n.@{fa-css-prefix}-google-plus:before { content: @fa-var-google-plus; }\n.@{fa-css-prefix}-money:before { content: @fa-var-money; }\n.@{fa-css-prefix}-caret-down:before { content: @fa-var-caret-down; }\n.@{fa-css-prefix}-caret-up:before { content: @fa-var-caret-up; }\n.@{fa-css-prefix}-caret-left:before { content: @fa-var-caret-left; }\n.@{fa-css-prefix}-caret-right:before { content: @fa-var-caret-right; }\n.@{fa-css-prefix}-columns:before { content: @fa-var-columns; }\n.@{fa-css-prefix}-unsorted:before,\n.@{fa-css-prefix}-sort:before { content: @fa-var-sort; }\n.@{fa-css-prefix}-sort-down:before,\n.@{fa-css-prefix}-sort-desc:before { content: @fa-var-sort-desc; }\n.@{fa-css-prefix}-sort-up:before,\n.@{fa-css-prefix}-sort-asc:before { content: @fa-var-sort-asc; }\n.@{fa-css-prefix}-envelope:before { content: @fa-var-envelope; }\n.@{fa-css-prefix}-linkedin:before { content: @fa-var-linkedin; }\n.@{fa-css-prefix}-rotate-left:before,\n.@{fa-css-prefix}-undo:before { content: @fa-var-undo; }\n.@{fa-css-prefix}-legal:before,\n.@{fa-css-prefix}-gavel:before { content: @fa-var-gavel; }\n.@{fa-css-prefix}-dashboard:before,\n.@{fa-css-prefix}-tachometer:before { content: @fa-var-tachometer; }\n.@{fa-css-prefix}-comment-o:before { content: @fa-var-comment-o; }\n.@{fa-css-prefix}-comments-o:before { content: @fa-var-comments-o; }\n.@{fa-css-prefix}-flash:before,\n.@{fa-css-prefix}-bolt:before { content: @fa-var-bolt; }\n.@{fa-css-prefix}-sitemap:before { content: @fa-var-sitemap; }\n.@{fa-css-prefix}-umbrella:before { content: @fa-var-umbrella; }\n.@{fa-css-prefix}-paste:before,\n.@{fa-css-prefix}-clipboard:before { content: @fa-var-clipboard; }\n.@{fa-css-prefix}-lightbulb-o:before { content: @fa-var-lightbulb-o; }\n.@{fa-css-prefix}-exchange:before { content: @fa-var-exchange; }\n.@{fa-css-prefix}-cloud-download:before { content: @fa-var-cloud-download; }\n.@{fa-css-prefix}-cloud-upload:before { content: @fa-var-cloud-upload; }\n.@{fa-css-prefix}-user-md:before { content: @fa-var-user-md; }\n.@{fa-css-prefix}-stethoscope:before { content: @fa-var-stethoscope; }\n.@{fa-css-prefix}-suitcase:before { content: @fa-var-suitcase; }\n.@{fa-css-prefix}-bell-o:before { content: @fa-var-bell-o; }\n.@{fa-css-prefix}-coffee:before { content: @fa-var-coffee; }\n.@{fa-css-prefix}-cutlery:before { content: @fa-var-cutlery; }\n.@{fa-css-prefix}-file-text-o:before { content: @fa-var-file-text-o; }\n.@{fa-css-prefix}-building-o:before { content: @fa-var-building-o; }\n.@{fa-css-prefix}-hospital-o:before { content: @fa-var-hospital-o; }\n.@{fa-css-prefix}-ambulance:before { content: @fa-var-ambulance; }\n.@{fa-css-prefix}-medkit:before { content: @fa-var-medkit; }\n.@{fa-css-prefix}-fighter-jet:before { content: @fa-var-fighter-jet; }\n.@{fa-css-prefix}-beer:before { content: @fa-var-beer; }\n.@{fa-css-prefix}-h-square:before { content: @fa-var-h-square; }\n.@{fa-css-prefix}-plus-square:before { content: @fa-var-plus-square; }\n.@{fa-css-prefix}-angle-double-left:before { content: @fa-var-angle-double-left; }\n.@{fa-css-prefix}-angle-double-right:before { content: @fa-var-angle-double-right; }\n.@{fa-css-prefix}-angle-double-up:before { content: @fa-var-angle-double-up; }\n.@{fa-css-prefix}-angle-double-down:before { content: @fa-var-angle-double-down; }\n.@{fa-css-prefix}-angle-left:before { content: @fa-var-angle-left; }\n.@{fa-css-prefix}-angle-right:before { content: @fa-var-angle-right; }\n.@{fa-css-prefix}-angle-up:before { content: @fa-var-angle-up; }\n.@{fa-css-prefix}-angle-down:before { content: @fa-var-angle-down; }\n.@{fa-css-prefix}-desktop:before { content: @fa-var-desktop; }\n.@{fa-css-prefix}-laptop:before { content: @fa-var-laptop; }\n.@{fa-css-prefix}-tablet:before { content: @fa-var-tablet; }\n.@{fa-css-prefix}-mobile-phone:before,\n.@{fa-css-prefix}-mobile:before { content: @fa-var-mobile; }\n.@{fa-css-prefix}-circle-o:before { content: @fa-var-circle-o; }\n.@{fa-css-prefix}-quote-left:before { content: @fa-var-quote-left; }\n.@{fa-css-prefix}-quote-right:before { content: @fa-var-quote-right; }\n.@{fa-css-prefix}-spinner:before { content: @fa-var-spinner; }\n.@{fa-css-prefix}-circle:before { content: @fa-var-circle; }\n.@{fa-css-prefix}-mail-reply:before,\n.@{fa-css-prefix}-reply:before { content: @fa-var-reply; }\n.@{fa-css-prefix}-github-alt:before { content: @fa-var-github-alt; }\n.@{fa-css-prefix}-folder-o:before { content: @fa-var-folder-o; }\n.@{fa-css-prefix}-folder-open-o:before { content: @fa-var-folder-open-o; }\n.@{fa-css-prefix}-smile-o:before { content: @fa-var-smile-o; }\n.@{fa-css-prefix}-frown-o:before { content: @fa-var-frown-o; }\n.@{fa-css-prefix}-meh-o:before { content: @fa-var-meh-o; }\n.@{fa-css-prefix}-gamepad:before { content: @fa-var-gamepad; }\n.@{fa-css-prefix}-keyboard-o:before { content: @fa-var-keyboard-o; }\n.@{fa-css-prefix}-flag-o:before { content: @fa-var-flag-o; }\n.@{fa-css-prefix}-flag-checkered:before { content: @fa-var-flag-checkered; }\n.@{fa-css-prefix}-terminal:before { content: @fa-var-terminal; }\n.@{fa-css-prefix}-code:before { content: @fa-var-code; }\n.@{fa-css-prefix}-mail-reply-all:before,\n.@{fa-css-prefix}-reply-all:before { content: @fa-var-reply-all; }\n.@{fa-css-prefix}-star-half-empty:before,\n.@{fa-css-prefix}-star-half-full:before,\n.@{fa-css-prefix}-star-half-o:before { content: @fa-var-star-half-o; }\n.@{fa-css-prefix}-location-arrow:before { content: @fa-var-location-arrow; }\n.@{fa-css-prefix}-crop:before { content: @fa-var-crop; }\n.@{fa-css-prefix}-code-fork:before { content: @fa-var-code-fork; }\n.@{fa-css-prefix}-unlink:before,\n.@{fa-css-prefix}-chain-broken:before { content: @fa-var-chain-broken; }\n.@{fa-css-prefix}-question:before { content: @fa-var-question; }\n.@{fa-css-prefix}-info:before { content: @fa-var-info; }\n.@{fa-css-prefix}-exclamation:before { content: @fa-var-exclamation; }\n.@{fa-css-prefix}-superscript:before { content: @fa-var-superscript; }\n.@{fa-css-prefix}-subscript:before { content: @fa-var-subscript; }\n.@{fa-css-prefix}-eraser:before { content: @fa-var-eraser; }\n.@{fa-css-prefix}-puzzle-piece:before { content: @fa-var-puzzle-piece; }\n.@{fa-css-prefix}-microphone:before { content: @fa-var-microphone; }\n.@{fa-css-prefix}-microphone-slash:before { content: @fa-var-microphone-slash; }\n.@{fa-css-prefix}-shield:before { content: @fa-var-shield; }\n.@{fa-css-prefix}-calendar-o:before { content: @fa-var-calendar-o; }\n.@{fa-css-prefix}-fire-extinguisher:before { content: @fa-var-fire-extinguisher; }\n.@{fa-css-prefix}-rocket:before { content: @fa-var-rocket; }\n.@{fa-css-prefix}-maxcdn:before { content: @fa-var-maxcdn; }\n.@{fa-css-prefix}-chevron-circle-left:before { content: @fa-var-chevron-circle-left; }\n.@{fa-css-prefix}-chevron-circle-right:before { content: @fa-var-chevron-circle-right; }\n.@{fa-css-prefix}-chevron-circle-up:before { content: @fa-var-chevron-circle-up; }\n.@{fa-css-prefix}-chevron-circle-down:before { content: @fa-var-chevron-circle-down; }\n.@{fa-css-prefix}-html5:before { content: @fa-var-html5; }\n.@{fa-css-prefix}-css3:before { content: @fa-var-css3; }\n.@{fa-css-prefix}-anchor:before { content: @fa-var-anchor; }\n.@{fa-css-prefix}-unlock-alt:before { content: @fa-var-unlock-alt; }\n.@{fa-css-prefix}-bullseye:before { content: @fa-var-bullseye; }\n.@{fa-css-prefix}-ellipsis-h:before { content: @fa-var-ellipsis-h; }\n.@{fa-css-prefix}-ellipsis-v:before { content: @fa-var-ellipsis-v; }\n.@{fa-css-prefix}-rss-square:before { content: @fa-var-rss-square; }\n.@{fa-css-prefix}-play-circle:before { content: @fa-var-play-circle; }\n.@{fa-css-prefix}-ticket:before { content: @fa-var-ticket; }\n.@{fa-css-prefix}-minus-square:before { content: @fa-var-minus-square; }\n.@{fa-css-prefix}-minus-square-o:before { content: @fa-var-minus-square-o; }\n.@{fa-css-prefix}-level-up:before { content: @fa-var-level-up; }\n.@{fa-css-prefix}-level-down:before { content: @fa-var-level-down; }\n.@{fa-css-prefix}-check-square:before { content: @fa-var-check-square; }\n.@{fa-css-prefix}-pencil-square:before { content: @fa-var-pencil-square; }\n.@{fa-css-prefix}-external-link-square:before { content: @fa-var-external-link-square; }\n.@{fa-css-prefix}-share-square:before { content: @fa-var-share-square; }\n.@{fa-css-prefix}-compass:before { content: @fa-var-compass; }\n.@{fa-css-prefix}-toggle-down:before,\n.@{fa-css-prefix}-caret-square-o-down:before { content: @fa-var-caret-square-o-down; }\n.@{fa-css-prefix}-toggle-up:before,\n.@{fa-css-prefix}-caret-square-o-up:before { content: @fa-var-caret-square-o-up; }\n.@{fa-css-prefix}-toggle-right:before,\n.@{fa-css-prefix}-caret-square-o-right:before { content: @fa-var-caret-square-o-right; }\n.@{fa-css-prefix}-euro:before,\n.@{fa-css-prefix}-eur:before { content: @fa-var-eur; }\n.@{fa-css-prefix}-gbp:before { content: @fa-var-gbp; }\n.@{fa-css-prefix}-dollar:before,\n.@{fa-css-prefix}-usd:before { content: @fa-var-usd; }\n.@{fa-css-prefix}-rupee:before,\n.@{fa-css-prefix}-inr:before { content: @fa-var-inr; }\n.@{fa-css-prefix}-cny:before,\n.@{fa-css-prefix}-rmb:before,\n.@{fa-css-prefix}-yen:before,\n.@{fa-css-prefix}-jpy:before { content: @fa-var-jpy; }\n.@{fa-css-prefix}-ruble:before,\n.@{fa-css-prefix}-rouble:before,\n.@{fa-css-prefix}-rub:before { content: @fa-var-rub; }\n.@{fa-css-prefix}-won:before,\n.@{fa-css-prefix}-krw:before { content: @fa-var-krw; }\n.@{fa-css-prefix}-bitcoin:before,\n.@{fa-css-prefix}-btc:before { content: @fa-var-btc; }\n.@{fa-css-prefix}-file:before { content: @fa-var-file; }\n.@{fa-css-prefix}-file-text:before { content: @fa-var-file-text; }\n.@{fa-css-prefix}-sort-alpha-asc:before { content: @fa-var-sort-alpha-asc; }\n.@{fa-css-prefix}-sort-alpha-desc:before { content: @fa-var-sort-alpha-desc; }\n.@{fa-css-prefix}-sort-amount-asc:before { content: @fa-var-sort-amount-asc; }\n.@{fa-css-prefix}-sort-amount-desc:before { content: @fa-var-sort-amount-desc; }\n.@{fa-css-prefix}-sort-numeric-asc:before { content: @fa-var-sort-numeric-asc; }\n.@{fa-css-prefix}-sort-numeric-desc:before { content: @fa-var-sort-numeric-desc; }\n.@{fa-css-prefix}-thumbs-up:before { content: @fa-var-thumbs-up; }\n.@{fa-css-prefix}-thumbs-down:before { content: @fa-var-thumbs-down; }\n.@{fa-css-prefix}-youtube-square:before { content: @fa-var-youtube-square; }\n.@{fa-css-prefix}-youtube:before { content: @fa-var-youtube; }\n.@{fa-css-prefix}-xing:before { content: @fa-var-xing; }\n.@{fa-css-prefix}-xing-square:before { content: @fa-var-xing-square; }\n.@{fa-css-prefix}-youtube-play:before { content: @fa-var-youtube-play; }\n.@{fa-css-prefix}-dropbox:before { content: @fa-var-dropbox; }\n.@{fa-css-prefix}-stack-overflow:before { content: @fa-var-stack-overflow; }\n.@{fa-css-prefix}-instagram:before { content: @fa-var-instagram; }\n.@{fa-css-prefix}-flickr:before { content: @fa-var-flickr; }\n.@{fa-css-prefix}-adn:before { content: @fa-var-adn; }\n.@{fa-css-prefix}-bitbucket:before { content: @fa-var-bitbucket; }\n.@{fa-css-prefix}-bitbucket-square:before { content: @fa-var-bitbucket-square; }\n.@{fa-css-prefix}-tumblr:before { content: @fa-var-tumblr; }\n.@{fa-css-prefix}-tumblr-square:before { content: @fa-var-tumblr-square; }\n.@{fa-css-prefix}-long-arrow-down:before { content: @fa-var-long-arrow-down; }\n.@{fa-css-prefix}-long-arrow-up:before { content: @fa-var-long-arrow-up; }\n.@{fa-css-prefix}-long-arrow-left:before { content: @fa-var-long-arrow-left; }\n.@{fa-css-prefix}-long-arrow-right:before { content: @fa-var-long-arrow-right; }\n.@{fa-css-prefix}-apple:before { content: @fa-var-apple; }\n.@{fa-css-prefix}-windows:before { content: @fa-var-windows; }\n.@{fa-css-prefix}-android:before { content: @fa-var-android; }\n.@{fa-css-prefix}-linux:before { content: @fa-var-linux; }\n.@{fa-css-prefix}-dribbble:before { content: @fa-var-dribbble; }\n.@{fa-css-prefix}-skype:before { content: @fa-var-skype; }\n.@{fa-css-prefix}-foursquare:before { content: @fa-var-foursquare; }\n.@{fa-css-prefix}-trello:before { content: @fa-var-trello; }\n.@{fa-css-prefix}-female:before { content: @fa-var-female; }\n.@{fa-css-prefix}-male:before { content: @fa-var-male; }\n.@{fa-css-prefix}-gittip:before,\n.@{fa-css-prefix}-gratipay:before { content: @fa-var-gratipay; }\n.@{fa-css-prefix}-sun-o:before { content: @fa-var-sun-o; }\n.@{fa-css-prefix}-moon-o:before { content: @fa-var-moon-o; }\n.@{fa-css-prefix}-archive:before { content: @fa-var-archive; }\n.@{fa-css-prefix}-bug:before { content: @fa-var-bug; }\n.@{fa-css-prefix}-vk:before { content: @fa-var-vk; }\n.@{fa-css-prefix}-weibo:before { content: @fa-var-weibo; }\n.@{fa-css-prefix}-renren:before { content: @fa-var-renren; }\n.@{fa-css-prefix}-pagelines:before { content: @fa-var-pagelines; }\n.@{fa-css-prefix}-stack-exchange:before { content: @fa-var-stack-exchange; }\n.@{fa-css-prefix}-arrow-circle-o-right:before { content: @fa-var-arrow-circle-o-right; }\n.@{fa-css-prefix}-arrow-circle-o-left:before { content: @fa-var-arrow-circle-o-left; }\n.@{fa-css-prefix}-toggle-left:before,\n.@{fa-css-prefix}-caret-square-o-left:before { content: @fa-var-caret-square-o-left; }\n.@{fa-css-prefix}-dot-circle-o:before { content: @fa-var-dot-circle-o; }\n.@{fa-css-prefix}-wheelchair:before { content: @fa-var-wheelchair; }\n.@{fa-css-prefix}-vimeo-square:before { content: @fa-var-vimeo-square; }\n.@{fa-css-prefix}-turkish-lira:before,\n.@{fa-css-prefix}-try:before { content: @fa-var-try; }\n.@{fa-css-prefix}-plus-square-o:before { content: @fa-var-plus-square-o; }\n.@{fa-css-prefix}-space-shuttle:before { content: @fa-var-space-shuttle; }\n.@{fa-css-prefix}-slack:before { content: @fa-var-slack; }\n.@{fa-css-prefix}-envelope-square:before { content: @fa-var-envelope-square; }\n.@{fa-css-prefix}-wordpress:before { content: @fa-var-wordpress; }\n.@{fa-css-prefix}-openid:before { content: @fa-var-openid; }\n.@{fa-css-prefix}-institution:before,\n.@{fa-css-prefix}-bank:before,\n.@{fa-css-prefix}-university:before { content: @fa-var-university; }\n.@{fa-css-prefix}-mortar-board:before,\n.@{fa-css-prefix}-graduation-cap:before { content: @fa-var-graduation-cap; }\n.@{fa-css-prefix}-yahoo:before { content: @fa-var-yahoo; }\n.@{fa-css-prefix}-google:before { content: @fa-var-google; }\n.@{fa-css-prefix}-reddit:before { content: @fa-var-reddit; }\n.@{fa-css-prefix}-reddit-square:before { content: @fa-var-reddit-square; }\n.@{fa-css-prefix}-stumbleupon-circle:before { content: @fa-var-stumbleupon-circle; }\n.@{fa-css-prefix}-stumbleupon:before { content: @fa-var-stumbleupon; }\n.@{fa-css-prefix}-delicious:before { content: @fa-var-delicious; }\n.@{fa-css-prefix}-digg:before { content: @fa-var-digg; }\n.@{fa-css-prefix}-pied-piper:before { content: @fa-var-pied-piper; }\n.@{fa-css-prefix}-pied-piper-alt:before { content: @fa-var-pied-piper-alt; }\n.@{fa-css-prefix}-drupal:before { content: @fa-var-drupal; }\n.@{fa-css-prefix}-joomla:before { content: @fa-var-joomla; }\n.@{fa-css-prefix}-language:before { content: @fa-var-language; }\n.@{fa-css-prefix}-fax:before { content: @fa-var-fax; }\n.@{fa-css-prefix}-building:before { content: @fa-var-building; }\n.@{fa-css-prefix}-child:before { content: @fa-var-child; }\n.@{fa-css-prefix}-paw:before { content: @fa-var-paw; }\n.@{fa-css-prefix}-spoon:before { content: @fa-var-spoon; }\n.@{fa-css-prefix}-cube:before { content: @fa-var-cube; }\n.@{fa-css-prefix}-cubes:before { content: @fa-var-cubes; }\n.@{fa-css-prefix}-behance:before { content: @fa-var-behance; }\n.@{fa-css-prefix}-behance-square:before { content: @fa-var-behance-square; }\n.@{fa-css-prefix}-steam:before { content: @fa-var-steam; }\n.@{fa-css-prefix}-steam-square:before { content: @fa-var-steam-square; }\n.@{fa-css-prefix}-recycle:before { content: @fa-var-recycle; }\n.@{fa-css-prefix}-automobile:before,\n.@{fa-css-prefix}-car:before { content: @fa-var-car; }\n.@{fa-css-prefix}-cab:before,\n.@{fa-css-prefix}-taxi:before { content: @fa-var-taxi; }\n.@{fa-css-prefix}-tree:before { content: @fa-var-tree; }\n.@{fa-css-prefix}-spotify:before { content: @fa-var-spotify; }\n.@{fa-css-prefix}-deviantart:before { content: @fa-var-deviantart; }\n.@{fa-css-prefix}-soundcloud:before { content: @fa-var-soundcloud; }\n.@{fa-css-prefix}-database:before { content: @fa-var-database; }\n.@{fa-css-prefix}-file-pdf-o:before { content: @fa-var-file-pdf-o; }\n.@{fa-css-prefix}-file-word-o:before { content: @fa-var-file-word-o; }\n.@{fa-css-prefix}-file-excel-o:before { content: @fa-var-file-excel-o; }\n.@{fa-css-prefix}-file-powerpoint-o:before { content: @fa-var-file-powerpoint-o; }\n.@{fa-css-prefix}-file-photo-o:before,\n.@{fa-css-prefix}-file-picture-o:before,\n.@{fa-css-prefix}-file-image-o:before { content: @fa-var-file-image-o; }\n.@{fa-css-prefix}-file-zip-o:before,\n.@{fa-css-prefix}-file-archive-o:before { content: @fa-var-file-archive-o; }\n.@{fa-css-prefix}-file-sound-o:before,\n.@{fa-css-prefix}-file-audio-o:before { content: @fa-var-file-audio-o; }\n.@{fa-css-prefix}-file-movie-o:before,\n.@{fa-css-prefix}-file-video-o:before { content: @fa-var-file-video-o; }\n.@{fa-css-prefix}-file-code-o:before { content: @fa-var-file-code-o; }\n.@{fa-css-prefix}-vine:before { content: @fa-var-vine; }\n.@{fa-css-prefix}-codepen:before { content: @fa-var-codepen; }\n.@{fa-css-prefix}-jsfiddle:before { content: @fa-var-jsfiddle; }\n.@{fa-css-prefix}-life-bouy:before,\n.@{fa-css-prefix}-life-buoy:before,\n.@{fa-css-prefix}-life-saver:before,\n.@{fa-css-prefix}-support:before,\n.@{fa-css-prefix}-life-ring:before { content: @fa-var-life-ring; }\n.@{fa-css-prefix}-circle-o-notch:before { content: @fa-var-circle-o-notch; }\n.@{fa-css-prefix}-ra:before,\n.@{fa-css-prefix}-rebel:before { content: @fa-var-rebel; }\n.@{fa-css-prefix}-ge:before,\n.@{fa-css-prefix}-empire:before { content: @fa-var-empire; }\n.@{fa-css-prefix}-git-square:before { content: @fa-var-git-square; }\n.@{fa-css-prefix}-git:before { content: @fa-var-git; }\n.@{fa-css-prefix}-hacker-news:before { content: @fa-var-hacker-news; }\n.@{fa-css-prefix}-tencent-weibo:before { content: @fa-var-tencent-weibo; }\n.@{fa-css-prefix}-qq:before { content: @fa-var-qq; }\n.@{fa-css-prefix}-wechat:before,\n.@{fa-css-prefix}-weixin:before { content: @fa-var-weixin; }\n.@{fa-css-prefix}-send:before,\n.@{fa-css-prefix}-paper-plane:before { content: @fa-var-paper-plane; }\n.@{fa-css-prefix}-send-o:before,\n.@{fa-css-prefix}-paper-plane-o:before { content: @fa-var-paper-plane-o; }\n.@{fa-css-prefix}-history:before { content: @fa-var-history; }\n.@{fa-css-prefix}-genderless:before,\n.@{fa-css-prefix}-circle-thin:before { content: @fa-var-circle-thin; }\n.@{fa-css-prefix}-header:before { content: @fa-var-header; }\n.@{fa-css-prefix}-paragraph:before { content: @fa-var-paragraph; }\n.@{fa-css-prefix}-sliders:before { content: @fa-var-sliders; }\n.@{fa-css-prefix}-share-alt:before { content: @fa-var-share-alt; }\n.@{fa-css-prefix}-share-alt-square:before { content: @fa-var-share-alt-square; }\n.@{fa-css-prefix}-bomb:before { content: @fa-var-bomb; }\n.@{fa-css-prefix}-soccer-ball-o:before,\n.@{fa-css-prefix}-futbol-o:before { content: @fa-var-futbol-o; }\n.@{fa-css-prefix}-tty:before { content: @fa-var-tty; }\n.@{fa-css-prefix}-binoculars:before { content: @fa-var-binoculars; }\n.@{fa-css-prefix}-plug:before { content: @fa-var-plug; }\n.@{fa-css-prefix}-slideshare:before { content: @fa-var-slideshare; }\n.@{fa-css-prefix}-twitch:before { content: @fa-var-twitch; }\n.@{fa-css-prefix}-yelp:before { content: @fa-var-yelp; }\n.@{fa-css-prefix}-newspaper-o:before { content: @fa-var-newspaper-o; }\n.@{fa-css-prefix}-wifi:before { content: @fa-var-wifi; }\n.@{fa-css-prefix}-calculator:before { content: @fa-var-calculator; }\n.@{fa-css-prefix}-paypal:before { content: @fa-var-paypal; }\n.@{fa-css-prefix}-google-wallet:before { content: @fa-var-google-wallet; }\n.@{fa-css-prefix}-cc-visa:before { content: @fa-var-cc-visa; }\n.@{fa-css-prefix}-cc-mastercard:before { content: @fa-var-cc-mastercard; }\n.@{fa-css-prefix}-cc-discover:before { content: @fa-var-cc-discover; }\n.@{fa-css-prefix}-cc-amex:before { content: @fa-var-cc-amex; }\n.@{fa-css-prefix}-cc-paypal:before { content: @fa-var-cc-paypal; }\n.@{fa-css-prefix}-cc-stripe:before { content: @fa-var-cc-stripe; }\n.@{fa-css-prefix}-bell-slash:before { content: @fa-var-bell-slash; }\n.@{fa-css-prefix}-bell-slash-o:before { content: @fa-var-bell-slash-o; }\n.@{fa-css-prefix}-trash:before { content: @fa-var-trash; }\n.@{fa-css-prefix}-copyright:before { content: @fa-var-copyright; }\n.@{fa-css-prefix}-at:before { content: @fa-var-at; }\n.@{fa-css-prefix}-eyedropper:before { content: @fa-var-eyedropper; }\n.@{fa-css-prefix}-paint-brush:before { content: @fa-var-paint-brush; }\n.@{fa-css-prefix}-birthday-cake:before { content: @fa-var-birthday-cake; }\n.@{fa-css-prefix}-area-chart:before { content: @fa-var-area-chart; }\n.@{fa-css-prefix}-pie-chart:before { content: @fa-var-pie-chart; }\n.@{fa-css-prefix}-line-chart:before { content: @fa-var-line-chart; }\n.@{fa-css-prefix}-lastfm:before { content: @fa-var-lastfm; }\n.@{fa-css-prefix}-lastfm-square:before { content: @fa-var-lastfm-square; }\n.@{fa-css-prefix}-toggle-off:before { content: @fa-var-toggle-off; }\n.@{fa-css-prefix}-toggle-on:before { content: @fa-var-toggle-on; }\n.@{fa-css-prefix}-bicycle:before { content: @fa-var-bicycle; }\n.@{fa-css-prefix}-bus:before { content: @fa-var-bus; }\n.@{fa-css-prefix}-ioxhost:before { content: @fa-var-ioxhost; }\n.@{fa-css-prefix}-angellist:before { content: @fa-var-angellist; }\n.@{fa-css-prefix}-cc:before { content: @fa-var-cc; }\n.@{fa-css-prefix}-shekel:before,\n.@{fa-css-prefix}-sheqel:before,\n.@{fa-css-prefix}-ils:before { content: @fa-var-ils; }\n.@{fa-css-prefix}-meanpath:before { content: @fa-var-meanpath; }\n.@{fa-css-prefix}-buysellads:before { content: @fa-var-buysellads; }\n.@{fa-css-prefix}-connectdevelop:before { content: @fa-var-connectdevelop; }\n.@{fa-css-prefix}-dashcube:before { content: @fa-var-dashcube; }\n.@{fa-css-prefix}-forumbee:before { content: @fa-var-forumbee; }\n.@{fa-css-prefix}-leanpub:before { content: @fa-var-leanpub; }\n.@{fa-css-prefix}-sellsy:before { content: @fa-var-sellsy; }\n.@{fa-css-prefix}-shirtsinbulk:before { content: @fa-var-shirtsinbulk; }\n.@{fa-css-prefix}-simplybuilt:before { content: @fa-var-simplybuilt; }\n.@{fa-css-prefix}-skyatlas:before { content: @fa-var-skyatlas; }\n.@{fa-css-prefix}-cart-plus:before { content: @fa-var-cart-plus; }\n.@{fa-css-prefix}-cart-arrow-down:before { content: @fa-var-cart-arrow-down; }\n.@{fa-css-prefix}-diamond:before { content: @fa-var-diamond; }\n.@{fa-css-prefix}-ship:before { content: @fa-var-ship; }\n.@{fa-css-prefix}-user-secret:before { content: @fa-var-user-secret; }\n.@{fa-css-prefix}-motorcycle:before { content: @fa-var-motorcycle; }\n.@{fa-css-prefix}-street-view:before { content: @fa-var-street-view; }\n.@{fa-css-prefix}-heartbeat:before { content: @fa-var-heartbeat; }\n.@{fa-css-prefix}-venus:before { content: @fa-var-venus; }\n.@{fa-css-prefix}-mars:before { content: @fa-var-mars; }\n.@{fa-css-prefix}-mercury:before { content: @fa-var-mercury; }\n.@{fa-css-prefix}-transgender:before { content: @fa-var-transgender; }\n.@{fa-css-prefix}-transgender-alt:before { content: @fa-var-transgender-alt; }\n.@{fa-css-prefix}-venus-double:before { content: @fa-var-venus-double; }\n.@{fa-css-prefix}-mars-double:before { content: @fa-var-mars-double; }\n.@{fa-css-prefix}-venus-mars:before { content: @fa-var-venus-mars; }\n.@{fa-css-prefix}-mars-stroke:before { content: @fa-var-mars-stroke; }\n.@{fa-css-prefix}-mars-stroke-v:before { content: @fa-var-mars-stroke-v; }\n.@{fa-css-prefix}-mars-stroke-h:before { content: @fa-var-mars-stroke-h; }\n.@{fa-css-prefix}-neuter:before { content: @fa-var-neuter; }\n.@{fa-css-prefix}-facebook-official:before { content: @fa-var-facebook-official; }\n.@{fa-css-prefix}-pinterest-p:before { content: @fa-var-pinterest-p; }\n.@{fa-css-prefix}-whatsapp:before { content: @fa-var-whatsapp; }\n.@{fa-css-prefix}-server:before { content: @fa-var-server; }\n.@{fa-css-prefix}-user-plus:before { content: @fa-var-user-plus; }\n.@{fa-css-prefix}-user-times:before { content: @fa-var-user-times; }\n.@{fa-css-prefix}-hotel:before,\n.@{fa-css-prefix}-bed:before { content: @fa-var-bed; }\n.@{fa-css-prefix}-viacoin:before { content: @fa-var-viacoin; }\n.@{fa-css-prefix}-train:before { content: @fa-var-train; }\n.@{fa-css-prefix}-subway:before { content: @fa-var-subway; }\n.@{fa-css-prefix}-medium:before { content: @fa-var-medium; }\n"],"sourceRoot":"/source/"} */ \ No newline at end of file +/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["bootstrap.less","mixins/vendor-prefixes.less","Lib.css","scaffolding.less","mixins/tab-focus.less","mixins/image.less","mixins/grid.less","grid.less","mixins/grid-framework.less","mixins/clearfix.less","utilities.less","mixins/center-block.less","mixins/hide-text.less","path.less","core.less","larger.less","fixed-width.less","list.less","bordered-pulled.less","animated.less","rotated-flipped.less","mixins.less","stacked.less","icons.less"],"names":[],"mappings":"AAKA;ECuEU,uBAAA;CCxET;AFCD;;ECuEU,uBAAA;CClET;AFLD;EGiBE,gBAAA;EACA,8CAAA;CDTD;AFTD;EGsBE,4DAAA;EACA,gBAAA;EACA,wBAAA;EACA,eAAA;EACA,0BAAA;CDVD;AFhBD;;;;EGkCE,qBAAA;EACA,mBAAA;EACA,qBAAA;CDZD;AFxBD;EG2CE,eAAA;EACA,sBAAA;CDhBD;ACkBC;;EAEE,eAAA;EACA,2BAAA;CDhBH;ACmBC;ECrDA,qBAAA;EAEA,2CAAA;EACA,qBAAA;CFoCD;AFtCD;EGgEE,UAAA;CDvBD;AFzCD;EGuEE,uBAAA;CD3BD;AF5CD;EKIE,eAAA;EACA,gBAAA;EACA,aAAA;CH2CD;AFjDD;EGiFE,mBAAA;CD7BD;AFpDD;EGwFE,aAAA;EACA,wBAAA;EACA,0BAAA;EACA,0BAAA;EACA,mBAAA;EF+FQ,iCAAA;EIvLR,sBAAA;EACA,gBAAA;EACA,aAAA;CH2DD;AFjED;EGqGE,mBAAA;CDjCD;AFpED;EG4GE,iBAAA;EACA,oBAAA;EACA,UAAA;EACA,8BAAA;CDrCD;AF1ED;EGwHE,mBAAA;EACA,WAAA;EACA,YAAA;EACA,aAAA;EACA,WAAA;EACA,iBAAA;EACA,uBAAA;EACA,UAAA;CD3CD;ACmDC;;EAEE,iBAAA;EACA,YAAA;EACA,aAAA;EACA,UAAA;EACA,kBAAA;EACA,WAAA;CDjDH;AF7FD;EMCE,mBAAA;EACA,kBAAA;EACA,mBAAA;EACA,oBAAA;CJ+FD;AKzFC;EAqEF;IAvEI,aAAA;GL+FD;CACF;AK3FC;EAkEF;IApEI,aAAA;GLiGD;CACF;AK7FD;EA+DA;IAjEI,cAAA;GLmGD;CACF;AFlHD;EMCE,mBAAA;EACA,kBAAA;EACA,mBAAA;EACA,oBAAA;CJoHD;AFxHD;EMUE,mBAAA;EACA,oBAAA;CJiHD;AF5HD;EQYM,mBAAA;EAEA,gBAAA;EAEA,mBAAA;EACA,oBAAA;CNiHL;AFlID;EQkCM,YAAA;CNmGL;AFrID;EQ0CI,YAAA;CN8FH;AFxID;EQ0CI,oBAAA;CNiGH;AF3ID;EQ0CI,oBAAA;CNoGH;AF9ID;EQ0CI,WAAA;CNuGH;AFjJD;EQ0CI,oBAAA;CN0GH;AFpJD;EQ0CI,oBAAA;CN6GH;AFvJD;EQ0CI,WAAA;CNgHH;AF1JD;EQ0CI,oBAAA;CNmHH;AF7JD;EQ0CI,oBAAA;CNsHH;AFhKD;EQ0CI,WAAA;CNyHH;AFnKD;EQ0CI,oBAAA;CN4HH;AFtKD;EQ0CI,mBAAA;CN+HH;AFzKD;EQyDI,YAAA;CNmHH;AF5KD;EQyDI,oBAAA;CNsHH;AF/KD;EQyDI,oBAAA;CNyHH;AFlLD;EQyDI,WAAA;CN4HH;AFrLD;EQyDI,oBAAA;CN+HH;AFxLD;EQyDI,oBAAA;CNkIH;AF3LD;EQyDI,WAAA;CNqIH;AF9LD;EQyDI,oBAAA;CNwIH;AFjMD;EQyDI,oBAAA;CN2IH;AFpMD;EQyDI,WAAA;CN8IH;AFvMD;EQyDI,oBAAA;CNiJH;AF1MD;EQyDI,mBAAA;CNoJH;AF7MD;EQ8DI,YAAA;CNkJH;AFhND;EQ+CI,WAAA;CNoKH;AFnND;EQ+CI,mBAAA;CNuKH;AFtND;EQ+CI,mBAAA;CN0KH;AFzND;EQ+CI,UAAA;CN6KH;AF5ND;EQ+CI,mBAAA;CNgLH;AF/ND;EQ+CI,mBAAA;CNmLH;AFlOD;EQ+CI,UAAA;CNsLH;AFrOD;EQ+CI,mBAAA;CNyLH;AFxOD;EQ+CI,mBAAA;CN4LH;AF3OD;EQ+CI,UAAA;CN+LH;AF9OD;EQ+CI,mBAAA;CNkMH;AFjPD;EQ+CI,kBAAA;CNqMH;AFpPD;EQoDI,WAAA;CNmMH;AFvPD;EQmEI,kBAAA;CNuLH;AF1PD;EQmEI,0BAAA;CN0LH;AF7PD;EQmEI,0BAAA;CN6LH;AFhQD;EQmEI,iBAAA;CNgMH;AFnQD;EQmEI,0BAAA;CNmMH;AFtQD;EQmEI,0BAAA;CNsMH;AFzQD;EQmEI,iBAAA;CNyMH;AF5QD;EQmEI,0BAAA;CN4MH;AF/QD;EQmEI,0BAAA;CN+MH;AFlRD;EQmEI,iBAAA;CNkNH;AFrRD;EQmEI,0BAAA;CNqNH;AFxRD;EQmEI,yBAAA;CNwNH;AF3RD;EQmEI,gBAAA;CN2NH;AK3ND;EAYA;IC7CM,YAAA;GNgQH;EKnNH;ICrCI,YAAA;GN2PD;EKtNH;ICrCI,oBAAA;GN8PD;EKzNH;ICrCI,oBAAA;GNiQD;EK5NH;ICrCI,WAAA;GNoQD;EK/NH;ICrCI,oBAAA;GNuQD;EKlOH;ICrCI,oBAAA;GN0QD;EKrOH;ICrCI,WAAA;GN6QD;EKxOH;ICrCI,oBAAA;GNgRD;EK3OH;ICrCI,oBAAA;GNmRD;EK9OH;ICrCI,WAAA;GNsRD;EKjPH;ICrCI,oBAAA;GNyRD;EKpPH;ICrCI,mBAAA;GN4RD;EKvPH;ICtBI,YAAA;GNgRD;EK1PH;ICtBI,oBAAA;GNmRD;EK7PH;ICtBI,oBAAA;GNsRD;EKhQH;ICtBI,WAAA;GNyRD;EKnQH;ICtBI,oBAAA;GN4RD;EKtQH;ICtBI,oBAAA;GN+RD;EKzQH;ICtBI,WAAA;GNkSD;EK5QH;ICtBI,oBAAA;GNqSD;EK/QH;ICtBI,oBAAA;GNwSD;EKlRH;ICtBI,WAAA;GN2SD;EKrRH;ICtBI,oBAAA;GN8SD;EKxRH;ICtBI,mBAAA;GNiTD;EK3RH;ICjBI,YAAA;GN+SD;EK9RH;IChCI,WAAA;GNiUD;EKjSH;IChCI,mBAAA;GNoUD;EKpSH;IChCI,mBAAA;GNuUD;EKvSH;IChCI,UAAA;GN0UD;EK1SH;IChCI,mBAAA;GN6UD;EK7SH;IChCI,mBAAA;GNgVD;EKhTH;IChCI,UAAA;GNmVD;EKnTH;IChCI,mBAAA;GNsVD;EKtTH;IChCI,mBAAA;GNyVD;EKzTH;IChCI,UAAA;GN4VD;EK5TH;IChCI,mBAAA;GN+VD;EK/TH;IChCI,kBAAA;GNkWD;EKlUH;IC3BI,WAAA;GNgWD;EKrUH;ICZI,kBAAA;GNoVD;EKxUH;ICZI,0BAAA;GNuVD;EK3UH;ICZI,0BAAA;GN0VD;EK9UH;ICZI,iBAAA;GN6VD;EKjVH;ICZI,0BAAA;GNgWD;EKpVH;ICZI,0BAAA;GNmWD;EKvVH;ICZI,iBAAA;GNsWD;EK1VH;ICZI,0BAAA;GNyWD;EK7VH;ICZI,0BAAA;GN4WD;EKhWH;ICZI,iBAAA;GN+WD;EKnWH;ICZI,0BAAA;GNkXD;EKtWH;ICZI,yBAAA;GNqXD;EKzWH;ICZI,gBAAA;GNwXD;CACF;AKhXD;EAGA;IC7CM,YAAA;GN8ZH;EKjXH;ICrCI,YAAA;GNyZD;EKpXH;ICrCI,oBAAA;GN4ZD;EKvXH;ICrCI,oBAAA;GN+ZD;EK1XH;ICrCI,WAAA;GNkaD;EK7XH;ICrCI,oBAAA;GNqaD;EKhYH;ICrCI,oBAAA;GNwaD;EKnYH;ICrCI,WAAA;GN2aD;EKtYH;ICrCI,oBAAA;GN8aD;EKzYH;ICrCI,oBAAA;GNibD;EK5YH;ICrCI,WAAA;GNobD;EK/YH;ICrCI,oBAAA;GNubD;EKlZH;ICrCI,mBAAA;GN0bD;EKrZH;ICtBI,YAAA;GN8aD;EKxZH;ICtBI,oBAAA;GNibD;EK3ZH;ICtBI,oBAAA;GNobD;EK9ZH;ICtBI,WAAA;GNubD;EKjaH;ICtBI,oBAAA;GN0bD;EKpaH;ICtBI,oBAAA;GN6bD;EKvaH;ICtBI,WAAA;GNgcD;EK1aH;ICtBI,oBAAA;GNmcD;EK7aH;ICtBI,oBAAA;GNscD;EKhbH;ICtBI,WAAA;GNycD;EKnbH;ICtBI,oBAAA;GN4cD;EKtbH;ICtBI,mBAAA;GN+cD;EKzbH;ICjBI,YAAA;GN6cD;EK5bH;IChCI,WAAA;GN+dD;EK/bH;IChCI,mBAAA;GNkeD;EKlcH;IChCI,mBAAA;GNqeD;EKrcH;IChCI,UAAA;GNweD;EKxcH;IChCI,mBAAA;GN2eD;EK3cH;IChCI,mBAAA;GN8eD;EK9cH;IChCI,UAAA;GNifD;EKjdH;IChCI,mBAAA;GNofD;EKpdH;IChCI,mBAAA;GNufD;EKvdH;IChCI,UAAA;GN0fD;EK1dH;IChCI,mBAAA;GN6fD;EK7dH;IChCI,kBAAA;GNggBD;EKheH;IC3BI,WAAA;GN8fD;EKneH;ICZI,kBAAA;GNkfD;EKteH;ICZI,0BAAA;GNqfD;EKzeH;ICZI,0BAAA;GNwfD;EK5eH;ICZI,iBAAA;GN2fD;EK/eH;ICZI,0BAAA;GN8fD;EKlfH;ICZI,0BAAA;GNigBD;EKrfH;ICZI,iBAAA;GNogBD;EKxfH;ICZI,0BAAA;GNugBD;EK3fH;ICZI,0BAAA;GN0gBD;EK9fH;ICZI,iBAAA;GN6gBD;EKjgBH;ICZI,0BAAA;GNghBD;EKpgBH;ICZI,yBAAA;GNmhBD;EKvgBH;ICZI,gBAAA;GNshBD;CACF;AK3gBD;EAAA;IC7CM,YAAA;GN4jBH;EK/gBH;ICrCI,YAAA;GNujBD;EKlhBH;ICrCI,oBAAA;GN0jBD;EKrhBH;ICrCI,oBAAA;GN6jBD;EKxhBH;ICrCI,WAAA;GNgkBD;EK3hBH;ICrCI,oBAAA;GNmkBD;EK9hBH;ICrCI,oBAAA;GNskBD;EKjiBH;ICrCI,WAAA;GNykBD;EKpiBH;ICrCI,oBAAA;GN4kBD;EKviBH;ICrCI,oBAAA;GN+kBD;EK1iBH;ICrCI,WAAA;GNklBD;EK7iBH;ICrCI,oBAAA;GNqlBD;EKhjBH;ICrCI,mBAAA;GNwlBD;EKnjBH;ICtBI,YAAA;GN4kBD;EKtjBH;ICtBI,oBAAA;GN+kBD;EKzjBH;ICtBI,oBAAA;GNklBD;EK5jBH;ICtBI,WAAA;GNqlBD;EK/jBH;ICtBI,oBAAA;GNwlBD;EKlkBH;ICtBI,oBAAA;GN2lBD;EKrkBH;ICtBI,WAAA;GN8lBD;EKxkBH;ICtBI,oBAAA;GNimBD;EK3kBH;ICtBI,oBAAA;GNomBD;EK9kBH;ICtBI,WAAA;GNumBD;EKjlBH;ICtBI,oBAAA;GN0mBD;EKplBH;ICtBI,mBAAA;GN6mBD;EKvlBH;ICjBI,YAAA;GN2mBD;EK1lBH;IChCI,WAAA;GN6nBD;EK7lBH;IChCI,mBAAA;GNgoBD;EKhmBH;IChCI,mBAAA;GNmoBD;EKnmBH;IChCI,UAAA;GNsoBD;EKtmBH;IChCI,mBAAA;GNyoBD;EKzmBH;IChCI,mBAAA;GN4oBD;EK5mBH;IChCI,UAAA;GN+oBD;EK/mBH;IChCI,mBAAA;GNkpBD;EKlnBH;IChCI,mBAAA;GNqpBD;EKrnBH;IChCI,UAAA;GNwpBD;EKxnBH;IChCI,mBAAA;GN2pBD;EK3nBH;IChCI,kBAAA;GN8pBD;EK9nBH;IC3BI,WAAA;GN4pBD;EKjoBH;ICZI,kBAAA;GNgpBD;EKpoBH;ICZI,0BAAA;GNmpBD;EKvoBH;ICZI,0BAAA;GNspBD;EK1oBH;ICZI,iBAAA;GNypBD;EK7oBH;ICZI,0BAAA;GN4pBD;EKhpBH;ICZI,0BAAA;GN+pBD;EKnpBH;ICZI,iBAAA;GNkqBD;EKtpBH;ICZI,0BAAA;GNqqBD;EKzpBH;ICZI,0BAAA;GNwqBD;EK5pBH;ICZI,iBAAA;GN2qBD;EK/pBH;ICZI,0BAAA;GN8qBD;EKlqBH;ICZI,yBAAA;GNirBD;EKrqBH;ICZI,gBAAA;GNorBD;CACF;AOhvBC;;;;;;;;EAEE,aAAA;EACA,eAAA;CPwvBH;AOtvBC;;;;EACE,YAAA;CP2vBH;AQnwBD;ECRE,eAAA;EACA,kBAAA;EACA,mBAAA;CT8wBD;AQrwBD;EACE,wBAAA;CRuwBD;AQrwBD;EACE,uBAAA;CRuwBD;AQ/vBD;EACE,yBAAA;CRiwBD;AQ/vBD;EACE,0BAAA;CRiwBD;AQ/vBD;EACE,mBAAA;CRiwBD;AQ/vBD;EEzBE,YAAA;EACA,mBAAA;EACA,kBAAA;EACA,8BAAA;EACA,UAAA;CV2xBD;AQ7vBD;EACE,yBAAA;EACA,8BAAA;CR+vBD;AQxvBD;EACE,gBAAA;CR0vBD;;AAED;;;GAGG;AACH;gCACgC;AWpzBhC;EACE,2BAAA;EACA,kEAAA;EACA,mbAAA;EAMA,oBAAA;EACA,mBAAA;CXizBD;AY3zBD;EACE,sBAAA;EACA,8CAAA;EACA,mBAAA;EACA,qBAAA;EACA,oCAAA;EACA,mCAAA;EACA,mCAAA;UAAA,2BAAA;CZ6zBD;AACD,8DAA8D;Aap0B9D;EACE,wBAAA;EACA,oBAAA;EACA,qBAAA;Cbs0BD;Aap0BD;EAAuB,eAAA;Cbu0BtB;Aat0BD;EAAuB,eAAA;Cby0BtB;Aax0BD;EAAuB,eAAA;Cb20BtB;Aa10BD;EAAuB,eAAA;Cb60BtB;Acv1BD;EACE,oBAAA;EACA,mBAAA;Cdy1BD;Ae11BD;EACE,gBAAA;EACA,0BAAA;EACA,sBAAA;Cf41BD;Ae/1BD;EAIS,mBAAA;Cf81BR;Ae51BD;EACE,mBAAA;EACA,oBAAA;EACA,oBAAA;EACA,kBAAA;EACA,mBAAA;Cf81BD;Ae71BC;EACE,oBAAA;Cf+1BH;AgB52BD;EACE,0BAAA;EACA,6BAAA;EACA,oBAAA;ChB82BD;AgB32BD;EAAc,aAAA;ChB82Bb;AgB72BD;EAAa,YAAA;ChBg3BZ;AgB72BC;EAAc,mBAAA;ChBg3Bf;AgB/2BC;EAAe,kBAAA;ChBk3BhB;AiB73BD;EACE,8CAAA;EACQ,sCAAA;CjB+3BT;AiB53BD;EACE,gDAAA;EACQ,wCAAA;CjB83BT;AiB33BD;EACE;IACE,gCAAA;IACQ,wBAAA;GjB63BT;EiB33BD;IACE,kCAAA;IACQ,0BAAA;GjB63BT;CACF;AiB13BD;EACE;IACE,gCAAA;IACQ,wBAAA;GjB43BT;EiB13BD;IACE,kCAAA;IACQ,0BAAA;GjB43BT;CACF;AkBz5BD;ECYE,iEAAA;EACA,iCAAA;EAEQ,yBAAA;CnBg5BT;AkB95BD;ECWE,iEAAA;EACA,kCAAA;EAEQ,0BAAA;CnBs5BT;AkBn6BD;ECUE,iEAAA;EACA,kCAAA;EAEQ,0BAAA;CnB45BT;AkBv6BD;ECeE,2EAAA;EACA,gCAAA;EAEQ,wBAAA;CnB25BT;AkB56BD;ECcE,2EAAA;EACA,gCAAA;EAEQ,wBAAA;CnBi6BT;AkB76BD;;;;;EAKE,qBAAA;UAAA,aAAA;ClB+6BD;AoB97BD;EACE,mBAAA;EACA,sBAAA;EACA,WAAA;EACA,YAAA;EACA,iBAAA;EACA,uBAAA;CpBg8BD;AoB97BD;;EACE,mBAAA;EACA,QAAA;EACA,YAAA;EACA,mBAAA;CpBi8BD;AoB/7BD;EAA6B,qBAAA;CpBk8B5B;AoBj8BD;EAA6B,eAAA;CpBo8B5B;AoBn8BD;EAA4B,eAAA;CpBs8B3B;AACD;oEACoE;AqBx9BpE;EAAiC,iBAAA;CrB29BhC;AqB19BD;EAAiC,iBAAA;CrB69BhC;AqB59BD;EAAkC,iBAAA;CrB+9BjC;AqB99BD;EAAsC,iBAAA;CrBi+BrC;AqBh+BD;EAAiC,iBAAA;CrBm+BhC;AqBl+BD;EAAgC,iBAAA;CrBq+B/B;AqBp+BD;EAAkC,iBAAA;CrBu+BjC;AqBt+BD;EAAgC,iBAAA;CrBy+B/B;AqBx+BD;EAAgC,iBAAA;CrB2+B/B;AqB1+BD;EAAoC,iBAAA;CrB6+BnC;AqB5+BD;EAA8B,iBAAA;CrB++B7B;AqB9+BD;EAAmC,iBAAA;CrBi/BlC;AqBh/BD;EAAiC,iBAAA;CrBm/BhC;AqBl/BD;;;EAEiC,iBAAA;CrBq/BhC;AqBp/BD;EAAuC,iBAAA;CrBu/BtC;AqBt/BD;EAAwC,iBAAA;CrBy/BvC;AqBx/BD;EAAqC,iBAAA;CrB2/BpC;AqB1/BD;EAAkC,iBAAA;CrB6/BjC;AqB5/BD;;EAC+B,iBAAA;CrB+/B9B;AqB9/BD;EAAmC,iBAAA;CrBigClC;AqBhgCD;EAAgC,iBAAA;CrBmgC/B;AqBlgCD;EAAkC,iBAAA;CrBqgCjC;AqBpgCD;EAAmC,iBAAA;CrBugClC;AqBtgCD;EAAgC,iBAAA;CrBygC/B;AqBxgCD;EAAoC,iBAAA;CrB2gCnC;AqB1gCD;EAA+C,iBAAA;CrB6gC9C;AqB5gCD;EAA6C,iBAAA;CrB+gC5C;AqB9gCD;EAAiC,iBAAA;CrBihChC;AqBhhCD;EAAyC,iBAAA;CrBmhCxC;AqBlhCD;;EACkC,iBAAA;CrBqhCjC;AqBphCD;EAAmC,iBAAA;CrBuhClC;AqBthCD;EAAoC,iBAAA;CrByhCnC;AqBxhCD;EAAgC,iBAAA;CrB2hC/B;AqB1hCD;EAAgC,iBAAA;CrB6hC/B;AqB5hCD;EAAsC,iBAAA;CrB+hCrC;AqB9hCD;EAAsC,iBAAA;CrBiiCrC;AqBhiCD;EAAuC,iBAAA;CrBmiCtC;AqBliCD;EAAqC,iBAAA;CrBqiCpC;AqBpiCD;EAAkC,iBAAA;CrBuiCjC;AqBtiCD;EAAmC,iBAAA;CrByiClC;AqBxiCD;EAA+B,iBAAA;CrB2iC9B;AqB1iCD;EAAgC,iBAAA;CrB6iC/B;AqB5iCD;EAAgC,iBAAA;CrB+iC/B;AqB9iCD;EAAoC,iBAAA;CrBijCnC;AqBhjCD;EAAiC,iBAAA;CrBmjChC;AqBljCD;EAAkC,iBAAA;CrBqjCjC;AqBpjCD;EAAgC,iBAAA;CrBujC/B;AqBtjCD;EAAgC,iBAAA;CrByjC/B;AqBxjCD;EAAkC,iBAAA;CrB2jCjC;AqB1jCD;EAAuC,iBAAA;CrB6jCtC;AqB5jCD;EAAsC,iBAAA;CrB+jCrC;AqB9jCD;EAAsC,iBAAA;CrBikCrC;AqBhkCD;EAAwC,iBAAA;CrBmkCvC;AqBlkCD;EAAuC,iBAAA;CrBqkCtC;AqBpkCD;EAAyC,iBAAA;CrBukCxC;AqBtkCD;EAAgC,iBAAA;CrBykC/B;AqBxkCD;;EACmC,iBAAA;CrB2kClC;AqB1kCD;EAAkC,iBAAA;CrB6kCjC;AqB5kCD;EAAwC,iBAAA;CrB+kCvC;AqB9kCD;;;EAEqC,iBAAA;CrBilCpC;AqBhlCD;EAAkC,iBAAA;CrBmlCjC;AqBllCD;EAAsC,iBAAA;CrBqlCrC;AqBplCD;EAAkC,iBAAA;CrBulCjC;AqBtlCD;EAAgC,iBAAA;CrBylC/B;AqBxlCD;;EAC2C,iBAAA;CrB2lC1C;AqB1lCD;EAA0C,iBAAA;CrB6lCzC;AqB5lCD;EAA0C,iBAAA;CrB+lCzC;AqB9lCD;EAAkC,iBAAA;CrBimCjC;AqBhmCD;EAAyC,iBAAA;CrBmmCxC;AqBlmCD;EAAyC,iBAAA;CrBqmCxC;AqBpmCD;EAAoC,iBAAA;CrBumCnC;AqBtmCD;EAAgC,iBAAA;CrBymC/B;AqBxmCD;EAAiC,iBAAA;CrB2mChC;AqB1mCD;EAAgC,iBAAA;CrB6mC/B;AqB5mCD;EAAmC,iBAAA;CrB+mClC;AqB9mCD;EAAwC,iBAAA;CrBinCvC;AqBhnCD;EAAwC,iBAAA;CrBmnCvC;AqBlnCD;EAAiC,iBAAA;CrBqnChC;AqBpnCD;EAAwC,iBAAA;CrBunCvC;AqBtnCD;EAAyC,iBAAA;CrBynCxC;AqBxnCD;EAAuC,iBAAA;CrB2nCtC;AqB1nCD;EAAwC,iBAAA;CrB6nCvC;AqB5nCD;EAAwC,iBAAA;CrB+nCvC;AqB9nCD;EAAwC,iBAAA;CrBioCvC;AqBhoCD;EAA2C,iBAAA;CrBmoC1C;AqBloCD;EAAuC,iBAAA;CrBqoCtC;AqBpoCD;EAAsC,iBAAA;CrBuoCrC;AqBtoCD;EAA0C,iBAAA;CrByoCzC;AqBxoCD;EAA0C,iBAAA;CrB2oCzC;AqB1oCD;EAA+B,iBAAA;CrB6oC9B;AqB5oCD;EAAsC,iBAAA;CrB+oCrC;AqB9oCD;EAAuC,iBAAA;CrBipCtC;AqBhpCD;EAAoC,iBAAA;CrBmpCnC;AqBlpCD;EAAsC,iBAAA;CrBqpCrC;AqBppCD;;EACiC,iBAAA;CrBupChC;AqBtpCD;EAAkC,iBAAA;CrBypCjC;AqBxpCD;EAAoC,iBAAA;CrB2pCnC;AqB1pCD;EAAgC,iBAAA;CrB6pC/B;AqB5pCD;EAAiC,iBAAA;CrB+pChC;AqB9pCD;EAAoC,iBAAA;CrBiqCnC;AqBhqCD;EAA8C,iBAAA;CrBmqC7C;AqBlqCD;EAAgC,iBAAA;CrBqqC/B;AqBpqCD;EAAgC,iBAAA;CrBuqC/B;AqBtqCD;EAAgC,iBAAA;CrByqC/B;AqBxqCD;EAA+B,iBAAA;CrB2qC9B;AqB1qCD;EAAqC,iBAAA;CrB6qCpC;AqB5qCD;;EACgD,iBAAA;CrB+qC/C;AqB9qCD;EAAiC,iBAAA;CrBirChC;AqBhrCD;EAAoC,iBAAA;CrBmrCnC;AqBlrCD;EAAkC,iBAAA;CrBqrCjC;AqBprCD;EAAmC,iBAAA;CrBurClC;AqBtrCD;EAAkC,iBAAA;CrByrCjC;AqBxrCD;EAAsC,iBAAA;CrB2rCrC;AqB1rCD;EAAwC,iBAAA;CrB6rCvC;AqB5rCD;EAAmC,iBAAA;CrB+rClC;AqB9rCD;EAAyC,iBAAA;CrBisCxC;AqBhsCD;EAAkC,iBAAA;CrBmsCjC;AqBlsCD;EAAuC,iBAAA;CrBqsCtC;AqBpsCD;EAAoC,iBAAA;CrBusCnC;AqBtsCD;EAAoC,iBAAA;CrBysCnC;AqBxsCD;;EACqC,iBAAA;CrB2sCpC;AqB1sCD;EAA0C,iBAAA;CrB6sCzC;AqB5sCD;EAA2C,iBAAA;CrB+sC1C;AqB9sCD;EAAwC,iBAAA;CrBitCvC;AqBhtCD;EAA+B,iBAAA;CrBmtC9B;AqBltCD;;EACgC,iBAAA;CrBqtC/B;AqBptCD;EAAoC,iBAAA;CrButCnC;AqBttCD;EAAuC,iBAAA;CrBytCtC;AqBxtCD;EAAyC,iBAAA;CrB2tCxC;AqB1tCD;EAAqC,iBAAA;CrB6tCpC;AqB5tCD;EAAmC,iBAAA;CrB+tClC;AqB9tCD;EAAoC,iBAAA;CrBiuCnC;AqBhuCD;EAA2C,iBAAA;CrBmuC1C;AqBluCD;EAAsC,iBAAA;CrBquCrC;AqBpuCD;EAAyC,iBAAA;CrBuuCxC;AqBtuCD;EAAmC,iBAAA;CrByuClC;AqBxuCD;EAAkC,iBAAA;CrB2uCjC;AqB1uCD;EAAyC,iBAAA;CrB6uCxC;AqB5uCD;EAAkC,iBAAA;CrB+uCjC;AqB9uCD;EAAmC,iBAAA;CrBivClC;AqBhvCD;EAAiC,iBAAA;CrBmvChC;AqBlvCD;EAAoC,iBAAA;CrBqvCnC;AqBpvCD;EAAsC,iBAAA;CrBuvCrC;AqBtvCD;EAAwC,iBAAA;CrByvCvC;AqBxvCD;EAAmC,iBAAA;CrB2vClC;AqB1vCD;;EACoC,iBAAA;CrB6vCnC;AqB5vCD;EAAkC,iBAAA;CrB+vCjC;AqB9vCD;EAAkC,iBAAA;CrBiwCjC;AqBhwCD;EAAuC,iBAAA;CrBmwCtC;AqBlwCD;EAA+B,iBAAA;CrBqwC9B;AqBpwCD;EAAiC,iBAAA;CrBuwChC;AqBtwCD;EAAoC,iBAAA;CrBywCnC;AqBxwCD;EAAgC,iBAAA;CrB2wC/B;AqB1wCD;EAAuC,iBAAA;CrB6wCtC;AqB5wCD;EAAwC,iBAAA;CrB+wCvC;AqB9wCD;EAAuC,iBAAA;CrBixCtC;AqBhxCD;EAAqC,iBAAA;CrBmxCpC;AqBlxCD;EAAuC,iBAAA;CrBqxCtC;AqBpxCD;EAA6C,iBAAA;CrBuxC5C;AqBtxCD;EAA8C,iBAAA;CrByxC7C;AqBxxCD;EAA2C,iBAAA;CrB2xC1C;AqB1xCD;EAA6C,iBAAA;CrB6xC5C;AqB5xCD;EAAiC,iBAAA;CrB+xChC;AqB9xCD;EAAkC,iBAAA;CrBiyCjC;AqBhyCD;EAAiC,iBAAA;CrBmyChC;AqBlyCD;EAAkC,iBAAA;CrBqyCjC;AqBpyCD;EAAqC,iBAAA;CrBuyCpC;AqBtyCD;EAAsC,iBAAA;CrByyCrC;AqBxyCD;;EACiC,iBAAA;CrB2yChC;AqB1yCD;;EACgC,iBAAA;CrB6yC/B;AqB5yCD;EAAiC,iBAAA;CrB+yChC;AqB9yCD;EAAiC,iBAAA;CrBizChC;AqBhzCD;;EACoC,iBAAA;CrBmzCnC;AqBlzCD;;EACmC,iBAAA;CrBqzClC;AqBpzCD;EAAqC,iBAAA;CrBuzCpC;AqBtzCD;;EACoC,iBAAA;CrByzCnC;AqBxzCD;EAAkC,iBAAA;CrB2zCjC;AqB1zCD;;;EAEgC,iBAAA;CrB6zC/B;AqB5zCD;EAAmC,iBAAA;CrB+zClC;AqB9zCD;EAAmC,iBAAA;CrBi0ClC;AqBh0CD;EAAyC,iBAAA;CrBm0CxC;AqBl0CD;EAAqC,iBAAA;CrBq0CpC;AqBp0CD;EAAiC,iBAAA;CrBu0ChC;AqBt0CD;EAAiC,iBAAA;CrBy0ChC;AqBx0CD;EAAiC,iBAAA;CrB20ChC;AqB10CD;EAAqC,iBAAA;CrB60CpC;AqB50CD;EAA4C,iBAAA;CrB+0C3C;AqB90CD;EAA8C,iBAAA;CrBi1C7C;AqBh1CD;EAAuC,iBAAA;CrBm1CtC;AqBl1CD;EAAiC,iBAAA;CrBq1ChC;AqBp1CD;EAAsC,iBAAA;CrBu1CrC;AqBt1CD;EAAoC,iBAAA;CrBy1CnC;AqBx1CD;EAAsC,iBAAA;CrB21CrC;AqB11CD;EAAuC,iBAAA;CrB61CtC;AqB51CD;EAAmC,iBAAA;CrB+1ClC;AqB91CD;;EACgC,iBAAA;CrBi2C/B;AqBh2CD;;EACqC,iBAAA;CrBm2CpC;AqBl2CD;;EACoC,iBAAA;CrBq2CnC;AqBp2CD;EAAoC,iBAAA;CrBu2CnC;AqBt2CD;EAAoC,iBAAA;CrBy2CnC;AqBx2CD;;EACgC,iBAAA;CrB22C/B;AqB12CD;;EACiC,iBAAA;CrB62ChC;AqB52CD;;EACsC,iBAAA;CrB+2CrC;AqB92CD;EAAqC,iBAAA;CrBi3CpC;AqBh3CD;EAAsC,iBAAA;CrBm3CrC;AqBl3CD;;EACgC,iBAAA;CrBq3C/B;AqBp3CD;EAAmC,iBAAA;CrBu3ClC;AqBt3CD;EAAoC,iBAAA;CrBy3CnC;AqBx3CD;;EACqC,iBAAA;CrB23CpC;AqB13CD;EAAuC,iBAAA;CrB63CtC;AqB53CD;EAAoC,iBAAA;CrB+3CnC;AqB93CD;EAA0C,iBAAA;CrBi4CzC;AqBh4CD;EAAwC,iBAAA;CrBm4CvC;AqBl4CD;EAAmC,iBAAA;CrBq4ClC;AqBp4CD;EAAuC,iBAAA;CrBu4CtC;AqBt4CD;EAAoC,iBAAA;CrBy4CnC;AqBx4CD;EAAkC,iBAAA;CrB24CjC;AqB14CD;EAAkC,iBAAA;CrB64CjC;AqB54CD;EAAmC,iBAAA;CrB+4ClC;AqB94CD;EAAuC,iBAAA;CrBi5CtC;AqBh5CD;EAAsC,iBAAA;CrBm5CrC;AqBl5CD;EAAsC,iBAAA;CrBq5CrC;AqBp5CD;EAAqC,iBAAA;CrBu5CpC;AqBt5CD;EAAkC,iBAAA;CrBy5CjC;AqBx5CD;EAAuC,iBAAA;CrB25CtC;AqB15CD;EAAgC,iBAAA;CrB65C/B;AqB55CD;EAAoC,iBAAA;CrB+5CnC;AqB95CD;EAAuC,iBAAA;CrBi6CtC;AqBh6CD;EAA6C,iBAAA;CrBm6C5C;AqBl6CD;EAA8C,iBAAA;CrBq6C7C;AqBp6CD;EAA2C,iBAAA;CrBu6C1C;AqBt6CD;EAA6C,iBAAA;CrBy6C5C;AqBx6CD;EAAsC,iBAAA;CrB26CrC;AqB16CD;EAAuC,iBAAA;CrB66CtC;AqB56CD;EAAoC,iBAAA;CrB+6CnC;AqB96CD;EAAsC,iBAAA;CrBi7CrC;AqBh7CD;EAAmC,iBAAA;CrBm7ClC;AqBl7CD;EAAkC,iBAAA;CrBq7CjC;AqBp7CD;EAAkC,iBAAA;CrBu7CjC;AqBt7CD;;EACkC,iBAAA;CrBy7CjC;AqBx7CD;EAAoC,iBAAA;CrB27CnC;AqB17CD;EAAsC,iBAAA;CrB67CrC;AqB57CD;EAAuC,iBAAA;CrB+7CtC;AqB97CD;EAAmC,iBAAA;CrBi8ClC;AqBh8CD;EAAkC,iBAAA;CrBm8CjC;AqBl8CD;;EACiC,iBAAA;CrBq8ChC;AqBp8CD;EAAsC,iBAAA;CrBu8CrC;AqBt8CD;EAAoC,iBAAA;CrBy8CnC;AqBx8CD;EAAyC,iBAAA;CrB28CxC;AqB18CD;EAAmC,iBAAA;CrB68ClC;AqB58CD;EAAmC,iBAAA;CrB+8ClC;AqB98CD;EAAiC,iBAAA;CrBi9ChC;AqBh9CD;EAAmC,iBAAA;CrBm9ClC;AqBl9CD;EAAsC,iBAAA;CrBq9CrC;AqBp9CD;EAAkC,iBAAA;CrBu9CjC;AqBt9CD;EAA0C,iBAAA;CrBy9CzC;AqBx9CD;EAAoC,iBAAA;CrB29CnC;AqB19CD;EAAgC,iBAAA;CrB69C/B;AqB59CD;;EACqC,iBAAA;CrB+9CpC;AqB99CD;;;EAEuC,iBAAA;CrBi+CtC;AqBh+CD;EAA0C,iBAAA;CrBm+CzC;AqBl+CD;EAAgC,iBAAA;CrBq+C/B;AqBp+CD;EAAqC,iBAAA;CrBu+CpC;AqBt+CD;;EACwC,iBAAA;CrBy+CvC;AqBx+CD;EAAoC,iBAAA;CrB2+CnC;AqB1+CD;EAAgC,iBAAA;CrB6+C/B;AqB5+CD;EAAuC,iBAAA;CrB++CtC;AqB9+CD;EAAuC,iBAAA;CrBi/CtC;AqBh/CD;EAAqC,iBAAA;CrBm/CpC;AqBl/CD;EAAkC,iBAAA;CrBq/CjC;AqBp/CD;EAAwC,iBAAA;CrBu/CvC;AqBt/CD;EAAsC,iBAAA;CrBy/CrC;AqBx/CD;EAA4C,iBAAA;CrB2/C3C;AqB1/CD;EAAkC,iBAAA;CrB6/CjC;AqB5/CD;EAAsC,iBAAA;CrB+/CrC;AqB9/CD;EAA6C,iBAAA;CrBigD5C;AqBhgDD;EAAkC,iBAAA;CrBmgDjC;AqBlgDD;EAAkC,iBAAA;CrBqgDjC;AqBpgDD;EAA+C,iBAAA;CrBugD9C;AqBtgDD;EAAgD,iBAAA;CrBygD/C;AqBxgDD;EAA6C,iBAAA;CrB2gD5C;AqB1gDD;EAA+C,iBAAA;CrB6gD9C;AqB5gDD;EAAiC,iBAAA;CrB+gDhC;AqB9gDD;EAAgC,iBAAA;CrBihD/B;AqBhhDD;EAAkC,iBAAA;CrBmhDjC;AqBlhDD;EAAsC,iBAAA;CrBqhDrC;AqBphDD;EAAoC,iBAAA;CrBuhDnC;AqBthDD;EAAsC,iBAAA;CrByhDrC;AqBxhDD;EAAsC,iBAAA;CrB2hDrC;AqB1hDD;EAAsC,iBAAA;CrB6hDrC;AqB5hDD;EAAuC,iBAAA;CrB+hDtC;AqB9hDD;EAAkC,iBAAA;CrBiiDjC;AqBhiDD;EAAwC,iBAAA;CrBmiDvC;AqBliDD;EAA0C,iBAAA;CrBqiDzC;AqBpiDD;EAAoC,iBAAA;CrBuiDnC;AqBtiDD;EAAsC,iBAAA;CrByiDrC;AqBxiDD;EAAwC,iBAAA;CrB2iDvC;AqB1iDD;EAAyC,iBAAA;CrB6iDxC;AqB5iDD;EAAgD,iBAAA;CrB+iD/C;AqB9iDD;EAAwC,iBAAA;CrBijDvC;AqBhjDD;EAAmC,iBAAA;CrBmjDlC;AqBljDD;;EAC+C,iBAAA;CrBqjD9C;AqBpjDD;;EAC6C,iBAAA;CrBujD5C;AqBtjDD;;EACgD,iBAAA;CrByjD/C;AqBxjDD;;EAC+B,iBAAA;CrB2jD9B;AqB1jDD;EAA+B,iBAAA;CrB6jD9B;AqB5jDD;;EAC+B,iBAAA;CrB+jD9B;AqB9jDD;;EAC+B,iBAAA;CrBikD9B;AqBhkDD;;;;EAG+B,iBAAA;CrBmkD9B;AqBlkDD;;;EAE+B,iBAAA;CrBqkD9B;AqBpkDD;;EAC+B,iBAAA;CrBukD9B;AqBtkDD;;EAC+B,iBAAA;CrBykD9B;AqBxkDD;EAAgC,iBAAA;CrB2kD/B;AqB1kDD;EAAqC,iBAAA;CrB6kDpC;AqB5kDD;EAA0C,iBAAA;CrB+kDzC;AqB9kDD;EAA2C,iBAAA;CrBilD1C;AqBhlDD;EAA2C,iBAAA;CrBmlD1C;AqBllDD;EAA4C,iBAAA;CrBqlD3C;AqBplDD;EAA4C,iBAAA;CrBulD3C;AqBtlDD;EAA6C,iBAAA;CrBylD5C;AqBxlDD;EAAqC,iBAAA;CrB2lDpC;AqB1lDD;EAAuC,iBAAA;CrB6lDtC;AqB5lDD;EAA0C,iBAAA;CrB+lDzC;AqB9lDD;EAAmC,iBAAA;CrBimDlC;AqBhmDD;EAAgC,iBAAA;CrBmmD/B;AqBlmDD;EAAuC,iBAAA;CrBqmDtC;AqBpmDD;EAAwC,iBAAA;CrBumDvC;AqBtmDD;EAAmC,iBAAA;CrBymDlC;AqBxmDD;EAA0C,iBAAA;CrB2mDzC;AqB1mDD;EAAqC,iBAAA;CrB6mDpC;AqB5mDD;EAAkC,iBAAA;CrB+mDjC;AqB9mDD;EAA+B,iBAAA;CrBinD9B;AqBhnDD;EAAqC,iBAAA;CrBmnDpC;AqBlnDD;EAA4C,iBAAA;CrBqnD3C;AqBpnDD;EAAkC,iBAAA;CrBunDjC;AqBtnDD;EAAyC,iBAAA;CrBynDxC;AqBxnDD;EAA2C,iBAAA;CrB2nD1C;AqB1nDD;EAAyC,iBAAA;CrB6nDxC;AqB5nDD;EAA2C,iBAAA;CrB+nD1C;AqB9nDD;EAA4C,iBAAA;CrBioD3C;AqBhoDD;EAAiC,iBAAA;CrBmoDhC;AqBloDD;EAAmC,iBAAA;CrBqoDlC;AqBpoDD;EAAmC,iBAAA;CrBuoDlC;AqBtoDD;EAAiC,iBAAA;CrByoDhC;AqBxoDD;EAAoC,iBAAA;CrB2oDnC;AqB1oDD;EAAiC,iBAAA;CrB6oDhC;AqB5oDD;EAAsC,iBAAA;CrB+oDrC;AqB9oDD;EAAkC,iBAAA;CrBipDjC;AqBhpDD;EAAkC,iBAAA;CrBmpDjC;AqBlpDD;EAAgC,iBAAA;CrBqpD/B;AqBppDD;;EACoC,iBAAA;CrBupDnC;AqBtpDD;EAAiC,iBAAA;CrBypDhC;AqBxpDD;EAAkC,iBAAA;CrB2pDjC;AqB1pDD;EAAmC,iBAAA;CrB6pDlC;AqB5pDD;EAA+B,iBAAA;CrB+pD9B;AqB9pDD;EAA8B,iBAAA;CrBiqD7B;AqBhqDD;EAAiC,iBAAA;CrBmqDhC;AqBlqDD;EAAkC,iBAAA;CrBqqDjC;AqBpqDD;EAAqC,iBAAA;CrBuqDpC;AqBtqDD;EAA0C,iBAAA;CrByqDzC;AqBxqDD;EAAgD,iBAAA;CrB2qD/C;AqB1qDD;EAA+C,iBAAA;CrB6qD9C;AqB5qDD;;EAC+C,iBAAA;CrB+qD9C;AqB9qDD;EAAwC,iBAAA;CrBirDvC;AqBhrDD;EAAsC,iBAAA;CrBmrDrC;AqBlrDD;EAAwC,iBAAA;CrBqrDvC;AqBprDD;;EAC+B,iBAAA;CrBurD9B;AqBtrDD;EAAyC,iBAAA;CrByrDxC;AqBxrDD;EAAyC,iBAAA;CrB2rDxC;AqB1rDD;EAAiC,iBAAA;CrB6rDhC;AqB5rDD;EAA2C,iBAAA;CrB+rD1C;AqB9rDD;EAAqC,iBAAA;CrBisDpC;AqBhsDD;EAAkC,iBAAA;CrBmsDjC;AqBlsDD;;;EAEsC,iBAAA;CrBqsDrC;AqBpsDD;;EAC0C,iBAAA;CrBusDzC;AqBtsDD;EAAiC,iBAAA;CrBysDhC;AqBxsDD;EAAkC,iBAAA;CrB2sDjC;AqB1sDD;EAAkC,iBAAA;CrB6sDjC;AqB5sDD;EAAyC,iBAAA;CrB+sDxC;AqB9sDD;EAA8C,iBAAA;CrBitD7C;AqBhtDD;EAAuC,iBAAA;CrBmtDtC;AqBltDD;EAAqC,iBAAA;CrBqtDpC;AqBptDD;EAAgC,iBAAA;CrButD/B;AqBttDD;EAAsC,iBAAA;CrBytDrC;AqBxtDD;EAA0C,iBAAA;CrB2tDzC;AqB1tDD;EAAkC,iBAAA;CrB6tDjC;AqB5tDD;EAAkC,iBAAA;CrB+tDjC;AqB9tDD;EAAoC,iBAAA;CrBiuDnC;AqBhuDD;EAA+B,iBAAA;CrBmuD9B;AqBluDD;EAAoC,iBAAA;CrBquDnC;AqBpuDD;EAAiC,iBAAA;CrBuuDhC;AqBtuDD;EAA+B,iBAAA;CrByuD9B;AqBxuDD;EAAiC,iBAAA;CrB2uDhC;AqB1uDD;EAAgC,iBAAA;CrB6uD/B;AqB5uDD;EAAiC,iBAAA;CrB+uDhC;AqB9uDD;EAAmC,iBAAA;CrBivDlC;AqBhvDD;EAA0C,iBAAA;CrBmvDzC;AqBlvDD;EAAiC,iBAAA;CrBqvDhC;AqBpvDD;EAAwC,iBAAA;CrBuvDvC;AqBtvDD;EAAmC,iBAAA;CrByvDlC;AqBxvDD;;EAC+B,iBAAA;CrB2vD9B;AqB1vDD;;EACgC,iBAAA;CrB6vD/B;AqB5vDD;EAAgC,iBAAA;CrB+vD/B;AqB9vDD;EAAmC,iBAAA;CrBiwDlC;AqBhwDD;EAAsC,iBAAA;CrBmwDrC;AqBlwDD;EAAsC,iBAAA;CrBqwDrC;AqBpwDD;EAAoC,iBAAA;CrBuwDnC;AqBtwDD;EAAsC,iBAAA;CrBywDrC;AqBxwDD;EAAuC,iBAAA;CrB2wDtC;AqB1wDD;EAAwC,iBAAA;CrB6wDvC;AqB5wDD;EAA6C,iBAAA;CrB+wD5C;AqB9wDD;;;EAEwC,iBAAA;CrBixDvC;AqBhxDD;;EAC0C,iBAAA;CrBmxDzC;AqBlxDD;;EACwC,iBAAA;CrBqxDvC;AqBpxDD;;EACwC,iBAAA;CrBuxDvC;AqBtxDD;EAAuC,iBAAA;CrByxDtC;AqBxxDD;EAAgC,iBAAA;CrB2xD/B;AqB1xDD;EAAmC,iBAAA;CrB6xDlC;AqB5xDD;EAAoC,iBAAA;CrB+xDnC;AqB9xDD;;;;;EAIqC,iBAAA;CrBiyDpC;AqBhyDD;EAA0C,iBAAA;CrBmyDzC;AqBlyDD;;EACiC,iBAAA;CrBqyDhC;AqBpyDD;;EACkC,iBAAA;CrBuyDjC;AqBtyDD;EAAsC,iBAAA;CrByyDrC;AqBxyDD;EAA+B,iBAAA;CrB2yD9B;AqB1yDD;EAAuC,iBAAA;CrB6yDtC;AqB5yDD;EAAyC,iBAAA;CrB+yDxC;AqB9yDD;EAA8B,iBAAA;CrBizD7B;AqBhzDD;;EACkC,iBAAA;CrBmzDjC;AqBlzDD;;EACuC,iBAAA;CrBqzDtC;AqBpzDD;;EACyC,iBAAA;CrBuzDxC;AqBtzDD;EAAmC,iBAAA;CrByzDlC;AqBxzDD;;EACuC,iBAAA;CrB2zDtC;AqB1zDD;EAAkC,iBAAA;CrB6zDjC;AqB5zDD;EAAqC,iBAAA;CrB+zDpC;AqB9zDD;EAAmC,iBAAA;CrBi0DlC;AqBh0DD;EAAqC,iBAAA;CrBm0DpC;AqBl0DD;EAA4C,iBAAA;CrBq0D3C;AqBp0DD;EAAgC,iBAAA;CrBu0D/B;AqBt0DD;;EACoC,iBAAA;CrBy0DnC;AqBx0DD;EAA+B,iBAAA;CrB20D9B;AqB10DD;EAAsC,iBAAA;CrB60DrC;AqB50DD;EAAgC,iBAAA;CrB+0D/B;AqB90DD;EAAsC,iBAAA;CrBi1DrC;AqBh1DD;EAAkC,iBAAA;CrBm1DjC;AqBl1DD;EAAgC,iBAAA;CrBq1D/B;AqBp1DD;EAAuC,iBAAA;CrBu1DtC;AqBt1DD;EAAgC,iBAAA;CrBy1D/B;AqBx1DD;EAAsC,iBAAA;CrB21DrC;AqB11DD;EAAkC,iBAAA;CrB61DjC;AqB51DD;EAAyC,iBAAA;CrB+1DxC;AqB91DD;EAAmC,iBAAA;CrBi2DlC;AqBh2DD;EAAyC,iBAAA;CrBm2DxC;AqBl2DD;EAAuC,iBAAA;CrBq2DtC;AqBp2DD;EAAmC,iBAAA;CrBu2DlC;AqBt2DD;EAAqC,iBAAA;CrBy2DpC;AqBx2DD;EAAqC,iBAAA;CrB22DpC;AqB12DD;EAAsC,iBAAA;CrB62DrC;AqB52DD;EAAwC,iBAAA;CrB+2DvC;AqB92DD;EAAiC,iBAAA;CrBi3DhC;AqBh3DD;EAAqC,iBAAA;CrBm3DpC;AqBl3DD;EAA8B,iBAAA;CrBq3D7B;AqBp3DD;EAAsC,iBAAA;CrBu3DrC;AqBt3DD;EAAuC,iBAAA;CrBy3DtC;AqBx3DD;EAAyC,iBAAA;CrB23DxC;AqB13DD;EAAsC,iBAAA;CrB63DrC;AqB53DD;EAAqC,iBAAA;CrB+3DpC;AqB93DD;EAAsC,iBAAA;CrBi4DrC;AqBh4DD;EAAkC,iBAAA;CrBm4DjC;AqBl4DD;EAAyC,iBAAA;CrBq4DxC;AqBp4DD;EAAsC,iBAAA;CrBu4DrC;AqBt4DD;EAAqC,iBAAA;CrBy4DpC;AqBx4DD;EAAmC,iBAAA;CrB24DlC;AqB14DD;EAA+B,iBAAA;CrB64D9B;AqB54DD;EAAmC,iBAAA;CrB+4DlC;AqB94DD;EAAqC,iBAAA;CrBi5DpC;AqBh5DD;EAA8B,iBAAA;CrBm5D7B;AqBl5DD;;;EAE+B,iBAAA;CrBq5D9B;AqBp5DD;EAAoC,iBAAA;CrBu5DnC;AqBt5DD;EAAsC,iBAAA;CrBy5DrC;AqBx5DD;EAA0C,iBAAA;CrB25DzC;AqB15DD;EAAoC,iBAAA;CrB65DnC;AqB55DD;EAAoC,iBAAA;CrB+5DnC;AqB95DD;EAAmC,iBAAA;CrBi6DlC;AqBh6DD;EAAkC,iBAAA;CrBm6DjC;AqBl6DD;EAAwC,iBAAA;CrBq6DvC;AqBp6DD;EAAuC,iBAAA;CrBu6DtC;AqBt6DD;EAAoC,iBAAA;CrBy6DnC;AqBx6DD;EAAqC,iBAAA;CrB26DpC;AqB16DD;EAA2C,iBAAA;CrB66D1C;AqB56DD;EAAmC,iBAAA;CrB+6DlC;AqB96DD;EAAgC,iBAAA;CrBi7D/B;AqBh7DD;EAAuC,iBAAA;CrBm7DtC;AqBl7DD;EAAsC,iBAAA;CrBq7DrC;AqBp7DD;EAAuC,iBAAA;CrBu7DtC;AqBt7DD;EAAqC,iBAAA;CrBy7DpC;AqBx7DD;EAAiC,iBAAA;CrB27DhC;AqB17DD;EAAgC,iBAAA;CrB67D/B;AqB57DD;EAAmC,iBAAA;CrB+7DlC;AqB97DD;EAAuC,iBAAA;CrBi8DtC;AqBh8DD;EAA2C,iBAAA;CrBm8D1C;AqBl8DD;EAAwC,iBAAA;CrBq8DvC;AqBp8DD;EAAuC,iBAAA;CrBu8DtC;AqBt8DD;EAAsC,iBAAA;CrBy8DrC;AqBx8DD;EAAuC,iBAAA;CrB28DtC;AqB18DD;EAAyC,iBAAA;CrB68DxC;AqB58DD;EAAyC,iBAAA;CrB+8DxC;AqB98DD;EAAkC,iBAAA;CrBi9DjC;AqBh9DD;EAA6C,iBAAA;CrBm9D5C;AqBl9DD;EAAuC,iBAAA;CrBq9DtC;AqBp9DD;EAAoC,iBAAA;CrBu9DnC;AqBt9DD;EAAkC,iBAAA;CrBy9DjC;AqBx9DD;EAAqC,iBAAA;CrB29DpC;AqB19DD;EAAsC,iBAAA;CrB69DrC;AqB59DD;;EAC+B,iBAAA;CrB+9D9B;AqB99DD;EAAmC,iBAAA;CrBi+DlC;AqBh+DD;EAAiC,iBAAA;CrBm+DhC;AqBl+DD;EAAkC,iBAAA;CrBq+DjC;AqBp+DD;EAAkC,iBAAA;CrBu+DjC","file":"Lib.css","sourcesContent":["// Core variables and mixins\r\n@import \"variables.less\";\r\n@import \"mixins.less\";\r\n\r\n// Core CSS\r\n.layout-editor {\r\n    @import \"scaffolding.less\";\r\n    @import \"grid.less\";\r\n}\r\n \r\n// Utility classes\r\n@import \"utilities.less\";\r\n","// Vendor Prefixes\n//\n// All vendor mixins are deprecated as of v3.2.0 due to the introduction of\n// Autoprefixer in our Gruntfile. They will be removed in v4.\n\n// - Animations\n// - Backface visibility\n// - Box shadow\n// - Box sizing\n// - Content columns\n// - Hyphens\n// - Placeholder text\n// - Transformations\n// - Transitions\n// - User Select\n\n\n// Animations\n.animation(@animation) {\n  -webkit-animation: @animation;\n       -o-animation: @animation;\n          animation: @animation;\n}\n.animation-name(@name) {\n  -webkit-animation-name: @name;\n          animation-name: @name;\n}\n.animation-duration(@duration) {\n  -webkit-animation-duration: @duration;\n          animation-duration: @duration;\n}\n.animation-timing-function(@timing-function) {\n  -webkit-animation-timing-function: @timing-function;\n          animation-timing-function: @timing-function;\n}\n.animation-delay(@delay) {\n  -webkit-animation-delay: @delay;\n          animation-delay: @delay;\n}\n.animation-iteration-count(@iteration-count) {\n  -webkit-animation-iteration-count: @iteration-count;\n          animation-iteration-count: @iteration-count;\n}\n.animation-direction(@direction) {\n  -webkit-animation-direction: @direction;\n          animation-direction: @direction;\n}\n.animation-fill-mode(@fill-mode) {\n  -webkit-animation-fill-mode: @fill-mode;\n          animation-fill-mode: @fill-mode;\n}\n\n// Backface visibility\n// Prevent browsers from flickering when using CSS 3D transforms.\n// Default value is `visible`, but can be changed to `hidden`\n\n.backface-visibility(@visibility){\n  -webkit-backface-visibility: @visibility;\n     -moz-backface-visibility: @visibility;\n          backface-visibility: @visibility;\n}\n\n// Drop shadows\n//\n// Note: Deprecated `.box-shadow()` as of v3.1.0 since all of Bootstrap's\n// supported browsers that have box shadow capabilities now support it.\n\n.box-shadow(@shadow) {\n  -webkit-box-shadow: @shadow; // iOS <4.3 & Android <4.1\n          box-shadow: @shadow;\n}\n\n// Box sizing\n.box-sizing(@boxmodel) {\n  -webkit-box-sizing: @boxmodel;\n     -moz-box-sizing: @boxmodel;\n          box-sizing: @boxmodel;\n}\n\n// CSS3 Content Columns\n.content-columns(@column-count; @column-gap: @grid-gutter-width) {\n  -webkit-column-count: @column-count;\n     -moz-column-count: @column-count;\n          column-count: @column-count;\n  -webkit-column-gap: @column-gap;\n     -moz-column-gap: @column-gap;\n          column-gap: @column-gap;\n}\n\n// Optional hyphenation\n.hyphens(@mode: auto) {\n  word-wrap: break-word;\n  -webkit-hyphens: @mode;\n     -moz-hyphens: @mode;\n      -ms-hyphens: @mode; // IE10+\n       -o-hyphens: @mode;\n          hyphens: @mode;\n}\n\n// Placeholder text\n.placeholder(@color: @input-color-placeholder) {\n  // Firefox\n  &::-moz-placeholder {\n    color: @color;\n    opacity: 1; // See https://github.com/twbs/bootstrap/pull/11526\n  }\n  &:-ms-input-placeholder { color: @color; } // Internet Explorer 10+\n  &::-webkit-input-placeholder  { color: @color; } // Safari and Chrome\n}\n\n// Transformations\n.scale(@ratio) {\n  -webkit-transform: scale(@ratio);\n      -ms-transform: scale(@ratio); // IE9 only\n       -o-transform: scale(@ratio);\n          transform: scale(@ratio);\n}\n.scale(@ratioX; @ratioY) {\n  -webkit-transform: scale(@ratioX, @ratioY);\n      -ms-transform: scale(@ratioX, @ratioY); // IE9 only\n       -o-transform: scale(@ratioX, @ratioY);\n          transform: scale(@ratioX, @ratioY);\n}\n.scaleX(@ratio) {\n  -webkit-transform: scaleX(@ratio);\n      -ms-transform: scaleX(@ratio); // IE9 only\n       -o-transform: scaleX(@ratio);\n          transform: scaleX(@ratio);\n}\n.scaleY(@ratio) {\n  -webkit-transform: scaleY(@ratio);\n      -ms-transform: scaleY(@ratio); // IE9 only\n       -o-transform: scaleY(@ratio);\n          transform: scaleY(@ratio);\n}\n.skew(@x; @y) {\n  -webkit-transform: skewX(@x) skewY(@y);\n      -ms-transform: skewX(@x) skewY(@y); // See https://github.com/twbs/bootstrap/issues/4885; IE9+\n       -o-transform: skewX(@x) skewY(@y);\n          transform: skewX(@x) skewY(@y);\n}\n.translate(@x; @y) {\n  -webkit-transform: translate(@x, @y);\n      -ms-transform: translate(@x, @y); // IE9 only\n       -o-transform: translate(@x, @y);\n          transform: translate(@x, @y);\n}\n.translate3d(@x; @y; @z) {\n  -webkit-transform: translate3d(@x, @y, @z);\n          transform: translate3d(@x, @y, @z);\n}\n.rotate(@degrees) {\n  -webkit-transform: rotate(@degrees);\n      -ms-transform: rotate(@degrees); // IE9 only\n       -o-transform: rotate(@degrees);\n          transform: rotate(@degrees);\n}\n.rotateX(@degrees) {\n  -webkit-transform: rotateX(@degrees);\n      -ms-transform: rotateX(@degrees); // IE9 only\n       -o-transform: rotateX(@degrees);\n          transform: rotateX(@degrees);\n}\n.rotateY(@degrees) {\n  -webkit-transform: rotateY(@degrees);\n      -ms-transform: rotateY(@degrees); // IE9 only\n       -o-transform: rotateY(@degrees);\n          transform: rotateY(@degrees);\n}\n.perspective(@perspective) {\n  -webkit-perspective: @perspective;\n     -moz-perspective: @perspective;\n          perspective: @perspective;\n}\n.perspective-origin(@perspective) {\n  -webkit-perspective-origin: @perspective;\n     -moz-perspective-origin: @perspective;\n          perspective-origin: @perspective;\n}\n.transform-origin(@origin) {\n  -webkit-transform-origin: @origin;\n     -moz-transform-origin: @origin;\n      -ms-transform-origin: @origin; // IE9 only\n          transform-origin: @origin;\n}\n\n\n// Transitions\n\n.transition(@transition) {\n  -webkit-transition: @transition;\n       -o-transition: @transition;\n          transition: @transition;\n}\n.transition-property(@transition-property) {\n  -webkit-transition-property: @transition-property;\n          transition-property: @transition-property;\n}\n.transition-delay(@transition-delay) {\n  -webkit-transition-delay: @transition-delay;\n          transition-delay: @transition-delay;\n}\n.transition-duration(@transition-duration) {\n  -webkit-transition-duration: @transition-duration;\n          transition-duration: @transition-duration;\n}\n.transition-timing-function(@timing-function) {\n  -webkit-transition-timing-function: @timing-function;\n          transition-timing-function: @timing-function;\n}\n.transition-transform(@transition) {\n  -webkit-transition: -webkit-transform @transition;\n     -moz-transition: -moz-transform @transition;\n       -o-transition: -o-transform @transition;\n          transition: transform @transition;\n}\n\n\n// User select\n// For selecting text on the page\n\n.user-select(@select) {\n  -webkit-user-select: @select;\n     -moz-user-select: @select;\n      -ms-user-select: @select; // IE10+\n          user-select: @select;\n}\n",".layout-editor * {\n  -webkit-box-sizing: border-box;\n  -moz-box-sizing: border-box;\n  box-sizing: border-box;\n}\n.layout-editor *:before,\n.layout-editor *:after {\n  -webkit-box-sizing: border-box;\n  -moz-box-sizing: border-box;\n  box-sizing: border-box;\n}\n.layout-editor html {\n  font-size: 10px;\n  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);\n}\n.layout-editor body {\n  font-family: \"Helvetica Neue\", Helvetica, Arial, sans-serif;\n  font-size: 14px;\n  line-height: 1.42857143;\n  color: #333333;\n  background-color: #ffffff;\n}\n.layout-editor input,\n.layout-editor button,\n.layout-editor select,\n.layout-editor textarea {\n  font-family: inherit;\n  font-size: inherit;\n  line-height: inherit;\n}\n.layout-editor a {\n  color: #337ab7;\n  text-decoration: none;\n}\n.layout-editor a:hover,\n.layout-editor a:focus {\n  color: #23527c;\n  text-decoration: underline;\n}\n.layout-editor a:focus {\n  outline: thin dotted;\n  outline: 5px auto -webkit-focus-ring-color;\n  outline-offset: -2px;\n}\n.layout-editor figure {\n  margin: 0;\n}\n.layout-editor img {\n  vertical-align: middle;\n}\n.layout-editor .img-responsive {\n  display: block;\n  max-width: 100%;\n  height: auto;\n}\n.layout-editor .img-rounded {\n  border-radius: 6px;\n}\n.layout-editor .img-thumbnail {\n  padding: 4px;\n  line-height: 1.42857143;\n  background-color: #ffffff;\n  border: 1px solid #dddddd;\n  border-radius: 4px;\n  -webkit-transition: all 0.2s ease-in-out;\n  -o-transition: all 0.2s ease-in-out;\n  transition: all 0.2s ease-in-out;\n  display: inline-block;\n  max-width: 100%;\n  height: auto;\n}\n.layout-editor .img-circle {\n  border-radius: 50%;\n}\n.layout-editor hr {\n  margin-top: 20px;\n  margin-bottom: 20px;\n  border: 0;\n  border-top: 1px solid #eeeeee;\n}\n.layout-editor .sr-only {\n  position: absolute;\n  width: 1px;\n  height: 1px;\n  margin: -1px;\n  padding: 0;\n  overflow: hidden;\n  clip: rect(0, 0, 0, 0);\n  border: 0;\n}\n.layout-editor .sr-only-focusable:active,\n.layout-editor .sr-only-focusable:focus {\n  position: static;\n  width: auto;\n  height: auto;\n  margin: 0;\n  overflow: visible;\n  clip: auto;\n}\n.layout-editor .container {\n  margin-right: auto;\n  margin-left: auto;\n  padding-left: 15px;\n  padding-right: 15px;\n}\n@media (min-width: 768px) {\n  .layout-editor .container {\n    width: 750px;\n  }\n}\n@media (min-width: 992px) {\n  .layout-editor .container {\n    width: 970px;\n  }\n}\n@media (min-width: 1200px) {\n  .layout-editor .container {\n    width: 1170px;\n  }\n}\n.layout-editor .container-fluid {\n  margin-right: auto;\n  margin-left: auto;\n  padding-left: 15px;\n  padding-right: 15px;\n}\n.layout-editor .row {\n  margin-left: -15px;\n  margin-right: -15px;\n}\n.layout-editor .col-xs-1, .col-sm-1, .col-md-1, .col-lg-1, .col-xs-2, .col-sm-2, .col-md-2, .col-lg-2, .col-xs-3, .col-sm-3, .col-md-3, .col-lg-3, .col-xs-4, .col-sm-4, .col-md-4, .col-lg-4, .col-xs-5, .col-sm-5, .col-md-5, .col-lg-5, .col-xs-6, .col-sm-6, .col-md-6, .col-lg-6, .col-xs-7, .col-sm-7, .col-md-7, .col-lg-7, .col-xs-8, .col-sm-8, .col-md-8, .col-lg-8, .col-xs-9, .col-sm-9, .col-md-9, .col-lg-9, .col-xs-10, .col-sm-10, .col-md-10, .col-lg-10, .col-xs-11, .col-sm-11, .col-md-11, .col-lg-11, .col-xs-12, .col-sm-12, .col-md-12, .col-lg-12 {\n  position: relative;\n  min-height: 1px;\n  padding-left: 15px;\n  padding-right: 15px;\n}\n.layout-editor .col-xs-1, .col-xs-2, .col-xs-3, .col-xs-4, .col-xs-5, .col-xs-6, .col-xs-7, .col-xs-8, .col-xs-9, .col-xs-10, .col-xs-11, .col-xs-12 {\n  float: left;\n}\n.layout-editor .col-xs-12 {\n  width: 100%;\n}\n.layout-editor .col-xs-11 {\n  width: 91.66666667%;\n}\n.layout-editor .col-xs-10 {\n  width: 83.33333333%;\n}\n.layout-editor .col-xs-9 {\n  width: 75%;\n}\n.layout-editor .col-xs-8 {\n  width: 66.66666667%;\n}\n.layout-editor .col-xs-7 {\n  width: 58.33333333%;\n}\n.layout-editor .col-xs-6 {\n  width: 50%;\n}\n.layout-editor .col-xs-5 {\n  width: 41.66666667%;\n}\n.layout-editor .col-xs-4 {\n  width: 33.33333333%;\n}\n.layout-editor .col-xs-3 {\n  width: 25%;\n}\n.layout-editor .col-xs-2 {\n  width: 16.66666667%;\n}\n.layout-editor .col-xs-1 {\n  width: 8.33333333%;\n}\n.layout-editor .col-xs-pull-12 {\n  right: 100%;\n}\n.layout-editor .col-xs-pull-11 {\n  right: 91.66666667%;\n}\n.layout-editor .col-xs-pull-10 {\n  right: 83.33333333%;\n}\n.layout-editor .col-xs-pull-9 {\n  right: 75%;\n}\n.layout-editor .col-xs-pull-8 {\n  right: 66.66666667%;\n}\n.layout-editor .col-xs-pull-7 {\n  right: 58.33333333%;\n}\n.layout-editor .col-xs-pull-6 {\n  right: 50%;\n}\n.layout-editor .col-xs-pull-5 {\n  right: 41.66666667%;\n}\n.layout-editor .col-xs-pull-4 {\n  right: 33.33333333%;\n}\n.layout-editor .col-xs-pull-3 {\n  right: 25%;\n}\n.layout-editor .col-xs-pull-2 {\n  right: 16.66666667%;\n}\n.layout-editor .col-xs-pull-1 {\n  right: 8.33333333%;\n}\n.layout-editor .col-xs-pull-0 {\n  right: auto;\n}\n.layout-editor .col-xs-push-12 {\n  left: 100%;\n}\n.layout-editor .col-xs-push-11 {\n  left: 91.66666667%;\n}\n.layout-editor .col-xs-push-10 {\n  left: 83.33333333%;\n}\n.layout-editor .col-xs-push-9 {\n  left: 75%;\n}\n.layout-editor .col-xs-push-8 {\n  left: 66.66666667%;\n}\n.layout-editor .col-xs-push-7 {\n  left: 58.33333333%;\n}\n.layout-editor .col-xs-push-6 {\n  left: 50%;\n}\n.layout-editor .col-xs-push-5 {\n  left: 41.66666667%;\n}\n.layout-editor .col-xs-push-4 {\n  left: 33.33333333%;\n}\n.layout-editor .col-xs-push-3 {\n  left: 25%;\n}\n.layout-editor .col-xs-push-2 {\n  left: 16.66666667%;\n}\n.layout-editor .col-xs-push-1 {\n  left: 8.33333333%;\n}\n.layout-editor .col-xs-push-0 {\n  left: auto;\n}\n.layout-editor .col-xs-offset-12 {\n  margin-left: 100%;\n}\n.layout-editor .col-xs-offset-11 {\n  margin-left: 91.66666667%;\n}\n.layout-editor .col-xs-offset-10 {\n  margin-left: 83.33333333%;\n}\n.layout-editor .col-xs-offset-9 {\n  margin-left: 75%;\n}\n.layout-editor .col-xs-offset-8 {\n  margin-left: 66.66666667%;\n}\n.layout-editor .col-xs-offset-7 {\n  margin-left: 58.33333333%;\n}\n.layout-editor .col-xs-offset-6 {\n  margin-left: 50%;\n}\n.layout-editor .col-xs-offset-5 {\n  margin-left: 41.66666667%;\n}\n.layout-editor .col-xs-offset-4 {\n  margin-left: 33.33333333%;\n}\n.layout-editor .col-xs-offset-3 {\n  margin-left: 25%;\n}\n.layout-editor .col-xs-offset-2 {\n  margin-left: 16.66666667%;\n}\n.layout-editor .col-xs-offset-1 {\n  margin-left: 8.33333333%;\n}\n.layout-editor .col-xs-offset-0 {\n  margin-left: 0%;\n}\n@media (min-width: 768px) {\n  .layout-editor .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12 {\n    float: left;\n  }\n  .layout-editor .col-sm-12 {\n    width: 100%;\n  }\n  .layout-editor .col-sm-11 {\n    width: 91.66666667%;\n  }\n  .layout-editor .col-sm-10 {\n    width: 83.33333333%;\n  }\n  .layout-editor .col-sm-9 {\n    width: 75%;\n  }\n  .layout-editor .col-sm-8 {\n    width: 66.66666667%;\n  }\n  .layout-editor .col-sm-7 {\n    width: 58.33333333%;\n  }\n  .layout-editor .col-sm-6 {\n    width: 50%;\n  }\n  .layout-editor .col-sm-5 {\n    width: 41.66666667%;\n  }\n  .layout-editor .col-sm-4 {\n    width: 33.33333333%;\n  }\n  .layout-editor .col-sm-3 {\n    width: 25%;\n  }\n  .layout-editor .col-sm-2 {\n    width: 16.66666667%;\n  }\n  .layout-editor .col-sm-1 {\n    width: 8.33333333%;\n  }\n  .layout-editor .col-sm-pull-12 {\n    right: 100%;\n  }\n  .layout-editor .col-sm-pull-11 {\n    right: 91.66666667%;\n  }\n  .layout-editor .col-sm-pull-10 {\n    right: 83.33333333%;\n  }\n  .layout-editor .col-sm-pull-9 {\n    right: 75%;\n  }\n  .layout-editor .col-sm-pull-8 {\n    right: 66.66666667%;\n  }\n  .layout-editor .col-sm-pull-7 {\n    right: 58.33333333%;\n  }\n  .layout-editor .col-sm-pull-6 {\n    right: 50%;\n  }\n  .layout-editor .col-sm-pull-5 {\n    right: 41.66666667%;\n  }\n  .layout-editor .col-sm-pull-4 {\n    right: 33.33333333%;\n  }\n  .layout-editor .col-sm-pull-3 {\n    right: 25%;\n  }\n  .layout-editor .col-sm-pull-2 {\n    right: 16.66666667%;\n  }\n  .layout-editor .col-sm-pull-1 {\n    right: 8.33333333%;\n  }\n  .layout-editor .col-sm-pull-0 {\n    right: auto;\n  }\n  .layout-editor .col-sm-push-12 {\n    left: 100%;\n  }\n  .layout-editor .col-sm-push-11 {\n    left: 91.66666667%;\n  }\n  .layout-editor .col-sm-push-10 {\n    left: 83.33333333%;\n  }\n  .layout-editor .col-sm-push-9 {\n    left: 75%;\n  }\n  .layout-editor .col-sm-push-8 {\n    left: 66.66666667%;\n  }\n  .layout-editor .col-sm-push-7 {\n    left: 58.33333333%;\n  }\n  .layout-editor .col-sm-push-6 {\n    left: 50%;\n  }\n  .layout-editor .col-sm-push-5 {\n    left: 41.66666667%;\n  }\n  .layout-editor .col-sm-push-4 {\n    left: 33.33333333%;\n  }\n  .layout-editor .col-sm-push-3 {\n    left: 25%;\n  }\n  .layout-editor .col-sm-push-2 {\n    left: 16.66666667%;\n  }\n  .layout-editor .col-sm-push-1 {\n    left: 8.33333333%;\n  }\n  .layout-editor .col-sm-push-0 {\n    left: auto;\n  }\n  .layout-editor .col-sm-offset-12 {\n    margin-left: 100%;\n  }\n  .layout-editor .col-sm-offset-11 {\n    margin-left: 91.66666667%;\n  }\n  .layout-editor .col-sm-offset-10 {\n    margin-left: 83.33333333%;\n  }\n  .layout-editor .col-sm-offset-9 {\n    margin-left: 75%;\n  }\n  .layout-editor .col-sm-offset-8 {\n    margin-left: 66.66666667%;\n  }\n  .layout-editor .col-sm-offset-7 {\n    margin-left: 58.33333333%;\n  }\n  .layout-editor .col-sm-offset-6 {\n    margin-left: 50%;\n  }\n  .layout-editor .col-sm-offset-5 {\n    margin-left: 41.66666667%;\n  }\n  .layout-editor .col-sm-offset-4 {\n    margin-left: 33.33333333%;\n  }\n  .layout-editor .col-sm-offset-3 {\n    margin-left: 25%;\n  }\n  .layout-editor .col-sm-offset-2 {\n    margin-left: 16.66666667%;\n  }\n  .layout-editor .col-sm-offset-1 {\n    margin-left: 8.33333333%;\n  }\n  .layout-editor .col-sm-offset-0 {\n    margin-left: 0%;\n  }\n}\n@media (min-width: 992px) {\n  .layout-editor .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12 {\n    float: left;\n  }\n  .layout-editor .col-md-12 {\n    width: 100%;\n  }\n  .layout-editor .col-md-11 {\n    width: 91.66666667%;\n  }\n  .layout-editor .col-md-10 {\n    width: 83.33333333%;\n  }\n  .layout-editor .col-md-9 {\n    width: 75%;\n  }\n  .layout-editor .col-md-8 {\n    width: 66.66666667%;\n  }\n  .layout-editor .col-md-7 {\n    width: 58.33333333%;\n  }\n  .layout-editor .col-md-6 {\n    width: 50%;\n  }\n  .layout-editor .col-md-5 {\n    width: 41.66666667%;\n  }\n  .layout-editor .col-md-4 {\n    width: 33.33333333%;\n  }\n  .layout-editor .col-md-3 {\n    width: 25%;\n  }\n  .layout-editor .col-md-2 {\n    width: 16.66666667%;\n  }\n  .layout-editor .col-md-1 {\n    width: 8.33333333%;\n  }\n  .layout-editor .col-md-pull-12 {\n    right: 100%;\n  }\n  .layout-editor .col-md-pull-11 {\n    right: 91.66666667%;\n  }\n  .layout-editor .col-md-pull-10 {\n    right: 83.33333333%;\n  }\n  .layout-editor .col-md-pull-9 {\n    right: 75%;\n  }\n  .layout-editor .col-md-pull-8 {\n    right: 66.66666667%;\n  }\n  .layout-editor .col-md-pull-7 {\n    right: 58.33333333%;\n  }\n  .layout-editor .col-md-pull-6 {\n    right: 50%;\n  }\n  .layout-editor .col-md-pull-5 {\n    right: 41.66666667%;\n  }\n  .layout-editor .col-md-pull-4 {\n    right: 33.33333333%;\n  }\n  .layout-editor .col-md-pull-3 {\n    right: 25%;\n  }\n  .layout-editor .col-md-pull-2 {\n    right: 16.66666667%;\n  }\n  .layout-editor .col-md-pull-1 {\n    right: 8.33333333%;\n  }\n  .layout-editor .col-md-pull-0 {\n    right: auto;\n  }\n  .layout-editor .col-md-push-12 {\n    left: 100%;\n  }\n  .layout-editor .col-md-push-11 {\n    left: 91.66666667%;\n  }\n  .layout-editor .col-md-push-10 {\n    left: 83.33333333%;\n  }\n  .layout-editor .col-md-push-9 {\n    left: 75%;\n  }\n  .layout-editor .col-md-push-8 {\n    left: 66.66666667%;\n  }\n  .layout-editor .col-md-push-7 {\n    left: 58.33333333%;\n  }\n  .layout-editor .col-md-push-6 {\n    left: 50%;\n  }\n  .layout-editor .col-md-push-5 {\n    left: 41.66666667%;\n  }\n  .layout-editor .col-md-push-4 {\n    left: 33.33333333%;\n  }\n  .layout-editor .col-md-push-3 {\n    left: 25%;\n  }\n  .layout-editor .col-md-push-2 {\n    left: 16.66666667%;\n  }\n  .layout-editor .col-md-push-1 {\n    left: 8.33333333%;\n  }\n  .layout-editor .col-md-push-0 {\n    left: auto;\n  }\n  .layout-editor .col-md-offset-12 {\n    margin-left: 100%;\n  }\n  .layout-editor .col-md-offset-11 {\n    margin-left: 91.66666667%;\n  }\n  .layout-editor .col-md-offset-10 {\n    margin-left: 83.33333333%;\n  }\n  .layout-editor .col-md-offset-9 {\n    margin-left: 75%;\n  }\n  .layout-editor .col-md-offset-8 {\n    margin-left: 66.66666667%;\n  }\n  .layout-editor .col-md-offset-7 {\n    margin-left: 58.33333333%;\n  }\n  .layout-editor .col-md-offset-6 {\n    margin-left: 50%;\n  }\n  .layout-editor .col-md-offset-5 {\n    margin-left: 41.66666667%;\n  }\n  .layout-editor .col-md-offset-4 {\n    margin-left: 33.33333333%;\n  }\n  .layout-editor .col-md-offset-3 {\n    margin-left: 25%;\n  }\n  .layout-editor .col-md-offset-2 {\n    margin-left: 16.66666667%;\n  }\n  .layout-editor .col-md-offset-1 {\n    margin-left: 8.33333333%;\n  }\n  .layout-editor .col-md-offset-0 {\n    margin-left: 0%;\n  }\n}\n@media (min-width: 1200px) {\n  .layout-editor .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12 {\n    float: left;\n  }\n  .layout-editor .col-lg-12 {\n    width: 100%;\n  }\n  .layout-editor .col-lg-11 {\n    width: 91.66666667%;\n  }\n  .layout-editor .col-lg-10 {\n    width: 83.33333333%;\n  }\n  .layout-editor .col-lg-9 {\n    width: 75%;\n  }\n  .layout-editor .col-lg-8 {\n    width: 66.66666667%;\n  }\n  .layout-editor .col-lg-7 {\n    width: 58.33333333%;\n  }\n  .layout-editor .col-lg-6 {\n    width: 50%;\n  }\n  .layout-editor .col-lg-5 {\n    width: 41.66666667%;\n  }\n  .layout-editor .col-lg-4 {\n    width: 33.33333333%;\n  }\n  .layout-editor .col-lg-3 {\n    width: 25%;\n  }\n  .layout-editor .col-lg-2 {\n    width: 16.66666667%;\n  }\n  .layout-editor .col-lg-1 {\n    width: 8.33333333%;\n  }\n  .layout-editor .col-lg-pull-12 {\n    right: 100%;\n  }\n  .layout-editor .col-lg-pull-11 {\n    right: 91.66666667%;\n  }\n  .layout-editor .col-lg-pull-10 {\n    right: 83.33333333%;\n  }\n  .layout-editor .col-lg-pull-9 {\n    right: 75%;\n  }\n  .layout-editor .col-lg-pull-8 {\n    right: 66.66666667%;\n  }\n  .layout-editor .col-lg-pull-7 {\n    right: 58.33333333%;\n  }\n  .layout-editor .col-lg-pull-6 {\n    right: 50%;\n  }\n  .layout-editor .col-lg-pull-5 {\n    right: 41.66666667%;\n  }\n  .layout-editor .col-lg-pull-4 {\n    right: 33.33333333%;\n  }\n  .layout-editor .col-lg-pull-3 {\n    right: 25%;\n  }\n  .layout-editor .col-lg-pull-2 {\n    right: 16.66666667%;\n  }\n  .layout-editor .col-lg-pull-1 {\n    right: 8.33333333%;\n  }\n  .layout-editor .col-lg-pull-0 {\n    right: auto;\n  }\n  .layout-editor .col-lg-push-12 {\n    left: 100%;\n  }\n  .layout-editor .col-lg-push-11 {\n    left: 91.66666667%;\n  }\n  .layout-editor .col-lg-push-10 {\n    left: 83.33333333%;\n  }\n  .layout-editor .col-lg-push-9 {\n    left: 75%;\n  }\n  .layout-editor .col-lg-push-8 {\n    left: 66.66666667%;\n  }\n  .layout-editor .col-lg-push-7 {\n    left: 58.33333333%;\n  }\n  .layout-editor .col-lg-push-6 {\n    left: 50%;\n  }\n  .layout-editor .col-lg-push-5 {\n    left: 41.66666667%;\n  }\n  .layout-editor .col-lg-push-4 {\n    left: 33.33333333%;\n  }\n  .layout-editor .col-lg-push-3 {\n    left: 25%;\n  }\n  .layout-editor .col-lg-push-2 {\n    left: 16.66666667%;\n  }\n  .layout-editor .col-lg-push-1 {\n    left: 8.33333333%;\n  }\n  .layout-editor .col-lg-push-0 {\n    left: auto;\n  }\n  .layout-editor .col-lg-offset-12 {\n    margin-left: 100%;\n  }\n  .layout-editor .col-lg-offset-11 {\n    margin-left: 91.66666667%;\n  }\n  .layout-editor .col-lg-offset-10 {\n    margin-left: 83.33333333%;\n  }\n  .layout-editor .col-lg-offset-9 {\n    margin-left: 75%;\n  }\n  .layout-editor .col-lg-offset-8 {\n    margin-left: 66.66666667%;\n  }\n  .layout-editor .col-lg-offset-7 {\n    margin-left: 58.33333333%;\n  }\n  .layout-editor .col-lg-offset-6 {\n    margin-left: 50%;\n  }\n  .layout-editor .col-lg-offset-5 {\n    margin-left: 41.66666667%;\n  }\n  .layout-editor .col-lg-offset-4 {\n    margin-left: 33.33333333%;\n  }\n  .layout-editor .col-lg-offset-3 {\n    margin-left: 25%;\n  }\n  .layout-editor .col-lg-offset-2 {\n    margin-left: 16.66666667%;\n  }\n  .layout-editor .col-lg-offset-1 {\n    margin-left: 8.33333333%;\n  }\n  .layout-editor .col-lg-offset-0 {\n    margin-left: 0%;\n  }\n}\n.clearfix:before,\n.clearfix:after,\n.layout-editor .container:before,\n.layout-editor .container:after,\n.layout-editor .container-fluid:before,\n.layout-editor .container-fluid:after,\n.layout-editor .row:before,\n.layout-editor .row:after {\n  content: \" \";\n  display: table;\n}\n.clearfix:after,\n.layout-editor .container:after,\n.layout-editor .container-fluid:after,\n.layout-editor .row:after {\n  clear: both;\n}\n.center-block {\n  display: block;\n  margin-left: auto;\n  margin-right: auto;\n}\n.pull-right {\n  float: right !important;\n}\n.pull-left {\n  float: left !important;\n}\n.hide {\n  display: none !important;\n}\n.show {\n  display: block !important;\n}\n.invisible {\n  visibility: hidden;\n}\n.text-hide {\n  font: 0/0 a;\n  color: transparent;\n  text-shadow: none;\n  background-color: transparent;\n  border: 0;\n}\n.hidden {\n  display: none !important;\n  visibility: hidden !important;\n}\n.affix {\n  position: fixed;\n}\n\n/*!\n *  Font Awesome 4.3.0 by @davegandy - http://fontawesome.io - @fontawesome\n *  License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License)\n */\n/* FONT PATH\n * -------------------------- */\n@font-face {\n  font-family: 'FontAwesome';\n  src: url('Lib/FontAwesome/Fonts/fontawesome-webfont.eot?v=4.3.0');\n  src: url('Lib/FontAwesome/Fonts/fontawesome-webfont.eot?#iefix&v=4.3.0') format('embedded-opentype'), url('Lib/FontAwesome/Fonts/fontawesome-webfont.woff2?v=4.3.0') format('woff2'), url('Lib/FontAwesome/Fonts/fontawesome-webfont.woff?v=4.3.0') format('woff'), url('Lib/FontAwesome/Fonts/fontawesome-webfont.ttf?v=4.3.0') format('truetype'), url('Lib/FontAwesome/Fonts/fontawesome-webfont.svg?v=4.3.0#fontawesomeregular') format('svg');\n  font-weight: normal;\n  font-style: normal;\n}\n.fa {\n  display: inline-block;\n  font: normal normal normal 14px/1 FontAwesome;\n  font-size: inherit;\n  text-rendering: auto;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n  transform: translate(0, 0);\n}\n/* makes the font 33% larger relative to the icon container */\n.fa-lg {\n  font-size: 1.33333333em;\n  line-height: 0.75em;\n  vertical-align: -15%;\n}\n.fa-2x {\n  font-size: 2em;\n}\n.fa-3x {\n  font-size: 3em;\n}\n.fa-4x {\n  font-size: 4em;\n}\n.fa-5x {\n  font-size: 5em;\n}\n.fa-fw {\n  width: 1.28571429em;\n  text-align: center;\n}\n.fa-ul {\n  padding-left: 0;\n  margin-left: 2.14285714em;\n  list-style-type: none;\n}\n.fa-ul > li {\n  position: relative;\n}\n.fa-li {\n  position: absolute;\n  left: -2.14285714em;\n  width: 2.14285714em;\n  top: 0.14285714em;\n  text-align: center;\n}\n.fa-li.fa-lg {\n  left: -1.85714286em;\n}\n.fa-border {\n  padding: .2em .25em .15em;\n  border: solid 0.08em #eeeeee;\n  border-radius: .1em;\n}\n.pull-right {\n  float: right;\n}\n.pull-left {\n  float: left;\n}\n.fa.pull-left {\n  margin-right: .3em;\n}\n.fa.pull-right {\n  margin-left: .3em;\n}\n.fa-spin {\n  -webkit-animation: fa-spin 2s infinite linear;\n  animation: fa-spin 2s infinite linear;\n}\n.fa-pulse {\n  -webkit-animation: fa-spin 1s infinite steps(8);\n  animation: fa-spin 1s infinite steps(8);\n}\n@-webkit-keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n    transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n    transform: rotate(359deg);\n  }\n}\n@keyframes fa-spin {\n  0% {\n    -webkit-transform: rotate(0deg);\n    transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(359deg);\n    transform: rotate(359deg);\n  }\n}\n.fa-rotate-90 {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=1);\n  -webkit-transform: rotate(90deg);\n  -ms-transform: rotate(90deg);\n  transform: rotate(90deg);\n}\n.fa-rotate-180 {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=2);\n  -webkit-transform: rotate(180deg);\n  -ms-transform: rotate(180deg);\n  transform: rotate(180deg);\n}\n.fa-rotate-270 {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=3);\n  -webkit-transform: rotate(270deg);\n  -ms-transform: rotate(270deg);\n  transform: rotate(270deg);\n}\n.fa-flip-horizontal {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=0, mirror=1);\n  -webkit-transform: scale(-1, 1);\n  -ms-transform: scale(-1, 1);\n  transform: scale(-1, 1);\n}\n.fa-flip-vertical {\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=2, mirror=1);\n  -webkit-transform: scale(1, -1);\n  -ms-transform: scale(1, -1);\n  transform: scale(1, -1);\n}\n:root .fa-rotate-90,\n:root .fa-rotate-180,\n:root .fa-rotate-270,\n:root .fa-flip-horizontal,\n:root .fa-flip-vertical {\n  filter: none;\n}\n.fa-stack {\n  position: relative;\n  display: inline-block;\n  width: 2em;\n  height: 2em;\n  line-height: 2em;\n  vertical-align: middle;\n}\n.fa-stack-1x,\n.fa-stack-2x {\n  position: absolute;\n  left: 0;\n  width: 100%;\n  text-align: center;\n}\n.fa-stack-1x {\n  line-height: inherit;\n}\n.fa-stack-2x {\n  font-size: 2em;\n}\n.fa-inverse {\n  color: #ffffff;\n}\n/* Font Awesome uses the Unicode Private Use Area (PUA) to ensure screen\n   readers do not read off random characters that represent icons */\n.fa-glass:before {\n  content: \"\\f000\";\n}\n.fa-music:before {\n  content: \"\\f001\";\n}\n.fa-search:before {\n  content: \"\\f002\";\n}\n.fa-envelope-o:before {\n  content: \"\\f003\";\n}\n.fa-heart:before {\n  content: \"\\f004\";\n}\n.fa-star:before {\n  content: \"\\f005\";\n}\n.fa-star-o:before {\n  content: \"\\f006\";\n}\n.fa-user:before {\n  content: \"\\f007\";\n}\n.fa-film:before {\n  content: \"\\f008\";\n}\n.fa-th-large:before {\n  content: \"\\f009\";\n}\n.fa-th:before {\n  content: \"\\f00a\";\n}\n.fa-th-list:before {\n  content: \"\\f00b\";\n}\n.fa-check:before {\n  content: \"\\f00c\";\n}\n.fa-remove:before,\n.fa-close:before,\n.fa-times:before {\n  content: \"\\f00d\";\n}\n.fa-search-plus:before {\n  content: \"\\f00e\";\n}\n.fa-search-minus:before {\n  content: \"\\f010\";\n}\n.fa-power-off:before {\n  content: \"\\f011\";\n}\n.fa-signal:before {\n  content: \"\\f012\";\n}\n.fa-gear:before,\n.fa-cog:before {\n  content: \"\\f013\";\n}\n.fa-trash-o:before {\n  content: \"\\f014\";\n}\n.fa-home:before {\n  content: \"\\f015\";\n}\n.fa-file-o:before {\n  content: \"\\f016\";\n}\n.fa-clock-o:before {\n  content: \"\\f017\";\n}\n.fa-road:before {\n  content: \"\\f018\";\n}\n.fa-download:before {\n  content: \"\\f019\";\n}\n.fa-arrow-circle-o-down:before {\n  content: \"\\f01a\";\n}\n.fa-arrow-circle-o-up:before {\n  content: \"\\f01b\";\n}\n.fa-inbox:before {\n  content: \"\\f01c\";\n}\n.fa-play-circle-o:before {\n  content: \"\\f01d\";\n}\n.fa-rotate-right:before,\n.fa-repeat:before {\n  content: \"\\f01e\";\n}\n.fa-refresh:before {\n  content: \"\\f021\";\n}\n.fa-list-alt:before {\n  content: \"\\f022\";\n}\n.fa-lock:before {\n  content: \"\\f023\";\n}\n.fa-flag:before {\n  content: \"\\f024\";\n}\n.fa-headphones:before {\n  content: \"\\f025\";\n}\n.fa-volume-off:before {\n  content: \"\\f026\";\n}\n.fa-volume-down:before {\n  content: \"\\f027\";\n}\n.fa-volume-up:before {\n  content: \"\\f028\";\n}\n.fa-qrcode:before {\n  content: \"\\f029\";\n}\n.fa-barcode:before {\n  content: \"\\f02a\";\n}\n.fa-tag:before {\n  content: \"\\f02b\";\n}\n.fa-tags:before {\n  content: \"\\f02c\";\n}\n.fa-book:before {\n  content: \"\\f02d\";\n}\n.fa-bookmark:before {\n  content: \"\\f02e\";\n}\n.fa-print:before {\n  content: \"\\f02f\";\n}\n.fa-camera:before {\n  content: \"\\f030\";\n}\n.fa-font:before {\n  content: \"\\f031\";\n}\n.fa-bold:before {\n  content: \"\\f032\";\n}\n.fa-italic:before {\n  content: \"\\f033\";\n}\n.fa-text-height:before {\n  content: \"\\f034\";\n}\n.fa-text-width:before {\n  content: \"\\f035\";\n}\n.fa-align-left:before {\n  content: \"\\f036\";\n}\n.fa-align-center:before {\n  content: \"\\f037\";\n}\n.fa-align-right:before {\n  content: \"\\f038\";\n}\n.fa-align-justify:before {\n  content: \"\\f039\";\n}\n.fa-list:before {\n  content: \"\\f03a\";\n}\n.fa-dedent:before,\n.fa-outdent:before {\n  content: \"\\f03b\";\n}\n.fa-indent:before {\n  content: \"\\f03c\";\n}\n.fa-video-camera:before {\n  content: \"\\f03d\";\n}\n.fa-photo:before,\n.fa-image:before,\n.fa-picture-o:before {\n  content: \"\\f03e\";\n}\n.fa-pencil:before {\n  content: \"\\f040\";\n}\n.fa-map-marker:before {\n  content: \"\\f041\";\n}\n.fa-adjust:before {\n  content: \"\\f042\";\n}\n.fa-tint:before {\n  content: \"\\f043\";\n}\n.fa-edit:before,\n.fa-pencil-square-o:before {\n  content: \"\\f044\";\n}\n.fa-share-square-o:before {\n  content: \"\\f045\";\n}\n.fa-check-square-o:before {\n  content: \"\\f046\";\n}\n.fa-arrows:before {\n  content: \"\\f047\";\n}\n.fa-step-backward:before {\n  content: \"\\f048\";\n}\n.fa-fast-backward:before {\n  content: \"\\f049\";\n}\n.fa-backward:before {\n  content: \"\\f04a\";\n}\n.fa-play:before {\n  content: \"\\f04b\";\n}\n.fa-pause:before {\n  content: \"\\f04c\";\n}\n.fa-stop:before {\n  content: \"\\f04d\";\n}\n.fa-forward:before {\n  content: \"\\f04e\";\n}\n.fa-fast-forward:before {\n  content: \"\\f050\";\n}\n.fa-step-forward:before {\n  content: \"\\f051\";\n}\n.fa-eject:before {\n  content: \"\\f052\";\n}\n.fa-chevron-left:before {\n  content: \"\\f053\";\n}\n.fa-chevron-right:before {\n  content: \"\\f054\";\n}\n.fa-plus-circle:before {\n  content: \"\\f055\";\n}\n.fa-minus-circle:before {\n  content: \"\\f056\";\n}\n.fa-times-circle:before {\n  content: \"\\f057\";\n}\n.fa-check-circle:before {\n  content: \"\\f058\";\n}\n.fa-question-circle:before {\n  content: \"\\f059\";\n}\n.fa-info-circle:before {\n  content: \"\\f05a\";\n}\n.fa-crosshairs:before {\n  content: \"\\f05b\";\n}\n.fa-times-circle-o:before {\n  content: \"\\f05c\";\n}\n.fa-check-circle-o:before {\n  content: \"\\f05d\";\n}\n.fa-ban:before {\n  content: \"\\f05e\";\n}\n.fa-arrow-left:before {\n  content: \"\\f060\";\n}\n.fa-arrow-right:before {\n  content: \"\\f061\";\n}\n.fa-arrow-up:before {\n  content: \"\\f062\";\n}\n.fa-arrow-down:before {\n  content: \"\\f063\";\n}\n.fa-mail-forward:before,\n.fa-share:before {\n  content: \"\\f064\";\n}\n.fa-expand:before {\n  content: \"\\f065\";\n}\n.fa-compress:before {\n  content: \"\\f066\";\n}\n.fa-plus:before {\n  content: \"\\f067\";\n}\n.fa-minus:before {\n  content: \"\\f068\";\n}\n.fa-asterisk:before {\n  content: \"\\f069\";\n}\n.fa-exclamation-circle:before {\n  content: \"\\f06a\";\n}\n.fa-gift:before {\n  content: \"\\f06b\";\n}\n.fa-leaf:before {\n  content: \"\\f06c\";\n}\n.fa-fire:before {\n  content: \"\\f06d\";\n}\n.fa-eye:before {\n  content: \"\\f06e\";\n}\n.fa-eye-slash:before {\n  content: \"\\f070\";\n}\n.fa-warning:before,\n.fa-exclamation-triangle:before {\n  content: \"\\f071\";\n}\n.fa-plane:before {\n  content: \"\\f072\";\n}\n.fa-calendar:before {\n  content: \"\\f073\";\n}\n.fa-random:before {\n  content: \"\\f074\";\n}\n.fa-comment:before {\n  content: \"\\f075\";\n}\n.fa-magnet:before {\n  content: \"\\f076\";\n}\n.fa-chevron-up:before {\n  content: \"\\f077\";\n}\n.fa-chevron-down:before {\n  content: \"\\f078\";\n}\n.fa-retweet:before {\n  content: \"\\f079\";\n}\n.fa-shopping-cart:before {\n  content: \"\\f07a\";\n}\n.fa-folder:before {\n  content: \"\\f07b\";\n}\n.fa-folder-open:before {\n  content: \"\\f07c\";\n}\n.fa-arrows-v:before {\n  content: \"\\f07d\";\n}\n.fa-arrows-h:before {\n  content: \"\\f07e\";\n}\n.fa-bar-chart-o:before,\n.fa-bar-chart:before {\n  content: \"\\f080\";\n}\n.fa-twitter-square:before {\n  content: \"\\f081\";\n}\n.fa-facebook-square:before {\n  content: \"\\f082\";\n}\n.fa-camera-retro:before {\n  content: \"\\f083\";\n}\n.fa-key:before {\n  content: \"\\f084\";\n}\n.fa-gears:before,\n.fa-cogs:before {\n  content: \"\\f085\";\n}\n.fa-comments:before {\n  content: \"\\f086\";\n}\n.fa-thumbs-o-up:before {\n  content: \"\\f087\";\n}\n.fa-thumbs-o-down:before {\n  content: \"\\f088\";\n}\n.fa-star-half:before {\n  content: \"\\f089\";\n}\n.fa-heart-o:before {\n  content: \"\\f08a\";\n}\n.fa-sign-out:before {\n  content: \"\\f08b\";\n}\n.fa-linkedin-square:before {\n  content: \"\\f08c\";\n}\n.fa-thumb-tack:before {\n  content: \"\\f08d\";\n}\n.fa-external-link:before {\n  content: \"\\f08e\";\n}\n.fa-sign-in:before {\n  content: \"\\f090\";\n}\n.fa-trophy:before {\n  content: \"\\f091\";\n}\n.fa-github-square:before {\n  content: \"\\f092\";\n}\n.fa-upload:before {\n  content: \"\\f093\";\n}\n.fa-lemon-o:before {\n  content: \"\\f094\";\n}\n.fa-phone:before {\n  content: \"\\f095\";\n}\n.fa-square-o:before {\n  content: \"\\f096\";\n}\n.fa-bookmark-o:before {\n  content: \"\\f097\";\n}\n.fa-phone-square:before {\n  content: \"\\f098\";\n}\n.fa-twitter:before {\n  content: \"\\f099\";\n}\n.fa-facebook-f:before,\n.fa-facebook:before {\n  content: \"\\f09a\";\n}\n.fa-github:before {\n  content: \"\\f09b\";\n}\n.fa-unlock:before {\n  content: \"\\f09c\";\n}\n.fa-credit-card:before {\n  content: \"\\f09d\";\n}\n.fa-rss:before {\n  content: \"\\f09e\";\n}\n.fa-hdd-o:before {\n  content: \"\\f0a0\";\n}\n.fa-bullhorn:before {\n  content: \"\\f0a1\";\n}\n.fa-bell:before {\n  content: \"\\f0f3\";\n}\n.fa-certificate:before {\n  content: \"\\f0a3\";\n}\n.fa-hand-o-right:before {\n  content: \"\\f0a4\";\n}\n.fa-hand-o-left:before {\n  content: \"\\f0a5\";\n}\n.fa-hand-o-up:before {\n  content: \"\\f0a6\";\n}\n.fa-hand-o-down:before {\n  content: \"\\f0a7\";\n}\n.fa-arrow-circle-left:before {\n  content: \"\\f0a8\";\n}\n.fa-arrow-circle-right:before {\n  content: \"\\f0a9\";\n}\n.fa-arrow-circle-up:before {\n  content: \"\\f0aa\";\n}\n.fa-arrow-circle-down:before {\n  content: \"\\f0ab\";\n}\n.fa-globe:before {\n  content: \"\\f0ac\";\n}\n.fa-wrench:before {\n  content: \"\\f0ad\";\n}\n.fa-tasks:before {\n  content: \"\\f0ae\";\n}\n.fa-filter:before {\n  content: \"\\f0b0\";\n}\n.fa-briefcase:before {\n  content: \"\\f0b1\";\n}\n.fa-arrows-alt:before {\n  content: \"\\f0b2\";\n}\n.fa-group:before,\n.fa-users:before {\n  content: \"\\f0c0\";\n}\n.fa-chain:before,\n.fa-link:before {\n  content: \"\\f0c1\";\n}\n.fa-cloud:before {\n  content: \"\\f0c2\";\n}\n.fa-flask:before {\n  content: \"\\f0c3\";\n}\n.fa-cut:before,\n.fa-scissors:before {\n  content: \"\\f0c4\";\n}\n.fa-copy:before,\n.fa-files-o:before {\n  content: \"\\f0c5\";\n}\n.fa-paperclip:before {\n  content: \"\\f0c6\";\n}\n.fa-save:before,\n.fa-floppy-o:before {\n  content: \"\\f0c7\";\n}\n.fa-square:before {\n  content: \"\\f0c8\";\n}\n.fa-navicon:before,\n.fa-reorder:before,\n.fa-bars:before {\n  content: \"\\f0c9\";\n}\n.fa-list-ul:before {\n  content: \"\\f0ca\";\n}\n.fa-list-ol:before {\n  content: \"\\f0cb\";\n}\n.fa-strikethrough:before {\n  content: \"\\f0cc\";\n}\n.fa-underline:before {\n  content: \"\\f0cd\";\n}\n.fa-table:before {\n  content: \"\\f0ce\";\n}\n.fa-magic:before {\n  content: \"\\f0d0\";\n}\n.fa-truck:before {\n  content: \"\\f0d1\";\n}\n.fa-pinterest:before {\n  content: \"\\f0d2\";\n}\n.fa-pinterest-square:before {\n  content: \"\\f0d3\";\n}\n.fa-google-plus-square:before {\n  content: \"\\f0d4\";\n}\n.fa-google-plus:before {\n  content: \"\\f0d5\";\n}\n.fa-money:before {\n  content: \"\\f0d6\";\n}\n.fa-caret-down:before {\n  content: \"\\f0d7\";\n}\n.fa-caret-up:before {\n  content: \"\\f0d8\";\n}\n.fa-caret-left:before {\n  content: \"\\f0d9\";\n}\n.fa-caret-right:before {\n  content: \"\\f0da\";\n}\n.fa-columns:before {\n  content: \"\\f0db\";\n}\n.fa-unsorted:before,\n.fa-sort:before {\n  content: \"\\f0dc\";\n}\n.fa-sort-down:before,\n.fa-sort-desc:before {\n  content: \"\\f0dd\";\n}\n.fa-sort-up:before,\n.fa-sort-asc:before {\n  content: \"\\f0de\";\n}\n.fa-envelope:before {\n  content: \"\\f0e0\";\n}\n.fa-linkedin:before {\n  content: \"\\f0e1\";\n}\n.fa-rotate-left:before,\n.fa-undo:before {\n  content: \"\\f0e2\";\n}\n.fa-legal:before,\n.fa-gavel:before {\n  content: \"\\f0e3\";\n}\n.fa-dashboard:before,\n.fa-tachometer:before {\n  content: \"\\f0e4\";\n}\n.fa-comment-o:before {\n  content: \"\\f0e5\";\n}\n.fa-comments-o:before {\n  content: \"\\f0e6\";\n}\n.fa-flash:before,\n.fa-bolt:before {\n  content: \"\\f0e7\";\n}\n.fa-sitemap:before {\n  content: \"\\f0e8\";\n}\n.fa-umbrella:before {\n  content: \"\\f0e9\";\n}\n.fa-paste:before,\n.fa-clipboard:before {\n  content: \"\\f0ea\";\n}\n.fa-lightbulb-o:before {\n  content: \"\\f0eb\";\n}\n.fa-exchange:before {\n  content: \"\\f0ec\";\n}\n.fa-cloud-download:before {\n  content: \"\\f0ed\";\n}\n.fa-cloud-upload:before {\n  content: \"\\f0ee\";\n}\n.fa-user-md:before {\n  content: \"\\f0f0\";\n}\n.fa-stethoscope:before {\n  content: \"\\f0f1\";\n}\n.fa-suitcase:before {\n  content: \"\\f0f2\";\n}\n.fa-bell-o:before {\n  content: \"\\f0a2\";\n}\n.fa-coffee:before {\n  content: \"\\f0f4\";\n}\n.fa-cutlery:before {\n  content: \"\\f0f5\";\n}\n.fa-file-text-o:before {\n  content: \"\\f0f6\";\n}\n.fa-building-o:before {\n  content: \"\\f0f7\";\n}\n.fa-hospital-o:before {\n  content: \"\\f0f8\";\n}\n.fa-ambulance:before {\n  content: \"\\f0f9\";\n}\n.fa-medkit:before {\n  content: \"\\f0fa\";\n}\n.fa-fighter-jet:before {\n  content: \"\\f0fb\";\n}\n.fa-beer:before {\n  content: \"\\f0fc\";\n}\n.fa-h-square:before {\n  content: \"\\f0fd\";\n}\n.fa-plus-square:before {\n  content: \"\\f0fe\";\n}\n.fa-angle-double-left:before {\n  content: \"\\f100\";\n}\n.fa-angle-double-right:before {\n  content: \"\\f101\";\n}\n.fa-angle-double-up:before {\n  content: \"\\f102\";\n}\n.fa-angle-double-down:before {\n  content: \"\\f103\";\n}\n.fa-angle-left:before {\n  content: \"\\f104\";\n}\n.fa-angle-right:before {\n  content: \"\\f105\";\n}\n.fa-angle-up:before {\n  content: \"\\f106\";\n}\n.fa-angle-down:before {\n  content: \"\\f107\";\n}\n.fa-desktop:before {\n  content: \"\\f108\";\n}\n.fa-laptop:before {\n  content: \"\\f109\";\n}\n.fa-tablet:before {\n  content: \"\\f10a\";\n}\n.fa-mobile-phone:before,\n.fa-mobile:before {\n  content: \"\\f10b\";\n}\n.fa-circle-o:before {\n  content: \"\\f10c\";\n}\n.fa-quote-left:before {\n  content: \"\\f10d\";\n}\n.fa-quote-right:before {\n  content: \"\\f10e\";\n}\n.fa-spinner:before {\n  content: \"\\f110\";\n}\n.fa-circle:before {\n  content: \"\\f111\";\n}\n.fa-mail-reply:before,\n.fa-reply:before {\n  content: \"\\f112\";\n}\n.fa-github-alt:before {\n  content: \"\\f113\";\n}\n.fa-folder-o:before {\n  content: \"\\f114\";\n}\n.fa-folder-open-o:before {\n  content: \"\\f115\";\n}\n.fa-smile-o:before {\n  content: \"\\f118\";\n}\n.fa-frown-o:before {\n  content: \"\\f119\";\n}\n.fa-meh-o:before {\n  content: \"\\f11a\";\n}\n.fa-gamepad:before {\n  content: \"\\f11b\";\n}\n.fa-keyboard-o:before {\n  content: \"\\f11c\";\n}\n.fa-flag-o:before {\n  content: \"\\f11d\";\n}\n.fa-flag-checkered:before {\n  content: \"\\f11e\";\n}\n.fa-terminal:before {\n  content: \"\\f120\";\n}\n.fa-code:before {\n  content: \"\\f121\";\n}\n.fa-mail-reply-all:before,\n.fa-reply-all:before {\n  content: \"\\f122\";\n}\n.fa-star-half-empty:before,\n.fa-star-half-full:before,\n.fa-star-half-o:before {\n  content: \"\\f123\";\n}\n.fa-location-arrow:before {\n  content: \"\\f124\";\n}\n.fa-crop:before {\n  content: \"\\f125\";\n}\n.fa-code-fork:before {\n  content: \"\\f126\";\n}\n.fa-unlink:before,\n.fa-chain-broken:before {\n  content: \"\\f127\";\n}\n.fa-question:before {\n  content: \"\\f128\";\n}\n.fa-info:before {\n  content: \"\\f129\";\n}\n.fa-exclamation:before {\n  content: \"\\f12a\";\n}\n.fa-superscript:before {\n  content: \"\\f12b\";\n}\n.fa-subscript:before {\n  content: \"\\f12c\";\n}\n.fa-eraser:before {\n  content: \"\\f12d\";\n}\n.fa-puzzle-piece:before {\n  content: \"\\f12e\";\n}\n.fa-microphone:before {\n  content: \"\\f130\";\n}\n.fa-microphone-slash:before {\n  content: \"\\f131\";\n}\n.fa-shield:before {\n  content: \"\\f132\";\n}\n.fa-calendar-o:before {\n  content: \"\\f133\";\n}\n.fa-fire-extinguisher:before {\n  content: \"\\f134\";\n}\n.fa-rocket:before {\n  content: \"\\f135\";\n}\n.fa-maxcdn:before {\n  content: \"\\f136\";\n}\n.fa-chevron-circle-left:before {\n  content: \"\\f137\";\n}\n.fa-chevron-circle-right:before {\n  content: \"\\f138\";\n}\n.fa-chevron-circle-up:before {\n  content: \"\\f139\";\n}\n.fa-chevron-circle-down:before {\n  content: \"\\f13a\";\n}\n.fa-html5:before {\n  content: \"\\f13b\";\n}\n.fa-css3:before {\n  content: \"\\f13c\";\n}\n.fa-anchor:before {\n  content: \"\\f13d\";\n}\n.fa-unlock-alt:before {\n  content: \"\\f13e\";\n}\n.fa-bullseye:before {\n  content: \"\\f140\";\n}\n.fa-ellipsis-h:before {\n  content: \"\\f141\";\n}\n.fa-ellipsis-v:before {\n  content: \"\\f142\";\n}\n.fa-rss-square:before {\n  content: \"\\f143\";\n}\n.fa-play-circle:before {\n  content: \"\\f144\";\n}\n.fa-ticket:before {\n  content: \"\\f145\";\n}\n.fa-minus-square:before {\n  content: \"\\f146\";\n}\n.fa-minus-square-o:before {\n  content: \"\\f147\";\n}\n.fa-level-up:before {\n  content: \"\\f148\";\n}\n.fa-level-down:before {\n  content: \"\\f149\";\n}\n.fa-check-square:before {\n  content: \"\\f14a\";\n}\n.fa-pencil-square:before {\n  content: \"\\f14b\";\n}\n.fa-external-link-square:before {\n  content: \"\\f14c\";\n}\n.fa-share-square:before {\n  content: \"\\f14d\";\n}\n.fa-compass:before {\n  content: \"\\f14e\";\n}\n.fa-toggle-down:before,\n.fa-caret-square-o-down:before {\n  content: \"\\f150\";\n}\n.fa-toggle-up:before,\n.fa-caret-square-o-up:before {\n  content: \"\\f151\";\n}\n.fa-toggle-right:before,\n.fa-caret-square-o-right:before {\n  content: \"\\f152\";\n}\n.fa-euro:before,\n.fa-eur:before {\n  content: \"\\f153\";\n}\n.fa-gbp:before {\n  content: \"\\f154\";\n}\n.fa-dollar:before,\n.fa-usd:before {\n  content: \"\\f155\";\n}\n.fa-rupee:before,\n.fa-inr:before {\n  content: \"\\f156\";\n}\n.fa-cny:before,\n.fa-rmb:before,\n.fa-yen:before,\n.fa-jpy:before {\n  content: \"\\f157\";\n}\n.fa-ruble:before,\n.fa-rouble:before,\n.fa-rub:before {\n  content: \"\\f158\";\n}\n.fa-won:before,\n.fa-krw:before {\n  content: \"\\f159\";\n}\n.fa-bitcoin:before,\n.fa-btc:before {\n  content: \"\\f15a\";\n}\n.fa-file:before {\n  content: \"\\f15b\";\n}\n.fa-file-text:before {\n  content: \"\\f15c\";\n}\n.fa-sort-alpha-asc:before {\n  content: \"\\f15d\";\n}\n.fa-sort-alpha-desc:before {\n  content: \"\\f15e\";\n}\n.fa-sort-amount-asc:before {\n  content: \"\\f160\";\n}\n.fa-sort-amount-desc:before {\n  content: \"\\f161\";\n}\n.fa-sort-numeric-asc:before {\n  content: \"\\f162\";\n}\n.fa-sort-numeric-desc:before {\n  content: \"\\f163\";\n}\n.fa-thumbs-up:before {\n  content: \"\\f164\";\n}\n.fa-thumbs-down:before {\n  content: \"\\f165\";\n}\n.fa-youtube-square:before {\n  content: \"\\f166\";\n}\n.fa-youtube:before {\n  content: \"\\f167\";\n}\n.fa-xing:before {\n  content: \"\\f168\";\n}\n.fa-xing-square:before {\n  content: \"\\f169\";\n}\n.fa-youtube-play:before {\n  content: \"\\f16a\";\n}\n.fa-dropbox:before {\n  content: \"\\f16b\";\n}\n.fa-stack-overflow:before {\n  content: \"\\f16c\";\n}\n.fa-instagram:before {\n  content: \"\\f16d\";\n}\n.fa-flickr:before {\n  content: \"\\f16e\";\n}\n.fa-adn:before {\n  content: \"\\f170\";\n}\n.fa-bitbucket:before {\n  content: \"\\f171\";\n}\n.fa-bitbucket-square:before {\n  content: \"\\f172\";\n}\n.fa-tumblr:before {\n  content: \"\\f173\";\n}\n.fa-tumblr-square:before {\n  content: \"\\f174\";\n}\n.fa-long-arrow-down:before {\n  content: \"\\f175\";\n}\n.fa-long-arrow-up:before {\n  content: \"\\f176\";\n}\n.fa-long-arrow-left:before {\n  content: \"\\f177\";\n}\n.fa-long-arrow-right:before {\n  content: \"\\f178\";\n}\n.fa-apple:before {\n  content: \"\\f179\";\n}\n.fa-windows:before {\n  content: \"\\f17a\";\n}\n.fa-android:before {\n  content: \"\\f17b\";\n}\n.fa-linux:before {\n  content: \"\\f17c\";\n}\n.fa-dribbble:before {\n  content: \"\\f17d\";\n}\n.fa-skype:before {\n  content: \"\\f17e\";\n}\n.fa-foursquare:before {\n  content: \"\\f180\";\n}\n.fa-trello:before {\n  content: \"\\f181\";\n}\n.fa-female:before {\n  content: \"\\f182\";\n}\n.fa-male:before {\n  content: \"\\f183\";\n}\n.fa-gittip:before,\n.fa-gratipay:before {\n  content: \"\\f184\";\n}\n.fa-sun-o:before {\n  content: \"\\f185\";\n}\n.fa-moon-o:before {\n  content: \"\\f186\";\n}\n.fa-archive:before {\n  content: \"\\f187\";\n}\n.fa-bug:before {\n  content: \"\\f188\";\n}\n.fa-vk:before {\n  content: \"\\f189\";\n}\n.fa-weibo:before {\n  content: \"\\f18a\";\n}\n.fa-renren:before {\n  content: \"\\f18b\";\n}\n.fa-pagelines:before {\n  content: \"\\f18c\";\n}\n.fa-stack-exchange:before {\n  content: \"\\f18d\";\n}\n.fa-arrow-circle-o-right:before {\n  content: \"\\f18e\";\n}\n.fa-arrow-circle-o-left:before {\n  content: \"\\f190\";\n}\n.fa-toggle-left:before,\n.fa-caret-square-o-left:before {\n  content: \"\\f191\";\n}\n.fa-dot-circle-o:before {\n  content: \"\\f192\";\n}\n.fa-wheelchair:before {\n  content: \"\\f193\";\n}\n.fa-vimeo-square:before {\n  content: \"\\f194\";\n}\n.fa-turkish-lira:before,\n.fa-try:before {\n  content: \"\\f195\";\n}\n.fa-plus-square-o:before {\n  content: \"\\f196\";\n}\n.fa-space-shuttle:before {\n  content: \"\\f197\";\n}\n.fa-slack:before {\n  content: \"\\f198\";\n}\n.fa-envelope-square:before {\n  content: \"\\f199\";\n}\n.fa-wordpress:before {\n  content: \"\\f19a\";\n}\n.fa-openid:before {\n  content: \"\\f19b\";\n}\n.fa-institution:before,\n.fa-bank:before,\n.fa-university:before {\n  content: \"\\f19c\";\n}\n.fa-mortar-board:before,\n.fa-graduation-cap:before {\n  content: \"\\f19d\";\n}\n.fa-yahoo:before {\n  content: \"\\f19e\";\n}\n.fa-google:before {\n  content: \"\\f1a0\";\n}\n.fa-reddit:before {\n  content: \"\\f1a1\";\n}\n.fa-reddit-square:before {\n  content: \"\\f1a2\";\n}\n.fa-stumbleupon-circle:before {\n  content: \"\\f1a3\";\n}\n.fa-stumbleupon:before {\n  content: \"\\f1a4\";\n}\n.fa-delicious:before {\n  content: \"\\f1a5\";\n}\n.fa-digg:before {\n  content: \"\\f1a6\";\n}\n.fa-pied-piper:before {\n  content: \"\\f1a7\";\n}\n.fa-pied-piper-alt:before {\n  content: \"\\f1a8\";\n}\n.fa-drupal:before {\n  content: \"\\f1a9\";\n}\n.fa-joomla:before {\n  content: \"\\f1aa\";\n}\n.fa-language:before {\n  content: \"\\f1ab\";\n}\n.fa-fax:before {\n  content: \"\\f1ac\";\n}\n.fa-building:before {\n  content: \"\\f1ad\";\n}\n.fa-child:before {\n  content: \"\\f1ae\";\n}\n.fa-paw:before {\n  content: \"\\f1b0\";\n}\n.fa-spoon:before {\n  content: \"\\f1b1\";\n}\n.fa-cube:before {\n  content: \"\\f1b2\";\n}\n.fa-cubes:before {\n  content: \"\\f1b3\";\n}\n.fa-behance:before {\n  content: \"\\f1b4\";\n}\n.fa-behance-square:before {\n  content: \"\\f1b5\";\n}\n.fa-steam:before {\n  content: \"\\f1b6\";\n}\n.fa-steam-square:before {\n  content: \"\\f1b7\";\n}\n.fa-recycle:before {\n  content: \"\\f1b8\";\n}\n.fa-automobile:before,\n.fa-car:before {\n  content: \"\\f1b9\";\n}\n.fa-cab:before,\n.fa-taxi:before {\n  content: \"\\f1ba\";\n}\n.fa-tree:before {\n  content: \"\\f1bb\";\n}\n.fa-spotify:before {\n  content: \"\\f1bc\";\n}\n.fa-deviantart:before {\n  content: \"\\f1bd\";\n}\n.fa-soundcloud:before {\n  content: \"\\f1be\";\n}\n.fa-database:before {\n  content: \"\\f1c0\";\n}\n.fa-file-pdf-o:before {\n  content: \"\\f1c1\";\n}\n.fa-file-word-o:before {\n  content: \"\\f1c2\";\n}\n.fa-file-excel-o:before {\n  content: \"\\f1c3\";\n}\n.fa-file-powerpoint-o:before {\n  content: \"\\f1c4\";\n}\n.fa-file-photo-o:before,\n.fa-file-picture-o:before,\n.fa-file-image-o:before {\n  content: \"\\f1c5\";\n}\n.fa-file-zip-o:before,\n.fa-file-archive-o:before {\n  content: \"\\f1c6\";\n}\n.fa-file-sound-o:before,\n.fa-file-audio-o:before {\n  content: \"\\f1c7\";\n}\n.fa-file-movie-o:before,\n.fa-file-video-o:before {\n  content: \"\\f1c8\";\n}\n.fa-file-code-o:before {\n  content: \"\\f1c9\";\n}\n.fa-vine:before {\n  content: \"\\f1ca\";\n}\n.fa-codepen:before {\n  content: \"\\f1cb\";\n}\n.fa-jsfiddle:before {\n  content: \"\\f1cc\";\n}\n.fa-life-bouy:before,\n.fa-life-buoy:before,\n.fa-life-saver:before,\n.fa-support:before,\n.fa-life-ring:before {\n  content: \"\\f1cd\";\n}\n.fa-circle-o-notch:before {\n  content: \"\\f1ce\";\n}\n.fa-ra:before,\n.fa-rebel:before {\n  content: \"\\f1d0\";\n}\n.fa-ge:before,\n.fa-empire:before {\n  content: \"\\f1d1\";\n}\n.fa-git-square:before {\n  content: \"\\f1d2\";\n}\n.fa-git:before {\n  content: \"\\f1d3\";\n}\n.fa-hacker-news:before {\n  content: \"\\f1d4\";\n}\n.fa-tencent-weibo:before {\n  content: \"\\f1d5\";\n}\n.fa-qq:before {\n  content: \"\\f1d6\";\n}\n.fa-wechat:before,\n.fa-weixin:before {\n  content: \"\\f1d7\";\n}\n.fa-send:before,\n.fa-paper-plane:before {\n  content: \"\\f1d8\";\n}\n.fa-send-o:before,\n.fa-paper-plane-o:before {\n  content: \"\\f1d9\";\n}\n.fa-history:before {\n  content: \"\\f1da\";\n}\n.fa-genderless:before,\n.fa-circle-thin:before {\n  content: \"\\f1db\";\n}\n.fa-header:before {\n  content: \"\\f1dc\";\n}\n.fa-paragraph:before {\n  content: \"\\f1dd\";\n}\n.fa-sliders:before {\n  content: \"\\f1de\";\n}\n.fa-share-alt:before {\n  content: \"\\f1e0\";\n}\n.fa-share-alt-square:before {\n  content: \"\\f1e1\";\n}\n.fa-bomb:before {\n  content: \"\\f1e2\";\n}\n.fa-soccer-ball-o:before,\n.fa-futbol-o:before {\n  content: \"\\f1e3\";\n}\n.fa-tty:before {\n  content: \"\\f1e4\";\n}\n.fa-binoculars:before {\n  content: \"\\f1e5\";\n}\n.fa-plug:before {\n  content: \"\\f1e6\";\n}\n.fa-slideshare:before {\n  content: \"\\f1e7\";\n}\n.fa-twitch:before {\n  content: \"\\f1e8\";\n}\n.fa-yelp:before {\n  content: \"\\f1e9\";\n}\n.fa-newspaper-o:before {\n  content: \"\\f1ea\";\n}\n.fa-wifi:before {\n  content: \"\\f1eb\";\n}\n.fa-calculator:before {\n  content: \"\\f1ec\";\n}\n.fa-paypal:before {\n  content: \"\\f1ed\";\n}\n.fa-google-wallet:before {\n  content: \"\\f1ee\";\n}\n.fa-cc-visa:before {\n  content: \"\\f1f0\";\n}\n.fa-cc-mastercard:before {\n  content: \"\\f1f1\";\n}\n.fa-cc-discover:before {\n  content: \"\\f1f2\";\n}\n.fa-cc-amex:before {\n  content: \"\\f1f3\";\n}\n.fa-cc-paypal:before {\n  content: \"\\f1f4\";\n}\n.fa-cc-stripe:before {\n  content: \"\\f1f5\";\n}\n.fa-bell-slash:before {\n  content: \"\\f1f6\";\n}\n.fa-bell-slash-o:before {\n  content: \"\\f1f7\";\n}\n.fa-trash:before {\n  content: \"\\f1f8\";\n}\n.fa-copyright:before {\n  content: \"\\f1f9\";\n}\n.fa-at:before {\n  content: \"\\f1fa\";\n}\n.fa-eyedropper:before {\n  content: \"\\f1fb\";\n}\n.fa-paint-brush:before {\n  content: \"\\f1fc\";\n}\n.fa-birthday-cake:before {\n  content: \"\\f1fd\";\n}\n.fa-area-chart:before {\n  content: \"\\f1fe\";\n}\n.fa-pie-chart:before {\n  content: \"\\f200\";\n}\n.fa-line-chart:before {\n  content: \"\\f201\";\n}\n.fa-lastfm:before {\n  content: \"\\f202\";\n}\n.fa-lastfm-square:before {\n  content: \"\\f203\";\n}\n.fa-toggle-off:before {\n  content: \"\\f204\";\n}\n.fa-toggle-on:before {\n  content: \"\\f205\";\n}\n.fa-bicycle:before {\n  content: \"\\f206\";\n}\n.fa-bus:before {\n  content: \"\\f207\";\n}\n.fa-ioxhost:before {\n  content: \"\\f208\";\n}\n.fa-angellist:before {\n  content: \"\\f209\";\n}\n.fa-cc:before {\n  content: \"\\f20a\";\n}\n.fa-shekel:before,\n.fa-sheqel:before,\n.fa-ils:before {\n  content: \"\\f20b\";\n}\n.fa-meanpath:before {\n  content: \"\\f20c\";\n}\n.fa-buysellads:before {\n  content: \"\\f20d\";\n}\n.fa-connectdevelop:before {\n  content: \"\\f20e\";\n}\n.fa-dashcube:before {\n  content: \"\\f210\";\n}\n.fa-forumbee:before {\n  content: \"\\f211\";\n}\n.fa-leanpub:before {\n  content: \"\\f212\";\n}\n.fa-sellsy:before {\n  content: \"\\f213\";\n}\n.fa-shirtsinbulk:before {\n  content: \"\\f214\";\n}\n.fa-simplybuilt:before {\n  content: \"\\f215\";\n}\n.fa-skyatlas:before {\n  content: \"\\f216\";\n}\n.fa-cart-plus:before {\n  content: \"\\f217\";\n}\n.fa-cart-arrow-down:before {\n  content: \"\\f218\";\n}\n.fa-diamond:before {\n  content: \"\\f219\";\n}\n.fa-ship:before {\n  content: \"\\f21a\";\n}\n.fa-user-secret:before {\n  content: \"\\f21b\";\n}\n.fa-motorcycle:before {\n  content: \"\\f21c\";\n}\n.fa-street-view:before {\n  content: \"\\f21d\";\n}\n.fa-heartbeat:before {\n  content: \"\\f21e\";\n}\n.fa-venus:before {\n  content: \"\\f221\";\n}\n.fa-mars:before {\n  content: \"\\f222\";\n}\n.fa-mercury:before {\n  content: \"\\f223\";\n}\n.fa-transgender:before {\n  content: \"\\f224\";\n}\n.fa-transgender-alt:before {\n  content: \"\\f225\";\n}\n.fa-venus-double:before {\n  content: \"\\f226\";\n}\n.fa-mars-double:before {\n  content: \"\\f227\";\n}\n.fa-venus-mars:before {\n  content: \"\\f228\";\n}\n.fa-mars-stroke:before {\n  content: \"\\f229\";\n}\n.fa-mars-stroke-v:before {\n  content: \"\\f22a\";\n}\n.fa-mars-stroke-h:before {\n  content: \"\\f22b\";\n}\n.fa-neuter:before {\n  content: \"\\f22c\";\n}\n.fa-facebook-official:before {\n  content: \"\\f230\";\n}\n.fa-pinterest-p:before {\n  content: \"\\f231\";\n}\n.fa-whatsapp:before {\n  content: \"\\f232\";\n}\n.fa-server:before {\n  content: \"\\f233\";\n}\n.fa-user-plus:before {\n  content: \"\\f234\";\n}\n.fa-user-times:before {\n  content: \"\\f235\";\n}\n.fa-hotel:before,\n.fa-bed:before {\n  content: \"\\f236\";\n}\n.fa-viacoin:before {\n  content: \"\\f237\";\n}\n.fa-train:before {\n  content: \"\\f238\";\n}\n.fa-subway:before {\n  content: \"\\f239\";\n}\n.fa-medium:before {\n  content: \"\\f23a\";\n}\n","//\n// Scaffolding\n// --------------------------------------------------\n\n\n// Reset the box-sizing\n//\n// Heads up! This reset may cause conflicts with some third-party widgets.\n// For recommendations on resolving such conflicts, see\n// http://getbootstrap.com/getting-started/#third-box-sizing\n* {\n  .box-sizing(border-box);\n}\n*:before,\n*:after {\n  .box-sizing(border-box);\n}\n\n\n// Body reset\n\nhtml {\n  font-size: 10px;\n  -webkit-tap-highlight-color: rgba(0,0,0,0);\n}\n\nbody {\n  font-family: @font-family-base;\n  font-size: @font-size-base;\n  line-height: @line-height-base;\n  color: @text-color;\n  background-color: @body-bg;\n}\n\n// Reset fonts for relevant elements\ninput,\nbutton,\nselect,\ntextarea {\n  font-family: inherit;\n  font-size: inherit;\n  line-height: inherit;\n}\n\n\n// Links\n\na {\n  color: @link-color;\n  text-decoration: none;\n\n  &:hover,\n  &:focus {\n    color: @link-hover-color;\n    text-decoration: @link-hover-decoration;\n  }\n\n  &:focus {\n    .tab-focus();\n  }\n}\n\n\n// Figures\n//\n// We reset this here because previously Normalize had no `figure` margins. This\n// ensures we don't break anyone's use of the element.\n\nfigure {\n  margin: 0;\n}\n\n\n// Images\n\nimg {\n  vertical-align: middle;\n}\n\n// Responsive images (ensure images don't scale beyond their parents)\n.img-responsive {\n  .img-responsive();\n}\n\n// Rounded corners\n.img-rounded {\n  border-radius: @border-radius-large;\n}\n\n// Image thumbnails\n//\n// Heads up! This is mixin-ed into thumbnails.less for `.thumbnail`.\n.img-thumbnail {\n  padding: @thumbnail-padding;\n  line-height: @line-height-base;\n  background-color: @thumbnail-bg;\n  border: 1px solid @thumbnail-border;\n  border-radius: @thumbnail-border-radius;\n  .transition(all .2s ease-in-out);\n\n  // Keep them at most 100% wide\n  .img-responsive(inline-block);\n}\n\n// Perfect circle\n.img-circle {\n  border-radius: 50%; // set radius in percents\n}\n\n\n// Horizontal rules\n\nhr {\n  margin-top:    @line-height-computed;\n  margin-bottom: @line-height-computed;\n  border: 0;\n  border-top: 1px solid @hr-border;\n}\n\n\n// Only display content to screen readers\n//\n// See: http://a11yproject.com/posts/how-to-hide-content/\n\n.sr-only {\n  position: absolute;\n  width: 1px;\n  height: 1px;\n  margin: -1px;\n  padding: 0;\n  overflow: hidden;\n  clip: rect(0,0,0,0);\n  border: 0;\n}\n\n// Use in conjunction with .sr-only to only display content when it's focused.\n// Useful for \"Skip to main content\" links; see http://www.w3.org/TR/2013/NOTE-WCAG20-TECHS-20130905/G1\n// Credit: HTML5 Boilerplate\n\n.sr-only-focusable {\n  &:active,\n  &:focus {\n    position: static;\n    width: auto;\n    height: auto;\n    margin: 0;\n    overflow: visible;\n    clip: auto;\n  }\n}\n","// WebKit-style focus\n\n.tab-focus() {\n  // Default\n  outline: thin dotted;\n  // WebKit\n  outline: 5px auto -webkit-focus-ring-color;\n  outline-offset: -2px;\n}\n","// Image Mixins\n// - Responsive image\n// - Retina image\n\n\n// Responsive image\n//\n// Keep images from scaling beyond the width of their parents.\n.img-responsive(@display: block) {\n  display: @display;\n  max-width: 100%; // Part 1: Set a maximum relative to the parent\n  height: auto; // Part 2: Scale the height according to the width, otherwise you get stretching\n}\n\n\n// Retina image\n//\n// Short retina mixin for setting background-image and -size. Note that the\n// spelling of `min--moz-device-pixel-ratio` is intentional.\n.img-retina(@file-1x; @file-2x; @width-1x; @height-1x) {\n  background-image: url(\"@{file-1x}\");\n\n  @media\n  only screen and (-webkit-min-device-pixel-ratio: 2),\n  only screen and (   min--moz-device-pixel-ratio: 2),\n  only screen and (     -o-min-device-pixel-ratio: 2/1),\n  only screen and (        min-device-pixel-ratio: 2),\n  only screen and (                min-resolution: 192dpi),\n  only screen and (                min-resolution: 2dppx) {\n    background-image: url(\"@{file-2x}\");\n    background-size: @width-1x @height-1x;\n  }\n}\n","// Grid system\n//\n// Generate semantic grid columns with these mixins.\n\n// Centered container element\n.container-fixed(@gutter: @grid-gutter-width) {\n  margin-right: auto;\n  margin-left: auto;\n  padding-left:  (@gutter / 2);\n  padding-right: (@gutter / 2);\n  &:extend(.clearfix all);\n}\n\n// Creates a wrapper for a series of columns\n.make-row(@gutter: @grid-gutter-width) {\n  margin-left:  (@gutter / -2);\n  margin-right: (@gutter / -2);\n  &:extend(.clearfix all);\n}\n\n// Generate the extra small columns\n.make-xs-column(@columns; @gutter: @grid-gutter-width) {\n  position: relative;\n  float: left;\n  width: percentage((@columns / @grid-columns));\n  min-height: 1px;\n  padding-left:  (@gutter / 2);\n  padding-right: (@gutter / 2);\n}\n.make-xs-column-offset(@columns) {\n  margin-left: percentage((@columns / @grid-columns));\n}\n.make-xs-column-push(@columns) {\n  left: percentage((@columns / @grid-columns));\n}\n.make-xs-column-pull(@columns) {\n  right: percentage((@columns / @grid-columns));\n}\n\n// Generate the small columns\n.make-sm-column(@columns; @gutter: @grid-gutter-width) {\n  position: relative;\n  min-height: 1px;\n  padding-left:  (@gutter / 2);\n  padding-right: (@gutter / 2);\n\n  @media (min-width: @screen-sm-min) {\n    float: left;\n    width: percentage((@columns / @grid-columns));\n  }\n}\n.make-sm-column-offset(@columns) {\n  @media (min-width: @screen-sm-min) {\n    margin-left: percentage((@columns / @grid-columns));\n  }\n}\n.make-sm-column-push(@columns) {\n  @media (min-width: @screen-sm-min) {\n    left: percentage((@columns / @grid-columns));\n  }\n}\n.make-sm-column-pull(@columns) {\n  @media (min-width: @screen-sm-min) {\n    right: percentage((@columns / @grid-columns));\n  }\n}\n\n// Generate the medium columns\n.make-md-column(@columns; @gutter: @grid-gutter-width) {\n  position: relative;\n  min-height: 1px;\n  padding-left:  (@gutter / 2);\n  padding-right: (@gutter / 2);\n\n  @media (min-width: @screen-md-min) {\n    float: left;\n    width: percentage((@columns / @grid-columns));\n  }\n}\n.make-md-column-offset(@columns) {\n  @media (min-width: @screen-md-min) {\n    margin-left: percentage((@columns / @grid-columns));\n  }\n}\n.make-md-column-push(@columns) {\n  @media (min-width: @screen-md-min) {\n    left: percentage((@columns / @grid-columns));\n  }\n}\n.make-md-column-pull(@columns) {\n  @media (min-width: @screen-md-min) {\n    right: percentage((@columns / @grid-columns));\n  }\n}\n\n// Generate the large columns\n.make-lg-column(@columns; @gutter: @grid-gutter-width) {\n  position: relative;\n  min-height: 1px;\n  padding-left:  (@gutter / 2);\n  padding-right: (@gutter / 2);\n\n  @media (min-width: @screen-lg-min) {\n    float: left;\n    width: percentage((@columns / @grid-columns));\n  }\n}\n.make-lg-column-offset(@columns) {\n  @media (min-width: @screen-lg-min) {\n    margin-left: percentage((@columns / @grid-columns));\n  }\n}\n.make-lg-column-push(@columns) {\n  @media (min-width: @screen-lg-min) {\n    left: percentage((@columns / @grid-columns));\n  }\n}\n.make-lg-column-pull(@columns) {\n  @media (min-width: @screen-lg-min) {\n    right: percentage((@columns / @grid-columns));\n  }\n}\n","//\n// Grid system\n// --------------------------------------------------\n\n\n// Container widths\n//\n// Set the container width, and override it for fixed navbars in media queries.\n\n.container {\n  .container-fixed();\n\n  @media (min-width: @screen-sm-min) {\n    width: @container-sm;\n  }\n  @media (min-width: @screen-md-min) {\n    width: @container-md;\n  }\n  @media (min-width: @screen-lg-min) {\n    width: @container-lg;\n  }\n}\n\n\n// Fluid container\n//\n// Utilizes the mixin meant for fixed width containers, but without any defined\n// width for fluid, full width layouts.\n\n.container-fluid {\n  .container-fixed();\n}\n\n\n// Row\n//\n// Rows contain and clear the floats of your columns.\n\n.row {\n  .make-row();\n}\n\n\n// Columns\n//\n// Common styles for small and large grid columns\n\n.make-grid-columns();\n\n\n// Extra small grid\n//\n// Columns, offsets, pushes, and pulls for extra small devices like\n// smartphones.\n\n.make-grid(xs);\n\n\n// Small grid\n//\n// Columns, offsets, pushes, and pulls for the small device range, from phones\n// to tablets.\n\n@media (min-width: @screen-sm-min) {\n  .make-grid(sm);\n}\n\n\n// Medium grid\n//\n// Columns, offsets, pushes, and pulls for the desktop device range.\n\n@media (min-width: @screen-md-min) {\n  .make-grid(md);\n}\n\n\n// Large grid\n//\n// Columns, offsets, pushes, and pulls for the large desktop device range.\n\n@media (min-width: @screen-lg-min) {\n  .make-grid(lg);\n}\n","// Framework grid generation\n//\n// Used only by Bootstrap to generate the correct number of grid classes given\n// any value of `@grid-columns`.\n\n.make-grid-columns() {\n  // Common styles for all sizes of grid columns, widths 1-12\n  .col(@index) { // initial\n    @item: ~\".col-xs-@{index}, .col-sm-@{index}, .col-md-@{index}, .col-lg-@{index}\";\n    .col((@index + 1), @item);\n  }\n  .col(@index, @list) when (@index =< @grid-columns) { // general; \"=<\" isn't a typo\n    @item: ~\".col-xs-@{index}, .col-sm-@{index}, .col-md-@{index}, .col-lg-@{index}\";\n    .col((@index + 1), ~\"@{list}, @{item}\");\n  }\n  .col(@index, @list) when (@index > @grid-columns) { // terminal\n    @{list} {\n      position: relative;\n      // Prevent columns from collapsing when empty\n      min-height: 1px;\n      // Inner gutter via padding\n      padding-left:  (@grid-gutter-width / 2);\n      padding-right: (@grid-gutter-width / 2);\n    }\n  }\n  .col(1); // kickstart it\n}\n\n.float-grid-columns(@class) {\n  .col(@index) { // initial\n    @item: ~\".col-@{class}-@{index}\";\n    .col((@index + 1), @item);\n  }\n  .col(@index, @list) when (@index =< @grid-columns) { // general\n    @item: ~\".col-@{class}-@{index}\";\n    .col((@index + 1), ~\"@{list}, @{item}\");\n  }\n  .col(@index, @list) when (@index > @grid-columns) { // terminal\n    @{list} {\n      float: left;\n    }\n  }\n  .col(1); // kickstart it\n}\n\n.calc-grid-column(@index, @class, @type) when (@type = width) and (@index > 0) {\n  .col-@{class}-@{index} {\n    width: percentage((@index / @grid-columns));\n  }\n}\n.calc-grid-column(@index, @class, @type) when (@type = push) and (@index > 0) {\n  .col-@{class}-push-@{index} {\n    left: percentage((@index / @grid-columns));\n  }\n}\n.calc-grid-column(@index, @class, @type) when (@type = push) and (@index = 0) {\n  .col-@{class}-push-0 {\n    left: auto;\n  }\n}\n.calc-grid-column(@index, @class, @type) when (@type = pull) and (@index > 0) {\n  .col-@{class}-pull-@{index} {\n    right: percentage((@index / @grid-columns));\n  }\n}\n.calc-grid-column(@index, @class, @type) when (@type = pull) and (@index = 0) {\n  .col-@{class}-pull-0 {\n    right: auto;\n  }\n}\n.calc-grid-column(@index, @class, @type) when (@type = offset) {\n  .col-@{class}-offset-@{index} {\n    margin-left: percentage((@index / @grid-columns));\n  }\n}\n\n// Basic looping in LESS\n.loop-grid-columns(@index, @class, @type) when (@index >= 0) {\n  .calc-grid-column(@index, @class, @type);\n  // next iteration\n  .loop-grid-columns((@index - 1), @class, @type);\n}\n\n// Create grid for specific class\n.make-grid(@class) {\n  .float-grid-columns(@class);\n  .loop-grid-columns(@grid-columns, @class, width);\n  .loop-grid-columns(@grid-columns, @class, pull);\n  .loop-grid-columns(@grid-columns, @class, push);\n  .loop-grid-columns(@grid-columns, @class, offset);\n}\n","// Clearfix\n//\n// For modern browsers\n// 1. The space content is one way to avoid an Opera bug when the\n//    contenteditable attribute is included anywhere else in the document.\n//    Otherwise it causes space to appear at the top and bottom of elements\n//    that are clearfixed.\n// 2. The use of `table` rather than `block` is only necessary if using\n//    `:before` to contain the top-margins of child elements.\n//\n// Source: http://nicolasgallagher.com/micro-clearfix-hack/\n\n.clearfix() {\n  &:before,\n  &:after {\n    content: \" \"; // 1\n    display: table; // 2\n  }\n  &:after {\n    clear: both;\n  }\n}\n","//\n// Utility classes\n// --------------------------------------------------\n\n\n// Floats\n// -------------------------\n\n.clearfix {\n  .clearfix();\n}\n.center-block {\n  .center-block();\n}\n.pull-right {\n  float: right !important;\n}\n.pull-left {\n  float: left !important;\n}\n\n\n// Toggling content\n// -------------------------\n\n// Note: Deprecated .hide in favor of .hidden or .sr-only (as appropriate) in v3.0.1\n.hide {\n  display: none !important;\n}\n.show {\n  display: block !important;\n}\n.invisible {\n  visibility: hidden;\n}\n.text-hide {\n  .text-hide();\n}\n\n\n// Hide from screenreaders and browsers\n//\n// Credit: HTML5 Boilerplate\n\n.hidden {\n  display: none !important;\n  visibility: hidden !important;\n}\n\n\n// For Affix plugin\n// -------------------------\n\n.affix {\n  position: fixed;\n}\n","// Center-align a block level element\n\n.center-block() {\n  display: block;\n  margin-left: auto;\n  margin-right: auto;\n}\n","// CSS image replacement\n//\n// Heads up! v3 launched with with only `.hide-text()`, but per our pattern for\n// mixins being reused as classes with the same name, this doesn't hold up. As\n// of v3.0.1 we have added `.text-hide()` and deprecated `.hide-text()`.\n//\n// Source: https://github.com/h5bp/html5-boilerplate/commit/aa0396eae757\n\n// Deprecated as of v3.0.1 (will be removed in v4)\n.hide-text() {\n  font: ~\"0/0\" a;\n  color: transparent;\n  text-shadow: none;\n  background-color: transparent;\n  border: 0;\n}\n\n// New mixin to use as of v3.0.1\n.text-hide() {\n  .hide-text();\n}\n","/* FONT PATH\r\n * -------------------------- */\r\n\r\n@font-face {\r\n  font-family: 'FontAwesome';\r\n  src: url('@{fa-font-path}/fontawesome-webfont.eot?v=@{fa-version}');\r\n  src: url('@{fa-font-path}/fontawesome-webfont.eot?#iefix&v=@{fa-version}') format('embedded-opentype'),\r\n    url('@{fa-font-path}/fontawesome-webfont.woff2?v=@{fa-version}') format('woff2'),\r\n    url('@{fa-font-path}/fontawesome-webfont.woff?v=@{fa-version}') format('woff'),\r\n    url('@{fa-font-path}/fontawesome-webfont.ttf?v=@{fa-version}') format('truetype'),\r\n    url('@{fa-font-path}/fontawesome-webfont.svg?v=@{fa-version}#fontawesomeregular') format('svg');\r\n//  src: url('@{fa-font-path}/FontAwesome.otf') format('opentype'); // used when developing fonts\r\n  font-weight: normal;\r\n  font-style: normal;\r\n}\r\n","// Base Class Definition\r\n// -------------------------\r\n\r\n.@{fa-css-prefix} {\r\n  display: inline-block;\r\n  font: normal normal normal @fa-font-size-base/1 FontAwesome; // shortening font declaration\r\n  font-size: inherit; // can't have font-size inherit on line above, so need to override\r\n  text-rendering: auto; // optimizelegibility throws things off #1094\r\n  -webkit-font-smoothing: antialiased;\r\n  -moz-osx-font-smoothing: grayscale;\r\n  transform: translate(0, 0); // ensures no half-pixel rendering in firefox\r\n\r\n}\r\n","// Icon Sizes\r\n// -------------------------\r\n\r\n/* makes the font 33% larger relative to the icon container */\r\n.@{fa-css-prefix}-lg {\r\n  font-size: (4em / 3);\r\n  line-height: (3em / 4);\r\n  vertical-align: -15%;\r\n}\r\n.@{fa-css-prefix}-2x { font-size: 2em; }\r\n.@{fa-css-prefix}-3x { font-size: 3em; }\r\n.@{fa-css-prefix}-4x { font-size: 4em; }\r\n.@{fa-css-prefix}-5x { font-size: 5em; }\r\n","// Fixed Width Icons\r\n// -------------------------\r\n.@{fa-css-prefix}-fw {\r\n  width: (18em / 14);\r\n  text-align: center;\r\n}\r\n","// List Icons\r\n// -------------------------\r\n\r\n.@{fa-css-prefix}-ul {\r\n  padding-left: 0;\r\n  margin-left: @fa-li-width;\r\n  list-style-type: none;\r\n  > li { position: relative; }\r\n}\r\n.@{fa-css-prefix}-li {\r\n  position: absolute;\r\n  left: -@fa-li-width;\r\n  width: @fa-li-width;\r\n  top: (2em / 14);\r\n  text-align: center;\r\n  &.@{fa-css-prefix}-lg {\r\n    left: (-@fa-li-width + (4em / 14));\r\n  }\r\n}\r\n","// Bordered & Pulled\r\n// -------------------------\r\n\r\n.@{fa-css-prefix}-border {\r\n  padding: .2em .25em .15em;\r\n  border: solid .08em @fa-border-color;\r\n  border-radius: .1em;\r\n}\r\n\r\n.pull-right { float: right; }\r\n.pull-left { float: left; }\r\n\r\n.@{fa-css-prefix} {\r\n  &.pull-left { margin-right: .3em; }\r\n  &.pull-right { margin-left: .3em; }\r\n}\r\n","// Animated Icons\r\n// --------------------------\r\n\r\n.@{fa-css-prefix}-spin {\r\n  -webkit-animation: fa-spin 2s infinite linear;\r\n          animation: fa-spin 2s infinite linear;\r\n}\r\n\r\n.@{fa-css-prefix}-pulse {\r\n  -webkit-animation: fa-spin 1s infinite steps(8);\r\n          animation: fa-spin 1s infinite steps(8);\r\n}\r\n\r\n@-webkit-keyframes fa-spin {\r\n  0% {\r\n    -webkit-transform: rotate(0deg);\r\n            transform: rotate(0deg);\r\n  }\r\n  100% {\r\n    -webkit-transform: rotate(359deg);\r\n            transform: rotate(359deg);\r\n  }\r\n}\r\n\r\n@keyframes fa-spin {\r\n  0% {\r\n    -webkit-transform: rotate(0deg);\r\n            transform: rotate(0deg);\r\n  }\r\n  100% {\r\n    -webkit-transform: rotate(359deg);\r\n            transform: rotate(359deg);\r\n  }\r\n}\r\n","// Rotated & Flipped Icons\r\n// -------------------------\r\n\r\n.@{fa-css-prefix}-rotate-90  { .fa-icon-rotate(90deg, 1);  }\r\n.@{fa-css-prefix}-rotate-180 { .fa-icon-rotate(180deg, 2); }\r\n.@{fa-css-prefix}-rotate-270 { .fa-icon-rotate(270deg, 3); }\r\n\r\n.@{fa-css-prefix}-flip-horizontal { .fa-icon-flip(-1, 1, 0); }\r\n.@{fa-css-prefix}-flip-vertical   { .fa-icon-flip(1, -1, 2); }\r\n\r\n// Hook for IE8-9\r\n// -------------------------\r\n\r\n:root .@{fa-css-prefix}-rotate-90,\r\n:root .@{fa-css-prefix}-rotate-180,\r\n:root .@{fa-css-prefix}-rotate-270,\r\n:root .@{fa-css-prefix}-flip-horizontal,\r\n:root .@{fa-css-prefix}-flip-vertical {\r\n  filter: none;\r\n}\r\n","// Mixins\r\n// --------------------------\r\n\r\n.fa-icon() {\r\n  display: inline-block;\r\n  font: normal normal normal @fa-font-size-base/1 FontAwesome; // shortening font declaration\r\n  font-size: inherit; // can't have font-size inherit on line above, so need to override\r\n  text-rendering: auto; // optimizelegibility throws things off #1094\r\n  -webkit-font-smoothing: antialiased;\r\n  -moz-osx-font-smoothing: grayscale;\r\n  transform: translate(0, 0); // ensures no half-pixel rendering in firefox\r\n\r\n}\r\n\r\n.fa-icon-rotate(@degrees, @rotation) {\r\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=@rotation);\r\n  -webkit-transform: rotate(@degrees);\r\n      -ms-transform: rotate(@degrees);\r\n          transform: rotate(@degrees);\r\n}\r\n\r\n.fa-icon-flip(@horiz, @vert, @rotation) {\r\n  filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=@rotation, mirror=1);\r\n  -webkit-transform: scale(@horiz, @vert);\r\n      -ms-transform: scale(@horiz, @vert);\r\n          transform: scale(@horiz, @vert);\r\n}\r\n","// Stacked Icons\r\n// -------------------------\r\n\r\n.@{fa-css-prefix}-stack {\r\n  position: relative;\r\n  display: inline-block;\r\n  width: 2em;\r\n  height: 2em;\r\n  line-height: 2em;\r\n  vertical-align: middle;\r\n}\r\n.@{fa-css-prefix}-stack-1x, .@{fa-css-prefix}-stack-2x {\r\n  position: absolute;\r\n  left: 0;\r\n  width: 100%;\r\n  text-align: center;\r\n}\r\n.@{fa-css-prefix}-stack-1x { line-height: inherit; }\r\n.@{fa-css-prefix}-stack-2x { font-size: 2em; }\r\n.@{fa-css-prefix}-inverse { color: @fa-inverse; }\r\n","/* Font Awesome uses the Unicode Private Use Area (PUA) to ensure screen\r\n   readers do not read off random characters that represent icons */\r\n\r\n.@{fa-css-prefix}-glass:before { content: @fa-var-glass; }\r\n.@{fa-css-prefix}-music:before { content: @fa-var-music; }\r\n.@{fa-css-prefix}-search:before { content: @fa-var-search; }\r\n.@{fa-css-prefix}-envelope-o:before { content: @fa-var-envelope-o; }\r\n.@{fa-css-prefix}-heart:before { content: @fa-var-heart; }\r\n.@{fa-css-prefix}-star:before { content: @fa-var-star; }\r\n.@{fa-css-prefix}-star-o:before { content: @fa-var-star-o; }\r\n.@{fa-css-prefix}-user:before { content: @fa-var-user; }\r\n.@{fa-css-prefix}-film:before { content: @fa-var-film; }\r\n.@{fa-css-prefix}-th-large:before { content: @fa-var-th-large; }\r\n.@{fa-css-prefix}-th:before { content: @fa-var-th; }\r\n.@{fa-css-prefix}-th-list:before { content: @fa-var-th-list; }\r\n.@{fa-css-prefix}-check:before { content: @fa-var-check; }\r\n.@{fa-css-prefix}-remove:before,\r\n.@{fa-css-prefix}-close:before,\r\n.@{fa-css-prefix}-times:before { content: @fa-var-times; }\r\n.@{fa-css-prefix}-search-plus:before { content: @fa-var-search-plus; }\r\n.@{fa-css-prefix}-search-minus:before { content: @fa-var-search-minus; }\r\n.@{fa-css-prefix}-power-off:before { content: @fa-var-power-off; }\r\n.@{fa-css-prefix}-signal:before { content: @fa-var-signal; }\r\n.@{fa-css-prefix}-gear:before,\r\n.@{fa-css-prefix}-cog:before { content: @fa-var-cog; }\r\n.@{fa-css-prefix}-trash-o:before { content: @fa-var-trash-o; }\r\n.@{fa-css-prefix}-home:before { content: @fa-var-home; }\r\n.@{fa-css-prefix}-file-o:before { content: @fa-var-file-o; }\r\n.@{fa-css-prefix}-clock-o:before { content: @fa-var-clock-o; }\r\n.@{fa-css-prefix}-road:before { content: @fa-var-road; }\r\n.@{fa-css-prefix}-download:before { content: @fa-var-download; }\r\n.@{fa-css-prefix}-arrow-circle-o-down:before { content: @fa-var-arrow-circle-o-down; }\r\n.@{fa-css-prefix}-arrow-circle-o-up:before { content: @fa-var-arrow-circle-o-up; }\r\n.@{fa-css-prefix}-inbox:before { content: @fa-var-inbox; }\r\n.@{fa-css-prefix}-play-circle-o:before { content: @fa-var-play-circle-o; }\r\n.@{fa-css-prefix}-rotate-right:before,\r\n.@{fa-css-prefix}-repeat:before { content: @fa-var-repeat; }\r\n.@{fa-css-prefix}-refresh:before { content: @fa-var-refresh; }\r\n.@{fa-css-prefix}-list-alt:before { content: @fa-var-list-alt; }\r\n.@{fa-css-prefix}-lock:before { content: @fa-var-lock; }\r\n.@{fa-css-prefix}-flag:before { content: @fa-var-flag; }\r\n.@{fa-css-prefix}-headphones:before { content: @fa-var-headphones; }\r\n.@{fa-css-prefix}-volume-off:before { content: @fa-var-volume-off; }\r\n.@{fa-css-prefix}-volume-down:before { content: @fa-var-volume-down; }\r\n.@{fa-css-prefix}-volume-up:before { content: @fa-var-volume-up; }\r\n.@{fa-css-prefix}-qrcode:before { content: @fa-var-qrcode; }\r\n.@{fa-css-prefix}-barcode:before { content: @fa-var-barcode; }\r\n.@{fa-css-prefix}-tag:before { content: @fa-var-tag; }\r\n.@{fa-css-prefix}-tags:before { content: @fa-var-tags; }\r\n.@{fa-css-prefix}-book:before { content: @fa-var-book; }\r\n.@{fa-css-prefix}-bookmark:before { content: @fa-var-bookmark; }\r\n.@{fa-css-prefix}-print:before { content: @fa-var-print; }\r\n.@{fa-css-prefix}-camera:before { content: @fa-var-camera; }\r\n.@{fa-css-prefix}-font:before { content: @fa-var-font; }\r\n.@{fa-css-prefix}-bold:before { content: @fa-var-bold; }\r\n.@{fa-css-prefix}-italic:before { content: @fa-var-italic; }\r\n.@{fa-css-prefix}-text-height:before { content: @fa-var-text-height; }\r\n.@{fa-css-prefix}-text-width:before { content: @fa-var-text-width; }\r\n.@{fa-css-prefix}-align-left:before { content: @fa-var-align-left; }\r\n.@{fa-css-prefix}-align-center:before { content: @fa-var-align-center; }\r\n.@{fa-css-prefix}-align-right:before { content: @fa-var-align-right; }\r\n.@{fa-css-prefix}-align-justify:before { content: @fa-var-align-justify; }\r\n.@{fa-css-prefix}-list:before { content: @fa-var-list; }\r\n.@{fa-css-prefix}-dedent:before,\r\n.@{fa-css-prefix}-outdent:before { content: @fa-var-outdent; }\r\n.@{fa-css-prefix}-indent:before { content: @fa-var-indent; }\r\n.@{fa-css-prefix}-video-camera:before { content: @fa-var-video-camera; }\r\n.@{fa-css-prefix}-photo:before,\r\n.@{fa-css-prefix}-image:before,\r\n.@{fa-css-prefix}-picture-o:before { content: @fa-var-picture-o; }\r\n.@{fa-css-prefix}-pencil:before { content: @fa-var-pencil; }\r\n.@{fa-css-prefix}-map-marker:before { content: @fa-var-map-marker; }\r\n.@{fa-css-prefix}-adjust:before { content: @fa-var-adjust; }\r\n.@{fa-css-prefix}-tint:before { content: @fa-var-tint; }\r\n.@{fa-css-prefix}-edit:before,\r\n.@{fa-css-prefix}-pencil-square-o:before { content: @fa-var-pencil-square-o; }\r\n.@{fa-css-prefix}-share-square-o:before { content: @fa-var-share-square-o; }\r\n.@{fa-css-prefix}-check-square-o:before { content: @fa-var-check-square-o; }\r\n.@{fa-css-prefix}-arrows:before { content: @fa-var-arrows; }\r\n.@{fa-css-prefix}-step-backward:before { content: @fa-var-step-backward; }\r\n.@{fa-css-prefix}-fast-backward:before { content: @fa-var-fast-backward; }\r\n.@{fa-css-prefix}-backward:before { content: @fa-var-backward; }\r\n.@{fa-css-prefix}-play:before { content: @fa-var-play; }\r\n.@{fa-css-prefix}-pause:before { content: @fa-var-pause; }\r\n.@{fa-css-prefix}-stop:before { content: @fa-var-stop; }\r\n.@{fa-css-prefix}-forward:before { content: @fa-var-forward; }\r\n.@{fa-css-prefix}-fast-forward:before { content: @fa-var-fast-forward; }\r\n.@{fa-css-prefix}-step-forward:before { content: @fa-var-step-forward; }\r\n.@{fa-css-prefix}-eject:before { content: @fa-var-eject; }\r\n.@{fa-css-prefix}-chevron-left:before { content: @fa-var-chevron-left; }\r\n.@{fa-css-prefix}-chevron-right:before { content: @fa-var-chevron-right; }\r\n.@{fa-css-prefix}-plus-circle:before { content: @fa-var-plus-circle; }\r\n.@{fa-css-prefix}-minus-circle:before { content: @fa-var-minus-circle; }\r\n.@{fa-css-prefix}-times-circle:before { content: @fa-var-times-circle; }\r\n.@{fa-css-prefix}-check-circle:before { content: @fa-var-check-circle; }\r\n.@{fa-css-prefix}-question-circle:before { content: @fa-var-question-circle; }\r\n.@{fa-css-prefix}-info-circle:before { content: @fa-var-info-circle; }\r\n.@{fa-css-prefix}-crosshairs:before { content: @fa-var-crosshairs; }\r\n.@{fa-css-prefix}-times-circle-o:before { content: @fa-var-times-circle-o; }\r\n.@{fa-css-prefix}-check-circle-o:before { content: @fa-var-check-circle-o; }\r\n.@{fa-css-prefix}-ban:before { content: @fa-var-ban; }\r\n.@{fa-css-prefix}-arrow-left:before { content: @fa-var-arrow-left; }\r\n.@{fa-css-prefix}-arrow-right:before { content: @fa-var-arrow-right; }\r\n.@{fa-css-prefix}-arrow-up:before { content: @fa-var-arrow-up; }\r\n.@{fa-css-prefix}-arrow-down:before { content: @fa-var-arrow-down; }\r\n.@{fa-css-prefix}-mail-forward:before,\r\n.@{fa-css-prefix}-share:before { content: @fa-var-share; }\r\n.@{fa-css-prefix}-expand:before { content: @fa-var-expand; }\r\n.@{fa-css-prefix}-compress:before { content: @fa-var-compress; }\r\n.@{fa-css-prefix}-plus:before { content: @fa-var-plus; }\r\n.@{fa-css-prefix}-minus:before { content: @fa-var-minus; }\r\n.@{fa-css-prefix}-asterisk:before { content: @fa-var-asterisk; }\r\n.@{fa-css-prefix}-exclamation-circle:before { content: @fa-var-exclamation-circle; }\r\n.@{fa-css-prefix}-gift:before { content: @fa-var-gift; }\r\n.@{fa-css-prefix}-leaf:before { content: @fa-var-leaf; }\r\n.@{fa-css-prefix}-fire:before { content: @fa-var-fire; }\r\n.@{fa-css-prefix}-eye:before { content: @fa-var-eye; }\r\n.@{fa-css-prefix}-eye-slash:before { content: @fa-var-eye-slash; }\r\n.@{fa-css-prefix}-warning:before,\r\n.@{fa-css-prefix}-exclamation-triangle:before { content: @fa-var-exclamation-triangle; }\r\n.@{fa-css-prefix}-plane:before { content: @fa-var-plane; }\r\n.@{fa-css-prefix}-calendar:before { content: @fa-var-calendar; }\r\n.@{fa-css-prefix}-random:before { content: @fa-var-random; }\r\n.@{fa-css-prefix}-comment:before { content: @fa-var-comment; }\r\n.@{fa-css-prefix}-magnet:before { content: @fa-var-magnet; }\r\n.@{fa-css-prefix}-chevron-up:before { content: @fa-var-chevron-up; }\r\n.@{fa-css-prefix}-chevron-down:before { content: @fa-var-chevron-down; }\r\n.@{fa-css-prefix}-retweet:before { content: @fa-var-retweet; }\r\n.@{fa-css-prefix}-shopping-cart:before { content: @fa-var-shopping-cart; }\r\n.@{fa-css-prefix}-folder:before { content: @fa-var-folder; }\r\n.@{fa-css-prefix}-folder-open:before { content: @fa-var-folder-open; }\r\n.@{fa-css-prefix}-arrows-v:before { content: @fa-var-arrows-v; }\r\n.@{fa-css-prefix}-arrows-h:before { content: @fa-var-arrows-h; }\r\n.@{fa-css-prefix}-bar-chart-o:before,\r\n.@{fa-css-prefix}-bar-chart:before { content: @fa-var-bar-chart; }\r\n.@{fa-css-prefix}-twitter-square:before { content: @fa-var-twitter-square; }\r\n.@{fa-css-prefix}-facebook-square:before { content: @fa-var-facebook-square; }\r\n.@{fa-css-prefix}-camera-retro:before { content: @fa-var-camera-retro; }\r\n.@{fa-css-prefix}-key:before { content: @fa-var-key; }\r\n.@{fa-css-prefix}-gears:before,\r\n.@{fa-css-prefix}-cogs:before { content: @fa-var-cogs; }\r\n.@{fa-css-prefix}-comments:before { content: @fa-var-comments; }\r\n.@{fa-css-prefix}-thumbs-o-up:before { content: @fa-var-thumbs-o-up; }\r\n.@{fa-css-prefix}-thumbs-o-down:before { content: @fa-var-thumbs-o-down; }\r\n.@{fa-css-prefix}-star-half:before { content: @fa-var-star-half; }\r\n.@{fa-css-prefix}-heart-o:before { content: @fa-var-heart-o; }\r\n.@{fa-css-prefix}-sign-out:before { content: @fa-var-sign-out; }\r\n.@{fa-css-prefix}-linkedin-square:before { content: @fa-var-linkedin-square; }\r\n.@{fa-css-prefix}-thumb-tack:before { content: @fa-var-thumb-tack; }\r\n.@{fa-css-prefix}-external-link:before { content: @fa-var-external-link; }\r\n.@{fa-css-prefix}-sign-in:before { content: @fa-var-sign-in; }\r\n.@{fa-css-prefix}-trophy:before { content: @fa-var-trophy; }\r\n.@{fa-css-prefix}-github-square:before { content: @fa-var-github-square; }\r\n.@{fa-css-prefix}-upload:before { content: @fa-var-upload; }\r\n.@{fa-css-prefix}-lemon-o:before { content: @fa-var-lemon-o; }\r\n.@{fa-css-prefix}-phone:before { content: @fa-var-phone; }\r\n.@{fa-css-prefix}-square-o:before { content: @fa-var-square-o; }\r\n.@{fa-css-prefix}-bookmark-o:before { content: @fa-var-bookmark-o; }\r\n.@{fa-css-prefix}-phone-square:before { content: @fa-var-phone-square; }\r\n.@{fa-css-prefix}-twitter:before { content: @fa-var-twitter; }\r\n.@{fa-css-prefix}-facebook-f:before,\r\n.@{fa-css-prefix}-facebook:before { content: @fa-var-facebook; }\r\n.@{fa-css-prefix}-github:before { content: @fa-var-github; }\r\n.@{fa-css-prefix}-unlock:before { content: @fa-var-unlock; }\r\n.@{fa-css-prefix}-credit-card:before { content: @fa-var-credit-card; }\r\n.@{fa-css-prefix}-rss:before { content: @fa-var-rss; }\r\n.@{fa-css-prefix}-hdd-o:before { content: @fa-var-hdd-o; }\r\n.@{fa-css-prefix}-bullhorn:before { content: @fa-var-bullhorn; }\r\n.@{fa-css-prefix}-bell:before { content: @fa-var-bell; }\r\n.@{fa-css-prefix}-certificate:before { content: @fa-var-certificate; }\r\n.@{fa-css-prefix}-hand-o-right:before { content: @fa-var-hand-o-right; }\r\n.@{fa-css-prefix}-hand-o-left:before { content: @fa-var-hand-o-left; }\r\n.@{fa-css-prefix}-hand-o-up:before { content: @fa-var-hand-o-up; }\r\n.@{fa-css-prefix}-hand-o-down:before { content: @fa-var-hand-o-down; }\r\n.@{fa-css-prefix}-arrow-circle-left:before { content: @fa-var-arrow-circle-left; }\r\n.@{fa-css-prefix}-arrow-circle-right:before { content: @fa-var-arrow-circle-right; }\r\n.@{fa-css-prefix}-arrow-circle-up:before { content: @fa-var-arrow-circle-up; }\r\n.@{fa-css-prefix}-arrow-circle-down:before { content: @fa-var-arrow-circle-down; }\r\n.@{fa-css-prefix}-globe:before { content: @fa-var-globe; }\r\n.@{fa-css-prefix}-wrench:before { content: @fa-var-wrench; }\r\n.@{fa-css-prefix}-tasks:before { content: @fa-var-tasks; }\r\n.@{fa-css-prefix}-filter:before { content: @fa-var-filter; }\r\n.@{fa-css-prefix}-briefcase:before { content: @fa-var-briefcase; }\r\n.@{fa-css-prefix}-arrows-alt:before { content: @fa-var-arrows-alt; }\r\n.@{fa-css-prefix}-group:before,\r\n.@{fa-css-prefix}-users:before { content: @fa-var-users; }\r\n.@{fa-css-prefix}-chain:before,\r\n.@{fa-css-prefix}-link:before { content: @fa-var-link; }\r\n.@{fa-css-prefix}-cloud:before { content: @fa-var-cloud; }\r\n.@{fa-css-prefix}-flask:before { content: @fa-var-flask; }\r\n.@{fa-css-prefix}-cut:before,\r\n.@{fa-css-prefix}-scissors:before { content: @fa-var-scissors; }\r\n.@{fa-css-prefix}-copy:before,\r\n.@{fa-css-prefix}-files-o:before { content: @fa-var-files-o; }\r\n.@{fa-css-prefix}-paperclip:before { content: @fa-var-paperclip; }\r\n.@{fa-css-prefix}-save:before,\r\n.@{fa-css-prefix}-floppy-o:before { content: @fa-var-floppy-o; }\r\n.@{fa-css-prefix}-square:before { content: @fa-var-square; }\r\n.@{fa-css-prefix}-navicon:before,\r\n.@{fa-css-prefix}-reorder:before,\r\n.@{fa-css-prefix}-bars:before { content: @fa-var-bars; }\r\n.@{fa-css-prefix}-list-ul:before { content: @fa-var-list-ul; }\r\n.@{fa-css-prefix}-list-ol:before { content: @fa-var-list-ol; }\r\n.@{fa-css-prefix}-strikethrough:before { content: @fa-var-strikethrough; }\r\n.@{fa-css-prefix}-underline:before { content: @fa-var-underline; }\r\n.@{fa-css-prefix}-table:before { content: @fa-var-table; }\r\n.@{fa-css-prefix}-magic:before { content: @fa-var-magic; }\r\n.@{fa-css-prefix}-truck:before { content: @fa-var-truck; }\r\n.@{fa-css-prefix}-pinterest:before { content: @fa-var-pinterest; }\r\n.@{fa-css-prefix}-pinterest-square:before { content: @fa-var-pinterest-square; }\r\n.@{fa-css-prefix}-google-plus-square:before { content: @fa-var-google-plus-square; }\r\n.@{fa-css-prefix}-google-plus:before { content: @fa-var-google-plus; }\r\n.@{fa-css-prefix}-money:before { content: @fa-var-money; }\r\n.@{fa-css-prefix}-caret-down:before { content: @fa-var-caret-down; }\r\n.@{fa-css-prefix}-caret-up:before { content: @fa-var-caret-up; }\r\n.@{fa-css-prefix}-caret-left:before { content: @fa-var-caret-left; }\r\n.@{fa-css-prefix}-caret-right:before { content: @fa-var-caret-right; }\r\n.@{fa-css-prefix}-columns:before { content: @fa-var-columns; }\r\n.@{fa-css-prefix}-unsorted:before,\r\n.@{fa-css-prefix}-sort:before { content: @fa-var-sort; }\r\n.@{fa-css-prefix}-sort-down:before,\r\n.@{fa-css-prefix}-sort-desc:before { content: @fa-var-sort-desc; }\r\n.@{fa-css-prefix}-sort-up:before,\r\n.@{fa-css-prefix}-sort-asc:before { content: @fa-var-sort-asc; }\r\n.@{fa-css-prefix}-envelope:before { content: @fa-var-envelope; }\r\n.@{fa-css-prefix}-linkedin:before { content: @fa-var-linkedin; }\r\n.@{fa-css-prefix}-rotate-left:before,\r\n.@{fa-css-prefix}-undo:before { content: @fa-var-undo; }\r\n.@{fa-css-prefix}-legal:before,\r\n.@{fa-css-prefix}-gavel:before { content: @fa-var-gavel; }\r\n.@{fa-css-prefix}-dashboard:before,\r\n.@{fa-css-prefix}-tachometer:before { content: @fa-var-tachometer; }\r\n.@{fa-css-prefix}-comment-o:before { content: @fa-var-comment-o; }\r\n.@{fa-css-prefix}-comments-o:before { content: @fa-var-comments-o; }\r\n.@{fa-css-prefix}-flash:before,\r\n.@{fa-css-prefix}-bolt:before { content: @fa-var-bolt; }\r\n.@{fa-css-prefix}-sitemap:before { content: @fa-var-sitemap; }\r\n.@{fa-css-prefix}-umbrella:before { content: @fa-var-umbrella; }\r\n.@{fa-css-prefix}-paste:before,\r\n.@{fa-css-prefix}-clipboard:before { content: @fa-var-clipboard; }\r\n.@{fa-css-prefix}-lightbulb-o:before { content: @fa-var-lightbulb-o; }\r\n.@{fa-css-prefix}-exchange:before { content: @fa-var-exchange; }\r\n.@{fa-css-prefix}-cloud-download:before { content: @fa-var-cloud-download; }\r\n.@{fa-css-prefix}-cloud-upload:before { content: @fa-var-cloud-upload; }\r\n.@{fa-css-prefix}-user-md:before { content: @fa-var-user-md; }\r\n.@{fa-css-prefix}-stethoscope:before { content: @fa-var-stethoscope; }\r\n.@{fa-css-prefix}-suitcase:before { content: @fa-var-suitcase; }\r\n.@{fa-css-prefix}-bell-o:before { content: @fa-var-bell-o; }\r\n.@{fa-css-prefix}-coffee:before { content: @fa-var-coffee; }\r\n.@{fa-css-prefix}-cutlery:before { content: @fa-var-cutlery; }\r\n.@{fa-css-prefix}-file-text-o:before { content: @fa-var-file-text-o; }\r\n.@{fa-css-prefix}-building-o:before { content: @fa-var-building-o; }\r\n.@{fa-css-prefix}-hospital-o:before { content: @fa-var-hospital-o; }\r\n.@{fa-css-prefix}-ambulance:before { content: @fa-var-ambulance; }\r\n.@{fa-css-prefix}-medkit:before { content: @fa-var-medkit; }\r\n.@{fa-css-prefix}-fighter-jet:before { content: @fa-var-fighter-jet; }\r\n.@{fa-css-prefix}-beer:before { content: @fa-var-beer; }\r\n.@{fa-css-prefix}-h-square:before { content: @fa-var-h-square; }\r\n.@{fa-css-prefix}-plus-square:before { content: @fa-var-plus-square; }\r\n.@{fa-css-prefix}-angle-double-left:before { content: @fa-var-angle-double-left; }\r\n.@{fa-css-prefix}-angle-double-right:before { content: @fa-var-angle-double-right; }\r\n.@{fa-css-prefix}-angle-double-up:before { content: @fa-var-angle-double-up; }\r\n.@{fa-css-prefix}-angle-double-down:before { content: @fa-var-angle-double-down; }\r\n.@{fa-css-prefix}-angle-left:before { content: @fa-var-angle-left; }\r\n.@{fa-css-prefix}-angle-right:before { content: @fa-var-angle-right; }\r\n.@{fa-css-prefix}-angle-up:before { content: @fa-var-angle-up; }\r\n.@{fa-css-prefix}-angle-down:before { content: @fa-var-angle-down; }\r\n.@{fa-css-prefix}-desktop:before { content: @fa-var-desktop; }\r\n.@{fa-css-prefix}-laptop:before { content: @fa-var-laptop; }\r\n.@{fa-css-prefix}-tablet:before { content: @fa-var-tablet; }\r\n.@{fa-css-prefix}-mobile-phone:before,\r\n.@{fa-css-prefix}-mobile:before { content: @fa-var-mobile; }\r\n.@{fa-css-prefix}-circle-o:before { content: @fa-var-circle-o; }\r\n.@{fa-css-prefix}-quote-left:before { content: @fa-var-quote-left; }\r\n.@{fa-css-prefix}-quote-right:before { content: @fa-var-quote-right; }\r\n.@{fa-css-prefix}-spinner:before { content: @fa-var-spinner; }\r\n.@{fa-css-prefix}-circle:before { content: @fa-var-circle; }\r\n.@{fa-css-prefix}-mail-reply:before,\r\n.@{fa-css-prefix}-reply:before { content: @fa-var-reply; }\r\n.@{fa-css-prefix}-github-alt:before { content: @fa-var-github-alt; }\r\n.@{fa-css-prefix}-folder-o:before { content: @fa-var-folder-o; }\r\n.@{fa-css-prefix}-folder-open-o:before { content: @fa-var-folder-open-o; }\r\n.@{fa-css-prefix}-smile-o:before { content: @fa-var-smile-o; }\r\n.@{fa-css-prefix}-frown-o:before { content: @fa-var-frown-o; }\r\n.@{fa-css-prefix}-meh-o:before { content: @fa-var-meh-o; }\r\n.@{fa-css-prefix}-gamepad:before { content: @fa-var-gamepad; }\r\n.@{fa-css-prefix}-keyboard-o:before { content: @fa-var-keyboard-o; }\r\n.@{fa-css-prefix}-flag-o:before { content: @fa-var-flag-o; }\r\n.@{fa-css-prefix}-flag-checkered:before { content: @fa-var-flag-checkered; }\r\n.@{fa-css-prefix}-terminal:before { content: @fa-var-terminal; }\r\n.@{fa-css-prefix}-code:before { content: @fa-var-code; }\r\n.@{fa-css-prefix}-mail-reply-all:before,\r\n.@{fa-css-prefix}-reply-all:before { content: @fa-var-reply-all; }\r\n.@{fa-css-prefix}-star-half-empty:before,\r\n.@{fa-css-prefix}-star-half-full:before,\r\n.@{fa-css-prefix}-star-half-o:before { content: @fa-var-star-half-o; }\r\n.@{fa-css-prefix}-location-arrow:before { content: @fa-var-location-arrow; }\r\n.@{fa-css-prefix}-crop:before { content: @fa-var-crop; }\r\n.@{fa-css-prefix}-code-fork:before { content: @fa-var-code-fork; }\r\n.@{fa-css-prefix}-unlink:before,\r\n.@{fa-css-prefix}-chain-broken:before { content: @fa-var-chain-broken; }\r\n.@{fa-css-prefix}-question:before { content: @fa-var-question; }\r\n.@{fa-css-prefix}-info:before { content: @fa-var-info; }\r\n.@{fa-css-prefix}-exclamation:before { content: @fa-var-exclamation; }\r\n.@{fa-css-prefix}-superscript:before { content: @fa-var-superscript; }\r\n.@{fa-css-prefix}-subscript:before { content: @fa-var-subscript; }\r\n.@{fa-css-prefix}-eraser:before { content: @fa-var-eraser; }\r\n.@{fa-css-prefix}-puzzle-piece:before { content: @fa-var-puzzle-piece; }\r\n.@{fa-css-prefix}-microphone:before { content: @fa-var-microphone; }\r\n.@{fa-css-prefix}-microphone-slash:before { content: @fa-var-microphone-slash; }\r\n.@{fa-css-prefix}-shield:before { content: @fa-var-shield; }\r\n.@{fa-css-prefix}-calendar-o:before { content: @fa-var-calendar-o; }\r\n.@{fa-css-prefix}-fire-extinguisher:before { content: @fa-var-fire-extinguisher; }\r\n.@{fa-css-prefix}-rocket:before { content: @fa-var-rocket; }\r\n.@{fa-css-prefix}-maxcdn:before { content: @fa-var-maxcdn; }\r\n.@{fa-css-prefix}-chevron-circle-left:before { content: @fa-var-chevron-circle-left; }\r\n.@{fa-css-prefix}-chevron-circle-right:before { content: @fa-var-chevron-circle-right; }\r\n.@{fa-css-prefix}-chevron-circle-up:before { content: @fa-var-chevron-circle-up; }\r\n.@{fa-css-prefix}-chevron-circle-down:before { content: @fa-var-chevron-circle-down; }\r\n.@{fa-css-prefix}-html5:before { content: @fa-var-html5; }\r\n.@{fa-css-prefix}-css3:before { content: @fa-var-css3; }\r\n.@{fa-css-prefix}-anchor:before { content: @fa-var-anchor; }\r\n.@{fa-css-prefix}-unlock-alt:before { content: @fa-var-unlock-alt; }\r\n.@{fa-css-prefix}-bullseye:before { content: @fa-var-bullseye; }\r\n.@{fa-css-prefix}-ellipsis-h:before { content: @fa-var-ellipsis-h; }\r\n.@{fa-css-prefix}-ellipsis-v:before { content: @fa-var-ellipsis-v; }\r\n.@{fa-css-prefix}-rss-square:before { content: @fa-var-rss-square; }\r\n.@{fa-css-prefix}-play-circle:before { content: @fa-var-play-circle; }\r\n.@{fa-css-prefix}-ticket:before { content: @fa-var-ticket; }\r\n.@{fa-css-prefix}-minus-square:before { content: @fa-var-minus-square; }\r\n.@{fa-css-prefix}-minus-square-o:before { content: @fa-var-minus-square-o; }\r\n.@{fa-css-prefix}-level-up:before { content: @fa-var-level-up; }\r\n.@{fa-css-prefix}-level-down:before { content: @fa-var-level-down; }\r\n.@{fa-css-prefix}-check-square:before { content: @fa-var-check-square; }\r\n.@{fa-css-prefix}-pencil-square:before { content: @fa-var-pencil-square; }\r\n.@{fa-css-prefix}-external-link-square:before { content: @fa-var-external-link-square; }\r\n.@{fa-css-prefix}-share-square:before { content: @fa-var-share-square; }\r\n.@{fa-css-prefix}-compass:before { content: @fa-var-compass; }\r\n.@{fa-css-prefix}-toggle-down:before,\r\n.@{fa-css-prefix}-caret-square-o-down:before { content: @fa-var-caret-square-o-down; }\r\n.@{fa-css-prefix}-toggle-up:before,\r\n.@{fa-css-prefix}-caret-square-o-up:before { content: @fa-var-caret-square-o-up; }\r\n.@{fa-css-prefix}-toggle-right:before,\r\n.@{fa-css-prefix}-caret-square-o-right:before { content: @fa-var-caret-square-o-right; }\r\n.@{fa-css-prefix}-euro:before,\r\n.@{fa-css-prefix}-eur:before { content: @fa-var-eur; }\r\n.@{fa-css-prefix}-gbp:before { content: @fa-var-gbp; }\r\n.@{fa-css-prefix}-dollar:before,\r\n.@{fa-css-prefix}-usd:before { content: @fa-var-usd; }\r\n.@{fa-css-prefix}-rupee:before,\r\n.@{fa-css-prefix}-inr:before { content: @fa-var-inr; }\r\n.@{fa-css-prefix}-cny:before,\r\n.@{fa-css-prefix}-rmb:before,\r\n.@{fa-css-prefix}-yen:before,\r\n.@{fa-css-prefix}-jpy:before { content: @fa-var-jpy; }\r\n.@{fa-css-prefix}-ruble:before,\r\n.@{fa-css-prefix}-rouble:before,\r\n.@{fa-css-prefix}-rub:before { content: @fa-var-rub; }\r\n.@{fa-css-prefix}-won:before,\r\n.@{fa-css-prefix}-krw:before { content: @fa-var-krw; }\r\n.@{fa-css-prefix}-bitcoin:before,\r\n.@{fa-css-prefix}-btc:before { content: @fa-var-btc; }\r\n.@{fa-css-prefix}-file:before { content: @fa-var-file; }\r\n.@{fa-css-prefix}-file-text:before { content: @fa-var-file-text; }\r\n.@{fa-css-prefix}-sort-alpha-asc:before { content: @fa-var-sort-alpha-asc; }\r\n.@{fa-css-prefix}-sort-alpha-desc:before { content: @fa-var-sort-alpha-desc; }\r\n.@{fa-css-prefix}-sort-amount-asc:before { content: @fa-var-sort-amount-asc; }\r\n.@{fa-css-prefix}-sort-amount-desc:before { content: @fa-var-sort-amount-desc; }\r\n.@{fa-css-prefix}-sort-numeric-asc:before { content: @fa-var-sort-numeric-asc; }\r\n.@{fa-css-prefix}-sort-numeric-desc:before { content: @fa-var-sort-numeric-desc; }\r\n.@{fa-css-prefix}-thumbs-up:before { content: @fa-var-thumbs-up; }\r\n.@{fa-css-prefix}-thumbs-down:before { content: @fa-var-thumbs-down; }\r\n.@{fa-css-prefix}-youtube-square:before { content: @fa-var-youtube-square; }\r\n.@{fa-css-prefix}-youtube:before { content: @fa-var-youtube; }\r\n.@{fa-css-prefix}-xing:before { content: @fa-var-xing; }\r\n.@{fa-css-prefix}-xing-square:before { content: @fa-var-xing-square; }\r\n.@{fa-css-prefix}-youtube-play:before { content: @fa-var-youtube-play; }\r\n.@{fa-css-prefix}-dropbox:before { content: @fa-var-dropbox; }\r\n.@{fa-css-prefix}-stack-overflow:before { content: @fa-var-stack-overflow; }\r\n.@{fa-css-prefix}-instagram:before { content: @fa-var-instagram; }\r\n.@{fa-css-prefix}-flickr:before { content: @fa-var-flickr; }\r\n.@{fa-css-prefix}-adn:before { content: @fa-var-adn; }\r\n.@{fa-css-prefix}-bitbucket:before { content: @fa-var-bitbucket; }\r\n.@{fa-css-prefix}-bitbucket-square:before { content: @fa-var-bitbucket-square; }\r\n.@{fa-css-prefix}-tumblr:before { content: @fa-var-tumblr; }\r\n.@{fa-css-prefix}-tumblr-square:before { content: @fa-var-tumblr-square; }\r\n.@{fa-css-prefix}-long-arrow-down:before { content: @fa-var-long-arrow-down; }\r\n.@{fa-css-prefix}-long-arrow-up:before { content: @fa-var-long-arrow-up; }\r\n.@{fa-css-prefix}-long-arrow-left:before { content: @fa-var-long-arrow-left; }\r\n.@{fa-css-prefix}-long-arrow-right:before { content: @fa-var-long-arrow-right; }\r\n.@{fa-css-prefix}-apple:before { content: @fa-var-apple; }\r\n.@{fa-css-prefix}-windows:before { content: @fa-var-windows; }\r\n.@{fa-css-prefix}-android:before { content: @fa-var-android; }\r\n.@{fa-css-prefix}-linux:before { content: @fa-var-linux; }\r\n.@{fa-css-prefix}-dribbble:before { content: @fa-var-dribbble; }\r\n.@{fa-css-prefix}-skype:before { content: @fa-var-skype; }\r\n.@{fa-css-prefix}-foursquare:before { content: @fa-var-foursquare; }\r\n.@{fa-css-prefix}-trello:before { content: @fa-var-trello; }\r\n.@{fa-css-prefix}-female:before { content: @fa-var-female; }\r\n.@{fa-css-prefix}-male:before { content: @fa-var-male; }\r\n.@{fa-css-prefix}-gittip:before,\r\n.@{fa-css-prefix}-gratipay:before { content: @fa-var-gratipay; }\r\n.@{fa-css-prefix}-sun-o:before { content: @fa-var-sun-o; }\r\n.@{fa-css-prefix}-moon-o:before { content: @fa-var-moon-o; }\r\n.@{fa-css-prefix}-archive:before { content: @fa-var-archive; }\r\n.@{fa-css-prefix}-bug:before { content: @fa-var-bug; }\r\n.@{fa-css-prefix}-vk:before { content: @fa-var-vk; }\r\n.@{fa-css-prefix}-weibo:before { content: @fa-var-weibo; }\r\n.@{fa-css-prefix}-renren:before { content: @fa-var-renren; }\r\n.@{fa-css-prefix}-pagelines:before { content: @fa-var-pagelines; }\r\n.@{fa-css-prefix}-stack-exchange:before { content: @fa-var-stack-exchange; }\r\n.@{fa-css-prefix}-arrow-circle-o-right:before { content: @fa-var-arrow-circle-o-right; }\r\n.@{fa-css-prefix}-arrow-circle-o-left:before { content: @fa-var-arrow-circle-o-left; }\r\n.@{fa-css-prefix}-toggle-left:before,\r\n.@{fa-css-prefix}-caret-square-o-left:before { content: @fa-var-caret-square-o-left; }\r\n.@{fa-css-prefix}-dot-circle-o:before { content: @fa-var-dot-circle-o; }\r\n.@{fa-css-prefix}-wheelchair:before { content: @fa-var-wheelchair; }\r\n.@{fa-css-prefix}-vimeo-square:before { content: @fa-var-vimeo-square; }\r\n.@{fa-css-prefix}-turkish-lira:before,\r\n.@{fa-css-prefix}-try:before { content: @fa-var-try; }\r\n.@{fa-css-prefix}-plus-square-o:before { content: @fa-var-plus-square-o; }\r\n.@{fa-css-prefix}-space-shuttle:before { content: @fa-var-space-shuttle; }\r\n.@{fa-css-prefix}-slack:before { content: @fa-var-slack; }\r\n.@{fa-css-prefix}-envelope-square:before { content: @fa-var-envelope-square; }\r\n.@{fa-css-prefix}-wordpress:before { content: @fa-var-wordpress; }\r\n.@{fa-css-prefix}-openid:before { content: @fa-var-openid; }\r\n.@{fa-css-prefix}-institution:before,\r\n.@{fa-css-prefix}-bank:before,\r\n.@{fa-css-prefix}-university:before { content: @fa-var-university; }\r\n.@{fa-css-prefix}-mortar-board:before,\r\n.@{fa-css-prefix}-graduation-cap:before { content: @fa-var-graduation-cap; }\r\n.@{fa-css-prefix}-yahoo:before { content: @fa-var-yahoo; }\r\n.@{fa-css-prefix}-google:before { content: @fa-var-google; }\r\n.@{fa-css-prefix}-reddit:before { content: @fa-var-reddit; }\r\n.@{fa-css-prefix}-reddit-square:before { content: @fa-var-reddit-square; }\r\n.@{fa-css-prefix}-stumbleupon-circle:before { content: @fa-var-stumbleupon-circle; }\r\n.@{fa-css-prefix}-stumbleupon:before { content: @fa-var-stumbleupon; }\r\n.@{fa-css-prefix}-delicious:before { content: @fa-var-delicious; }\r\n.@{fa-css-prefix}-digg:before { content: @fa-var-digg; }\r\n.@{fa-css-prefix}-pied-piper:before { content: @fa-var-pied-piper; }\r\n.@{fa-css-prefix}-pied-piper-alt:before { content: @fa-var-pied-piper-alt; }\r\n.@{fa-css-prefix}-drupal:before { content: @fa-var-drupal; }\r\n.@{fa-css-prefix}-joomla:before { content: @fa-var-joomla; }\r\n.@{fa-css-prefix}-language:before { content: @fa-var-language; }\r\n.@{fa-css-prefix}-fax:before { content: @fa-var-fax; }\r\n.@{fa-css-prefix}-building:before { content: @fa-var-building; }\r\n.@{fa-css-prefix}-child:before { content: @fa-var-child; }\r\n.@{fa-css-prefix}-paw:before { content: @fa-var-paw; }\r\n.@{fa-css-prefix}-spoon:before { content: @fa-var-spoon; }\r\n.@{fa-css-prefix}-cube:before { content: @fa-var-cube; }\r\n.@{fa-css-prefix}-cubes:before { content: @fa-var-cubes; }\r\n.@{fa-css-prefix}-behance:before { content: @fa-var-behance; }\r\n.@{fa-css-prefix}-behance-square:before { content: @fa-var-behance-square; }\r\n.@{fa-css-prefix}-steam:before { content: @fa-var-steam; }\r\n.@{fa-css-prefix}-steam-square:before { content: @fa-var-steam-square; }\r\n.@{fa-css-prefix}-recycle:before { content: @fa-var-recycle; }\r\n.@{fa-css-prefix}-automobile:before,\r\n.@{fa-css-prefix}-car:before { content: @fa-var-car; }\r\n.@{fa-css-prefix}-cab:before,\r\n.@{fa-css-prefix}-taxi:before { content: @fa-var-taxi; }\r\n.@{fa-css-prefix}-tree:before { content: @fa-var-tree; }\r\n.@{fa-css-prefix}-spotify:before { content: @fa-var-spotify; }\r\n.@{fa-css-prefix}-deviantart:before { content: @fa-var-deviantart; }\r\n.@{fa-css-prefix}-soundcloud:before { content: @fa-var-soundcloud; }\r\n.@{fa-css-prefix}-database:before { content: @fa-var-database; }\r\n.@{fa-css-prefix}-file-pdf-o:before { content: @fa-var-file-pdf-o; }\r\n.@{fa-css-prefix}-file-word-o:before { content: @fa-var-file-word-o; }\r\n.@{fa-css-prefix}-file-excel-o:before { content: @fa-var-file-excel-o; }\r\n.@{fa-css-prefix}-file-powerpoint-o:before { content: @fa-var-file-powerpoint-o; }\r\n.@{fa-css-prefix}-file-photo-o:before,\r\n.@{fa-css-prefix}-file-picture-o:before,\r\n.@{fa-css-prefix}-file-image-o:before { content: @fa-var-file-image-o; }\r\n.@{fa-css-prefix}-file-zip-o:before,\r\n.@{fa-css-prefix}-file-archive-o:before { content: @fa-var-file-archive-o; }\r\n.@{fa-css-prefix}-file-sound-o:before,\r\n.@{fa-css-prefix}-file-audio-o:before { content: @fa-var-file-audio-o; }\r\n.@{fa-css-prefix}-file-movie-o:before,\r\n.@{fa-css-prefix}-file-video-o:before { content: @fa-var-file-video-o; }\r\n.@{fa-css-prefix}-file-code-o:before { content: @fa-var-file-code-o; }\r\n.@{fa-css-prefix}-vine:before { content: @fa-var-vine; }\r\n.@{fa-css-prefix}-codepen:before { content: @fa-var-codepen; }\r\n.@{fa-css-prefix}-jsfiddle:before { content: @fa-var-jsfiddle; }\r\n.@{fa-css-prefix}-life-bouy:before,\r\n.@{fa-css-prefix}-life-buoy:before,\r\n.@{fa-css-prefix}-life-saver:before,\r\n.@{fa-css-prefix}-support:before,\r\n.@{fa-css-prefix}-life-ring:before { content: @fa-var-life-ring; }\r\n.@{fa-css-prefix}-circle-o-notch:before { content: @fa-var-circle-o-notch; }\r\n.@{fa-css-prefix}-ra:before,\r\n.@{fa-css-prefix}-rebel:before { content: @fa-var-rebel; }\r\n.@{fa-css-prefix}-ge:before,\r\n.@{fa-css-prefix}-empire:before { content: @fa-var-empire; }\r\n.@{fa-css-prefix}-git-square:before { content: @fa-var-git-square; }\r\n.@{fa-css-prefix}-git:before { content: @fa-var-git; }\r\n.@{fa-css-prefix}-hacker-news:before { content: @fa-var-hacker-news; }\r\n.@{fa-css-prefix}-tencent-weibo:before { content: @fa-var-tencent-weibo; }\r\n.@{fa-css-prefix}-qq:before { content: @fa-var-qq; }\r\n.@{fa-css-prefix}-wechat:before,\r\n.@{fa-css-prefix}-weixin:before { content: @fa-var-weixin; }\r\n.@{fa-css-prefix}-send:before,\r\n.@{fa-css-prefix}-paper-plane:before { content: @fa-var-paper-plane; }\r\n.@{fa-css-prefix}-send-o:before,\r\n.@{fa-css-prefix}-paper-plane-o:before { content: @fa-var-paper-plane-o; }\r\n.@{fa-css-prefix}-history:before { content: @fa-var-history; }\r\n.@{fa-css-prefix}-genderless:before,\r\n.@{fa-css-prefix}-circle-thin:before { content: @fa-var-circle-thin; }\r\n.@{fa-css-prefix}-header:before { content: @fa-var-header; }\r\n.@{fa-css-prefix}-paragraph:before { content: @fa-var-paragraph; }\r\n.@{fa-css-prefix}-sliders:before { content: @fa-var-sliders; }\r\n.@{fa-css-prefix}-share-alt:before { content: @fa-var-share-alt; }\r\n.@{fa-css-prefix}-share-alt-square:before { content: @fa-var-share-alt-square; }\r\n.@{fa-css-prefix}-bomb:before { content: @fa-var-bomb; }\r\n.@{fa-css-prefix}-soccer-ball-o:before,\r\n.@{fa-css-prefix}-futbol-o:before { content: @fa-var-futbol-o; }\r\n.@{fa-css-prefix}-tty:before { content: @fa-var-tty; }\r\n.@{fa-css-prefix}-binoculars:before { content: @fa-var-binoculars; }\r\n.@{fa-css-prefix}-plug:before { content: @fa-var-plug; }\r\n.@{fa-css-prefix}-slideshare:before { content: @fa-var-slideshare; }\r\n.@{fa-css-prefix}-twitch:before { content: @fa-var-twitch; }\r\n.@{fa-css-prefix}-yelp:before { content: @fa-var-yelp; }\r\n.@{fa-css-prefix}-newspaper-o:before { content: @fa-var-newspaper-o; }\r\n.@{fa-css-prefix}-wifi:before { content: @fa-var-wifi; }\r\n.@{fa-css-prefix}-calculator:before { content: @fa-var-calculator; }\r\n.@{fa-css-prefix}-paypal:before { content: @fa-var-paypal; }\r\n.@{fa-css-prefix}-google-wallet:before { content: @fa-var-google-wallet; }\r\n.@{fa-css-prefix}-cc-visa:before { content: @fa-var-cc-visa; }\r\n.@{fa-css-prefix}-cc-mastercard:before { content: @fa-var-cc-mastercard; }\r\n.@{fa-css-prefix}-cc-discover:before { content: @fa-var-cc-discover; }\r\n.@{fa-css-prefix}-cc-amex:before { content: @fa-var-cc-amex; }\r\n.@{fa-css-prefix}-cc-paypal:before { content: @fa-var-cc-paypal; }\r\n.@{fa-css-prefix}-cc-stripe:before { content: @fa-var-cc-stripe; }\r\n.@{fa-css-prefix}-bell-slash:before { content: @fa-var-bell-slash; }\r\n.@{fa-css-prefix}-bell-slash-o:before { content: @fa-var-bell-slash-o; }\r\n.@{fa-css-prefix}-trash:before { content: @fa-var-trash; }\r\n.@{fa-css-prefix}-copyright:before { content: @fa-var-copyright; }\r\n.@{fa-css-prefix}-at:before { content: @fa-var-at; }\r\n.@{fa-css-prefix}-eyedropper:before { content: @fa-var-eyedropper; }\r\n.@{fa-css-prefix}-paint-brush:before { content: @fa-var-paint-brush; }\r\n.@{fa-css-prefix}-birthday-cake:before { content: @fa-var-birthday-cake; }\r\n.@{fa-css-prefix}-area-chart:before { content: @fa-var-area-chart; }\r\n.@{fa-css-prefix}-pie-chart:before { content: @fa-var-pie-chart; }\r\n.@{fa-css-prefix}-line-chart:before { content: @fa-var-line-chart; }\r\n.@{fa-css-prefix}-lastfm:before { content: @fa-var-lastfm; }\r\n.@{fa-css-prefix}-lastfm-square:before { content: @fa-var-lastfm-square; }\r\n.@{fa-css-prefix}-toggle-off:before { content: @fa-var-toggle-off; }\r\n.@{fa-css-prefix}-toggle-on:before { content: @fa-var-toggle-on; }\r\n.@{fa-css-prefix}-bicycle:before { content: @fa-var-bicycle; }\r\n.@{fa-css-prefix}-bus:before { content: @fa-var-bus; }\r\n.@{fa-css-prefix}-ioxhost:before { content: @fa-var-ioxhost; }\r\n.@{fa-css-prefix}-angellist:before { content: @fa-var-angellist; }\r\n.@{fa-css-prefix}-cc:before { content: @fa-var-cc; }\r\n.@{fa-css-prefix}-shekel:before,\r\n.@{fa-css-prefix}-sheqel:before,\r\n.@{fa-css-prefix}-ils:before { content: @fa-var-ils; }\r\n.@{fa-css-prefix}-meanpath:before { content: @fa-var-meanpath; }\r\n.@{fa-css-prefix}-buysellads:before { content: @fa-var-buysellads; }\r\n.@{fa-css-prefix}-connectdevelop:before { content: @fa-var-connectdevelop; }\r\n.@{fa-css-prefix}-dashcube:before { content: @fa-var-dashcube; }\r\n.@{fa-css-prefix}-forumbee:before { content: @fa-var-forumbee; }\r\n.@{fa-css-prefix}-leanpub:before { content: @fa-var-leanpub; }\r\n.@{fa-css-prefix}-sellsy:before { content: @fa-var-sellsy; }\r\n.@{fa-css-prefix}-shirtsinbulk:before { content: @fa-var-shirtsinbulk; }\r\n.@{fa-css-prefix}-simplybuilt:before { content: @fa-var-simplybuilt; }\r\n.@{fa-css-prefix}-skyatlas:before { content: @fa-var-skyatlas; }\r\n.@{fa-css-prefix}-cart-plus:before { content: @fa-var-cart-plus; }\r\n.@{fa-css-prefix}-cart-arrow-down:before { content: @fa-var-cart-arrow-down; }\r\n.@{fa-css-prefix}-diamond:before { content: @fa-var-diamond; }\r\n.@{fa-css-prefix}-ship:before { content: @fa-var-ship; }\r\n.@{fa-css-prefix}-user-secret:before { content: @fa-var-user-secret; }\r\n.@{fa-css-prefix}-motorcycle:before { content: @fa-var-motorcycle; }\r\n.@{fa-css-prefix}-street-view:before { content: @fa-var-street-view; }\r\n.@{fa-css-prefix}-heartbeat:before { content: @fa-var-heartbeat; }\r\n.@{fa-css-prefix}-venus:before { content: @fa-var-venus; }\r\n.@{fa-css-prefix}-mars:before { content: @fa-var-mars; }\r\n.@{fa-css-prefix}-mercury:before { content: @fa-var-mercury; }\r\n.@{fa-css-prefix}-transgender:before { content: @fa-var-transgender; }\r\n.@{fa-css-prefix}-transgender-alt:before { content: @fa-var-transgender-alt; }\r\n.@{fa-css-prefix}-venus-double:before { content: @fa-var-venus-double; }\r\n.@{fa-css-prefix}-mars-double:before { content: @fa-var-mars-double; }\r\n.@{fa-css-prefix}-venus-mars:before { content: @fa-var-venus-mars; }\r\n.@{fa-css-prefix}-mars-stroke:before { content: @fa-var-mars-stroke; }\r\n.@{fa-css-prefix}-mars-stroke-v:before { content: @fa-var-mars-stroke-v; }\r\n.@{fa-css-prefix}-mars-stroke-h:before { content: @fa-var-mars-stroke-h; }\r\n.@{fa-css-prefix}-neuter:before { content: @fa-var-neuter; }\r\n.@{fa-css-prefix}-facebook-official:before { content: @fa-var-facebook-official; }\r\n.@{fa-css-prefix}-pinterest-p:before { content: @fa-var-pinterest-p; }\r\n.@{fa-css-prefix}-whatsapp:before { content: @fa-var-whatsapp; }\r\n.@{fa-css-prefix}-server:before { content: @fa-var-server; }\r\n.@{fa-css-prefix}-user-plus:before { content: @fa-var-user-plus; }\r\n.@{fa-css-prefix}-user-times:before { content: @fa-var-user-times; }\r\n.@{fa-css-prefix}-hotel:before,\r\n.@{fa-css-prefix}-bed:before { content: @fa-var-bed; }\r\n.@{fa-css-prefix}-viacoin:before { content: @fa-var-viacoin; }\r\n.@{fa-css-prefix}-train:before { content: @fa-var-train; }\r\n.@{fa-css-prefix}-subway:before { content: @fa-var-subway; }\r\n.@{fa-css-prefix}-medium:before { content: @fa-var-medium; }\r\n"],"sourceRoot":"/source/"} */ \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/ViewModels/HeadingEditorViewModel.cs b/src/Orchard.Web/Modules/Orchard.Layouts/ViewModels/HeadingEditorViewModel.cs new file mode 100644 index 000000000..3bbbdbe92 --- /dev/null +++ b/src/Orchard.Web/Modules/Orchard.Layouts/ViewModels/HeadingEditorViewModel.cs @@ -0,0 +1,6 @@ +namespace Orchard.Layouts.ViewModels { + public class HeadingEditorViewModel { + public string Text { get; set; } + public int Level { get; set; } + } +} \ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Views/EditorTemplates/Elements.Heading.cshtml b/src/Orchard.Web/Modules/Orchard.Layouts/Views/EditorTemplates/Elements.Heading.cshtml new file mode 100644 index 000000000..4d174ea6f --- /dev/null +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Views/EditorTemplates/Elements.Heading.cshtml @@ -0,0 +1,20 @@ +@model Orchard.Layouts.ViewModels.HeadingEditorViewModel +@{ + Script.Include("AutoFocus.js"); +} +
+ @T("Level") +
    + @for (var i = 1; i <= 6; i++) { +
  • + @Html.RadioButtonFor(m => m.Level, i, new {id = "h" + i}) + +
  • + } +
+
+
+ @Html.LabelFor(m => m.Text, T("Text")) + @Html.TextBoxFor(m => m.Text, new { @class = "text large tokenized", autofocus = "autofocus" }) + @Html.Hint(T("Note: HTML markup will be rendered unencoded.")) +
\ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/Heading.cshtml b/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/Heading.cshtml new file mode 100644 index 000000000..7e691b16f --- /dev/null +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/Heading.cshtml @@ -0,0 +1,6 @@ +@using Orchard.Layouts.Helpers +@{ + var tagBuilder = TagBuilderExtensions.CreateElementTagBuilder(Model, "h" + (Model.Level >= 1 && Model.Level <= 6 ? Model.Level : 1)); + tagBuilder.InnerHtml = Model.ProcessedText; +} +@tagBuilder.ToHtmlString() diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/Paragraph.Design.cshtml b/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/Paragraph.Design.cshtml index 8f659fcf5..30c90227c 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/Paragraph.Design.cshtml +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/Paragraph.Design.cshtml @@ -1 +1 @@ -@Html.Raw((string)Model.Element.Content) \ No newline at end of file +

@Html.Raw((string)Model.Element.Content)

\ No newline at end of file diff --git a/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/Paragraph.cshtml b/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/Paragraph.cshtml index 4cd4709c1..30c90227c 100644 --- a/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/Paragraph.cshtml +++ b/src/Orchard.Web/Modules/Orchard.Layouts/Views/Elements/Paragraph.cshtml @@ -1,6 +1 @@ -@using Orchard.Layouts.Helpers -@{ - var tagBuilder = TagBuilderExtensions.CreateElementTagBuilder(Model, "p"); - tagBuilder.InnerHtml = Model.ProcessedText; -} -@tagBuilder.ToHtmlString() +

@Html.Raw((string)Model.Element.Content)

\ No newline at end of file