diff --git a/Changelog.md b/Changelog.md index ce257938..bb9198e0 100644 --- a/Changelog.md +++ b/Changelog.md @@ -1,5 +1,11 @@ # Impac! Frontend Changelog +### v1.7.6 + +- Applies v1.6.11 + +------------------------------------------------------------- + ### v1.7.5 | 2018 - Week 20 - [IMPAC-855] CF: Fix Payroll costs series legend image @@ -27,6 +33,12 @@ ------------------------------------------------------------- +### v1.6.11 | 2018 + +- [KAPPASUP-61] Improve messaging on live balance widget + +------------------------------------------------------------- + ### v1.6.10 | 2018 - Week 15 #### Adds diff --git a/bower.json b/bower.json index 4d3ab0e7..3c1f9e52 100755 --- a/bower.json +++ b/bower.json @@ -1,7 +1,7 @@ { "name": "impac-angular", "description": "Impac! Front-End Library", - "version": "1.7.5", + "version": "1.7.6", "license": "Copyright 2017 Maestrano Pty Ltd", "repository": { "type": "git", diff --git a/dist/impac-angular.css b/dist/impac-angular.css index ac99ab12..495548d8 100644 --- a/dist/impac-angular.css +++ b/dist/impac-angular.css @@ -9478,28 +9478,6 @@ dashboard-templates-selector .templates .template.selected { #transactions-list .table-container td > .expected-payment-date .reset-date { margin-left: 3px; } -#trends-list .top { - height: 40px; -} -#trends-list .top a.back-link { - font-weight: normal; -} -#trends-list .top .pagination { - margin: 0px; -} -#trends-list .table-container { - max-height: calc(565px - 60px); - overflow: auto; -} -#trends-list .table-container div[uib-datepicker-popup-wrap] { - display: inline-block; -} -#trends-list .table-container input.btn.btn-xs { - margin-top: -2px; -} -#trends-list .table-container button.btn.reset-date { - margin-top: -2px; -} #trends-add { text-align: center; font-size: 13px; @@ -9567,6 +9545,28 @@ dashboard-templates-selector .templates .template.selected { #trends-add .message .bottom { margin-top: 20px; } +#trends-list .top { + height: 40px; +} +#trends-list .top a.back-link { + font-weight: normal; +} +#trends-list .top .pagination { + margin: 0px; +} +#trends-list .table-container { + max-height: calc(565px - 60px); + overflow: auto; +} +#trends-list .table-container div[uib-datepicker-popup-wrap] { + display: inline-block; +} +#trends-list .table-container input.btn.btn-xs { + margin-top: -2px; +} +#trends-list .table-container button.btn.reset-date { + margin-top: -2px; +} .analytics .dashboard-settings.currency { text-align: right; } @@ -10031,680 +10031,754 @@ chart-threshold .attach-panel .actions button.loading { .analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-close:hover { color: #ed1e79; } -.analytics .widget-item .content .settings.select-account { - padding: 0px 5px; -} -.analytics .settings.accounting-behaviour .btn.btn-primary { - background-color: #bba9f5; - border: solid 1px #977bf0; +.analytics .widget-item .content.accounts-assets-liability-summary .param-selector { + text-align: center; } -.analytics .settings.accounting-behaviour .btn.btn-primary.focus, -.analytics .settings.accounting-behaviour .btn.btn-primary.active { - background-color: #977bf0; +.analytics .widget-item .content.accounts-assets-liability-summary .legend { + text-align: left; + max-height: 90px; } -.analytics .settings.attach-kpis .attach-kpi { - padding: 8px 5px; +.analytics .widget-item .content.accounts-assets-liability-summary .legend .title { + text-align: center; + border-bottom: dashed 1px #dfe2e2; } -.analytics .settings.attach-kpis .attach-kpi form .row { - padding-bottom: 5px; +.analytics .widget-item .content.accounts-assets-summary .legend { + text-align: left; + max-height: 115px; } -.analytics .settings.attach-kpis .attach-kpi .attach-kpi-form { - background-color: white; - border: 1px solid #ddd; - padding: 5px; +.analytics .widget-item .content.accounts-assets-summary .legend .title { + text-align: center; + border-bottom: dashed 1px #dfe2e2; } -.analytics .settings.attach-kpis .attach-kpi form .row.kpi-description { - padding: 10px 2px; +.analytics .widget-item .content.accounts-assets-vs-liabilities .legend > .title span { + margin-left: 3px; } -.analytics .settings.attach-kpis .attach-kpi form .row.kpi-description span { - display: block; - font-weight: bold; - font-size: 13px; +.analytics .widget-item .content.accounts-balance h3 { + font-weight: 300; + font-size: 14px; + color: #5B6667; + text-align: left; + margin-top: 30px; + text-align: center; } -.analytics .settings.attach-kpis .attach-kpi form.attach-kpi-form input.attach-target { - background-color: white; - height: inherit; +.analytics .widget-item .content.accounts-balance .price { + font-weight: 900; + font-size: 22px; + color: #5B6667; + text-align: center; + margin-top: 0px; } -.analytics .settings.attach-kpis .attach-kpi .error-messages { - color: #e01f74; - width: 120px; +.analytics .widget-item .content.accounts-balance-sheet { + min-height: 565px; } -.analytics .settings.attach-kpis .attached-kpis { - padding: 5px; +@media (min-width: 992px) { + .analytics .widget-item .content.accounts-balance-sheet { + height: 565px; + } + .analytics .widget-item .content.accounts-balance-sheet .chart-container { + max-width: 585px; + max-height: 440px; + margin: auto; + } } -.analytics .settings.attach-kpis .list-group-item.attached-kpi { - padding: 5px 10px; +.analytics .widget-item .content.accounts-balance-sheet .edit { + max-height: 545px; } -.analytics .settings.attach-kpis .list-group-item.attached-kpi .attached-kpi-name { - overflow: hidden; - width: 75%; - display: inline-block; - white-space: nowrap; - text-overflow: ellipsis; - margin-top: 3px; - font-size: 13px; - font-weight: bold; +.analytics .widget-item .content.accounts-balance-sheet .edit .widget-lines-container { + overflow-y: hidden; + overflow-x: hidden; } -.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions { - padding-top: 2px; +.analytics .widget-item .content.accounts-balance-sheet .widget-lines-container { + overflow-y: scroll; + overflow-x: hidden; + max-height: 490px; } -.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .alerts-config { - display: inline-block; - text-align: left; - padding-left: 4px; - height: 20px; - border-radius: 40px; - width: 21px; - color: #358fdc; - background-color: white; - border: solid 1px #358fdc; +@media (max-width: 767px) { + .analytics .widget-item .content.accounts-balance-sheet .widget-lines-container .row.widget-line:not(:last-child) { + border-bottom: dashed 1px #dfe2e2; + } } -.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .alerts-config:hover { - cursor: pointer; +.analytics .widget-item .content.accounts-balance-sheet .widget-lines-container .row.widget-line.header > [class*='col-'] { + position: static; } -.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .edit-attached-kpi { - display: inline-block; +.analytics .widget-item .content.accounts-balance-sheet .widget-lines-container.no-scroll { + overflow: visible; } -.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .edit-attached-kpi i { - border-radius: 10px; - width: 21px; - color: #358fdc; - background-color: white; - height: 20px; - padding: 3px 5px 5px 5px; - border: solid 1px #358fdc; +.analytics .widget-item .content.accounts-balance-sheet .no-data-block { + font-weight: 300; + font-size: 16px; + color: #5B6667; + text-align: center; + margin: 15px 0px; } -.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .edit-attached-kpi i:hover { - cursor: pointer; +.analytics .widget-item .content.accounts-cash-balance { + min-height: 565px; } -.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .remove-attached-kpi { - display: inline-block; +@media (min-width: 992px) { + .analytics .widget-item .content.accounts-cash-balance { + height: 565px; + } + .analytics .widget-item .content.accounts-cash-balance .chart-container { + max-width: 585px; + max-height: 440px; + margin: auto; + } } -.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .remove-attached-kpi i { - border-radius: 10px; - width: 21px; - color: #e01f74; - background-color: white; - height: 20px; - padding: 3px 5px 5px 5px; - border: solid 1px #e01f74; +.analytics .widget-item .content.accounts-cash-balance .edit { + max-height: 545px; } -.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .remove-attached-kpi i:hover { - cursor: pointer; +.analytics .widget-item .content.accounts-cash-balance .edit .widget-lines-container { + overflow-y: hidden; + overflow-x: hidden; } -.analytics .widget-item .content .settings.select-account { - padding: 0px 5px; +.analytics .widget-item .content.accounts-cash-balance .data-container { + height: calc(565px - 50px); + width: 100%; } -.analytics .widget-item .content .settings.chart-filters .row { - margin: 0px; +.analytics .widget-item .content.accounts-cash-balance .left-panel { + width: 180px; + display: inline-block; + overflow: auto; + max-height: 100%; } -.analytics .widget-item .content .settings.chart-filters input[type="radio"] { - margin: 0; - margin-right: 3px; - padding: 0; - width: 13px; - height: 13px; - vertical-align: middle; - position: relative; - top: -1px; - outline: none; +.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + min-height: 45px; + margin: 3px; + font-size: 13px; + padding: 3px; + cursor: pointer; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; } -.analytics .widget-item .content .settings.chart-filters input[type="range"] { - height: auto; - width: 100%; +.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item:hover { + background-color: #ececec; } -.analytics .settings.dates-picker h5 { - display: none; +.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item i { + font-size: 19px; + padding: 4px; + margin-top: 1px; } -.analytics .settings.dates-picker button.btn.btn-sm { - line-height: 1; +.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item span { + color: #5B6667; } -.analytics .settings.dates-picker button.btn.btn-sm.date-button { - margin: 0px 5px; -} -.analytics .settings.dates-picker button.btn.btn-sm.btn-danger { - display: none; +.analytics .widget-item .content.accounts-cash-balance .legend-item-icon { + width: 16px; + height: 16px; } -.analytics .settings.dates-picker button.btn.btn-sm.btn-info { - border-radius: 3px; +.analytics .widget-item .content.accounts-cash-balance .right-panel { + width: calc(100% - 180px); + float: right; } -.analytics .settings.dates-picker .tooltip-inner { - text-transform: none; +.analytics .widget-item .content.accounts-cash-balance .right-panel .cash-balance-chart { + height: calc(565px - 50px); } -.analytics .settings.dates-picker .dropdown-menu > li > div > table { - outline: none; +.analytics .widget-item .content.accounts-cash-balance .dates-picker { + display: inline-block; + float: right; + font-size: 12px; } -.analytics .settings.forecast-payroll .widget-lines-container .widget-line { - padding: 5px 10px 5px 18px; +.analytics .widget-item .content.accounts-cash-projection { + min-height: 565px; } -.analytics .settings.forecast-payroll .widget-lines-container .widget-line:nth-child(even) { - background-color: #f3f4f4; +@media (min-width: 992px) { + .analytics .widget-item .content.accounts-cash-projection { + height: 565px; + } + .analytics .widget-item .content.accounts-cash-projection .chart-container { + max-width: 585px; + max-height: 440px; + margin: auto; + } } -.analytics .settings.forecast-payroll .widget-lines-container .widget-line:nth-child(odd) { - background-color: white; +.analytics .widget-item .content.accounts-cash-projection .edit { + max-height: 545px; } -.analytics .settings.forecast-payroll .widget-lines-container .widget-line .fa { - float: right; - font-size: 20px; - cursor: pointer; +.analytics .widget-item .content.accounts-cash-projection .edit .widget-lines-container { + overflow-y: hidden; + overflow-x: hidden; } -.analytics .settings.forecast-payroll .widget-lines-container .widget-line .fa.fa-toggle-on { - color: #977bf0; +.analytics .widget-item .content.accounts-cash-projection .cash-projection-chart { + height: calc(565px - 50px); } -.analytics .settings.forecast-payroll .widget-lines-container .widget-line .fa.fa-toggle-off { - color: #9ba6a7; +.analytics .widget-item .content.accounts-cash-projection .highcharts-legend-item rect.highcharts-point { + display: none; } -.analytics .widget-item .content .settings.hist-mode-choser { - max-height: 70px; +.analytics .widget-item .content.accounts-cash-projection .highcharts-legend-item span { + width: 110px; + text-align: center; } -.analytics .widget-item .content .settings.hist-mode-choser [common-time-period-info] { - padding-bottom: 8px; +.analytics .widget-item .content.accounts-cash-projection .highcharts-legend-item span img { + text-align: center; + width: 55px; + height: 25px; } -.analytics .widget-item .content .settings.hist-mode-choser .options { - width: 150px; - margin: auto; - padding-bottom: 8px; - border-bottom: solid 1px #e6e6e6; - font-weight: 500; +.analytics .widget-item .content.accounts-cash-projection .dates-picker { + display: inline-block; + float: right; font-size: 12px; - color: #c4caca; } -.analytics .widget-item .content .settings.hist-mode-choser .options a { - font-weight: 500; +.analytics .widget-item .content.accounts-cash-projection transactions-list { font-size: 12px; - color: #c4caca; - text-transform: uppercase; -} -.analytics .widget-item .content .settings.hist-mode-choser .options a.active { - color: #977bf0; -} -.analytics .widget-item .content .settings.hist-mode-choser .arrow-container { - width: 28px; - height: 28px; - position: relative; - top: -14px; - margin: auto; } -.analytics .widget-item .content .settings.hist-mode-choser .arrow-container.right { - left: 46px; +.analytics .widget-item .content.accounts-cash-summary { + min-height: 565px; } -.analytics .widget-item .content .settings.hist-mode-choser .arrow-container.left { - left: -30px; +@media (min-width: 992px) { + .analytics .widget-item .content.accounts-cash-summary { + height: 565px; + } + .analytics .widget-item .content.accounts-cash-summary .chart-container { + max-width: 585px; + max-height: 440px; + margin: auto; + } } -.analytics .widget-item .content .settings.hist-mode-choser .arrow-container .arrow-border { - border-top: 14px solid #e6e6e6; - border-left: 14px solid transparent; - border-right: 14px solid transparent; - width: 0px; - height: 0px; +.analytics .widget-item .content.accounts-cash-summary .edit { + max-height: 545px; } -.analytics .widget-item .content .settings.hist-mode-choser .arrow-container .arrow { - border-top: 14px solid white; - border-left: 14px solid transparent; - border-right: 14px solid transparent; - position: relative; - top: 12px; - width: 0px; - height: 0px; +.analytics .widget-item .content.accounts-cash-summary .edit .widget-lines-container { + overflow-y: hidden; + overflow-x: hidden; } -.analytics .settings.limit-entries { - color: #1E303B; - text-transform: uppercase; - text-align: center; - border-bottom: dashed 1px #E6E6E6; - padding-bottom: 8px; +.analytics .widget-item .content.accounts-cash-summary .widget-lines-container { + max-height: 540px; } -.analytics .settings.limit-entries a.option.badge { - color: white; - background-color: #1E303B; +.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line { + cursor: pointer; + border: solid 1px white; } -.analytics .settings.offsets .offset-value { - font-style: italic; - font-size: 13px; +.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line .selection-tag { + display: block; + right: 0px; + margin-top: -6px; + width: 10px; + height: 29px; + position: absolute; } -.analytics .settings.offsets .offset-value .fa-trash-o { - margin-left: 10px; +.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line:hover { + background-color: #e6e0fb; } -.analytics .settings.offsets .offset-value .fa-trash-o:hover { - color: #e01f74; - cursor: pointer; +.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line.no-select { + cursor: auto; } -.analytics .settings.offsets input { - width: 75%; +.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line.no-select:hover { + color: #626d6d; } -.analytics .settings.offsets button { - width: 30px; +.analytics .widget-item .content.accounts-cash-summary .right-panel .widget-lines-container { + overflow-y: auto; + overflow-x: hidden; + max-height: 235px; } -.analytics .settings.organizations .widget-lines-container .widget-line { - padding: 5px 10px 5px 18px; +.analytics .widget-item .content.accounts-cash-summary .no-element { + font-weight: 300; + font-size: 16px; + color: #5B6667; + text-align: center; } -.analytics .settings.organizations .widget-lines-container .widget-line:nth-child(even) { - background-color: #f3f4f4; +.analytics .widget-item .content.accounts-cash-summary .right-panel .widget-lines-container { + max-height: 215px; } -.analytics .settings.organizations .widget-lines-container .widget-line:nth-child(odd) { - background-color: white; +.analytics .widget-item .content.accounts-cash-summary .row.lines-group.cash { + border-top: solid 1px; + border-bottom: double; } -.analytics .settings.organizations .widget-lines-container .widget-line .fa { - float: right; - font-size: 20px; - cursor: pointer; +.analytics .widget-item .content.accounts-class-comparison .param-selector { + text-align: center; } -.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-toggle-on, -.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-check-circle { - color: #977bf0; +.analytics .widget-item .content.accounts-class-comparison .widget-lines-container { + max-height: 94px; + color: #626d6d; } -.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-toggle-off, -.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-circle-thin { - color: #9ba6a7; +.analytics .widget-item .content.accounts-comparison { + min-height: 565px; } -.analytics .widget-item .content .settings.param-selector { - display: inline-block; +@media (min-width: 992px) { + .analytics .widget-item .content.accounts-comparison { + height: 565px; + } + .analytics .widget-item .content.accounts-comparison .chart-container { + max-width: 585px; + max-height: 440px; + margin: auto; + } } -.analytics .widget-item .content .settings.param-selector.classic { - width: 100%; +.analytics .widget-item .content.accounts-comparison .edit { + max-height: 545px; } -.analytics .widget-item .content .settings.param-selector.classic select { - width: 100%; - height: 25px; - border: 1px solid #ccc; - text-transform: uppercase; - margin: 0px 0px 5px 0px; +.analytics .widget-item .content.accounts-comparison .edit .widget-lines-container { + overflow-y: hidden; + overflow-x: hidden; } -.analytics .widget-item .content .settings.param-selector a { - font-weight: normal; - color: #977bf0; - white-space: nowrap; +@media print { + .analytics .widget-item .content.accounts-comparison .chart-container { + max-width: 80% !important; + } } -.analytics .widget-item .content .settings.param-selector .options-container { +.analytics .widget-item .content.accounts-comparison .add-account { position: absolute; - background-color: white; - text-align: left; - min-width: 150px; - max-height: 200px; - z-index: 999; - overflow-y: auto; - overflow-x: hidden; - box-shadow: #000000 0px 3px 15px -3px; -} -.analytics .widget-item .content .settings.param-selector .options-container .param-selector-label { - padding: 3px 5px; - font-weight: 500; - font-size: inherit; - color: black; - cursor: text; - overflow: hidden; - white-space: nowrap; - text-overflow: ellipsis; - line-height: 1.9; + right: 40px; + bottom: 30px; + width: 160px; } -.analytics .widget-item .content .settings.param-selector .options-container .param-selector-label:hover { - cursor: pointer; +.analytics .widget-item .content.accounts-comparison .add-account select { + font-size: 13px; background-color: #977bf0; color: white; + outline: none; + border: none; + cursor: pointer; } -.analytics .widget-item .content .settings.param-selector .options-container::-webkit-scrollbar { - width: 8px; - background-color: #d7e2e4; +.analytics .widget-item .content.accounts-comparison .add-account select[disabled] { + cursor: not-allowed; + background-color: #bba9f5; } -.analytics .widget-item .content .settings.param-selector .options-container::-webkit-scrollbar-thumb { - background-color: #977bf0; +.analytics .widget-item .content.accounts-comparison .add-account select[disabled]:hover { + background-color: #bba9f5; } -.analytics .widget-item .content .settings.param-selector .options-container::-webkit-scrollbar-thumb:hover { - background-color: #a992f3; +.analytics .widget-item .content.accounts-comparison .add-account select:hover { + background-color: #734deb; } -.analytics .settings.params-checkboxes { - padding: 2px 0px; +.analytics .widget-item .content.accounts-comparison .add-account select option { + background-color: white; + color: #c4caca; } -.analytics .settings.params-checkboxes input { +.analytics .widget-item .content.accounts-comparison .add-account select option[disabled] { + color: white; +} +.analytics .widget-item .content.accounts-comparison button.close { + font-size: 15px; +} +.analytics .widget-item .content.accounts-comparison .legend { + text-align: left; + max-height: 103px; +} +.analytics .widget-item .content.accounts-comparison .row { margin: 0; - height: inherit; } -.analytics .settings.params-checkboxes span { - margin-left: 5px; +.analytics .widget-item .content.accounts-comparison .widget-lines-container { + font-size: 11px; + max-height: 220px; + margin-bottom: 65px; + overflow: auto; } -.analytics .settings.params-checkboxes label { - display: -webkit-box; - display: -ms-flexbox; - display: flex; - -webkit-box-pack: center; - -ms-flex-pack: center; - justify-content: center; - line-height: 14px; +.analytics .widget-item .content.accounts-comparison .settings.params-checkboxes { + margin-left: 13px; } -.analytics .widget-item .content .settings.params-picker { - padding: 0px 10px; +.analytics .widget-item .content.accounts-comparison .comparable-error h5 { + margin-left: 13px; + color: #ed1e79; } -.analytics .widget-item .content .settings.params-picker .parameter { - margin: 0px 3px 3px 0px; - padding: 3px 5px; - background-color: #1E303B; - color: white; - border: solid 1px #1E303B; - border-radius: 4px; - cursor: move; +.analytics .widget-item .content.accounts-custom-calculation h3 { + margin-top: 85px; + text-align: center; font-weight: bold; - white-space: nowrap; - float: left; } -.analytics .widget-item .content .settings.params-picker .parameter input[type="checkbox"] { - margin: 0px -3px 0px 3px; - vertical-align: middle; - height: inherit; - outline: none; - cursor: pointer; +.analytics .widget-item .content.accounts-custom-calculation .legend { + max-height: 125px; } -.analytics .widget-item .content .settings.params-picker .parameter .badge { - margin-right: 3px; - font-size: 10px; - background-color: #f2f2f2; - color: #1E303B; - padding: 2px 6px; +.analytics.modal-custom-calculation { + margin: 0px; + padding: 0px; } -.analytics .widget-item .content .settings.params-picker .parameter.unchecked { - background-color: inherit; - font-weight: normal; - color: inherit; - border-color: #c2c4c4; +.analytics.modal-custom-calculation .modal-body .edit { + overflow-y: auto; + overflow-x: hidden; + color: #5B6667; + padding: 2px; + font-size: 12px; + padding: 5px; + overflow: visible; } -.analytics .widget-item .content .settings.params-picker .parameter.unchecked .badge { +.analytics.modal-custom-calculation .modal-body .edit .bottom-buttons .btn { + border-radius: 2px; + margin-right: 5px; + padding: 3px 13px; + text-transform: uppercase; + font-size: 12px; +} +.analytics.modal-custom-calculation .modal-body .edit .bottom-buttons .btn.btn-default { background-color: #c2c4c4; + border: solid 1px #a8abab; color: white; } -.analytics .settings.tag-filter { - padding: 0px 5px; +.analytics.modal-custom-calculation .modal-body .edit .bottom-buttons .btn.btn-default:hover { + border: solid 1px #8e9292; + background-color: #a8abab; } -.analytics .settings.tag-filter .btn.btn-default { - height: 32px; - width: 30px; +.analytics.modal-custom-calculation .modal-body .edit h4 { + margin: 0; + margin-bottom: 8px; + text-align: left; + font-weight: normal; + font-size: 12px; + color: #c4caca; } -.analytics .settings.tag-filter .tag-lines-container { - padding: 0px 10px; +.analytics.modal-custom-calculation .modal-body .edit .part { + margin-bottom: 8px; + padding: 10px 0px; + background-color: #fcfcfc; + border: solid 1px #dfe2e2; } -.analytics .settings.tag-filter .tag-lines-container .tag-line { - display: -webkit-box; - display: -ms-flexbox; - display: flex; - -webkit-box-align: center; - -ms-flex-align: center; - align-items: center; - -webkit-box-pack: end; - -ms-flex-pack: end; - justify-content: flex-end; +.analytics.modal-custom-calculation .modal-body .edit .part h5 { + display: block; + margin: 0; + margin-bottom: 10px; + padding: 0px 15px; + text-transform: uppercase; + font-weight: normal; + font-size: 12px; + color: #c4caca; } -.analytics .settings.tag-filter .tag-lines-container .tag-line .tags-col { - position: static; +.analytics.modal-custom-calculation .modal-body .edit .part label { + font-weight: normal; } -.analytics .settings.tag-filter .tag-lines-container .tag-line tags-input .tags { - display: -webkit-box; - display: -ms-flexbox; - display: flex; - border-radius: 4px; - border: solid 1px #ccc; +.analytics.modal-custom-calculation .modal-body .edit .part select.form-control { + margin: 0px; + border: solid 1px #acb0b1; + outline: none; + -webkit-box-shadow: none; + font-size: 13px; + color: #72728b; } -.analytics .settings.tag-filter .tag-lines-container .tag-line tags-input .tags .tag-item { - background: #79a2bb; - border-radius: 4px; - color: white; +.analytics .widget-item .content.accounts-detailed-classifications { + min-height: 565px; } -.analytics .settings.tag-filter .tag-lines-container .tag-line .host { - position: static; +@media (min-width: 992px) { + .analytics .widget-item .content.accounts-detailed-classifications { + height: 565px; + } + .analytics .widget-item .content.accounts-detailed-classifications .chart-container { + max-width: 585px; + max-height: 440px; + margin: auto; + } } -.analytics .settings.time-period { - padding: 0px 5px; +.analytics .widget-item .content.accounts-detailed-classifications .edit { + max-height: 545px; } -.analytics .settings.time-period select { - height: 22px; - width: 100%; +.analytics .widget-item .content.accounts-detailed-classifications .edit .widget-lines-container { + overflow-y: hidden; + overflow-x: hidden; } -.analytics .settings.time-period > .row { - margin: 0px -5px 7px -5px; +.analytics .widget-item .content.accounts-detailed-classifications .widget-lines-container { + overflow-y: scroll; + overflow-x: hidden; + max-height: 540px; } -.analytics .settings.time-period > .row > div { - padding: 0px 5px; - position: static; +.analytics .widget-item .content.accounts-detailed-classifications .account-class-title { + margin-bottom: 8px; + margin-left: 11px; } -.analytics .settings.time-period > .row .sub-setting { - padding: 5px; +.analytics .widget-item .content.accounts-detailed-classifications .time-period-info { + text-align: right; } -.analytics .widget-item .content .settings.width { - float: right; - font-size: 14px; +.analytics .widget-item .content.accounts-detailed-classifications .widget-line.header.sorting { + border-bottom: 1px solid #ccc; } -.analytics .widget-item .content .settings.width i { - color: silver; - cursor: pointer; +.analytics .widget-item .content.accounts-expense-weight .legend { + text-align: left; + max-height: 115px; +} +.analytics .widget-item .content.accounts-expense-weight .legend .title { + text-align: center; +} +.analytics .widget-item .content.accounts-expenses-revenue .legend { + font-weight: bold; +} +.analytics .widget-item .content.accounts-expenses-revenue .settings.params-checkboxes { + font-size: 12px; + margin-left: 0px; + text-align: center; +} +.analytics .widget-item .content.accounts-invoices-list { + min-height: 565px; +} +@media (min-width: 992px) { + .analytics .widget-item .content.accounts-invoices-list { + height: 565px; + } + .analytics .widget-item .content.accounts-invoices-list .chart-container { + max-width: 585px; + max-height: 440px; + margin: auto; + } +} +.analytics .widget-item .content.accounts-invoices-list .edit { + max-height: 545px; } -.analytics .widget-item .content .settings.width i.reduce { - margin-right: -10px; +.analytics .widget-item .content.accounts-invoices-list .edit .widget-lines-container { + overflow-y: hidden; + overflow-x: hidden; } -.analytics .widget-item .content .settings.width i.expand { - margin-right: -3px; +.analytics .widget-item .content.accounts-invoices-list transactions-list { + font-size: 12px; } -.analytics .widget-item .content.accounts-assets-liability-summary .param-selector { +.analytics .widget-item .content.accounts-live-balance h3 { + font-weight: 900; + font-size: 22px; + color: #5B6667; + margin-top: 0px; + font-size: 18px; text-align: center; + text-shadow: 1px; } -.analytics .widget-item .content.accounts-assets-liability-summary .legend { - text-align: left; - max-height: 90px; +.analytics .widget-item .content.accounts-live-balance .statement-title { + font-size: 13px; + font-weight: 400; } -.analytics .widget-item .content.accounts-assets-liability-summary .legend .title { +.analytics .widget-item .content.accounts-live-balance .balance-title { + font-size: 12px; +} +.analytics .widget-item .content.accounts-live-balance .currency-centered { + font-weight: 300; + font-size: 12px; + color: #5B6667; text-align: center; - border-bottom: dashed 1px #dfe2e2; } -.analytics .widget-item .content.accounts-assets-summary .legend { - text-align: left; - max-height: 115px; +.analytics .widget-item .content.accounts-live-balance .headers { + text-align: center; } -.analytics .widget-item .content.accounts-assets-summary .legend .title { +.analytics .widget-item .content.accounts-live-balance .spacer { + min-height: 30px; +} +.analytics .widget-item .content.accounts-live-balance .price { + font-weight: 900; + font-size: 22px; + color: #5B6667; text-align: center; - border-bottom: dashed 1px #dfe2e2; + margin-top: 0px; } -.analytics .widget-item .content.accounts-assets-vs-liabilities .legend > .title span { - margin-left: 3px; +.analytics .widget-item .content.accounts-live-balance .come-back-later { + text-align: center; + font-size: 11px; + opacity: 0.8; } -.analytics .widget-item .content.accounts-balance h3 { - font-weight: 300; +.analytics .widget-item .content.accounts-live-balance .negative2 { font-size: 14px; - color: #5B6667; - text-align: left; - margin-top: 30px; +} +.analytics .widget-item .content.accounts-payable-receivable h3 { text-align: center; } -.analytics .widget-item .content.accounts-balance .price { +.analytics .widget-item .content.accounts-payable-receivable .legend { + font-weight: bold; +} +.analytics .widget-item .content.accounts-payable-receivable .payable { + margin-top: 15px; +} +.analytics .widget-item .content.accounts-payable-receivable .price { font-weight: 900; font-size: 22px; color: #5B6667; text-align: center; margin-top: 0px; } -.analytics .widget-item .content.accounts-balance-sheet { +.analytics .widget-item .content.accounts-profit-and-loss { min-height: 565px; } @media (min-width: 992px) { - .analytics .widget-item .content.accounts-balance-sheet { + .analytics .widget-item .content.accounts-profit-and-loss { height: 565px; } - .analytics .widget-item .content.accounts-balance-sheet .chart-container { + .analytics .widget-item .content.accounts-profit-and-loss .chart-container { max-width: 585px; max-height: 440px; margin: auto; } } -.analytics .widget-item .content.accounts-balance-sheet .edit { +.analytics .widget-item .content.accounts-profit-and-loss .edit { max-height: 545px; } -.analytics .widget-item .content.accounts-balance-sheet .edit .widget-lines-container { +.analytics .widget-item .content.accounts-profit-and-loss .edit .widget-lines-container { overflow-y: hidden; overflow-x: hidden; } -.analytics .widget-item .content.accounts-balance-sheet .widget-lines-container { - overflow-y: scroll; - overflow-x: hidden; - max-height: 490px; +.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container { + max-height: 540px; } -@media (max-width: 767px) { - .analytics .widget-item .content.accounts-balance-sheet .widget-lines-container .row.widget-line:not(:last-child) { - border-bottom: dashed 1px #dfe2e2; - } +.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line { + cursor: pointer; + border: solid 1px white; } -.analytics .widget-item .content.accounts-balance-sheet .widget-lines-container .row.widget-line.header > [class*='col-'] { - position: static; +.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line .selection-tag { + display: block; + right: 0px; + margin-top: -6px; + width: 10px; + height: 29px; + position: absolute; } -.analytics .widget-item .content.accounts-balance-sheet .widget-lines-container.no-scroll { - overflow: visible; +.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line:hover { + background-color: #e6e0fb; } -.analytics .widget-item .content.accounts-balance-sheet .no-data-block { +.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line.no-select { + cursor: auto; +} +.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line.no-select:hover { + color: #626d6d; +} +.analytics .widget-item .content.accounts-profit-and-loss .right-panel .widget-lines-container { + overflow-y: auto; + overflow-x: hidden; + max-height: 235px; +} +.analytics .widget-item .content.accounts-profit-and-loss .no-element { font-weight: 300; font-size: 16px; color: #5B6667; text-align: center; - margin: 15px 0px; -} -.analytics .widget-item .content.accounts-cash-balance { - min-height: 565px; } -@media (min-width: 992px) { - .analytics .widget-item .content.accounts-cash-balance { - height: 565px; - } - .analytics .widget-item .content.accounts-cash-balance .chart-container { - max-width: 585px; - max-height: 440px; - margin: auto; - } +.analytics .widget-item .content.accounts-profit-and-loss .row.lines-group.profit { + border-top: solid 1px; + border-bottom: double; } -.analytics .widget-item .content.accounts-cash-balance .edit { - max-height: 545px; +.analytics .widget-item .content.accounts-profit-and-loss .right-panel .widget-lines-container { + max-height: 215px; } -.analytics .widget-item .content.accounts-cash-balance .edit .widget-lines-container { - overflow-y: hidden; - overflow-x: hidden; +.analytics .widget-item .content.accounts-profit-and-loss .row.widget-line.header > [class*='col-'] { + position: static; } -.analytics .widget-item .content.accounts-cash-balance .data-container { - height: calc(565px - 50px); - width: 100%; +.analytics .widget-item .content.accounts-ratios .left-panel { + max-height: 230px; + overflow-y: auto; } -.analytics .widget-item .content.accounts-cash-balance .left-panel { - width: 180px; - display: inline-block; - overflow: auto; - max-height: 100%; +.analytics .widget-item .content.accounts-ratios .left-panel .separator { + border-bottom: solid 1px #5B6667; + width: 75%; } -.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item { - display: -webkit-box; - display: -ms-flexbox; - display: flex; - -webkit-box-align: center; - -ms-flex-align: center; - align-items: center; - min-height: 45px; - margin: 3px; - font-size: 13px; - padding: 3px; - cursor: pointer; - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; +.analytics .widget-item .content.accounts-ratios .left-panel .member { + padding-top: 20px; + padding-bottom: 20px; } -.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item:hover { - background-color: #ececec; +.analytics .widget-item .content.accounts-ratios .left-panel .member .price { + margin-top: 0px; + font-size: 18px; } -.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item i { - font-size: 19px; - padding: 4px; - margin-top: 1px; +.analytics .widget-item .content.accounts-ratios .left-panel button { + outline: none; } -.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item span { - color: #5B6667; +.analytics .widget-item .content.accounts-ratios .left-panel.simulation .member { + padding-top: 5px; } -.analytics .widget-item .content.accounts-cash-balance .legend-item-icon { - width: 16px; - height: 16px; +.analytics .widget-item .content.accounts-ratios .left-panel.simulation .member .legend { + display: none; } -.analytics .widget-item .content.accounts-cash-balance .right-panel { - width: calc(100% - 180px); - float: right; +.analytics .widget-item .content.accounts-ratios .left-panel.simulation .member .price { + text-align: right; } -.analytics .widget-item .content.accounts-cash-balance .right-panel .cash-balance-chart { - height: calc(565px - 50px); +.analytics .widget-item .content.accounts-ratios .left-panel.simulation .separator { + width: 100%; } -.analytics .widget-item .content.accounts-cash-balance .dates-picker { - display: inline-block; - float: right; +.analytics .widget-item .content.hr-employee-details { font-size: 12px; } -.analytics .widget-item .content.accounts-cash-projection { - min-height: 565px; +.analytics .widget-item .content.hr-employee-details .details-container { + padding: 0px; + max-height: none; + overflow-y: auto; + overflow-x: hidden; } @media (min-width: 992px) { - .analytics .widget-item .content.accounts-cash-projection { - height: 565px; + .analytics .widget-item .content.hr-employee-details .details-container { + max-height: 200px; } - .analytics .widget-item .content.accounts-cash-projection .chart-container { - max-width: 585px; - max-height: 440px; - margin: auto; +} +@media (min-width: 992px) { + .analytics .widget-item .content.hr-employee-details .right-panel .details-container { + max-height: 220px; } } -.analytics .widget-item .content.accounts-cash-projection .edit { - max-height: 545px; +.analytics .widget-item .content.hr-employee-details .right-panel .legend { + margin-bottom: 5px; } -.analytics .widget-item .content.accounts-cash-projection .edit .widget-lines-container { - overflow-y: hidden; - overflow-x: hidden; +.analytics .widget-item .content.hr-employee-details .title { + text-align: center; + margin-bottom: 10px; + font-size: 14px; } -.analytics .widget-item .content.accounts-cash-projection .cash-projection-chart { - height: calc(565px - 50px); +.analytics .widget-item .content.hr-employees-list .legend { + margin-bottom: 9px; } -.analytics .widget-item .content.accounts-cash-projection .highcharts-legend-item rect.highcharts-point { - display: none; +.analytics .widget-item .content.hr-employees-list .widget-lines-container { + text-align: center; +} +.analytics .widget-item .content.hr-employees-list .widget-lines-container .widget-line:nth-child(even) { + background-color: #f0f0f0; +} +.analytics .widget-item .content.hr-employees-list .widget-lines-container .widget-line:nth-child(odd) { + background-color: white; +} +.analytics .widget-item .content.hr-employees-list .edit .widget-lines-container { + text-align: left; +} +.analytics .widget-item .content.hr-leaves-balance .employee-name { + text-align: center; } -.analytics .widget-item .content.accounts-cash-projection .highcharts-legend-item span { - width: 110px; +.analytics .widget-item .content.hr-leaves-balance .balance { + font-weight: 900; + font-size: 22px; + color: #5B6667; text-align: center; + margin-top: 0px; } -.analytics .widget-item .content.accounts-cash-projection .highcharts-legend-item span img { +.analytics .widget-item .content.hr-leaves-balance h3 { + margin-top: 33px; text-align: center; - width: 55px; - height: 25px; } -.analytics .widget-item .content.accounts-cash-projection .dates-picker { - display: inline-block; - float: right; +.analytics .widget-item .content.hr-leaves-schedule .fc-button { + height: 22px; font-size: 12px; + color: #977bf0; + background: white; + outline: none; } -.analytics .widget-item .content.accounts-cash-projection transactions-list { +.analytics .widget-item .content.hr-leaves-schedule .fc-button:hover { + color: white; + background: #977bf0; +} +.analytics .widget-item .content.hr-leaves-schedule .fc-toolbar { + margin-bottom: 5px; +} +.analytics .widget-item .content.hr-leaves-schedule .fc-day-grid, +.analytics .widget-item .content.hr-leaves-schedule .fc-widget-header { font-size: 12px; + color: #5B6667; } -.analytics .widget-item .content.accounts-cash-summary { +.analytics .widget-item .content.hr-payroll-summary { min-height: 565px; } @media (min-width: 992px) { - .analytics .widget-item .content.accounts-cash-summary { + .analytics .widget-item .content.hr-payroll-summary { height: 565px; } - .analytics .widget-item .content.accounts-cash-summary .chart-container { + .analytics .widget-item .content.hr-payroll-summary .chart-container { max-width: 585px; max-height: 440px; margin: auto; } } -.analytics .widget-item .content.accounts-cash-summary .edit { +.analytics .widget-item .content.hr-payroll-summary .edit { max-height: 545px; } -.analytics .widget-item .content.accounts-cash-summary .edit .widget-lines-container { +.analytics .widget-item .content.hr-payroll-summary .edit .widget-lines-container { overflow-y: hidden; overflow-x: hidden; } -.analytics .widget-item .content.accounts-cash-summary .widget-lines-container { +.analytics .widget-item .content.hr-payroll-summary .widget-lines-container { max-height: 540px; } -.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line { +.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line { cursor: pointer; border: solid 1px white; } -.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line .selection-tag { +.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line .selection-tag { display: block; right: 0px; margin-top: -6px; @@ -10712,346 +10786,315 @@ chart-threshold .attach-panel .actions button.loading { height: 29px; position: absolute; } -.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line:hover { +.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line:hover { background-color: #e6e0fb; } -.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line.no-select { +.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line.no-select { cursor: auto; } -.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line.no-select:hover { +.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line.no-select:hover { color: #626d6d; } -.analytics .widget-item .content.accounts-cash-summary .right-panel .widget-lines-container { +.analytics .widget-item .content.hr-payroll-summary .right-panel .widget-lines-container { overflow-y: auto; overflow-x: hidden; max-height: 235px; } -.analytics .widget-item .content.accounts-cash-summary .no-element { +.analytics .widget-item .content.hr-payroll-summary .no-element { font-weight: 300; font-size: 16px; color: #5B6667; text-align: center; } -.analytics .widget-item .content.accounts-cash-summary .right-panel .widget-lines-container { - max-height: 215px; -} -.analytics .widget-item .content.accounts-cash-summary .row.lines-group.cash { - border-top: solid 1px; - border-bottom: double; +.analytics .widget-item .content.hr-payroll-summary .right-panel .widget-lines-container { + max-height: 145px; } -.analytics .widget-item .content.accounts-class-comparison .param-selector { +.analytics .widget-item .content.hr-salaries-summary h3.left { text-align: center; } -.analytics .widget-item .content.accounts-class-comparison .widget-lines-container { - max-height: 94px; - color: #626d6d; -} -.analytics .widget-item .content.accounts-comparison { - min-height: 565px; -} @media (min-width: 992px) { - .analytics .widget-item .content.accounts-comparison { - height: 565px; - } - .analytics .widget-item .content.accounts-comparison .chart-container { - max-width: 585px; - max-height: 440px; - margin: auto; + .analytics .widget-item .content.hr-salaries-summary h3.left { + margin-top: 69px; } } -.analytics .widget-item .content.accounts-comparison .edit { - max-height: 545px; -} -.analytics .widget-item .content.accounts-comparison .edit .widget-lines-container { - overflow-y: hidden; - overflow-x: hidden; +.analytics .widget-item .content.hr-salaries-summary h3.reduced-left { + text-align: center; } -@media print { - .analytics .widget-item .content.accounts-comparison .chart-container { - max-width: 80% !important; +@media (min-width: 992px) { + .analytics .widget-item .content.hr-salaries-summary h3.reduced-left { + margin-top: 10px; } } -.analytics .widget-item .content.accounts-comparison .add-account { - position: absolute; - right: 40px; - bottom: 30px; - width: 160px; -} -.analytics .widget-item .content.accounts-comparison .add-account select { - font-size: 13px; - background-color: #977bf0; - color: white; - outline: none; - border: none; - cursor: pointer; -} -.analytics .widget-item .content.accounts-comparison .add-account select[disabled] { - cursor: not-allowed; - background-color: #bba9f5; -} -.analytics .widget-item .content.accounts-comparison .add-account select[disabled]:hover { - background-color: #bba9f5; -} -.analytics .widget-item .content.accounts-comparison .add-account select:hover { - background-color: #734deb; -} -.analytics .widget-item .content.accounts-comparison .add-account select option { - background-color: white; - color: #c4caca; -} -.analytics .widget-item .content.accounts-comparison .add-account select option[disabled] { - color: white; -} -.analytics .widget-item .content.accounts-comparison button.close { - font-size: 15px; +.analytics .widget-item .content.hr-salaries-summary h3.right { + margin-bottom: 10px; + text-align: center; } -.analytics .widget-item .content.accounts-comparison .legend { - text-align: left; - max-height: 103px; +.analytics .widget-item .content.hr-salaries-summary .price { + margin-top: 0; } -.analytics .widget-item .content.accounts-comparison .row { - margin: 0; +.analytics .widget-item .content.hr-salaries-summary .widget-lines-container { + max-height: 75px; } -.analytics .widget-item .content.accounts-comparison .widget-lines-container { +.analytics .widget-item .content.hr-salaries-summary .widget-lines-container .widget-line { font-size: 11px; - max-height: 220px; - margin-bottom: 65px; - overflow: auto; -} -.analytics .widget-item .content.accounts-comparison .settings.params-checkboxes { - margin-left: 13px; } -.analytics .widget-item .content.accounts-comparison .comparable-error h5 { - margin-left: 13px; - color: #ed1e79; +@media (min-width: 480px) and (max-width: 991px) { + .analytics .widget-item .content.hr-salaries-summary .right-panel .chart-container { + max-width: 320px; + } } -.analytics .widget-item .content.accounts-custom-calculation h3 { - margin-top: 85px; +.analytics .widget-item .content.hr-superannuation-accruals h3 { + margin-top: 63px; text-align: center; - font-weight: bold; } -.analytics .widget-item .content.accounts-custom-calculation .legend { - max-height: 125px; +.analytics .widget-item .content.hr-superannuation-accruals .legend { + margin-top: 23px; } -.analytics.modal-custom-calculation { - margin: 0px; - padding: 0px; +.analytics .widget-item .content.hr-superannuation-accruals .currency { + font-size: 14px; } -.analytics.modal-custom-calculation .modal-body .edit { - overflow-y: auto; - overflow-x: hidden; +.analytics .widget-item .content.hr-superannuation-accruals .price { + font-weight: 900; + font-size: 22px; color: #5B6667; - padding: 2px; - font-size: 12px; - padding: 5px; - overflow: visible; + text-align: center; + margin-top: 0px; } -.analytics.modal-custom-calculation .modal-body .edit .bottom-buttons .btn { - border-radius: 2px; - margin-right: 5px; - padding: 3px 13px; - text-transform: uppercase; - font-size: 12px; +.analytics .widget-item .content.hr-timesheets .currency { + font-size: 14px; } -.analytics.modal-custom-calculation .modal-body .edit .bottom-buttons .btn.btn-default { - background-color: #c2c4c4; - border: solid 1px #a8abab; - color: white; +.analytics .widget-item .content.hr-timesheets .widget-lines-container { + max-height: 210px; } -.analytics.modal-custom-calculation .modal-body .edit .bottom-buttons .btn.btn-default:hover { - border: solid 1px #8e9292; - background-color: #a8abab; +.analytics .widget-item .content.hr-workforce-summary h3.left { + text-align: center; } -.analytics.modal-custom-calculation .modal-body .edit h4 { - margin: 0; - margin-bottom: 8px; - text-align: left; - font-weight: normal; - font-size: 12px; - color: #c4caca; +@media (min-width: 992px) { + .analytics .widget-item .content.hr-workforce-summary h3.left { + margin-top: 69px; + } } -.analytics.modal-custom-calculation .modal-body .edit .part { - margin-bottom: 8px; - padding: 10px 0px; - background-color: #fcfcfc; - border: solid 1px #dfe2e2; +.analytics .widget-item .content.hr-workforce-summary h3.reduced-left { + text-align: center; } -.analytics.modal-custom-calculation .modal-body .edit .part h5 { - display: block; - margin: 0; +@media (min-width: 992px) { + .analytics .widget-item .content.hr-workforce-summary h3.reduced-left { + margin-top: 10px; + } +} +.analytics .widget-item .content.hr-workforce-summary h3.right { margin-bottom: 10px; - padding: 0px 15px; - text-transform: uppercase; - font-weight: normal; - font-size: 12px; - color: #c4caca; + text-align: center; } -.analytics.modal-custom-calculation .modal-body .edit .part label { - font-weight: normal; +.analytics .widget-item .content.hr-workforce-summary .price { + margin-top: 0; } -.analytics.modal-custom-calculation .modal-body .edit .part select.form-control { - margin: 0px; - border: solid 1px #acb0b1; - outline: none; - -webkit-box-shadow: none; - font-size: 13px; - color: #72728b; +.analytics .widget-item .content.hr-workforce-summary .widget-lines-container { + max-height: 75px; +} +.analytics .widget-item .content.hr-workforce-summary .widget-lines-container .widget-line { + font-size: 11px; +} +@media (min-width: 480px) and (max-width: 991px) { + .analytics .widget-item .content.hr-workforce-summary .right-panel .chart-container { + max-width: 320px; + } } -.analytics .widget-item .content.accounts-detailed-classifications { +.analytics .widget-item .content.invoices-aged-payables-receivables { min-height: 565px; } @media (min-width: 992px) { - .analytics .widget-item .content.accounts-detailed-classifications { + .analytics .widget-item .content.invoices-aged-payables-receivables { height: 565px; } - .analytics .widget-item .content.accounts-detailed-classifications .chart-container { + .analytics .widget-item .content.invoices-aged-payables-receivables .chart-container { max-width: 585px; max-height: 440px; margin: auto; } } -.analytics .widget-item .content.accounts-detailed-classifications .edit { +.analytics .widget-item .content.invoices-aged-payables-receivables .edit { max-height: 545px; } -.analytics .widget-item .content.accounts-detailed-classifications .edit .widget-lines-container { +.analytics .widget-item .content.invoices-aged-payables-receivables .edit .widget-lines-container { overflow-y: hidden; overflow-x: hidden; } -.analytics .widget-item .content.accounts-detailed-classifications .widget-lines-container { - overflow-y: scroll; - overflow-x: hidden; +.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container { max-height: 540px; } -.analytics .widget-item .content.accounts-detailed-classifications .account-class-title { - margin-bottom: 8px; - margin-left: 11px; +.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line { + cursor: pointer; + border: solid 1px white; } -.analytics .widget-item .content.accounts-detailed-classifications .time-period-info { - text-align: right; +.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line .selection-tag { + display: block; + right: 0px; + margin-top: -6px; + width: 10px; + height: 29px; + position: absolute; } -.analytics .widget-item .content.accounts-detailed-classifications .widget-line.header.sorting { - border-bottom: 1px solid #ccc; +.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line:hover { + background-color: #e6e0fb; } -.analytics .widget-item .content.accounts-expense-weight .legend { - text-align: left; - max-height: 115px; +.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line.no-select { + cursor: auto; } -.analytics .widget-item .content.accounts-expense-weight .legend .title { - text-align: center; +.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line.no-select:hover { + color: #626d6d; } -.analytics .widget-item .content.accounts-expenses-revenue .legend { - font-weight: bold; +.analytics .widget-item .content.invoices-aged-payables-receivables .right-panel .widget-lines-container { + overflow-y: auto; + overflow-x: hidden; + max-height: 235px; } -.analytics .widget-item .content.accounts-expenses-revenue .settings.params-checkboxes { - font-size: 12px; - margin-left: 0px; +.analytics .widget-item .content.invoices-aged-payables-receivables .no-element { + font-weight: 300; + font-size: 16px; + color: #5B6667; text-align: center; } -.analytics .widget-item .content.accounts-invoices-list { +.analytics .widget-item .content.invoices-aged-payables-receivables .right-panel .widget-lines-container { + max-height: 215px; +} +.analytics .widget-item .content.invoices-aged-payables-receivables .row.astericks-info { + margin-top: 15px; +} +.analytics .widget-item .content.invoices-aged-payables-receivables .currency-conversions { + float: right; + margin-left: 3px; +} +.analytics .widget-item .content.invoices-list .widget-lines-container { + max-height: 230px; +} +.analytics .widget-item .content.invoices-list .widget-lines-container .widget-line:nth-child(even) { + background-color: #f0f0f0; +} +.analytics .widget-item .content.invoices-list .widget-lines-container .widget-line:nth-child(odd) { + background-color: white; +} +.analytics .widget-item .content.invoices-list .widget-lines-container .widget-line.header { + background-color: white; +} +.analytics .widget-item .content.invoices-list .currency-conversions { + float: right; + margin-right: 3px; + margin-top: -2px; +} +.analytics .widget-item .content.invoices-list .fa.fa-info-circle { + float: right; + font-size: 15px; +} +.analytics .widget-item .content.invoices-list .right-column { + padding-left: 0px; + padding-right: 0px; +} +.analytics .widget-item .content.invoices-summary .chart-container { + max-width: 410px; +} +.analytics .widget-item .content.invoices-summary .legend { + max-height: 28px; +} +.analytics .widget-item .content.sales-aged { min-height: 565px; } @media (min-width: 992px) { - .analytics .widget-item .content.accounts-invoices-list { + .analytics .widget-item .content.sales-aged { height: 565px; } - .analytics .widget-item .content.accounts-invoices-list .chart-container { + .analytics .widget-item .content.sales-aged .chart-container { max-width: 585px; max-height: 440px; margin: auto; } } -.analytics .widget-item .content.accounts-invoices-list .edit { +.analytics .widget-item .content.sales-aged .edit { max-height: 545px; } -.analytics .widget-item .content.accounts-invoices-list .edit .widget-lines-container { +.analytics .widget-item .content.sales-aged .edit .widget-lines-container { overflow-y: hidden; overflow-x: hidden; } -.analytics .widget-item .content.accounts-invoices-list transactions-list { - font-size: 12px; +.analytics .widget-item .content.sales-aged .widget-lines-container { + max-height: 238px; } -.analytics .widget-item .content.accounts-live-balance h3 { +.analytics .widget-item .content.sales-break-even .price { font-weight: 900; font-size: 22px; color: #5B6667; - margin-top: 0px; - font-size: 18px; text-align: center; - text-shadow: 1px; -} -.analytics .widget-item .content.accounts-live-balance .statement-title { - font-size: 13px; - font-weight: 400; + margin-top: 0px; } -.analytics .widget-item .content.accounts-live-balance .balance-title { +.analytics .widget-item .content.sales-break-even .block { + margin: 5px; + padding: 0px 10px 5px 10px; + text-align: left; + box-shadow: 0px 7px 10px -7px #17262d; font-size: 12px; } -.analytics .widget-item .content.accounts-live-balance .currency-centered { - font-weight: 300; - font-size: 12px; +.analytics .widget-item .content.sales-break-even .block form.editable-wrap .editable-controls input { + margin-top: 5px; + width: 100px; +} +.analytics .widget-item .content.sales-break-even .block.to-date { + background-color: #f0f0f0; color: #5B6667; - text-align: center; } -.analytics .widget-item .content.accounts-live-balance .headers { - text-align: center; +.analytics .widget-item .content.sales-break-even .block.to-breakeven { + margin-top: 10px; + background-color: #192831; + color: #1de9b6; } -.analytics .widget-item .content.accounts-live-balance .spacer { - min-height: 30px; +.analytics .widget-item .content.sales-break-even .block.to-breakeven .title { + border-bottom: solid 1px #2a4453; } -.analytics .widget-item .content.accounts-live-balance .price { - font-weight: 900; - font-size: 22px; +.analytics .widget-item .content.sales-break-even .block.to-breakeven .define-text { + font-weight: 300; + font-size: 16px; color: #5B6667; text-align: center; - margin-top: 0px; -} -.analytics .widget-item .content.accounts-live-balance .negative2 { - font-size: 14px; -} -.analytics .widget-item .content.accounts-payable-receivable h3 { - text-align: center; -} -.analytics .widget-item .content.accounts-payable-receivable .legend { - font-weight: bold; + padding-top: 5px; + color: #1de9b6; } -.analytics .widget-item .content.accounts-payable-receivable .payable { - margin-top: 15px; +.analytics .widget-item .content.sales-break-even .block.to-breakeven .price { + color: #1de9b6; } -.analytics .widget-item .content.accounts-payable-receivable .price { - font-weight: 900; - font-size: 22px; - color: #5B6667; +.analytics .widget-item .content.sales-break-even .block .title { + font-size: 13px; text-align: center; - margin-top: 0px; + font-variant: small-caps; + border-bottom: solid 1px #e6edee; + font-weight: 300; } -.analytics .widget-item .content.accounts-profit-and-loss { +.analytics .widget-item .content.sales-comparison { min-height: 565px; } @media (min-width: 992px) { - .analytics .widget-item .content.accounts-profit-and-loss { + .analytics .widget-item .content.sales-comparison { height: 565px; } - .analytics .widget-item .content.accounts-profit-and-loss .chart-container { + .analytics .widget-item .content.sales-comparison .chart-container { max-width: 585px; max-height: 440px; margin: auto; } } -.analytics .widget-item .content.accounts-profit-and-loss .edit { +.analytics .widget-item .content.sales-comparison .edit { max-height: 545px; } -.analytics .widget-item .content.accounts-profit-and-loss .edit .widget-lines-container { +.analytics .widget-item .content.sales-comparison .edit .widget-lines-container { overflow-y: hidden; overflow-x: hidden; } -.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container { +.analytics .widget-item .content.sales-comparison .widget-lines-container { max-height: 540px; } -.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line { +.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line { cursor: pointer; border: solid 1px white; } -.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line .selection-tag { +.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line .selection-tag { display: block; right: 0px; margin-top: -6px; @@ -11059,170 +11102,102 @@ chart-threshold .attach-panel .actions button.loading { height: 29px; position: absolute; } -.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line:hover { +.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line:hover { background-color: #e6e0fb; } -.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line.no-select { +.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line.no-select { cursor: auto; } -.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line.no-select:hover { +.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line.no-select:hover { color: #626d6d; } -.analytics .widget-item .content.accounts-profit-and-loss .right-panel .widget-lines-container { +.analytics .widget-item .content.sales-comparison .right-panel .widget-lines-container { overflow-y: auto; overflow-x: hidden; max-height: 235px; } -.analytics .widget-item .content.accounts-profit-and-loss .no-element { +.analytics .widget-item .content.sales-comparison .no-element { font-weight: 300; font-size: 16px; color: #5B6667; text-align: center; } -.analytics .widget-item .content.accounts-profit-and-loss .row.lines-group.profit { - border-top: solid 1px; - border-bottom: double; -} -.analytics .widget-item .content.accounts-profit-and-loss .right-panel .widget-lines-container { - max-height: 215px; -} -.analytics .widget-item .content.accounts-profit-and-loss .row.widget-line.header > [class*='col-'] { - position: static; -} -.analytics .widget-item .content.accounts-ratios .left-panel { - max-height: 230px; - overflow-y: auto; -} -.analytics .widget-item .content.accounts-ratios .left-panel .separator { - border-bottom: solid 1px #5B6667; - width: 75%; -} -.analytics .widget-item .content.accounts-ratios .left-panel .member { - padding-top: 20px; - padding-bottom: 20px; -} -.analytics .widget-item .content.accounts-ratios .left-panel .member .price { - margin-top: 0px; - font-size: 18px; -} -.analytics .widget-item .content.accounts-ratios .left-panel button { - outline: none; -} -.analytics .widget-item .content.accounts-ratios .left-panel.simulation .member { - padding-top: 5px; -} -.analytics .widget-item .content.accounts-ratios .left-panel.simulation .member .legend { - display: none; +.analytics .widget-item .content.sales-comparison .widget-lines-container { + max-height: 530px; } -.analytics .widget-item .content.accounts-ratios .left-panel.simulation .member .price { - text-align: right; +.analytics .widget-item .content.sales-comparison .right-panel .widget-lines-container { + max-height: 250px; } -.analytics .widget-item .content.accounts-ratios .left-panel.simulation .separator { - width: 100%; +.analytics .widget-item .content.sales-comparison .currency-conversions img { + margin-top: -2px; } -.analytics .widget-item .content.hr-employee-details { +.analytics .widget-item .content.sales-customer-details { font-size: 12px; } -.analytics .widget-item .content.hr-employee-details .details-container { +.analytics .widget-item .content.sales-customer-details .loader { + font-size: 14px; +} +.analytics .widget-item .content.sales-customer-details .details-container { padding: 0px; - max-height: none; overflow-y: auto; overflow-x: hidden; } @media (min-width: 992px) { - .analytics .widget-item .content.hr-employee-details .details-container { - max-height: 200px; + .analytics .widget-item .content.sales-customer-details .details-container { + max-height: 194px; } } @media (min-width: 992px) { - .analytics .widget-item .content.hr-employee-details .right-panel .details-container { - max-height: 220px; + .analytics .widget-item .content.sales-customer-details .right-panel .details-container { + max-height: 230px; } } -.analytics .widget-item .content.hr-employee-details .right-panel .legend { +.analytics .widget-item .content.sales-customer-details .right-panel .legend { margin-bottom: 5px; } -.analytics .widget-item .content.hr-employee-details .title { +.analytics .widget-item .content.sales-customer-details .row.title { text-align: center; margin-bottom: 10px; font-size: 14px; } -.analytics .widget-item .content.hr-employees-list .legend { - margin-bottom: 9px; -} -.analytics .widget-item .content.hr-employees-list .widget-lines-container { - text-align: center; -} -.analytics .widget-item .content.hr-employees-list .widget-lines-container .widget-line:nth-child(even) { - background-color: #f0f0f0; -} -.analytics .widget-item .content.hr-employees-list .widget-lines-container .widget-line:nth-child(odd) { - background-color: white; -} -.analytics .widget-item .content.hr-employees-list .edit .widget-lines-container { - text-align: left; -} -.analytics .widget-item .content.hr-leaves-balance .employee-name { - text-align: center; -} -.analytics .widget-item .content.hr-leaves-balance .balance { - font-weight: 900; - font-size: 22px; - color: #5B6667; - text-align: center; - margin-top: 0px; -} -.analytics .widget-item .content.hr-leaves-balance h3 { - margin-top: 33px; - text-align: center; -} -.analytics .widget-item .content.hr-leaves-schedule .fc-button { - height: 22px; - font-size: 12px; - color: #977bf0; - background: white; - outline: none; -} -.analytics .widget-item .content.hr-leaves-schedule .fc-button:hover { - color: white; - background: #977bf0; +.analytics .widget-item .content.sales-customer-details .currency-conversions { + float: left; + margin-right: 3px; } -.analytics .widget-item .content.hr-leaves-schedule .fc-toolbar { - margin-bottom: 5px; +.analytics .widget-item .content.sales-cycle .chart-container { + max-width: 410px; } -.analytics .widget-item .content.hr-leaves-schedule .fc-day-grid, -.analytics .widget-item .content.hr-leaves-schedule .fc-widget-header { - font-size: 12px; - color: #5B6667; +.analytics .widget-item .content.sales-cycle .legend { + max-height: 28px; } -.analytics .widget-item .content.hr-payroll-summary { +.analytics .widget-item .content.sales-forecast { min-height: 565px; } @media (min-width: 992px) { - .analytics .widget-item .content.hr-payroll-summary { + .analytics .widget-item .content.sales-forecast { height: 565px; } - .analytics .widget-item .content.hr-payroll-summary .chart-container { + .analytics .widget-item .content.sales-forecast .chart-container { max-width: 585px; max-height: 440px; margin: auto; } } -.analytics .widget-item .content.hr-payroll-summary .edit { +.analytics .widget-item .content.sales-forecast .edit { max-height: 545px; } -.analytics .widget-item .content.hr-payroll-summary .edit .widget-lines-container { +.analytics .widget-item .content.sales-forecast .edit .widget-lines-container { overflow-y: hidden; overflow-x: hidden; } -.analytics .widget-item .content.hr-payroll-summary .widget-lines-container { - max-height: 540px; +.analytics .widget-item .content.sales-forecast .widget-lines-container { + max-height: 275px; } -.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line { +.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main { cursor: pointer; border: solid 1px white; } -.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line .selection-tag { +.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main .selection-tag { display: block; right: 0px; margin-top: -6px; @@ -11230,148 +11205,240 @@ chart-threshold .attach-panel .actions button.loading { height: 29px; position: absolute; } -.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line:hover { +.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main:hover { background-color: #e6e0fb; } -.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line.no-select { +.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main.no-select { cursor: auto; } -.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line.no-select:hover { +.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main.no-select:hover { color: #626d6d; } -.analytics .widget-item .content.hr-payroll-summary .right-panel .widget-lines-container { - overflow-y: auto; - overflow-x: hidden; - max-height: 235px; -} -.analytics .widget-item .content.hr-payroll-summary .no-element { - font-weight: 300; - font-size: 16px; +.analytics .widget-item .content.sales-growth .price { + font-weight: 900; + font-size: 22px; color: #5B6667; text-align: center; + margin-top: 0px; } -.analytics .widget-item .content.hr-payroll-summary .right-panel .widget-lines-container { - max-height: 145px; +.analytics .widget-item .content.sales-growth .legend { + max-height: 49px; + font-size: 14px; + text-overflow: ellipsis; + white-space: nowrap; } -.analytics .widget-item .content.hr-salaries-summary h3.left { - text-align: center; +.analytics .widget-item .content.sales-leads-funnel { + min-height: 565px; } @media (min-width: 992px) { - .analytics .widget-item .content.hr-salaries-summary h3.left { - margin-top: 69px; + .analytics .widget-item .content.sales-leads-funnel { + height: 565px; + } + .analytics .widget-item .content.sales-leads-funnel .chart-container { + max-width: 585px; + max-height: 440px; + margin: auto; } } -.analytics .widget-item .content.hr-salaries-summary h3.reduced-left { - text-align: center; +.analytics .widget-item .content.sales-leads-funnel .edit { + max-height: 545px; } -@media (min-width: 992px) { - .analytics .widget-item .content.hr-salaries-summary h3.reduced-left { - margin-top: 10px; - } +.analytics .widget-item .content.sales-leads-funnel .edit .widget-lines-container { + overflow-y: hidden; + overflow-x: hidden; } -.analytics .widget-item .content.hr-salaries-summary h3.right { - margin-bottom: 10px; - text-align: center; +.analytics .widget-item .content.sales-leads-funnel .funnel-container { + width: 95%; + margin: auto; + margin-top: 15px; + padding-right: 10px; + max-height: 505px; + overflow: auto; } -.analytics .widget-item .content.hr-salaries-summary .price { - margin-top: 0; +.analytics .widget-item .content.sales-leads-funnel .right-panel .widget-lines-container { + max-height: 545px; + margin-right: 10px; } -.analytics .widget-item .content.hr-salaries-summary .widget-lines-container { - max-height: 75px; +.analytics .widget-item .content.sales-leads-funnel .right-panel .widget-lines-container .widget-line { + cursor: default; } -.analytics .widget-item .content.hr-salaries-summary .widget-lines-container .widget-line { - font-size: 11px; +.analytics .widget-item .content.sales-leads-list .widget-lines-container { + max-height: 230px; } -@media (min-width: 480px) and (max-width: 991px) { - .analytics .widget-item .content.hr-salaries-summary .right-panel .chart-container { - max-width: 320px; +.analytics .widget-item .content.sales-leads-list .widget-lines-container .widget-line:nth-child(even) { + background-color: #f0f0f0; +} +.analytics .widget-item .content.sales-leads-list .widget-lines-container .widget-line:nth-child(odd) { + background-color: white; +} +.analytics .widget-item .content.sales-leads-list .widget-lines-container .widget-line.header { + background-color: white; +} +.analytics .widget-item .content.sales-leads-list .widget-lines-container { + overflow-y: scroll; + overflow-x: hidden; +} +.analytics .widget-item .content.sales-list .widget-lines-container { + max-height: 230px; +} +.analytics .widget-item .content.sales-list .widget-lines-container .widget-line:nth-child(even) { + background-color: #f0f0f0; +} +.analytics .widget-item .content.sales-list .widget-lines-container .widget-line:nth-child(odd) { + background-color: white; +} +.analytics .widget-item .content.sales-list .widget-lines-container .widget-line.header { + background-color: white; +} +.analytics .widget-item .content.sales-list .widget-lines-container { + overflow-y: scroll; + overflow-x: hidden; + max-height: 170px; +} +.analytics .widget-item .content.sales-list .widget-lines-container.no-scroll { + overflow: visible; +} +.analytics .widget-item .content.sales-list .selector { + margin-bottom: 4px; +} +.analytics .widget-item .content.sales-list .currency-conversions img { + margin-top: -2px; +} +.analytics .widget-item .content.sales-net-sales .value-container, +.analytics .widget-item .content.sales-net-sales .operator { + line-height: 85px; +} +.analytics .widget-item .content.sales-net-sales .value-container .title { + line-height: 20px; + font-size: 1.2em; + padding: 10px 0px; +} +.analytics .widget-item .content.sales-net-sales .value-container .value-box { + font-size: 1.3em; + border-radius: 10px; + border-top: solid 1px #C4CACA; + border-bottom: solid 1px #C4CACA; + white-space: nowrap; +} +.analytics .widget-item .content.sales-net-sales .operator { + padding-top: 38px; + font-size: 1.3em; +} +@media (min-width: 992px) { + .analytics .widget-item .content.sales-net-sales .values { + margin-top: 25px; } } -.analytics .widget-item .content.hr-superannuation-accruals h3 { - margin-top: 63px; - text-align: center; +.analytics .widget-item .content.sales-new-vs-existing-customers .selector .selector-wrap { + display: inline-block; + margin: 0 5px; } -.analytics .widget-item .content.hr-superannuation-accruals .legend { - margin-top: 23px; +.analytics .widget-item .content.sales-new-vs-existing-customers .chart-container { + margin-top: 15px; } -.analytics .widget-item .content.hr-superannuation-accruals .currency { - font-size: 14px; +.analytics .widget-item .content.sales-new-vs-existing-customers .legend { + margin-top: 5px; + font-weight: bold; + max-height: 77px !important; } -.analytics .widget-item .content.hr-superannuation-accruals .price { - font-weight: 900; - font-size: 22px; - color: #5B6667; - text-align: center; - margin-top: 0px; +.analytics .widget-item .content.sales-new-vs-existing-customers .legend .row { + margin: 0px -5px; } -.analytics .widget-item .content.hr-timesheets .currency { +.analytics .widget-item .content.sales-new-vs-existing-customers .legend .row > div { + padding: 0px 5px; +} +.analytics .widget-item .content.sales-new-vs-existing-customers .legend .total { + color: #5B6667; font-size: 14px; } -.analytics .widget-item .content.hr-timesheets .widget-lines-container { - max-height: 210px; +.analytics .widget-item .content.sales-number-of-leads .stats { + margin-top: 35px; + font-size: 18px; +} +.analytics .widget-item .content.sales-number-of-leads .stats .stat { + margin: 15px 0px 10px 0px; + border-bottom: solid 1px #e6edee; +} +.analytics .widget-item .content.sales-number-of-leads .stats .stat span.title { + font-weight: bold; } -.analytics .widget-item .content.hr-workforce-summary h3.left { - text-align: center; +.analytics .widget-item .content.sales-number-of-leads .stats .stat span.nominal { + float: right; + text-align: right; + font-weight: 300; } -@media (min-width: 992px) { - .analytics .widget-item .content.hr-workforce-summary h3.left { - margin-top: 69px; - } +.analytics .widget-item .content.sales-number-of-leads .stats .stat span.variation { + float: right; + width: 50px; + text-align: right; + font-style: italic; + font-size: 14px; + font-weight: 300; + margin-top: 2px; } -.analytics .widget-item .content.hr-workforce-summary h3.reduced-left { - text-align: center; +.analytics .widget-item .content.sales-opportunities-funnel { + min-height: 565px; } @media (min-width: 992px) { - .analytics .widget-item .content.hr-workforce-summary h3.reduced-left { - margin-top: 10px; + .analytics .widget-item .content.sales-opportunities-funnel { + height: 565px; + } + .analytics .widget-item .content.sales-opportunities-funnel .chart-container { + max-width: 585px; + max-height: 440px; + margin: auto; } } -.analytics .widget-item .content.hr-workforce-summary h3.right { - margin-bottom: 10px; - text-align: center; +.analytics .widget-item .content.sales-opportunities-funnel .edit { + max-height: 545px; } -.analytics .widget-item .content.hr-workforce-summary .price { - margin-top: 0; +.analytics .widget-item .content.sales-opportunities-funnel .edit .widget-lines-container { + overflow-y: hidden; + overflow-x: hidden; } -.analytics .widget-item .content.hr-workforce-summary .widget-lines-container { - max-height: 75px; +.analytics .widget-item .content.sales-opportunities-funnel .funnel-container { + width: 95%; + margin: auto; + margin-top: 15px; + padding-right: 10px; + max-height: 505px; + overflow: auto; } -.analytics .widget-item .content.hr-workforce-summary .widget-lines-container .widget-line { - font-size: 11px; +.analytics .widget-item .content.sales-opportunities-funnel .right-panel .widget-lines-container { + max-height: 545px; + margin-right: 10px; } -@media (min-width: 480px) and (max-width: 991px) { - .analytics .widget-item .content.hr-workforce-summary .right-panel .chart-container { - max-width: 320px; - } +.analytics .widget-item .content.sales-opportunities-funnel .right-panel .widget-lines-container .widget-line { + cursor: default; } -.analytics .widget-item .content.invoices-aged-payables-receivables { +.analytics .widget-item .content.sales-performance { min-height: 565px; } @media (min-width: 992px) { - .analytics .widget-item .content.invoices-aged-payables-receivables { + .analytics .widget-item .content.sales-performance { height: 565px; } - .analytics .widget-item .content.invoices-aged-payables-receivables .chart-container { + .analytics .widget-item .content.sales-performance .chart-container { max-width: 585px; max-height: 440px; margin: auto; } } -.analytics .widget-item .content.invoices-aged-payables-receivables .edit { +.analytics .widget-item .content.sales-performance .edit { max-height: 545px; } -.analytics .widget-item .content.invoices-aged-payables-receivables .edit .widget-lines-container { +.analytics .widget-item .content.sales-performance .edit .widget-lines-container { overflow-y: hidden; overflow-x: hidden; } -.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container { +.analytics .widget-item .content.sales-performance .widget-lines-container { max-height: 540px; } -.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line { +.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line { cursor: pointer; border: solid 1px white; } -.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line .selection-tag { +.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line .selection-tag { display: block; right: 0px; margin-top: -6px; @@ -11379,666 +11446,604 @@ chart-threshold .attach-panel .actions button.loading { height: 29px; position: absolute; } -.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line:hover { +.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line:hover { background-color: #e6e0fb; } -.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line.no-select { +.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line.no-select { cursor: auto; } -.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line.no-select:hover { +.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line.no-select:hover { color: #626d6d; } -.analytics .widget-item .content.invoices-aged-payables-receivables .right-panel .widget-lines-container { +.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container { overflow-y: auto; overflow-x: hidden; max-height: 235px; } -.analytics .widget-item .content.invoices-aged-payables-receivables .no-element { +.analytics .widget-item .content.sales-performance .no-element { font-weight: 300; font-size: 16px; color: #5B6667; text-align: center; } -.analytics .widget-item .content.invoices-aged-payables-receivables .right-panel .widget-lines-container { +.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container { max-height: 215px; } -.analytics .widget-item .content.invoices-aged-payables-receivables .row.astericks-info { - margin-top: 15px; -} -.analytics .widget-item .content.invoices-aged-payables-receivables .currency-conversions { - float: right; - margin-left: 3px; -} -.analytics .widget-item .content.invoices-list .widget-lines-container { - max-height: 230px; -} -.analytics .widget-item .content.invoices-list .widget-lines-container .widget-line:nth-child(even) { - background-color: #f0f0f0; -} -.analytics .widget-item .content.invoices-list .widget-lines-container .widget-line:nth-child(odd) { - background-color: white; -} -.analytics .widget-item .content.invoices-list .widget-lines-container .widget-line.header { - background-color: white; -} -.analytics .widget-item .content.invoices-list .currency-conversions { - float: right; - margin-right: 3px; - margin-top: -2px; -} -.analytics .widget-item .content.invoices-list .fa.fa-info-circle { - float: right; - font-size: 15px; -} -.analytics .widget-item .content.invoices-list .right-column { - padding-left: 0px; - padding-right: 0px; -} -.analytics .widget-item .content.invoices-summary .chart-container { - max-width: 410px; +.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header { + cursor: pointer; + border: solid 1px white; } -.analytics .widget-item .content.invoices-summary .legend { - max-height: 28px; +.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header .selection-tag { + display: block; + right: 0px; + margin-top: -6px; + width: 10px; + height: 29px; + position: absolute; } -.analytics .widget-item .content.sales-aged { - min-height: 565px; +.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header:hover { + background-color: #e6e0fb; } -@media (min-width: 992px) { - .analytics .widget-item .content.sales-aged { - height: 565px; - } - .analytics .widget-item .content.sales-aged .chart-container { - max-width: 585px; - max-height: 440px; - margin: auto; - } +.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header.no-select { + cursor: auto; } -.analytics .widget-item .content.sales-aged .edit { - max-height: 545px; +.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header.no-select:hover { + color: #626d6d; } -.analytics .widget-item .content.sales-aged .edit .widget-lines-container { - overflow-y: hidden; - overflow-x: hidden; +.analytics .widget-item .content.sales-segmented-turnover h3.right { + margin-top: 55px; + text-align: center; } -.analytics .widget-item .content.sales-aged .widget-lines-container { - max-height: 238px; +.analytics .widget-item .content.sales-segmented-turnover .selector { + margin-bottom: 10px; } -.analytics .widget-item .content.sales-break-even .price { +.analytics .widget-item .content.sales-segmented-turnover .analysis { font-weight: 900; font-size: 22px; color: #5B6667; text-align: center; margin-top: 0px; } -.analytics .widget-item .content.sales-break-even .block { - margin: 5px; - padding: 0px 10px 5px 10px; - text-align: left; - box-shadow: 0px 7px 10px -7px #17262d; - font-size: 12px; -} -.analytics .widget-item .content.sales-break-even .block form.editable-wrap .editable-controls input { - margin-top: 5px; - width: 100px; -} -.analytics .widget-item .content.sales-break-even .block.to-date { - background-color: #f0f0f0; - color: #5B6667; -} -.analytics .widget-item .content.sales-break-even .block.to-breakeven { - margin-top: 10px; - background-color: #192831; - color: #1de9b6; -} -.analytics .widget-item .content.sales-break-even .block.to-breakeven .title { - border-bottom: solid 1px #2a4453; -} -.analytics .widget-item .content.sales-break-even .block.to-breakeven .define-text { - font-weight: 300; - font-size: 16px; - color: #5B6667; - text-align: center; - padding-top: 5px; - color: #1de9b6; +.analytics .widget-item .content.sales-segmented-turnover .widget-lines-container { + max-height: 75px; } -.analytics .widget-item .content.sales-break-even .block.to-breakeven .price { - color: #1de9b6; +.analytics .widget-item .content.sales-segmented-turnover .widget-lines-container .widget-line { + font-size: 11px; } -.analytics .widget-item .content.sales-break-even .block .title { - font-size: 13px; +.analytics .widget-item .content.sales-segmented-turnover .right-panel h3 { + margin: 15px 10px 5px 10px; text-align: center; - font-variant: small-caps; - border-bottom: solid 1px #e6edee; - font-weight: 300; -} -.analytics .widget-item .content.sales-comparison { - min-height: 565px; -} -@media (min-width: 992px) { - .analytics .widget-item .content.sales-comparison { - height: 565px; - } - .analytics .widget-item .content.sales-comparison .chart-container { - max-width: 585px; - max-height: 440px; - margin: auto; - } -} -.analytics .widget-item .content.sales-comparison .edit { - max-height: 545px; -} -.analytics .widget-item .content.sales-comparison .edit .widget-lines-container { - overflow-y: hidden; - overflow-x: hidden; -} -.analytics .widget-item .content.sales-comparison .widget-lines-container { - max-height: 540px; -} -.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line { - cursor: pointer; - border: solid 1px white; } -.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line .selection-tag { - display: block; - right: 0px; - margin-top: -6px; - width: 10px; - height: 29px; - position: absolute; +.analytics .widget-item .content.sales-segmented-turnover .right-panel .fa.fa-info-circle { + float: left; } -.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line:hover { - background-color: #e6e0fb; +.analytics .widget-item .content.sales-summary .chart-container { + max-width: 410px; } -.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line.no-select { - cursor: auto; +.analytics .widget-item .content.sales-summary .legend { + max-height: 28px; } -.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line.no-select:hover { - color: #626d6d; +.analytics .widget-item .content.sales-summary .selector { + margin-bottom: 5px; } -.analytics .widget-item .content.sales-comparison .right-panel .widget-lines-container { - overflow-y: auto; - overflow-x: hidden; - max-height: 235px; +.analytics .widget-item .content.sales-top-customers .selector { + border-bottom: dashed 1px #E6E6E6; + padding-bottom: 3px; } -.analytics .widget-item .content.sales-comparison .no-element { - font-weight: 300; - font-size: 16px; - color: #5B6667; - text-align: center; +.analytics .widget-item .content.sales-top-customers .selector a { + font-weight: normal; } -.analytics .widget-item .content.sales-comparison .widget-lines-container { - max-height: 530px; +.analytics .widget-item .content.sales-top-customers .selector .param-selector { + display: inline-block; } -.analytics .widget-item .content.sales-comparison .right-panel .widget-lines-container { - max-height: 250px; +.analytics .widget-item .content.sales-top-customers .widget-lines-container { + max-height: 235px; } -.analytics .widget-item .content.sales-comparison .currency-conversions img { - margin-top: -2px; +.analytics .widget-item .content.sales-top-customers .widget-lines-container .widget-line.sub-line { + background-color: #f0f0f0; } -.analytics .widget-item .content.sales-customer-details { - font-size: 12px; +.analytics .widget-item .content.sales-top-customers .widget-lines-container .row > [class*='col-'] { + position: static; } -.analytics .widget-item .content.sales-customer-details .loader { - font-size: 14px; +.analytics .widget-item .content.sales-top-customers .currency-conversions img { + margin-top: -2px; } -.analytics .widget-item .content.sales-customer-details .details-container { - padding: 0px; +.analytics .widget-item .content.sales-top-opportunities .opps-container { + max-height: 195px; + margin-top: 10px; + padding-right: 10px; overflow-y: auto; overflow-x: hidden; } -@media (min-width: 992px) { - .analytics .widget-item .content.sales-customer-details .details-container { - max-height: 194px; - } -} -@media (min-width: 992px) { - .analytics .widget-item .content.sales-customer-details .right-panel .details-container { - max-height: 230px; - } -} -.analytics .widget-item .content.sales-customer-details .right-panel .legend { - margin-bottom: 5px; +.analytics .widget-item .content.sales-top-opportunities .opps-container .tile { + height: 40px; + font-size: 13px; + font-weight: 300; } -.analytics .widget-item .content.sales-customer-details .row.title { +.analytics .widget-item .content.sales-top-opportunities .opps-container .tile .colored-area { + width: 10%; text-align: center; - margin-bottom: 10px; - font-size: 14px; + font-size: 20px; } -.analytics .widget-item .content.sales-customer-details .currency-conversions { - float: left; - margin-right: 3px; +.analytics .widget-item .content.sales-top-opportunities .opps-container .tile .main-text { + color: #5B6667; + padding: 3px 0px 0px 10px; } -.analytics .widget-item .content.sales-cycle .chart-container { - max-width: 410px; +.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.first { + height: 55px; + font-size: 15px; + font-weight: bold; } -.analytics .widget-item .content.sales-cycle .legend { - max-height: 28px; +.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.first .colored-area { + font-size: 26px; + padding-top: 10px; + background-color: #ff6e41; } -.analytics .widget-item .content.sales-forecast { - min-height: 565px; +.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.first .main-text { + padding-top: 8px; } -@media (min-width: 992px) { - .analytics .widget-item .content.sales-forecast { - height: 565px; - } - .analytics .widget-item .content.sales-forecast .chart-container { - max-width: 585px; - max-height: 440px; - margin: auto; - } +.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.second { + height: 55px; + font-size: 15px; + font-weight: 500; } -.analytics .widget-item .content.sales-forecast .edit { - max-height: 545px; +.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.second .colored-area { + font-size: 26px; + padding-top: 10px; + background-color: #1de9b6; } -.analytics .widget-item .content.sales-forecast .edit .widget-lines-container { - overflow-y: hidden; - overflow-x: hidden; +.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.second .main-text { + padding-top: 8px; } -.analytics .widget-item .content.sales-forecast .widget-lines-container { - max-height: 275px; +.analytics .widget-item .content .settings.select-account { + padding: 0px 5px; } -.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main { - cursor: pointer; - border: solid 1px white; +.analytics .settings.accounting-behaviour .btn.btn-primary { + background-color: #bba9f5; + border: solid 1px #977bf0; } -.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main .selection-tag { - display: block; - right: 0px; - margin-top: -6px; - width: 10px; - height: 29px; - position: absolute; +.analytics .settings.accounting-behaviour .btn.btn-primary.focus, +.analytics .settings.accounting-behaviour .btn.btn-primary.active { + background-color: #977bf0; } -.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main:hover { - background-color: #e6e0fb; +.analytics .settings.attach-kpis .attach-kpi { + padding: 8px 5px; } -.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main.no-select { - cursor: auto; +.analytics .settings.attach-kpis .attach-kpi form .row { + padding-bottom: 5px; } -.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main.no-select:hover { - color: #626d6d; +.analytics .settings.attach-kpis .attach-kpi .attach-kpi-form { + background-color: white; + border: 1px solid #ddd; + padding: 5px; } -.analytics .widget-item .content.sales-growth .price { - font-weight: 900; - font-size: 22px; - color: #5B6667; - text-align: center; - margin-top: 0px; +.analytics .settings.attach-kpis .attach-kpi form .row.kpi-description { + padding: 10px 2px; } -.analytics .widget-item .content.sales-growth .legend { - max-height: 49px; - font-size: 14px; - text-overflow: ellipsis; - white-space: nowrap; +.analytics .settings.attach-kpis .attach-kpi form .row.kpi-description span { + display: block; + font-weight: bold; + font-size: 13px; } -.analytics .widget-item .content.sales-leads-funnel { - min-height: 565px; +.analytics .settings.attach-kpis .attach-kpi form.attach-kpi-form input.attach-target { + background-color: white; + height: inherit; } -@media (min-width: 992px) { - .analytics .widget-item .content.sales-leads-funnel { - height: 565px; - } - .analytics .widget-item .content.sales-leads-funnel .chart-container { - max-width: 585px; - max-height: 440px; - margin: auto; - } +.analytics .settings.attach-kpis .attach-kpi .error-messages { + color: #e01f74; + width: 120px; } -.analytics .widget-item .content.sales-leads-funnel .edit { - max-height: 545px; +.analytics .settings.attach-kpis .attached-kpis { + padding: 5px; } -.analytics .widget-item .content.sales-leads-funnel .edit .widget-lines-container { - overflow-y: hidden; - overflow-x: hidden; +.analytics .settings.attach-kpis .list-group-item.attached-kpi { + padding: 5px 10px; } -.analytics .widget-item .content.sales-leads-funnel .funnel-container { - width: 95%; - margin: auto; - margin-top: 15px; - padding-right: 10px; - max-height: 505px; - overflow: auto; +.analytics .settings.attach-kpis .list-group-item.attached-kpi .attached-kpi-name { + overflow: hidden; + width: 75%; + display: inline-block; + white-space: nowrap; + text-overflow: ellipsis; + margin-top: 3px; + font-size: 13px; + font-weight: bold; } -.analytics .widget-item .content.sales-leads-funnel .right-panel .widget-lines-container { - max-height: 545px; - margin-right: 10px; +.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions { + padding-top: 2px; } -.analytics .widget-item .content.sales-leads-funnel .right-panel .widget-lines-container .widget-line { - cursor: default; +.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .alerts-config { + display: inline-block; + text-align: left; + padding-left: 4px; + height: 20px; + border-radius: 40px; + width: 21px; + color: #358fdc; + background-color: white; + border: solid 1px #358fdc; } -.analytics .widget-item .content.sales-leads-list .widget-lines-container { - max-height: 230px; +.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .alerts-config:hover { + cursor: pointer; } -.analytics .widget-item .content.sales-leads-list .widget-lines-container .widget-line:nth-child(even) { - background-color: #f0f0f0; +.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .edit-attached-kpi { + display: inline-block; } -.analytics .widget-item .content.sales-leads-list .widget-lines-container .widget-line:nth-child(odd) { +.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .edit-attached-kpi i { + border-radius: 10px; + width: 21px; + color: #358fdc; background-color: white; + height: 20px; + padding: 3px 5px 5px 5px; + border: solid 1px #358fdc; } -.analytics .widget-item .content.sales-leads-list .widget-lines-container .widget-line.header { +.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .edit-attached-kpi i:hover { + cursor: pointer; +} +.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .remove-attached-kpi { + display: inline-block; +} +.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .remove-attached-kpi i { + border-radius: 10px; + width: 21px; + color: #e01f74; background-color: white; + height: 20px; + padding: 3px 5px 5px 5px; + border: solid 1px #e01f74; } -.analytics .widget-item .content.sales-leads-list .widget-lines-container { - overflow-y: scroll; - overflow-x: hidden; +.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .remove-attached-kpi i:hover { + cursor: pointer; } -.analytics .widget-item .content.sales-list .widget-lines-container { - max-height: 230px; +.analytics .widget-item .content .settings.select-account { + padding: 0px 5px; } -.analytics .widget-item .content.sales-list .widget-lines-container .widget-line:nth-child(even) { - background-color: #f0f0f0; +.analytics .widget-item .content .settings.chart-filters .row { + margin: 0px; } -.analytics .widget-item .content.sales-list .widget-lines-container .widget-line:nth-child(odd) { - background-color: white; +.analytics .widget-item .content .settings.chart-filters input[type="radio"] { + margin: 0; + margin-right: 3px; + padding: 0; + width: 13px; + height: 13px; + vertical-align: middle; + position: relative; + top: -1px; + outline: none; } -.analytics .widget-item .content.sales-list .widget-lines-container .widget-line.header { - background-color: white; +.analytics .widget-item .content .settings.chart-filters input[type="range"] { + height: auto; + width: 100%; } -.analytics .widget-item .content.sales-list .widget-lines-container { - overflow-y: scroll; - overflow-x: hidden; - max-height: 170px; +.analytics .settings.dates-picker h5 { + display: none; } -.analytics .widget-item .content.sales-list .widget-lines-container.no-scroll { - overflow: visible; +.analytics .settings.dates-picker button.btn.btn-sm { + line-height: 1; } -.analytics .widget-item .content.sales-list .selector { - margin-bottom: 4px; +.analytics .settings.dates-picker button.btn.btn-sm.date-button { + margin: 0px 5px; } -.analytics .widget-item .content.sales-list .currency-conversions img { - margin-top: -2px; +.analytics .settings.dates-picker button.btn.btn-sm.btn-danger { + display: none; } -.analytics .widget-item .content.sales-net-sales .value-container, -.analytics .widget-item .content.sales-net-sales .operator { - line-height: 85px; +.analytics .settings.dates-picker button.btn.btn-sm.btn-info { + border-radius: 3px; } -.analytics .widget-item .content.sales-net-sales .value-container .title { - line-height: 20px; - font-size: 1.2em; - padding: 10px 0px; +.analytics .settings.dates-picker .tooltip-inner { + text-transform: none; } -.analytics .widget-item .content.sales-net-sales .value-container .value-box { - font-size: 1.3em; - border-radius: 10px; - border-top: solid 1px #C4CACA; - border-bottom: solid 1px #C4CACA; - white-space: nowrap; +.analytics .settings.dates-picker .dropdown-menu > li > div > table { + outline: none; } -.analytics .widget-item .content.sales-net-sales .operator { - padding-top: 38px; - font-size: 1.3em; +.analytics .settings.forecast-payroll .widget-lines-container .widget-line { + padding: 5px 10px 5px 18px; } -@media (min-width: 992px) { - .analytics .widget-item .content.sales-net-sales .values { - margin-top: 25px; - } +.analytics .settings.forecast-payroll .widget-lines-container .widget-line:nth-child(even) { + background-color: #f3f4f4; } -.analytics .widget-item .content.sales-new-vs-existing-customers .selector .selector-wrap { - display: inline-block; - margin: 0 5px; +.analytics .settings.forecast-payroll .widget-lines-container .widget-line:nth-child(odd) { + background-color: white; } -.analytics .widget-item .content.sales-new-vs-existing-customers .chart-container { - margin-top: 15px; +.analytics .settings.forecast-payroll .widget-lines-container .widget-line .fa { + float: right; + font-size: 20px; + cursor: pointer; } -.analytics .widget-item .content.sales-new-vs-existing-customers .legend { - margin-top: 5px; - font-weight: bold; - max-height: 77px !important; +.analytics .settings.forecast-payroll .widget-lines-container .widget-line .fa.fa-toggle-on { + color: #977bf0; } -.analytics .widget-item .content.sales-new-vs-existing-customers .legend .row { - margin: 0px -5px; +.analytics .settings.forecast-payroll .widget-lines-container .widget-line .fa.fa-toggle-off { + color: #9ba6a7; } -.analytics .widget-item .content.sales-new-vs-existing-customers .legend .row > div { - padding: 0px 5px; +.analytics .widget-item .content .settings.hist-mode-choser { + max-height: 70px; } -.analytics .widget-item .content.sales-new-vs-existing-customers .legend .total { - color: #5B6667; - font-size: 14px; +.analytics .widget-item .content .settings.hist-mode-choser [common-time-period-info] { + padding-bottom: 8px; } -.analytics .widget-item .content.sales-number-of-leads .stats { - margin-top: 35px; - font-size: 18px; +.analytics .widget-item .content .settings.hist-mode-choser .options { + width: 150px; + margin: auto; + padding-bottom: 8px; + border-bottom: solid 1px #e6e6e6; + font-weight: 500; + font-size: 12px; + color: #c4caca; } -.analytics .widget-item .content.sales-number-of-leads .stats .stat { - margin: 15px 0px 10px 0px; - border-bottom: solid 1px #e6edee; +.analytics .widget-item .content .settings.hist-mode-choser .options a { + font-weight: 500; + font-size: 12px; + color: #c4caca; + text-transform: uppercase; } -.analytics .widget-item .content.sales-number-of-leads .stats .stat span.title { - font-weight: bold; +.analytics .widget-item .content .settings.hist-mode-choser .options a.active { + color: #977bf0; } -.analytics .widget-item .content.sales-number-of-leads .stats .stat span.nominal { - float: right; - text-align: right; - font-weight: 300; +.analytics .widget-item .content .settings.hist-mode-choser .arrow-container { + width: 28px; + height: 28px; + position: relative; + top: -14px; + margin: auto; } -.analytics .widget-item .content.sales-number-of-leads .stats .stat span.variation { - float: right; - width: 50px; - text-align: right; - font-style: italic; - font-size: 14px; - font-weight: 300; - margin-top: 2px; +.analytics .widget-item .content .settings.hist-mode-choser .arrow-container.right { + left: 46px; } -.analytics .widget-item .content.sales-opportunities-funnel { - min-height: 565px; +.analytics .widget-item .content .settings.hist-mode-choser .arrow-container.left { + left: -30px; } -@media (min-width: 992px) { - .analytics .widget-item .content.sales-opportunities-funnel { - height: 565px; - } - .analytics .widget-item .content.sales-opportunities-funnel .chart-container { - max-width: 585px; - max-height: 440px; - margin: auto; - } +.analytics .widget-item .content .settings.hist-mode-choser .arrow-container .arrow-border { + border-top: 14px solid #e6e6e6; + border-left: 14px solid transparent; + border-right: 14px solid transparent; + width: 0px; + height: 0px; } -.analytics .widget-item .content.sales-opportunities-funnel .edit { - max-height: 545px; +.analytics .widget-item .content .settings.hist-mode-choser .arrow-container .arrow { + border-top: 14px solid white; + border-left: 14px solid transparent; + border-right: 14px solid transparent; + position: relative; + top: 12px; + width: 0px; + height: 0px; } -.analytics .widget-item .content.sales-opportunities-funnel .edit .widget-lines-container { - overflow-y: hidden; - overflow-x: hidden; +.analytics .settings.limit-entries { + color: #1E303B; + text-transform: uppercase; + text-align: center; + border-bottom: dashed 1px #E6E6E6; + padding-bottom: 8px; } -.analytics .widget-item .content.sales-opportunities-funnel .funnel-container { - width: 95%; - margin: auto; - margin-top: 15px; - padding-right: 10px; - max-height: 505px; - overflow: auto; +.analytics .settings.limit-entries a.option.badge { + color: white; + background-color: #1E303B; } -.analytics .widget-item .content.sales-opportunities-funnel .right-panel .widget-lines-container { - max-height: 545px; - margin-right: 10px; +.analytics .settings.offsets .offset-value { + font-style: italic; + font-size: 13px; } -.analytics .widget-item .content.sales-opportunities-funnel .right-panel .widget-lines-container .widget-line { - cursor: default; +.analytics .settings.offsets .offset-value .fa-trash-o { + margin-left: 10px; } -.analytics .widget-item .content.sales-performance { - min-height: 565px; +.analytics .settings.offsets .offset-value .fa-trash-o:hover { + color: #e01f74; + cursor: pointer; } -@media (min-width: 992px) { - .analytics .widget-item .content.sales-performance { - height: 565px; - } - .analytics .widget-item .content.sales-performance .chart-container { - max-width: 585px; - max-height: 440px; - margin: auto; - } +.analytics .settings.offsets input { + width: 75%; } -.analytics .widget-item .content.sales-performance .edit { - max-height: 545px; +.analytics .settings.offsets button { + width: 30px; } -.analytics .widget-item .content.sales-performance .edit .widget-lines-container { - overflow-y: hidden; - overflow-x: hidden; +.analytics .settings.organizations .widget-lines-container .widget-line { + padding: 5px 10px 5px 18px; } -.analytics .widget-item .content.sales-performance .widget-lines-container { - max-height: 540px; +.analytics .settings.organizations .widget-lines-container .widget-line:nth-child(even) { + background-color: #f3f4f4; } -.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line { +.analytics .settings.organizations .widget-lines-container .widget-line:nth-child(odd) { + background-color: white; +} +.analytics .settings.organizations .widget-lines-container .widget-line .fa { + float: right; + font-size: 20px; cursor: pointer; - border: solid 1px white; } -.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line .selection-tag { - display: block; - right: 0px; - margin-top: -6px; - width: 10px; - height: 29px; - position: absolute; +.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-toggle-on, +.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-check-circle { + color: #977bf0; } -.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line:hover { - background-color: #e6e0fb; +.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-toggle-off, +.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-circle-thin { + color: #9ba6a7; } -.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line.no-select { - cursor: auto; +.analytics .widget-item .content .settings.param-selector { + display: inline-block; } -.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line.no-select:hover { - color: #626d6d; +.analytics .widget-item .content .settings.param-selector.classic { + width: 100%; } -.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container { +.analytics .widget-item .content .settings.param-selector.classic select { + width: 100%; + height: 25px; + border: 1px solid #ccc; + text-transform: uppercase; + margin: 0px 0px 5px 0px; +} +.analytics .widget-item .content .settings.param-selector a { + font-weight: normal; + color: #977bf0; + white-space: nowrap; +} +.analytics .widget-item .content .settings.param-selector .options-container { + position: absolute; + background-color: white; + text-align: left; + min-width: 150px; + max-height: 200px; + z-index: 999; overflow-y: auto; overflow-x: hidden; - max-height: 235px; -} -.analytics .widget-item .content.sales-performance .no-element { - font-weight: 300; - font-size: 16px; - color: #5B6667; - text-align: center; + box-shadow: #000000 0px 3px 15px -3px; } -.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container { - max-height: 215px; +.analytics .widget-item .content .settings.param-selector .options-container .param-selector-label { + padding: 3px 5px; + font-weight: 500; + font-size: inherit; + color: black; + cursor: text; + overflow: hidden; + white-space: nowrap; + text-overflow: ellipsis; + line-height: 1.9; } -.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header { +.analytics .widget-item .content .settings.param-selector .options-container .param-selector-label:hover { cursor: pointer; - border: solid 1px white; -} -.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header .selection-tag { - display: block; - right: 0px; - margin-top: -6px; - width: 10px; - height: 29px; - position: absolute; -} -.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header:hover { - background-color: #e6e0fb; + background-color: #977bf0; + color: white; } -.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header.no-select { - cursor: auto; +.analytics .widget-item .content .settings.param-selector .options-container::-webkit-scrollbar { + width: 8px; + background-color: #d7e2e4; } -.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header.no-select:hover { - color: #626d6d; +.analytics .widget-item .content .settings.param-selector .options-container::-webkit-scrollbar-thumb { + background-color: #977bf0; } -.analytics .widget-item .content.sales-segmented-turnover h3.right { - margin-top: 55px; - text-align: center; +.analytics .widget-item .content .settings.param-selector .options-container::-webkit-scrollbar-thumb:hover { + background-color: #a992f3; } -.analytics .widget-item .content.sales-segmented-turnover .selector { - margin-bottom: 10px; +.analytics .settings.params-checkboxes { + padding: 2px 0px; } -.analytics .widget-item .content.sales-segmented-turnover .analysis { - font-weight: 900; - font-size: 22px; - color: #5B6667; - text-align: center; - margin-top: 0px; +.analytics .settings.params-checkboxes input { + margin: 0; + height: inherit; } -.analytics .widget-item .content.sales-segmented-turnover .widget-lines-container { - max-height: 75px; +.analytics .settings.params-checkboxes span { + margin-left: 5px; } -.analytics .widget-item .content.sales-segmented-turnover .widget-lines-container .widget-line { - font-size: 11px; +.analytics .settings.params-checkboxes label { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: center; + -ms-flex-pack: center; + justify-content: center; + line-height: 14px; } -.analytics .widget-item .content.sales-segmented-turnover .right-panel h3 { - margin: 15px 10px 5px 10px; - text-align: center; +.analytics .widget-item .content .settings.params-picker { + padding: 0px 10px; } -.analytics .widget-item .content.sales-segmented-turnover .right-panel .fa.fa-info-circle { +.analytics .widget-item .content .settings.params-picker .parameter { + margin: 0px 3px 3px 0px; + padding: 3px 5px; + background-color: #1E303B; + color: white; + border: solid 1px #1E303B; + border-radius: 4px; + cursor: move; + font-weight: bold; + white-space: nowrap; float: left; } -.analytics .widget-item .content.sales-summary .chart-container { - max-width: 410px; +.analytics .widget-item .content .settings.params-picker .parameter input[type="checkbox"] { + margin: 0px -3px 0px 3px; + vertical-align: middle; + height: inherit; + outline: none; + cursor: pointer; } -.analytics .widget-item .content.sales-summary .legend { - max-height: 28px; +.analytics .widget-item .content .settings.params-picker .parameter .badge { + margin-right: 3px; + font-size: 10px; + background-color: #f2f2f2; + color: #1E303B; + padding: 2px 6px; } -.analytics .widget-item .content.sales-summary .selector { - margin-bottom: 5px; +.analytics .widget-item .content .settings.params-picker .parameter.unchecked { + background-color: inherit; + font-weight: normal; + color: inherit; + border-color: #c2c4c4; } -.analytics .widget-item .content.sales-top-customers .selector { - border-bottom: dashed 1px #E6E6E6; - padding-bottom: 3px; +.analytics .widget-item .content .settings.params-picker .parameter.unchecked .badge { + background-color: #c2c4c4; + color: white; } -.analytics .widget-item .content.sales-top-customers .selector a { - font-weight: normal; +.analytics .settings.tag-filter { + padding: 0px 5px; } -.analytics .widget-item .content.sales-top-customers .selector .param-selector { - display: inline-block; +.analytics .settings.tag-filter .btn.btn-default { + height: 32px; + width: 30px; } -.analytics .widget-item .content.sales-top-customers .widget-lines-container { - max-height: 235px; +.analytics .settings.tag-filter .tag-lines-container { + padding: 0px 10px; } -.analytics .widget-item .content.sales-top-customers .widget-lines-container .widget-line.sub-line { - background-color: #f0f0f0; +.analytics .settings.tag-filter .tag-lines-container .tag-line { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: end; + -ms-flex-pack: end; + justify-content: flex-end; } -.analytics .widget-item .content.sales-top-customers .widget-lines-container .row > [class*='col-'] { +.analytics .settings.tag-filter .tag-lines-container .tag-line .tags-col { position: static; } -.analytics .widget-item .content.sales-top-customers .currency-conversions img { - margin-top: -2px; +.analytics .settings.tag-filter .tag-lines-container .tag-line tags-input .tags { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + border-radius: 4px; + border: solid 1px #ccc; } -.analytics .widget-item .content.sales-top-opportunities .opps-container { - max-height: 195px; - margin-top: 10px; - padding-right: 10px; - overflow-y: auto; - overflow-x: hidden; +.analytics .settings.tag-filter .tag-lines-container .tag-line tags-input .tags .tag-item { + background: #79a2bb; + border-radius: 4px; + color: white; } -.analytics .widget-item .content.sales-top-opportunities .opps-container .tile { - height: 40px; - font-size: 13px; - font-weight: 300; +.analytics .settings.tag-filter .tag-lines-container .tag-line .host { + position: static; } -.analytics .widget-item .content.sales-top-opportunities .opps-container .tile .colored-area { - width: 10%; - text-align: center; - font-size: 20px; +.analytics .settings.time-period { + padding: 0px 5px; } -.analytics .widget-item .content.sales-top-opportunities .opps-container .tile .main-text { - color: #5B6667; - padding: 3px 0px 0px 10px; +.analytics .settings.time-period select { + height: 22px; + width: 100%; } -.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.first { - height: 55px; - font-size: 15px; - font-weight: bold; +.analytics .settings.time-period > .row { + margin: 0px -5px 7px -5px; } -.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.first .colored-area { - font-size: 26px; - padding-top: 10px; - background-color: #ff6e41; +.analytics .settings.time-period > .row > div { + padding: 0px 5px; + position: static; } -.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.first .main-text { - padding-top: 8px; +.analytics .settings.time-period > .row .sub-setting { + padding: 5px; } -.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.second { - height: 55px; - font-size: 15px; - font-weight: 500; +.analytics .widget-item .content .settings.width { + float: right; + font-size: 14px; } -.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.second .colored-area { - font-size: 26px; - padding-top: 10px; - background-color: #1de9b6; +.analytics .widget-item .content .settings.width i { + color: silver; + cursor: pointer; } -.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.second .main-text { - padding-top: 8px; +.analytics .widget-item .content .settings.width i.reduce { + margin-right: -10px; +} +.analytics .widget-item .content .settings.width i.expand { + margin-right: -3px; } /* endinject */ -/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["impac-angular.css","../bower_components/bootstrap/less/normalize.less","../bower_components/bootstrap/less/glyphicons.less","../bower_components/bootstrap/less/scaffolding.less","../bower_components/bootstrap/less/mixins/vendor-prefixes.less","../bower_components/bootstrap/less/mixins/tab-focus.less","../bower_components/bootstrap/less/mixins/image.less","../bower_components/bootstrap/less/type.less","../bower_components/bootstrap/less/mixins/text-emphasis.less","../bower_components/bootstrap/less/mixins/background-variant.less","../bower_components/bootstrap/less/mixins/text-overflow.less","../bower_components/bootstrap/less/code.less","../bower_components/bootstrap/less/grid.less","../bower_components/bootstrap/less/mixins/grid.less","../bower_components/bootstrap/less/mixins/grid-framework.less","../bower_components/bootstrap/less/tables.less","../bower_components/bootstrap/less/mixins/table-row.less","../bower_components/bootstrap/less/forms.less","../bower_components/bootstrap/less/mixins/forms.less","../bower_components/bootstrap/less/buttons.less","../bower_components/bootstrap/less/mixins/buttons.less","../bower_components/bootstrap/less/mixins/opacity.less","../bower_components/bootstrap/less/component-animations.less","../bower_components/bootstrap/less/dropdowns.less","../bower_components/bootstrap/less/mixins/nav-divider.less","../bower_components/bootstrap/less/mixins/reset-filter.less","../bower_components/bootstrap/less/button-groups.less","../bower_components/bootstrap/less/mixins/border-radius.less","../bower_components/bootstrap/less/input-groups.less","../bower_components/bootstrap/less/navs.less","../bower_components/bootstrap/less/navbar.less","../bower_components/bootstrap/less/mixins/nav-vertical-align.less","../bower_components/bootstrap/less/utilities.less","../bower_components/bootstrap/less/breadcrumbs.less","../bower_components/bootstrap/less/pagination.less","../bower_components/bootstrap/less/mixins/pagination.less","../bower_components/bootstrap/less/pager.less","../bower_components/bootstrap/less/labels.less","../bower_components/bootstrap/less/mixins/labels.less","../bower_components/bootstrap/less/badges.less","../bower_components/bootstrap/less/jumbotron.less","../bower_components/bootstrap/less/thumbnails.less","../bower_components/bootstrap/less/alerts.less","../bower_components/bootstrap/less/mixins/alerts.less","../bower_components/bootstrap/less/progress-bars.less","../bower_components/bootstrap/less/mixins/gradients.less","../bower_components/bootstrap/less/mixins/progress-bar.less","../bower_components/bootstrap/less/media.less","../bower_components/bootstrap/less/list-group.less","../bower_components/bootstrap/less/mixins/list-group.less","../bower_components/bootstrap/less/panels.less","../bower_components/bootstrap/less/mixins/panels.less","../bower_components/bootstrap/less/responsive-embed.less","../bower_components/bootstrap/less/wells.less","../bower_components/bootstrap/less/close.less","../bower_components/bootstrap/less/modals.less","../bower_components/bootstrap/less/tooltip.less","../bower_components/bootstrap/less/mixins/reset-text.less","../bower_components/bootstrap/less/popovers.less","../bower_components/bootstrap/less/carousel.less","../bower_components/bootstrap/less/mixins/clearfix.less","../bower_components/bootstrap/less/mixins/center-block.less","../bower_components/bootstrap/less/mixins/hide-text.less","../bower_components/bootstrap/less/responsive-utilities.less","../bower_components/bootstrap/less/mixins/responsive-visibility.less","stylesheets/variables.less","stylesheets/globals.less","stylesheets/mixins.less","stylesheets/print.less","components/alerts-config/alerts-config.less","components/dashboard/dashboard.less","components/dashboard-create/dashboard-create.less","components/dashboard-selector/dashboard-selector.less","components/dashboard-templates-selector/dashboard-templates-selector.less","components/kpi/kpi.less","stylesheets/impac-material.less","components/kpis-bar/kpis-bar.less","components/widget/widget.less","components/common/data-not-found/data-not-found.less","components/common/duplicate-transactions-list/duplicate-transactions-list.less","components/common/transactions-add/transactions-add.less","components/common/transactions-list/transactions-list.less","components/common/trends-list/trends-list.less","components/common/trends-add/trends-add.less","components/dashboard-settings/currency/currency.less","components/dashboard-settings/sync-apps/sync-apps.less","components/widgets-common/chart-threshold/chart-threshold.less","components/widgets-common/confirm-modal/confirm-modal.less","components/widgets-common/currency-conversions/currency-conversions.less","components/widgets-common/editable-title/editable-title.less","components/widgets-common/info-panel/info-panel.less","components/widgets-common/time-period-info/time-period-info.less","components/widgets-common/top-buttons/top-buttons.less","components/widgets-settings/account/account.less","components/widgets-settings/accounting-behaviour/accounting-behaviour.less","components/widgets-settings/attach-kpis/attach-kpis.less","components/widgets-settings/bolt-account/bolt-account.less","components/widgets-settings/chart-filters/chart-filters.less","components/widgets-settings/dates-picker/dates-picker.less","components/widgets-settings/forecast-payroll/forecast-payroll.less","components/widgets-settings/hist-mode/hist-mode.less","components/widgets-settings/limit-entries/limit-entries.less","components/widgets-settings/offsets/offsets.less","components/widgets-settings/organizations/organizations.less","components/widgets-settings/param-selector/param-selector.less","components/widgets-settings/params-checkboxes/params-checkboxes.less","components/widgets-settings/params-picker/params-picker.less","components/widgets-settings/tag-filter/tag-filter.less","components/widgets-settings/time-period/time-period.less","components/widgets-settings/width/width.less","components/widgets/accounts-assets-liability-summary/accounts-assets-liability-summary.less","components/widgets/accounts-assets-summary/accounts-assets-summary.less","components/widgets/accounts-assets-vs-liabilities/accounts-assets-vs-liabilities.less","components/widgets/accounts-balance/accounts-balance.less","components/widgets/accounts-balance-sheet/accounts-balance-sheet.less","components/widgets/accounts-cash-balance/accounts-cash-balance.less","components/widgets/accounts-cash-projection/accounts-cash-projection.less","components/widgets/accounts-cash-summary/accounts-cash-summary.less","stylesheets/widget-master-styles.less","components/widgets/accounts-class-comparison/accounts-class-comparison.less","components/widgets/accounts-comparison/accounts-comparison.less","components/widgets/accounts-custom-calculation/accounts-custom-calculation.less","components/widgets/accounts-detailed-classifications/accounts-detailed-classifications.less","components/widgets/accounts-expense-weight/accounts-expense-weight.less","components/widgets/accounts-expenses-revenue/accounts-expenses-revenue.less","components/widgets/accounts-invoices-list/accounts-invoices-list.less","components/widgets/accounts-live-balance/accounts-live-balance.less","components/widgets/accounts-payable-receivable/accounts-payable-receivable.less","components/widgets/accounts-profit-and-loss/accounts-profit-and-loss.less","components/widgets/accounts-ratios/accounts-ratios.less","components/widgets/hr-employee-details/hr-employee-details.less","components/widgets/hr-employees-list/hr-employees-list.less","components/widgets/hr-leaves-balance/hr-leaves-balance.less","components/widgets/hr-leaves-schedule/hr-leaves-schedule.less","components/widgets/hr-payroll-summary/hr-payroll-summary.less","components/widgets/hr-salaries-summary/hr-salaries-summary.less","components/widgets/hr-superannuation-accruals/hr-superannuation-accruals.less","components/widgets/hr-timesheets/hr-timesheets.less","components/widgets/hr-workforce-summary/hr-workforce-summary.less","components/widgets/invoices-aged-payables-receivables/invoices-aged-payables-receivables.less","components/widgets/invoices-list/invoices-list.less","components/widgets/invoices-summary/invoices-summary.less","components/widgets/sales-aged/sales-aged.less","components/widgets/sales-break-even/sales-break-even.less","components/widgets/sales-comparison/sales-comparison.less","components/widgets/sales-customer-details/sales-customer-details.less","components/widgets/sales-cycle/sales-cycle.less","components/widgets/sales-forecast/sales-forecast.less","components/widgets/sales-growth/sales-growth.less","components/widgets/sales-leads-funnel/sales-leads-funnel.less","components/widgets/sales-leads-list/sales-leads-list.less","components/widgets/sales-list/sales-list.less","components/widgets/sales-net-sales/sales-net-sales.less","components/widgets/sales-new-vs-existing-customers/sales-new-vs-existing-customers.less","components/widgets/sales-number-of-leads/sales-number-of-leads.less","components/widgets/sales-opportunities-funnel/sales-opportunities-funnel.less","components/widgets/sales-performance/sales-performance.less","components/widgets/sales-segmented-turnover/sales-segmented-turnover.less","components/widgets/sales-summary/sales-summary.less","components/widgets/sales-top-customers/sales-top-customers.less","components/widgets/sales-top-opportunities/sales-top-opportunities.less"],"names":[],"mappings":"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CFgQ9C;AE/PmC;EAAW,iBAAA;CFkQ9C;AEjQmC;EAAW,iBAAA;CFoQ9C;AEnQmC;EAAW,iBAAA;CFsQ9C;AErQmC;EAAW,iBAAA;CFwQ9C;AEvQmC;EAAW,iBAAA;CF0Q9C;AEzQmC;EAAW,iBAAA;CF4Q9C;AE3QmC;EAAW,iBAAA;CF8Q9C;AE7QmC;EAAW,iBAAA;CFgR9C;AE/QmC;EAAW,iBAAA;CFkR9C;AEjRmC;EAAW,iBAAA;CFoR9C;AEnRmC;EAAW,iBAAA;CFsR9C;AErRmC;EAAW,iBAAA;CFwR9C;AEvRmC;EAAW,iBAAA;CF0R9C;AEzRmC;EAAW,iBAAA;CF4R9C;AE3RmC;EAAW,iBAAA;CF8R9C;AE7RmC;EAAW,iBAAA;CFgS9C;AE/RmC;EAAW,iBAAA;CFkS9C;AEjSmC;EAAW,iBAAA;CFoS9C;AEnSmC;EAAW,iBAAA;CFsS9C;AErSmC;EAAW,iBAAA;CFwS9C;AEvSmC;EAAW,iBAAA;CF0S9C;AEzSmC;EAAW,iBAAA;CF4S9C;AE3SmC;EAAW,iBAAA;CF8S9C;AE7SmC;EAAW,iBAAA;CFgT9C;AE/SmC;EAAW,iBAAA;CFkT9C;AEjTmC;EAAW,iBAAA;CFoT9C;AEnTmC;EAAW,iBAAA;CFsT9C;AErTmC;EAAW,iBAAA;CFwT9C;AEvTmC;EAAW,iBAAA;CF0T9C;AEzTmC;EAAW,iBAAA;CF4T9C;AE3TmC;EAAW,iBAAA;CF8T9C;AE7TmC;EAAW,iBAAA;CFgU9C;AE/TmC;EAAW,iBAAA;CFkU9C;AEjUmC;EAAW,iBAAA;CFoU9C;AEnUmC;EAAW,iBAAA;CFsU9C;AErUmC;EAAW,iBAAA;CFwU9C;AEvUmC;EAAW,iBAAA;CF0U9C;AEzUmC;EAAW,iBAAA;CF4U9C;AE3UmC;EAAW,iBAAA;CF8U9C;AE7UmC;EAAW,iBAAA;CFgV9C;AE/UmC;EAAW,iBAAA;CFkV9C;AEjVmC;EAAW,iBAAA;CFoV9C;AEnVmC;EAAW,iBAAA;CFsV9C;AErVmC;EAAW,iBAAA;CFwV9C;AEvVmC;EAAW,iBAAA;CF0V9C;AEzVmC;EAAW,iBAAA;CF4V9C;AE3VmC;EAAW,iBAAA;CF8V9C;AE7VmC;EAAW,iBAAA;CFgW9C;AE/VmC;EAAW,iBAAA;CFkW9C;AEjWmC;EAAW,iBAAA;CFoW9C;AEnWmC;EAAW,iBAAA;CFsW9C;AErWmC;EAAW,iBAAA;CFwW9C;AEvWmC;EAAW,iBAAA;CF0W9C;AEzWmC;EAAW,iBAAA;CF4W9C;AE3WmC;EAAW,iBAAA;CF8W9C;AE7WmC;EAAW,iBAAA;CFgX9C;AE/WmC;EAAW,iBAAA;CFkX9C;AEjXmC;EAAW,iBAAA;CFoX9C;AEnXmC;EAAW,iBAAA;CFsX9C;AErXmC;EAAW,iBAAA;CFwX9C;AEvXmC;EAAW,iBAAA;CF0X9C;AEzXmC;EAAW,iBAAA;CF4X9C;AE3XmC;EAAW,iBAAA;CF8X9C;AE7XmC;EAAW,iBAAA;CFgY9C;AE/XmC;EAAW,iBAAA;CFkY9C;AEjYmC;EAAW,iBAAA;CFoY9C;AEnYmC;EAAW,iBAAA;CFsY9C;AErYmC;EAAW,iBAAA;CFwY9C;AEvYmC;EAAW,iBAAA;CF0Y9C;AEzYmC;EAAW,iBAAA;CF4Y9C;AE3YmC;EAAW,iBAAA;CF8Y9C;AE7YmC;EAAW,iBAAA;CFgZ9C;AE/YmC;EAAW,iBAAA;CFkZ9C;AEjZmC;EAAW,iBAAA;CFoZ9C;AEnZmC;EAAW,iBAAA;CFsZ9C;AErZmC;EAAW,iBAAA;CFwZ9C;AEvZmC;EAAW,iBAAA;CF0Z9C;AEzZmC;EAAW,iBAAA;CF4Z9C;AE3ZmC;EAAW,iBAAA;CF8Z9C;AE7ZmC;EAAW,iBAAA;CFga9C;AE/ZmC;EAAW,iBAAA;CFka9C;AEjamC;EAAW,iBAAA;CFoa9C;AEnamC;EAAW,iBAAA;CFsa9C;AEramC;EAAW,iBAAA;CFwa9C;AEvamC;EAAW,iBAAA;CF0a9C;AEzamC;EAAW,iBAAA;CF4a9C;AE3amC;EAAW,iBAAA;CF8a9C;AE7amC;EAAW,iBAAA;CFgb9C;AE/amC;EAAW,iBAAA;CFkb9C;AEjbmC;EAAW,iBAAA;CFob9C;AEnbmC;EAAW,iBAAA;CFsb9C;AErbmC;EAAW,iBAAA;CFwb9C;AEvbmC;EAAW,iBAAA;CF0b9C;AEzbmC;EAAW,iBAAA;CF4b9C;AE3bmC;EAAW,iBAAA;CF8b9C;AE7bmC;EAAW,iBAAA;CFgc9C;AE/bmC;EAAW,iBAAA;CFkc9C;AEjcmC;EAAW,iBAAA;CFoc9C;AEncmC;EAAW,iBAAA;CFsc9C;AErcmC;EAAW,iBAAA;CFwc9C;AEvcmC;EAAW,iBAAA;CF0c9C;AEzcmC;EAAW,iBAAA;CF4c9C;AE3cmC;EAAW,iBAAA;CF8c9C;AE7cmC;EAAW,iBAAA;CFgd9C;AE/cmC;EAAW,iBAAA;CFkd9C;AEjdmC;EAAW,iBAAA;CFod9C;AEndmC;EAAW,iBAAA;CFsd9C;AErdmC;EAAW,iBAAA;CFwd9C;AEvdmC;EAAW,iBAAA;CF0d9C;AEzdmC;EAAW,iBAAA;CF4d9C;AE3dmC;EAAW,iBAAA;CF8d9C;AE7dmC;EAAW,iBAAA;CFge9C;AE/dmC;EAAW,iBAAA;CFke9C;AEjemC;EAAW,iBAAA;CFoe9C;AEnemC;EAAW,iBAAA;CFse9C;AEremC;EAAW,iBAAA;CFwe9C;AEvemC;EAAW,iBAAA;CF0e9C;AEzemC;EAAW,iBAAA;CF4e9C;AE3emC;EAAW,iBAAA;CF8e9C;AE7emC;EAAW,iBAAA;CFgf9C;AE/emC;EAAW,iBAAA;CFkf9C;AEjfmC;EAAW,iBAAA;CFof9C;AEnfmC;EAAW,iBAAA;CFsf9C;AErfmC;EAAW,iBAAA;CFwf9C;AEvfmC;EAAW,iBAAA;CF0f9C;AEzfmC;EAAW,iBAAA;CF4f9C;AE3fmC;EAAW,iBAAA;CF8f9C;AE7fmC;EAAW,iBAAA;CFggB9C;AE/fmC;EAAW,iBAAA;CFkgB9C;AEjgBmC;EAAW,iBAAA;CFogB9C;AEngBmC;EAAW,iBAAA;CFsgB9C;AErgBmC;EAAW,iBAAA;CFwgB9C;AEvgBmC;EAAW,iBAAA;CF0gB9C;AEzgBmC;EAAW,iBAAA;CF4gB9C;AE3gBmC;EAAW,iBAAA;CF8gB9C;AE7gBmC;EAAW,iBAAA;CFghB9C;AE/gBmC;EAAW,iBAAA;CFkhB9C;AEjhBmC;EAAW,iBAAA;CFohB9C;AEnhBmC;EAAW,iBAAA;CFshB9C;AErhBmC;EAAW,iBAAA;CFwhB9C;AEvhBmC;EAAW,iBAAA;CF0hB9C;AEzhBmC;EAAW,iBAAA;CF4hB9C;AE3hBmC;EAAW,iBAAA;CF8hB9C;AE7hBmC;EAAW,iBAAA;CFgiB9C;AE/hBmC;EAAW,iBAAA;CFkiB9C;AEjiBmC;EAAW,iBAAA;CFoiB9C;AEniBmC;EAAW,iBAAA;CFsiB9C;AEriBmC;EAAW,iBAAA;CFwiB9C;AEviBmC;EAAW,iBAAA;CF0iB9C;AEziBmC;EAAW,iBAAA;CF4iB9C;AE3iBmC;EAAW,iBAAA;CF8iB9C;AE7iBmC;EAAW,iBAAA;CFgjB9C;AE/iBmC;EAAW,iBAAA;CFkjB9C;AEjjBmC;EAAW,iBAAA;CFojB9C;AEnjBmC;EAAW,iBAAA;CFsjB9C;AErjBmC;EAAW,iBAAA;CFwjB9C;AEvjBmC;EAAW,iBAAA;CF0jB9C;AEzjBmC;EAAW,iBAAA;CF4jB9C;AE3jBmC;EAAW,iBAAA;CF8jB9C;AE7jBmC;EAAW,iBAAA;CFgkB9C;AE/jBmC;EAAW,iBAAA;CFkkB9C;AEjkBmC;EAAW,iBAAA;CFokB9C;AEnkBmC;EAAW,iBAAA;CFskB9C;AErkBmC;EAAW,iBAAA;CFwkB9C;AE/jBmC;EAAW,iBAAA;CFkkB9C;AEjkBmC;EAAW,iBAAA;CFokB9C;AEnkBmC;EAAW,iBAAA;CFskB9C;AErkBmC;EAAW,iBAAA;CFwkB9C;AEvkBmC;EAAW,iBAAA;CF0kB9C;AEzkBmC;EAAW,iBAAA;CF4kB9C;AE3kBmC;EAAW,iBAAA;CF8kB9C;AE7kBmC;EAAW,iBAAA;CFglB9C;AE/kBmC;EAAW,iBAAA;CFklB9C;AEjlBmC;EAAW,iBAAA;CFolB9C;AEnlBmC;EAAW,iBAAA;CFslB9C;AErlBmC;EAAW,iBAAA;CFwlB9C;AEvlBmC;EAAW,iBAAA;CF0lB9C;AEzlBmC;EAAW,iBAAA;CF4lB9C;AE3lBmC;EAAW,iBAAA;CF8lB9C;AE7lBmC;EAAW,iBAAA;CFgmB9C;AE/lBmC;EAAW,iBAAA;CFkmB9C;AEjmBmC;EAAW,iBAAA;CFomB9C;AEnmBmC;EAAW,iBAAA;CFsmB9C;AErmBmC;EAAW,iBAAA;CFwmB9C;AEvmBmC;EAAW,iBAAA;CF0mB9C;AEzmBmC;EAAW,iBAAA;CF4mB9C;AE3mBmC;EAAW,iBAAA;CF8mB9C;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oBAAA;Cdg/CL;Ach+CG;EACE,YAAA;Cdk+CL;Ac39CC;EACE,YAAA;Cd69CH;Ac99CC;EACE,oBAAA;Cdg+CH;Acj+CC;EACE,oBAAA;Cdm+CH;Acp+CC;EACE,WAAA;Cds+CH;Acv+CC;EACE,oBAAA;Cdy+CH;Ac1+CC;EACE,oBAAA;Cd4+CH;Ac7+CC;EACE,WAAA;Cd++CH;Ach/CC;EACE,oBAAA;Cdk/CH;Acn/CC;EACE,oBAAA;Cdq/CH;Act/CC;EACE,WAAA;Cdw/CH;Acz/CC;EACE,oBAAA;Cd2/CH;Ac5/CC;EACE,mBAAA;Cd8/CH;Ach/CC;EACE,YAAA;Cdk/CH;Acn/CC;EACE,oBAAA;Cdq/CH;Act/CC;EACE,oBAAA;Cdw/CH;Acz/CC;EACE,WAAA;Cd2/CH;Ac5/CC;EACE,oBAAA;Cd8/CH;Ac//CC;EACE,oBAAA;CdigDH;AclgDC;EACE,WAAA;CdogDH;AcrgDC;EACE,oBAAA;CdugDH;AcxgDC;EACE,oBAAA;Cd0gDH;Ac3gDC;EACE,WAAA;Cd6gDH;Ac9gDC;EACE,oBAAA;CdghDH;AcjhDC;EACE,mBAAA;CdmhDH;Ac/gDC;EACE,YAAA;CdihDH;AcjiDC;EACE,WAAA;CdmiDH;AcpiDC;EACE,mBAAA;CdsiDH;AcviDC;EACE,mBAAA;CdyiDH;Ac1iDC;EACE,UAAA;Cd4iDH;Ac7iDC;EACE,mBAAA;Cd+iDH;AchjDC;EACE,mBAAA;CdkjDH;AcnjDC;EACE,UAAA;CdqjDH;ActjDC;EACE,mBAAA;CdwjDH;AczjDC;EACE,mBAAA;Cd2jDH;Ac5jDC;EACE,UAAA;Cd8jDH;Ac/jDC;EACE,mBAAA;CdikDH;AclkDC;EACE,kBAAA;CdokDH;AchkDC;EACE,WAAA;CdkkDH;AcpjDC;EACE,kBAAA;CdsjDH;AcvjDC;EACE,0BAAA;CdyjDH;Ac1jDC;EACE,0BAAA;Cd4jDH;Ac7jDC;EACE,iBAAA;Cd+jDH;AchkDC;EACE,0BAAA;CdkkDH;AcnkDC;EACE,0BAAA;CdqkDH;ActkDC;EACE,iBAAA;CdwkDH;AczkDC;EACE,0BAAA;Cd2kDH;Ac5kDC;EACE,0BAAA;Cd8kDH;Ac/kDC;EACE,iBAAA;CdilDH;AcllDC;EACE,0BAAA;CdolDH;AcrlDC;EACE,yBAAA;CdulDH;AcxlDC;EACE,gBAAA;Cd0lDH;AYnmDD;EEzBI;IACE,YAAA;Gd+nDH;EcxnDD;IACE,YAAA;Gd0nDD;Ec3nDD;IACE,oBAAA;Gd6nDD;Ec9nDD;IACE,oBAAA;GdgoDD;EcjoDD;IACE,WAAA;GdmoDD;EcpoDD;IACE,oBAAA;GdsoDD;EcvoDD;IACE,oBAAA;GdyoDD;Ec1oDD;IACE,WAAA;Gd4oDD;Ec7oDD;IACE,oBAAA;Gd+oDD;EchpDD;IACE,oBAAA;GdkpDD;EcnpDD;IACE,WAAA;GdqpDD;EctpDD;IACE,oBAAA;GdwpDD;EczpDD;IACE,mBAAA;Gd2pDD;Ec7oDD;IACE,YAAA;Gd+oDD;EchpDD;IACE,oBAAA;GdkpDD;EcnpDD;IACE,oBAAA;GdqpDD;EctpDD;IACE,WAAA;GdwpDD;EczpDD;IACE,oBAAA;Gd2pDD;Ec5pDD;IACE,oBAAA;Gd8pDD;Ec/pDD;IACE,WAAA;GdiqDD;EclqDD;IACE,oBAAA;GdoqDD;EcrqDD;IACE,oBAAA;GduqDD;EcxqDD;IACE,WAAA;Gd0qDD;Ec3qDD;IACE,oBAAA;Gd6qDD;Ec9qDD;IACE,mBAAA;GdgrDD;Ec5qDD;IACE,YAAA;Gd8qDD;Ec9rDD;IACE,WAAA;GdgsDD;EcjsDD;IACE,mBAAA;GdmsDD;EcpsDD;IACE,mBAAA;GdssDD;EcvsDD;IACE,UAAA;GdysDD;Ec1sDD;IACE,mBAAA;Gd4sDD;Ec7sDD;IACE,mBAAA;Gd+sDD;EchtDD;IACE,UAAA;GdktDD;EcntDD;IACE,mBAAA;GdqtDD;EcttDD;IACE,mBAAA;GdwtDD;EcztDD;IACE,UAAA;Gd2tDD;Ec5tDD;IACE,mBAAA;Gd8tDD;Ec/tDD;IACE,kBAAA;GdiuDD;Ec7tDD;IACE,WAAA;Gd+tDD;EcjtDD;IACE,kBAAA;GdmtDD;EcptDD;IACE,0BAAA;GdstDD;EcvtDD;IACE,0BAAA;GdytDD;Ec1tDD;IACE,iBAAA;Gd4tDD;Ec7tDD;IACE,0BAAA;Gd+tDD;EchuDD;IACE,0BAAA;GdkuDD;EcnuDD;IACE,iBAAA;GdquDD;EctuDD;IACE,0BAAA;GdwuDD;EczuDD;IACE,0BAAA;Gd2uDD;Ec5uDD;IACE,iBAAA;Gd8uDD;Ec/uDD;IACE,0BAAA;GdivDD;EclvDD;IACE,yBAAA;GdovDD;EcrvDD;IACE,gBAAA;GduvDD;CACF;AYxvDD;EElCI;IACE,YAAA;Gd6xDH;EctxDD;IACE,YAAA;GdwxDD;EczxDD;IACE,oBAAA;Gd2xDD;Ec5xDD;IACE,oBAAA;Gd8xDD;Ec/xDD;IACE,WAAA;GdiyDD;EclyDD;IACE,oBAAA;GdoyDD;EcryDD;IACE,oBAAA;GduyDD;EcxyDD;IACE,WAAA;Gd0yDD;Ec3yDD;IACE,oBAAA;Gd6yDD;Ec9yDD;IACE,oBAAA;GdgzDD;EcjzDD;IACE,WAAA;GdmzDD;EcpzDD;IACE,oBAAA;GdszDD;EcvzDD;IACE,mBAAA;GdyzDD;Ec3yDD;IACE,YAAA;Gd6yDD;Ec9yDD;IACE,oBAAA;GdgzDD;EcjzDD;IACE,oBAAA;GdmzDD;EcpzDD;IACE,WAAA;GdszDD;EcvzDD;IACE,oBAAA;GdyzDD;Ec1zDD;IACE,oBAAA;Gd4zDD;Ec7zDD;IACE,WAAA;Gd+zDD;Ech0DD;IACE,oBAAA;Gdk0DD;Ecn0DD;IACE,oBAAA;Gdq0DD;Ect0DD;IACE,WAAA;Gdw0DD;Ecz0DD;IACE,oBAAA;Gd20DD;Ec50DD;IACE,mBAAA;Gd80DD;Ec10DD;IACE,YAAA;Gd40DD;Ec51DD;IACE,WAAA;Gd81DD;Ec/1DD;IACE,mBAAA;Gdi2DD;Ecl2DD;IACE,mBAAA;Gdo2DD;Ecr2DD;IACE,UAAA;Gdu2DD;Ecx2DD;IACE,mBAAA;Gd02DD;Ec32DD;IACE,mBAAA;Gd62DD;Ec92DD;IACE,UAAA;Gdg3DD;Ecj3DD;IACE,mBAAA;Gdm3DD;Ecp3DD;IACE,mBAAA;Gds3DD;Ecv3DD;IACE,UAAA;Gdy3DD;Ec13DD;IACE,mBAAA;Gd43DD;Ec73DD;IACE,kBAAA;Gd+3DD;Ec33DD;IACE,WAAA;Gd63DD;Ec/2DD;IACE,kBAAA;Gdi3DD;Ecl3DD;IACE,0BAAA;Gdo3DD;Ecr3DD;IACE,0BAAA;Gdu3DD;Ecx3DD;IACE,iBAAA;Gd03DD;Ec33DD;IACE,0BAAA;Gd63DD;Ec93DD;IACE,0BAAA;Gdg4DD;Ecj4DD;IACE,iBAAA;Gdm4DD;Ecp4DD;IACE,0BAAA;Gds4DD;Ecv4DD;IACE,0BAAA;Gdy4DD;Ec14DD;IACE,iBAAA;Gd44DD;Ec74DD;IACE,0BAAA;Gd+4DD;Ech5DD;IACE,yBAAA;Gdk5DD;Ecn5DD;IACE,gBAAA;Gdq5DD;CACF;AY74DD;EE3CI;IACE,YAAA;Gd27DH;Ecp7DD;IACE,YAAA;Gds7DD;Ecv7DD;IACE,oBAAA;Gdy7DD;Ec17DD;IACE,oBAAA;Gd47DD;Ec77DD;IACE,WAAA;Gd+7DD;Ech8DD;IACE,oBAAA;Gdk8DD;Ecn8DD;IACE,oBAAA;Gdq8DD;Ect8DD;IACE,WAAA;Gdw8DD;Ecz8DD;IACE,oBAAA;Gd28DD;Ec58DD;IACE,oBAAA;Gd88DD;Ec/8DD;IACE,WAAA;Gdi9DD;Ecl9DD;IACE,oBAAA;Gdo9DD;Ecr9DD;IACE,mBAAA;Gdu9DD;Ecz8DD;IACE,YAAA;Gd28DD;Ec58DD;IACE,oBAAA;Gd88DD;Ec/8DD;IACE,oBAAA;Gdi9DD;Ecl9DD;IACE,WAAA;Gdo9DD;Ecr9DD;IACE,oBAAA;Gdu9DD;Ecx9DD;IACE,oBAAA;Gd09DD;Ec39DD;IACE,WAAA;Gd69DD;Ec99DD;IACE,oBAAA;Gdg+DD;Ecj+DD;IACE,oBAAA;Gdm+DD;Ecp+DD;IACE,WAAA;Gds+DD;Ecv+DD;IACE,oBAAA;Gdy+DD;Ec1+DD;IACE,mBAAA;Gd4+DD;Ecx+DD;IACE,YAAA;Gd0+DD;Ec1/DD;IACE,WAAA;Gd4/DD;Ec7/DD;IACE,mBAAA;Gd+/DD;EchgED;IACE,mBAAA;GdkgED;EcngED;IACE,UAAA;GdqgED;EctgED;IACE,mBAAA;GdwgED;EczgED;IACE,mBAAA;Gd2gED;Ec5gED;IACE,UAAA;Gd8gED;Ec/gED;IACE,mBAAA;GdihED;EclhED;IACE,mBAAA;GdohED;EcrhED;IACE,UAAA;GduhED;EcxhED;IACE,mBAAA;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","file":"impac-angular.css","sourcesContent":["/*\n** All @import's should live in this file!\n*/\n/**\n *  Do not remove this comments bellow. It's the markers used by wiredep to inject\n *  less dependencies when defined in the bower.json of your dependencies\n */\n/*!\n * Bootstrap v3.3.7 (http://getbootstrap.com)\n * Copyright 2011-2016 Twitter, Inc.\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n */\n/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */\nhtml {\n  font-family: sans-serif;\n  -ms-text-size-adjust: 100%;\n  -webkit-text-size-adjust: 100%;\n}\nbody {\n  margin: 0;\n}\narticle,\naside,\ndetails,\nfigcaption,\nfigure,\nfooter,\nheader,\nhgroup,\nmain,\nmenu,\nnav,\nsection,\nsummary {\n  display: block;\n}\naudio,\ncanvas,\nprogress,\nvideo {\n  display: inline-block;\n  vertical-align: baseline;\n}\naudio:not([controls]) {\n  display: none;\n  height: 0;\n}\n[hidden],\ntemplate {\n  display: none;\n}\na {\n  background-color: transparent;\n}\na:active,\na:hover {\n  outline: 0;\n}\nabbr[title] {\n  border-bottom: 1px dotted;\n}\nb,\nstrong {\n  font-weight: bold;\n}\ndfn {\n  font-style: italic;\n}\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0;\n}\nmark {\n  background: #ff0;\n  color: #000;\n}\nsmall {\n  font-size: 80%;\n}\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n}\nsup {\n  top: -0.5em;\n}\nsub {\n  bottom: -0.25em;\n}\nimg {\n  border: 0;\n}\nsvg:not(:root) {\n  overflow: hidden;\n}\nfigure {\n  margin: 1em 40px;\n}\nhr {\n  box-sizing: content-box;\n  height: 0;\n}\npre {\n  overflow: auto;\n}\ncode,\nkbd,\npre,\nsamp {\n  font-family: monospace, monospace;\n  font-size: 1em;\n}\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  color: inherit;\n  font: inherit;\n  margin: 0;\n}\nbutton {\n  overflow: visible;\n}\nbutton,\nselect {\n  text-transform: none;\n}\nbutton,\nhtml input[type=\"button\"],\ninput[type=\"reset\"],\ninput[type=\"submit\"] {\n  -webkit-appearance: button;\n  cursor: pointer;\n}\nbutton[disabled],\nhtml input[disabled] {\n  cursor: default;\n}\nbutton::-moz-focus-inner,\ninput::-moz-focus-inner {\n  border: 0;\n  padding: 0;\n}\ninput {\n  line-height: normal;\n}\ninput[type=\"checkbox\"],\ninput[type=\"radio\"] {\n  box-sizing: border-box;\n  padding: 0;\n}\ninput[type=\"number\"]::-webkit-inner-spin-button,\ninput[type=\"number\"]::-webkit-outer-spin-button {\n  height: auto;\n}\ninput[type=\"search\"] {\n  -webkit-appearance: textfield;\n  box-sizing: content-box;\n}\ninput[type=\"search\"]::-webkit-search-cancel-button,\ninput[type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none;\n}\nfieldset {\n  border: 1px solid #c0c0c0;\n  margin: 0 2px;\n  padding: 0.35em 0.625em 0.75em;\n}\nlegend {\n  border: 0;\n  padding: 0;\n}\ntextarea {\n  overflow: auto;\n}\noptgroup {\n  font-weight: bold;\n}\ntable {\n  border-collapse: collapse;\n  border-spacing: 0;\n}\ntd,\nth {\n  padding: 0;\n}\n@font-face {\n  font-family: 'Glyphicons Halflings';\n  src: url('../fonts/glyphicons-halflings-regular.eot');\n  src: url('../fonts/glyphicons-halflings-regular.eot?#iefix') format('embedded-opentype'), url('../fonts/glyphicons-halflings-regular.woff2') format('woff2'), url('../fonts/glyphicons-halflings-regular.woff') format('woff'), url('../fonts/glyphicons-halflings-regular.ttf') format('truetype'), url('../fonts/glyphicons-halflings-regular.svg#glyphicons_halflingsregular') format('svg');\n}\n.glyphicon {\n  position: relative;\n  top: 1px;\n  display: inline-block;\n  font-family: 'Glyphicons Halflings';\n  font-style: normal;\n  font-weight: normal;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n.glyphicon-asterisk:before {\n  content: \"\\002a\";\n}\n.glyphicon-plus:before {\n  content: \"\\002b\";\n}\n.glyphicon-euro:before,\n.glyphicon-eur:before {\n  content: \"\\20ac\";\n}\n.glyphicon-minus:before {\n  content: \"\\2212\";\n}\n.glyphicon-cloud:before {\n  content: \"\\2601\";\n}\n.glyphicon-envelope:before {\n  content: \"\\2709\";\n}\n.glyphicon-pencil:before {\n  content: \"\\270f\";\n}\n.glyphicon-glass:before {\n  content: \"\\e001\";\n}\n.glyphicon-music:before {\n  content: \"\\e002\";\n}\n.glyphicon-search:before {\n  content: \"\\e003\";\n}\n.glyphicon-heart:before {\n  content: \"\\e005\";\n}\n.glyphicon-star:before {\n  content: \"\\e006\";\n}\n.glyphicon-star-empty:before {\n  content: \"\\e007\";\n}\n.glyphicon-user:before {\n  content: \"\\e008\";\n}\n.glyphicon-film:before {\n  content: \"\\e009\";\n}\n.glyphicon-th-large:before {\n  content: \"\\e010\";\n}\n.glyphicon-th:before {\n  content: \"\\e011\";\n}\n.glyphicon-th-list:before {\n  content: \"\\e012\";\n}\n.glyphicon-ok:before {\n  content: \"\\e013\";\n}\n.glyphicon-remove:before {\n  content: \"\\e014\";\n}\n.glyphicon-zoom-in:before {\n  content: \"\\e015\";\n}\n.glyphicon-zoom-out:before {\n  content: \"\\e016\";\n}\n.glyphicon-off:before {\n  content: \"\\e017\";\n}\n.glyphicon-signal:before {\n  content: \"\\e018\";\n}\n.glyphicon-cog:before {\n  content: \"\\e019\";\n}\n.glyphicon-trash:before {\n  content: \"\\e020\";\n}\n.glyphicon-home:before {\n  content: \"\\e021\";\n}\n.glyphicon-file:before {\n  content: \"\\e022\";\n}\n.glyphicon-time:before {\n  content: \"\\e023\";\n}\n.glyphicon-road:before {\n  content: \"\\e024\";\n}\n.glyphicon-download-alt:before {\n  content: \"\\e025\";\n}\n.glyphicon-download:before {\n  content: \"\\e026\";\n}\n.glyphicon-upload:before {\n  content: \"\\e027\";\n}\n.glyphicon-inbox:before {\n  content: \"\\e028\";\n}\n.glyphicon-play-circle:before {\n  content: \"\\e029\";\n}\n.glyphicon-repeat:before {\n  content: \"\\e030\";\n}\n.glyphicon-refresh:before {\n  content: \"\\e031\";\n}\n.glyphicon-list-alt:before {\n  content: \"\\e032\";\n}\n.glyphicon-lock:before {\n  content: \"\\e033\";\n}\n.glyphicon-flag:before {\n  content: \"\\e034\";\n}\n.glyphicon-headphones:before {\n  content: \"\\e035\";\n}\n.glyphicon-volume-off:before {\n  content: \"\\e036\";\n}\n.glyphicon-volume-down:before {\n  content: \"\\e037\";\n}\n.glyphicon-volume-up:before {\n  content: \"\\e038\";\n}\n.glyphicon-qrcode:before {\n  content: \"\\e039\";\n}\n.glyphicon-barcode:before {\n  content: \"\\e040\";\n}\n.glyphicon-tag:before {\n  content: \"\\e041\";\n}\n.glyphicon-tags:before {\n  content: \"\\e042\";\n}\n.glyphicon-book:before {\n  content: \"\\e043\";\n}\n.glyphicon-bookmark:before {\n  content: \"\\e044\";\n}\n.glyphicon-print:before {\n  content: \"\\e045\";\n}\n.glyphicon-camera:before {\n  content: \"\\e046\";\n}\n.glyphicon-font:before {\n  content: \"\\e047\";\n}\n.glyphicon-bold:before {\n  content: \"\\e048\";\n}\n.glyphicon-italic:before {\n  content: \"\\e049\";\n}\n.glyphicon-text-height:before {\n  content: \"\\e050\";\n}\n.glyphicon-text-width:before {\n  content: \"\\e051\";\n}\n.glyphicon-align-left:before {\n  content: \"\\e052\";\n}\n.glyphicon-align-center:before {\n  content: \"\\e053\";\n}\n.glyphicon-align-right:before {\n  content: \"\\e054\";\n}\n.glyphicon-align-justify:before {\n  content: \"\\e055\";\n}\n.glyphicon-list:before {\n  content: \"\\e056\";\n}\n.glyphicon-indent-left:before {\n  content: \"\\e057\";\n}\n.glyphicon-indent-right:before {\n  content: \"\\e058\";\n}\n.glyphicon-facetime-video:before {\n  content: \"\\e059\";\n}\n.glyphicon-picture:before {\n  content: \"\\e060\";\n}\n.glyphicon-map-marker:before {\n  content: \"\\e062\";\n}\n.glyphicon-adjust:before {\n  content: \"\\e063\";\n}\n.glyphicon-tint:before {\n  content: \"\\e064\";\n}\n.glyphicon-edit:before {\n  content: \"\\e065\";\n}\n.glyphicon-share:before {\n  content: \"\\e066\";\n}\n.glyphicon-check:before {\n  content: \"\\e067\";\n}\n.glyphicon-move:before {\n  content: \"\\e068\";\n}\n.glyphicon-step-backward:before {\n  content: \"\\e069\";\n}\n.glyphicon-fast-backward:before {\n  content: \"\\e070\";\n}\n.glyphicon-backward:before {\n  content: \"\\e071\";\n}\n.glyphicon-play:before {\n  content: \"\\e072\";\n}\n.glyphicon-pause:before {\n  content: \"\\e073\";\n}\n.glyphicon-stop:before {\n  content: \"\\e074\";\n}\n.glyphicon-forward:before {\n  content: \"\\e075\";\n}\n.glyphicon-fast-forward:before {\n  content: \"\\e076\";\n}\n.glyphicon-step-forward:before {\n  content: \"\\e077\";\n}\n.glyphicon-eject:before {\n  content: \"\\e078\";\n}\n.glyphicon-chevron-left:before {\n  content: \"\\e079\";\n}\n.glyphicon-chevron-right:before {\n  content: \"\\e080\";\n}\n.glyphicon-plus-sign:before {\n  content: \"\\e081\";\n}\n.glyphicon-minus-sign:before {\n  content: \"\\e082\";\n}\n.glyphicon-remove-sign:before {\n  content: \"\\e083\";\n}\n.glyphicon-ok-sign:before {\n  content: \"\\e084\";\n}\n.glyphicon-question-sign:before {\n  content: \"\\e085\";\n}\n.glyphicon-info-sign:before {\n  content: \"\\e086\";\n}\n.glyphicon-screenshot:before {\n  content: \"\\e087\";\n}\n.glyphicon-remove-circle:before {\n  content: \"\\e088\";\n}\n.glyphicon-ok-circle:before {\n  content: \"\\e089\";\n}\n.glyphicon-ban-circle:before {\n  content: \"\\e090\";\n}\n.glyphicon-arrow-left:before {\n  content: \"\\e091\";\n}\n.glyphicon-arrow-right:before {\n  content: \"\\e092\";\n}\n.glyphicon-arrow-up:before {\n  content: \"\\e093\";\n}\n.glyphicon-arrow-down:before {\n  content: \"\\e094\";\n}\n.glyphicon-share-alt:before {\n  content: \"\\e095\";\n}\n.glyphicon-resize-full:before {\n  content: \"\\e096\";\n}\n.glyphicon-resize-small:before {\n  content: \"\\e097\";\n}\n.glyphicon-exclamation-sign:before {\n  content: \"\\e101\";\n}\n.glyphicon-gift:before {\n  content: \"\\e102\";\n}\n.glyphicon-leaf:before {\n  content: \"\\e103\";\n}\n.glyphicon-fire:before {\n  content: \"\\e104\";\n}\n.glyphicon-eye-open:before {\n  content: \"\\e105\";\n}\n.glyphicon-eye-close:before {\n  content: \"\\e106\";\n}\n.glyphicon-warning-sign:before {\n  content: \"\\e107\";\n}\n.glyphicon-plane:before {\n  content: \"\\e108\";\n}\n.glyphicon-calendar:before {\n  content: \"\\e109\";\n}\n.glyphicon-random:before {\n  content: \"\\e110\";\n}\n.glyphicon-comment:before {\n  content: \"\\e111\";\n}\n.glyphicon-magnet:before {\n  content: \"\\e112\";\n}\n.glyphicon-chevron-up:before {\n  content: \"\\e113\";\n}\n.glyphicon-chevron-down:before {\n  content: \"\\e114\";\n}\n.glyphicon-retweet:before {\n  content: \"\\e115\";\n}\n.glyphicon-shopping-cart:before {\n  content: \"\\e116\";\n}\n.glyphicon-folder-close:before {\n  content: \"\\e117\";\n}\n.glyphicon-folder-open:before {\n  content: \"\\e118\";\n}\n.glyphicon-resize-vertical:before {\n  content: \"\\e119\";\n}\n.glyphicon-resize-horizontal:before {\n  content: \"\\e120\";\n}\n.glyphicon-hdd:before {\n  content: \"\\e121\";\n}\n.glyphicon-bullhorn:before {\n  content: \"\\e122\";\n}\n.glyphicon-bell:before {\n  content: \"\\e123\";\n}\n.glyphicon-certificate:before {\n  content: \"\\e124\";\n}\n.glyphicon-thumbs-up:before {\n  content: \"\\e125\";\n}\n.glyphicon-thumbs-down:before {\n  content: \"\\e126\";\n}\n.glyphicon-hand-right:before {\n  content: \"\\e127\";\n}\n.glyphicon-hand-left:before {\n  content: \"\\e128\";\n}\n.glyphicon-hand-up:before {\n  content: \"\\e129\";\n}\n.glyphicon-hand-down:before {\n  content: \"\\e130\";\n}\n.glyphicon-circle-arrow-right:before {\n  content: \"\\e131\";\n}\n.glyphicon-circle-arrow-left:before {\n  content: \"\\e132\";\n}\n.glyphicon-circle-arrow-up:before {\n  content: \"\\e133\";\n}\n.glyphicon-circle-arrow-down:before {\n  content: \"\\e134\";\n}\n.glyphicon-globe:before {\n  content: \"\\e135\";\n}\n.glyphicon-wrench:before {\n  content: \"\\e136\";\n}\n.glyphicon-tasks:before {\n  content: \"\\e137\";\n}\n.glyphicon-filter:before {\n  content: \"\\e138\";\n}\n.glyphicon-briefcase:before {\n  content: \"\\e139\";\n}\n.glyphicon-fullscreen:before {\n  content: \"\\e140\";\n}\n.glyphicon-dashboard:before {\n  content: \"\\e141\";\n}\n.glyphicon-paperclip:before {\n  content: \"\\e142\";\n}\n.glyphicon-heart-empty:before {\n  content: \"\\e143\";\n}\n.glyphicon-link:before {\n  content: \"\\e144\";\n}\n.glyphicon-phone:before {\n  content: \"\\e145\";\n}\n.glyphicon-pushpin:before {\n  content: \"\\e146\";\n}\n.glyphicon-usd:before {\n  content: \"\\e148\";\n}\n.glyphicon-gbp:before {\n  content: \"\\e149\";\n}\n.glyphicon-sort:before {\n  content: \"\\e150\";\n}\n.glyphicon-sort-by-alphabet:before {\n  content: \"\\e151\";\n}\n.glyphicon-sort-by-alphabet-alt:before {\n  content: \"\\e152\";\n}\n.glyphicon-sort-by-order:before {\n  content: \"\\e153\";\n}\n.glyphicon-sort-by-order-alt:before {\n  content: \"\\e154\";\n}\n.glyphicon-sort-by-attributes:before {\n  content: \"\\e155\";\n}\n.glyphicon-sort-by-attributes-alt:before {\n  content: \"\\e156\";\n}\n.glyphicon-unchecked:before {\n  content: \"\\e157\";\n}\n.glyphicon-expand:before {\n  content: \"\\e158\";\n}\n.glyphicon-collapse-down:before {\n  content: \"\\e159\";\n}\n.glyphicon-collapse-up:before {\n  content: \"\\e160\";\n}\n.glyphicon-log-in:before {\n  content: \"\\e161\";\n}\n.glyphicon-flash:before {\n  content: \"\\e162\";\n}\n.glyphicon-log-out:before {\n  content: \"\\e163\";\n}\n.glyphicon-new-window:before {\n  content: \"\\e164\";\n}\n.glyphicon-record:before {\n  content: \"\\e165\";\n}\n.glyphicon-save:before {\n  content: \"\\e166\";\n}\n.glyphicon-open:before {\n  content: \"\\e167\";\n}\n.glyphicon-saved:before {\n  content: \"\\e168\";\n}\n.glyphicon-import:before {\n  content: \"\\e169\";\n}\n.glyphicon-export:before {\n  content: \"\\e170\";\n}\n.glyphicon-send:before {\n  content: \"\\e171\";\n}\n.glyphicon-floppy-disk:before {\n  content: \"\\e172\";\n}\n.glyphicon-floppy-saved:before {\n  content: \"\\e173\";\n}\n.glyphicon-floppy-remove:before {\n  content: \"\\e174\";\n}\n.glyphicon-floppy-save:before {\n  content: \"\\e175\";\n}\n.glyphicon-floppy-open:before {\n  content: \"\\e176\";\n}\n.glyphicon-credit-card:before {\n  content: \"\\e177\";\n}\n.glyphicon-transfer:before {\n  content: \"\\e178\";\n}\n.glyphicon-cutlery:before {\n  content: \"\\e179\";\n}\n.glyphicon-header:before {\n  content: \"\\e180\";\n}\n.glyphicon-compressed:before {\n  content: \"\\e181\";\n}\n.glyphicon-earphone:before {\n  content: \"\\e182\";\n}\n.glyphicon-phone-alt:before {\n  content: \"\\e183\";\n}\n.glyphicon-tower:before {\n  content: \"\\e184\";\n}\n.glyphicon-stats:before {\n  content: \"\\e185\";\n}\n.glyphicon-sd-video:before {\n  content: \"\\e186\";\n}\n.glyphicon-hd-video:before {\n  content: \"\\e187\";\n}\n.glyphicon-subtitles:before {\n  content: \"\\e188\";\n}\n.glyphicon-sound-stereo:before {\n  content: \"\\e189\";\n}\n.glyphicon-sound-dolby:before {\n  content: \"\\e190\";\n}\n.glyphicon-sound-5-1:before {\n  content: \"\\e191\";\n}\n.glyphicon-sound-6-1:before {\n  content: \"\\e192\";\n}\n.glyphicon-sound-7-1:before {\n  content: \"\\e193\";\n}\n.glyphicon-copyright-mark:before {\n  content: \"\\e194\";\n}\n.glyphicon-registration-mark:before {\n  content: \"\\e195\";\n}\n.glyphicon-cloud-download:before {\n  content: \"\\e197\";\n}\n.glyphicon-cloud-upload:before {\n  content: \"\\e198\";\n}\n.glyphicon-tree-conifer:before {\n  content: \"\\e199\";\n}\n.glyphicon-tree-deciduous:before {\n  content: \"\\e200\";\n}\n.glyphicon-cd:before {\n  content: \"\\e201\";\n}\n.glyphicon-save-file:before {\n  content: \"\\e202\";\n}\n.glyphicon-open-file:before {\n  content: \"\\e203\";\n}\n.glyphicon-level-up:before {\n  content: \"\\e204\";\n}\n.glyphicon-copy:before {\n  content: \"\\e205\";\n}\n.glyphicon-paste:before {\n  content: \"\\e206\";\n}\n.glyphicon-alert:before {\n  content: \"\\e209\";\n}\n.glyphicon-equalizer:before {\n  content: \"\\e210\";\n}\n.glyphicon-king:before {\n  content: \"\\e211\";\n}\n.glyphicon-queen:before {\n  content: \"\\e212\";\n}\n.glyphicon-pawn:before {\n  content: \"\\e213\";\n}\n.glyphicon-bishop:before {\n  content: \"\\e214\";\n}\n.glyphicon-knight:before {\n  content: \"\\e215\";\n}\n.glyphicon-baby-formula:before {\n  content: \"\\e216\";\n}\n.glyphicon-tent:before {\n  content: \"\\26fa\";\n}\n.glyphicon-blackboard:before {\n  content: \"\\e218\";\n}\n.glyphicon-bed:before {\n  content: \"\\e219\";\n}\n.glyphicon-apple:before {\n  content: \"\\f8ff\";\n}\n.glyphicon-erase:before {\n  content: \"\\e221\";\n}\n.glyphicon-hourglass:before {\n  content: \"\\231b\";\n}\n.glyphicon-lamp:before {\n  content: \"\\e223\";\n}\n.glyphicon-duplicate:before {\n  content: \"\\e224\";\n}\n.glyphicon-piggy-bank:before {\n  content: \"\\e225\";\n}\n.glyphicon-scissors:before {\n  content: \"\\e226\";\n}\n.glyphicon-bitcoin:before {\n  content: \"\\e227\";\n}\n.glyphicon-btc:before {\n  content: \"\\e227\";\n}\n.glyphicon-xbt:before {\n  content: \"\\e227\";\n}\n.glyphicon-yen:before {\n  content: \"\\00a5\";\n}\n.glyphicon-jpy:before {\n  content: \"\\00a5\";\n}\n.glyphicon-ruble:before {\n  content: \"\\20bd\";\n}\n.glyphicon-rub:before {\n  content: \"\\20bd\";\n}\n.glyphicon-scale:before {\n  content: \"\\e230\";\n}\n.glyphicon-ice-lolly:before {\n  content: \"\\e231\";\n}\n.glyphicon-ice-lolly-tasted:before {\n  content: \"\\e232\";\n}\n.glyphicon-education:before {\n  content: \"\\e233\";\n}\n.glyphicon-option-horizontal:before {\n  content: \"\\e234\";\n}\n.glyphicon-option-vertical:before {\n  content: \"\\e235\";\n}\n.glyphicon-menu-hamburger:before {\n  content: \"\\e236\";\n}\n.glyphicon-modal-window:before {\n  content: \"\\e237\";\n}\n.glyphicon-oil:before {\n  content: \"\\e238\";\n}\n.glyphicon-grain:before {\n  content: \"\\e239\";\n}\n.glyphicon-sunglasses:before {\n  content: \"\\e240\";\n}\n.glyphicon-text-size:before {\n  content: \"\\e241\";\n}\n.glyphicon-text-color:before {\n  content: \"\\e242\";\n}\n.glyphicon-text-background:before {\n  content: \"\\e243\";\n}\n.glyphicon-object-align-top:before {\n  content: \"\\e244\";\n}\n.glyphicon-object-align-bottom:before {\n  content: \"\\e245\";\n}\n.glyphicon-object-align-horizontal:before {\n  content: \"\\e246\";\n}\n.glyphicon-object-align-left:before {\n  content: \"\\e247\";\n}\n.glyphicon-object-align-vertical:before {\n  content: \"\\e248\";\n}\n.glyphicon-object-align-right:before {\n  content: \"\\e249\";\n}\n.glyphicon-triangle-right:before {\n  content: \"\\e250\";\n}\n.glyphicon-triangle-left:before {\n  content: \"\\e251\";\n}\n.glyphicon-triangle-bottom:before {\n  content: \"\\e252\";\n}\n.glyphicon-triangle-top:before {\n  content: \"\\e253\";\n}\n.glyphicon-console:before {\n  content: \"\\e254\";\n}\n.glyphicon-superscript:before {\n  content: \"\\e255\";\n}\n.glyphicon-subscript:before {\n  content: \"\\e256\";\n}\n.glyphicon-menu-left:before {\n  content: \"\\e257\";\n}\n.glyphicon-menu-right:before {\n  content: \"\\e258\";\n}\n.glyphicon-menu-down:before {\n  content: \"\\e259\";\n}\n.glyphicon-menu-up:before {\n  content: \"\\e260\";\n}\n* {\n  -webkit-box-sizing: border-box;\n  -moz-box-sizing: border-box;\n  box-sizing: border-box;\n}\n*:before,\n*:after {\n  -webkit-box-sizing: border-box;\n  -moz-box-sizing: border-box;\n  box-sizing: border-box;\n}\nhtml {\n  font-size: 10px;\n  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);\n}\nbody {\n  font-family: \"Helvetica Neue\", Helvetica, Arial, sans-serif;\n  font-size: 14px;\n  line-height: 1.42857143;\n  color: #333333;\n  background-color: #fff;\n}\ninput,\nbutton,\nselect,\ntextarea {\n  font-family: inherit;\n  font-size: inherit;\n  line-height: inherit;\n}\na {\n  color: #00e5f0;\n  text-decoration: none;\n}\na:hover,\na:focus {\n  color: #009ca3;\n  text-decoration: underline;\n}\na:focus {\n  outline: 5px auto -webkit-focus-ring-color;\n  outline-offset: -2px;\n}\nfigure {\n  margin: 0;\n}\nimg {\n  vertical-align: middle;\n}\n.img-responsive,\n.thumbnail > img,\n.thumbnail a > img,\n.carousel-inner > .item > img,\n.carousel-inner > .item > a > img {\n  display: block;\n  max-width: 100%;\n  height: auto;\n}\n.img-rounded {\n  border-radius: 6px;\n}\n.img-thumbnail {\n  padding: 4px;\n  line-height: 1.42857143;\n  background-color: #fff;\n  border: 1px solid #ddd;\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.img-circle {\n  border-radius: 50%;\n}\nhr {\n  margin-top: 20px;\n  margin-bottom: 20px;\n  border: 0;\n  border-top: 1px solid #eeeeee;\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.sr-only-focusable:active,\n.sr-only-focusable:focus {\n  position: static;\n  width: auto;\n  height: auto;\n  margin: 0;\n  overflow: visible;\n  clip: auto;\n}\n[role=\"button\"] {\n  cursor: pointer;\n}\nh1,\nh2,\nh3,\nh4,\nh5,\nh6,\n.h1,\n.h2,\n.h3,\n.h4,\n.h5,\n.h6 {\n  font-family: inherit;\n  font-weight: 500;\n  line-height: 1.1;\n  color: inherit;\n}\nh1 small,\nh2 small,\nh3 small,\nh4 small,\nh5 small,\nh6 small,\n.h1 small,\n.h2 small,\n.h3 small,\n.h4 small,\n.h5 small,\n.h6 small,\nh1 .small,\nh2 .small,\nh3 .small,\nh4 .small,\nh5 .small,\nh6 .small,\n.h1 .small,\n.h2 .small,\n.h3 .small,\n.h4 .small,\n.h5 .small,\n.h6 .small {\n  font-weight: normal;\n  line-height: 1;\n  color: #777777;\n}\nh1,\n.h1,\nh2,\n.h2,\nh3,\n.h3 {\n  margin-top: 20px;\n  margin-bottom: 10px;\n}\nh1 small,\n.h1 small,\nh2 small,\n.h2 small,\nh3 small,\n.h3 small,\nh1 .small,\n.h1 .small,\nh2 .small,\n.h2 .small,\nh3 .small,\n.h3 .small {\n  font-size: 65%;\n}\nh4,\n.h4,\nh5,\n.h5,\nh6,\n.h6 {\n  margin-top: 10px;\n  margin-bottom: 10px;\n}\nh4 small,\n.h4 small,\nh5 small,\n.h5 small,\nh6 small,\n.h6 small,\nh4 .small,\n.h4 .small,\nh5 .small,\n.h5 .small,\nh6 .small,\n.h6 .small {\n  font-size: 75%;\n}\nh1,\n.h1 {\n  font-size: 36px;\n}\nh2,\n.h2 {\n  font-size: 30px;\n}\nh3,\n.h3 {\n  font-size: 24px;\n}\nh4,\n.h4 {\n  font-size: 18px;\n}\nh5,\n.h5 {\n  font-size: 14px;\n}\nh6,\n.h6 {\n  font-size: 12px;\n}\np {\n  margin: 0 0 10px;\n}\n.lead {\n  margin-bottom: 20px;\n  font-size: 16px;\n  font-weight: 300;\n  line-height: 1.4;\n}\n@media (min-width: 768px) {\n  .lead {\n    font-size: 21px;\n  }\n}\nsmall,\n.small {\n  font-size: 85%;\n}\nmark,\n.mark {\n  background-color: #fcf8e3;\n  padding: .2em;\n}\n.text-left {\n  text-align: left;\n}\n.text-right {\n  text-align: right;\n}\n.text-center {\n  text-align: center;\n}\n.text-justify {\n  text-align: justify;\n}\n.text-nowrap {\n  white-space: nowrap;\n}\n.text-lowercase {\n  text-transform: lowercase;\n}\n.text-uppercase {\n  text-transform: uppercase;\n}\n.text-capitalize {\n  text-transform: capitalize;\n}\n.text-muted {\n  color: #777777;\n}\n.text-primary {\n  color: #00e5f0;\n}\na.text-primary:hover,\na.text-primary:focus {\n  color: #00b4bd;\n}\n.text-success {\n  color: #3c763d;\n}\na.text-success:hover,\na.text-success:focus {\n  color: #2b542c;\n}\n.text-info {\n  color: #31708f;\n}\na.text-info:hover,\na.text-info:focus {\n  color: #245269;\n}\n.text-warning {\n  color: #8a6d3b;\n}\na.text-warning:hover,\na.text-warning:focus {\n  color: #66512c;\n}\n.text-danger {\n  color: #a94442;\n}\na.text-danger:hover,\na.text-danger:focus {\n  color: #843534;\n}\n.bg-primary {\n  color: #fff;\n  background-color: #00e5f0;\n}\na.bg-primary:hover,\na.bg-primary:focus {\n  background-color: #00b4bd;\n}\n.bg-success {\n  background-color: #dff0d8;\n}\na.bg-success:hover,\na.bg-success:focus {\n  background-color: #c1e2b3;\n}\n.bg-info {\n  background-color: #d9edf7;\n}\na.bg-info:hover,\na.bg-info:focus {\n  background-color: #afd9ee;\n}\n.bg-warning {\n  background-color: #fcf8e3;\n}\na.bg-warning:hover,\na.bg-warning:focus {\n  background-color: #f7ecb5;\n}\n.bg-danger {\n  background-color: #f2dede;\n}\na.bg-danger:hover,\na.bg-danger:focus {\n  background-color: #e4b9b9;\n}\n.page-header {\n  padding-bottom: 9px;\n  margin: 40px 0 20px;\n  border-bottom: 1px solid #eeeeee;\n}\nul,\nol {\n  margin-top: 0;\n  margin-bottom: 10px;\n}\nul ul,\nol ul,\nul ol,\nol ol {\n  margin-bottom: 0;\n}\n.list-unstyled {\n  padding-left: 0;\n  list-style: none;\n}\n.list-inline {\n  padding-left: 0;\n  list-style: none;\n  margin-left: -5px;\n}\n.list-inline > li {\n  display: inline-block;\n  padding-left: 5px;\n  padding-right: 5px;\n}\ndl {\n  margin-top: 0;\n  margin-bottom: 20px;\n}\ndt,\ndd {\n  line-height: 1.42857143;\n}\ndt {\n  font-weight: bold;\n}\ndd {\n  margin-left: 0;\n}\n@media (min-width: 768px) {\n  .dl-horizontal dt {\n    float: left;\n    width: 160px;\n    clear: left;\n    text-align: right;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n  }\n  .dl-horizontal dd {\n    margin-left: 180px;\n  }\n}\nabbr[title],\nabbr[data-original-title] {\n  cursor: help;\n  border-bottom: 1px dotted #777777;\n}\n.initialism {\n  font-size: 90%;\n  text-transform: uppercase;\n}\nblockquote {\n  padding: 10px 20px;\n  margin: 0 0 20px;\n  font-size: 17.5px;\n  border-left: 5px solid #eeeeee;\n}\nblockquote p:last-child,\nblockquote ul:last-child,\nblockquote ol:last-child {\n  margin-bottom: 0;\n}\nblockquote footer,\nblockquote small,\nblockquote .small {\n  display: block;\n  font-size: 80%;\n  line-height: 1.42857143;\n  color: #777777;\n}\nblockquote footer:before,\nblockquote small:before,\nblockquote .small:before {\n  content: '\\2014 \\00A0';\n}\n.blockquote-reverse,\nblockquote.pull-right {\n  padding-right: 15px;\n  padding-left: 0;\n  border-right: 5px solid #eeeeee;\n  border-left: 0;\n  text-align: right;\n}\n.blockquote-reverse footer:before,\nblockquote.pull-right footer:before,\n.blockquote-reverse small:before,\nblockquote.pull-right small:before,\n.blockquote-reverse .small:before,\nblockquote.pull-right .small:before {\n  content: '';\n}\n.blockquote-reverse footer:after,\nblockquote.pull-right footer:after,\n.blockquote-reverse small:after,\nblockquote.pull-right small:after,\n.blockquote-reverse .small:after,\nblockquote.pull-right .small:after {\n  content: '\\00A0 \\2014';\n}\naddress {\n  margin-bottom: 20px;\n  font-style: normal;\n  line-height: 1.42857143;\n}\ncode,\nkbd,\npre,\nsamp {\n  font-family: Menlo, Monaco, Consolas, \"Courier New\", monospace;\n}\ncode {\n  padding: 2px 4px;\n  font-size: 90%;\n  color: #c7254e;\n  background-color: #f9f2f4;\n  border-radius: 4px;\n}\nkbd {\n  padding: 2px 4px;\n  font-size: 90%;\n  color: #fff;\n  background-color: #333;\n  border-radius: 3px;\n  box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.25);\n}\nkbd kbd {\n  padding: 0;\n  font-size: 100%;\n  font-weight: bold;\n  box-shadow: none;\n}\npre {\n  display: block;\n  padding: 9.5px;\n  margin: 0 0 10px;\n  font-size: 13px;\n  line-height: 1.42857143;\n  word-break: break-all;\n  word-wrap: break-word;\n  color: #333333;\n  background-color: #f5f5f5;\n  border: 1px solid #ccc;\n  border-radius: 4px;\n}\npre code {\n  padding: 0;\n  font-size: inherit;\n  color: inherit;\n  white-space: pre-wrap;\n  background-color: transparent;\n  border-radius: 0;\n}\n.pre-scrollable {\n  max-height: 340px;\n  overflow-y: scroll;\n}\n.container {\n  margin-right: auto;\n  margin-left: auto;\n  padding-left: 15px;\n  padding-right: 15px;\n}\n@media (min-width: 768px) {\n  .container {\n    width: 750px;\n  }\n}\n@media (min-width: 992px) {\n  .container {\n    width: 970px;\n  }\n}\n@media (min-width: 1200px) {\n  .container {\n    width: 1170px;\n  }\n}\n.container-fluid {\n  margin-right: auto;\n  margin-left: auto;\n  padding-left: 15px;\n  padding-right: 15px;\n}\n.row {\n  margin-left: -15px;\n  margin-right: -15px;\n}\n.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.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.col-xs-12 {\n  width: 100%;\n}\n.col-xs-11 {\n  width: 91.66666667%;\n}\n.col-xs-10 {\n  width: 83.33333333%;\n}\n.col-xs-9 {\n  width: 75%;\n}\n.col-xs-8 {\n  width: 66.66666667%;\n}\n.col-xs-7 {\n  width: 58.33333333%;\n}\n.col-xs-6 {\n  width: 50%;\n}\n.col-xs-5 {\n  width: 41.66666667%;\n}\n.col-xs-4 {\n  width: 33.33333333%;\n}\n.col-xs-3 {\n  width: 25%;\n}\n.col-xs-2 {\n  width: 16.66666667%;\n}\n.col-xs-1 {\n  width: 8.33333333%;\n}\n.col-xs-pull-12 {\n  right: 100%;\n}\n.col-xs-pull-11 {\n  right: 91.66666667%;\n}\n.col-xs-pull-10 {\n  right: 83.33333333%;\n}\n.col-xs-pull-9 {\n  right: 75%;\n}\n.col-xs-pull-8 {\n  right: 66.66666667%;\n}\n.col-xs-pull-7 {\n  right: 58.33333333%;\n}\n.col-xs-pull-6 {\n  right: 50%;\n}\n.col-xs-pull-5 {\n  right: 41.66666667%;\n}\n.col-xs-pull-4 {\n  right: 33.33333333%;\n}\n.col-xs-pull-3 {\n  right: 25%;\n}\n.col-xs-pull-2 {\n  right: 16.66666667%;\n}\n.col-xs-pull-1 {\n  right: 8.33333333%;\n}\n.col-xs-pull-0 {\n  right: auto;\n}\n.col-xs-push-12 {\n  left: 100%;\n}\n.col-xs-push-11 {\n  left: 91.66666667%;\n}\n.col-xs-push-10 {\n  left: 83.33333333%;\n}\n.col-xs-push-9 {\n  left: 75%;\n}\n.col-xs-push-8 {\n  left: 66.66666667%;\n}\n.col-xs-push-7 {\n  left: 58.33333333%;\n}\n.col-xs-push-6 {\n  left: 50%;\n}\n.col-xs-push-5 {\n  left: 41.66666667%;\n}\n.col-xs-push-4 {\n  left: 33.33333333%;\n}\n.col-xs-push-3 {\n  left: 25%;\n}\n.col-xs-push-2 {\n  left: 16.66666667%;\n}\n.col-xs-push-1 {\n  left: 8.33333333%;\n}\n.col-xs-push-0 {\n  left: auto;\n}\n.col-xs-offset-12 {\n  margin-left: 100%;\n}\n.col-xs-offset-11 {\n  margin-left: 91.66666667%;\n}\n.col-xs-offset-10 {\n  margin-left: 83.33333333%;\n}\n.col-xs-offset-9 {\n  margin-left: 75%;\n}\n.col-xs-offset-8 {\n  margin-left: 66.66666667%;\n}\n.col-xs-offset-7 {\n  margin-left: 58.33333333%;\n}\n.col-xs-offset-6 {\n  margin-left: 50%;\n}\n.col-xs-offset-5 {\n  margin-left: 41.66666667%;\n}\n.col-xs-offset-4 {\n  margin-left: 33.33333333%;\n}\n.col-xs-offset-3 {\n  margin-left: 25%;\n}\n.col-xs-offset-2 {\n  margin-left: 16.66666667%;\n}\n.col-xs-offset-1 {\n  margin-left: 8.33333333%;\n}\n.col-xs-offset-0 {\n  margin-left: 0%;\n}\n@media (min-width: 768px) {\n  .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  .col-sm-12 {\n    width: 100%;\n  }\n  .col-sm-11 {\n    width: 91.66666667%;\n  }\n  .col-sm-10 {\n    width: 83.33333333%;\n  }\n  .col-sm-9 {\n    width: 75%;\n  }\n  .col-sm-8 {\n    width: 66.66666667%;\n  }\n  .col-sm-7 {\n    width: 58.33333333%;\n  }\n  .col-sm-6 {\n    width: 50%;\n  }\n  .col-sm-5 {\n    width: 41.66666667%;\n  }\n  .col-sm-4 {\n    width: 33.33333333%;\n  }\n  .col-sm-3 {\n    width: 25%;\n  }\n  .col-sm-2 {\n    width: 16.66666667%;\n  }\n  .col-sm-1 {\n    width: 8.33333333%;\n  }\n  .col-sm-pull-12 {\n    right: 100%;\n  }\n  .col-sm-pull-11 {\n    right: 91.66666667%;\n  }\n  .col-sm-pull-10 {\n    right: 83.33333333%;\n  }\n  .col-sm-pull-9 {\n    right: 75%;\n  }\n  .col-sm-pull-8 {\n    right: 66.66666667%;\n  }\n  .col-sm-pull-7 {\n    right: 58.33333333%;\n  }\n  .col-sm-pull-6 {\n    right: 50%;\n  }\n  .col-sm-pull-5 {\n    right: 41.66666667%;\n  }\n  .col-sm-pull-4 {\n    right: 33.33333333%;\n  }\n  .col-sm-pull-3 {\n    right: 25%;\n  }\n  .col-sm-pull-2 {\n    right: 16.66666667%;\n  }\n  .col-sm-pull-1 {\n    right: 8.33333333%;\n  }\n  .col-sm-pull-0 {\n    right: auto;\n  }\n  .col-sm-push-12 {\n    left: 100%;\n  }\n  .col-sm-push-11 {\n    left: 91.66666667%;\n  }\n  .col-sm-push-10 {\n    left: 83.33333333%;\n  }\n  .col-sm-push-9 {\n    left: 75%;\n  }\n  .col-sm-push-8 {\n    left: 66.66666667%;\n  }\n  .col-sm-push-7 {\n    left: 58.33333333%;\n  }\n  .col-sm-push-6 {\n    left: 50%;\n  }\n  .col-sm-push-5 {\n    left: 41.66666667%;\n  }\n  .col-sm-push-4 {\n    left: 33.33333333%;\n  }\n  .col-sm-push-3 {\n    left: 25%;\n  }\n  .col-sm-push-2 {\n    left: 16.66666667%;\n  }\n  .col-sm-push-1 {\n    left: 8.33333333%;\n  }\n  .col-sm-push-0 {\n    left: auto;\n  }\n  .col-sm-offset-12 {\n    margin-left: 100%;\n  }\n  .col-sm-offset-11 {\n    margin-left: 91.66666667%;\n  }\n  .col-sm-offset-10 {\n    margin-left: 83.33333333%;\n  }\n  .col-sm-offset-9 {\n    margin-left: 75%;\n  }\n  .col-sm-offset-8 {\n    margin-left: 66.66666667%;\n  }\n  .col-sm-offset-7 {\n    margin-left: 58.33333333%;\n  }\n  .col-sm-offset-6 {\n    margin-left: 50%;\n  }\n  .col-sm-offset-5 {\n    margin-left: 41.66666667%;\n  }\n  .col-sm-offset-4 {\n    margin-left: 33.33333333%;\n  }\n  .col-sm-offset-3 {\n    margin-left: 25%;\n  }\n  .col-sm-offset-2 {\n    margin-left: 16.66666667%;\n  }\n  .col-sm-offset-1 {\n    margin-left: 8.33333333%;\n  }\n  .col-sm-offset-0 {\n    margin-left: 0%;\n  }\n}\n@media (min-width: 992px) {\n  .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  .col-md-12 {\n    width: 100%;\n  }\n  .col-md-11 {\n    width: 91.66666667%;\n  }\n  .col-md-10 {\n    width: 83.33333333%;\n  }\n  .col-md-9 {\n    width: 75%;\n  }\n  .col-md-8 {\n    width: 66.66666667%;\n  }\n  .col-md-7 {\n    width: 58.33333333%;\n  }\n  .col-md-6 {\n    width: 50%;\n  }\n  .col-md-5 {\n    width: 41.66666667%;\n  }\n  .col-md-4 {\n    width: 33.33333333%;\n  }\n  .col-md-3 {\n    width: 25%;\n  }\n  .col-md-2 {\n    width: 16.66666667%;\n  }\n  .col-md-1 {\n    width: 8.33333333%;\n  }\n  .col-md-pull-12 {\n    right: 100%;\n  }\n  .col-md-pull-11 {\n    right: 91.66666667%;\n  }\n  .col-md-pull-10 {\n    right: 83.33333333%;\n  }\n  .col-md-pull-9 {\n    right: 75%;\n  }\n  .col-md-pull-8 {\n    right: 66.66666667%;\n  }\n  .col-md-pull-7 {\n    right: 58.33333333%;\n  }\n  .col-md-pull-6 {\n    right: 50%;\n  }\n  .col-md-pull-5 {\n    right: 41.66666667%;\n  }\n  .col-md-pull-4 {\n    right: 33.33333333%;\n  }\n  .col-md-pull-3 {\n    right: 25%;\n  }\n  .col-md-pull-2 {\n    right: 16.66666667%;\n  }\n  .col-md-pull-1 {\n    right: 8.33333333%;\n  }\n  .col-md-pull-0 {\n    right: auto;\n  }\n  .col-md-push-12 {\n    left: 100%;\n  }\n  .col-md-push-11 {\n    left: 91.66666667%;\n  }\n  .col-md-push-10 {\n    left: 83.33333333%;\n  }\n  .col-md-push-9 {\n    left: 75%;\n  }\n  .col-md-push-8 {\n    left: 66.66666667%;\n  }\n  .col-md-push-7 {\n    left: 58.33333333%;\n  }\n  .col-md-push-6 {\n    left: 50%;\n  }\n  .col-md-push-5 {\n    left: 41.66666667%;\n  }\n  .col-md-push-4 {\n    left: 33.33333333%;\n  }\n  .col-md-push-3 {\n    left: 25%;\n  }\n  .col-md-push-2 {\n    left: 16.66666667%;\n  }\n  .col-md-push-1 {\n    left: 8.33333333%;\n  }\n  .col-md-push-0 {\n    left: auto;\n  }\n  .col-md-offset-12 {\n    margin-left: 100%;\n  }\n  .col-md-offset-11 {\n    margin-left: 91.66666667%;\n  }\n  .col-md-offset-10 {\n    margin-left: 83.33333333%;\n  }\n  .col-md-offset-9 {\n    margin-left: 75%;\n  }\n  .col-md-offset-8 {\n    margin-left: 66.66666667%;\n  }\n  .col-md-offset-7 {\n    margin-left: 58.33333333%;\n  }\n  .col-md-offset-6 {\n    margin-left: 50%;\n  }\n  .col-md-offset-5 {\n    margin-left: 41.66666667%;\n  }\n  .col-md-offset-4 {\n    margin-left: 33.33333333%;\n  }\n  .col-md-offset-3 {\n    margin-left: 25%;\n  }\n  .col-md-offset-2 {\n    margin-left: 16.66666667%;\n  }\n  .col-md-offset-1 {\n    margin-left: 8.33333333%;\n  }\n  .col-md-offset-0 {\n    margin-left: 0%;\n  }\n}\n@media (min-width: 1200px) {\n  .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  .col-lg-12 {\n    width: 100%;\n  }\n  .col-lg-11 {\n    width: 91.66666667%;\n  }\n  .col-lg-10 {\n    width: 83.33333333%;\n  }\n  .col-lg-9 {\n    width: 75%;\n  }\n  .col-lg-8 {\n    width: 66.66666667%;\n  }\n  .col-lg-7 {\n    width: 58.33333333%;\n  }\n  .col-lg-6 {\n    width: 50%;\n  }\n  .col-lg-5 {\n    width: 41.66666667%;\n  }\n  .col-lg-4 {\n    width: 33.33333333%;\n  }\n  .col-lg-3 {\n    width: 25%;\n  }\n  .col-lg-2 {\n    width: 16.66666667%;\n  }\n  .col-lg-1 {\n    width: 8.33333333%;\n  }\n  .col-lg-pull-12 {\n    right: 100%;\n  }\n  .col-lg-pull-11 {\n    right: 91.66666667%;\n  }\n  .col-lg-pull-10 {\n    right: 83.33333333%;\n  }\n  .col-lg-pull-9 {\n    right: 75%;\n  }\n  .col-lg-pull-8 {\n    right: 66.66666667%;\n  }\n  .col-lg-pull-7 {\n    right: 58.33333333%;\n  }\n  .col-lg-pull-6 {\n    right: 50%;\n  }\n  .col-lg-pull-5 {\n    right: 41.66666667%;\n  }\n  .col-lg-pull-4 {\n    right: 33.33333333%;\n  }\n  .col-lg-pull-3 {\n    right: 25%;\n  }\n  .col-lg-pull-2 {\n    right: 16.66666667%;\n  }\n  .col-lg-pull-1 {\n    right: 8.33333333%;\n  }\n  .col-lg-pull-0 {\n    right: auto;\n  }\n  .col-lg-push-12 {\n    left: 100%;\n  }\n  .col-lg-push-11 {\n    left: 91.66666667%;\n  }\n  .col-lg-push-10 {\n    left: 83.33333333%;\n  }\n  .col-lg-push-9 {\n    left: 75%;\n  }\n  .col-lg-push-8 {\n    left: 66.66666667%;\n  }\n  .col-lg-push-7 {\n    left: 58.33333333%;\n  }\n  .col-lg-push-6 {\n    left: 50%;\n  }\n  .col-lg-push-5 {\n    left: 41.66666667%;\n  }\n  .col-lg-push-4 {\n    left: 33.33333333%;\n  }\n  .col-lg-push-3 {\n    left: 25%;\n  }\n  .col-lg-push-2 {\n    left: 16.66666667%;\n  }\n  .col-lg-push-1 {\n    left: 8.33333333%;\n  }\n  .col-lg-push-0 {\n    left: auto;\n  }\n  .col-lg-offset-12 {\n    margin-left: 100%;\n  }\n  .col-lg-offset-11 {\n    margin-left: 91.66666667%;\n  }\n  .col-lg-offset-10 {\n    margin-left: 83.33333333%;\n  }\n  .col-lg-offset-9 {\n    margin-left: 75%;\n  }\n  .col-lg-offset-8 {\n    margin-left: 66.66666667%;\n  }\n  .col-lg-offset-7 {\n    margin-left: 58.33333333%;\n  }\n  .col-lg-offset-6 {\n    margin-left: 50%;\n  }\n  .col-lg-offset-5 {\n    margin-left: 41.66666667%;\n  }\n  .col-lg-offset-4 {\n    margin-left: 33.33333333%;\n  }\n  .col-lg-offset-3 {\n    margin-left: 25%;\n  }\n  .col-lg-offset-2 {\n    margin-left: 16.66666667%;\n  }\n  .col-lg-offset-1 {\n    margin-left: 8.33333333%;\n  }\n  .col-lg-offset-0 {\n    margin-left: 0%;\n  }\n}\ntable {\n  background-color: transparent;\n}\ncaption {\n  padding-top: 8px;\n  padding-bottom: 8px;\n  color: #777777;\n  text-align: left;\n}\nth {\n  text-align: left;\n}\n.table {\n  width: 100%;\n  max-width: 100%;\n  margin-bottom: 20px;\n}\n.table > thead > tr > th,\n.table > tbody > tr > th,\n.table > tfoot > tr > th,\n.table > thead > tr > td,\n.table > tbody > tr > td,\n.table > tfoot > tr > td {\n  padding: 8px;\n  line-height: 1.42857143;\n  vertical-align: top;\n  border-top: 1px solid #ddd;\n}\n.table > thead > tr > th {\n  vertical-align: bottom;\n  border-bottom: 2px solid #ddd;\n}\n.table > caption + thead > tr:first-child > th,\n.table > colgroup + thead > tr:first-child > th,\n.table > thead:first-child > tr:first-child > th,\n.table > caption + thead > tr:first-child > td,\n.table > colgroup + thead > tr:first-child > td,\n.table > thead:first-child > tr:first-child > td {\n  border-top: 0;\n}\n.table > tbody + tbody {\n  border-top: 2px solid #ddd;\n}\n.table .table {\n  background-color: #fff;\n}\n.table-condensed > thead > tr > th,\n.table-condensed > tbody > tr > th,\n.table-condensed > tfoot > tr > th,\n.table-condensed > thead > tr > td,\n.table-condensed > tbody > tr > td,\n.table-condensed > tfoot > tr > td {\n  padding: 5px;\n}\n.table-bordered {\n  border: 1px solid #ddd;\n}\n.table-bordered > thead > tr > th,\n.table-bordered > tbody > tr > th,\n.table-bordered > tfoot > tr > th,\n.table-bordered > thead > tr > td,\n.table-bordered > tbody > tr > td,\n.table-bordered > tfoot > tr > td {\n  border: 1px solid #ddd;\n}\n.table-bordered > thead > tr > th,\n.table-bordered > thead > tr > td {\n  border-bottom-width: 2px;\n}\n.table-striped > tbody > tr:nth-of-type(odd) {\n  background-color: #f9f9f9;\n}\n.table-hover > tbody > tr:hover {\n  background-color: #f5f5f5;\n}\ntable col[class*=\"col-\"] {\n  position: static;\n  float: none;\n  display: table-column;\n}\ntable td[class*=\"col-\"],\ntable th[class*=\"col-\"] {\n  position: static;\n  float: none;\n  display: table-cell;\n}\n.table > thead > tr > td.active,\n.table > tbody > tr > td.active,\n.table > tfoot > tr > td.active,\n.table > thead > tr > th.active,\n.table > tbody > tr > th.active,\n.table > tfoot > tr > th.active,\n.table > thead > tr.active > td,\n.table > tbody > tr.active > td,\n.table > tfoot > tr.active > td,\n.table > thead > tr.active > th,\n.table > tbody > tr.active > th,\n.table > tfoot > tr.active > th {\n  background-color: #f5f5f5;\n}\n.table-hover > tbody > tr > td.active:hover,\n.table-hover > tbody > tr > th.active:hover,\n.table-hover > tbody > tr.active:hover > td,\n.table-hover > tbody > tr:hover > .active,\n.table-hover > tbody > tr.active:hover > th {\n  background-color: #e8e8e8;\n}\n.table > thead > tr > td.success,\n.table > tbody > tr > td.success,\n.table > tfoot > tr > td.success,\n.table > thead > tr > th.success,\n.table > tbody > tr > th.success,\n.table > tfoot > tr > th.success,\n.table > thead > tr.success > td,\n.table > tbody > tr.success > td,\n.table > tfoot > tr.success > td,\n.table > thead > tr.success > th,\n.table > tbody > tr.success > th,\n.table > tfoot > tr.success > th {\n  background-color: #dff0d8;\n}\n.table-hover > tbody > tr > td.success:hover,\n.table-hover > tbody > tr > th.success:hover,\n.table-hover > tbody > tr.success:hover > td,\n.table-hover > tbody > tr:hover > .success,\n.table-hover > tbody > tr.success:hover > th {\n  background-color: #d0e9c6;\n}\n.table > thead > tr > td.info,\n.table > tbody > tr > td.info,\n.table > tfoot > tr > td.info,\n.table > thead > tr > th.info,\n.table > tbody > tr > th.info,\n.table > tfoot > tr > th.info,\n.table > thead > tr.info > td,\n.table > tbody > tr.info > td,\n.table > tfoot > tr.info > td,\n.table > thead > tr.info > th,\n.table > tbody > tr.info > th,\n.table > tfoot > tr.info > th {\n  background-color: #d9edf7;\n}\n.table-hover > tbody > tr > td.info:hover,\n.table-hover > tbody > tr > th.info:hover,\n.table-hover > tbody > tr.info:hover > td,\n.table-hover > tbody > tr:hover > .info,\n.table-hover > tbody > tr.info:hover > th {\n  background-color: #c4e3f3;\n}\n.table > thead > tr > td.warning,\n.table > tbody > tr > td.warning,\n.table > tfoot > tr > td.warning,\n.table > thead > tr > th.warning,\n.table > tbody > tr > th.warning,\n.table > tfoot > tr > th.warning,\n.table > thead > tr.warning > td,\n.table > tbody > tr.warning > td,\n.table > tfoot > tr.warning > td,\n.table > thead > tr.warning > th,\n.table > tbody > tr.warning > th,\n.table > tfoot > tr.warning > th {\n  background-color: #fcf8e3;\n}\n.table-hover > tbody > tr > td.warning:hover,\n.table-hover > tbody > tr > th.warning:hover,\n.table-hover > tbody > tr.warning:hover > td,\n.table-hover > tbody > tr:hover > .warning,\n.table-hover > tbody > tr.warning:hover > th {\n  background-color: #faf2cc;\n}\n.table > thead > tr > td.danger,\n.table > tbody > tr > td.danger,\n.table > tfoot > tr > td.danger,\n.table > thead > tr > th.danger,\n.table > tbody > tr > th.danger,\n.table > tfoot > tr > th.danger,\n.table > thead > tr.danger > td,\n.table > tbody > tr.danger > td,\n.table > tfoot > tr.danger > td,\n.table > thead > tr.danger > th,\n.table > tbody > tr.danger > th,\n.table > tfoot > tr.danger > th {\n  background-color: #f2dede;\n}\n.table-hover > tbody > tr > td.danger:hover,\n.table-hover > tbody > tr > th.danger:hover,\n.table-hover > tbody > tr.danger:hover > td,\n.table-hover > tbody > tr:hover > .danger,\n.table-hover > tbody > tr.danger:hover > th {\n  background-color: #ebcccc;\n}\n.table-responsive {\n  overflow-x: auto;\n  min-height: 0.01%;\n}\n@media screen and (max-width: 767px) {\n  .table-responsive {\n    width: 100%;\n    margin-bottom: 15px;\n    overflow-y: hidden;\n    -ms-overflow-style: -ms-autohiding-scrollbar;\n    border: 1px solid #ddd;\n  }\n  .table-responsive > .table {\n    margin-bottom: 0;\n  }\n  .table-responsive > .table > thead > tr > th,\n  .table-responsive > .table > tbody > tr > th,\n  .table-responsive > .table > tfoot > tr > th,\n  .table-responsive > .table > thead > tr > td,\n  .table-responsive > .table > tbody > tr > td,\n  .table-responsive > .table > tfoot > tr > td {\n    white-space: nowrap;\n  }\n  .table-responsive > .table-bordered {\n    border: 0;\n  }\n  .table-responsive > .table-bordered > thead > tr > th:first-child,\n  .table-responsive > .table-bordered > tbody > tr > th:first-child,\n  .table-responsive > .table-bordered > tfoot > tr > th:first-child,\n  .table-responsive > .table-bordered > thead > tr > td:first-child,\n  .table-responsive > .table-bordered > tbody > tr > td:first-child,\n  .table-responsive > .table-bordered > tfoot > tr > td:first-child {\n    border-left: 0;\n  }\n  .table-responsive > .table-bordered > thead > tr > th:last-child,\n  .table-responsive > .table-bordered > tbody > tr > th:last-child,\n  .table-responsive > .table-bordered > tfoot > tr > th:last-child,\n  .table-responsive > .table-bordered > thead > tr > td:last-child,\n  .table-responsive > .table-bordered > tbody > tr > td:last-child,\n  .table-responsive > .table-bordered > tfoot > tr > td:last-child {\n    border-right: 0;\n  }\n  .table-responsive > .table-bordered > tbody > tr:last-child > th,\n  .table-responsive > .table-bordered > tfoot > tr:last-child > th,\n  .table-responsive > .table-bordered > tbody > tr:last-child > td,\n  .table-responsive > .table-bordered > tfoot > tr:last-child > td {\n    border-bottom: 0;\n  }\n}\nfieldset {\n  padding: 0;\n  margin: 0;\n  border: 0;\n  min-width: 0;\n}\nlegend {\n  display: block;\n  width: 100%;\n  padding: 0;\n  margin-bottom: 20px;\n  font-size: 21px;\n  line-height: inherit;\n  color: #333333;\n  border: 0;\n  border-bottom: 1px solid #e5e5e5;\n}\nlabel {\n  display: inline-block;\n  max-width: 100%;\n  margin-bottom: 5px;\n  font-weight: bold;\n}\ninput[type=\"search\"] {\n  -webkit-box-sizing: border-box;\n  -moz-box-sizing: border-box;\n  box-sizing: border-box;\n}\ninput[type=\"radio\"],\ninput[type=\"checkbox\"] {\n  margin: 4px 0 0;\n  margin-top: 1px \\9;\n  line-height: normal;\n}\ninput[type=\"file\"] {\n  display: block;\n}\ninput[type=\"range\"] {\n  display: block;\n  width: 100%;\n}\nselect[multiple],\nselect[size] {\n  height: auto;\n}\ninput[type=\"file\"]:focus,\ninput[type=\"radio\"]:focus,\ninput[type=\"checkbox\"]:focus {\n  outline: 5px auto -webkit-focus-ring-color;\n  outline-offset: -2px;\n}\noutput {\n  display: block;\n  padding-top: 7px;\n  font-size: 14px;\n  line-height: 1.42857143;\n  color: #555555;\n}\n.form-control {\n  display: block;\n  width: 100%;\n  height: 34px;\n  padding: 6px 12px;\n  font-size: 14px;\n  line-height: 1.42857143;\n  color: #555555;\n  background-color: #fff;\n  background-image: none;\n  border: 1px solid #ccc;\n  border-radius: 4px;\n  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);\n  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);\n  -webkit-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;\n  -o-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;\n  transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;\n}\n.form-control:focus {\n  border-color: #66afe9;\n  outline: 0;\n  -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102, 175, 233, 0.6);\n  box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102, 175, 233, 0.6);\n}\n.form-control::-moz-placeholder {\n  color: #999;\n  opacity: 1;\n}\n.form-control:-ms-input-placeholder {\n  color: #999;\n}\n.form-control::-webkit-input-placeholder {\n  color: #999;\n}\n.form-control::-ms-expand {\n  border: 0;\n  background-color: transparent;\n}\n.form-control[disabled],\n.form-control[readonly],\nfieldset[disabled] .form-control {\n  background-color: #eeeeee;\n  opacity: 1;\n}\n.form-control[disabled],\nfieldset[disabled] .form-control {\n  cursor: not-allowed;\n}\ntextarea.form-control {\n  height: auto;\n}\ninput[type=\"search\"] {\n  -webkit-appearance: none;\n}\n@media screen and (-webkit-min-device-pixel-ratio: 0) {\n  input[type=\"date\"].form-control,\n  input[type=\"time\"].form-control,\n  input[type=\"datetime-local\"].form-control,\n  input[type=\"month\"].form-control {\n    line-height: 34px;\n  }\n  input[type=\"date\"].input-sm,\n  input[type=\"time\"].input-sm,\n  input[type=\"datetime-local\"].input-sm,\n  input[type=\"month\"].input-sm,\n  .input-group-sm input[type=\"date\"],\n  .input-group-sm input[type=\"time\"],\n  .input-group-sm input[type=\"datetime-local\"],\n  .input-group-sm input[type=\"month\"] {\n    line-height: 30px;\n  }\n  input[type=\"date\"].input-lg,\n  input[type=\"time\"].input-lg,\n  input[type=\"datetime-local\"].input-lg,\n  input[type=\"month\"].input-lg,\n  .input-group-lg input[type=\"date\"],\n  .input-group-lg input[type=\"time\"],\n  .input-group-lg input[type=\"datetime-local\"],\n  .input-group-lg input[type=\"month\"] {\n    line-height: 46px;\n  }\n}\n.form-group {\n  margin-bottom: 15px;\n}\n.radio,\n.checkbox {\n  position: relative;\n  display: block;\n  margin-top: 10px;\n  margin-bottom: 10px;\n}\n.radio label,\n.checkbox label {\n  min-height: 20px;\n  padding-left: 20px;\n  margin-bottom: 0;\n  font-weight: normal;\n  cursor: pointer;\n}\n.radio input[type=\"radio\"],\n.radio-inline input[type=\"radio\"],\n.checkbox input[type=\"checkbox\"],\n.checkbox-inline input[type=\"checkbox\"] {\n  position: absolute;\n  margin-left: -20px;\n  margin-top: 4px \\9;\n}\n.radio + .radio,\n.checkbox + .checkbox {\n  margin-top: -5px;\n}\n.radio-inline,\n.checkbox-inline {\n  position: relative;\n  display: inline-block;\n  padding-left: 20px;\n  margin-bottom: 0;\n  vertical-align: middle;\n  font-weight: normal;\n  cursor: pointer;\n}\n.radio-inline + .radio-inline,\n.checkbox-inline + .checkbox-inline {\n  margin-top: 0;\n  margin-left: 10px;\n}\ninput[type=\"radio\"][disabled],\ninput[type=\"checkbox\"][disabled],\ninput[type=\"radio\"].disabled,\ninput[type=\"checkbox\"].disabled,\nfieldset[disabled] input[type=\"radio\"],\nfieldset[disabled] input[type=\"checkbox\"] {\n  cursor: not-allowed;\n}\n.radio-inline.disabled,\n.checkbox-inline.disabled,\nfieldset[disabled] .radio-inline,\nfieldset[disabled] .checkbox-inline {\n  cursor: not-allowed;\n}\n.radio.disabled label,\n.checkbox.disabled label,\nfieldset[disabled] .radio label,\nfieldset[disabled] .checkbox label {\n  cursor: not-allowed;\n}\n.form-control-static {\n  padding-top: 7px;\n  padding-bottom: 7px;\n  margin-bottom: 0;\n  min-height: 34px;\n}\n.form-control-static.input-lg,\n.form-control-static.input-sm {\n  padding-left: 0;\n  padding-right: 0;\n}\n.input-sm {\n  height: 30px;\n  padding: 5px 10px;\n  font-size: 12px;\n  line-height: 1.5;\n  border-radius: 3px;\n}\nselect.input-sm {\n  height: 30px;\n  line-height: 30px;\n}\ntextarea.input-sm,\nselect[multiple].input-sm {\n  height: auto;\n}\n.form-group-sm .form-control {\n  height: 30px;\n  padding: 5px 10px;\n  font-size: 12px;\n  line-height: 1.5;\n  border-radius: 3px;\n}\n.form-group-sm select.form-control {\n  height: 30px;\n  line-height: 30px;\n}\n.form-group-sm textarea.form-control,\n.form-group-sm select[multiple].form-control {\n  height: auto;\n}\n.form-group-sm .form-control-static {\n  height: 30px;\n  min-height: 32px;\n  padding: 6px 10px;\n  font-size: 12px;\n  line-height: 1.5;\n}\n.input-lg {\n  height: 46px;\n  padding: 10px 16px;\n  font-size: 18px;\n  line-height: 1.3333333;\n  border-radius: 6px;\n}\nselect.input-lg {\n  height: 46px;\n  line-height: 46px;\n}\ntextarea.input-lg,\nselect[multiple].input-lg {\n  height: auto;\n}\n.form-group-lg .form-control {\n  height: 46px;\n  padding: 10px 16px;\n  font-size: 18px;\n  line-height: 1.3333333;\n  border-radius: 6px;\n}\n.form-group-lg select.form-control {\n  height: 46px;\n  line-height: 46px;\n}\n.form-group-lg textarea.form-control,\n.form-group-lg select[multiple].form-control {\n  height: auto;\n}\n.form-group-lg .form-control-static {\n  height: 46px;\n  min-height: 38px;\n  padding: 11px 16px;\n  font-size: 18px;\n  line-height: 1.3333333;\n}\n.has-feedback {\n  position: relative;\n}\n.has-feedback .form-control {\n  padding-right: 42.5px;\n}\n.form-control-feedback {\n  position: absolute;\n  top: 0;\n  right: 0;\n  z-index: 2;\n  display: block;\n  width: 34px;\n  height: 34px;\n  line-height: 34px;\n  text-align: center;\n  pointer-events: none;\n}\n.input-lg + .form-control-feedback,\n.input-group-lg + .form-control-feedback,\n.form-group-lg .form-control + .form-control-feedback {\n  width: 46px;\n  height: 46px;\n  line-height: 46px;\n}\n.input-sm + .form-control-feedback,\n.input-group-sm + .form-control-feedback,\n.form-group-sm .form-control + .form-control-feedback {\n  width: 30px;\n  height: 30px;\n  line-height: 30px;\n}\n.has-success .help-block,\n.has-success .control-label,\n.has-success .radio,\n.has-success .checkbox,\n.has-success .radio-inline,\n.has-success .checkbox-inline,\n.has-success.radio label,\n.has-success.checkbox label,\n.has-success.radio-inline label,\n.has-success.checkbox-inline label {\n  color: #3c763d;\n}\n.has-success .form-control {\n  border-color: #3c763d;\n  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);\n  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);\n}\n.has-success .form-control:focus {\n  border-color: #2b542c;\n  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #67b168;\n  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #67b168;\n}\n.has-success .input-group-addon {\n  color: #3c763d;\n  border-color: #3c763d;\n  background-color: #dff0d8;\n}\n.has-success .form-control-feedback {\n  color: #3c763d;\n}\n.has-warning .help-block,\n.has-warning .control-label,\n.has-warning .radio,\n.has-warning .checkbox,\n.has-warning .radio-inline,\n.has-warning .checkbox-inline,\n.has-warning.radio label,\n.has-warning.checkbox label,\n.has-warning.radio-inline label,\n.has-warning.checkbox-inline label {\n  color: #8a6d3b;\n}\n.has-warning .form-control {\n  border-color: #8a6d3b;\n  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);\n  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);\n}\n.has-warning .form-control:focus {\n  border-color: #66512c;\n  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #c0a16b;\n  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #c0a16b;\n}\n.has-warning .input-group-addon {\n  color: #8a6d3b;\n  border-color: #8a6d3b;\n  background-color: #fcf8e3;\n}\n.has-warning .form-control-feedback {\n  color: #8a6d3b;\n}\n.has-error .help-block,\n.has-error .control-label,\n.has-error .radio,\n.has-error .checkbox,\n.has-error .radio-inline,\n.has-error .checkbox-inline,\n.has-error.radio label,\n.has-error.checkbox label,\n.has-error.radio-inline label,\n.has-error.checkbox-inline label {\n  color: #a94442;\n}\n.has-error .form-control {\n  border-color: #a94442;\n  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);\n  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);\n}\n.has-error .form-control:focus {\n  border-color: #843534;\n  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #ce8483;\n  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #ce8483;\n}\n.has-error .input-group-addon {\n  color: #a94442;\n  border-color: #a94442;\n  background-color: #f2dede;\n}\n.has-error .form-control-feedback {\n  color: #a94442;\n}\n.has-feedback label ~ .form-control-feedback {\n  top: 25px;\n}\n.has-feedback label.sr-only ~ .form-control-feedback {\n  top: 0;\n}\n.help-block {\n  display: block;\n  margin-top: 5px;\n  margin-bottom: 10px;\n  color: #737373;\n}\n@media (min-width: 768px) {\n  .form-inline .form-group {\n    display: inline-block;\n    margin-bottom: 0;\n    vertical-align: middle;\n  }\n  .form-inline .form-control {\n    display: inline-block;\n    width: auto;\n    vertical-align: middle;\n  }\n  .form-inline .form-control-static {\n    display: inline-block;\n  }\n  .form-inline .input-group {\n    display: inline-table;\n    vertical-align: middle;\n  }\n  .form-inline .input-group .input-group-addon,\n  .form-inline .input-group .input-group-btn,\n  .form-inline .input-group .form-control {\n    width: auto;\n  }\n  .form-inline .input-group > .form-control {\n    width: 100%;\n  }\n  .form-inline .control-label {\n    margin-bottom: 0;\n    vertical-align: middle;\n  }\n  .form-inline .radio,\n  .form-inline .checkbox {\n    display: inline-block;\n    margin-top: 0;\n    margin-bottom: 0;\n    vertical-align: middle;\n  }\n  .form-inline .radio label,\n  .form-inline .checkbox label {\n    padding-left: 0;\n  }\n  .form-inline .radio input[type=\"radio\"],\n  .form-inline .checkbox input[type=\"checkbox\"] {\n    position: relative;\n    margin-left: 0;\n  }\n  .form-inline .has-feedback .form-control-feedback {\n    top: 0;\n  }\n}\n.form-horizontal .radio,\n.form-horizontal .checkbox,\n.form-horizontal .radio-inline,\n.form-horizontal .checkbox-inline {\n  margin-top: 0;\n  margin-bottom: 0;\n  padding-top: 7px;\n}\n.form-horizontal .radio,\n.form-horizontal .checkbox {\n  min-height: 27px;\n}\n.form-horizontal .form-group {\n  margin-left: -15px;\n  margin-right: -15px;\n}\n@media (min-width: 768px) {\n  .form-horizontal .control-label {\n    text-align: right;\n    margin-bottom: 0;\n    padding-top: 7px;\n  }\n}\n.form-horizontal .has-feedback .form-control-feedback {\n  right: 15px;\n}\n@media (min-width: 768px) {\n  .form-horizontal .form-group-lg .control-label {\n    padding-top: 11px;\n    font-size: 18px;\n  }\n}\n@media (min-width: 768px) {\n  .form-horizontal .form-group-sm .control-label {\n    padding-top: 6px;\n    font-size: 12px;\n  }\n}\n.btn {\n  display: inline-block;\n  margin-bottom: 0;\n  font-weight: normal;\n  text-align: center;\n  vertical-align: middle;\n  touch-action: manipulation;\n  cursor: pointer;\n  background-image: none;\n  border: 1px solid transparent;\n  white-space: nowrap;\n  padding: 6px 12px;\n  font-size: 14px;\n  line-height: 1.42857143;\n  border-radius: 4px;\n  -webkit-user-select: none;\n  -moz-user-select: none;\n  -ms-user-select: none;\n  user-select: none;\n}\n.btn:focus,\n.btn:active:focus,\n.btn.active:focus,\n.btn.focus,\n.btn:active.focus,\n.btn.active.focus {\n  outline: 5px auto -webkit-focus-ring-color;\n  outline-offset: -2px;\n}\n.btn:hover,\n.btn:focus,\n.btn.focus {\n  color: #333;\n  text-decoration: none;\n}\n.btn:active,\n.btn.active {\n  outline: 0;\n  background-image: none;\n  -webkit-box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);\n  box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);\n}\n.btn.disabled,\n.btn[disabled],\nfieldset[disabled] .btn {\n  cursor: not-allowed;\n  opacity: 0.65;\n  filter: alpha(opacity=65);\n  -webkit-box-shadow: none;\n  box-shadow: none;\n}\na.btn.disabled,\nfieldset[disabled] a.btn {\n  pointer-events: none;\n}\n.btn-default {\n  color: #333;\n  background-color: #fff;\n  border-color: #ccc;\n}\n.btn-default:focus,\n.btn-default.focus {\n  color: #333;\n  background-color: #e6e6e6;\n  border-color: #8c8c8c;\n}\n.btn-default:hover {\n  color: #333;\n  background-color: #e6e6e6;\n  border-color: #adadad;\n}\n.btn-default:active,\n.btn-default.active,\n.open > .dropdown-toggle.btn-default {\n  color: #333;\n  background-color: #e6e6e6;\n  border-color: #adadad;\n}\n.btn-default:active:hover,\n.btn-default.active:hover,\n.open > .dropdown-toggle.btn-default:hover,\n.btn-default:active:focus,\n.btn-default.active:focus,\n.open > .dropdown-toggle.btn-default:focus,\n.btn-default:active.focus,\n.btn-default.active.focus,\n.open > .dropdown-toggle.btn-default.focus {\n  color: #333;\n  background-color: #d4d4d4;\n  border-color: #8c8c8c;\n}\n.btn-default:active,\n.btn-default.active,\n.open > .dropdown-toggle.btn-default {\n  background-image: none;\n}\n.btn-default.disabled:hover,\n.btn-default[disabled]:hover,\nfieldset[disabled] .btn-default:hover,\n.btn-default.disabled:focus,\n.btn-default[disabled]:focus,\nfieldset[disabled] .btn-default:focus,\n.btn-default.disabled.focus,\n.btn-default[disabled].focus,\nfieldset[disabled] .btn-default.focus {\n  background-color: #fff;\n  border-color: #ccc;\n}\n.btn-default .badge {\n  color: #fff;\n  background-color: #333;\n}\n.btn-primary {\n  color: #fff;\n  background-color: #00e5f0;\n  border-color: #00cdd7;\n}\n.btn-primary:focus,\n.btn-primary.focus {\n  color: #fff;\n  background-color: #00b4bd;\n  border-color: #005357;\n}\n.btn-primary:hover {\n  color: #fff;\n  background-color: #00b4bd;\n  border-color: #009299;\n}\n.btn-primary:active,\n.btn-primary.active,\n.open > .dropdown-toggle.btn-primary {\n  color: #fff;\n  background-color: #00b4bd;\n  border-color: #009299;\n}\n.btn-primary:active:hover,\n.btn-primary.active:hover,\n.open > .dropdown-toggle.btn-primary:hover,\n.btn-primary:active:focus,\n.btn-primary.active:focus,\n.open > .dropdown-toggle.btn-primary:focus,\n.btn-primary:active.focus,\n.btn-primary.active.focus,\n.open > .dropdown-toggle.btn-primary.focus {\n  color: #fff;\n  background-color: #009299;\n  border-color: #005357;\n}\n.btn-primary:active,\n.btn-primary.active,\n.open > .dropdown-toggle.btn-primary {\n  background-image: none;\n}\n.btn-primary.disabled:hover,\n.btn-primary[disabled]:hover,\nfieldset[disabled] .btn-primary:hover,\n.btn-primary.disabled:focus,\n.btn-primary[disabled]:focus,\nfieldset[disabled] .btn-primary:focus,\n.btn-primary.disabled.focus,\n.btn-primary[disabled].focus,\nfieldset[disabled] .btn-primary.focus {\n  background-color: #00e5f0;\n  border-color: #00cdd7;\n}\n.btn-primary .badge {\n  color: #00e5f0;\n  background-color: #fff;\n}\n.btn-success {\n  color: #fff;\n  background-color: #00e5f0;\n  border-color: #00cdd7;\n}\n.btn-success:focus,\n.btn-success.focus {\n  color: #fff;\n  background-color: #00b4bd;\n  border-color: #005357;\n}\n.btn-success:hover {\n  color: #fff;\n  background-color: #00b4bd;\n  border-color: #009299;\n}\n.btn-success:active,\n.btn-success.active,\n.open > .dropdown-toggle.btn-success {\n  color: #fff;\n  background-color: #00b4bd;\n  border-color: #009299;\n}\n.btn-success:active:hover,\n.btn-success.active:hover,\n.open > .dropdown-toggle.btn-success:hover,\n.btn-success:active:focus,\n.btn-success.active:focus,\n.open > .dropdown-toggle.btn-success:focus,\n.btn-success:active.focus,\n.btn-success.active.focus,\n.open > .dropdown-toggle.btn-success.focus {\n  color: #fff;\n  background-color: #009299;\n  border-color: #005357;\n}\n.btn-success:active,\n.btn-success.active,\n.open > .dropdown-toggle.btn-success {\n  background-image: none;\n}\n.btn-success.disabled:hover,\n.btn-success[disabled]:hover,\nfieldset[disabled] .btn-success:hover,\n.btn-success.disabled:focus,\n.btn-success[disabled]:focus,\nfieldset[disabled] .btn-success:focus,\n.btn-success.disabled.focus,\n.btn-success[disabled].focus,\nfieldset[disabled] .btn-success.focus {\n  background-color: #00e5f0;\n  border-color: #00cdd7;\n}\n.btn-success .badge {\n  color: #00e5f0;\n  background-color: #fff;\n}\n.btn-info {\n  color: #fff;\n  background-color: #00e5f0;\n  border-color: #00cdd7;\n}\n.btn-info:focus,\n.btn-info.focus {\n  color: #fff;\n  background-color: #00b4bd;\n  border-color: #005357;\n}\n.btn-info:hover {\n  color: #fff;\n  background-color: #00b4bd;\n  border-color: #009299;\n}\n.btn-info:active,\n.btn-info.active,\n.open > .dropdown-toggle.btn-info {\n  color: #fff;\n  background-color: #00b4bd;\n  border-color: #009299;\n}\n.btn-info:active:hover,\n.btn-info.active:hover,\n.open > .dropdown-toggle.btn-info:hover,\n.btn-info:active:focus,\n.btn-info.active:focus,\n.open > .dropdown-toggle.btn-info:focus,\n.btn-info:active.focus,\n.btn-info.active.focus,\n.open > .dropdown-toggle.btn-info.focus {\n  color: #fff;\n  background-color: #009299;\n  border-color: #005357;\n}\n.btn-info:active,\n.btn-info.active,\n.open > .dropdown-toggle.btn-info {\n  background-image: none;\n}\n.btn-info.disabled:hover,\n.btn-info[disabled]:hover,\nfieldset[disabled] .btn-info:hover,\n.btn-info.disabled:focus,\n.btn-info[disabled]:focus,\nfieldset[disabled] .btn-info:focus,\n.btn-info.disabled.focus,\n.btn-info[disabled].focus,\nfieldset[disabled] .btn-info.focus {\n  background-color: #00e5f0;\n  border-color: #00cdd7;\n}\n.btn-info .badge {\n  color: #00e5f0;\n  background-color: #fff;\n}\n.btn-warning {\n  color: #fff;\n  background-color: #977bf0;\n  border-color: #8564ed;\n}\n.btn-warning:focus,\n.btn-warning.focus {\n  color: #fff;\n  background-color: #734deb;\n  border-color: #3d15bd;\n}\n.btn-warning:hover {\n  color: #fff;\n  background-color: #734deb;\n  border-color: #5a2de7;\n}\n.btn-warning:active,\n.btn-warning.active,\n.open > .dropdown-toggle.btn-warning {\n  color: #fff;\n  background-color: #734deb;\n  border-color: #5a2de7;\n}\n.btn-warning:active:hover,\n.btn-warning.active:hover,\n.open > .dropdown-toggle.btn-warning:hover,\n.btn-warning:active:focus,\n.btn-warning.active:focus,\n.open > .dropdown-toggle.btn-warning:focus,\n.btn-warning:active.focus,\n.btn-warning.active.focus,\n.open > .dropdown-toggle.btn-warning.focus {\n  color: #fff;\n  background-color: #5a2de7;\n  border-color: #3d15bd;\n}\n.btn-warning:active,\n.btn-warning.active,\n.open > .dropdown-toggle.btn-warning {\n  background-image: none;\n}\n.btn-warning.disabled:hover,\n.btn-warning[disabled]:hover,\nfieldset[disabled] .btn-warning:hover,\n.btn-warning.disabled:focus,\n.btn-warning[disabled]:focus,\nfieldset[disabled] .btn-warning:focus,\n.btn-warning.disabled.focus,\n.btn-warning[disabled].focus,\nfieldset[disabled] .btn-warning.focus {\n  background-color: #977bf0;\n  border-color: #8564ed;\n}\n.btn-warning .badge {\n  color: #977bf0;\n  background-color: #fff;\n}\n.btn-danger {\n  color: #fff;\n  background-color: #e01f74;\n  border-color: #ca1c68;\n}\n.btn-danger:focus,\n.btn-danger.focus {\n  color: #fff;\n  background-color: #b3195d;\n  border-color: #5a0c2e;\n}\n.btn-danger:hover {\n  color: #fff;\n  background-color: #b3195d;\n  border-color: #94144d;\n}\n.btn-danger:active,\n.btn-danger.active,\n.open > .dropdown-toggle.btn-danger {\n  color: #fff;\n  background-color: #b3195d;\n  border-color: #94144d;\n}\n.btn-danger:active:hover,\n.btn-danger.active:hover,\n.open > .dropdown-toggle.btn-danger:hover,\n.btn-danger:active:focus,\n.btn-danger.active:focus,\n.open > .dropdown-toggle.btn-danger:focus,\n.btn-danger:active.focus,\n.btn-danger.active.focus,\n.open > .dropdown-toggle.btn-danger.focus {\n  color: #fff;\n  background-color: #94144d;\n  border-color: #5a0c2e;\n}\n.btn-danger:active,\n.btn-danger.active,\n.open > .dropdown-toggle.btn-danger {\n  background-image: none;\n}\n.btn-danger.disabled:hover,\n.btn-danger[disabled]:hover,\nfieldset[disabled] .btn-danger:hover,\n.btn-danger.disabled:focus,\n.btn-danger[disabled]:focus,\nfieldset[disabled] .btn-danger:focus,\n.btn-danger.disabled.focus,\n.btn-danger[disabled].focus,\nfieldset[disabled] .btn-danger.focus {\n  background-color: #e01f74;\n  border-color: #ca1c68;\n}\n.btn-danger .badge {\n  color: #e01f74;\n  background-color: #fff;\n}\n.btn-link {\n  color: #00e5f0;\n  font-weight: normal;\n  border-radius: 0;\n}\n.btn-link,\n.btn-link:active,\n.btn-link.active,\n.btn-link[disabled],\nfieldset[disabled] .btn-link {\n  background-color: transparent;\n  -webkit-box-shadow: none;\n  box-shadow: none;\n}\n.btn-link,\n.btn-link:hover,\n.btn-link:focus,\n.btn-link:active {\n  border-color: transparent;\n}\n.btn-link:hover,\n.btn-link:focus {\n  color: #009ca3;\n  text-decoration: underline;\n  background-color: transparent;\n}\n.btn-link[disabled]:hover,\nfieldset[disabled] .btn-link:hover,\n.btn-link[disabled]:focus,\nfieldset[disabled] .btn-link:focus {\n  color: #777777;\n  text-decoration: none;\n}\n.btn-lg,\n.btn-group-lg > .btn {\n  padding: 10px 16px;\n  font-size: 18px;\n  line-height: 1.3333333;\n  border-radius: 6px;\n}\n.btn-sm,\n.btn-group-sm > .btn {\n  padding: 5px 10px;\n  font-size: 12px;\n  line-height: 1.5;\n  border-radius: 3px;\n}\n.btn-xs,\n.btn-group-xs > .btn {\n  padding: 1px 5px;\n  font-size: 12px;\n  line-height: 1.5;\n  border-radius: 3px;\n}\n.btn-block {\n  display: block;\n  width: 100%;\n}\n.btn-block + .btn-block {\n  margin-top: 5px;\n}\ninput[type=\"submit\"].btn-block,\ninput[type=\"reset\"].btn-block,\ninput[type=\"button\"].btn-block {\n  width: 100%;\n}\n.fade {\n  opacity: 0;\n  -webkit-transition: opacity 0.15s linear;\n  -o-transition: opacity 0.15s linear;\n  transition: opacity 0.15s linear;\n}\n.fade.in {\n  opacity: 1;\n}\n.collapse {\n  display: none;\n}\n.collapse.in {\n  display: block;\n}\ntr.collapse.in {\n  display: table-row;\n}\ntbody.collapse.in {\n  display: table-row-group;\n}\n.collapsing {\n  position: relative;\n  height: 0;\n  overflow: hidden;\n  -webkit-transition-property: height, visibility;\n  transition-property: height, visibility;\n  -webkit-transition-duration: 0.35s;\n  transition-duration: 0.35s;\n  -webkit-transition-timing-function: ease;\n  transition-timing-function: ease;\n}\n.caret {\n  display: inline-block;\n  width: 0;\n  height: 0;\n  margin-left: 2px;\n  vertical-align: middle;\n  border-top: 4px dashed;\n  border-top: 4px solid \\9;\n  border-right: 4px solid transparent;\n  border-left: 4px solid transparent;\n}\n.dropup,\n.dropdown {\n  position: relative;\n}\n.dropdown-toggle:focus {\n  outline: 0;\n}\n.dropdown-menu {\n  position: absolute;\n  top: 100%;\n  left: 0;\n  z-index: 1000;\n  display: none;\n  float: left;\n  min-width: 160px;\n  padding: 5px 0;\n  margin: 2px 0 0;\n  list-style: none;\n  font-size: 14px;\n  text-align: left;\n  background-color: #fff;\n  border: 1px solid #ccc;\n  border: 1px solid rgba(0, 0, 0, 0.15);\n  border-radius: 4px;\n  -webkit-box-shadow: 0 6px 12px rgba(0, 0, 0, 0.175);\n  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.175);\n  background-clip: padding-box;\n}\n.dropdown-menu.pull-right {\n  right: 0;\n  left: auto;\n}\n.dropdown-menu .divider {\n  height: 1px;\n  margin: 9px 0;\n  overflow: hidden;\n  background-color: #e5e5e5;\n}\n.dropdown-menu > li > a {\n  display: block;\n  padding: 3px 20px;\n  clear: both;\n  font-weight: normal;\n  line-height: 1.42857143;\n  color: #333333;\n  white-space: nowrap;\n}\n.dropdown-menu > li > a:hover,\n.dropdown-menu > li > a:focus {\n  text-decoration: none;\n  color: #262626;\n  background-color: #f5f5f5;\n}\n.dropdown-menu > .active > a,\n.dropdown-menu > .active > a:hover,\n.dropdown-menu > .active > a:focus {\n  color: #fff;\n  text-decoration: none;\n  outline: 0;\n  background-color: #00e5f0;\n}\n.dropdown-menu > .disabled > a,\n.dropdown-menu > .disabled > a:hover,\n.dropdown-menu > .disabled > a:focus {\n  color: #777777;\n}\n.dropdown-menu > .disabled > a:hover,\n.dropdown-menu > .disabled > a:focus {\n  text-decoration: none;\n  background-color: transparent;\n  background-image: none;\n  filter: progid:DXImageTransform.Microsoft.gradient(enabled = false);\n  cursor: not-allowed;\n}\n.open > .dropdown-menu {\n  display: block;\n}\n.open > a {\n  outline: 0;\n}\n.dropdown-menu-right {\n  left: auto;\n  right: 0;\n}\n.dropdown-menu-left {\n  left: 0;\n  right: auto;\n}\n.dropdown-header {\n  display: block;\n  padding: 3px 20px;\n  font-size: 12px;\n  line-height: 1.42857143;\n  color: #777777;\n  white-space: nowrap;\n}\n.dropdown-backdrop {\n  position: fixed;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  top: 0;\n  z-index: 990;\n}\n.pull-right > .dropdown-menu {\n  right: 0;\n  left: auto;\n}\n.dropup .caret,\n.navbar-fixed-bottom .dropdown .caret {\n  border-top: 0;\n  border-bottom: 4px dashed;\n  border-bottom: 4px solid \\9;\n  content: \"\";\n}\n.dropup .dropdown-menu,\n.navbar-fixed-bottom .dropdown .dropdown-menu {\n  top: auto;\n  bottom: 100%;\n  margin-bottom: 2px;\n}\n@media (min-width: 768px) {\n  .navbar-right .dropdown-menu {\n    left: auto;\n    right: 0;\n  }\n  .navbar-right .dropdown-menu-left {\n    left: 0;\n    right: auto;\n  }\n}\n.btn-group,\n.btn-group-vertical {\n  position: relative;\n  display: inline-block;\n  vertical-align: middle;\n}\n.btn-group > .btn,\n.btn-group-vertical > .btn {\n  position: relative;\n  float: left;\n}\n.btn-group > .btn:hover,\n.btn-group-vertical > .btn:hover,\n.btn-group > .btn:focus,\n.btn-group-vertical > .btn:focus,\n.btn-group > .btn:active,\n.btn-group-vertical > .btn:active,\n.btn-group > .btn.active,\n.btn-group-vertical > .btn.active {\n  z-index: 2;\n}\n.btn-group .btn + .btn,\n.btn-group .btn + .btn-group,\n.btn-group .btn-group + .btn,\n.btn-group .btn-group + .btn-group {\n  margin-left: -1px;\n}\n.btn-toolbar {\n  margin-left: -5px;\n}\n.btn-toolbar .btn,\n.btn-toolbar .btn-group,\n.btn-toolbar .input-group {\n  float: left;\n}\n.btn-toolbar > .btn,\n.btn-toolbar > .btn-group,\n.btn-toolbar > .input-group {\n  margin-left: 5px;\n}\n.btn-group > .btn:not(:first-child):not(:last-child):not(.dropdown-toggle) {\n  border-radius: 0;\n}\n.btn-group > .btn:first-child {\n  margin-left: 0;\n}\n.btn-group > .btn:first-child:not(:last-child):not(.dropdown-toggle) {\n  border-bottom-right-radius: 0;\n  border-top-right-radius: 0;\n}\n.btn-group > .btn:last-child:not(:first-child),\n.btn-group > .dropdown-toggle:not(:first-child) {\n  border-bottom-left-radius: 0;\n  border-top-left-radius: 0;\n}\n.btn-group > .btn-group {\n  float: left;\n}\n.btn-group > .btn-group:not(:first-child):not(:last-child) > .btn {\n  border-radius: 0;\n}\n.btn-group > .btn-group:first-child:not(:last-child) > .btn:last-child,\n.btn-group > .btn-group:first-child:not(:last-child) > .dropdown-toggle {\n  border-bottom-right-radius: 0;\n  border-top-right-radius: 0;\n}\n.btn-group > .btn-group:last-child:not(:first-child) > .btn:first-child {\n  border-bottom-left-radius: 0;\n  border-top-left-radius: 0;\n}\n.btn-group .dropdown-toggle:active,\n.btn-group.open .dropdown-toggle {\n  outline: 0;\n}\n.btn-group > .btn + .dropdown-toggle {\n  padding-left: 8px;\n  padding-right: 8px;\n}\n.btn-group > .btn-lg + .dropdown-toggle {\n  padding-left: 12px;\n  padding-right: 12px;\n}\n.btn-group.open .dropdown-toggle {\n  -webkit-box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);\n  box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);\n}\n.btn-group.open .dropdown-toggle.btn-link {\n  -webkit-box-shadow: none;\n  box-shadow: none;\n}\n.btn .caret {\n  margin-left: 0;\n}\n.btn-lg .caret {\n  border-width: 5px 5px 0;\n  border-bottom-width: 0;\n}\n.dropup .btn-lg .caret {\n  border-width: 0 5px 5px;\n}\n.btn-group-vertical > .btn,\n.btn-group-vertical > .btn-group,\n.btn-group-vertical > .btn-group > .btn {\n  display: block;\n  float: none;\n  width: 100%;\n  max-width: 100%;\n}\n.btn-group-vertical > .btn-group > .btn {\n  float: none;\n}\n.btn-group-vertical > .btn + .btn,\n.btn-group-vertical > .btn + .btn-group,\n.btn-group-vertical > .btn-group + .btn,\n.btn-group-vertical > .btn-group + .btn-group {\n  margin-top: -1px;\n  margin-left: 0;\n}\n.btn-group-vertical > .btn:not(:first-child):not(:last-child) {\n  border-radius: 0;\n}\n.btn-group-vertical > .btn:first-child:not(:last-child) {\n  border-top-right-radius: 4px;\n  border-top-left-radius: 4px;\n  border-bottom-right-radius: 0;\n  border-bottom-left-radius: 0;\n}\n.btn-group-vertical > .btn:last-child:not(:first-child) {\n  border-top-right-radius: 0;\n  border-top-left-radius: 0;\n  border-bottom-right-radius: 4px;\n  border-bottom-left-radius: 4px;\n}\n.btn-group-vertical > .btn-group:not(:first-child):not(:last-child) > .btn {\n  border-radius: 0;\n}\n.btn-group-vertical > .btn-group:first-child:not(:last-child) > .btn:last-child,\n.btn-group-vertical > .btn-group:first-child:not(:last-child) > .dropdown-toggle {\n  border-bottom-right-radius: 0;\n  border-bottom-left-radius: 0;\n}\n.btn-group-vertical > .btn-group:last-child:not(:first-child) > .btn:first-child {\n  border-top-right-radius: 0;\n  border-top-left-radius: 0;\n}\n.btn-group-justified {\n  display: table;\n  width: 100%;\n  table-layout: fixed;\n  border-collapse: separate;\n}\n.btn-group-justified > .btn,\n.btn-group-justified > .btn-group {\n  float: none;\n  display: table-cell;\n  width: 1%;\n}\n.btn-group-justified > .btn-group .btn {\n  width: 100%;\n}\n.btn-group-justified > .btn-group .dropdown-menu {\n  left: auto;\n}\n[data-toggle=\"buttons\"] > .btn input[type=\"radio\"],\n[data-toggle=\"buttons\"] > .btn-group > .btn input[type=\"radio\"],\n[data-toggle=\"buttons\"] > .btn input[type=\"checkbox\"],\n[data-toggle=\"buttons\"] > .btn-group > .btn input[type=\"checkbox\"] {\n  position: absolute;\n  clip: rect(0, 0, 0, 0);\n  pointer-events: none;\n}\n.input-group {\n  position: relative;\n  display: table;\n  border-collapse: separate;\n}\n.input-group[class*=\"col-\"] {\n  float: none;\n  padding-left: 0;\n  padding-right: 0;\n}\n.input-group .form-control {\n  position: relative;\n  z-index: 2;\n  float: left;\n  width: 100%;\n  margin-bottom: 0;\n}\n.input-group .form-control:focus {\n  z-index: 3;\n}\n.input-group-lg > .form-control,\n.input-group-lg > .input-group-addon,\n.input-group-lg > .input-group-btn > .btn {\n  height: 46px;\n  padding: 10px 16px;\n  font-size: 18px;\n  line-height: 1.3333333;\n  border-radius: 6px;\n}\nselect.input-group-lg > .form-control,\nselect.input-group-lg > .input-group-addon,\nselect.input-group-lg > .input-group-btn > .btn {\n  height: 46px;\n  line-height: 46px;\n}\ntextarea.input-group-lg > .form-control,\ntextarea.input-group-lg > .input-group-addon,\ntextarea.input-group-lg > .input-group-btn > .btn,\nselect[multiple].input-group-lg > .form-control,\nselect[multiple].input-group-lg > .input-group-addon,\nselect[multiple].input-group-lg > .input-group-btn > .btn {\n  height: auto;\n}\n.input-group-sm > .form-control,\n.input-group-sm > .input-group-addon,\n.input-group-sm > .input-group-btn > .btn {\n  height: 30px;\n  padding: 5px 10px;\n  font-size: 12px;\n  line-height: 1.5;\n  border-radius: 3px;\n}\nselect.input-group-sm > .form-control,\nselect.input-group-sm > .input-group-addon,\nselect.input-group-sm > .input-group-btn > .btn {\n  height: 30px;\n  line-height: 30px;\n}\ntextarea.input-group-sm > .form-control,\ntextarea.input-group-sm > .input-group-addon,\ntextarea.input-group-sm > .input-group-btn > .btn,\nselect[multiple].input-group-sm > .form-control,\nselect[multiple].input-group-sm > .input-group-addon,\nselect[multiple].input-group-sm > .input-group-btn > .btn {\n  height: auto;\n}\n.input-group-addon,\n.input-group-btn,\n.input-group .form-control {\n  display: table-cell;\n}\n.input-group-addon:not(:first-child):not(:last-child),\n.input-group-btn:not(:first-child):not(:last-child),\n.input-group .form-control:not(:first-child):not(:last-child) {\n  border-radius: 0;\n}\n.input-group-addon,\n.input-group-btn {\n  width: 1%;\n  white-space: nowrap;\n  vertical-align: middle;\n}\n.input-group-addon {\n  padding: 6px 12px;\n  font-size: 14px;\n  font-weight: normal;\n  line-height: 1;\n  color: #555555;\n  text-align: center;\n  background-color: #eeeeee;\n  border: 1px solid #ccc;\n  border-radius: 4px;\n}\n.input-group-addon.input-sm {\n  padding: 5px 10px;\n  font-size: 12px;\n  border-radius: 3px;\n}\n.input-group-addon.input-lg {\n  padding: 10px 16px;\n  font-size: 18px;\n  border-radius: 6px;\n}\n.input-group-addon input[type=\"radio\"],\n.input-group-addon input[type=\"checkbox\"] {\n  margin-top: 0;\n}\n.input-group .form-control:first-child,\n.input-group-addon:first-child,\n.input-group-btn:first-child > .btn,\n.input-group-btn:first-child > .btn-group > .btn,\n.input-group-btn:first-child > .dropdown-toggle,\n.input-group-btn:last-child > .btn:not(:last-child):not(.dropdown-toggle),\n.input-group-btn:last-child > .btn-group:not(:last-child) > .btn {\n  border-bottom-right-radius: 0;\n  border-top-right-radius: 0;\n}\n.input-group-addon:first-child {\n  border-right: 0;\n}\n.input-group .form-control:last-child,\n.input-group-addon:last-child,\n.input-group-btn:last-child > .btn,\n.input-group-btn:last-child > .btn-group > .btn,\n.input-group-btn:last-child > .dropdown-toggle,\n.input-group-btn:first-child > .btn:not(:first-child),\n.input-group-btn:first-child > .btn-group:not(:first-child) > .btn {\n  border-bottom-left-radius: 0;\n  border-top-left-radius: 0;\n}\n.input-group-addon:last-child {\n  border-left: 0;\n}\n.input-group-btn {\n  position: relative;\n  font-size: 0;\n  white-space: nowrap;\n}\n.input-group-btn > .btn {\n  position: relative;\n}\n.input-group-btn > .btn + .btn {\n  margin-left: -1px;\n}\n.input-group-btn > .btn:hover,\n.input-group-btn > .btn:focus,\n.input-group-btn > .btn:active {\n  z-index: 2;\n}\n.input-group-btn:first-child > .btn,\n.input-group-btn:first-child > .btn-group {\n  margin-right: -1px;\n}\n.input-group-btn:last-child > .btn,\n.input-group-btn:last-child > .btn-group {\n  z-index: 2;\n  margin-left: -1px;\n}\n.nav {\n  margin-bottom: 0;\n  padding-left: 0;\n  list-style: none;\n}\n.nav > li {\n  position: relative;\n  display: block;\n}\n.nav > li > a {\n  position: relative;\n  display: block;\n  padding: 10px 15px;\n}\n.nav > li > a:hover,\n.nav > li > a:focus {\n  text-decoration: none;\n  background-color: #eeeeee;\n}\n.nav > li.disabled > a {\n  color: #777777;\n}\n.nav > li.disabled > a:hover,\n.nav > li.disabled > a:focus {\n  color: #777777;\n  text-decoration: none;\n  background-color: transparent;\n  cursor: not-allowed;\n}\n.nav .open > a,\n.nav .open > a:hover,\n.nav .open > a:focus {\n  background-color: #eeeeee;\n  border-color: #00e5f0;\n}\n.nav .nav-divider {\n  height: 1px;\n  margin: 9px 0;\n  overflow: hidden;\n  background-color: #e5e5e5;\n}\n.nav > li > a > img {\n  max-width: none;\n}\n.nav-tabs {\n  border-bottom: 1px solid #ddd;\n}\n.nav-tabs > li {\n  float: left;\n  margin-bottom: -1px;\n}\n.nav-tabs > li > a {\n  margin-right: 2px;\n  line-height: 1.42857143;\n  border: 1px solid transparent;\n  border-radius: 4px 4px 0 0;\n}\n.nav-tabs > li > a:hover {\n  border-color: #eeeeee #eeeeee #ddd;\n}\n.nav-tabs > li.active > a,\n.nav-tabs > li.active > a:hover,\n.nav-tabs > li.active > a:focus {\n  color: #555555;\n  background-color: #fff;\n  border: 1px solid #ddd;\n  border-bottom-color: transparent;\n  cursor: default;\n}\n.nav-tabs.nav-justified {\n  width: 100%;\n  border-bottom: 0;\n}\n.nav-tabs.nav-justified > li {\n  float: none;\n}\n.nav-tabs.nav-justified > li > a {\n  text-align: center;\n  margin-bottom: 5px;\n}\n.nav-tabs.nav-justified > .dropdown .dropdown-menu {\n  top: auto;\n  left: auto;\n}\n@media (min-width: 768px) {\n  .nav-tabs.nav-justified > li {\n    display: table-cell;\n    width: 1%;\n  }\n  .nav-tabs.nav-justified > li > a {\n    margin-bottom: 0;\n  }\n}\n.nav-tabs.nav-justified > li > a {\n  margin-right: 0;\n  border-radius: 4px;\n}\n.nav-tabs.nav-justified > .active > a,\n.nav-tabs.nav-justified > .active > a:hover,\n.nav-tabs.nav-justified > .active > a:focus {\n  border: 1px solid #ddd;\n}\n@media (min-width: 768px) {\n  .nav-tabs.nav-justified > li > a {\n    border-bottom: 1px solid #ddd;\n    border-radius: 4px 4px 0 0;\n  }\n  .nav-tabs.nav-justified > .active > a,\n  .nav-tabs.nav-justified > .active > a:hover,\n  .nav-tabs.nav-justified > .active > a:focus {\n    border-bottom-color: #fff;\n  }\n}\n.nav-pills > li {\n  float: left;\n}\n.nav-pills > li > a {\n  border-radius: 4px;\n}\n.nav-pills > li + li {\n  margin-left: 2px;\n}\n.nav-pills > li.active > a,\n.nav-pills > li.active > a:hover,\n.nav-pills > li.active > a:focus {\n  color: #fff;\n  background-color: #00e5f0;\n}\n.nav-stacked > li {\n  float: none;\n}\n.nav-stacked > li + li {\n  margin-top: 2px;\n  margin-left: 0;\n}\n.nav-justified {\n  width: 100%;\n}\n.nav-justified > li {\n  float: none;\n}\n.nav-justified > li > a {\n  text-align: center;\n  margin-bottom: 5px;\n}\n.nav-justified > .dropdown .dropdown-menu {\n  top: auto;\n  left: auto;\n}\n@media (min-width: 768px) {\n  .nav-justified > li {\n    display: table-cell;\n    width: 1%;\n  }\n  .nav-justified > li > a {\n    margin-bottom: 0;\n  }\n}\n.nav-tabs-justified {\n  border-bottom: 0;\n}\n.nav-tabs-justified > li > a {\n  margin-right: 0;\n  border-radius: 4px;\n}\n.nav-tabs-justified > .active > a,\n.nav-tabs-justified > .active > a:hover,\n.nav-tabs-justified > .active > a:focus {\n  border: 1px solid #ddd;\n}\n@media (min-width: 768px) {\n  .nav-tabs-justified > li > a {\n    border-bottom: 1px solid #ddd;\n    border-radius: 4px 4px 0 0;\n  }\n  .nav-tabs-justified > .active > a,\n  .nav-tabs-justified > .active > a:hover,\n  .nav-tabs-justified > .active > a:focus {\n    border-bottom-color: #fff;\n  }\n}\n.tab-content > .tab-pane {\n  display: none;\n}\n.tab-content > .active {\n  display: block;\n}\n.nav-tabs .dropdown-menu {\n  margin-top: -1px;\n  border-top-right-radius: 0;\n  border-top-left-radius: 0;\n}\n.navbar {\n  position: relative;\n  min-height: 50px;\n  margin-bottom: 20px;\n  border: 1px solid transparent;\n}\n@media (min-width: 768px) {\n  .navbar {\n    border-radius: 4px;\n  }\n}\n@media (min-width: 768px) {\n  .navbar-header {\n    float: left;\n  }\n}\n.navbar-collapse {\n  overflow-x: visible;\n  padding-right: 15px;\n  padding-left: 15px;\n  border-top: 1px solid transparent;\n  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1);\n  -webkit-overflow-scrolling: touch;\n}\n.navbar-collapse.in {\n  overflow-y: auto;\n}\n@media (min-width: 768px) {\n  .navbar-collapse {\n    width: auto;\n    border-top: 0;\n    box-shadow: none;\n  }\n  .navbar-collapse.collapse {\n    display: block !important;\n    height: auto !important;\n    padding-bottom: 0;\n    overflow: visible !important;\n  }\n  .navbar-collapse.in {\n    overflow-y: visible;\n  }\n  .navbar-fixed-top .navbar-collapse,\n  .navbar-static-top .navbar-collapse,\n  .navbar-fixed-bottom .navbar-collapse {\n    padding-left: 0;\n    padding-right: 0;\n  }\n}\n.navbar-fixed-top .navbar-collapse,\n.navbar-fixed-bottom .navbar-collapse {\n  max-height: 340px;\n}\n@media (max-device-width: 480px) and (orientation: landscape) {\n  .navbar-fixed-top .navbar-collapse,\n  .navbar-fixed-bottom .navbar-collapse {\n    max-height: 200px;\n  }\n}\n.container > .navbar-header,\n.container-fluid > .navbar-header,\n.container > .navbar-collapse,\n.container-fluid > .navbar-collapse {\n  margin-right: -15px;\n  margin-left: -15px;\n}\n@media (min-width: 768px) {\n  .container > .navbar-header,\n  .container-fluid > .navbar-header,\n  .container > .navbar-collapse,\n  .container-fluid > .navbar-collapse {\n    margin-right: 0;\n    margin-left: 0;\n  }\n}\n.navbar-static-top {\n  z-index: 1000;\n  border-width: 0 0 1px;\n}\n@media (min-width: 768px) {\n  .navbar-static-top {\n    border-radius: 0;\n  }\n}\n.navbar-fixed-top,\n.navbar-fixed-bottom {\n  position: fixed;\n  right: 0;\n  left: 0;\n  z-index: 1030;\n}\n@media (min-width: 768px) {\n  .navbar-fixed-top,\n  .navbar-fixed-bottom {\n    border-radius: 0;\n  }\n}\n.navbar-fixed-top {\n  top: 0;\n  border-width: 0 0 1px;\n}\n.navbar-fixed-bottom {\n  bottom: 0;\n  margin-bottom: 0;\n  border-width: 1px 0 0;\n}\n.navbar-brand {\n  float: left;\n  padding: 15px 15px;\n  font-size: 18px;\n  line-height: 20px;\n  height: 50px;\n}\n.navbar-brand:hover,\n.navbar-brand:focus {\n  text-decoration: none;\n}\n.navbar-brand > img {\n  display: block;\n}\n@media (min-width: 768px) {\n  .navbar > .container .navbar-brand,\n  .navbar > .container-fluid .navbar-brand {\n    margin-left: -15px;\n  }\n}\n.navbar-toggle {\n  position: relative;\n  float: right;\n  margin-right: 15px;\n  padding: 9px 10px;\n  margin-top: 8px;\n  margin-bottom: 8px;\n  background-color: transparent;\n  background-image: none;\n  border: 1px solid transparent;\n  border-radius: 4px;\n}\n.navbar-toggle:focus {\n  outline: 0;\n}\n.navbar-toggle .icon-bar {\n  display: block;\n  width: 22px;\n  height: 2px;\n  border-radius: 1px;\n}\n.navbar-toggle .icon-bar + .icon-bar {\n  margin-top: 4px;\n}\n@media (min-width: 768px) {\n  .navbar-toggle {\n    display: none;\n  }\n}\n.navbar-nav {\n  margin: 7.5px -15px;\n}\n.navbar-nav > li > a {\n  padding-top: 10px;\n  padding-bottom: 10px;\n  line-height: 20px;\n}\n@media (max-width: 767px) {\n  .navbar-nav .open .dropdown-menu {\n    position: static;\n    float: none;\n    width: auto;\n    margin-top: 0;\n    background-color: transparent;\n    border: 0;\n    box-shadow: none;\n  }\n  .navbar-nav .open .dropdown-menu > li > a,\n  .navbar-nav .open .dropdown-menu .dropdown-header {\n    padding: 5px 15px 5px 25px;\n  }\n  .navbar-nav .open .dropdown-menu > li > a {\n    line-height: 20px;\n  }\n  .navbar-nav .open .dropdown-menu > li > a:hover,\n  .navbar-nav .open .dropdown-menu > li > a:focus {\n    background-image: none;\n  }\n}\n@media (min-width: 768px) {\n  .navbar-nav {\n    float: left;\n    margin: 0;\n  }\n  .navbar-nav > li {\n    float: left;\n  }\n  .navbar-nav > li > a {\n    padding-top: 15px;\n    padding-bottom: 15px;\n  }\n}\n.navbar-form {\n  margin-left: -15px;\n  margin-right: -15px;\n  padding: 10px 15px;\n  border-top: 1px solid transparent;\n  border-bottom: 1px solid transparent;\n  -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 1px 0 rgba(255, 255, 255, 0.1);\n  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 1px 0 rgba(255, 255, 255, 0.1);\n  margin-top: 8px;\n  margin-bottom: 8px;\n}\n@media (min-width: 768px) {\n  .navbar-form .form-group {\n    display: inline-block;\n    margin-bottom: 0;\n    vertical-align: middle;\n  }\n  .navbar-form .form-control {\n    display: inline-block;\n    width: auto;\n    vertical-align: middle;\n  }\n  .navbar-form .form-control-static {\n    display: inline-block;\n  }\n  .navbar-form .input-group {\n    display: inline-table;\n    vertical-align: middle;\n  }\n  .navbar-form .input-group .input-group-addon,\n  .navbar-form .input-group .input-group-btn,\n  .navbar-form .input-group .form-control {\n    width: auto;\n  }\n  .navbar-form .input-group > .form-control {\n    width: 100%;\n  }\n  .navbar-form .control-label {\n    margin-bottom: 0;\n    vertical-align: middle;\n  }\n  .navbar-form .radio,\n  .navbar-form .checkbox {\n    display: inline-block;\n    margin-top: 0;\n    margin-bottom: 0;\n    vertical-align: middle;\n  }\n  .navbar-form .radio label,\n  .navbar-form .checkbox label {\n    padding-left: 0;\n  }\n  .navbar-form .radio input[type=\"radio\"],\n  .navbar-form .checkbox input[type=\"checkbox\"] {\n    position: relative;\n    margin-left: 0;\n  }\n  .navbar-form .has-feedback .form-control-feedback {\n    top: 0;\n  }\n}\n@media (max-width: 767px) {\n  .navbar-form .form-group {\n    margin-bottom: 5px;\n  }\n  .navbar-form .form-group:last-child {\n    margin-bottom: 0;\n  }\n}\n@media (min-width: 768px) {\n  .navbar-form {\n    width: auto;\n    border: 0;\n    margin-left: 0;\n    margin-right: 0;\n    padding-top: 0;\n    padding-bottom: 0;\n    -webkit-box-shadow: none;\n    box-shadow: none;\n  }\n}\n.navbar-nav > li > .dropdown-menu {\n  margin-top: 0;\n  border-top-right-radius: 0;\n  border-top-left-radius: 0;\n}\n.navbar-fixed-bottom .navbar-nav > li > .dropdown-menu {\n  margin-bottom: 0;\n  border-top-right-radius: 4px;\n  border-top-left-radius: 4px;\n  border-bottom-right-radius: 0;\n  border-bottom-left-radius: 0;\n}\n.navbar-btn {\n  margin-top: 8px;\n  margin-bottom: 8px;\n}\n.navbar-btn.btn-sm {\n  margin-top: 10px;\n  margin-bottom: 10px;\n}\n.navbar-btn.btn-xs {\n  margin-top: 14px;\n  margin-bottom: 14px;\n}\n.navbar-text {\n  margin-top: 15px;\n  margin-bottom: 15px;\n}\n@media (min-width: 768px) {\n  .navbar-text {\n    float: left;\n    margin-left: 15px;\n    margin-right: 15px;\n  }\n}\n@media (min-width: 768px) {\n  .navbar-left {\n    float: left !important;\n  }\n  .navbar-right {\n    float: right !important;\n    margin-right: -15px;\n  }\n  .navbar-right ~ .navbar-right {\n    margin-right: 0;\n  }\n}\n.navbar-default {\n  background-color: #f8f8f8;\n  border-color: #e7e7e7;\n}\n.navbar-default .navbar-brand {\n  color: #777;\n}\n.navbar-default .navbar-brand:hover,\n.navbar-default .navbar-brand:focus {\n  color: #5e5e5e;\n  background-color: transparent;\n}\n.navbar-default .navbar-text {\n  color: #777;\n}\n.navbar-default .navbar-nav > li > a {\n  color: #777;\n}\n.navbar-default .navbar-nav > li > a:hover,\n.navbar-default .navbar-nav > li > a:focus {\n  color: #333;\n  background-color: transparent;\n}\n.navbar-default .navbar-nav > .active > a,\n.navbar-default .navbar-nav > .active > a:hover,\n.navbar-default .navbar-nav > .active > a:focus {\n  color: #555;\n  background-color: #e7e7e7;\n}\n.navbar-default .navbar-nav > .disabled > a,\n.navbar-default .navbar-nav > .disabled > a:hover,\n.navbar-default .navbar-nav > .disabled > a:focus {\n  color: #ccc;\n  background-color: transparent;\n}\n.navbar-default .navbar-toggle {\n  border-color: #ddd;\n}\n.navbar-default .navbar-toggle:hover,\n.navbar-default .navbar-toggle:focus {\n  background-color: #ddd;\n}\n.navbar-default .navbar-toggle .icon-bar {\n  background-color: #888;\n}\n.navbar-default .navbar-collapse,\n.navbar-default .navbar-form {\n  border-color: #e7e7e7;\n}\n.navbar-default .navbar-nav > .open > a,\n.navbar-default .navbar-nav > .open > a:hover,\n.navbar-default .navbar-nav > .open > a:focus {\n  background-color: #e7e7e7;\n  color: #555;\n}\n@media (max-width: 767px) {\n  .navbar-default .navbar-nav .open .dropdown-menu > li > a {\n    color: #777;\n  }\n  .navbar-default .navbar-nav .open .dropdown-menu > li > a:hover,\n  .navbar-default .navbar-nav .open .dropdown-menu > li > a:focus {\n    color: #333;\n    background-color: transparent;\n  }\n  .navbar-default .navbar-nav .open .dropdown-menu > .active > a,\n  .navbar-default .navbar-nav .open .dropdown-menu > .active > a:hover,\n  .navbar-default .navbar-nav .open .dropdown-menu > .active > a:focus {\n    color: #555;\n    background-color: #e7e7e7;\n  }\n  .navbar-default .navbar-nav .open .dropdown-menu > .disabled > a,\n  .navbar-default .navbar-nav .open .dropdown-menu > .disabled > a:hover,\n  .navbar-default .navbar-nav .open .dropdown-menu > .disabled > a:focus {\n    color: #ccc;\n    background-color: transparent;\n  }\n}\n.navbar-default .navbar-link {\n  color: #777;\n}\n.navbar-default .navbar-link:hover {\n  color: #333;\n}\n.navbar-default .btn-link {\n  color: #777;\n}\n.navbar-default .btn-link:hover,\n.navbar-default .btn-link:focus {\n  color: #333;\n}\n.navbar-default .btn-link[disabled]:hover,\nfieldset[disabled] .navbar-default .btn-link:hover,\n.navbar-default .btn-link[disabled]:focus,\nfieldset[disabled] .navbar-default .btn-link:focus {\n  color: #ccc;\n}\n.navbar-inverse {\n  background-color: #222;\n  border-color: #080808;\n}\n.navbar-inverse .navbar-brand {\n  color: #9d9d9d;\n}\n.navbar-inverse .navbar-brand:hover,\n.navbar-inverse .navbar-brand:focus {\n  color: #fff;\n  background-color: transparent;\n}\n.navbar-inverse .navbar-text {\n  color: #9d9d9d;\n}\n.navbar-inverse .navbar-nav > li > a {\n  color: #9d9d9d;\n}\n.navbar-inverse .navbar-nav > li > a:hover,\n.navbar-inverse .navbar-nav > li > a:focus {\n  color: #fff;\n  background-color: transparent;\n}\n.navbar-inverse .navbar-nav > .active > a,\n.navbar-inverse .navbar-nav > .active > a:hover,\n.navbar-inverse .navbar-nav > .active > a:focus {\n  color: #fff;\n  background-color: #080808;\n}\n.navbar-inverse .navbar-nav > .disabled > a,\n.navbar-inverse .navbar-nav > .disabled > a:hover,\n.navbar-inverse .navbar-nav > .disabled > a:focus {\n  color: #444;\n  background-color: transparent;\n}\n.navbar-inverse .navbar-toggle {\n  border-color: #333;\n}\n.navbar-inverse .navbar-toggle:hover,\n.navbar-inverse .navbar-toggle:focus {\n  background-color: #333;\n}\n.navbar-inverse .navbar-toggle .icon-bar {\n  background-color: #fff;\n}\n.navbar-inverse .navbar-collapse,\n.navbar-inverse .navbar-form {\n  border-color: #101010;\n}\n.navbar-inverse .navbar-nav > .open > a,\n.navbar-inverse .navbar-nav > .open > a:hover,\n.navbar-inverse .navbar-nav > .open > a:focus {\n  background-color: #080808;\n  color: #fff;\n}\n@media (max-width: 767px) {\n  .navbar-inverse .navbar-nav .open .dropdown-menu > .dropdown-header {\n    border-color: #080808;\n  }\n  .navbar-inverse .navbar-nav .open .dropdown-menu .divider {\n    background-color: #080808;\n  }\n  .navbar-inverse .navbar-nav .open .dropdown-menu > li > a {\n    color: #9d9d9d;\n  }\n  .navbar-inverse .navbar-nav .open .dropdown-menu > li > a:hover,\n  .navbar-inverse .navbar-nav .open .dropdown-menu > li > a:focus {\n    color: #fff;\n    background-color: transparent;\n  }\n  .navbar-inverse .navbar-nav .open .dropdown-menu > .active > a,\n  .navbar-inverse .navbar-nav .open .dropdown-menu > .active > a:hover,\n  .navbar-inverse .navbar-nav .open .dropdown-menu > .active > a:focus {\n    color: #fff;\n    background-color: #080808;\n  }\n  .navbar-inverse .navbar-nav .open .dropdown-menu > .disabled > a,\n  .navbar-inverse .navbar-nav .open .dropdown-menu > .disabled > a:hover,\n  .navbar-inverse .navbar-nav .open .dropdown-menu > .disabled > a:focus {\n    color: #444;\n    background-color: transparent;\n  }\n}\n.navbar-inverse .navbar-link {\n  color: #9d9d9d;\n}\n.navbar-inverse .navbar-link:hover {\n  color: #fff;\n}\n.navbar-inverse .btn-link {\n  color: #9d9d9d;\n}\n.navbar-inverse .btn-link:hover,\n.navbar-inverse .btn-link:focus {\n  color: #fff;\n}\n.navbar-inverse .btn-link[disabled]:hover,\nfieldset[disabled] .navbar-inverse .btn-link:hover,\n.navbar-inverse .btn-link[disabled]:focus,\nfieldset[disabled] .navbar-inverse .btn-link:focus {\n  color: #444;\n}\n.breadcrumb {\n  padding: 8px 15px;\n  margin-bottom: 20px;\n  list-style: none;\n  background-color: #f5f5f5;\n  border-radius: 4px;\n}\n.breadcrumb > li {\n  display: inline-block;\n}\n.breadcrumb > li + li:before {\n  content: \"/\\00a0\";\n  padding: 0 5px;\n  color: #ccc;\n}\n.breadcrumb > .active {\n  color: #777777;\n}\n.pagination {\n  display: inline-block;\n  padding-left: 0;\n  margin: 20px 0;\n  border-radius: 4px;\n}\n.pagination > li {\n  display: inline;\n}\n.pagination > li > a,\n.pagination > li > span {\n  position: relative;\n  float: left;\n  padding: 6px 12px;\n  line-height: 1.42857143;\n  text-decoration: none;\n  color: #00e5f0;\n  background-color: #fff;\n  border: 1px solid #ddd;\n  margin-left: -1px;\n}\n.pagination > li:first-child > a,\n.pagination > li:first-child > span {\n  margin-left: 0;\n  border-bottom-left-radius: 4px;\n  border-top-left-radius: 4px;\n}\n.pagination > li:last-child > a,\n.pagination > li:last-child > span {\n  border-bottom-right-radius: 4px;\n  border-top-right-radius: 4px;\n}\n.pagination > li > a:hover,\n.pagination > li > span:hover,\n.pagination > li > a:focus,\n.pagination > li > span:focus {\n  z-index: 2;\n  color: #009ca3;\n  background-color: #eeeeee;\n  border-color: #ddd;\n}\n.pagination > .active > a,\n.pagination > .active > span,\n.pagination > .active > a:hover,\n.pagination > .active > span:hover,\n.pagination > .active > a:focus,\n.pagination > .active > span:focus {\n  z-index: 3;\n  color: #fff;\n  background-color: #00e5f0;\n  border-color: #00e5f0;\n  cursor: default;\n}\n.pagination > .disabled > span,\n.pagination > .disabled > span:hover,\n.pagination > .disabled > span:focus,\n.pagination > .disabled > a,\n.pagination > .disabled > a:hover,\n.pagination > .disabled > a:focus {\n  color: #777777;\n  background-color: #fff;\n  border-color: #ddd;\n  cursor: not-allowed;\n}\n.pagination-lg > li > a,\n.pagination-lg > li > span {\n  padding: 10px 16px;\n  font-size: 18px;\n  line-height: 1.3333333;\n}\n.pagination-lg > li:first-child > a,\n.pagination-lg > li:first-child > span {\n  border-bottom-left-radius: 6px;\n  border-top-left-radius: 6px;\n}\n.pagination-lg > li:last-child > a,\n.pagination-lg > li:last-child > span {\n  border-bottom-right-radius: 6px;\n  border-top-right-radius: 6px;\n}\n.pagination-sm > li > a,\n.pagination-sm > li > span {\n  padding: 5px 10px;\n  font-size: 12px;\n  line-height: 1.5;\n}\n.pagination-sm > li:first-child > a,\n.pagination-sm > li:first-child > span {\n  border-bottom-left-radius: 3px;\n  border-top-left-radius: 3px;\n}\n.pagination-sm > li:last-child > a,\n.pagination-sm > li:last-child > span {\n  border-bottom-right-radius: 3px;\n  border-top-right-radius: 3px;\n}\n.pager {\n  padding-left: 0;\n  margin: 20px 0;\n  list-style: none;\n  text-align: center;\n}\n.pager li {\n  display: inline;\n}\n.pager li > a,\n.pager li > span {\n  display: inline-block;\n  padding: 5px 14px;\n  background-color: #fff;\n  border: 1px solid #ddd;\n  border-radius: 15px;\n}\n.pager li > a:hover,\n.pager li > a:focus {\n  text-decoration: none;\n  background-color: #eeeeee;\n}\n.pager .next > a,\n.pager .next > span {\n  float: right;\n}\n.pager .previous > a,\n.pager .previous > span {\n  float: left;\n}\n.pager .disabled > a,\n.pager .disabled > a:hover,\n.pager .disabled > a:focus,\n.pager .disabled > span {\n  color: #777777;\n  background-color: #fff;\n  cursor: not-allowed;\n}\n.label {\n  display: inline;\n  padding: .2em .6em .3em;\n  font-size: 75%;\n  font-weight: bold;\n  line-height: 1;\n  color: #fff;\n  text-align: center;\n  white-space: nowrap;\n  vertical-align: baseline;\n  border-radius: .25em;\n}\na.label:hover,\na.label:focus {\n  color: #fff;\n  text-decoration: none;\n  cursor: pointer;\n}\n.label:empty {\n  display: none;\n}\n.btn .label {\n  position: relative;\n  top: -1px;\n}\n.label-default {\n  background-color: #777777;\n}\n.label-default[href]:hover,\n.label-default[href]:focus {\n  background-color: #5e5e5e;\n}\n.label-primary {\n  background-color: #00e5f0;\n}\n.label-primary[href]:hover,\n.label-primary[href]:focus {\n  background-color: #00b4bd;\n}\n.label-success {\n  background-color: #00e5f0;\n}\n.label-success[href]:hover,\n.label-success[href]:focus {\n  background-color: #00b4bd;\n}\n.label-info {\n  background-color: #00e5f0;\n}\n.label-info[href]:hover,\n.label-info[href]:focus {\n  background-color: #00b4bd;\n}\n.label-warning {\n  background-color: #977bf0;\n}\n.label-warning[href]:hover,\n.label-warning[href]:focus {\n  background-color: #734deb;\n}\n.label-danger {\n  background-color: #e01f74;\n}\n.label-danger[href]:hover,\n.label-danger[href]:focus {\n  background-color: #b3195d;\n}\n.badge {\n  display: inline-block;\n  min-width: 10px;\n  padding: 3px 7px;\n  font-size: 12px;\n  font-weight: bold;\n  color: #fff;\n  line-height: 1;\n  vertical-align: middle;\n  white-space: nowrap;\n  text-align: center;\n  background-color: #777777;\n  border-radius: 10px;\n}\n.badge:empty {\n  display: none;\n}\n.btn .badge {\n  position: relative;\n  top: -1px;\n}\n.btn-xs .badge,\n.btn-group-xs > .btn .badge {\n  top: 0;\n  padding: 1px 5px;\n}\na.badge:hover,\na.badge:focus {\n  color: #fff;\n  text-decoration: none;\n  cursor: pointer;\n}\n.list-group-item.active > .badge,\n.nav-pills > .active > a > .badge {\n  color: #00e5f0;\n  background-color: #fff;\n}\n.list-group-item > .badge {\n  float: right;\n}\n.list-group-item > .badge + .badge {\n  margin-right: 5px;\n}\n.nav-pills > li > a > .badge {\n  margin-left: 3px;\n}\n.jumbotron {\n  padding-top: 30px;\n  padding-bottom: 30px;\n  margin-bottom: 30px;\n  color: inherit;\n  background-color: #eeeeee;\n}\n.jumbotron h1,\n.jumbotron .h1 {\n  color: inherit;\n}\n.jumbotron p {\n  margin-bottom: 15px;\n  font-size: 21px;\n  font-weight: 200;\n}\n.jumbotron > hr {\n  border-top-color: #d5d5d5;\n}\n.container .jumbotron,\n.container-fluid .jumbotron {\n  border-radius: 6px;\n  padding-left: 15px;\n  padding-right: 15px;\n}\n.jumbotron .container {\n  max-width: 100%;\n}\n@media screen and (min-width: 768px) {\n  .jumbotron {\n    padding-top: 48px;\n    padding-bottom: 48px;\n  }\n  .container .jumbotron,\n  .container-fluid .jumbotron {\n    padding-left: 60px;\n    padding-right: 60px;\n  }\n  .jumbotron h1,\n  .jumbotron .h1 {\n    font-size: 63px;\n  }\n}\n.thumbnail {\n  display: block;\n  padding: 4px;\n  margin-bottom: 20px;\n  line-height: 1.42857143;\n  background-color: #fff;\n  border: 1px solid #ddd;\n  border-radius: 4px;\n  -webkit-transition: border 0.2s ease-in-out;\n  -o-transition: border 0.2s ease-in-out;\n  transition: border 0.2s ease-in-out;\n}\n.thumbnail > img,\n.thumbnail a > img {\n  margin-left: auto;\n  margin-right: auto;\n}\na.thumbnail:hover,\na.thumbnail:focus,\na.thumbnail.active {\n  border-color: #00e5f0;\n}\n.thumbnail .caption {\n  padding: 9px;\n  color: #333333;\n}\n.alert {\n  padding: 15px;\n  margin-bottom: 20px;\n  border: 1px solid transparent;\n  border-radius: 4px;\n}\n.alert h4 {\n  margin-top: 0;\n  color: inherit;\n}\n.alert .alert-link {\n  font-weight: bold;\n}\n.alert > p,\n.alert > ul {\n  margin-bottom: 0;\n}\n.alert > p + p {\n  margin-top: 5px;\n}\n.alert-dismissable,\n.alert-dismissible {\n  padding-right: 35px;\n}\n.alert-dismissable .close,\n.alert-dismissible .close {\n  position: relative;\n  top: -2px;\n  right: -21px;\n  color: inherit;\n}\n.alert-success {\n  background-color: #dff0d8;\n  border-color: #d6e9c6;\n  color: #3c763d;\n}\n.alert-success hr {\n  border-top-color: #c9e2b3;\n}\n.alert-success .alert-link {\n  color: #2b542c;\n}\n.alert-info {\n  background-color: #d9edf7;\n  border-color: #bce8f1;\n  color: #31708f;\n}\n.alert-info hr {\n  border-top-color: #a6e1ec;\n}\n.alert-info .alert-link {\n  color: #245269;\n}\n.alert-warning {\n  background-color: #fcf8e3;\n  border-color: #faebcc;\n  color: #8a6d3b;\n}\n.alert-warning hr {\n  border-top-color: #f7e1b5;\n}\n.alert-warning .alert-link {\n  color: #66512c;\n}\n.alert-danger {\n  background-color: #f2dede;\n  border-color: #ebccd1;\n  color: #a94442;\n}\n.alert-danger hr {\n  border-top-color: #e4b9c0;\n}\n.alert-danger .alert-link {\n  color: #843534;\n}\n@-webkit-keyframes progress-bar-stripes {\n  from {\n    background-position: 40px 0;\n  }\n  to {\n    background-position: 0 0;\n  }\n}\n@keyframes progress-bar-stripes {\n  from {\n    background-position: 40px 0;\n  }\n  to {\n    background-position: 0 0;\n  }\n}\n.progress {\n  overflow: hidden;\n  height: 20px;\n  margin-bottom: 20px;\n  background-color: #f5f5f5;\n  border-radius: 4px;\n  -webkit-box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);\n  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);\n}\n.progress-bar {\n  float: left;\n  width: 0%;\n  height: 100%;\n  font-size: 12px;\n  line-height: 20px;\n  color: #fff;\n  text-align: center;\n  background-color: #00e5f0;\n  -webkit-box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.15);\n  box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.15);\n  -webkit-transition: width 0.6s ease;\n  -o-transition: width 0.6s ease;\n  transition: width 0.6s ease;\n}\n.progress-striped .progress-bar,\n.progress-bar-striped {\n  background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-size: 40px 40px;\n}\n.progress.active .progress-bar,\n.progress-bar.active {\n  -webkit-animation: progress-bar-stripes 2s linear infinite;\n  -o-animation: progress-bar-stripes 2s linear infinite;\n  animation: progress-bar-stripes 2s linear infinite;\n}\n.progress-bar-success {\n  background-color: #00e5f0;\n}\n.progress-striped .progress-bar-success {\n  background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n}\n.progress-bar-info {\n  background-color: #00e5f0;\n}\n.progress-striped .progress-bar-info {\n  background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n}\n.progress-bar-warning {\n  background-color: #977bf0;\n}\n.progress-striped .progress-bar-warning {\n  background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n}\n.progress-bar-danger {\n  background-color: #e01f74;\n}\n.progress-striped .progress-bar-danger {\n  background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n}\n.media {\n  margin-top: 15px;\n}\n.media:first-child {\n  margin-top: 0;\n}\n.media,\n.media-body {\n  zoom: 1;\n  overflow: hidden;\n}\n.media-body {\n  width: 10000px;\n}\n.media-object {\n  display: block;\n}\n.media-object.img-thumbnail {\n  max-width: none;\n}\n.media-right,\n.media > .pull-right {\n  padding-left: 10px;\n}\n.media-left,\n.media > .pull-left {\n  padding-right: 10px;\n}\n.media-left,\n.media-right,\n.media-body {\n  display: table-cell;\n  vertical-align: top;\n}\n.media-middle {\n  vertical-align: middle;\n}\n.media-bottom {\n  vertical-align: bottom;\n}\n.media-heading {\n  margin-top: 0;\n  margin-bottom: 5px;\n}\n.media-list {\n  padding-left: 0;\n  list-style: none;\n}\n.list-group {\n  margin-bottom: 20px;\n  padding-left: 0;\n}\n.list-group-item {\n  position: relative;\n  display: block;\n  padding: 10px 15px;\n  margin-bottom: -1px;\n  background-color: #fff;\n  border: 1px solid #ddd;\n}\n.list-group-item:first-child {\n  border-top-right-radius: 4px;\n  border-top-left-radius: 4px;\n}\n.list-group-item:last-child {\n  margin-bottom: 0;\n  border-bottom-right-radius: 4px;\n  border-bottom-left-radius: 4px;\n}\na.list-group-item,\nbutton.list-group-item {\n  color: #555;\n}\na.list-group-item .list-group-item-heading,\nbutton.list-group-item .list-group-item-heading {\n  color: #333;\n}\na.list-group-item:hover,\nbutton.list-group-item:hover,\na.list-group-item:focus,\nbutton.list-group-item:focus {\n  text-decoration: none;\n  color: #555;\n  background-color: #f5f5f5;\n}\nbutton.list-group-item {\n  width: 100%;\n  text-align: left;\n}\n.list-group-item.disabled,\n.list-group-item.disabled:hover,\n.list-group-item.disabled:focus {\n  background-color: #eeeeee;\n  color: #777777;\n  cursor: not-allowed;\n}\n.list-group-item.disabled .list-group-item-heading,\n.list-group-item.disabled:hover .list-group-item-heading,\n.list-group-item.disabled:focus .list-group-item-heading {\n  color: inherit;\n}\n.list-group-item.disabled .list-group-item-text,\n.list-group-item.disabled:hover .list-group-item-text,\n.list-group-item.disabled:focus .list-group-item-text {\n  color: #777777;\n}\n.list-group-item.active,\n.list-group-item.active:hover,\n.list-group-item.active:focus {\n  z-index: 2;\n  color: #fff;\n  background-color: #00e5f0;\n  border-color: #00e5f0;\n}\n.list-group-item.active .list-group-item-heading,\n.list-group-item.active:hover .list-group-item-heading,\n.list-group-item.active:focus .list-group-item-heading,\n.list-group-item.active .list-group-item-heading > small,\n.list-group-item.active:hover .list-group-item-heading > small,\n.list-group-item.active:focus .list-group-item-heading > small,\n.list-group-item.active .list-group-item-heading > .small,\n.list-group-item.active:hover .list-group-item-heading > .small,\n.list-group-item.active:focus .list-group-item-heading > .small {\n  color: inherit;\n}\n.list-group-item.active .list-group-item-text,\n.list-group-item.active:hover .list-group-item-text,\n.list-group-item.active:focus .list-group-item-text {\n  color: #bdfcff;\n}\n.list-group-item-success {\n  color: #3c763d;\n  background-color: #dff0d8;\n}\na.list-group-item-success,\nbutton.list-group-item-success {\n  color: #3c763d;\n}\na.list-group-item-success .list-group-item-heading,\nbutton.list-group-item-success .list-group-item-heading {\n  color: inherit;\n}\na.list-group-item-success:hover,\nbutton.list-group-item-success:hover,\na.list-group-item-success:focus,\nbutton.list-group-item-success:focus {\n  color: #3c763d;\n  background-color: #d0e9c6;\n}\na.list-group-item-success.active,\nbutton.list-group-item-success.active,\na.list-group-item-success.active:hover,\nbutton.list-group-item-success.active:hover,\na.list-group-item-success.active:focus,\nbutton.list-group-item-success.active:focus {\n  color: #fff;\n  background-color: #3c763d;\n  border-color: #3c763d;\n}\n.list-group-item-info {\n  color: #31708f;\n  background-color: #d9edf7;\n}\na.list-group-item-info,\nbutton.list-group-item-info {\n  color: #31708f;\n}\na.list-group-item-info .list-group-item-heading,\nbutton.list-group-item-info .list-group-item-heading {\n  color: inherit;\n}\na.list-group-item-info:hover,\nbutton.list-group-item-info:hover,\na.list-group-item-info:focus,\nbutton.list-group-item-info:focus {\n  color: #31708f;\n  background-color: #c4e3f3;\n}\na.list-group-item-info.active,\nbutton.list-group-item-info.active,\na.list-group-item-info.active:hover,\nbutton.list-group-item-info.active:hover,\na.list-group-item-info.active:focus,\nbutton.list-group-item-info.active:focus {\n  color: #fff;\n  background-color: #31708f;\n  border-color: #31708f;\n}\n.list-group-item-warning {\n  color: #8a6d3b;\n  background-color: #fcf8e3;\n}\na.list-group-item-warning,\nbutton.list-group-item-warning {\n  color: #8a6d3b;\n}\na.list-group-item-warning .list-group-item-heading,\nbutton.list-group-item-warning .list-group-item-heading {\n  color: inherit;\n}\na.list-group-item-warning:hover,\nbutton.list-group-item-warning:hover,\na.list-group-item-warning:focus,\nbutton.list-group-item-warning:focus {\n  color: #8a6d3b;\n  background-color: #faf2cc;\n}\na.list-group-item-warning.active,\nbutton.list-group-item-warning.active,\na.list-group-item-warning.active:hover,\nbutton.list-group-item-warning.active:hover,\na.list-group-item-warning.active:focus,\nbutton.list-group-item-warning.active:focus {\n  color: #fff;\n  background-color: #8a6d3b;\n  border-color: #8a6d3b;\n}\n.list-group-item-danger {\n  color: #a94442;\n  background-color: #f2dede;\n}\na.list-group-item-danger,\nbutton.list-group-item-danger {\n  color: #a94442;\n}\na.list-group-item-danger .list-group-item-heading,\nbutton.list-group-item-danger .list-group-item-heading {\n  color: inherit;\n}\na.list-group-item-danger:hover,\nbutton.list-group-item-danger:hover,\na.list-group-item-danger:focus,\nbutton.list-group-item-danger:focus {\n  color: #a94442;\n  background-color: #ebcccc;\n}\na.list-group-item-danger.active,\nbutton.list-group-item-danger.active,\na.list-group-item-danger.active:hover,\nbutton.list-group-item-danger.active:hover,\na.list-group-item-danger.active:focus,\nbutton.list-group-item-danger.active:focus {\n  color: #fff;\n  background-color: #a94442;\n  border-color: #a94442;\n}\n.list-group-item-heading {\n  margin-top: 0;\n  margin-bottom: 5px;\n}\n.list-group-item-text {\n  margin-bottom: 0;\n  line-height: 1.3;\n}\n.panel {\n  margin-bottom: 20px;\n  background-color: #fff;\n  border: 1px solid transparent;\n  border-radius: 4px;\n  -webkit-box-shadow: 0 1px 1px rgba(0, 0, 0, 0.05);\n  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.05);\n}\n.panel-body {\n  padding: 15px;\n}\n.panel-heading {\n  padding: 10px 15px;\n  border-bottom: 1px solid transparent;\n  border-top-right-radius: 3px;\n  border-top-left-radius: 3px;\n}\n.panel-heading > .dropdown .dropdown-toggle {\n  color: inherit;\n}\n.panel-title {\n  margin-top: 0;\n  margin-bottom: 0;\n  font-size: 16px;\n  color: inherit;\n}\n.panel-title > a,\n.panel-title > small,\n.panel-title > .small,\n.panel-title > small > a,\n.panel-title > .small > a {\n  color: inherit;\n}\n.panel-footer {\n  padding: 10px 15px;\n  background-color: #f5f5f5;\n  border-top: 1px solid #ddd;\n  border-bottom-right-radius: 3px;\n  border-bottom-left-radius: 3px;\n}\n.panel > .list-group,\n.panel > .panel-collapse > .list-group {\n  margin-bottom: 0;\n}\n.panel > .list-group .list-group-item,\n.panel > .panel-collapse > .list-group .list-group-item {\n  border-width: 1px 0;\n  border-radius: 0;\n}\n.panel > .list-group:first-child .list-group-item:first-child,\n.panel > .panel-collapse > .list-group:first-child .list-group-item:first-child {\n  border-top: 0;\n  border-top-right-radius: 3px;\n  border-top-left-radius: 3px;\n}\n.panel > .list-group:last-child .list-group-item:last-child,\n.panel > .panel-collapse > .list-group:last-child .list-group-item:last-child {\n  border-bottom: 0;\n  border-bottom-right-radius: 3px;\n  border-bottom-left-radius: 3px;\n}\n.panel > .panel-heading + .panel-collapse > .list-group .list-group-item:first-child {\n  border-top-right-radius: 0;\n  border-top-left-radius: 0;\n}\n.panel-heading + .list-group .list-group-item:first-child {\n  border-top-width: 0;\n}\n.list-group + .panel-footer {\n  border-top-width: 0;\n}\n.panel > .table,\n.panel > .table-responsive > .table,\n.panel > .panel-collapse > .table {\n  margin-bottom: 0;\n}\n.panel > .table caption,\n.panel > .table-responsive > .table caption,\n.panel > .panel-collapse > .table caption {\n  padding-left: 15px;\n  padding-right: 15px;\n}\n.panel > .table:first-child,\n.panel > .table-responsive:first-child > .table:first-child {\n  border-top-right-radius: 3px;\n  border-top-left-radius: 3px;\n}\n.panel > .table:first-child > thead:first-child > tr:first-child,\n.panel > .table-responsive:first-child > .table:first-child > thead:first-child > tr:first-child,\n.panel > .table:first-child > tbody:first-child > tr:first-child,\n.panel > .table-responsive:first-child > .table:first-child > tbody:first-child > tr:first-child {\n  border-top-left-radius: 3px;\n  border-top-right-radius: 3px;\n}\n.panel > .table:first-child > thead:first-child > tr:first-child td:first-child,\n.panel > .table-responsive:first-child > .table:first-child > thead:first-child > tr:first-child td:first-child,\n.panel > .table:first-child > tbody:first-child > tr:first-child td:first-child,\n.panel > .table-responsive:first-child > .table:first-child > tbody:first-child > tr:first-child td:first-child,\n.panel > .table:first-child > thead:first-child > tr:first-child th:first-child,\n.panel > .table-responsive:first-child > .table:first-child > thead:first-child > tr:first-child th:first-child,\n.panel > .table:first-child > tbody:first-child > tr:first-child th:first-child,\n.panel > .table-responsive:first-child > .table:first-child > tbody:first-child > tr:first-child th:first-child {\n  border-top-left-radius: 3px;\n}\n.panel > .table:first-child > thead:first-child > tr:first-child td:last-child,\n.panel > .table-responsive:first-child > .table:first-child > thead:first-child > tr:first-child td:last-child,\n.panel > .table:first-child > tbody:first-child > tr:first-child td:last-child,\n.panel > .table-responsive:first-child > .table:first-child > tbody:first-child > tr:first-child td:last-child,\n.panel > .table:first-child > thead:first-child > tr:first-child th:last-child,\n.panel > .table-responsive:first-child > .table:first-child > thead:first-child > tr:first-child th:last-child,\n.panel > .table:first-child > tbody:first-child > tr:first-child th:last-child,\n.panel > .table-responsive:first-child > .table:first-child > tbody:first-child > tr:first-child th:last-child {\n  border-top-right-radius: 3px;\n}\n.panel > .table:last-child,\n.panel > .table-responsive:last-child > .table:last-child {\n  border-bottom-right-radius: 3px;\n  border-bottom-left-radius: 3px;\n}\n.panel > .table:last-child > tbody:last-child > tr:last-child,\n.panel > .table-responsive:last-child > .table:last-child > tbody:last-child > tr:last-child,\n.panel > .table:last-child > tfoot:last-child > tr:last-child,\n.panel > .table-responsive:last-child > .table:last-child > tfoot:last-child > tr:last-child {\n  border-bottom-left-radius: 3px;\n  border-bottom-right-radius: 3px;\n}\n.panel > .table:last-child > tbody:last-child > tr:last-child td:first-child,\n.panel > .table-responsive:last-child > .table:last-child > tbody:last-child > tr:last-child td:first-child,\n.panel > .table:last-child > tfoot:last-child > tr:last-child td:first-child,\n.panel > .table-responsive:last-child > .table:last-child > tfoot:last-child > tr:last-child td:first-child,\n.panel > .table:last-child > tbody:last-child > tr:last-child th:first-child,\n.panel > .table-responsive:last-child > .table:last-child > tbody:last-child > tr:last-child th:first-child,\n.panel > .table:last-child > tfoot:last-child > tr:last-child th:first-child,\n.panel > .table-responsive:last-child > .table:last-child > tfoot:last-child > tr:last-child th:first-child {\n  border-bottom-left-radius: 3px;\n}\n.panel > .table:last-child > tbody:last-child > tr:last-child td:last-child,\n.panel > .table-responsive:last-child > .table:last-child > tbody:last-child > tr:last-child td:last-child,\n.panel > .table:last-child > tfoot:last-child > tr:last-child td:last-child,\n.panel > .table-responsive:last-child > .table:last-child > tfoot:last-child > tr:last-child td:last-child,\n.panel > .table:last-child > tbody:last-child > tr:last-child th:last-child,\n.panel > .table-responsive:last-child > .table:last-child > tbody:last-child > tr:last-child th:last-child,\n.panel > .table:last-child > tfoot:last-child > tr:last-child th:last-child,\n.panel > .table-responsive:last-child > .table:last-child > tfoot:last-child > tr:last-child th:last-child {\n  border-bottom-right-radius: 3px;\n}\n.panel > .panel-body + .table,\n.panel > .panel-body + .table-responsive,\n.panel > .table + .panel-body,\n.panel > .table-responsive + .panel-body {\n  border-top: 1px solid #ddd;\n}\n.panel > .table > tbody:first-child > tr:first-child th,\n.panel > .table > tbody:first-child > tr:first-child td {\n  border-top: 0;\n}\n.panel > .table-bordered,\n.panel > .table-responsive > .table-bordered {\n  border: 0;\n}\n.panel > .table-bordered > thead > tr > th:first-child,\n.panel > .table-responsive > .table-bordered > thead > tr > th:first-child,\n.panel > .table-bordered > tbody > tr > th:first-child,\n.panel > .table-responsive > .table-bordered > tbody > tr > th:first-child,\n.panel > .table-bordered > tfoot > tr > th:first-child,\n.panel > .table-responsive > .table-bordered > tfoot > tr > th:first-child,\n.panel > .table-bordered > thead > tr > td:first-child,\n.panel > .table-responsive > .table-bordered > thead > tr > td:first-child,\n.panel > .table-bordered > tbody > tr > td:first-child,\n.panel > .table-responsive > .table-bordered > tbody > tr > td:first-child,\n.panel > .table-bordered > tfoot > tr > td:first-child,\n.panel > .table-responsive > .table-bordered > tfoot > tr > td:first-child {\n  border-left: 0;\n}\n.panel > .table-bordered > thead > tr > th:last-child,\n.panel > .table-responsive > .table-bordered > thead > tr > th:last-child,\n.panel > .table-bordered > tbody > tr > th:last-child,\n.panel > .table-responsive > .table-bordered > tbody > tr > th:last-child,\n.panel > .table-bordered > tfoot > tr > th:last-child,\n.panel > .table-responsive > .table-bordered > tfoot > tr > th:last-child,\n.panel > .table-bordered > thead > tr > td:last-child,\n.panel > .table-responsive > .table-bordered > thead > tr > td:last-child,\n.panel > .table-bordered > tbody > tr > td:last-child,\n.panel > .table-responsive > .table-bordered > tbody > tr > td:last-child,\n.panel > .table-bordered > tfoot > tr > td:last-child,\n.panel > .table-responsive > .table-bordered > tfoot > tr > td:last-child {\n  border-right: 0;\n}\n.panel > .table-bordered > thead > tr:first-child > td,\n.panel > .table-responsive > .table-bordered > thead > tr:first-child > td,\n.panel > .table-bordered > tbody > tr:first-child > td,\n.panel > .table-responsive > .table-bordered > tbody > tr:first-child > td,\n.panel > .table-bordered > thead > tr:first-child > th,\n.panel > .table-responsive > .table-bordered > thead > tr:first-child > th,\n.panel > .table-bordered > tbody > tr:first-child > th,\n.panel > .table-responsive > .table-bordered > tbody > tr:first-child > th {\n  border-bottom: 0;\n}\n.panel > .table-bordered > tbody > tr:last-child > td,\n.panel > .table-responsive > .table-bordered > tbody > tr:last-child > td,\n.panel > .table-bordered > tfoot > tr:last-child > td,\n.panel > .table-responsive > .table-bordered > tfoot > tr:last-child > td,\n.panel > .table-bordered > tbody > tr:last-child > th,\n.panel > .table-responsive > .table-bordered > tbody > tr:last-child > th,\n.panel > .table-bordered > tfoot > tr:last-child > th,\n.panel > .table-responsive > .table-bordered > tfoot > tr:last-child > th {\n  border-bottom: 0;\n}\n.panel > .table-responsive {\n  border: 0;\n  margin-bottom: 0;\n}\n.panel-group {\n  margin-bottom: 20px;\n}\n.panel-group .panel {\n  margin-bottom: 0;\n  border-radius: 4px;\n}\n.panel-group .panel + .panel {\n  margin-top: 5px;\n}\n.panel-group .panel-heading {\n  border-bottom: 0;\n}\n.panel-group .panel-heading + .panel-collapse > .panel-body,\n.panel-group .panel-heading + .panel-collapse > .list-group {\n  border-top: 1px solid #ddd;\n}\n.panel-group .panel-footer {\n  border-top: 0;\n}\n.panel-group .panel-footer + .panel-collapse .panel-body {\n  border-bottom: 1px solid #ddd;\n}\n.panel-default {\n  border-color: #ddd;\n}\n.panel-default > .panel-heading {\n  color: #333333;\n  background-color: #f5f5f5;\n  border-color: #ddd;\n}\n.panel-default > .panel-heading + .panel-collapse > .panel-body {\n  border-top-color: #ddd;\n}\n.panel-default > .panel-heading .badge {\n  color: #f5f5f5;\n  background-color: #333333;\n}\n.panel-default > .panel-footer + .panel-collapse > .panel-body {\n  border-bottom-color: #ddd;\n}\n.panel-primary {\n  border-color: #00e5f0;\n}\n.panel-primary > .panel-heading {\n  color: #fff;\n  background-color: #00e5f0;\n  border-color: #00e5f0;\n}\n.panel-primary > .panel-heading + .panel-collapse > .panel-body {\n  border-top-color: #00e5f0;\n}\n.panel-primary > .panel-heading .badge {\n  color: #00e5f0;\n  background-color: #fff;\n}\n.panel-primary > .panel-footer + .panel-collapse > .panel-body {\n  border-bottom-color: #00e5f0;\n}\n.panel-success {\n  border-color: #d6e9c6;\n}\n.panel-success > .panel-heading {\n  color: #3c763d;\n  background-color: #dff0d8;\n  border-color: #d6e9c6;\n}\n.panel-success > .panel-heading + .panel-collapse > .panel-body {\n  border-top-color: #d6e9c6;\n}\n.panel-success > .panel-heading .badge {\n  color: #dff0d8;\n  background-color: #3c763d;\n}\n.panel-success > .panel-footer + .panel-collapse > .panel-body {\n  border-bottom-color: #d6e9c6;\n}\n.panel-info {\n  border-color: #bce8f1;\n}\n.panel-info > .panel-heading {\n  color: #31708f;\n  background-color: #d9edf7;\n  border-color: #bce8f1;\n}\n.panel-info > .panel-heading + .panel-collapse > .panel-body {\n  border-top-color: #bce8f1;\n}\n.panel-info > .panel-heading .badge {\n  color: #d9edf7;\n  background-color: #31708f;\n}\n.panel-info > .panel-footer + .panel-collapse > .panel-body {\n  border-bottom-color: #bce8f1;\n}\n.panel-warning {\n  border-color: #faebcc;\n}\n.panel-warning > .panel-heading {\n  color: #8a6d3b;\n  background-color: #fcf8e3;\n  border-color: #faebcc;\n}\n.panel-warning > .panel-heading + .panel-collapse > .panel-body {\n  border-top-color: #faebcc;\n}\n.panel-warning > .panel-heading .badge {\n  color: #fcf8e3;\n  background-color: #8a6d3b;\n}\n.panel-warning > .panel-footer + .panel-collapse > .panel-body {\n  border-bottom-color: #faebcc;\n}\n.panel-danger {\n  border-color: #ebccd1;\n}\n.panel-danger > .panel-heading {\n  color: #a94442;\n  background-color: #f2dede;\n  border-color: #ebccd1;\n}\n.panel-danger > .panel-heading + .panel-collapse > .panel-body {\n  border-top-color: #ebccd1;\n}\n.panel-danger > .panel-heading .badge {\n  color: #f2dede;\n  background-color: #a94442;\n}\n.panel-danger > .panel-footer + .panel-collapse > .panel-body {\n  border-bottom-color: #ebccd1;\n}\n.embed-responsive {\n  position: relative;\n  display: block;\n  height: 0;\n  padding: 0;\n  overflow: hidden;\n}\n.embed-responsive .embed-responsive-item,\n.embed-responsive iframe,\n.embed-responsive embed,\n.embed-responsive object,\n.embed-responsive video {\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  height: 100%;\n  width: 100%;\n  border: 0;\n}\n.embed-responsive-16by9 {\n  padding-bottom: 56.25%;\n}\n.embed-responsive-4by3 {\n  padding-bottom: 75%;\n}\n.well {\n  min-height: 20px;\n  padding: 19px;\n  margin-bottom: 20px;\n  background-color: #f5f5f5;\n  border: 1px solid #e3e3e3;\n  border-radius: 4px;\n  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05);\n  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05);\n}\n.well blockquote {\n  border-color: #ddd;\n  border-color: rgba(0, 0, 0, 0.15);\n}\n.well-lg {\n  padding: 24px;\n  border-radius: 6px;\n}\n.well-sm {\n  padding: 9px;\n  border-radius: 3px;\n}\n.close {\n  float: right;\n  font-size: 21px;\n  font-weight: bold;\n  line-height: 1;\n  color: #000;\n  text-shadow: 0 1px 0 #fff;\n  opacity: 0.2;\n  filter: alpha(opacity=20);\n}\n.close:hover,\n.close:focus {\n  color: #000;\n  text-decoration: none;\n  cursor: pointer;\n  opacity: 0.5;\n  filter: alpha(opacity=50);\n}\nbutton.close {\n  padding: 0;\n  cursor: pointer;\n  background: transparent;\n  border: 0;\n  -webkit-appearance: none;\n}\n.modal-open {\n  overflow: hidden;\n}\n.modal {\n  display: none;\n  overflow: hidden;\n  position: fixed;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: 1050;\n  -webkit-overflow-scrolling: touch;\n  outline: 0;\n}\n.modal.fade .modal-dialog {\n  -webkit-transform: translate(0, -25%);\n  -ms-transform: translate(0, -25%);\n  -o-transform: translate(0, -25%);\n  transform: translate(0, -25%);\n  -webkit-transition: -webkit-transform 0.3s ease-out;\n  -moz-transition: -moz-transform 0.3s ease-out;\n  -o-transition: -o-transform 0.3s ease-out;\n  transition: transform 0.3s ease-out;\n}\n.modal.in .modal-dialog {\n  -webkit-transform: translate(0, 0);\n  -ms-transform: translate(0, 0);\n  -o-transform: translate(0, 0);\n  transform: translate(0, 0);\n}\n.modal-open .modal {\n  overflow-x: hidden;\n  overflow-y: auto;\n}\n.modal-dialog {\n  position: relative;\n  width: auto;\n  margin: 10px;\n}\n.modal-content {\n  position: relative;\n  background-color: #fff;\n  border: 1px solid #999;\n  border: 1px solid rgba(0, 0, 0, 0.2);\n  border-radius: 6px;\n  -webkit-box-shadow: 0 3px 9px rgba(0, 0, 0, 0.5);\n  box-shadow: 0 3px 9px rgba(0, 0, 0, 0.5);\n  background-clip: padding-box;\n  outline: 0;\n}\n.modal-backdrop {\n  position: fixed;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: 1040;\n  background-color: #000;\n}\n.modal-backdrop.fade {\n  opacity: 0;\n  filter: alpha(opacity=0);\n}\n.modal-backdrop.in {\n  opacity: 0.5;\n  filter: alpha(opacity=50);\n}\n.modal-header {\n  padding: 15px;\n  border-bottom: 1px solid #e5e5e5;\n}\n.modal-header .close {\n  margin-top: -2px;\n}\n.modal-title {\n  margin: 0;\n  line-height: 1.42857143;\n}\n.modal-body {\n  position: relative;\n  padding: 15px;\n}\n.modal-footer {\n  padding: 15px;\n  text-align: right;\n  border-top: 1px solid #e5e5e5;\n}\n.modal-footer .btn + .btn {\n  margin-left: 5px;\n  margin-bottom: 0;\n}\n.modal-footer .btn-group .btn + .btn {\n  margin-left: -1px;\n}\n.modal-footer .btn-block + .btn-block {\n  margin-left: 0;\n}\n.modal-scrollbar-measure {\n  position: absolute;\n  top: -9999px;\n  width: 50px;\n  height: 50px;\n  overflow: scroll;\n}\n@media (min-width: 768px) {\n  .modal-dialog {\n    width: 600px;\n    margin: 30px auto;\n  }\n  .modal-content {\n    -webkit-box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5);\n    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5);\n  }\n  .modal-sm {\n    width: 300px;\n  }\n}\n@media (min-width: 992px) {\n  .modal-lg {\n    width: 900px;\n  }\n}\n.tooltip {\n  position: absolute;\n  z-index: 1070;\n  display: block;\n  font-family: \"Helvetica Neue\", Helvetica, Arial, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  letter-spacing: normal;\n  line-break: auto;\n  line-height: 1.42857143;\n  text-align: left;\n  text-align: start;\n  text-decoration: none;\n  text-shadow: none;\n  text-transform: none;\n  white-space: normal;\n  word-break: normal;\n  word-spacing: normal;\n  word-wrap: normal;\n  font-size: 12px;\n  opacity: 0;\n  filter: alpha(opacity=0);\n}\n.tooltip.in {\n  opacity: 0.9;\n  filter: alpha(opacity=90);\n}\n.tooltip.top {\n  margin-top: -3px;\n  padding: 5px 0;\n}\n.tooltip.right {\n  margin-left: 3px;\n  padding: 0 5px;\n}\n.tooltip.bottom {\n  margin-top: 3px;\n  padding: 5px 0;\n}\n.tooltip.left {\n  margin-left: -3px;\n  padding: 0 5px;\n}\n.tooltip-inner {\n  max-width: 200px;\n  padding: 3px 8px;\n  color: #fff;\n  text-align: center;\n  background-color: #000;\n  border-radius: 4px;\n}\n.tooltip-arrow {\n  position: absolute;\n  width: 0;\n  height: 0;\n  border-color: transparent;\n  border-style: solid;\n}\n.tooltip.top .tooltip-arrow {\n  bottom: 0;\n  left: 50%;\n  margin-left: -5px;\n  border-width: 5px 5px 0;\n  border-top-color: #000;\n}\n.tooltip.top-left .tooltip-arrow {\n  bottom: 0;\n  right: 5px;\n  margin-bottom: -5px;\n  border-width: 5px 5px 0;\n  border-top-color: #000;\n}\n.tooltip.top-right .tooltip-arrow {\n  bottom: 0;\n  left: 5px;\n  margin-bottom: -5px;\n  border-width: 5px 5px 0;\n  border-top-color: #000;\n}\n.tooltip.right .tooltip-arrow {\n  top: 50%;\n  left: 0;\n  margin-top: -5px;\n  border-width: 5px 5px 5px 0;\n  border-right-color: #000;\n}\n.tooltip.left .tooltip-arrow {\n  top: 50%;\n  right: 0;\n  margin-top: -5px;\n  border-width: 5px 0 5px 5px;\n  border-left-color: #000;\n}\n.tooltip.bottom .tooltip-arrow {\n  top: 0;\n  left: 50%;\n  margin-left: -5px;\n  border-width: 0 5px 5px;\n  border-bottom-color: #000;\n}\n.tooltip.bottom-left .tooltip-arrow {\n  top: 0;\n  right: 5px;\n  margin-top: -5px;\n  border-width: 0 5px 5px;\n  border-bottom-color: #000;\n}\n.tooltip.bottom-right .tooltip-arrow {\n  top: 0;\n  left: 5px;\n  margin-top: -5px;\n  border-width: 0 5px 5px;\n  border-bottom-color: #000;\n}\n.popover {\n  position: absolute;\n  top: 0;\n  left: 0;\n  z-index: 1060;\n  display: none;\n  max-width: 276px;\n  padding: 1px;\n  font-family: \"Helvetica Neue\", Helvetica, Arial, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  letter-spacing: normal;\n  line-break: auto;\n  line-height: 1.42857143;\n  text-align: left;\n  text-align: start;\n  text-decoration: none;\n  text-shadow: none;\n  text-transform: none;\n  white-space: normal;\n  word-break: normal;\n  word-spacing: normal;\n  word-wrap: normal;\n  font-size: 14px;\n  background-color: #fff;\n  background-clip: padding-box;\n  border: 1px solid #ccc;\n  border: 1px solid rgba(0, 0, 0, 0.2);\n  border-radius: 6px;\n  -webkit-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);\n  box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);\n}\n.popover.top {\n  margin-top: -10px;\n}\n.popover.right {\n  margin-left: 10px;\n}\n.popover.bottom {\n  margin-top: 10px;\n}\n.popover.left {\n  margin-left: -10px;\n}\n.popover-title {\n  margin: 0;\n  padding: 8px 14px;\n  font-size: 14px;\n  background-color: #f7f7f7;\n  border-bottom: 1px solid #ebebeb;\n  border-radius: 5px 5px 0 0;\n}\n.popover-content {\n  padding: 9px 14px;\n}\n.popover > .arrow,\n.popover > .arrow:after {\n  position: absolute;\n  display: block;\n  width: 0;\n  height: 0;\n  border-color: transparent;\n  border-style: solid;\n}\n.popover > .arrow {\n  border-width: 11px;\n}\n.popover > .arrow:after {\n  border-width: 10px;\n  content: \"\";\n}\n.popover.top > .arrow {\n  left: 50%;\n  margin-left: -11px;\n  border-bottom-width: 0;\n  border-top-color: #999999;\n  border-top-color: rgba(0, 0, 0, 0.25);\n  bottom: -11px;\n}\n.popover.top > .arrow:after {\n  content: \" \";\n  bottom: 1px;\n  margin-left: -10px;\n  border-bottom-width: 0;\n  border-top-color: #fff;\n}\n.popover.right > .arrow {\n  top: 50%;\n  left: -11px;\n  margin-top: -11px;\n  border-left-width: 0;\n  border-right-color: #999999;\n  border-right-color: rgba(0, 0, 0, 0.25);\n}\n.popover.right > .arrow:after {\n  content: \" \";\n  left: 1px;\n  bottom: -10px;\n  border-left-width: 0;\n  border-right-color: #fff;\n}\n.popover.bottom > .arrow {\n  left: 50%;\n  margin-left: -11px;\n  border-top-width: 0;\n  border-bottom-color: #999999;\n  border-bottom-color: rgba(0, 0, 0, 0.25);\n  top: -11px;\n}\n.popover.bottom > .arrow:after {\n  content: \" \";\n  top: 1px;\n  margin-left: -10px;\n  border-top-width: 0;\n  border-bottom-color: #fff;\n}\n.popover.left > .arrow {\n  top: 50%;\n  right: -11px;\n  margin-top: -11px;\n  border-right-width: 0;\n  border-left-color: #999999;\n  border-left-color: rgba(0, 0, 0, 0.25);\n}\n.popover.left > .arrow:after {\n  content: \" \";\n  right: 1px;\n  border-right-width: 0;\n  border-left-color: #fff;\n  bottom: -10px;\n}\n.carousel {\n  position: relative;\n}\n.carousel-inner {\n  position: relative;\n  overflow: hidden;\n  width: 100%;\n}\n.carousel-inner > .item {\n  display: none;\n  position: relative;\n  -webkit-transition: 0.6s ease-in-out left;\n  -o-transition: 0.6s ease-in-out left;\n  transition: 0.6s ease-in-out left;\n}\n.carousel-inner > .item > img,\n.carousel-inner > .item > a > img {\n  line-height: 1;\n}\n@media all and (transform-3d), (-webkit-transform-3d) {\n  .carousel-inner > .item {\n    -webkit-transition: -webkit-transform 0.6s ease-in-out;\n    -moz-transition: -moz-transform 0.6s ease-in-out;\n    -o-transition: -o-transform 0.6s ease-in-out;\n    transition: transform 0.6s ease-in-out;\n    -webkit-backface-visibility: hidden;\n    -moz-backface-visibility: hidden;\n    backface-visibility: hidden;\n    -webkit-perspective: 1000px;\n    -moz-perspective: 1000px;\n    perspective: 1000px;\n  }\n  .carousel-inner > .item.next,\n  .carousel-inner > .item.active.right {\n    -webkit-transform: translate3d(100%, 0, 0);\n    transform: translate3d(100%, 0, 0);\n    left: 0;\n  }\n  .carousel-inner > .item.prev,\n  .carousel-inner > .item.active.left {\n    -webkit-transform: translate3d(-100%, 0, 0);\n    transform: translate3d(-100%, 0, 0);\n    left: 0;\n  }\n  .carousel-inner > .item.next.left,\n  .carousel-inner > .item.prev.right,\n  .carousel-inner > .item.active {\n    -webkit-transform: translate3d(0, 0, 0);\n    transform: translate3d(0, 0, 0);\n    left: 0;\n  }\n}\n.carousel-inner > .active,\n.carousel-inner > .next,\n.carousel-inner > .prev {\n  display: block;\n}\n.carousel-inner > .active {\n  left: 0;\n}\n.carousel-inner > .next,\n.carousel-inner > .prev {\n  position: absolute;\n  top: 0;\n  width: 100%;\n}\n.carousel-inner > .next {\n  left: 100%;\n}\n.carousel-inner > .prev {\n  left: -100%;\n}\n.carousel-inner > .next.left,\n.carousel-inner > .prev.right {\n  left: 0;\n}\n.carousel-inner > .active.left {\n  left: -100%;\n}\n.carousel-inner > .active.right {\n  left: 100%;\n}\n.carousel-control {\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  width: 15%;\n  opacity: 0.5;\n  filter: alpha(opacity=50);\n  font-size: 20px;\n  color: #fff;\n  text-align: center;\n  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);\n  background-color: rgba(0, 0, 0, 0);\n}\n.carousel-control.left {\n  background-image: -webkit-linear-gradient(left, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.0001) 100%);\n  background-image: -o-linear-gradient(left, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.0001) 100%);\n  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.0001) 100%);\n  background-repeat: repeat-x;\n  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#80000000', endColorstr='#00000000', GradientType=1);\n}\n.carousel-control.right {\n  left: auto;\n  right: 0;\n  background-image: -webkit-linear-gradient(left, rgba(0, 0, 0, 0.0001) 0%, rgba(0, 0, 0, 0.5) 100%);\n  background-image: -o-linear-gradient(left, rgba(0, 0, 0, 0.0001) 0%, rgba(0, 0, 0, 0.5) 100%);\n  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.0001) 0%, rgba(0, 0, 0, 0.5) 100%);\n  background-repeat: repeat-x;\n  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000', endColorstr='#80000000', GradientType=1);\n}\n.carousel-control:hover,\n.carousel-control:focus {\n  outline: 0;\n  color: #fff;\n  text-decoration: none;\n  opacity: 0.9;\n  filter: alpha(opacity=90);\n}\n.carousel-control .icon-prev,\n.carousel-control .icon-next,\n.carousel-control .glyphicon-chevron-left,\n.carousel-control .glyphicon-chevron-right {\n  position: absolute;\n  top: 50%;\n  margin-top: -10px;\n  z-index: 5;\n  display: inline-block;\n}\n.carousel-control .icon-prev,\n.carousel-control .glyphicon-chevron-left {\n  left: 50%;\n  margin-left: -10px;\n}\n.carousel-control .icon-next,\n.carousel-control .glyphicon-chevron-right {\n  right: 50%;\n  margin-right: -10px;\n}\n.carousel-control .icon-prev,\n.carousel-control .icon-next {\n  width: 20px;\n  height: 20px;\n  line-height: 1;\n  font-family: serif;\n}\n.carousel-control .icon-prev:before {\n  content: '\\2039';\n}\n.carousel-control .icon-next:before {\n  content: '\\203a';\n}\n.carousel-indicators {\n  position: absolute;\n  bottom: 10px;\n  left: 50%;\n  z-index: 15;\n  width: 60%;\n  margin-left: -30%;\n  padding-left: 0;\n  list-style: none;\n  text-align: center;\n}\n.carousel-indicators li {\n  display: inline-block;\n  width: 10px;\n  height: 10px;\n  margin: 1px;\n  text-indent: -999px;\n  border: 1px solid #fff;\n  border-radius: 10px;\n  cursor: pointer;\n  background-color: #000 \\9;\n  background-color: rgba(0, 0, 0, 0);\n}\n.carousel-indicators .active {\n  margin: 0;\n  width: 12px;\n  height: 12px;\n  background-color: #fff;\n}\n.carousel-caption {\n  position: absolute;\n  left: 15%;\n  right: 15%;\n  bottom: 20px;\n  z-index: 10;\n  padding-top: 20px;\n  padding-bottom: 20px;\n  color: #fff;\n  text-align: center;\n  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);\n}\n.carousel-caption .btn {\n  text-shadow: none;\n}\n@media screen and (min-width: 768px) {\n  .carousel-control .glyphicon-chevron-left,\n  .carousel-control .glyphicon-chevron-right,\n  .carousel-control .icon-prev,\n  .carousel-control .icon-next {\n    width: 30px;\n    height: 30px;\n    margin-top: -10px;\n    font-size: 30px;\n  }\n  .carousel-control .glyphicon-chevron-left,\n  .carousel-control .icon-prev {\n    margin-left: -10px;\n  }\n  .carousel-control .glyphicon-chevron-right,\n  .carousel-control .icon-next {\n    margin-right: -10px;\n  }\n  .carousel-caption {\n    left: 20%;\n    right: 20%;\n    padding-bottom: 30px;\n  }\n  .carousel-indicators {\n    bottom: 20px;\n  }\n}\n.clearfix:before,\n.clearfix:after,\n.dl-horizontal dd:before,\n.dl-horizontal dd:after,\n.container:before,\n.container:after,\n.container-fluid:before,\n.container-fluid:after,\n.row:before,\n.row:after,\n.form-horizontal .form-group:before,\n.form-horizontal .form-group:after,\n.btn-toolbar:before,\n.btn-toolbar:after,\n.btn-group-vertical > .btn-group:before,\n.btn-group-vertical > .btn-group:after,\n.nav:before,\n.nav:after,\n.navbar:before,\n.navbar:after,\n.navbar-header:before,\n.navbar-header:after,\n.navbar-collapse:before,\n.navbar-collapse:after,\n.pager:before,\n.pager:after,\n.panel-body:before,\n.panel-body:after,\n.modal-header:before,\n.modal-header:after,\n.modal-footer:before,\n.modal-footer:after {\n  content: \" \";\n  display: table;\n}\n.clearfix:after,\n.dl-horizontal dd:after,\n.container:after,\n.container-fluid:after,\n.row:after,\n.form-horizontal .form-group:after,\n.btn-toolbar:after,\n.btn-group-vertical > .btn-group:after,\n.nav:after,\n.navbar:after,\n.navbar-header:after,\n.navbar-collapse:after,\n.pager:after,\n.panel-body:after,\n.modal-header:after,\n.modal-footer: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}\n.affix {\n  position: fixed;\n}\n@-ms-viewport {\n  width: device-width;\n}\n.visible-xs,\n.visible-sm,\n.visible-md,\n.visible-lg {\n  display: none !important;\n}\n.visible-xs-block,\n.visible-xs-inline,\n.visible-xs-inline-block,\n.visible-sm-block,\n.visible-sm-inline,\n.visible-sm-inline-block,\n.visible-md-block,\n.visible-md-inline,\n.visible-md-inline-block,\n.visible-lg-block,\n.visible-lg-inline,\n.visible-lg-inline-block {\n  display: none !important;\n}\n@media (max-width: 767px) {\n  .visible-xs {\n    display: block !important;\n  }\n  table.visible-xs {\n    display: table !important;\n  }\n  tr.visible-xs {\n    display: table-row !important;\n  }\n  th.visible-xs,\n  td.visible-xs {\n    display: table-cell !important;\n  }\n}\n@media (max-width: 767px) {\n  .visible-xs-block {\n    display: block !important;\n  }\n}\n@media (max-width: 767px) {\n  .visible-xs-inline {\n    display: inline !important;\n  }\n}\n@media (max-width: 767px) {\n  .visible-xs-inline-block {\n    display: inline-block !important;\n  }\n}\n@media (min-width: 768px) and (max-width: 991px) {\n  .visible-sm {\n    display: block !important;\n  }\n  table.visible-sm {\n    display: table !important;\n  }\n  tr.visible-sm {\n    display: table-row !important;\n  }\n  th.visible-sm,\n  td.visible-sm {\n    display: table-cell !important;\n  }\n}\n@media (min-width: 768px) and (max-width: 991px) {\n  .visible-sm-block {\n    display: block !important;\n  }\n}\n@media (min-width: 768px) and (max-width: 991px) {\n  .visible-sm-inline {\n    display: inline !important;\n  }\n}\n@media (min-width: 768px) and (max-width: 991px) {\n  .visible-sm-inline-block {\n    display: inline-block !important;\n  }\n}\n@media (min-width: 992px) and (max-width: 1199px) {\n  .visible-md {\n    display: block !important;\n  }\n  table.visible-md {\n    display: table !important;\n  }\n  tr.visible-md {\n    display: table-row !important;\n  }\n  th.visible-md,\n  td.visible-md {\n    display: table-cell !important;\n  }\n}\n@media (min-width: 992px) and (max-width: 1199px) {\n  .visible-md-block {\n    display: block !important;\n  }\n}\n@media (min-width: 992px) and (max-width: 1199px) {\n  .visible-md-inline {\n    display: inline !important;\n  }\n}\n@media (min-width: 992px) and (max-width: 1199px) {\n  .visible-md-inline-block {\n    display: inline-block !important;\n  }\n}\n@media (min-width: 1200px) {\n  .visible-lg {\n    display: block !important;\n  }\n  table.visible-lg {\n    display: table !important;\n  }\n  tr.visible-lg {\n    display: table-row !important;\n  }\n  th.visible-lg,\n  td.visible-lg {\n    display: table-cell !important;\n  }\n}\n@media (min-width: 1200px) {\n  .visible-lg-block {\n    display: block !important;\n  }\n}\n@media (min-width: 1200px) {\n  .visible-lg-inline {\n    display: inline !important;\n  }\n}\n@media (min-width: 1200px) {\n  .visible-lg-inline-block {\n    display: inline-block !important;\n  }\n}\n@media (max-width: 767px) {\n  .hidden-xs {\n    display: none !important;\n  }\n}\n@media (min-width: 768px) and (max-width: 991px) {\n  .hidden-sm {\n    display: none !important;\n  }\n}\n@media (min-width: 992px) and (max-width: 1199px) {\n  .hidden-md {\n    display: none !important;\n  }\n}\n@media (min-width: 1200px) {\n  .hidden-lg {\n    display: none !important;\n  }\n}\n.visible-print {\n  display: none !important;\n}\n@media print {\n  .visible-print {\n    display: block !important;\n  }\n  table.visible-print {\n    display: table !important;\n  }\n  tr.visible-print {\n    display: table-row !important;\n  }\n  th.visible-print,\n  td.visible-print {\n    display: table-cell !important;\n  }\n}\n.visible-print-block {\n  display: none !important;\n}\n@media print {\n  .visible-print-block {\n    display: block !important;\n  }\n}\n.visible-print-inline {\n  display: none !important;\n}\n@media print {\n  .visible-print-inline {\n    display: inline !important;\n  }\n}\n.visible-print-inline-block {\n  display: none !important;\n}\n@media print {\n  .visible-print-inline-block {\n    display: inline-block !important;\n  }\n}\n@media print {\n  .hidden-print {\n    display: none !important;\n  }\n}\n/* ************************************************************************ */\n/*                                LESS VARIABLES\n**                This stylesheet should only contain variables.\n/* ************************************************************************ */\n/*-----------------------------------------------------------------------*/\n/*                          Color palette                                */\n/*-----------------------------------------------------------------------*/\n.top-buffer-1 {\n  margin-top: 15px;\n}\n.top-buffer-2 {\n  margin-top: 30px;\n}\n.top-buffer-3 {\n  margin-top: 45px;\n}\n.top-buffer-4 {\n  margin-top: 60px;\n}\n.top-buffer-5 {\n  margin-top: 75px;\n}\n.top-buffer-6 {\n  margin-top: 90px;\n}\n.top-buffer-7 {\n  margin-top: 105px;\n}\n.top-buffer-8 {\n  margin-top: 120px;\n}\n.top-buffer-9 {\n  margin-top: 135px;\n}\n.top-buffer-10 {\n  margin-top: 150px;\n}\n/* ************************************************************************ */\n/*                                IMPAC MATERIAL\n/*                  ------------------------------------------\n** Mixin material styled form inputs, overriding bootstrap's ungodly round-ness.\n/* ************************************************************************ */\n/* DEMO HTML - use this html to test all impac material features.\n<form>\n  <div class=\"im-form-group\">\n    <select>\n      <option>Value 1</option>\n      <option>Value 2</option>\n    </select>\n    <label for=\"select\" class=\"im-control-label\">Selectbox</label><i class=\"im-bar\"></i>\n  </div>\n  <div class=\"im-form-group\">\n    <input type=\"text\" required/>\n    <label for=\"input\" class=\"im-control-label\">Textfield</label><i class=\"im-bar\"></i>\n    <div class=\"im-messages\">\n      <p>This is an error message</p>\n    </div>\n  </div>\n  <div class=\"im-form-inline\">\n    <div class=\"im-form-group\">\n      <input type=\"text\" required/>\n      <label for=\"input\" class=\"im-control-label\">Inline</label><i class=\"im-bar\"></i>\n    </div>\n    <div class=\"im-form-group\">\n      <input type=\"text\" required/>\n      <label for=\"input\" class=\"im-control-label\">Inline</label><i class=\"im-bar\"></i>\n    </div>\n  </div>\n  <div class=\"im-form-group\">\n    <textarea required></textarea>\n    <label for=\"textarea\" class=\"im-control-label\">Textarea</label><i class=\"im-bar\"></i>\n  </div>\n  <div class=\"im-checkbox\">\n    <label>\n      <input type=\"checkbox\" checked=\"checked\"/><i class=\"im-helper\"></i>I'm the label from a checkbox\n    </label>\n  </div>\n  <div class=\"im-checkbox\">\n    <label>\n      <input type=\"checkbox\"/><i class=\"im-helper\"></i>I'm the label from a checkbox\n    </label>\n  </div>\n  <div class=\"im-form-radio\">\n    <div class=\"im-radio\">\n      <label>\n        <input type=\"radio\" name=\"radio\" checked=\"checked\"/><i class=\"im-helper\"></i>I'm the label from a radio button\n      </label>\n    </div>\n    <div class=\"im-radio\">\n      <label>\n        <input type=\"radio\" name=\"radio\"/><i class=\"im-helper\"></i>I'm the label from a radio button\n      </label>\n    </div>\n  </div>\n  <div class=\"im-checkbox\">\n    <label>\n      <input type=\"checkbox\"/><i class=\"im-helper\"></i>I'm the label from a checkbox\n    </label>\n  </div>\n  <button type=\"button\" class=\"im-fab im-primary\"><i>♥</i></button>\n  <button type=\"button\" class=\"im-fab im-warn\"><i>♥</i></button>\n</form>\n*/\n/* ************************************************************************ */\n/*                                GLOBAL STYLES\n**        This stylesheet should only contain styles applied global or in\n**                            2 or more components.\n/* ************************************************************************ */\nbody {\n  height: 101% !important;\n}\n.analytics h2 {\n  margin-top: 2px;\n  font-size: 14px;\n  color: #5B6667;\n}\n.analytics h3 {\n  margin: 0px;\n  font-weight: 300;\n  font-size: 14px;\n  color: #5B6667;\n  text-align: left;\n  margin-top: 0px;\n}\n.analytics h4 {\n  color: #5B6667;\n  font-size: 16px;\n}\n.analytics .positive,\n.analytics .green {\n  color: green !important;\n}\n.analytics .negative,\n.analytics .red {\n  color: #ed1e79 !important;\n}\n.analytics .positive2 {\n  color: #3fc4ff !important;\n}\n.analytics .negative2 {\n  color: #1de9b6 !important;\n}\n.analytics a {\n  font-weight: bold;\n  color: #977bf0;\n  cursor: pointer;\n}\n.analytics .input-group {\n  width: 100%;\n}\n.analytics select {\n  margin-top: 5px;\n  background-color: white;\n  height: 32px;\n}\n.analytics pre {\n  font-size: 12px;\n  padding: 0px;\n  margin: 1px 0px 8px 0px;\n  border: none;\n  white-space: pre-wrap;\n  word-wrap: break-word;\n  overflow: hidden;\n}\n.analytics .widget-item .content ::-webkit-scrollbar,\n.analytics kpis-bar .kpi ::-webkit-scrollbar {\n  width: 6px;\n  background-color: transparent;\n}\n.analytics .widget-item .content ::-webkit-scrollbar-thumb,\n.analytics kpis-bar .kpi ::-webkit-scrollbar-thumb {\n  background-color: #6896b2;\n  border-radius: 10px;\n}\n.analytics .widget-item .content ::-webkit-scrollbar-thumb:hover,\n.analytics kpis-bar .kpi ::-webkit-scrollbar-thumb:hover {\n  background-color: #79a2bb;\n}\n.analytics .nopadding {\n  padding: 0;\n}\n.analytics .nomargin {\n  margin: 0;\n}\n.analytics .btn.btn-shaded {\n  background-color: #17262d;\n  border: solid 1px #0e181c;\n  color: #626d6d;\n  font-weight: 400;\n}\n.analytics .btn.btn-shaded:hover {\n  color: #6e7a7a;\n  background-color: #20343e;\n}\n.analytics .price {\n  font-weight: 900;\n  font-size: 22px;\n  color: #5B6667;\n  text-align: center;\n  margin-top: 30px;\n}\n.analytics .currency {\n  font-weight: 300;\n  font-size: 16px;\n  color: #5B6667;\n  text-align: center;\n  color: #9ba6a7;\n}\n.analytics .legend {\n  font-weight: 300;\n  font-size: 12px;\n  color: #5B6667;\n  text-align: center;\n  overflow-y: auto;\n  overflow-x: hidden;\n  color: #c4caca;\n}\n.analytics .loader {\n  height: 100%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n}\n.analytics .loader i {\n  color: #67BBE9;\n}\n.analytics .loader p {\n  margin-top: 10px;\n}\n.analytics .right-panel {\n  border-left: solid 1px #e6e6e6;\n}\n.analytics .selector {\n  text-transform: uppercase;\n  font-size: 12px;\n  color: #626d6d;\n  text-align: center;\n}\n.analytics .tile {\n  background-color: #f7f7f7;\n  box-shadow: 0px 7px 10px -7px #17262d;\n  height: 45px;\n  margin-bottom: 10px;\n  white-space: nowrap;\n  cursor: pointer;\n}\n.analytics .tile:hover {\n  background-color: #e2f2ff;\n}\n.analytics .tile .colored-area {\n  background-color: #3FC4FF;\n  height: 100%;\n  float: right;\n  color: white;\n  text-align: right;\n  padding: 5px 10px;\n  min-width: 8%;\n}\n.analytics .tile .colored-area.selected {\n  background-color: #977bf0;\n}\n.analytics .tile .main-text {\n  color: #5B6667;\n  padding: 20px 0px 0px 5px;\n  height: 100%;\n  font-style: italic;\n  font-weight: bold;\n}\n.analytics .widget-lines-container {\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: 200px;\n  text-align: left;\n  font-size: 12px;\n  padding: 0px 15px;\n}\n.analytics .widget-lines-container .row.widget-line {\n  padding: 5px;\n  color: #626d6d;\n}\n.analytics .widget-lines-container .row.widget-line.header {\n  font-weight: 500;\n  font-size: 12px;\n  color: #9ba6a7;\n  text-transform: uppercase;\n}\n@media (max-width: 767px) {\n  .analytics .widget-lines-container .row.widget-line {\n    margin: inherit;\n    margin-left: -3px;\n    margin-right: -3px;\n    padding: 2px;\n  }\n  .analytics .widget-lines-container .row.widget-line > [class*='col-'] {\n    padding-left: 3px;\n    padding-right: 3px;\n  }\n}\n.analytics .widget-lines-container .row.widget-line i.fa {\n  min-width: 12px;\n  min-height: 12px;\n}\n.analytics .widget-lines-container .row .dashed {\n  border-bottom: dashed 1px #dfe2e2;\n  padding-bottom: 3px;\n  margin-bottom: 3px;\n}\n.analytics .widget-lines-container .row.lines-group {\n  border-top: solid 1px #e6edee;\n}\n.vertical-scroll {\n  overflow-y: scroll;\n}\n.horizontal-scroll {\n  overflow-x: scroll;\n}\n.tooltip.impac-widgets-tooltip .tooltip-inner.ng-binding {\n  text-align: left;\n  background-color: #232528;\n  max-width: 100%;\n  white-space: nowrap;\n}\n.tooltip.impac-widgets-tooltip .tooltip-inner.ng-binding strong {\n  color: #dae173;\n}\n.sortable-title {\n  cursor: pointer;\n}\n.sortable-title div {\n  display: inline-block;\n}\ndiv[ng-messages] {\n  color: #FF0000;\n}\n.has-error .form-control {\n  border-color: #e01f74;\n}\n.has-error .form-control:focus {\n  border-color: #e01f74;\n}\n.has-success .form-control {\n  border-color: #00e5f0;\n}\n.has-success .form-control:focus {\n  border-color: #00e5f0;\n}\n.row.no-gutters {\n  margin-right: 0;\n  margin-left: 0;\n}\n[class^=\"col-\"].no-gutters,\n[class*=\" col-\"].no-gutters {\n  padding-right: 0;\n  padding-left: 0;\n}\n@media print {\n  body {\n    background-color: white !important;\n  }\n  .analytics {\n    padding-top: 0px !important;\n  }\n  .analytics #module__dashboard-selector .title-container {\n    margin-top: 20px;\n  }\n  .analytics .widget-item {\n    page-break-inside: avoid;\n  }\n  .analytics .widget-item .content .chart-container {\n    max-width: 270px;\n    margin: auto;\n  }\n  .analytics .widget-item .content .chart-container canvas {\n    width: 100% !important;\n    height: 100% !important;\n  }\n  .analytics .widget-item .right-panel {\n    page-break-inside: avoid;\n    border-left: 0;\n  }\n  .analytics .widget-item .right-panel .chart-container {\n    max-width: inherit;\n    max-height: inherit;\n  }\n  .analytics .widget-item .right-panel .chart-container canvas {\n    width: 80% !important;\n    height: 80% !important;\n  }\n  * {\n    transition: none !important;\n  }\n}\n/**\n *  Do not remove this comments bellow. It's the markers used by gulp-inject to inject\n *  all your less files automatically\n */\n/* inject:imports */\n.kpi-alerts-settings .modal-header {\n  font-size: 20px;\n}\n.kpi-alerts-settings .modal-body {\n  line-height: 2;\n}\n.kpi-alerts-settings .modal-body ul {\n  margin-top: 10px;\n}\n.kpi-alerts-settings .modal-body ul > li.list-group-item {\n  list-style: none;\n  padding: 6px 15px;\n  color: #9ba6a7;\n  user-select: none;\n}\n.kpi-alerts-settings .modal-body ul > li.list-group-item .alert-toggle:hover {\n  cursor: pointer;\n}\n.kpi-alerts-settings .modal-body ul > li.list-group-item.active {\n  color: #358fdc;\n  font-weight: bold;\n  background-color: transparent;\n  border-color: #c4caca;\n}\n.kpi-alerts-settings .modal-body .fa.fa-toggle-on,\n.kpi-alerts-settings .modal-body .fa.fa-toggle-off {\n  font-size: 17px;\n  margin-right: 8px;\n}\n.kpi-alerts-settings .modal-body ul.recipients-list {\n  height: 75px;\n  overflow: hidden;\n  overflow-y: scroll;\n  border: 1px solid #c4caca;\n}\n.kpi-alerts-settings .modal-body ul.recipients-list li {\n  border: none;\n}\n.kpi-alerts-settings .modal-body input.recipient-search {\n  color: black;\n  width: 100%;\n}\n.kpi-alerts-settings .modal-body ul.available {\n  margin-top: 0px;\n}\n.analytics {\n  padding-top: 50px;\n  margin-left: 100px;\n}\n@media screen and (max-width: 992px) {\n  .analytics {\n    padding-top: 150px;\n  }\n}\n.analytics.pdf-mode {\n  padding-top: 20px;\n}\n.analytics.show-dhb {\n  transition: opacity 1s;\n  opacity: 1;\n}\n.analytics.hide-dhb {\n  opacity: 0;\n}\n.analytics #dashboard-heading img {\n  float: left;\n  margin-right: 15px;\n  max-width: 200px;\n  max-height: 150px;\n}\n.analytics #dashboard-heading img.pdf-mode:hover {\n  cursor: pointer;\n}\n.analytics #dashboard-heading .caption {\n  font-size: 14px;\n  margin: 5px 0px;\n}\n.analytics #sub-menu {\n  margin-top: 15px;\n}\n.analytics #sub-menu h3 {\n  font-size: 26px;\n  font-weight: normal;\n  margin-bottom: 10px;\n  color: #233845;\n}\n.analytics #sub-menu .fa.fa-times {\n  margin: 6px;\n  color: #3d6178;\n  cursor: pointer;\n  float: right;\n}\n.analytics #widget-selector {\n  background-color: #233845;\n  color: white;\n  padding: 0px 45px 10px 45px;\n  margin: 10px -45px;\n  border-radius: 3px;\n  -webkit-user-select: none;\n  /* Chrome/Safari */\n  -moz-user-select: none;\n  /* Firefox */\n  -ms-user-select: none;\n  /* IE10+ */\n  /* Rules below not implemented in browsers yet */\n  -o-user-select: none;\n  user-select: none;\n}\n@media (max-width: 767px) {\n  .analytics #widget-selector {\n    padding: 0 15px 10px 15px;\n    margin: 0;\n  }\n}\n.analytics #widget-selector .title {\n  padding: 15px 0px;\n  border-bottom: solid 1px #2d4859;\n  display: flex;\n  align-items: center;\n}\n.analytics #widget-selector .title p.instruction {\n  flex-grow: 1;\n  margin: 0;\n}\n@media screen and (max-width: 768px) {\n  .analytics #widget-selector .title p.instruction {\n    width: 50%;\n    font-size: 13px;\n  }\n}\n.analytics #widget-selector .title .widget-added.badge {\n  margin-right: 10px;\n  opacity: 0;\n}\n.analytics #widget-selector .title .fa.close-selector {\n  float: right;\n  cursor: pointer;\n  font-size: 20px;\n  padding: 6px;\n}\n.analytics #widget-selector .title .fa.close-selector:hover {\n  color: #999999;\n}\n.analytics #widget-selector .top-container {\n  margin: 15px 0px;\n  background-color: transparent;\n  border-radius: 3px;\n}\n.analytics #widget-selector .section-header {\n  padding: 10px 20px;\n  font-weight: bold;\n  min-height: 40px;\n  display: flex;\n  align-items: center;\n}\n.analytics #widget-selector .section-lines {\n  overflow-x: hidden;\n  overflow-y: auto;\n  height: 200px;\n  margin-right: -10px;\n  margin-left: 0px;\n}\n.analytics #widget-selector .section-lines p {\n  padding: 5px;\n  margin: 0px;\n  cursor: pointer;\n}\n.analytics #widget-selector .section-lines p:hover,\n.analytics #widget-selector .section-lines p.selected {\n  color: white;\n}\n.analytics #widget-selector .section-lines::-webkit-scrollbar {\n  width: 6px;\n  background-color: transparent;\n}\n.analytics #widget-selector .section-lines::-webkit-scrollbar-thumb {\n  background-color: #28404f;\n  border-radius: 10px;\n}\n.analytics #widget-selector .section-lines::-webkit-scrollbar-thumb:hover {\n  background-color: #2d4859;\n}\n.analytics #widget-selector .categories-section {\n  background-color: #192831;\n  padding-bottom: 15px;\n}\n.analytics #widget-selector .categories-section > .section-lines > [class*='col-']:first-child {\n  padding: 3px 12px;\n}\n.analytics #widget-selector .categories-section > .section-lines .line-item:hover {\n  background-color: #1e303b;\n}\n.analytics #widget-selector .categories-section > .section-lines .line-item.selected {\n  background-color: #977bf0;\n  font-weight: bold;\n  -webkit-box-shadow: -2px 2px 10px -4px black;\n  box-shadow: -2px 2px 10px -4px black;\n}\n.analytics #widget-selector .categories-section .arrow-icon {\n  position: absolute;\n  top: 33px;\n  right: -11px;\n  z-index: 1;\n}\n.analytics #widget-selector .categories-section .arrow-icon .square {\n  width: 50px;\n  height: 30px;\n  position: absolute;\n  top: 10px;\n  right: 17px;\n  background-color: #977bf0;\n}\n.analytics #widget-selector .categories-section .arrow-icon i.fa.fa-caret-right {\n  font-size: 52px;\n  color: #977bf0;\n  float: right;\n  position: absolute;\n  top: -1.5px;\n  right: 0px;\n}\n.analytics #widget-selector .widgets-section {\n  background-color: #1e303b;\n  padding-bottom: 15px;\n}\n.analytics #widget-selector .widgets-section > .section-header {\n  text-transform: uppercase;\n  font-size: 12px;\n  color: #977bf0;\n}\n.analytics #widget-selector .widgets-section > .section-lines {\n  padding: 3px 0px;\n}\n.analytics #widget-selector .widgets-section > .section-lines .fa.fa-plus-circle {\n  float: right;\n  margin-top: 3px;\n}\n.analytics #widget-selector .widgets-section > .section-lines > .line-items-grid {\n  width: 100%;\n  display: flex;\n  flex-wrap: wrap;\n  height: 0%;\n}\n.analytics #widget-selector .widgets-section > .section-lines > .line-items-grid > .grid-item {\n  padding: 0 13px;\n  display: flex;\n  flex-grow: 1;\n  flex: 0 31.33%;\n  margin: 0 1%;\n  align-items: center;\n  border-bottom: solid 1px #233845;\n  min-height: 0px;\n}\n@media screen and (max-width: 992px) {\n  .analytics #widget-selector .widgets-section > .section-lines > .line-items-grid > .grid-item {\n    flex: 0 100%;\n  }\n}\n.analytics #widget-selector .widgets-section > .section-lines > .line-items-grid > .grid-item:hover {\n  background-color: #192831;\n  font-weight: normal;\n}\n.analytics #widget-selector .widgets-section > .section-lines > .line-items-grid > .grid-item p.line-item {\n  flex-grow: 1;\n}\n.analytics #widget-selector .bottom {\n  height: 20px;\n}\n.analytics #widget-selector .bottom > .suggestion {\n  float: right;\n  opacity: 0.7;\n}\n.analytics #widget-selector .bottom > .suggestion a {\n  cursor: pointer;\n}\n.analytics #widget-selector .bottom > .suggestion a:hover {\n  color: #00e5f0;\n}\n.analytics #widget-selector .bottom > .suggestion:hover {\n  opacity: 1;\n}\n.analytics #dashboard-settings-panel {\n  position: relative;\n  margin-top: 5px;\n}\n.analytics #dashboard-settings-panel > div {\n  display: flex;\n  justify-content: flex-end;\n}\n.analytics #dashboard-settings-panel > div > * {\n  margin: 0px 3px;\n}\n.analytics #dashboard-settings-panel select {\n  margin: 0;\n  height: 34px;\n  padding-top: 1px;\n}\n.analytics #no-widgets-container {\n  position: relative;\n  min-height: 150px;\n}\n.analytics #no-widgets-container img.bg {\n  left: 0;\n  top: 0;\n  min-width: 100%;\n  min-height: 100%;\n}\n.analytics #no-widgets-container .impac-info-message {\n  position: absolute;\n  top: 0;\n  width: 100%;\n}\n.analytics #no-widgets-container .impac-info-message .info-text {\n  font-size: 25px;\n  font-weight: 300;\n  padding: 20px;\n  min-height: 115px;\n  color: white;\n  border-radius: 10px;\n  background-color: rgba(23, 38, 45, 0.7);\n}\n.analytics #widgets-section #widgets-container {\n  min-height: 700px;\n}\n.analytics #widgets-section .placeHolderBox {\n  margin: 12px;\n  height: 267px;\n  width: 300px;\n  float: left;\n  border: 2px dashed #abc4c6;\n  background: none;\n}\n.analytics.load-failed p {\n  font-size: 22px;\n}\n.analytics.load-failed .second-msg p {\n  color: #e01f74;\n  font-size: 14px;\n}\n.tooltip.impac-widget-selector-tooltip .tooltip-inner.ng-binding {\n  font-size: 14px;\n}\n.impac-widget-suggestion .modal-body input,\n.impac-widget-suggestion .modal-body textarea {\n  width: 100%;\n  color: black;\n}\n.impac-widget-suggestion .modal-body textarea {\n  height: 150px;\n}\n.impac-widget-suggestion .modal-body .thanks-message {\n  color: #dae173;\n}\n.modal-footer .loader {\n  color: white;\n}\n.analytics .dashboard-create .btn-create {\n  background-color: #977bf0;\n}\n.modal.impac-dashboard-create h1 {\n  font-size: 24px;\n}\n.modal.impac-dashboard-create .fa.fa-times {\n  float: right;\n  color: #ccc;\n  cursor: pointer;\n}\n.modal.impac-dashboard-create .control-label {\n  text-align: left;\n}\n.modal.impac-dashboard-create .modal-footer .loader {\n  color: white;\n}\n#module__dashboard-selector a {\n  font-weight: normal;\n}\n#module__dashboard-selector > div:first-child {\n  border-bottom: 1px solid #abc4c6;\n}\n#module__dashboard-selector .buttons-bar-row {\n  margin-top: 54px;\n}\n#module__dashboard-selector .buttons-bar-row.pdf-mode {\n  margin-top: 0px;\n}\n#module__dashboard-selector .buttons-bar {\n  padding: 0;\n  position: relative;\n}\n#module__dashboard-selector .buttons-bar .btn {\n  float: right;\n  margin: 3px;\n  border-radius: 4px;\n}\n#module__dashboard-selector .buttons-bar .title-container h1 {\n  margin: 0px;\n  color: black;\n  cursor: auto;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-title {\n  color: #977bf0;\n  display: inline;\n  cursor: pointer;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-title:hover {\n  color: #734deb;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-title i.fa.fa-pencil {\n  margin-left: 20px;\n  font-size: 14px;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-title i.fa.fa-pencil:hover {\n  color: #dae173;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select {\n  margin: 5px 0px 10px 30px;\n  height: auto;\n  border-left: 1px solid #977bf0;\n  border-bottom: 1px solid #977bf0;\n  width: 300px;\n  background-color: #e6edee;\n  cursor: pointer;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option {\n  color: #17262d;\n  white-space: nowrap;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option:hover {\n  background-color: white;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option.dashboard-create {\n  height: 33px;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option.dashboard-create .btn {\n  float: none;\n  width: 100%;\n  text-align: left;\n  margin: 0px;\n  border-radius: 0px;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option i.fa.fa-pencil {\n  float: right;\n  padding-top: 7px;\n  text-align: center;\n  width: 15%;\n  height: 30px;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option i.fa.fa-pencil:hover {\n  color: #734deb;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option span.name {\n  width: 85%;\n  height: 30px;\n  display: inline-block;\n  padding: 5px 10px 5px 10px;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .change-name {\n  position: absolute;\n  top: 30px;\n  left: 20px;\n  width: 60%;\n  background-color: #17262d;\n  color: white;\n  padding: 10px;\n  border-radius: 4px;\n  text-align: center;\n  -webkit-box-shadow: 0px 0px 25px 4px black;\n  box-shadow: 0px 0px 25px 4px black;\n  z-index: 50;\n  border: solid 1px white;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .change-name .form-control {\n  height: 25px;\n  margin-bottom: 10px;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .data-source-label {\n  color: #17262d;\n  padding-left: 3px;\n  margin: 0px;\n}\n#module__dashboard-selector .buttons-bar .loader-container {\n  padding-left: 10px;\n}\n#module__dashboard-selector .buttons-bar .loader-container .loading-spinner {\n  color: #67BBE9;\n  font-size: 40px;\n}\n#module__dashboard-selector .nav-tabs {\n  border-bottom: 0;\n}\n#module__dashboard-selector .nav.nav-tabs li:last-child > a,\n#module__dashboard-selector .nav.nav-pills li:last-child > a {\n  padding-right: 15px;\n}\n#module__dashboard-selector .nav.nav-tabs li:last-child > a tab-heading a,\n#module__dashboard-selector .nav.nav-pills li:last-child > a tab-heading a {\n  position: static;\n}\n#module__dashboard-selector .nav.nav-tabs li > a {\n  padding: 10px 8px 10px 15px;\n  margin: 0 2px 0 0;\n  background-color: transparent;\n  border: 1px solid #abc4c6;\n  color: black;\n}\n#module__dashboard-selector .nav.nav-tabs li.active > a {\n  background-color: #ffffff;\n  color: #977bf0;\n}\n#module__dashboard-selector .nav.nav-tabs li:last-child.active > a {\n  background-color: transparent;\n}\n#module__dashboard-selector .nav.nav-pills li > a {\n  min-width: 0px;\n  padding-right: 8px;\n}\n#module__dashboard-selector .nav.nav-pills li:last-child tab-heading a {\n  margin-left: 2px;\n}\n#module__dashboard-selector .nav.nav-pills li:last-child.active > a {\n  background-color: #f4f4f4;\n}\n#module__dashboard-selector tab-heading a.close-link {\n  border-bottom: 0px solid;\n  margin-left: 12px;\n  position: relative;\n  top: -9px;\n  right: 1px;\n  color: black;\n}\ndashboard-templates-selector .templates-header {\n  display: flex;\n}\ndashboard-templates-selector .templates-header .templates-toggle {\n  display: flex;\n  flex-grow: 1;\n  justify-content: flex-end;\n  font-size: 20px;\n}\ndashboard-templates-selector .templates-header .templates-toggle i.fa {\n  cursor: pointer;\n}\ndashboard-templates-selector .templates-header .templates-toggle i.fa.fa-toggle-on {\n  color: #977bf0;\n}\ndashboard-templates-selector .templates {\n  border: 1px solid #ccc;\n  box-shadow: inset 0px 0px 1px 0px #ccc;\n  height: 130px;\n  overflow: auto;\n  border-radius: 2px;\n}\ndashboard-templates-selector .templates .template {\n  padding: 5px 10px;\n  color: #5B6667;\n  border-bottom: 1px solid #ececec;\n}\ndashboard-templates-selector .templates .template:hover {\n  cursor: pointer;\n  background-color: rgba(96, 232, 119, 0.62);\n}\ndashboard-templates-selector .templates .template.selected {\n  background-color: rgba(29, 197, 57, 0.62);\n}\n.analytics .impac-kpi .kpi {\n  position: relative;\n  max-width: 220px;\n  min-height: 95px;\n  max-height: 95px;\n  background-color: white;\n  margin: 10px 0 10px 0;\n  border-bottom: 1px solid white;\n  transition: all 0.2s ease-in;\n}\n@media screen and (max-width: 768px) {\n  .analytics .impac-kpi .kpi {\n    margin-left: auto;\n    margin-right: auto;\n  }\n}\n.analytics .impac-kpi .kpi.triggered,\n.analytics .impac-kpi .kpi.add:hover {\n  border-bottom: 4px solid #e01f74;\n}\n.analytics .impac-kpi .kpi.add .kpi-text .emphasis {\n  visibility: hidden;\n}\n.analytics .impac-kpi .kpi.add:hover {\n  cursor: pointer;\n}\n.analytics .impac-kpi .kpi.add:hover .top-line {\n  background-color: black;\n}\n.analytics .impac-kpi .kpi.add:hover .kpi-text {\n  color: black;\n}\n.analytics .impac-kpi .kpi.add:hover .kpi-text .emphasis {\n  visibility: visible;\n}\n.analytics .impac-kpi .kpi.add:hover .kpi-icon {\n  color: black;\n}\n.analytics .impac-kpi .kpi.add:hover .kpi-icon .fa-plus:before {\n  content: \"\\f00c\";\n}\n.analytics .impac-kpi .kpi.editing {\n  min-height: 185px;\n}\n.analytics .impac-kpi .kpi:hover {\n  cursor: default;\n}\n.analytics .impac-kpi .kpi.static .kpi-value {\n  display: block;\n  font-size: 14px;\n  font-weight: 700;\n}\n.analytics .impac-kpi .kpi .top-line {\n  width: 100%;\n  position: relative;\n  cursor: move;\n  padding: 9px 9px 0px 12px;\n  border-bottom: none;\n  min-height: 7px;\n  box-shadow: none;\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-orient: horizontal;\n  -webkit-box-direction: normal;\n  -webkit-flex-direction: row;\n  -ms-flex-direction: row;\n  flex-direction: row;\n  margin-bottom: 5px;\n  background-color: grey;\n  transition: background 0.2s ease-in;\n}\n.analytics .impac-kpi .kpi .top-line.triggered {\n  background-color: black;\n}\n.analytics .impac-kpi .kpi .kpi-content {\n  max-height: 90px;\n}\n.analytics .impac-kpi .kpi .kpi-content.editing {\n  min-height: 180px;\n  overflow-y: auto;\n  overflow-x: hidden;\n}\n.analytics .impac-kpi .kpi .kpi-show {\n  white-space: normal;\n  padding: 10px;\n}\n@media screen and (max-width: 380px) {\n  .analytics .impac-kpi .kpi .kpi-show {\n    padding: 10px 3px;\n  }\n}\n.analytics .impac-kpi .kpi .kpi-show .emphasis {\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n}\n.analytics .impac-kpi .kpi .kpi-show .emphasis .real-value {\n  color: #676767;\n}\n.analytics .impac-kpi .kpi .kpi-show .caption {\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n}\n.analytics .impac-kpi .kpi .kpi-show .kpi-text {\n  padding: 7px 0;\n  color: grey;\n  transition: color 0.2s ease-in;\n}\n.analytics .impac-kpi .kpi .kpi-show .kpi-text > span {\n  display: block;\n}\n.analytics .impac-kpi .kpi .kpi-show .kpi-text.triggered {\n  color: black;\n}\n.analytics .impac-kpi .kpi .kpi-show .kpi-text .caption {\n  font-size: 11px;\n  padding-bottom: 2px;\n}\n@media screen and (max-width: 465px) {\n  .analytics .impac-kpi .kpi .kpi-show .kpi-text .caption {\n    font-size: 10px;\n  }\n  .analytics .impac-kpi .kpi .kpi-show .kpi-text .emphasis {\n    font-size: 11px;\n  }\n}\n.analytics .impac-kpi .kpi .kpi-show .kpi-icon {\n  font-size: 16px;\n  padding: 10px 0;\n  color: grey;\n  transition: color 0.2s ease-in;\n}\n.analytics .impac-kpi .kpi .kpi-show .kpi-icon.triggered {\n  color: black;\n}\n@media screen and (max-width: 465px) {\n  .analytics .impac-kpi .kpi .kpi-show .kpi-icon {\n    font-size: 12px;\n    padding: 16px 0;\n  }\n}\n.analytics .impac-kpi .kpi .kpi-edit a {\n  color: white;\n}\n.analytics .impac-kpi .kpi .kpi-edit .kpi-name {\n  text-align: center;\n  margin-bottom: 5px;\n}\n.analytics .impac-kpi .kpi .kpi-edit .kpi-name h6 {\n  margin: 0 0 5px 0;\n}\n.analytics .impac-kpi .kpi .kpi-edit .real-value {\n  text-transform: uppercase;\n  font-size: 10px;\n  text-align: center;\n}\n.analytics .impac-kpi .kpi .kpi-edit .alert-caption {\n  text-align: center;\n  font-size: 11px;\n  background: #ff9999;\n  border-radius: 3px;\n  width: 100%;\n  margin: 0 auto 5px auto;\n  box-shadow: none;\n  padding: 2px;\n  color: white;\n}\n.analytics .impac-kpi .kpi .kpi-edit .kpi-target-watchable,\n.analytics .impac-kpi .kpi .kpi-edit .kpi-target-unit {\n  text-transform: uppercase;\n  font-weight: 500;\n  font-size: 11px;\n}\n.analytics .impac-kpi .kpi .kpi-edit .kpi-target-watchable {\n  margin-bottom: 20px;\n  color: #8d8d8d;\n}\n.analytics .impac-kpi .kpi .kpi-edit .kpi-target-unit {\n  position: absolute;\n  top: 6px;\n  right: 0;\n  color: #9a9a9a;\n}\n.analytics .impac-kpi .kpi .kpi-edit .param-name {\n  font-size: 85%;\n}\n.analytics .impac-kpi .kpi .kpi-edit .btn.btn-xs {\n  margin-top: 4px;\n}\n.analytics .impac-kpi .kpi .kpi-edit,\n.analytics .impac-kpi .kpi .kpi-no-data {\n  /* Flatten der Bootstrap */\n}\n.analytics .impac-kpi .kpi .kpi-edit .well,\n.analytics .impac-kpi .kpi .kpi-no-data .well,\n.analytics .impac-kpi .kpi .kpi-edit .navbar-inner,\n.analytics .impac-kpi .kpi .kpi-no-data .navbar-inner,\n.analytics .impac-kpi .kpi .kpi-edit .popover,\n.analytics .impac-kpi .kpi .kpi-no-data .popover,\n.analytics .impac-kpi .kpi .kpi-edit .btn,\n.analytics .impac-kpi .kpi .kpi-no-data .btn,\n.analytics .impac-kpi .kpi .kpi-edit .tooltip,\n.analytics .impac-kpi .kpi .kpi-no-data .tooltip,\n.analytics .impac-kpi .kpi .kpi-edit input,\n.analytics .impac-kpi .kpi .kpi-no-data input,\n.analytics .impac-kpi .kpi .kpi-edit select,\n.analytics .impac-kpi .kpi .kpi-no-data select,\n.analytics .impac-kpi .kpi .kpi-edit textarea,\n.analytics .impac-kpi .kpi .kpi-no-data textarea,\n.analytics .impac-kpi .kpi .kpi-edit pre,\n.analytics .impac-kpi .kpi .kpi-no-data pre,\n.analytics .impac-kpi .kpi .kpi-edit .progress,\n.analytics .impac-kpi .kpi .kpi-no-data .progress,\n.analytics .impac-kpi .kpi .kpi-edit .modal,\n.analytics .impac-kpi .kpi .kpi-no-data .modal,\n.analytics .impac-kpi .kpi .kpi-edit .add-on,\n.analytics .impac-kpi .kpi .kpi-no-data .add-on,\n.analytics .impac-kpi .kpi .kpi-edit .alert,\n.analytics .impac-kpi .kpi .kpi-no-data .alert,\n.analytics .impac-kpi .kpi .kpi-edit .table-bordered,\n.analytics .impac-kpi .kpi .kpi-no-data .table-bordered,\n.analytics .impac-kpi .kpi .kpi-edit .nav > .active > a,\n.analytics .impac-kpi .kpi .kpi-no-data .nav > .active > a,\n.analytics .impac-kpi .kpi .kpi-edit .dropdown-menu,\n.analytics .impac-kpi .kpi .kpi-no-data .dropdown-menu,\n.analytics .impac-kpi .kpi .kpi-edit .tooltip-inner,\n.analytics .impac-kpi .kpi .kpi-no-data .tooltip-inner,\n.analytics .impac-kpi .kpi .kpi-edit .badge,\n.analytics .impac-kpi .kpi .kpi-no-data .badge,\n.analytics .impac-kpi .kpi .kpi-edit .label,\n.analytics .impac-kpi .kpi .kpi-no-data .label,\n.analytics .impac-kpi .kpi .kpi-edit .img-polaroid,\n.analytics .impac-kpi .kpi .kpi-no-data .img-polaroid {\n  -moz-box-shadow: none !important;\n  -webkit-box-shadow: none !important;\n  box-shadow: none !important;\n  -webkit-border-radius: 0px !important;\n  -moz-border-radius: 0px !important;\n  border-radius: 0px !important;\n  border-collapse: collapse !important;\n  background-image: none !important;\n}\n.analytics .impac-kpi .kpi .kpi-edit body,\n.analytics .impac-kpi .kpi .kpi-no-data body,\n.analytics .impac-kpi .kpi .kpi-edit input,\n.analytics .impac-kpi .kpi .kpi-no-data input,\n.analytics .impac-kpi .kpi .kpi-edit select,\n.analytics .impac-kpi .kpi .kpi-no-data select,\n.analytics .impac-kpi .kpi .kpi-edit textarea,\n.analytics .impac-kpi .kpi .kpi-no-data textarea {\n  box-sizing: border-box;\n}\n.analytics .impac-kpi .kpi .kpi-edit body::after,\n.analytics .impac-kpi .kpi .kpi-no-data body::after,\n.analytics .impac-kpi .kpi .kpi-edit input::after,\n.analytics .impac-kpi .kpi .kpi-no-data input::after,\n.analytics .impac-kpi .kpi .kpi-edit select::after,\n.analytics .impac-kpi .kpi .kpi-no-data select::after,\n.analytics .impac-kpi .kpi .kpi-edit textarea::after,\n.analytics .impac-kpi .kpi .kpi-no-data textarea::after,\n.analytics .impac-kpi .kpi .kpi-edit body::before,\n.analytics .impac-kpi .kpi .kpi-no-data body::before,\n.analytics .impac-kpi .kpi .kpi-edit input::before,\n.analytics .impac-kpi .kpi .kpi-no-data input::before,\n.analytics .impac-kpi .kpi .kpi-edit select::before,\n.analytics .impac-kpi .kpi .kpi-no-data select::before,\n.analytics .impac-kpi .kpi .kpi-edit textarea::before,\n.analytics .impac-kpi .kpi .kpi-no-data textarea::before {\n  box-sizing: border-box;\n}\n.analytics .impac-kpi .kpi .kpi-edit input[type=number]::-webkit-inner-spin-button,\n.analytics .impac-kpi .kpi .kpi-no-data input[type=number]::-webkit-inner-spin-button,\n.analytics .impac-kpi .kpi .kpi-edit input[type=number]::-webkit-outer-spin-button,\n.analytics .impac-kpi .kpi .kpi-no-data input[type=number]::-webkit-outer-spin-button {\n  -webkit-appearance: none;\n  margin: 0;\n}\n.analytics .impac-kpi .kpi .kpi-edit a:hover,\n.analytics .impac-kpi .kpi .kpi-no-data a:hover {\n  text-decoration: none;\n}\n.analytics .impac-kpi .kpi .kpi-edit fieldset,\n.analytics .impac-kpi .kpi .kpi-no-data fieldset {\n  margin: 0 0 1.75rem;\n  padding: 0;\n  border: none;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-radio,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-radio,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group {\n  position: relative;\n  margin-top: 1.3125rem;\n  margin-bottom: 1.3125rem;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-inline,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-inline {\n  display: flex;\n  flex-direction: row;\n  box-sizing: border-box;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-inline > .im-form-group,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-inline > .im-form-group {\n  display: block;\n  flex: 1;\n  position: relative;\n  vertical-align: middle;\n  margin-left: 0.175rem;\n  margin-right: 0.175rem;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-inline > .btn,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-inline > .btn {\n  display: inline-block;\n  margin-bottom: 0;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input {\n  height: 2.375rem;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea {\n  resize: none;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group select,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select {\n  width: 100%;\n  font-size: 1.25rem;\n  height: 2rem;\n  padding: 0.15625rem 0.15625rem 0.078125rem;\n  background: none;\n  border: none;\n  line-height: 1.6;\n  box-shadow: none;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group .im-control-label {\n  position: absolute;\n  top: 0.3125rem;\n  pointer-events: none;\n  padding-left: 0.15625rem;\n  z-index: 1;\n  color: #b3b3b3;\n  font-size: 1.25rem;\n  font-weight: normal;\n  transition: all 0.28s ease;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group .im-bar,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group .im-bar {\n  position: relative;\n  border-bottom: 0.078125rem solid #999;\n  display: block;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group .im-bar::before,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group .im-bar::before {\n  content: '';\n  height: 0.15625rem;\n  width: 0;\n  left: 50%;\n  bottom: -0.078125rem;\n  position: absolute;\n  background: #358fdc;\n  transition: left 0.28s ease, width 0.28s ease;\n  z-index: 2;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea {\n  display: block;\n  background: none;\n  padding: 0.15625rem 0.15625rem 0.078125rem;\n  font-size: 1.25rem;\n  border-width: 0;\n  border-color: transparent;\n  line-height: 1.9;\n  width: 100%;\n  color: transparent;\n  transition: all 0.28s ease;\n  box-shadow: none;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input[type=\"file\"],\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input[type=\"file\"] {\n  line-height: 1;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input[type=\"file\"] ~ .im-bar,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input[type=\"file\"] ~ .im-bar {\n  display: none;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group select,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:focus,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:focus,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:valid,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:valid,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input.form-file,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input.form-file,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input.has-value,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input.has-value,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:focus,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:focus,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:valid,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:valid,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea.form-file,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea.form-file,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea.has-value,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea.has-value {\n  color: #333;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group select ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:focus ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:focus ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:valid ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:valid ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input.form-file ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input.form-file ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input.has-value ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input.has-value ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:focus ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:focus ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:valid ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:valid ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea.form-file ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea.form-file ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea.has-value ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea.has-value ~ .im-control-label {\n  font-size: 1rem;\n  color: #808080;\n  top: -1.25rem;\n  left: 0;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group select:focus,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select:focus,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:focus,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:focus,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:focus,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:focus {\n  outline: none;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group select:focus ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select:focus ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:focus ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:focus ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:focus ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:focus ~ .im-control-label {\n  color: #358fdc;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group select:focus ~ .im-bar::before,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select:focus ~ .im-bar::before,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:focus ~ .im-bar::before,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:focus ~ .im-bar::before,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:focus ~ .im-bar::before,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:focus ~ .im-bar::before {\n  width: 100%;\n  left: 0;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-radio label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-radio label {\n  position: relative;\n  cursor: pointer;\n  padding-left: 2.5rem;\n  text-align: left;\n  color: #333;\n  display: block;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-radio input,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-radio input {\n  width: auto;\n  opacity: 0.00000001;\n  position: absolute;\n  left: 0;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-radio,\n.analytics .impac-kpi .kpi .kpi-no-data .im-radio {\n  margin-bottom: 1.25rem;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-radio .im-helper,\n.analytics .impac-kpi .kpi .kpi-no-data .im-radio .im-helper {\n  position: absolute;\n  top: -0.3125rem;\n  left: -0.3125rem;\n  cursor: pointer;\n  display: block;\n  font-size: 1.25rem;\n  user-select: none;\n  color: #999;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-radio .im-helper::before,\n.analytics .impac-kpi .kpi .kpi-no-data .im-radio .im-helper::before,\n.analytics .impac-kpi .kpi .kpi-edit .im-radio .im-helper::after,\n.analytics .impac-kpi .kpi .kpi-no-data .im-radio .im-helper::after {\n  content: '';\n  position: absolute;\n  left: 0;\n  top: 0;\n  margin: 0.3125rem;\n  width: 1.25rem;\n  height: 1.25rem;\n  transition: transform 0.28s ease;\n  border-radius: 50%;\n  border: 0.15625rem solid currentColor;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-radio .im-helper::after,\n.analytics .impac-kpi .kpi .kpi-no-data .im-radio .im-helper::after {\n  transform: scale(0);\n  background-color: #358fdc;\n  border-color: #358fdc;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-radio label:hover .im-helper,\n.analytics .impac-kpi .kpi .kpi-no-data .im-radio label:hover .im-helper {\n  color: #358fdc;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-radio input:checked ~ .im-helper::after,\n.analytics .impac-kpi .kpi .kpi-no-data .im-radio input:checked ~ .im-helper::after {\n  transform: scale(0.5);\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-radio input:checked ~ .im-helper::before,\n.analytics .impac-kpi .kpi .kpi-no-data .im-radio input:checked ~ .im-helper::before {\n  color: #358fdc;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox {\n  margin-top: 1.75rem;\n  margin-bottom: 1.25rem;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox .im-helper,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox .im-helper {\n  color: #999;\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 1.25rem;\n  height: 1.25rem;\n  z-index: 0;\n  border: 0.15625rem solid currentColor;\n  border-radius: 0.078125rem;\n  transition: border-color 0.28s ease;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox .im-helper::before,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox .im-helper::before,\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox .im-helper::after,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox .im-helper::after {\n  position: absolute;\n  height: 0;\n  width: 0.25rem;\n  background-color: #358fdc;\n  display: block;\n  transform-origin: left top;\n  border-radius: 0.3125rem;\n  content: '';\n  transition: opacity 0.28s ease, height 0s linear 0.28s;\n  opacity: 0;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox .im-helper::before,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox .im-helper::before {\n  top: 0.8125rem;\n  left: 0.475rem;\n  transform: rotate(-135deg);\n  box-shadow: 0 0 0 0.078125rem #fff;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox .im-helper::after,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox .im-helper::after {\n  top: 0.375rem;\n  left: 0;\n  transform: rotate(-45deg);\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox label:hover .im-helper,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox label:hover .im-helper {\n  color: #358fdc;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input:checked ~ .im-helper,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input:checked ~ .im-helper {\n  color: #358fdc;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input:checked ~ .im-helper::after,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input:checked ~ .im-helper::after,\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input:checked ~ .im-helper::before,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input:checked ~ .im-helper::before {\n  opacity: 1;\n  transition: height 0.28s ease;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input:checked ~ .im-helper::after,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input:checked ~ .im-helper::after {\n  height: 0.625rem;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input:checked ~ .im-helper::before,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input:checked ~ .im-helper::before {\n  height: 1.5rem;\n  transition-delay: 0.28s;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-radio + .im-radio,\n.analytics .impac-kpi .kpi .kpi-no-data .im-radio + .im-radio,\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox + .im-checkbox,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox + .im-checkbox {\n  margin-top: 1.25rem;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-messages,\n.analytics .impac-kpi .kpi .kpi-no-data .im-messages {\n  font-size: 1.04166667rem;\n  color: #e01f74;\n  overflow: hidden;\n  transition: all 0.28s cubic-bezier(0.55, 0, 0.55, 0.2);\n  opacity: 0;\n  margin-top: 0;\n  padding-top: 5px;\n}\n.analytics .impac-kpi .kpi .kpi-edit .has-error .legend.legend,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error .legend.legend,\n.analytics .impac-kpi .kpi .kpi-edit .has-error.im-form-group .im-control-label.im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-form-group .im-control-label.im-control-label {\n  color: #e01f74;\n}\n.analytics .impac-kpi .kpi .kpi-edit .has-error.im-form-group .im-messages,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-form-group .im-messages,\n.analytics .impac-kpi .kpi .kpi-edit .has-error.im-checkbox .im-messages,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-checkbox .im-messages,\n.analytics .impac-kpi .kpi .kpi-edit .has-error.im-radio .im-messages,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-radio .im-messages,\n.analytics .impac-kpi .kpi .kpi-edit .has-error.im-form-radio .im-messages,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-form-radio .im-messages,\n.analytics .impac-kpi .kpi .kpi-edit .has-error.im-form-group .im-helper,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-form-group .im-helper,\n.analytics .impac-kpi .kpi .kpi-edit .has-error.im-checkbox .im-helper,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-checkbox .im-helper,\n.analytics .impac-kpi .kpi .kpi-edit .has-error.im-radio .im-helper,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-radio .im-helper,\n.analytics .impac-kpi .kpi .kpi-edit .has-error.im-form-radio .im-helper,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-form-radio .im-helper {\n  color: #e01f74;\n  opacity: 1;\n}\n.analytics .impac-kpi .kpi .kpi-edit .has-error .im-bar::before,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error .im-bar::before {\n  background: #e01f74;\n  left: 0;\n  width: 100%;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-button,\n.analytics .impac-kpi .kpi .kpi-no-data .im-button {\n  position: relative;\n  background: #60a7e4;\n  border: 0;\n  font-size: 1.375rem;\n  color: #333;\n  margin: 0.7rem 0;\n  padding: 0.4375rem 1.75rem;\n  border-radius: 3px;\n  cursor: pointer;\n  overflow: hidden;\n  box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-button span,\n.analytics .impac-kpi .kpi .kpi-no-data .im-button span {\n  color: #fff;\n  position: relative;\n  z-index: 1;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-button:hover,\n.analytics .impac-kpi .kpi .kpi-no-data .im-button:hover {\n  transition: background 0.1s ease-in;\n  background: #2583d3;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-button:active,\n.analytics .impac-kpi .kpi .kpi-no-data .im-button:active {\n  box-shadow: inset 0 2px 2px 0 rgba(0, 0, 0, 0.14);\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-button a:focus,\n.analytics .impac-kpi .kpi .kpi-no-data .im-button a:focus,\n.analytics .impac-kpi .kpi .kpi-edit .im-button:focus,\n.analytics .impac-kpi .kpi .kpi-no-data .im-button:focus {\n  outline: none;\n  text-decoration: none;\n}\n.analytics .impac-kpi .kpi .kpi-edit button.im-fab,\n.analytics .impac-kpi .kpi .kpi-no-data button.im-fab {\n  position: relative;\n  height: 46px;\n  width: 46px;\n  flex: 0 0 56px;\n  display: inline-block;\n  padding: 0;\n  margin: 4px;\n  border: 0;\n  border-radius: 100%;\n  overflow: hidden;\n  font-size: 20px;\n  box-shadow: 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12), 0 2px 4px -1px rgba(0, 0, 0, 0.2);\n  color: white;\n}\n.analytics .impac-kpi .kpi .kpi-edit button.im-fab:focus,\n.analytics .impac-kpi .kpi .kpi-no-data button.im-fab:focus {\n  outline: 0;\n}\n.analytics .impac-kpi .kpi .kpi-edit button.im-fab:active,\n.analytics .impac-kpi .kpi .kpi-no-data button.im-fab:active {\n  box-shadow: inset 0 2px 2px 0 rgba(0, 0, 0, 0.14);\n}\n.analytics .impac-kpi .kpi .kpi-edit button.im-fab.im-primary,\n.analytics .impac-kpi .kpi .kpi-no-data button.im-fab.im-primary {\n  background: #358fdc;\n}\n.analytics .impac-kpi .kpi .kpi-edit button.im-fab.im-primary:hover,\n.analytics .impac-kpi .kpi .kpi-no-data button.im-fab.im-primary:hover {\n  transition: background 0.1s ease-in;\n  background: #2583d3;\n}\n.analytics .impac-kpi .kpi .kpi-edit button.im-fab.im-warn,\n.analytics .impac-kpi .kpi .kpi-no-data button.im-fab.im-warn {\n  background: #e01f74;\n}\n.analytics .impac-kpi .kpi .kpi-edit button.im-fab.im-warn:hover,\n.analytics .impac-kpi .kpi .kpi-no-data button.im-fab.im-warn:hover {\n  transition: background 0.1s ease-in;\n  background: #ca1c68;\n}\n.analytics .impac-kpi .kpi button.kpi-alerts.im-fab.im-primary {\n  position: absolute;\n  top: -12px;\n  right: 15px;\n  width: 22px;\n  height: 22px;\n  font-size: 13px;\n  background: #4c4749;\n}\n.analytics .impac-kpi .kpi button.kpi-alerts.im-fab.im-primary:hover {\n  backgroud: #358fdc;\n}\n.analytics .impac-kpi .kpi button.kpi-remove.im-fab.im-warn {\n  position: absolute;\n  top: -12px;\n  right: -11px;\n  width: 22px;\n  height: 22px;\n  font-size: 13px;\n  background: #4c4749;\n}\n.analytics .impac-kpi .kpi button.kpi-remove.im-fab.im-warn:hover {\n  background: #ca1c68;\n}\n.analytics .impac-kpi .kpi .kpi-data-loader {\n  width: 100%;\n  min-height: 95px;\n}\n.analytics kpis-bar > .key-stats .kpi {\n  min-height: 80px;\n}\n.analytics kpis-bar > .kpis {\n  position: relative;\n}\n.analytics kpis-bar > .kpis .actions {\n  margin-bottom: 12px;\n  /* Flatten der Bootstrap */\n}\n@media screen and (max-width: 675px) {\n  .analytics kpis-bar > .kpis .actions {\n    position: relative;\n  }\n}\n.analytics kpis-bar > .kpis .actions .well,\n.analytics kpis-bar > .kpis .actions .navbar-inner,\n.analytics kpis-bar > .kpis .actions .popover,\n.analytics kpis-bar > .kpis .actions .btn,\n.analytics kpis-bar > .kpis .actions .tooltip,\n.analytics kpis-bar > .kpis .actions input,\n.analytics kpis-bar > .kpis .actions select,\n.analytics kpis-bar > .kpis .actions textarea,\n.analytics kpis-bar > .kpis .actions pre,\n.analytics kpis-bar > .kpis .actions .progress,\n.analytics kpis-bar > .kpis .actions .modal,\n.analytics kpis-bar > .kpis .actions .add-on,\n.analytics kpis-bar > .kpis .actions .alert,\n.analytics kpis-bar > .kpis .actions .table-bordered,\n.analytics kpis-bar > .kpis .actions .nav > .active > a,\n.analytics kpis-bar > .kpis .actions .dropdown-menu,\n.analytics kpis-bar > .kpis .actions .tooltip-inner,\n.analytics kpis-bar > .kpis .actions .badge,\n.analytics kpis-bar > .kpis .actions .label,\n.analytics kpis-bar > .kpis .actions .img-polaroid {\n  -moz-box-shadow: none !important;\n  -webkit-box-shadow: none !important;\n  box-shadow: none !important;\n  -webkit-border-radius: 0px !important;\n  -moz-border-radius: 0px !important;\n  border-radius: 0px !important;\n  border-collapse: collapse !important;\n  background-image: none !important;\n}\n.analytics kpis-bar > .kpis .actions body,\n.analytics kpis-bar > .kpis .actions input,\n.analytics kpis-bar > .kpis .actions select,\n.analytics kpis-bar > .kpis .actions textarea {\n  box-sizing: border-box;\n}\n.analytics kpis-bar > .kpis .actions body::after,\n.analytics kpis-bar > .kpis .actions input::after,\n.analytics kpis-bar > .kpis .actions select::after,\n.analytics kpis-bar > .kpis .actions textarea::after,\n.analytics kpis-bar > .kpis .actions body::before,\n.analytics kpis-bar > .kpis .actions input::before,\n.analytics kpis-bar > .kpis .actions select::before,\n.analytics kpis-bar > .kpis .actions textarea::before {\n  box-sizing: border-box;\n}\n.analytics kpis-bar > .kpis .actions input[type=number]::-webkit-inner-spin-button,\n.analytics kpis-bar > .kpis .actions input[type=number]::-webkit-outer-spin-button {\n  -webkit-appearance: none;\n  margin: 0;\n}\n.analytics kpis-bar > .kpis .actions a:hover {\n  text-decoration: none;\n}\n.analytics kpis-bar > .kpis .actions fieldset {\n  margin: 0 0 1.75rem;\n  padding: 0;\n  border: none;\n}\n.analytics kpis-bar > .kpis .actions .im-form-radio,\n.analytics kpis-bar > .kpis .actions .im-form-group {\n  position: relative;\n  margin-top: 1.3125rem;\n  margin-bottom: 1.3125rem;\n}\n.analytics kpis-bar > .kpis .actions .im-form-inline {\n  display: flex;\n  flex-direction: row;\n  box-sizing: border-box;\n}\n.analytics kpis-bar > .kpis .actions .im-form-inline > .im-form-group {\n  display: block;\n  flex: 1;\n  position: relative;\n  vertical-align: middle;\n  margin-left: 0.175rem;\n  margin-right: 0.175rem;\n}\n.analytics kpis-bar > .kpis .actions .im-form-inline > .btn {\n  display: inline-block;\n  margin-bottom: 0;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group input {\n  height: 2.375rem;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group textarea {\n  resize: none;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group select {\n  width: 100%;\n  font-size: 1.25rem;\n  height: 2rem;\n  padding: 0.15625rem 0.15625rem 0.078125rem;\n  background: none;\n  border: none;\n  line-height: 1.6;\n  box-shadow: none;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group .im-control-label {\n  position: absolute;\n  top: 0.3125rem;\n  pointer-events: none;\n  padding-left: 0.15625rem;\n  z-index: 1;\n  color: #b3b3b3;\n  font-size: 1.25rem;\n  font-weight: normal;\n  transition: all 0.28s ease;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group .im-bar {\n  position: relative;\n  border-bottom: 0.078125rem solid #999;\n  display: block;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group .im-bar::before {\n  content: '';\n  height: 0.15625rem;\n  width: 0;\n  left: 50%;\n  bottom: -0.078125rem;\n  position: absolute;\n  background: #358fdc;\n  transition: left 0.28s ease, width 0.28s ease;\n  z-index: 2;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group input,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea {\n  display: block;\n  background: none;\n  padding: 0.15625rem 0.15625rem 0.078125rem;\n  font-size: 1.25rem;\n  border-width: 0;\n  border-color: transparent;\n  line-height: 1.9;\n  width: 100%;\n  color: transparent;\n  transition: all 0.28s ease;\n  box-shadow: none;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group input[type=\"file\"] {\n  line-height: 1;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group input[type=\"file\"] ~ .im-bar {\n  display: none;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group select,\n.analytics kpis-bar > .kpis .actions .im-form-group input:focus,\n.analytics kpis-bar > .kpis .actions .im-form-group input:valid,\n.analytics kpis-bar > .kpis .actions .im-form-group input.form-file,\n.analytics kpis-bar > .kpis .actions .im-form-group input.has-value,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea:focus,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea:valid,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea.form-file,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea.has-value {\n  color: #333;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group select ~ .im-control-label,\n.analytics kpis-bar > .kpis .actions .im-form-group input:focus ~ .im-control-label,\n.analytics kpis-bar > .kpis .actions .im-form-group input:valid ~ .im-control-label,\n.analytics kpis-bar > .kpis .actions .im-form-group input.form-file ~ .im-control-label,\n.analytics kpis-bar > .kpis .actions .im-form-group input.has-value ~ .im-control-label,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea:focus ~ .im-control-label,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea:valid ~ .im-control-label,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea.form-file ~ .im-control-label,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea.has-value ~ .im-control-label {\n  font-size: 1rem;\n  color: #808080;\n  top: -1.25rem;\n  left: 0;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group select:focus,\n.analytics kpis-bar > .kpis .actions .im-form-group input:focus,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea:focus {\n  outline: none;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group select:focus ~ .im-control-label,\n.analytics kpis-bar > .kpis .actions .im-form-group input:focus ~ .im-control-label,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea:focus ~ .im-control-label {\n  color: #358fdc;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group select:focus ~ .im-bar::before,\n.analytics kpis-bar > .kpis .actions .im-form-group input:focus ~ .im-bar::before,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea:focus ~ .im-bar::before {\n  width: 100%;\n  left: 0;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox label,\n.analytics kpis-bar > .kpis .actions .im-form-radio label {\n  position: relative;\n  cursor: pointer;\n  padding-left: 2.5rem;\n  text-align: left;\n  color: #333;\n  display: block;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox input,\n.analytics kpis-bar > .kpis .actions .im-form-radio input {\n  width: auto;\n  opacity: 0.00000001;\n  position: absolute;\n  left: 0;\n}\n.analytics kpis-bar > .kpis .actions .im-radio {\n  margin-bottom: 1.25rem;\n}\n.analytics kpis-bar > .kpis .actions .im-radio .im-helper {\n  position: absolute;\n  top: -0.3125rem;\n  left: -0.3125rem;\n  cursor: pointer;\n  display: block;\n  font-size: 1.25rem;\n  user-select: none;\n  color: #999;\n}\n.analytics kpis-bar > .kpis .actions .im-radio .im-helper::before,\n.analytics kpis-bar > .kpis .actions .im-radio .im-helper::after {\n  content: '';\n  position: absolute;\n  left: 0;\n  top: 0;\n  margin: 0.3125rem;\n  width: 1.25rem;\n  height: 1.25rem;\n  transition: transform 0.28s ease;\n  border-radius: 50%;\n  border: 0.15625rem solid currentColor;\n}\n.analytics kpis-bar > .kpis .actions .im-radio .im-helper::after {\n  transform: scale(0);\n  background-color: #358fdc;\n  border-color: #358fdc;\n}\n.analytics kpis-bar > .kpis .actions .im-radio label:hover .im-helper {\n  color: #358fdc;\n}\n.analytics kpis-bar > .kpis .actions .im-radio input:checked ~ .im-helper::after {\n  transform: scale(0.5);\n}\n.analytics kpis-bar > .kpis .actions .im-radio input:checked ~ .im-helper::before {\n  color: #358fdc;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox {\n  margin-top: 1.75rem;\n  margin-bottom: 1.25rem;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox .im-helper {\n  color: #999;\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 1.25rem;\n  height: 1.25rem;\n  z-index: 0;\n  border: 0.15625rem solid currentColor;\n  border-radius: 0.078125rem;\n  transition: border-color 0.28s ease;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox .im-helper::before,\n.analytics kpis-bar > .kpis .actions .im-checkbox .im-helper::after {\n  position: absolute;\n  height: 0;\n  width: 0.25rem;\n  background-color: #358fdc;\n  display: block;\n  transform-origin: left top;\n  border-radius: 0.3125rem;\n  content: '';\n  transition: opacity 0.28s ease, height 0s linear 0.28s;\n  opacity: 0;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox .im-helper::before {\n  top: 0.8125rem;\n  left: 0.475rem;\n  transform: rotate(-135deg);\n  box-shadow: 0 0 0 0.078125rem #fff;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox .im-helper::after {\n  top: 0.375rem;\n  left: 0;\n  transform: rotate(-45deg);\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox label:hover .im-helper {\n  color: #358fdc;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox input:checked ~ .im-helper {\n  color: #358fdc;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox input:checked ~ .im-helper::after,\n.analytics kpis-bar > .kpis .actions .im-checkbox input:checked ~ .im-helper::before {\n  opacity: 1;\n  transition: height 0.28s ease;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox input:checked ~ .im-helper::after {\n  height: 0.625rem;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox input:checked ~ .im-helper::before {\n  height: 1.5rem;\n  transition-delay: 0.28s;\n}\n.analytics kpis-bar > .kpis .actions .im-radio + .im-radio,\n.analytics kpis-bar > .kpis .actions .im-checkbox + .im-checkbox {\n  margin-top: 1.25rem;\n}\n.analytics kpis-bar > .kpis .actions .im-messages {\n  font-size: 1.04166667rem;\n  color: #e01f74;\n  overflow: hidden;\n  transition: all 0.28s cubic-bezier(0.55, 0, 0.55, 0.2);\n  opacity: 0;\n  margin-top: 0;\n  padding-top: 5px;\n}\n.analytics kpis-bar > .kpis .actions .has-error .legend.legend,\n.analytics kpis-bar > .kpis .actions .has-error.im-form-group .im-control-label.im-control-label {\n  color: #e01f74;\n}\n.analytics kpis-bar > .kpis .actions .has-error.im-form-group .im-messages,\n.analytics kpis-bar > .kpis .actions .has-error.im-checkbox .im-messages,\n.analytics kpis-bar > .kpis .actions .has-error.im-radio .im-messages,\n.analytics kpis-bar > .kpis .actions .has-error.im-form-radio .im-messages,\n.analytics kpis-bar > .kpis .actions .has-error.im-form-group .im-helper,\n.analytics kpis-bar > .kpis .actions .has-error.im-checkbox .im-helper,\n.analytics kpis-bar > .kpis .actions .has-error.im-radio .im-helper,\n.analytics kpis-bar > .kpis .actions .has-error.im-form-radio .im-helper {\n  color: #e01f74;\n  opacity: 1;\n}\n.analytics kpis-bar > .kpis .actions .has-error .im-bar::before {\n  background: #e01f74;\n  left: 0;\n  width: 100%;\n}\n.analytics kpis-bar > .kpis .actions .im-button {\n  position: relative;\n  background: #60a7e4;\n  border: 0;\n  font-size: 1.375rem;\n  color: #333;\n  margin: 0.7rem 0;\n  padding: 0.4375rem 1.75rem;\n  border-radius: 3px;\n  cursor: pointer;\n  overflow: hidden;\n  box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n}\n.analytics kpis-bar > .kpis .actions .im-button span {\n  color: #fff;\n  position: relative;\n  z-index: 1;\n}\n.analytics kpis-bar > .kpis .actions .im-button:hover {\n  transition: background 0.1s ease-in;\n  background: #2583d3;\n}\n.analytics kpis-bar > .kpis .actions .im-button:active {\n  box-shadow: inset 0 2px 2px 0 rgba(0, 0, 0, 0.14);\n}\n.analytics kpis-bar > .kpis .actions .im-button a:focus,\n.analytics kpis-bar > .kpis .actions .im-button:focus {\n  outline: none;\n  text-decoration: none;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab {\n  position: relative;\n  height: 46px;\n  width: 46px;\n  flex: 0 0 56px;\n  display: inline-block;\n  padding: 0;\n  margin: 4px;\n  border: 0;\n  border-radius: 100%;\n  overflow: hidden;\n  font-size: 20px;\n  box-shadow: 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12), 0 2px 4px -1px rgba(0, 0, 0, 0.2);\n  color: white;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab:focus {\n  outline: 0;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab:active {\n  box-shadow: inset 0 2px 2px 0 rgba(0, 0, 0, 0.14);\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.im-primary {\n  background: #358fdc;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.im-primary:hover {\n  transition: background 0.1s ease-in;\n  background: #2583d3;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.im-warn {\n  background: #e01f74;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.im-warn:hover {\n  transition: background 0.1s ease-in;\n  background: #ca1c68;\n}\n.analytics kpis-bar > .kpis .actions a {\n  color: white;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.add-kpis,\n.analytics kpis-bar > .kpis .actions button.im-fab.edit-kpis,\n.analytics kpis-bar > .kpis .actions button.im-fab.toggle-show-content {\n  position: absolute;\n  width: 40px;\n  height: 40px;\n  font-size: 18px;\n  transition: all 0.28s ease-in;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.add-kpis.im-primary,\n.analytics kpis-bar > .kpis .actions button.im-fab.edit-kpis.im-primary,\n.analytics kpis-bar > .kpis .actions button.im-fab.toggle-show-content.im-primary {\n  background: #4c4749;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.add-kpis.im-primary.disabled,\n.analytics kpis-bar > .kpis .actions button.im-fab.edit-kpis.im-primary.disabled,\n.analytics kpis-bar > .kpis .actions button.im-fab.toggle-show-content.im-primary.disabled {\n  background: #b2b5c1;\n  cursor: not-allowed;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.add-kpis.im-primary.disabled a,\n.analytics kpis-bar > .kpis .actions button.im-fab.edit-kpis.im-primary.disabled a,\n.analytics kpis-bar > .kpis .actions button.im-fab.toggle-show-content.im-primary.disabled a {\n  cursor: not-allowed;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.add-kpis.im-primary:hover:not(.disabled),\n.analytics kpis-bar > .kpis .actions button.im-fab.edit-kpis.im-primary:hover:not(.disabled),\n.analytics kpis-bar > .kpis .actions button.im-fab.toggle-show-content.im-primary:hover:not(.disabled) {\n  background: black;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.toggle-show-content {\n  top: -15px;\n  right: -15px;\n  z-index: 10;\n}\n@media screen and (max-width: 675px) {\n  .analytics kpis-bar > .kpis .actions button.im-fab.toggle-show-content {\n    top: -30px;\n    right: -14px;\n    bottom: 0;\n  }\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.add-kpis {\n  top: 30px;\n  right: -15px;\n  z-index: 10;\n}\n@media screen and (max-width: 675px) {\n  .analytics kpis-bar > .kpis .actions button.im-fab.add-kpis {\n    top: -30px;\n    right: 33px;\n    bottom: 0;\n  }\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.edit-kpis {\n  top: 75px;\n  right: -15px;\n  z-index: 10;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.edit-kpis.editing {\n  background: #358fdc;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.edit-kpis.editing:hover:not(.disabled) {\n  background: #76b3e7;\n}\n@media screen and (max-width: 675px) {\n  .analytics kpis-bar > .kpis .actions button.im-fab.edit-kpis {\n    top: -30px;\n    right: 79px;\n    bottom: 0;\n  }\n}\n.analytics kpis-bar > .kpis .content-buttons {\n  position: absolute;\n  top: 0;\n  right: 0;\n}\n.analytics kpis-bar > .kpis .content {\n  padding: 15px;\n  background-color: white;\n  box-shadow: 0px 1px 8px -4px;\n}\n@media screen and (min-width: 725px) {\n  .analytics kpis-bar > .kpis .content {\n    padding: 0 60px;\n  }\n}\n@media screen and (max-width: 675px) {\n  .analytics kpis-bar > .kpis .content {\n    margin-top: 25px;\n  }\n}\n.analytics kpis-bar > .kpis .content .impac-kpi {\n  padding-left: 5px;\n  padding-right: 5px;\n}\n@media screen and (min-width: 1200px) {\n  .analytics kpis-bar > .kpis .content .impac-kpi {\n    padding-left: 20px;\n    padding-right: 20px;\n  }\n}\n.analytics kpis-bar > .kpis .content .impac-kpi .kpi.add .kpi-show .caption {\n  white-space: inherit;\n}\n.analytics kpis-bar > .kpis .content .title .text-center {\n  line-height: 3;\n  font-variant: small-caps;\n  font-size: larger;\n}\n.analytics kpis-bar > .kpis .content .title .badge {\n  position: absolute;\n  top: 8px;\n  left: -10px;\n  background-color: #d1e55c;\n  color: #4f5959;\n  box-shadow: 0px 1px 3px -1px;\n}\n.analytics kpis-bar > .kpis .content .title .no-kpi-templates {\n  color: #afadb5;\n  font-weight: 500;\n}\n.analytics kpis-bar > .kpis .content .add-bar {\n  border-bottom: dashed 1px;\n}\n.analytics kpis-bar > .kpis .content .kpi-loader {\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  min-height: 115px;\n}\n.analytics kpis-bar > .kpis .content .dates-picker-container {\n  width: 40%;\n  margin: 0 auto;\n}\n.analytics kpis-bar > .kpis .content .dates-picker-container .sdp-from-label,\n.analytics kpis-bar > .kpis .content .dates-picker-container .sdp-to-label {\n  text-transform: uppercase;\n  font-weight: 400;\n}\n.analytics kpis-bar {\n  display: block;\n}\n.analytics kpis-bar > .key-stats {\n  background-color: white;\n  padding: 5px 0px;\n}\n.analytics.pdf-mode kpis-bar > .kpis .actions {\n  display: none;\n}\n.widget-item {\n  transition: width 0.3s;\n  padding: 12px;\n}\n.widget-item.pdf-mode {\n  width: 100%;\n  padding: 12px 0px;\n}\n.widget-item .top-line {\n  position: relative;\n  cursor: move;\n  background-color: white;\n  padding: 9px 9px 0px 12px;\n  border-radius: 5px 5px 0px 0px;\n  border: solid 1px #c8d7d9;\n  border-bottom: none;\n  min-height: 41px;\n  -webkit-box-shadow: 0px 1px 8px -4px;\n  box-shadow: 0px 1px 8px -4px;\n  display: flex;\n  flex-direction: row;\n  z-index: 4;\n}\n.widget-item .content {\n  position: relative;\n  padding: 9px;\n  border-radius: 0px 0px 5px 5px;\n  border: solid 1px #c8d7d9;\n  border-top: none;\n  background-color: white;\n  vertical-align: top;\n  -webkit-box-shadow: 0px 1px 8px -4px;\n  box-shadow: 0px 1px 8px -4px;\n  min-height: 250px;\n}\n@media (min-width: 992px) {\n  .widget-item .content {\n    height: 250px;\n  }\n  .widget-item .content .chart-container {\n    max-width: 270px;\n    max-height: 125px;\n    margin: auto;\n  }\n}\n.widget-item .content .edit {\n  max-height: 230px;\n}\n.widget-item .content .edit {\n  overflow-y: auto;\n  overflow-x: hidden;\n  color: #5B6667;\n  padding: 2px;\n  font-size: 12px;\n}\n.widget-item .content .edit .bottom-buttons .btn {\n  border-radius: 2px;\n  margin-right: 5px;\n  padding: 3px 13px;\n  text-transform: uppercase;\n  font-size: 12px;\n}\n.widget-item .content .edit .bottom-buttons .btn.btn-default {\n  background-color: #c2c4c4;\n  border: solid 1px #a8abab;\n  color: white;\n}\n.widget-item .content .edit .bottom-buttons .btn.btn-default:hover {\n  border: solid 1px #8e9292;\n  background-color: #a8abab;\n}\n.widget-item .content .edit h4 {\n  margin: 0;\n  margin-bottom: 8px;\n  text-align: left;\n  font-weight: normal;\n  font-size: 12px;\n  color: #c4caca;\n}\n.widget-item .content .edit .part {\n  margin-bottom: 8px;\n  padding: 10px 0px;\n  background-color: #fcfcfc;\n  border: solid 1px #dfe2e2;\n}\n.widget-item .content .edit .part h5 {\n  display: block;\n  margin: 0;\n  margin-bottom: 10px;\n  padding: 0px 15px;\n  text-transform: uppercase;\n  font-weight: normal;\n  font-size: 12px;\n  color: #c4caca;\n}\n.widget-item .content .edit .part label {\n  font-weight: normal;\n}\n.widget-item .content .edit .part select.form-control {\n  margin: 0px;\n  border: solid 1px #acb0b1;\n  outline: none;\n  -webkit-box-shadow: none;\n  font-size: 13px;\n  color: #72728b;\n}\n.widget-item .content.accessible {\n  height: auto !important;\n  min-height: 250px !important;\n  max-height: auto !important;\n}\n.widget-item .content .content-template-wrapper {\n  height: 100%;\n  overflow: auto;\n  overflow-x: hidden;\n}\n.widget-item.pdf-mode .content {\n  height: 100% !important;\n  min-height: 250px !important;\n  max-height: none !important;\n}\n.widget-item.pdf-mode .content .collapse {\n  display: inherit;\n}\n.widget-item.pdf-mode .content .fa-plus-square-o:before {\n  content: \"\\f147\";\n}\n.widget-item.pdf-mode .content .legend {\n  max-height: none !important;\n}\n.widget-item.pdf-mode .content .chart-container {\n  max-height: none;\n}\n.widget-item.pdf-mode .content .widget-lines-container {\n  max-height: none !important;\n}\n.widget-item.pdf-mode .content .data-not-found .message {\n  position: inherit;\n  width: 100%;\n}\n.widget-item.pdf-mode .include-to-pdf.title {\n  position: absolute;\n  width: calc(100% - 2*12px );\n  z-index: 3;\n  padding-right: 1px;\n}\n.widget-item.pdf-mode .include-to-pdf.title h6 {\n  padding: 10px;\n  background-color: #FFC928;\n  text-align: center;\n  margin: 0;\n}\n.widget-item.pdf-mode .include-to-pdf.tick i {\n  position: absolute;\n  top: 35%;\n  left: 46%;\n  font-size: 100px;\n  opacity: .5;\n  z-index: 2;\n  color: black;\n}\n.widget-item.pdf-mode .include-to-pdf .widget-hover {\n  position: absolute;\n  width: 100%;\n  height: 100%;\n  padding: 9px;\n  top: 0;\n  right: 0;\n  -webkit-transition: all ease .5s;\n  -moz-transition: all ease .5s;\n  transition: all ease .5s;\n  z-index: 1;\n}\n.widget-item.pdf-mode .include-to-pdf .widget-hover:hover {\n  opacity: .5;\n  background: #CCCFD0;\n}\n.widget-item .widget-lines-container .widget-line > [class*='col-'] {\n  overflow-wrap: break-word;\n}\n.analytics .widget-item .content .data-not-found,\n.analytics .kpi .data-not-found {\n  text-align: center;\n  font-size: 13px;\n  color: #5B6667;\n}\n.analytics .widget-item .content .data-not-found .overlay,\n.analytics .kpi .data-not-found .overlay {\n  background-color: white;\n  position: absolute;\n  height: calc(100% - 4px);\n  width: calc(100% - 4px);\n  top: 2px;\n  left: 2px;\n  opacity: 0.6;\n  z-index: 3;\n}\n.analytics .widget-item .content .data-not-found .message,\n.analytics .kpi .data-not-found .message {\n  position: absolute;\n  top: 125px;\n  left: 50%;\n  padding-bottom: 10px;\n  transform: translate(-50%, -50%);\n  width: 85%;\n  background-color: #f4f8f9;\n  border-radius: 4px;\n  box-shadow: 0px 0px 25px 0px;\n  z-index: 4;\n}\n.analytics .widget-item .content .data-not-found .message .title,\n.analytics .kpi .data-not-found .message .title {\n  padding: 2px;\n  background-color: #192831;\n  color: white;\n  margin: -1px -1px 10px -1px;\n  text-transform: uppercase;\n}\n.analytics .widget-item .content .data-not-found .message p,\n.analytics .kpi .data-not-found .message p {\n  margin-left: 5px;\n  margin-right: 5px;\n}\n.analytics .widget-item .content .data-not-found .message .btn,\n.analytics .kpi .data-not-found .message .btn {\n  margin-top: 5px;\n}\n.analytics .widget-item .content .data-not-found .example,\n.analytics .kpi .data-not-found .example {\n  position: absolute;\n  bottom: 0px;\n  left: 0px;\n  width: 100%;\n  color: white;\n  background-color: #192831;\n  padding: 3px;\n  z-index: 6;\n}\n.analytics .widget-item .content .data-not-found .example a,\n.analytics .kpi .data-not-found .example a {\n  font-weight: normal;\n  color: #dae173;\n}\n.analytics .kpi .data-not-found .message {\n  width: 90%;\n  padding-bottom: 0px;\n  border: solid 1px silver;\n  box-shadow: none;\n}\n.analytics .kpi .data-not-found .message p {\n  margin: 5px;\n}\n.analytics .kpi .data-not-found .overlay,\n.analytics .kpi .data-not-found .title,\n.analytics .kpi .data-not-found .btn,\n.analytics .kpi .data-not-found .example {\n  display: none;\n}\n#duplicate-transactions-list .top {\n  height: 40px;\n}\n#duplicate-transactions-list .top a.back-link {\n  font-weight: normal;\n}\n#duplicate-transactions-list .top .pagination {\n  margin: 0px;\n}\n#duplicate-transactions-list .table-striped tr.origin:nth-of-type(odd) {\n  background-color: #f9f9f9;\n}\n#duplicate-transactions-list .table-container {\n  max-height: calc(565px - 60px);\n  overflow: auto;\n}\n#duplicate-transactions-list .table-container div[uib-datepicker-popup-wrap] {\n  display: inline-block;\n}\n#duplicate-transactions-list .table-container input.btn.btn-xs {\n  margin-top: -2px;\n}\n#duplicate-transactions-list .table-container button.btn.reset-date {\n  margin-top: -2px;\n}\n#duplicate-transactions-list .table-container .fa.fa-times {\n  color: #e01f74;\n  cursor: pointer;\n}\n#duplicate-transactions-list .table-container tr.total {\n  font-weight: bold;\n}\n#duplicate-transactions-list .table-container tr.total.invoices {\n  background-color: #00e600;\n}\n#duplicate-transactions-list .table-container tr.total.bills {\n  background-color: #f57cb1;\n}\n#transactions-add {\n  text-align: center;\n  font-size: 13px;\n  color: #5B6667;\n}\n#transactions-add .overlay {\n  background-color: white;\n  position: absolute;\n  height: calc(100% - 4px);\n  width: calc(100% - 4px);\n  top: 2px;\n  left: 2px;\n  opacity: 0.6;\n  z-index: 5;\n}\n#transactions-add .message {\n  z-index: 6;\n  position: absolute;\n  min-height: 160px;\n  padding-bottom: 10px;\n  top: 45px;\n  left: 7%;\n  width: 86%;\n  background-color: #f4f8f9;\n  border-radius: 4px;\n  box-shadow: 0px 0px 25px 0px;\n}\n#transactions-add .message .title {\n  padding: 2px;\n  background-color: #192831;\n  color: white;\n  margin: -1px -1px 10px -1px;\n  text-transform: uppercase;\n}\n#transactions-add .message {\n  top: 30px;\n  left: 35%;\n  width: 30%;\n}\n#transactions-add .message .form {\n  padding: 0px 10px;\n}\n#transactions-add .message .form > label,\n#transactions-add .message .form .schedulable-section > label {\n  padding-top: 10px;\n  font-weight: normal;\n  margin-bottom: 3px;\n}\n#transactions-add .message .form input.form-control,\n#transactions-add .message .form select.form-control {\n  width: 90%;\n  border-radius: 2px;\n  height: 28px;\n  font-size: 13px;\n}\n#transactions-add .message .form .btn-group {\n  display: block;\n  min-height: 22px;\n}\n#transactions-add .message .form .btn-group select {\n  border-radius: 2px;\n  height: 28px;\n  margin-top: 0px;\n}\n#transactions-add .message .form .disable {\n  color: #888888;\n  font-style: italic;\n}\n#transactions-add .message .form .never-disable {\n  color: black;\n  font-style: normal;\n}\n#transactions-add .message .form .repeat-btn {\n  margin-top: 30px;\n}\n#transactions-add .message .form .repeat-btn input[type=\"checkbox\"] {\n  vertical-align: text-bottom;\n  margin: 0px;\n}\n#transactions-add .message .form .repeat-btn select {\n  height: 22px;\n}\n#transactions-add .message .form .repeat-btn .btn {\n  float: none;\n  border-color: #888888;\n}\n#transactions-add .message .form .schedulable-section {\n  padding: 5px;\n  border: solid 1px silver;\n  margin-top: 0px;\n  background-color: white;\n}\n#transactions-add .message .form .schedulable-section .badge {\n  font-weight: normal;\n  background-color: #888888;\n}\n#transactions-add .message .form .schedulable-section .interval-field {\n  width: 40px;\n}\n#transactions-add .message .form .schedulable-section .btn-group {\n  margin-left: 10px;\n}\n#transactions-add .message .form .schedulable-section .btn-group select {\n  height: 22px;\n}\n#transactions-add .message .form .schedulable-section .btn-group .btn {\n  float: none;\n  border-color: #888888;\n}\n#transactions-add .message .bottom {\n  margin-top: 20px;\n}\n#transactions-list .top {\n  height: 40px;\n  position: relative;\n}\n#transactions-list .top .back {\n  position: absolute;\n}\n#transactions-list .top .resource-type {\n  position: absolute;\n  left: calc(50% - 98px);\n}\n@media (max-width: 767px) {\n  #transactions-list .top .resource-type {\n    left: unset;\n    right: 0;\n  }\n}\n#transactions-list .top .btn-group {\n  display: flex;\n}\n#transactions-list .bottom {\n  height: 40px;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n}\n#transactions-list .bottom .pagination {\n  margin: 0px;\n}\n#transactions-list .table-container {\n  max-height: calc(565px - 100px);\n  overflow: auto;\n  width: 100%;\n}\n#transactions-list .table-container div[uib-datepicker-popup-wrap] {\n  display: inline-block;\n}\n#transactions-list .table-container input.btn.btn-xs {\n  margin-top: -2px;\n}\n#transactions-list .table-container button.btn.reset-date {\n  margin-top: -2px;\n}\n#transactions-list .table-container .actions {\n  cursor: pointer;\n}\n#transactions-list .table-container .actions .fa.fa-times {\n  color: #e01f74;\n}\n#transactions-list .table-container tr.total {\n  font-weight: bold;\n}\n#transactions-list .table-container tr.total.invoices {\n  background-color: #c1d1b1;\n}\n#transactions-list .table-container tr.total.bills {\n  background-color: #e2aeb9;\n}\n#transactions-list .table-container td > .expected-payment-date {\n  display: flex;\n}\n#transactions-list .table-container td > .expected-payment-date .reset-date {\n  margin-left: 3px;\n}\n#trends-list .top {\n  height: 40px;\n}\n#trends-list .top a.back-link {\n  font-weight: normal;\n}\n#trends-list .top .pagination {\n  margin: 0px;\n}\n#trends-list .table-container {\n  max-height: calc(565px - 60px);\n  overflow: auto;\n}\n#trends-list .table-container div[uib-datepicker-popup-wrap] {\n  display: inline-block;\n}\n#trends-list .table-container input.btn.btn-xs {\n  margin-top: -2px;\n}\n#trends-list .table-container button.btn.reset-date {\n  margin-top: -2px;\n}\n#trends-add {\n  text-align: center;\n  font-size: 13px;\n  color: #5B6667;\n}\n#trends-add .overlay {\n  background-color: white;\n  position: absolute;\n  height: calc(100% - 4px);\n  width: calc(100% - 4px);\n  top: 2px;\n  left: 2px;\n  opacity: 0.6;\n  z-index: 5;\n}\n#trends-add .message {\n  z-index: 6;\n  position: absolute;\n  min-height: 160px;\n  padding-bottom: 10px;\n  top: 45px;\n  left: 7%;\n  width: 86%;\n  background-color: #f4f8f9;\n  border-radius: 4px;\n  box-shadow: 0px 0px 25px 0px;\n}\n#trends-add .message .title {\n  padding: 2px;\n  background-color: #192831;\n  color: white;\n  margin: -1px -1px 10px -1px;\n  text-transform: uppercase;\n}\n#trends-add .message {\n  top: 30px;\n  left: 35%;\n  width: 30%;\n}\n#trends-add .message .form {\n  padding: 0px 10px;\n}\n#trends-add .message .form > label {\n  padding-top: 10px;\n  font-weight: normal;\n  margin-bottom: 3px;\n}\n#trends-add .message .form input.form-control {\n  width: 90%;\n  border-radius: 2px;\n  height: 28px;\n  font-size: 13px;\n}\n#trends-add .message .form .btn-group {\n  display: block;\n  min-height: 22px;\n  margin-top: 10px;\n}\n#trends-add .message .form .btn-group > .btn {\n  float: none;\n}\n#trends-add .message .form .btn-group input[type=\"radio\"] {\n  margin: 4px 0 10px;\n}\n#trends-add .message .bottom {\n  margin-top: 20px;\n}\n.analytics .dashboard-settings.currency {\n  text-align: right;\n}\n.analytics .dashboard-settings.currency select {\n  margin-top: 4px;\n}\n.analytics .dashboard-settings.sync-apps .show-status {\n  margin-right: 5px;\n  color: #9ba6a7;\n}\n.analytics .dashboard-settings.sync-apps .show-status:hover {\n  cursor: pointer;\n  text-decoration: underline;\n}\n.analytics .dashboard-settings.sync-apps .show-status .fa.fa-info {\n  margin-right: 2px;\n}\n.analytics .dashboard-settings.sync-apps .status-btn {\n  display: inline-block;\n  cursor: pointer;\n  padding: 5px 7px 5px 0px;\n}\n.analytics .dashboard-settings.sync-apps .status-btn i {\n  font-size: 16px;\n}\n.analytics .dashboard-settings.sync-apps .status-btn i.fa-exclamation-triangle {\n  color: #ff7300;\n}\n.analytics .dashboard-settings.sync-apps .status-btn i.fa-check {\n  color: #d1e55c;\n}\n.analytics .dashboard-settings.sync-apps .popover {\n  max-width: 550px;\n}\n.analytics .dashboard-settings.sync-apps .popover .connector {\n  padding: 4px 13px;\n}\n.analytics .dashboard-settings.sync-apps .popover .connector.add-seperator {\n  border-bottom: 1px solid #ccc;\n}\n.analytics .dashboard-settings.sync-apps .popover .popover-content {\n  padding: 0;\n}\n.analytics .dashboard-settings.sync-apps .popover .popover-footer {\n  border-top: 1px solid #ccc;\n  padding: 4px 13px;\n}\n.analytics .dashboard-settings.sync-apps .popover .popover-footer p {\n  font-weight: bold;\n  margin: 0;\n}\n.analytics .dashboard-settings.sync-apps .popover .popover-footer.remove-seperator {\n  border: 0;\n}\n.analytics .dashboard-settings.sync-apps .badge {\n  float: right;\n  margin-left: 8px;\n}\n.analytics .dashboard-settings.sync-apps .success .badge {\n  background-color: #d1e55c;\n}\n.analytics .dashboard-settings.sync-apps .pending .badge {\n  background-color: #ff7300;\n}\n.analytics .dashboard-settings.sync-apps .running .badge {\n  background-color: #ff7300;\n}\n.analytics .dashboard-settings.sync-apps .error .badge {\n  background-color: #ed1e79;\n}\n.analytics .dashboard-settings.sync-apps .failed .badge {\n  background-color: #ed1e79;\n}\n.analytics .dashboard-settings.sync-apps .unknown .badge {\n  background-color: #ed1e79;\n}\n.analytics .dashboard-settings.sync-apps .disconnected .badge {\n  background-color: #ed1e79;\n}\n#sync-apps-modal .modal-header {\n  text-align: center;\n  border: 0;\n  box-shadow: 0px 2px 3px 0px #ccc;\n}\n#sync-apps-modal .modal-list {\n  max-height: 280px;\n  overflow-y: auto;\n}\n#sync-apps-modal .modal-list-item {\n  border-bottom: 1px solid #ccc;\n  padding: 10px;\n}\n#sync-apps-modal .modal-list-item .badge {\n  float: right;\n}\n#sync-apps-modal .modal-list-item.success .badge {\n  background-color: #d1e55c;\n}\n#sync-apps-modal .modal-list-item.pending .badge {\n  background-color: #ff7300;\n}\n#sync-apps-modal .modal-list-item.running .badge {\n  background-color: #ff7300;\n}\n#sync-apps-modal .modal-list-item.error .badge {\n  background-color: #ed1e79;\n}\n#sync-apps-modal .modal-list-item.failed .badge {\n  background-color: #ed1e79;\n}\n#sync-apps-modal .modal-list-item.unknown .badge {\n  background-color: #ed1e79;\n}\n#sync-apps-modal .modal-list-item.disconnected .badge {\n  background-color: #ed1e79;\n}\n#sync-apps-modal .modal-list-item .message {\n  padding: 3px;\n  border-radius: 2px;\n  margin-left: 31px;\n  margin-top: 9px;\n}\n#sync-apps-modal .modal-list-item .message p {\n  margin: 0;\n}\n#sync-apps-modal .modal-list-item.success .message {\n  background-color: rgba(0, 255, 55, 0.08);\n}\n#sync-apps-modal .modal-list-item.pending .message {\n  background-color: rgba(255, 118, 0, 0.08);\n}\n#sync-apps-modal .modal-list-item.running .message {\n  background-color: rgba(255, 118, 0, 0.08);\n}\n#sync-apps-modal .modal-list-item.error .message {\n  background-color: rgba(255, 0, 0, 0.08);\n}\n#sync-apps-modal .modal-list-item.failed .message {\n  background-color: rgba(255, 0, 0, 0.08);\n}\n#sync-apps-modal .modal-list-item.unknown .message {\n  background-color: rgba(255, 0, 0, 0.08);\n}\n#sync-apps-modal .modal-list-item.disconnected .message {\n  background-color: rgba(255, 0, 0, 0.08);\n}\n#sync-apps-modal .modal-list-item.with-message {\n  cursor: pointer;\n}\n#sync-apps-modal .modal-list-item.with-message:hover {\n  background-color: #ccc;\n}\n#sync-apps-modal .modal-footer {\n  border: 0;\n}\n#sync-apps-modal .fa {\n  padding: 0px 10px;\n}\n#sync-apps-modal .fa.error {\n  color: #FF0000;\n}\n#sync-apps-modal .fa.warn {\n  color: #ff7300;\n}\n#sync-apps-modal .fa.success {\n  color: #47ff00;\n}\nchart-threshold .attach-panel {\n  padding: 5px 0;\n  display: flex;\n  justify-content: center;\n  align-items: baseline;\n  background-color: rgba(20, 132, 228, 0.16);\n}\nchart-threshold .attach-panel > div {\n  padding-right: 5px;\n}\nchart-threshold .attach-panel > div.target {\n  text-align: center;\n}\n@media (max-width: 1199px) {\n  chart-threshold .attach-panel {\n    flex-direction: column;\n    align-items: center;\n  }\n  chart-threshold .attach-panel > div {\n    padding: 5px;\n  }\n}\nchart-threshold .attach-panel .text {\n  text-transform: uppercase;\n  font-weight: bold;\n  color: #5B6667;\n  font-size: 13px;\n}\nchart-threshold .attach-panel input {\n  border-radius: 3px;\n  border: 1px white;\n  padding: 3px;\n}\nchart-threshold .attach-panel input[name=amount] {\n  max-width: 70px;\n}\nchart-threshold .attach-panel .currency {\n  font-weight: bold;\n  color: #000;\n}\nchart-threshold .attach-panel .actions {\n  display: inline-block;\n  padding: 0 2px;\n}\nchart-threshold .attach-panel .actions button {\n  padding: 3px 6px;\n  display: inline-block;\n}\nchart-threshold .attach-panel .actions button.loading {\n  padding: 3px 20px;\n}\n.analytics widgets-common-confirm-modal {\n  text-align: center;\n  font-size: 13px;\n  color: #5B6667;\n}\n.analytics widgets-common-confirm-modal .overlay {\n  background-color: white;\n  position: absolute;\n  height: calc(100% - 4px);\n  width: calc(100% - 4px);\n  top: 2px;\n  left: 2px;\n  opacity: 0.6;\n  z-index: 5;\n}\n.analytics widgets-common-confirm-modal .message {\n  z-index: 6;\n  position: absolute;\n  min-height: 160px;\n  padding-bottom: 10px;\n  top: 45px;\n  left: 7%;\n  width: 86%;\n  background-color: #f4f8f9;\n  border-radius: 4px;\n  box-shadow: 0px 0px 25px 0px;\n}\n.analytics widgets-common-confirm-modal .message .title {\n  padding: 2px;\n  background-color: #192831;\n  color: white;\n  margin: -1px -1px 10px -1px;\n  text-transform: uppercase;\n}\n.analytics widgets-common-confirm-modal .message {\n  display: flex;\n  flex-direction: column;\n  justify-content: space-between;\n}\n.analytics widgets-common-confirm-modal .message p {\n  padding: 0px 10px;\n}\n.analytics widgets-common-confirm-modal .message button.btn {\n  margin-top: 20px;\n}\n.analytics widgets-common-confirm-modal .message .loader i.fa.fa-spinner {\n  font-size: 26px;\n}\n.currency-conversions img {\n  width: 15px;\n  cursor: pointer;\n}\n.currency-conversions.popover .popover-title {\n  background-color: black;\n  color: white;\n}\n.analytics .widget-item .editable-title {\n  width: 100%;\n  flex: 1;\n  overflow: hidden;\n  height: 22px;\n}\n.analytics .widget-item .editable-title .title {\n  text-transform: uppercase;\n  font-weight: 600;\n  font-size: 12px;\n  color: #4f5959;\n  cursor: text;\n  overflow: hidden;\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  line-height: 1.9;\n}\n.analytics .widget-item .editable-title .editable-wrap {\n  position: relative;\n  height: 20px;\n  min-width: 100%;\n  white-space: nowrap;\n}\n.analytics .widget-item .editable-title .editable-wrap .editable-controls {\n  min-width: 100%;\n}\n.analytics .widget-item .editable-title .editable-wrap .editable-controls .editable-input {\n  height: 20px;\n  font-size: 12px;\n  text-transform: uppercase;\n  width: calc(100% - 65px);\n  padding: 0px 3px;\n}\n.analytics .widget-item .editable-title .editable-wrap .editable-controls .editable-buttons {\n  background-color: white;\n}\n.analytics .widget-item .editable-title .editable-wrap .editable-controls .editable-buttons button {\n  margin: 0px 0px 0px 5px;\n  height: 20px;\n  padding: 0px 5px;\n}\n.analytics .widget-item .info-panel {\n  position: absolute;\n  top: 15px;\n  left: 15px;\n  width: calc(100% - 30px);\n  max-height: calc(100% - 30px);\n  height: 100%;\n  z-index: 100;\n  background-color: white;\n  border: dotted 1px #B7CDCE;\n  display: flex;\n  flex-direction: column;\n  font-family: \"Lato Semibold\", \"Lato\";\n  z-index: 4;\n}\n.analytics .widget-item .info-panel:hover {\n  opacity: 1;\n}\n.analytics .widget-item .info-panel .i-header {\n  background-color: #FFC928;\n  color: #1E303B;\n  padding: 8px;\n  text-transform: uppercase;\n  font-family: \"Lato Medium\", \"Lato\";\n  font-size: 12px;\n}\n.analytics .widget-item .info-panel .i-header .fa {\n  font-size: 18px;\n}\n.analytics .widget-item .info-panel .i-header .fa-info-circle {\n  float: left;\n}\n.analytics .widget-item .info-panel .i-header .fa-times-circle {\n  cursor: pointer;\n  float: right;\n}\n.analytics .widget-item .info-panel .i-content {\n  overflow-y: auto;\n  overflow-x: hidden;\n  padding: 5px;\n  text-align: justify;\n  flex: 1;\n}\n.analytics .widget-item .info-panel .i-content .row {\n  margin-bottom: 6px;\n  padding-bottom: 6px;\n  border-bottom: solid 1px #abc4c6;\n}\n.analytics .widget-item .info-panel .i-content .row:last-child {\n  margin-bottom: 0;\n  padding-bottom: 0;\n  border-bottom: none;\n}\n.analytics .widget-item .info-panel .i-content .row .key {\n  text-align: right;\n  font-variant: small-caps;\n}\n@media (max-width: 991px) {\n  .analytics .widget-item .info-panel .i-content .row .key {\n    text-align: center;\n  }\n}\n.analytics .widget-item .info-panel .i-content .row .value {\n  text-align: justify;\n}\n.analytics .time-period-info {\n  font-size: 11px;\n  color: #ABC4C6;\n  text-transform: uppercase;\n}\n.analytics .widget-item .top-line .top-buttons {\n  text-align: right;\n  margin-top: -1px;\n  white-space: nowrap;\n  padding-left: 10px;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button {\n  background: transparent;\n  border: none;\n  color: #c4caca;\n  padding: 0;\n  outline: none;\n  width: 17px;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button:active,\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button:focus {\n  box-shadow: none;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-info {\n  font-size: 17px;\n  margin-top: 1px;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-info:hover {\n  color: #FFC928;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-export {\n  font-size: 17px;\n  margin-top: 1px;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-export:hover {\n  color: #358fdc;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-refresh {\n  font-size: 17px;\n  margin-top: 1px;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-refresh:hover {\n  color: #358fdc;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-edit {\n  font-size: 13px;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-edit:hover,\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-edit.edit-mode {\n  color: #cfd849;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-close {\n  font-size: 13px;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-close:hover {\n  color: #ed1e79;\n}\n.analytics .widget-item .content .settings.select-account {\n  padding: 0px 5px;\n}\n.analytics .settings.accounting-behaviour .btn.btn-primary {\n  background-color: #bba9f5;\n  border: solid 1px #977bf0;\n}\n.analytics .settings.accounting-behaviour .btn.btn-primary.focus,\n.analytics .settings.accounting-behaviour .btn.btn-primary.active {\n  background-color: #977bf0;\n}\n.analytics .settings.attach-kpis .attach-kpi {\n  padding: 8px 5px;\n}\n.analytics .settings.attach-kpis .attach-kpi form .row {\n  padding-bottom: 5px;\n}\n.analytics .settings.attach-kpis .attach-kpi .attach-kpi-form {\n  background-color: white;\n  border: 1px solid #ddd;\n  padding: 5px;\n}\n.analytics .settings.attach-kpis .attach-kpi form .row.kpi-description {\n  padding: 10px 2px;\n}\n.analytics .settings.attach-kpis .attach-kpi form .row.kpi-description span {\n  display: block;\n  font-weight: bold;\n  font-size: 13px;\n}\n.analytics .settings.attach-kpis .attach-kpi form.attach-kpi-form input.attach-target {\n  background-color: white;\n  height: inherit;\n}\n.analytics .settings.attach-kpis .attach-kpi .error-messages {\n  color: #e01f74;\n  width: 120px;\n}\n.analytics .settings.attach-kpis .attached-kpis {\n  padding: 5px;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi {\n  padding: 5px 10px;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi .attached-kpi-name {\n  overflow: hidden;\n  width: 75%;\n  display: inline-block;\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  margin-top: 3px;\n  font-size: 13px;\n  font-weight: bold;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions {\n  padding-top: 2px;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .alerts-config {\n  display: inline-block;\n  text-align: left;\n  padding-left: 4px;\n  height: 20px;\n  border-radius: 40px;\n  width: 21px;\n  color: #358fdc;\n  background-color: white;\n  border: solid 1px #358fdc;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .alerts-config:hover {\n  cursor: pointer;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .edit-attached-kpi {\n  display: inline-block;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .edit-attached-kpi i {\n  border-radius: 10px;\n  width: 21px;\n  color: #358fdc;\n  background-color: white;\n  height: 20px;\n  padding: 3px 5px 5px 5px;\n  border: solid 1px #358fdc;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .edit-attached-kpi i:hover {\n  cursor: pointer;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .remove-attached-kpi {\n  display: inline-block;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .remove-attached-kpi i {\n  border-radius: 10px;\n  width: 21px;\n  color: #e01f74;\n  background-color: white;\n  height: 20px;\n  padding: 3px 5px 5px 5px;\n  border: solid 1px #e01f74;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .remove-attached-kpi i:hover {\n  cursor: pointer;\n}\n.analytics .widget-item .content .settings.select-account {\n  padding: 0px 5px;\n}\n.analytics .widget-item .content .settings.chart-filters .row {\n  margin: 0px;\n}\n.analytics .widget-item .content .settings.chart-filters input[type=\"radio\"] {\n  margin: 0;\n  margin-right: 3px;\n  padding: 0;\n  width: 13px;\n  height: 13px;\n  vertical-align: middle;\n  position: relative;\n  top: -1px;\n  outline: none;\n}\n.analytics .widget-item .content .settings.chart-filters input[type=\"range\"] {\n  height: auto;\n  width: 100%;\n}\n.analytics .settings.dates-picker h5 {\n  display: none;\n}\n.analytics .settings.dates-picker button.btn.btn-sm {\n  line-height: 1;\n}\n.analytics .settings.dates-picker button.btn.btn-sm.date-button {\n  margin: 0px 5px;\n}\n.analytics .settings.dates-picker button.btn.btn-sm.btn-danger {\n  display: none;\n}\n.analytics .settings.dates-picker button.btn.btn-sm.btn-info {\n  border-radius: 3px;\n}\n.analytics .settings.dates-picker .tooltip-inner {\n  text-transform: none;\n}\n.analytics .settings.dates-picker .dropdown-menu > li > div > table {\n  outline: none;\n}\n.analytics .settings.forecast-payroll .widget-lines-container .widget-line {\n  padding: 5px 10px 5px 18px;\n}\n.analytics .settings.forecast-payroll .widget-lines-container .widget-line:nth-child(even) {\n  background-color: #f3f4f4;\n}\n.analytics .settings.forecast-payroll .widget-lines-container .widget-line:nth-child(odd) {\n  background-color: white;\n}\n.analytics .settings.forecast-payroll .widget-lines-container .widget-line .fa {\n  float: right;\n  font-size: 20px;\n  cursor: pointer;\n}\n.analytics .settings.forecast-payroll .widget-lines-container .widget-line .fa.fa-toggle-on {\n  color: #977bf0;\n}\n.analytics .settings.forecast-payroll .widget-lines-container .widget-line .fa.fa-toggle-off {\n  color: #9ba6a7;\n}\n.analytics .widget-item .content .settings.hist-mode-choser {\n  max-height: 70px;\n}\n.analytics .widget-item .content .settings.hist-mode-choser [common-time-period-info] {\n  padding-bottom: 8px;\n}\n.analytics .widget-item .content .settings.hist-mode-choser .options {\n  width: 150px;\n  margin: auto;\n  padding-bottom: 8px;\n  border-bottom: solid 1px #e6e6e6;\n  font-weight: 500;\n  font-size: 12px;\n  color: #c4caca;\n}\n.analytics .widget-item .content .settings.hist-mode-choser .options a {\n  font-weight: 500;\n  font-size: 12px;\n  color: #c4caca;\n  text-transform: uppercase;\n}\n.analytics .widget-item .content .settings.hist-mode-choser .options a.active {\n  color: #977bf0;\n}\n.analytics .widget-item .content .settings.hist-mode-choser .arrow-container {\n  width: 28px;\n  height: 28px;\n  position: relative;\n  top: -14px;\n  margin: auto;\n}\n.analytics .widget-item .content .settings.hist-mode-choser .arrow-container.right {\n  left: 46px;\n}\n.analytics .widget-item .content .settings.hist-mode-choser .arrow-container.left {\n  left: -30px;\n}\n.analytics .widget-item .content .settings.hist-mode-choser .arrow-container .arrow-border {\n  border-top: 14px solid #e6e6e6;\n  border-left: 14px solid transparent;\n  border-right: 14px solid transparent;\n  width: 0px;\n  height: 0px;\n}\n.analytics .widget-item .content .settings.hist-mode-choser .arrow-container .arrow {\n  border-top: 14px solid white;\n  border-left: 14px solid transparent;\n  border-right: 14px solid transparent;\n  position: relative;\n  top: 12px;\n  width: 0px;\n  height: 0px;\n}\n.analytics .settings.limit-entries {\n  color: #1E303B;\n  text-transform: uppercase;\n  text-align: center;\n  border-bottom: dashed 1px #E6E6E6;\n  padding-bottom: 8px;\n}\n.analytics .settings.limit-entries a.option.badge {\n  color: white;\n  background-color: #1E303B;\n}\n.analytics .settings.offsets .offset-value {\n  font-style: italic;\n  font-size: 13px;\n}\n.analytics .settings.offsets .offset-value .fa-trash-o {\n  margin-left: 10px;\n}\n.analytics .settings.offsets .offset-value .fa-trash-o:hover {\n  color: #e01f74;\n  cursor: pointer;\n}\n.analytics .settings.offsets input {\n  width: 75%;\n}\n.analytics .settings.offsets button {\n  width: 30px;\n}\n.analytics .settings.organizations .widget-lines-container .widget-line {\n  padding: 5px 10px 5px 18px;\n}\n.analytics .settings.organizations .widget-lines-container .widget-line:nth-child(even) {\n  background-color: #f3f4f4;\n}\n.analytics .settings.organizations .widget-lines-container .widget-line:nth-child(odd) {\n  background-color: white;\n}\n.analytics .settings.organizations .widget-lines-container .widget-line .fa {\n  float: right;\n  font-size: 20px;\n  cursor: pointer;\n}\n.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-toggle-on,\n.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-check-circle {\n  color: #977bf0;\n}\n.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-toggle-off,\n.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-circle-thin {\n  color: #9ba6a7;\n}\n.analytics .widget-item .content .settings.param-selector {\n  display: inline-block;\n}\n.analytics .widget-item .content .settings.param-selector.classic {\n  width: 100%;\n}\n.analytics .widget-item .content .settings.param-selector.classic select {\n  width: 100%;\n  height: 25px;\n  border: 1px solid #ccc;\n  text-transform: uppercase;\n  margin: 0px 0px 5px 0px;\n}\n.analytics .widget-item .content .settings.param-selector a {\n  font-weight: normal;\n  color: #977bf0;\n  white-space: nowrap;\n}\n.analytics .widget-item .content .settings.param-selector .options-container {\n  position: absolute;\n  background-color: white;\n  text-align: left;\n  min-width: 150px;\n  max-height: 200px;\n  z-index: 999;\n  overflow-y: auto;\n  overflow-x: hidden;\n  -webkit-box-shadow: #000000 0px 3px 15px -3px;\n  box-shadow: #000000 0px 3px 15px -3px;\n}\n.analytics .widget-item .content .settings.param-selector .options-container .param-selector-label {\n  padding: 3px 5px;\n  font-weight: 500;\n  font-size: inherit;\n  color: black;\n  cursor: text;\n  overflow: hidden;\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  line-height: 1.9;\n}\n.analytics .widget-item .content .settings.param-selector .options-container .param-selector-label:hover {\n  cursor: pointer;\n  background-color: #977bf0;\n  color: white;\n}\n.analytics .widget-item .content .settings.param-selector .options-container::-webkit-scrollbar {\n  width: 8px;\n  background-color: #d7e2e4;\n}\n.analytics .widget-item .content .settings.param-selector .options-container::-webkit-scrollbar-thumb {\n  background-color: #977bf0;\n}\n.analytics .widget-item .content .settings.param-selector .options-container::-webkit-scrollbar-thumb:hover {\n  background-color: #a992f3;\n}\n.analytics .settings.params-checkboxes {\n  padding: 2px 0px;\n}\n.analytics .settings.params-checkboxes input {\n  margin: 0;\n  height: inherit;\n}\n.analytics .settings.params-checkboxes span {\n  margin-left: 5px;\n}\n.analytics .settings.params-checkboxes label {\n  display: flex;\n  justify-content: center;\n  line-height: 14px;\n}\n.analytics .widget-item .content .settings.params-picker {\n  padding: 0px 10px;\n}\n.analytics .widget-item .content .settings.params-picker .parameter {\n  margin: 0px 3px 3px 0px;\n  padding: 3px 5px;\n  background-color: #1E303B;\n  color: white;\n  border: solid 1px #1E303B;\n  border-radius: 4px;\n  cursor: move;\n  font-weight: bold;\n  white-space: nowrap;\n  float: left;\n}\n.analytics .widget-item .content .settings.params-picker .parameter input[type=\"checkbox\"] {\n  margin: 0px -3px 0px 3px;\n  vertical-align: middle;\n  height: inherit;\n  outline: none;\n  cursor: pointer;\n}\n.analytics .widget-item .content .settings.params-picker .parameter .badge {\n  margin-right: 3px;\n  font-size: 10px;\n  background-color: #f2f2f2;\n  color: #1E303B;\n  padding: 2px 6px;\n}\n.analytics .widget-item .content .settings.params-picker .parameter.unchecked {\n  background-color: inherit;\n  font-weight: normal;\n  color: inherit;\n  border-color: #c2c4c4;\n}\n.analytics .widget-item .content .settings.params-picker .parameter.unchecked .badge {\n  background-color: #c2c4c4;\n  color: white;\n}\n.analytics .settings.tag-filter {\n  padding: 0px 5px;\n}\n.analytics .settings.tag-filter .btn.btn-default {\n  height: 32px;\n  width: 30px;\n}\n.analytics .settings.tag-filter .tag-lines-container {\n  padding: 0px 10px;\n}\n.analytics .settings.tag-filter .tag-lines-container .tag-line {\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n}\n.analytics .settings.tag-filter .tag-lines-container .tag-line .tags-col {\n  position: static;\n}\n.analytics .settings.tag-filter .tag-lines-container .tag-line tags-input .tags {\n  display: flex;\n  border-radius: 4px;\n  border: solid 1px #ccc;\n}\n.analytics .settings.tag-filter .tag-lines-container .tag-line tags-input .tags .tag-item {\n  background: #79a2bb;\n  border-radius: 4px;\n  color: white;\n}\n.analytics .settings.tag-filter .tag-lines-container .tag-line .host {\n  position: static;\n}\n.analytics .settings.time-period {\n  padding: 0px 5px;\n}\n.analytics .settings.time-period select {\n  height: 22px;\n  width: 100%;\n}\n.analytics .settings.time-period > .row {\n  margin: 0px -5px 7px -5px;\n}\n.analytics .settings.time-period > .row > div {\n  padding: 0px 5px;\n  position: static;\n}\n.analytics .settings.time-period > .row .sub-setting {\n  padding: 5px;\n}\n.analytics .widget-item .content .settings.width {\n  float: right;\n  font-size: 14px;\n}\n.analytics .widget-item .content .settings.width i {\n  color: silver;\n  cursor: pointer;\n}\n.analytics .widget-item .content .settings.width i.reduce {\n  margin-right: -10px;\n}\n.analytics .widget-item .content .settings.width i.expand {\n  margin-right: -3px;\n}\n.analytics .widget-item .content.accounts-assets-liability-summary .param-selector {\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-assets-liability-summary .legend {\n  text-align: left;\n  max-height: 90px;\n}\n.analytics .widget-item .content.accounts-assets-liability-summary .legend .title {\n  text-align: center;\n  border-bottom: dashed 1px #dfe2e2;\n}\n.analytics .widget-item .content.accounts-assets-summary .legend {\n  text-align: left;\n  max-height: 115px;\n}\n.analytics .widget-item .content.accounts-assets-summary .legend .title {\n  text-align: center;\n  border-bottom: dashed 1px #dfe2e2;\n}\n.analytics .widget-item .content.accounts-assets-vs-liabilities .legend > .title span {\n  margin-left: 3px;\n}\n.analytics .widget-item .content.accounts-balance h3 {\n  font-weight: 300;\n  font-size: 14px;\n  color: #5B6667;\n  text-align: left;\n  margin-top: 30px;\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-balance .price {\n  font-weight: 900;\n  font-size: 22px;\n  color: #5B6667;\n  text-align: center;\n  margin-top: 0px;\n}\n.analytics .widget-item .content.accounts-balance-sheet {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.accounts-balance-sheet {\n    height: 565px;\n  }\n  .analytics .widget-item .content.accounts-balance-sheet .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.accounts-balance-sheet .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.accounts-balance-sheet .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.accounts-balance-sheet .widget-lines-container {\n  overflow-y: scroll;\n  overflow-x: hidden;\n  max-height: 490px;\n}\n@media (max-width: 767px) {\n  .analytics .widget-item .content.accounts-balance-sheet .widget-lines-container .row.widget-line:not(:last-child) {\n    border-bottom: dashed 1px #dfe2e2;\n  }\n}\n.analytics .widget-item .content.accounts-balance-sheet .widget-lines-container .row.widget-line.header > [class*='col-'] {\n  position: static;\n}\n.analytics .widget-item .content.accounts-balance-sheet .widget-lines-container.no-scroll {\n  overflow: visible;\n}\n.analytics .widget-item .content.accounts-balance-sheet .no-data-block {\n  font-weight: 300;\n  font-size: 16px;\n  color: #5B6667;\n  text-align: center;\n  margin: 15px 0px;\n}\n.analytics .widget-item .content.accounts-cash-balance {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.accounts-cash-balance {\n    height: 565px;\n  }\n  .analytics .widget-item .content.accounts-cash-balance .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.accounts-cash-balance .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.accounts-cash-balance .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.accounts-cash-balance .data-container {\n  height: calc(565px - 50px);\n  width: 100%;\n}\n.analytics .widget-item .content.accounts-cash-balance .left-panel {\n  width: 180px;\n  display: inline-block;\n  overflow: auto;\n  max-height: 100%;\n}\n.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item {\n  display: flex;\n  align-items: center;\n  min-height: 45px;\n  margin: 3px;\n  font-size: 13px;\n  padding: 3px;\n  cursor: pointer;\n  user-select: none;\n}\n.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item:hover {\n  background-color: #ececec;\n}\n.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item i {\n  font-size: 19px;\n  padding: 4px;\n  margin-top: 1px;\n}\n.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item span {\n  color: #5B6667;\n}\n.analytics .widget-item .content.accounts-cash-balance .legend-item-icon {\n  width: 16px;\n  height: 16px;\n}\n.analytics .widget-item .content.accounts-cash-balance .right-panel {\n  width: calc(100% - 180px);\n  float: right;\n}\n.analytics .widget-item .content.accounts-cash-balance .right-panel .cash-balance-chart {\n  height: calc(565px - 50px);\n}\n.analytics .widget-item .content.accounts-cash-balance .dates-picker {\n  display: inline-block;\n  float: right;\n  font-size: 12px;\n}\n.analytics .widget-item .content.accounts-cash-projection {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.accounts-cash-projection {\n    height: 565px;\n  }\n  .analytics .widget-item .content.accounts-cash-projection .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.accounts-cash-projection .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.accounts-cash-projection .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.accounts-cash-projection .cash-projection-chart {\n  height: calc(565px - 50px);\n}\n.analytics .widget-item .content.accounts-cash-projection .highcharts-legend-item rect.highcharts-point {\n  display: none;\n}\n.analytics .widget-item .content.accounts-cash-projection .highcharts-legend-item span {\n  width: 110px;\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-cash-projection .highcharts-legend-item span img {\n  text-align: center;\n  width: 55px;\n  height: 25px;\n}\n.analytics .widget-item .content.accounts-cash-projection .dates-picker {\n  display: inline-block;\n  float: right;\n  font-size: 12px;\n}\n.analytics .widget-item .content.accounts-cash-projection transactions-list {\n  font-size: 12px;\n}\n.analytics .widget-item .content.accounts-cash-summary {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.accounts-cash-summary {\n    height: 565px;\n  }\n  .analytics .widget-item .content.accounts-cash-summary .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.accounts-cash-summary .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.accounts-cash-summary .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.accounts-cash-summary .widget-lines-container {\n  max-height: 540px;\n}\n.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line {\n  cursor: pointer;\n  border: solid 1px white;\n}\n.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line .selection-tag {\n  display: block;\n  right: 0px;\n  margin-top: -6px;\n  width: 10px;\n  height: 29px;\n  position: absolute;\n}\n.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line:hover {\n  background-color: #e6e0fb;\n}\n.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line.no-select {\n  cursor: auto;\n}\n.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line.no-select:hover {\n  color: #626d6d;\n}\n.analytics .widget-item .content.accounts-cash-summary .right-panel .widget-lines-container {\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: 235px;\n}\n.analytics .widget-item .content.accounts-cash-summary .no-element {\n  font-weight: 300;\n  font-size: 16px;\n  color: #5B6667;\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-cash-summary .right-panel .widget-lines-container {\n  max-height: 215px;\n}\n.analytics .widget-item .content.accounts-cash-summary .row.lines-group.cash {\n  border-top: solid 1px;\n  border-bottom: double;\n}\n.analytics .widget-item .content.accounts-class-comparison .param-selector {\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-class-comparison .widget-lines-container {\n  max-height: 94px;\n  color: #626d6d;\n}\n.analytics .widget-item .content.accounts-comparison {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.accounts-comparison {\n    height: 565px;\n  }\n  .analytics .widget-item .content.accounts-comparison .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.accounts-comparison .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.accounts-comparison .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n@media print {\n  .analytics .widget-item .content.accounts-comparison .chart-container {\n    max-width: 80% !important;\n  }\n}\n.analytics .widget-item .content.accounts-comparison .add-account {\n  position: absolute;\n  right: 40px;\n  bottom: 30px;\n  width: 160px;\n}\n.analytics .widget-item .content.accounts-comparison .add-account select {\n  font-size: 13px;\n  background-color: #977bf0;\n  color: white;\n  outline: none;\n  border: none;\n  cursor: pointer;\n}\n.analytics .widget-item .content.accounts-comparison .add-account select[disabled] {\n  cursor: not-allowed;\n  background-color: #bba9f5;\n}\n.analytics .widget-item .content.accounts-comparison .add-account select[disabled]:hover {\n  background-color: #bba9f5;\n}\n.analytics .widget-item .content.accounts-comparison .add-account select:hover {\n  background-color: #734deb;\n}\n.analytics .widget-item .content.accounts-comparison .add-account select option {\n  background-color: white;\n  color: #c4caca;\n}\n.analytics .widget-item .content.accounts-comparison .add-account select option[disabled] {\n  color: white;\n}\n.analytics .widget-item .content.accounts-comparison button.close {\n  font-size: 15px;\n}\n.analytics .widget-item .content.accounts-comparison .legend {\n  text-align: left;\n  max-height: 103px;\n}\n.analytics .widget-item .content.accounts-comparison .row {\n  margin: 0;\n}\n.analytics .widget-item .content.accounts-comparison .widget-lines-container {\n  font-size: 11px;\n  max-height: 220px;\n  margin-bottom: 65px;\n  overflow: auto;\n}\n.analytics .widget-item .content.accounts-comparison .settings.params-checkboxes {\n  margin-left: 13px;\n}\n.analytics .widget-item .content.accounts-comparison .comparable-error h5 {\n  margin-left: 13px;\n  color: #ed1e79;\n}\n.analytics .widget-item .content.accounts-custom-calculation h3 {\n  margin-top: 85px;\n  text-align: center;\n  font-weight: bold;\n}\n.analytics .widget-item .content.accounts-custom-calculation .legend {\n  max-height: 125px;\n}\n.analytics.modal-custom-calculation {\n  margin: 0px;\n  padding: 0px;\n}\n.analytics.modal-custom-calculation .modal-body .edit {\n  overflow-y: auto;\n  overflow-x: hidden;\n  color: #5B6667;\n  padding: 2px;\n  font-size: 12px;\n  padding: 5px;\n  overflow: visible;\n}\n.analytics.modal-custom-calculation .modal-body .edit .bottom-buttons .btn {\n  border-radius: 2px;\n  margin-right: 5px;\n  padding: 3px 13px;\n  text-transform: uppercase;\n  font-size: 12px;\n}\n.analytics.modal-custom-calculation .modal-body .edit .bottom-buttons .btn.btn-default {\n  background-color: #c2c4c4;\n  border: solid 1px #a8abab;\n  color: white;\n}\n.analytics.modal-custom-calculation .modal-body .edit .bottom-buttons .btn.btn-default:hover {\n  border: solid 1px #8e9292;\n  background-color: #a8abab;\n}\n.analytics.modal-custom-calculation .modal-body .edit h4 {\n  margin: 0;\n  margin-bottom: 8px;\n  text-align: left;\n  font-weight: normal;\n  font-size: 12px;\n  color: #c4caca;\n}\n.analytics.modal-custom-calculation .modal-body .edit .part {\n  margin-bottom: 8px;\n  padding: 10px 0px;\n  background-color: #fcfcfc;\n  border: solid 1px #dfe2e2;\n}\n.analytics.modal-custom-calculation .modal-body .edit .part h5 {\n  display: block;\n  margin: 0;\n  margin-bottom: 10px;\n  padding: 0px 15px;\n  text-transform: uppercase;\n  font-weight: normal;\n  font-size: 12px;\n  color: #c4caca;\n}\n.analytics.modal-custom-calculation .modal-body .edit .part label {\n  font-weight: normal;\n}\n.analytics.modal-custom-calculation .modal-body .edit .part select.form-control {\n  margin: 0px;\n  border: solid 1px #acb0b1;\n  outline: none;\n  -webkit-box-shadow: none;\n  font-size: 13px;\n  color: #72728b;\n}\n.analytics .widget-item .content.accounts-detailed-classifications {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.accounts-detailed-classifications {\n    height: 565px;\n  }\n  .analytics .widget-item .content.accounts-detailed-classifications .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.accounts-detailed-classifications .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.accounts-detailed-classifications .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.accounts-detailed-classifications .widget-lines-container {\n  overflow-y: scroll;\n  overflow-x: hidden;\n  max-height: 540px;\n}\n.analytics .widget-item .content.accounts-detailed-classifications .account-class-title {\n  margin-bottom: 8px;\n  margin-left: 11px;\n}\n.analytics .widget-item .content.accounts-detailed-classifications .time-period-info {\n  text-align: right;\n}\n.analytics .widget-item .content.accounts-detailed-classifications .widget-line.header.sorting {\n  border-bottom: 1px solid #ccc;\n}\n.analytics .widget-item .content.accounts-expense-weight .legend {\n  text-align: left;\n  max-height: 115px;\n}\n.analytics .widget-item .content.accounts-expense-weight .legend .title {\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-expenses-revenue .legend {\n  font-weight: bold;\n}\n.analytics .widget-item .content.accounts-expenses-revenue .settings.params-checkboxes {\n  font-size: 12px;\n  margin-left: 0px;\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-invoices-list {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.accounts-invoices-list {\n    height: 565px;\n  }\n  .analytics .widget-item .content.accounts-invoices-list .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.accounts-invoices-list .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.accounts-invoices-list .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.accounts-invoices-list transactions-list {\n  font-size: 12px;\n}\n.analytics .widget-item .content.accounts-live-balance h3 {\n  font-weight: 900;\n  font-size: 22px;\n  color: #5B6667;\n  margin-top: 0px;\n  font-size: 18px;\n  text-align: center;\n  text-shadow: 1px;\n}\n.analytics .widget-item .content.accounts-live-balance .statement-title {\n  font-size: 13px;\n  font-weight: 400;\n}\n.analytics .widget-item .content.accounts-live-balance .balance-title {\n  font-size: 12px;\n}\n.analytics .widget-item .content.accounts-live-balance .currency-centered {\n  font-weight: 300;\n  font-size: 12px;\n  color: #5B6667;\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-live-balance .headers {\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-live-balance .spacer {\n  min-height: 30px;\n}\n.analytics .widget-item .content.accounts-live-balance .price {\n  font-weight: 900;\n  font-size: 22px;\n  color: #5B6667;\n  text-align: center;\n  margin-top: 0px;\n}\n.analytics .widget-item .content.accounts-live-balance .negative2 {\n  font-size: 14px;\n}\n.analytics .widget-item .content.accounts-payable-receivable h3 {\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-payable-receivable .legend {\n  font-weight: bold;\n}\n.analytics .widget-item .content.accounts-payable-receivable .payable {\n  margin-top: 15px;\n}\n.analytics .widget-item .content.accounts-payable-receivable .price {\n  font-weight: 900;\n  font-size: 22px;\n  color: #5B6667;\n  text-align: center;\n  margin-top: 0px;\n}\n.analytics .widget-item .content.accounts-profit-and-loss {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.accounts-profit-and-loss {\n    height: 565px;\n  }\n  .analytics .widget-item .content.accounts-profit-and-loss .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.accounts-profit-and-loss .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container {\n  max-height: 540px;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line {\n  cursor: pointer;\n  border: solid 1px white;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line .selection-tag {\n  display: block;\n  right: 0px;\n  margin-top: -6px;\n  width: 10px;\n  height: 29px;\n  position: absolute;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line:hover {\n  background-color: #e6e0fb;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line.no-select {\n  cursor: auto;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line.no-select:hover {\n  color: #626d6d;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .right-panel .widget-lines-container {\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: 235px;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .no-element {\n  font-weight: 300;\n  font-size: 16px;\n  color: #5B6667;\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .row.lines-group.profit {\n  border-top: solid 1px;\n  border-bottom: double;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .right-panel .widget-lines-container {\n  max-height: 215px;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .row.widget-line.header > [class*='col-'] {\n  position: static;\n}\n.analytics .widget-item .content.accounts-ratios .left-panel {\n  max-height: 230px;\n  overflow-y: auto;\n}\n.analytics .widget-item .content.accounts-ratios .left-panel .separator {\n  border-bottom: solid 1px #5B6667;\n  width: 75%;\n}\n.analytics .widget-item .content.accounts-ratios .left-panel .member {\n  padding-top: 20px;\n  padding-bottom: 20px;\n}\n.analytics .widget-item .content.accounts-ratios .left-panel .member .price {\n  margin-top: 0px;\n  font-size: 18px;\n}\n.analytics .widget-item .content.accounts-ratios .left-panel button {\n  outline: none;\n}\n.analytics .widget-item .content.accounts-ratios .left-panel.simulation .member {\n  padding-top: 5px;\n}\n.analytics .widget-item .content.accounts-ratios .left-panel.simulation .member .legend {\n  display: none;\n}\n.analytics .widget-item .content.accounts-ratios .left-panel.simulation .member .price {\n  text-align: right;\n}\n.analytics .widget-item .content.accounts-ratios .left-panel.simulation .separator {\n  width: 100%;\n}\n.analytics .widget-item .content.hr-employee-details {\n  font-size: 12px;\n}\n.analytics .widget-item .content.hr-employee-details .details-container {\n  padding: 0px;\n  max-height: none;\n  overflow-y: auto;\n  overflow-x: hidden;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.hr-employee-details .details-container {\n    max-height: 200px;\n  }\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.hr-employee-details .right-panel .details-container {\n    max-height: 220px;\n  }\n}\n.analytics .widget-item .content.hr-employee-details .right-panel .legend {\n  margin-bottom: 5px;\n}\n.analytics .widget-item .content.hr-employee-details .title {\n  text-align: center;\n  margin-bottom: 10px;\n  font-size: 14px;\n}\n.analytics .widget-item .content.hr-employees-list .legend {\n  margin-bottom: 9px;\n}\n.analytics .widget-item .content.hr-employees-list .widget-lines-container {\n  text-align: center;\n}\n.analytics .widget-item .content.hr-employees-list .widget-lines-container .widget-line:nth-child(even) {\n  background-color: #f0f0f0;\n}\n.analytics .widget-item .content.hr-employees-list .widget-lines-container .widget-line:nth-child(odd) {\n  background-color: white;\n}\n.analytics .widget-item .content.hr-employees-list .edit .widget-lines-container {\n  text-align: left;\n}\n.analytics .widget-item .content.hr-leaves-balance .employee-name {\n  text-align: center;\n}\n.analytics .widget-item .content.hr-leaves-balance .balance {\n  font-weight: 900;\n  font-size: 22px;\n  color: #5B6667;\n  text-align: center;\n  margin-top: 0px;\n}\n.analytics .widget-item .content.hr-leaves-balance h3 {\n  margin-top: 33px;\n  text-align: center;\n}\n.analytics .widget-item .content.hr-leaves-schedule .fc-button {\n  height: 22px;\n  font-size: 12px;\n  color: #977bf0;\n  background: white;\n  outline: none;\n}\n.analytics .widget-item .content.hr-leaves-schedule .fc-button:hover {\n  color: white;\n  background: #977bf0;\n}\n.analytics .widget-item .content.hr-leaves-schedule .fc-toolbar {\n  margin-bottom: 5px;\n}\n.analytics .widget-item .content.hr-leaves-schedule .fc-day-grid,\n.analytics .widget-item .content.hr-leaves-schedule .fc-widget-header {\n  font-size: 12px;\n  color: #5B6667;\n}\n.analytics .widget-item .content.hr-payroll-summary {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.hr-payroll-summary {\n    height: 565px;\n  }\n  .analytics .widget-item .content.hr-payroll-summary .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.hr-payroll-summary .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.hr-payroll-summary .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.hr-payroll-summary .widget-lines-container {\n  max-height: 540px;\n}\n.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line {\n  cursor: pointer;\n  border: solid 1px white;\n}\n.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line .selection-tag {\n  display: block;\n  right: 0px;\n  margin-top: -6px;\n  width: 10px;\n  height: 29px;\n  position: absolute;\n}\n.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line:hover {\n  background-color: #e6e0fb;\n}\n.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line.no-select {\n  cursor: auto;\n}\n.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line.no-select:hover {\n  color: #626d6d;\n}\n.analytics .widget-item .content.hr-payroll-summary .right-panel .widget-lines-container {\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: 235px;\n}\n.analytics .widget-item .content.hr-payroll-summary .no-element {\n  font-weight: 300;\n  font-size: 16px;\n  color: #5B6667;\n  text-align: center;\n}\n.analytics .widget-item .content.hr-payroll-summary .right-panel .widget-lines-container {\n  max-height: 145px;\n}\n.analytics .widget-item .content.hr-salaries-summary h3.left {\n  text-align: center;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.hr-salaries-summary h3.left {\n    margin-top: 69px;\n  }\n}\n.analytics .widget-item .content.hr-salaries-summary h3.reduced-left {\n  text-align: center;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.hr-salaries-summary h3.reduced-left {\n    margin-top: 10px;\n  }\n}\n.analytics .widget-item .content.hr-salaries-summary h3.right {\n  margin-bottom: 10px;\n  text-align: center;\n}\n.analytics .widget-item .content.hr-salaries-summary .price {\n  margin-top: 0;\n}\n.analytics .widget-item .content.hr-salaries-summary .widget-lines-container {\n  max-height: 75px;\n}\n.analytics .widget-item .content.hr-salaries-summary .widget-lines-container .widget-line {\n  font-size: 11px;\n}\n@media (min-width: 480px) and (max-width: 991px) {\n  .analytics .widget-item .content.hr-salaries-summary .right-panel .chart-container {\n    max-width: 320px;\n  }\n}\n.analytics .widget-item .content.hr-superannuation-accruals h3 {\n  margin-top: 63px;\n  text-align: center;\n}\n.analytics .widget-item .content.hr-superannuation-accruals .legend {\n  margin-top: 23px;\n}\n.analytics .widget-item .content.hr-superannuation-accruals .currency {\n  font-size: 14px;\n}\n.analytics .widget-item .content.hr-superannuation-accruals .price {\n  font-weight: 900;\n  font-size: 22px;\n  color: #5B6667;\n  text-align: center;\n  margin-top: 0px;\n}\n.analytics .widget-item .content.hr-timesheets .currency {\n  font-size: 14px;\n}\n.analytics .widget-item .content.hr-timesheets .widget-lines-container {\n  max-height: 210px;\n}\n.analytics .widget-item .content.hr-workforce-summary h3.left {\n  text-align: center;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.hr-workforce-summary h3.left {\n    margin-top: 69px;\n  }\n}\n.analytics .widget-item .content.hr-workforce-summary h3.reduced-left {\n  text-align: center;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.hr-workforce-summary h3.reduced-left {\n    margin-top: 10px;\n  }\n}\n.analytics .widget-item .content.hr-workforce-summary h3.right {\n  margin-bottom: 10px;\n  text-align: center;\n}\n.analytics .widget-item .content.hr-workforce-summary .price {\n  margin-top: 0;\n}\n.analytics .widget-item .content.hr-workforce-summary .widget-lines-container {\n  max-height: 75px;\n}\n.analytics .widget-item .content.hr-workforce-summary .widget-lines-container .widget-line {\n  font-size: 11px;\n}\n@media (min-width: 480px) and (max-width: 991px) {\n  .analytics .widget-item .content.hr-workforce-summary .right-panel .chart-container {\n    max-width: 320px;\n  }\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.invoices-aged-payables-receivables {\n    height: 565px;\n  }\n  .analytics .widget-item .content.invoices-aged-payables-receivables .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container {\n  max-height: 540px;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line {\n  cursor: pointer;\n  border: solid 1px white;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line .selection-tag {\n  display: block;\n  right: 0px;\n  margin-top: -6px;\n  width: 10px;\n  height: 29px;\n  position: absolute;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line:hover {\n  background-color: #e6e0fb;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line.no-select {\n  cursor: auto;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line.no-select:hover {\n  color: #626d6d;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .right-panel .widget-lines-container {\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: 235px;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .no-element {\n  font-weight: 300;\n  font-size: 16px;\n  color: #5B6667;\n  text-align: center;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .right-panel .widget-lines-container {\n  max-height: 215px;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .row.astericks-info {\n  margin-top: 15px;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .currency-conversions {\n  float: right;\n  margin-left: 3px;\n}\n.analytics .widget-item .content.invoices-list .widget-lines-container {\n  max-height: 230px;\n}\n.analytics .widget-item .content.invoices-list .widget-lines-container .widget-line:nth-child(even) {\n  background-color: #f0f0f0;\n}\n.analytics .widget-item .content.invoices-list .widget-lines-container .widget-line:nth-child(odd) {\n  background-color: white;\n}\n.analytics .widget-item .content.invoices-list .widget-lines-container .widget-line.header {\n  background-color: white;\n}\n.analytics .widget-item .content.invoices-list .currency-conversions {\n  float: right;\n  margin-right: 3px;\n  margin-top: -2px;\n}\n.analytics .widget-item .content.invoices-list .fa.fa-info-circle {\n  float: right;\n  font-size: 15px;\n}\n.analytics .widget-item .content.invoices-list .right-column {\n  padding-left: 0px;\n  padding-right: 0px;\n}\n.analytics .widget-item .content.invoices-summary .chart-container {\n  max-width: 410px;\n}\n.analytics .widget-item .content.invoices-summary .legend {\n  max-height: 28px;\n}\n.analytics .widget-item .content.sales-aged {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.sales-aged {\n    height: 565px;\n  }\n  .analytics .widget-item .content.sales-aged .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.sales-aged .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.sales-aged .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.sales-aged .widget-lines-container {\n  max-height: 238px;\n}\n.analytics .widget-item .content.sales-break-even .price {\n  font-weight: 900;\n  font-size: 22px;\n  color: #5B6667;\n  text-align: center;\n  margin-top: 0px;\n}\n.analytics .widget-item .content.sales-break-even .block {\n  margin: 5px;\n  padding: 0px 10px 5px 10px;\n  text-align: left;\n  box-shadow: 0px 7px 10px -7px #17262d;\n  font-size: 12px;\n}\n.analytics .widget-item .content.sales-break-even .block form.editable-wrap .editable-controls input {\n  margin-top: 5px;\n  width: 100px;\n}\n.analytics .widget-item .content.sales-break-even .block.to-date {\n  background-color: #f0f0f0;\n  color: #5B6667;\n}\n.analytics .widget-item .content.sales-break-even .block.to-breakeven {\n  margin-top: 10px;\n  background-color: #192831;\n  color: #1de9b6;\n}\n.analytics .widget-item .content.sales-break-even .block.to-breakeven .title {\n  border-bottom: solid 1px #2a4453;\n}\n.analytics .widget-item .content.sales-break-even .block.to-breakeven .define-text {\n  font-weight: 300;\n  font-size: 16px;\n  color: #5B6667;\n  text-align: center;\n  padding-top: 5px;\n  color: #1de9b6;\n}\n.analytics .widget-item .content.sales-break-even .block.to-breakeven .price {\n  color: #1de9b6;\n}\n.analytics .widget-item .content.sales-break-even .block .title {\n  font-size: 13px;\n  text-align: center;\n  font-variant: small-caps;\n  border-bottom: solid 1px #e6edee;\n  font-weight: 300;\n}\n.analytics .widget-item .content.sales-comparison {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.sales-comparison {\n    height: 565px;\n  }\n  .analytics .widget-item .content.sales-comparison .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.sales-comparison .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.sales-comparison .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.sales-comparison .widget-lines-container {\n  max-height: 540px;\n}\n.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line {\n  cursor: pointer;\n  border: solid 1px white;\n}\n.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line .selection-tag {\n  display: block;\n  right: 0px;\n  margin-top: -6px;\n  width: 10px;\n  height: 29px;\n  position: absolute;\n}\n.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line:hover {\n  background-color: #e6e0fb;\n}\n.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line.no-select {\n  cursor: auto;\n}\n.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line.no-select:hover {\n  color: #626d6d;\n}\n.analytics .widget-item .content.sales-comparison .right-panel .widget-lines-container {\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: 235px;\n}\n.analytics .widget-item .content.sales-comparison .no-element {\n  font-weight: 300;\n  font-size: 16px;\n  color: #5B6667;\n  text-align: center;\n}\n.analytics .widget-item .content.sales-comparison .widget-lines-container {\n  max-height: 530px;\n}\n.analytics .widget-item .content.sales-comparison .right-panel .widget-lines-container {\n  max-height: 250px;\n}\n.analytics .widget-item .content.sales-comparison .currency-conversions img {\n  margin-top: -2px;\n}\n.analytics .widget-item .content.sales-customer-details {\n  font-size: 12px;\n}\n.analytics .widget-item .content.sales-customer-details .loader {\n  font-size: 14px;\n}\n.analytics .widget-item .content.sales-customer-details .details-container {\n  padding: 0px;\n  overflow-y: auto;\n  overflow-x: hidden;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.sales-customer-details .details-container {\n    max-height: 194px;\n  }\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.sales-customer-details .right-panel .details-container {\n    max-height: 230px;\n  }\n}\n.analytics .widget-item .content.sales-customer-details .right-panel .legend {\n  margin-bottom: 5px;\n}\n.analytics .widget-item .content.sales-customer-details .row.title {\n  text-align: center;\n  margin-bottom: 10px;\n  font-size: 14px;\n}\n.analytics .widget-item .content.sales-customer-details .currency-conversions {\n  float: left;\n  margin-right: 3px;\n}\n.analytics .widget-item .content.sales-cycle .chart-container {\n  max-width: 410px;\n}\n.analytics .widget-item .content.sales-cycle .legend {\n  max-height: 28px;\n}\n.analytics .widget-item .content.sales-forecast {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.sales-forecast {\n    height: 565px;\n  }\n  .analytics .widget-item .content.sales-forecast .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.sales-forecast .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.sales-forecast .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.sales-forecast .widget-lines-container {\n  max-height: 275px;\n}\n.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main {\n  cursor: pointer;\n  border: solid 1px white;\n}\n.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main .selection-tag {\n  display: block;\n  right: 0px;\n  margin-top: -6px;\n  width: 10px;\n  height: 29px;\n  position: absolute;\n}\n.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main:hover {\n  background-color: #e6e0fb;\n}\n.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main.no-select {\n  cursor: auto;\n}\n.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main.no-select:hover {\n  color: #626d6d;\n}\n.analytics .widget-item .content.sales-growth .price {\n  font-weight: 900;\n  font-size: 22px;\n  color: #5B6667;\n  text-align: center;\n  margin-top: 0px;\n}\n.analytics .widget-item .content.sales-growth .legend {\n  max-height: 49px;\n  font-size: 14px;\n  text-overflow: ellipsis;\n  white-space: nowrap;\n}\n.analytics .widget-item .content.sales-leads-funnel {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.sales-leads-funnel {\n    height: 565px;\n  }\n  .analytics .widget-item .content.sales-leads-funnel .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.sales-leads-funnel .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.sales-leads-funnel .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.sales-leads-funnel .funnel-container {\n  width: 95%;\n  margin: auto;\n  margin-top: 15px;\n  padding-right: 10px;\n  max-height: 505px;\n  overflow: auto;\n}\n.analytics .widget-item .content.sales-leads-funnel .right-panel .widget-lines-container {\n  max-height: 545px;\n  margin-right: 10px;\n}\n.analytics .widget-item .content.sales-leads-funnel .right-panel .widget-lines-container .widget-line {\n  cursor: default;\n}\n.analytics .widget-item .content.sales-leads-list .widget-lines-container {\n  max-height: 230px;\n}\n.analytics .widget-item .content.sales-leads-list .widget-lines-container .widget-line:nth-child(even) {\n  background-color: #f0f0f0;\n}\n.analytics .widget-item .content.sales-leads-list .widget-lines-container .widget-line:nth-child(odd) {\n  background-color: white;\n}\n.analytics .widget-item .content.sales-leads-list .widget-lines-container .widget-line.header {\n  background-color: white;\n}\n.analytics .widget-item .content.sales-leads-list .widget-lines-container {\n  overflow-y: scroll;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.sales-list .widget-lines-container {\n  max-height: 230px;\n}\n.analytics .widget-item .content.sales-list .widget-lines-container .widget-line:nth-child(even) {\n  background-color: #f0f0f0;\n}\n.analytics .widget-item .content.sales-list .widget-lines-container .widget-line:nth-child(odd) {\n  background-color: white;\n}\n.analytics .widget-item .content.sales-list .widget-lines-container .widget-line.header {\n  background-color: white;\n}\n.analytics .widget-item .content.sales-list .widget-lines-container {\n  overflow-y: scroll;\n  overflow-x: hidden;\n  max-height: 170px;\n}\n.analytics .widget-item .content.sales-list .widget-lines-container.no-scroll {\n  overflow: visible;\n}\n.analytics .widget-item .content.sales-list .selector {\n  margin-bottom: 4px;\n}\n.analytics .widget-item .content.sales-list .currency-conversions img {\n  margin-top: -2px;\n}\n.analytics .widget-item .content.sales-net-sales .value-container,\n.analytics .widget-item .content.sales-net-sales .operator {\n  line-height: 85px;\n}\n.analytics .widget-item .content.sales-net-sales .value-container .title {\n  line-height: 20px;\n  font-size: 1.2em;\n  padding: 10px 0px;\n}\n.analytics .widget-item .content.sales-net-sales .value-container .value-box {\n  font-size: 1.3em;\n  border-radius: 10px;\n  border-top: solid 1px #C4CACA;\n  border-bottom: solid 1px #C4CACA;\n  white-space: nowrap;\n}\n.analytics .widget-item .content.sales-net-sales .operator {\n  padding-top: 38px;\n  font-size: 1.3em;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.sales-net-sales .values {\n    margin-top: 25px;\n  }\n}\n.analytics .widget-item .content.sales-new-vs-existing-customers .selector .selector-wrap {\n  display: inline-block;\n  margin: 0 5px;\n}\n.analytics .widget-item .content.sales-new-vs-existing-customers .chart-container {\n  margin-top: 15px;\n}\n.analytics .widget-item .content.sales-new-vs-existing-customers .legend {\n  margin-top: 5px;\n  font-weight: bold;\n  max-height: 77px !important;\n}\n.analytics .widget-item .content.sales-new-vs-existing-customers .legend .row {\n  margin: 0px -5px;\n}\n.analytics .widget-item .content.sales-new-vs-existing-customers .legend .row > div {\n  padding: 0px 5px;\n}\n.analytics .widget-item .content.sales-new-vs-existing-customers .legend .total {\n  color: #5B6667;\n  font-size: 14px;\n}\n.analytics .widget-item .content.sales-number-of-leads .stats {\n  margin-top: 35px;\n  font-size: 18px;\n}\n.analytics .widget-item .content.sales-number-of-leads .stats .stat {\n  margin: 15px 0px 10px 0px;\n  border-bottom: solid 1px #e6edee;\n}\n.analytics .widget-item .content.sales-number-of-leads .stats .stat span.title {\n  font-weight: bold;\n}\n.analytics .widget-item .content.sales-number-of-leads .stats .stat span.nominal {\n  float: right;\n  text-align: right;\n  font-weight: 300;\n}\n.analytics .widget-item .content.sales-number-of-leads .stats .stat span.variation {\n  float: right;\n  width: 50px;\n  text-align: right;\n  font-style: italic;\n  font-size: 14px;\n  font-weight: 300;\n  margin-top: 2px;\n}\n.analytics .widget-item .content.sales-opportunities-funnel {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.sales-opportunities-funnel {\n    height: 565px;\n  }\n  .analytics .widget-item .content.sales-opportunities-funnel .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.sales-opportunities-funnel .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.sales-opportunities-funnel .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.sales-opportunities-funnel .funnel-container {\n  width: 95%;\n  margin: auto;\n  margin-top: 15px;\n  padding-right: 10px;\n  max-height: 505px;\n  overflow: auto;\n}\n.analytics .widget-item .content.sales-opportunities-funnel .right-panel .widget-lines-container {\n  max-height: 545px;\n  margin-right: 10px;\n}\n.analytics .widget-item .content.sales-opportunities-funnel .right-panel .widget-lines-container .widget-line {\n  cursor: default;\n}\n.analytics .widget-item .content.sales-performance {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.sales-performance {\n    height: 565px;\n  }\n  .analytics .widget-item .content.sales-performance .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.sales-performance .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.sales-performance .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.sales-performance .widget-lines-container {\n  max-height: 540px;\n}\n.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line {\n  cursor: pointer;\n  border: solid 1px white;\n}\n.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line .selection-tag {\n  display: block;\n  right: 0px;\n  margin-top: -6px;\n  width: 10px;\n  height: 29px;\n  position: absolute;\n}\n.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line:hover {\n  background-color: #e6e0fb;\n}\n.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line.no-select {\n  cursor: auto;\n}\n.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line.no-select:hover {\n  color: #626d6d;\n}\n.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container {\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: 235px;\n}\n.analytics .widget-item .content.sales-performance .no-element {\n  font-weight: 300;\n  font-size: 16px;\n  color: #5B6667;\n  text-align: center;\n}\n.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container {\n  max-height: 215px;\n}\n.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header {\n  cursor: pointer;\n  border: solid 1px white;\n}\n.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header .selection-tag {\n  display: block;\n  right: 0px;\n  margin-top: -6px;\n  width: 10px;\n  height: 29px;\n  position: absolute;\n}\n.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header:hover {\n  background-color: #e6e0fb;\n}\n.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header.no-select {\n  cursor: auto;\n}\n.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header.no-select:hover {\n  color: #626d6d;\n}\n.analytics .widget-item .content.sales-segmented-turnover h3.right {\n  margin-top: 55px;\n  text-align: center;\n}\n.analytics .widget-item .content.sales-segmented-turnover .selector {\n  margin-bottom: 10px;\n}\n.analytics .widget-item .content.sales-segmented-turnover .analysis {\n  font-weight: 900;\n  font-size: 22px;\n  color: #5B6667;\n  text-align: center;\n  margin-top: 0px;\n}\n.analytics .widget-item .content.sales-segmented-turnover .widget-lines-container {\n  max-height: 75px;\n}\n.analytics .widget-item .content.sales-segmented-turnover .widget-lines-container .widget-line {\n  font-size: 11px;\n}\n.analytics .widget-item .content.sales-segmented-turnover .right-panel h3 {\n  margin: 15px 10px 5px 10px;\n  text-align: center;\n}\n.analytics .widget-item .content.sales-segmented-turnover .right-panel .fa.fa-info-circle {\n  float: left;\n}\n.analytics .widget-item .content.sales-summary .chart-container {\n  max-width: 410px;\n}\n.analytics .widget-item .content.sales-summary .legend {\n  max-height: 28px;\n}\n.analytics .widget-item .content.sales-summary .selector {\n  margin-bottom: 5px;\n}\n.analytics .widget-item .content.sales-top-customers .selector {\n  border-bottom: dashed 1px #E6E6E6;\n  padding-bottom: 3px;\n}\n.analytics .widget-item .content.sales-top-customers .selector a {\n  font-weight: normal;\n}\n.analytics .widget-item .content.sales-top-customers .selector .param-selector {\n  display: inline-block;\n}\n.analytics .widget-item .content.sales-top-customers .widget-lines-container {\n  max-height: 235px;\n}\n.analytics .widget-item .content.sales-top-customers .widget-lines-container .widget-line.sub-line {\n  background-color: #f0f0f0;\n}\n.analytics .widget-item .content.sales-top-customers .widget-lines-container .row > [class*='col-'] {\n  position: static;\n}\n.analytics .widget-item .content.sales-top-customers .currency-conversions img {\n  margin-top: -2px;\n}\n.analytics .widget-item .content.sales-top-opportunities .opps-container {\n  max-height: 195px;\n  margin-top: 10px;\n  padding-right: 10px;\n  overflow-y: auto;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.sales-top-opportunities .opps-container .tile {\n  height: 40px;\n  font-size: 13px;\n  font-weight: 300;\n}\n.analytics .widget-item .content.sales-top-opportunities .opps-container .tile .colored-area {\n  width: 10%;\n  text-align: center;\n  font-size: 20px;\n}\n.analytics .widget-item .content.sales-top-opportunities .opps-container .tile .main-text {\n  color: #5B6667;\n  padding: 3px 0px 0px 10px;\n}\n.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.first {\n  height: 55px;\n  font-size: 15px;\n  font-weight: bold;\n}\n.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.first .colored-area {\n  font-size: 26px;\n  padding-top: 10px;\n  background-color: #ff6e41;\n}\n.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.first .main-text {\n  padding-top: 8px;\n}\n.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.second {\n  height: 55px;\n  font-size: 15px;\n  font-weight: 500;\n}\n.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.second .colored-area {\n  font-size: 26px;\n  padding-top: 10px;\n  background-color: #1de9b6;\n}\n.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.second .main-text {\n  padding-top: 8px;\n}\n/* endinject */\n","/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */\n\n//\n// 1. Set default font family to sans-serif.\n// 2. Prevent iOS and IE text size adjust after device orientation change,\n//    without disabling user zoom.\n//\n\nhtml {\n  font-family: sans-serif; // 1\n  -ms-text-size-adjust: 100%; // 2\n  -webkit-text-size-adjust: 100%; // 2\n}\n\n//\n// Remove default margin.\n//\n\nbody {\n  margin: 0;\n}\n\n// HTML5 display definitions\n// ==========================================================================\n\n//\n// Correct `block` display not defined for any HTML5 element in IE 8/9.\n// Correct `block` display not defined for `details` or `summary` in IE 10/11\n// and Firefox.\n// Correct `block` display not defined for `main` in IE 11.\n//\n\narticle,\naside,\ndetails,\nfigcaption,\nfigure,\nfooter,\nheader,\nhgroup,\nmain,\nmenu,\nnav,\nsection,\nsummary {\n  display: block;\n}\n\n//\n// 1. Correct `inline-block` display not defined in IE 8/9.\n// 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.\n//\n\naudio,\ncanvas,\nprogress,\nvideo {\n  display: inline-block; // 1\n  vertical-align: baseline; // 2\n}\n\n//\n// Prevent modern browsers from displaying `audio` without controls.\n// Remove excess height in iOS 5 devices.\n//\n\naudio:not([controls]) {\n  display: none;\n  height: 0;\n}\n\n//\n// Address `[hidden]` styling not present in IE 8/9/10.\n// Hide the `template` element in IE 8/9/10/11, Safari, and Firefox < 22.\n//\n\n[hidden],\ntemplate {\n  display: none;\n}\n\n// Links\n// ==========================================================================\n\n//\n// Remove the gray background color from active links in IE 10.\n//\n\na {\n  background-color: transparent;\n}\n\n//\n// Improve readability of focused elements when they are also in an\n// active/hover state.\n//\n\na:active,\na:hover {\n  outline: 0;\n}\n\n// Text-level semantics\n// ==========================================================================\n\n//\n// Address styling not present in IE 8/9/10/11, Safari, and Chrome.\n//\n\nabbr[title] {\n  border-bottom: 1px dotted;\n}\n\n//\n// Address style set to `bolder` in Firefox 4+, Safari, and Chrome.\n//\n\nb,\nstrong {\n  font-weight: bold;\n}\n\n//\n// Address styling not present in Safari and Chrome.\n//\n\ndfn {\n  font-style: italic;\n}\n\n//\n// Address variable `h1` font-size and margin within `section` and `article`\n// contexts in Firefox 4+, Safari, and Chrome.\n//\n\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0;\n}\n\n//\n// Address styling not present in IE 8/9.\n//\n\nmark {\n  background: #ff0;\n  color: #000;\n}\n\n//\n// Address inconsistent and variable font size in all browsers.\n//\n\nsmall {\n  font-size: 80%;\n}\n\n//\n// Prevent `sub` and `sup` affecting `line-height` in all browsers.\n//\n\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n}\n\nsup {\n  top: -0.5em;\n}\n\nsub {\n  bottom: -0.25em;\n}\n\n// Embedded content\n// ==========================================================================\n\n//\n// Remove border when inside `a` element in IE 8/9/10.\n//\n\nimg {\n  border: 0;\n}\n\n//\n// Correct overflow not hidden in IE 9/10/11.\n//\n\nsvg:not(:root) {\n  overflow: hidden;\n}\n\n// Grouping content\n// ==========================================================================\n\n//\n// Address margin not present in IE 8/9 and Safari.\n//\n\nfigure {\n  margin: 1em 40px;\n}\n\n//\n// Address differences between Firefox and other browsers.\n//\n\nhr {\n  box-sizing: content-box;\n  height: 0;\n}\n\n//\n// Contain overflow in all browsers.\n//\n\npre {\n  overflow: auto;\n}\n\n//\n// Address odd `em`-unit font size rendering in all browsers.\n//\n\ncode,\nkbd,\npre,\nsamp {\n  font-family: monospace, monospace;\n  font-size: 1em;\n}\n\n// Forms\n// ==========================================================================\n\n//\n// Known limitation: by default, Chrome and Safari on OS X allow very limited\n// styling of `select`, unless a `border` property is set.\n//\n\n//\n// 1. Correct color not being inherited.\n//    Known issue: affects color of disabled elements.\n// 2. Correct font properties not being inherited.\n// 3. Address margins set differently in Firefox 4+, Safari, and Chrome.\n//\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  color: inherit; // 1\n  font: inherit; // 2\n  margin: 0; // 3\n}\n\n//\n// Address `overflow` set to `hidden` in IE 8/9/10/11.\n//\n\nbutton {\n  overflow: visible;\n}\n\n//\n// Address inconsistent `text-transform` inheritance for `button` and `select`.\n// All other form control elements do not inherit `text-transform` values.\n// Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.\n// Correct `select` style inheritance in Firefox.\n//\n\nbutton,\nselect {\n  text-transform: none;\n}\n\n//\n// 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`\n//    and `video` controls.\n// 2. Correct inability to style clickable `input` types in iOS.\n// 3. Improve usability and consistency of cursor style between image-type\n//    `input` and others.\n//\n\nbutton,\nhtml input[type=\"button\"], // 1\ninput[type=\"reset\"],\ninput[type=\"submit\"] {\n  -webkit-appearance: button; // 2\n  cursor: pointer; // 3\n}\n\n//\n// Re-set default cursor for disabled elements.\n//\n\nbutton[disabled],\nhtml input[disabled] {\n  cursor: default;\n}\n\n//\n// Remove inner padding and border in Firefox 4+.\n//\n\nbutton::-moz-focus-inner,\ninput::-moz-focus-inner {\n  border: 0;\n  padding: 0;\n}\n\n//\n// Address Firefox 4+ setting `line-height` on `input` using `!important` in\n// the UA stylesheet.\n//\n\ninput {\n  line-height: normal;\n}\n\n//\n// It's recommended that you don't attempt to style these elements.\n// Firefox's implementation doesn't respect box-sizing, padding, or width.\n//\n// 1. Address box sizing set to `content-box` in IE 8/9/10.\n// 2. Remove excess padding in IE 8/9/10.\n//\n\ninput[type=\"checkbox\"],\ninput[type=\"radio\"] {\n  box-sizing: border-box; // 1\n  padding: 0; // 2\n}\n\n//\n// Fix the cursor style for Chrome's increment/decrement buttons. For certain\n// `font-size` values of the `input`, it causes the cursor style of the\n// decrement button to change from `default` to `text`.\n//\n\ninput[type=\"number\"]::-webkit-inner-spin-button,\ninput[type=\"number\"]::-webkit-outer-spin-button {\n  height: auto;\n}\n\n//\n// 1. Address `appearance` set to `searchfield` in Safari and Chrome.\n// 2. Address `box-sizing` set to `border-box` in Safari and Chrome.\n//\n\ninput[type=\"search\"] {\n  -webkit-appearance: textfield; // 1\n  box-sizing: content-box; //2\n}\n\n//\n// Remove inner padding and search cancel button in Safari and Chrome on OS X.\n// Safari (but not Chrome) clips the cancel button when the search input has\n// padding (and `textfield` appearance).\n//\n\ninput[type=\"search\"]::-webkit-search-cancel-button,\ninput[type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none;\n}\n\n//\n// Define consistent border, margin, and padding.\n//\n\nfieldset {\n  border: 1px solid #c0c0c0;\n  margin: 0 2px;\n  padding: 0.35em 0.625em 0.75em;\n}\n\n//\n// 1. Correct `color` not being inherited in IE 8/9/10/11.\n// 2. Remove padding so people aren't caught out if they zero out fieldsets.\n//\n\nlegend {\n  border: 0; // 1\n  padding: 0; // 2\n}\n\n//\n// Remove default vertical scrollbar in IE 8/9/10/11.\n//\n\ntextarea {\n  overflow: auto;\n}\n\n//\n// Don't inherit the `font-weight` (applied by a rule above).\n// NOTE: the default cannot safely be changed in Chrome and Safari on OS X.\n//\n\noptgroup {\n  font-weight: bold;\n}\n\n// Tables\n// ==========================================================================\n\n//\n// Remove most spacing between table cells.\n//\n\ntable {\n  border-collapse: collapse;\n  border-spacing: 0;\n}\n\ntd,\nth {\n  padding: 0;\n}\n","//\n// Glyphicons for Bootstrap\n//\n// Since icons are fonts, they can be placed anywhere text is placed and are\n// thus automatically sized to match the surrounding child. To use, create an\n// inline element with the appropriate classes, like so:\n//\n// <a href=\"#\"><span class=\"glyphicon glyphicon-star\"></span> Star</a>\n\n// Import the fonts\n@font-face {\n  font-family: 'Glyphicons Halflings';\n  src: url('@{icon-font-path}@{icon-font-name}.eot');\n  src: url('@{icon-font-path}@{icon-font-name}.eot?#iefix') format('embedded-opentype'),\n       url('@{icon-font-path}@{icon-font-name}.woff2') format('woff2'),\n       url('@{icon-font-path}@{icon-font-name}.woff') format('woff'),\n       url('@{icon-font-path}@{icon-font-name}.ttf') format('truetype'),\n       url('@{icon-font-path}@{icon-font-name}.svg#@{icon-font-svg-id}') format('svg');\n}\n\n// Catchall baseclass\n.glyphicon {\n  position: relative;\n  top: 1px;\n  display: inline-block;\n  font-family: 'Glyphicons Halflings';\n  font-style: normal;\n  font-weight: normal;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\n// Individual icons\n.glyphicon-asterisk               { &:before { content: \"\\002a\"; } }\n.glyphicon-plus                   { &:before { content: \"\\002b\"; } }\n.glyphicon-euro,\n.glyphicon-eur                    { &:before { content: \"\\20ac\"; } }\n.glyphicon-minus                  { &:before { content: \"\\2212\"; } }\n.glyphicon-cloud                  { &:before { content: \"\\2601\"; } }\n.glyphicon-envelope               { &:before { content: \"\\2709\"; } }\n.glyphicon-pencil                 { &:before { content: \"\\270f\"; } }\n.glyphicon-glass                  { &:before { content: \"\\e001\"; } }\n.glyphicon-music                  { &:before { content: \"\\e002\"; } }\n.glyphicon-search                 { &:before { content: \"\\e003\"; } }\n.glyphicon-heart                  { &:before { content: \"\\e005\"; } }\n.glyphicon-star                   { &:before { content: \"\\e006\"; } }\n.glyphicon-star-empty             { &:before { content: \"\\e007\"; } }\n.glyphicon-user                   { &:before { content: \"\\e008\"; } }\n.glyphicon-film                   { &:before { content: \"\\e009\"; } }\n.glyphicon-th-large               { &:before { content: \"\\e010\"; } }\n.glyphicon-th                     { &:before { content: \"\\e011\"; } }\n.glyphicon-th-list                { &:before { content: \"\\e012\"; } }\n.glyphicon-ok                     { &:before { content: \"\\e013\"; } }\n.glyphicon-remove                 { &:before { content: \"\\e014\"; } }\n.glyphicon-zoom-in                { &:before { content: \"\\e015\"; } }\n.glyphicon-zoom-out               { &:before { content: \"\\e016\"; } }\n.glyphicon-off                    { &:before { content: \"\\e017\"; } }\n.glyphicon-signal                 { &:before { content: \"\\e018\"; } }\n.glyphicon-cog                    { &:before { content: \"\\e019\"; } }\n.glyphicon-trash                  { &:before { content: \"\\e020\"; } }\n.glyphicon-home                   { &:before { content: \"\\e021\"; } }\n.glyphicon-file                   { &:before { content: \"\\e022\"; } }\n.glyphicon-time                   { &:before { content: \"\\e023\"; } }\n.glyphicon-road                   { &:before { content: \"\\e024\"; } }\n.glyphicon-download-alt           { &:before { content: \"\\e025\"; } }\n.glyphicon-download               { &:before { content: \"\\e026\"; } }\n.glyphicon-upload                 { &:before { content: \"\\e027\"; } }\n.glyphicon-inbox                  { &:before { content: \"\\e028\"; } }\n.glyphicon-play-circle            { &:before { content: \"\\e029\"; } }\n.glyphicon-repeat                 { &:before { content: \"\\e030\"; } }\n.glyphicon-refresh                { &:before { content: \"\\e031\"; } }\n.glyphicon-list-alt               { &:before { content: \"\\e032\"; } }\n.glyphicon-lock                   { &:before { content: \"\\e033\"; } }\n.glyphicon-flag                   { &:before { content: \"\\e034\"; } }\n.glyphicon-headphones             { &:before { content: \"\\e035\"; } }\n.glyphicon-volume-off             { &:before { content: \"\\e036\"; } }\n.glyphicon-volume-down            { &:before { content: \"\\e037\"; } }\n.glyphicon-volume-up              { &:before { content: \"\\e038\"; } }\n.glyphicon-qrcode                 { &:before { content: \"\\e039\"; } }\n.glyphicon-barcode                { &:before { content: \"\\e040\"; } }\n.glyphicon-tag                    { &:before { content: \"\\e041\"; } }\n.glyphicon-tags                   { &:before { content: \"\\e042\"; } }\n.glyphicon-book                   { &:before { content: \"\\e043\"; } }\n.glyphicon-bookmark               { &:before { content: \"\\e044\"; } }\n.glyphicon-print                  { &:before { content: \"\\e045\"; } }\n.glyphicon-camera                 { &:before { content: \"\\e046\"; } }\n.glyphicon-font                   { &:before { content: \"\\e047\"; } }\n.glyphicon-bold                   { &:before { content: \"\\e048\"; } }\n.glyphicon-italic                 { &:before { content: \"\\e049\"; } }\n.glyphicon-text-height            { &:before { content: \"\\e050\"; } }\n.glyphicon-text-width             { &:before { content: \"\\e051\"; } }\n.glyphicon-align-left             { &:before { content: \"\\e052\"; } }\n.glyphicon-align-center           { &:before { content: \"\\e053\"; } }\n.glyphicon-align-right            { &:before { content: \"\\e054\"; } }\n.glyphicon-align-justify          { &:before { content: \"\\e055\"; } }\n.glyphicon-list                   { &:before { content: \"\\e056\"; } }\n.glyphicon-indent-left            { &:before { content: \"\\e057\"; } }\n.glyphicon-indent-right           { &:before { content: \"\\e058\"; } }\n.glyphicon-facetime-video         { &:before { content: \"\\e059\"; } }\n.glyphicon-picture                { &:before { content: \"\\e060\"; } }\n.glyphicon-map-marker             { &:before { content: \"\\e062\"; } }\n.glyphicon-adjust                 { &:before { content: \"\\e063\"; } }\n.glyphicon-tint                   { &:before { content: \"\\e064\"; } }\n.glyphicon-edit                   { &:before { content: \"\\e065\"; } }\n.glyphicon-share                  { &:before { content: \"\\e066\"; } }\n.glyphicon-check                  { &:before { content: \"\\e067\"; } }\n.glyphicon-move                   { &:before { content: \"\\e068\"; } }\n.glyphicon-step-backward          { &:before { content: \"\\e069\"; } }\n.glyphicon-fast-backward          { &:before { content: \"\\e070\"; } }\n.glyphicon-backward               { &:before { content: \"\\e071\"; } }\n.glyphicon-play                   { &:before { content: \"\\e072\"; } }\n.glyphicon-pause                  { &:before { content: \"\\e073\"; } }\n.glyphicon-stop                   { &:before { content: \"\\e074\"; } }\n.glyphicon-forward                { &:before { content: \"\\e075\"; } }\n.glyphicon-fast-forward           { &:before { content: \"\\e076\"; } }\n.glyphicon-step-forward           { &:before { content: \"\\e077\"; } }\n.glyphicon-eject                  { &:before { content: \"\\e078\"; } }\n.glyphicon-chevron-left           { &:before { content: \"\\e079\"; } }\n.glyphicon-chevron-right          { &:before { content: \"\\e080\"; } }\n.glyphicon-plus-sign              { &:before { content: \"\\e081\"; } }\n.glyphicon-minus-sign             { &:before { content: \"\\e082\"; } }\n.glyphicon-remove-sign            { &:before { content: \"\\e083\"; } }\n.glyphicon-ok-sign                { &:before { content: \"\\e084\"; } }\n.glyphicon-question-sign          { &:before { content: \"\\e085\"; } }\n.glyphicon-info-sign              { &:before { content: \"\\e086\"; } }\n.glyphicon-screenshot             { &:before { content: \"\\e087\"; } }\n.glyphicon-remove-circle          { &:before { content: \"\\e088\"; } }\n.glyphicon-ok-circle              { &:before { content: \"\\e089\"; } }\n.glyphicon-ban-circle             { &:before { content: \"\\e090\"; } }\n.glyphicon-arrow-left             { &:before { content: \"\\e091\"; } }\n.glyphicon-arrow-right            { &:before { content: \"\\e092\"; } }\n.glyphicon-arrow-up               { &:before { content: \"\\e093\"; } }\n.glyphicon-arrow-down             { &:before { content: \"\\e094\"; } }\n.glyphicon-share-alt              { &:before { content: \"\\e095\"; } }\n.glyphicon-resize-full            { &:before { content: \"\\e096\"; } }\n.glyphicon-resize-small           { &:before { content: \"\\e097\"; } }\n.glyphicon-exclamation-sign       { &:before { content: \"\\e101\"; } }\n.glyphicon-gift                   { &:before { content: \"\\e102\"; } }\n.glyphicon-leaf                   { &:before { content: \"\\e103\"; } }\n.glyphicon-fire                   { &:before { content: \"\\e104\"; } }\n.glyphicon-eye-open               { &:before { content: \"\\e105\"; } }\n.glyphicon-eye-close              { &:before { content: \"\\e106\"; } }\n.glyphicon-warning-sign           { &:before { content: \"\\e107\"; } }\n.glyphicon-plane                  { &:before { content: \"\\e108\"; } }\n.glyphicon-calendar               { &:before { content: \"\\e109\"; } }\n.glyphicon-random                 { &:before { content: \"\\e110\"; } }\n.glyphicon-comment                { &:before { content: \"\\e111\"; } }\n.glyphicon-magnet                 { &:before { content: \"\\e112\"; } }\n.glyphicon-chevron-up             { &:before { content: \"\\e113\"; } }\n.glyphicon-chevron-down           { &:before { content: \"\\e114\"; } }\n.glyphicon-retweet                { &:before { content: \"\\e115\"; } }\n.glyphicon-shopping-cart          { &:before { content: \"\\e116\"; } }\n.glyphicon-folder-close           { &:before { content: \"\\e117\"; } }\n.glyphicon-folder-open            { &:before { content: \"\\e118\"; } }\n.glyphicon-resize-vertical        { &:before { content: \"\\e119\"; } }\n.glyphicon-resize-horizontal      { &:before { content: \"\\e120\"; } }\n.glyphicon-hdd                    { &:before { content: \"\\e121\"; } }\n.glyphicon-bullhorn               { &:before { content: \"\\e122\"; } }\n.glyphicon-bell                   { &:before { content: \"\\e123\"; } }\n.glyphicon-certificate            { &:before { content: \"\\e124\"; } }\n.glyphicon-thumbs-up              { &:before { content: \"\\e125\"; } }\n.glyphicon-thumbs-down            { &:before { content: \"\\e126\"; } }\n.glyphicon-hand-right             { &:before { content: \"\\e127\"; } }\n.glyphicon-hand-left              { &:before { content: \"\\e128\"; } }\n.glyphicon-hand-up                { &:before { content: \"\\e129\"; } }\n.glyphicon-hand-down              { &:before { content: \"\\e130\"; } }\n.glyphicon-circle-arrow-right     { &:before { content: \"\\e131\"; } }\n.glyphicon-circle-arrow-left      { &:before { content: \"\\e132\"; } }\n.glyphicon-circle-arrow-up        { &:before { content: \"\\e133\"; } }\n.glyphicon-circle-arrow-down      { &:before { content: \"\\e134\"; } }\n.glyphicon-globe                  { &:before { content: \"\\e135\"; } }\n.glyphicon-wrench                 { &:before { content: \"\\e136\"; } }\n.glyphicon-tasks                  { &:before { content: \"\\e137\"; } }\n.glyphicon-filter                 { &:before { content: \"\\e138\"; } }\n.glyphicon-briefcase              { &:before { content: \"\\e139\"; } }\n.glyphicon-fullscreen             { &:before { content: \"\\e140\"; } }\n.glyphicon-dashboard              { &:before { content: \"\\e141\"; } }\n.glyphicon-paperclip              { &:before { content: \"\\e142\"; } }\n.glyphicon-heart-empty            { &:before { content: \"\\e143\"; } }\n.glyphicon-link                   { &:before { content: \"\\e144\"; } }\n.glyphicon-phone                  { &:before { content: \"\\e145\"; } }\n.glyphicon-pushpin                { &:before { content: \"\\e146\"; } }\n.glyphicon-usd                    { &:before { content: \"\\e148\"; } }\n.glyphicon-gbp                    { &:before { content: \"\\e149\"; } }\n.glyphicon-sort                   { &:before { content: \"\\e150\"; } }\n.glyphicon-sort-by-alphabet       { &:before { content: \"\\e151\"; } }\n.glyphicon-sort-by-alphabet-alt   { &:before { content: \"\\e152\"; } }\n.glyphicon-sort-by-order          { &:before { content: \"\\e153\"; } }\n.glyphicon-sort-by-order-alt      { &:before { content: \"\\e154\"; } }\n.glyphicon-sort-by-attributes     { &:before { content: \"\\e155\"; } }\n.glyphicon-sort-by-attributes-alt { &:before { content: \"\\e156\"; } }\n.glyphicon-unchecked              { &:before { content: \"\\e157\"; } }\n.glyphicon-expand                 { &:before { content: \"\\e158\"; } }\n.glyphicon-collapse-down          { &:before { content: \"\\e159\"; } }\n.glyphicon-collapse-up            { &:before { content: \"\\e160\"; } }\n.glyphicon-log-in                 { &:before { content: \"\\e161\"; } }\n.glyphicon-flash                  { &:before { content: \"\\e162\"; } }\n.glyphicon-log-out                { &:before { content: \"\\e163\"; } }\n.glyphicon-new-window             { &:before { content: \"\\e164\"; } }\n.glyphicon-record                 { &:before { content: \"\\e165\"; } }\n.glyphicon-save                   { &:before { content: \"\\e166\"; } }\n.glyphicon-open                   { &:before { content: \"\\e167\"; } }\n.glyphicon-saved                  { &:before { content: \"\\e168\"; } }\n.glyphicon-import                 { &:before { content: \"\\e169\"; } }\n.glyphicon-export                 { &:before { content: \"\\e170\"; } }\n.glyphicon-send                   { &:before { content: \"\\e171\"; } }\n.glyphicon-floppy-disk            { &:before { content: \"\\e172\"; } }\n.glyphicon-floppy-saved           { &:before { content: \"\\e173\"; } }\n.glyphicon-floppy-remove          { &:before { content: \"\\e174\"; } }\n.glyphicon-floppy-save            { &:before { content: \"\\e175\"; } }\n.glyphicon-floppy-open            { &:before { content: \"\\e176\"; } }\n.glyphicon-credit-card            { &:before { content: \"\\e177\"; } }\n.glyphicon-transfer               { &:before { content: \"\\e178\"; } }\n.glyphicon-cutlery                { &:before { content: \"\\e179\"; } }\n.glyphicon-header                 { &:before { content: \"\\e180\"; } }\n.glyphicon-compressed             { &:before { content: \"\\e181\"; } }\n.glyphicon-earphone               { &:before { content: \"\\e182\"; } }\n.glyphicon-phone-alt              { &:before { content: \"\\e183\"; } }\n.glyphicon-tower                  { &:before { content: \"\\e184\"; } }\n.glyphicon-stats                  { &:before { content: \"\\e185\"; } }\n.glyphicon-sd-video               { &:before { content: \"\\e186\"; } }\n.glyphicon-hd-video               { &:before { content: \"\\e187\"; } }\n.glyphicon-subtitles              { &:before { content: \"\\e188\"; } }\n.glyphicon-sound-stereo           { &:before { content: \"\\e189\"; } }\n.glyphicon-sound-dolby            { &:before { content: \"\\e190\"; } }\n.glyphicon-sound-5-1              { &:before { content: \"\\e191\"; } }\n.glyphicon-sound-6-1              { &:before { content: \"\\e192\"; } }\n.glyphicon-sound-7-1              { &:before { content: \"\\e193\"; } }\n.glyphicon-copyright-mark         { &:before { content: \"\\e194\"; } }\n.glyphicon-registration-mark      { &:before { content: \"\\e195\"; } }\n.glyphicon-cloud-download         { &:before { content: \"\\e197\"; } }\n.glyphicon-cloud-upload           { &:before { content: \"\\e198\"; } }\n.glyphicon-tree-conifer           { &:before { content: \"\\e199\"; } }\n.glyphicon-tree-deciduous         { &:before { content: \"\\e200\"; } }\n.glyphicon-cd                     { &:before { content: \"\\e201\"; } }\n.glyphicon-save-file              { &:before { content: \"\\e202\"; } }\n.glyphicon-open-file              { &:before { content: \"\\e203\"; } }\n.glyphicon-level-up               { &:before { content: \"\\e204\"; } }\n.glyphicon-copy                   { &:before { content: \"\\e205\"; } }\n.glyphicon-paste                  { &:before { content: \"\\e206\"; } }\n// The following 2 Glyphicons are omitted for the time being because\n// they currently use Unicode codepoints that are outside the\n// Basic Multilingual Plane (BMP). Older buggy versions of WebKit can't handle\n// non-BMP codepoints in CSS string escapes, and thus can't display these two icons.\n// Notably, the bug affects some older versions of the Android Browser.\n// More info: https://github.com/twbs/bootstrap/issues/10106\n// .glyphicon-door                   { &:before { content: \"\\1f6aa\"; } }\n// .glyphicon-key                    { &:before { content: \"\\1f511\"; } }\n.glyphicon-alert                  { &:before { content: \"\\e209\"; } }\n.glyphicon-equalizer              { &:before { content: \"\\e210\"; } }\n.glyphicon-king                   { &:before { content: \"\\e211\"; } }\n.glyphicon-queen                  { &:before { content: \"\\e212\"; } }\n.glyphicon-pawn                   { &:before { content: \"\\e213\"; } }\n.glyphicon-bishop                 { &:before { content: \"\\e214\"; } }\n.glyphicon-knight                 { &:before { content: \"\\e215\"; } }\n.glyphicon-baby-formula           { &:before { content: \"\\e216\"; } }\n.glyphicon-tent                   { &:before { content: \"\\26fa\"; } }\n.glyphicon-blackboard             { &:before { content: \"\\e218\"; } }\n.glyphicon-bed                    { &:before { content: \"\\e219\"; } }\n.glyphicon-apple                  { &:before { content: \"\\f8ff\"; } }\n.glyphicon-erase                  { &:before { content: \"\\e221\"; } }\n.glyphicon-hourglass              { &:before { content: \"\\231b\"; } }\n.glyphicon-lamp                   { &:before { content: \"\\e223\"; } }\n.glyphicon-duplicate              { &:before { content: \"\\e224\"; } }\n.glyphicon-piggy-bank             { &:before { content: \"\\e225\"; } }\n.glyphicon-scissors               { &:before { content: \"\\e226\"; } }\n.glyphicon-bitcoin                { &:before { content: \"\\e227\"; } }\n.glyphicon-btc                    { &:before { content: \"\\e227\"; } }\n.glyphicon-xbt                    { &:before { content: \"\\e227\"; } }\n.glyphicon-yen                    { &:before { content: \"\\00a5\"; } }\n.glyphicon-jpy                    { &:before { content: \"\\00a5\"; } }\n.glyphicon-ruble                  { &:before { content: \"\\20bd\"; } }\n.glyphicon-rub                    { &:before { content: \"\\20bd\"; } }\n.glyphicon-scale                  { &:before { content: \"\\e230\"; } }\n.glyphicon-ice-lolly              { &:before { content: \"\\e231\"; } }\n.glyphicon-ice-lolly-tasted       { &:before { content: \"\\e232\"; } }\n.glyphicon-education              { &:before { content: \"\\e233\"; } }\n.glyphicon-option-horizontal      { &:before { content: \"\\e234\"; } }\n.glyphicon-option-vertical        { &:before { content: \"\\e235\"; } }\n.glyphicon-menu-hamburger         { &:before { content: \"\\e236\"; } }\n.glyphicon-modal-window           { &:before { content: \"\\e237\"; } }\n.glyphicon-oil                    { &:before { content: \"\\e238\"; } }\n.glyphicon-grain                  { &:before { content: \"\\e239\"; } }\n.glyphicon-sunglasses             { &:before { content: \"\\e240\"; } }\n.glyphicon-text-size              { &:before { content: \"\\e241\"; } }\n.glyphicon-text-color             { &:before { content: \"\\e242\"; } }\n.glyphicon-text-background        { &:before { content: \"\\e243\"; } }\n.glyphicon-object-align-top       { &:before { content: \"\\e244\"; } }\n.glyphicon-object-align-bottom    { &:before { content: \"\\e245\"; } }\n.glyphicon-object-align-horizontal{ &:before { content: \"\\e246\"; } }\n.glyphicon-object-align-left      { &:before { content: \"\\e247\"; } }\n.glyphicon-object-align-vertical  { &:before { content: \"\\e248\"; } }\n.glyphicon-object-align-right     { &:before { content: \"\\e249\"; } }\n.glyphicon-triangle-right         { &:before { content: \"\\e250\"; } }\n.glyphicon-triangle-left          { &:before { content: \"\\e251\"; } }\n.glyphicon-triangle-bottom        { &:before { content: \"\\e252\"; } }\n.glyphicon-triangle-top           { &:before { content: \"\\e253\"; } }\n.glyphicon-console                { &:before { content: \"\\e254\"; } }\n.glyphicon-superscript            { &:before { content: \"\\e255\"; } }\n.glyphicon-subscript              { &:before { content: \"\\e256\"; } }\n.glyphicon-menu-left              { &:before { content: \"\\e257\"; } }\n.glyphicon-menu-right             { &:before { content: \"\\e258\"; } }\n.glyphicon-menu-down              { &:before { content: \"\\e259\"; } }\n.glyphicon-menu-up                { &:before { content: \"\\e260\"; } }\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\n\n// iOS \"clickable elements\" fix for role=\"button\"\n//\n// Fixes \"clickability\" issue (and more generally, the firing of events such as focus as well)\n// for traditionally non-focusable elements with role=\"button\"\n// see https://developer.mozilla.org/en-US/docs/Web/Events/click#Safari_Mobile\n\n[role=\"button\"] {\n  cursor: pointer;\n}\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 have been 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; // Override Firefox's unusual default opacity; 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","// WebKit-style focus\n\n.tab-focus() {\n  // WebKit-specific. Other browsers will keep their default outline style.\n  // (Initially tried to also force default via `outline: initial`,\n  // but that seems to erroneously remove the outline in Firefox altogether.)\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","//\n// Typography\n// --------------------------------------------------\n\n\n// Headings\n// -------------------------\n\nh1, h2, h3, h4, h5, h6,\n.h1, .h2, .h3, .h4, .h5, .h6 {\n  font-family: @headings-font-family;\n  font-weight: @headings-font-weight;\n  line-height: @headings-line-height;\n  color: @headings-color;\n\n  small,\n  .small {\n    font-weight: normal;\n    line-height: 1;\n    color: @headings-small-color;\n  }\n}\n\nh1, .h1,\nh2, .h2,\nh3, .h3 {\n  margin-top: @line-height-computed;\n  margin-bottom: (@line-height-computed / 2);\n\n  small,\n  .small {\n    font-size: 65%;\n  }\n}\nh4, .h4,\nh5, .h5,\nh6, .h6 {\n  margin-top: (@line-height-computed / 2);\n  margin-bottom: (@line-height-computed / 2);\n\n  small,\n  .small {\n    font-size: 75%;\n  }\n}\n\nh1, .h1 { font-size: @font-size-h1; }\nh2, .h2 { font-size: @font-size-h2; }\nh3, .h3 { font-size: @font-size-h3; }\nh4, .h4 { font-size: @font-size-h4; }\nh5, .h5 { font-size: @font-size-h5; }\nh6, .h6 { font-size: @font-size-h6; }\n\n\n// Body text\n// -------------------------\n\np {\n  margin: 0 0 (@line-height-computed / 2);\n}\n\n.lead {\n  margin-bottom: @line-height-computed;\n  font-size: floor((@font-size-base * 1.15));\n  font-weight: 300;\n  line-height: 1.4;\n\n  @media (min-width: @screen-sm-min) {\n    font-size: (@font-size-base * 1.5);\n  }\n}\n\n\n// Emphasis & misc\n// -------------------------\n\n// Ex: (12px small font / 14px base font) * 100% = about 85%\nsmall,\n.small {\n  font-size: floor((100% * @font-size-small / @font-size-base));\n}\n\nmark,\n.mark {\n  background-color: @state-warning-bg;\n  padding: .2em;\n}\n\n// Alignment\n.text-left           { text-align: left; }\n.text-right          { text-align: right; }\n.text-center         { text-align: center; }\n.text-justify        { text-align: justify; }\n.text-nowrap         { white-space: nowrap; }\n\n// Transformation\n.text-lowercase      { text-transform: lowercase; }\n.text-uppercase      { text-transform: uppercase; }\n.text-capitalize     { text-transform: capitalize; }\n\n// Contextual colors\n.text-muted {\n  color: @text-muted;\n}\n.text-primary {\n  .text-emphasis-variant(@brand-primary);\n}\n.text-success {\n  .text-emphasis-variant(@state-success-text);\n}\n.text-info {\n  .text-emphasis-variant(@state-info-text);\n}\n.text-warning {\n  .text-emphasis-variant(@state-warning-text);\n}\n.text-danger {\n  .text-emphasis-variant(@state-danger-text);\n}\n\n// Contextual backgrounds\n// For now we'll leave these alongside the text classes until v4 when we can\n// safely shift things around (per SemVer rules).\n.bg-primary {\n  // Given the contrast here, this is the only class to have its color inverted\n  // automatically.\n  color: #fff;\n  .bg-variant(@brand-primary);\n}\n.bg-success {\n  .bg-variant(@state-success-bg);\n}\n.bg-info {\n  .bg-variant(@state-info-bg);\n}\n.bg-warning {\n  .bg-variant(@state-warning-bg);\n}\n.bg-danger {\n  .bg-variant(@state-danger-bg);\n}\n\n\n// Page header\n// -------------------------\n\n.page-header {\n  padding-bottom: ((@line-height-computed / 2) - 1);\n  margin: (@line-height-computed * 2) 0 @line-height-computed;\n  border-bottom: 1px solid @page-header-border-color;\n}\n\n\n// Lists\n// -------------------------\n\n// Unordered and Ordered lists\nul,\nol {\n  margin-top: 0;\n  margin-bottom: (@line-height-computed / 2);\n  ul,\n  ol {\n    margin-bottom: 0;\n  }\n}\n\n// List options\n\n// Unstyled keeps list items block level, just removes default browser padding and list-style\n.list-unstyled {\n  padding-left: 0;\n  list-style: none;\n}\n\n// Inline turns list items into inline-block\n.list-inline {\n  .list-unstyled();\n  margin-left: -5px;\n\n  > li {\n    display: inline-block;\n    padding-left: 5px;\n    padding-right: 5px;\n  }\n}\n\n// Description Lists\ndl {\n  margin-top: 0; // Remove browser default\n  margin-bottom: @line-height-computed;\n}\ndt,\ndd {\n  line-height: @line-height-base;\n}\ndt {\n  font-weight: bold;\n}\ndd {\n  margin-left: 0; // Undo browser default\n}\n\n// Horizontal description lists\n//\n// Defaults to being stacked without any of the below styles applied, until the\n// grid breakpoint is reached (default of ~768px).\n\n.dl-horizontal {\n  dd {\n    &:extend(.clearfix all); // Clear the floated `dt` if an empty `dd` is present\n  }\n\n  @media (min-width: @dl-horizontal-breakpoint) {\n    dt {\n      float: left;\n      width: (@dl-horizontal-offset - 20);\n      clear: left;\n      text-align: right;\n      .text-overflow();\n    }\n    dd {\n      margin-left: @dl-horizontal-offset;\n    }\n  }\n}\n\n\n// Misc\n// -------------------------\n\n// Abbreviations and acronyms\nabbr[title],\n// Add data-* attribute to help out our tooltip plugin, per https://github.com/twbs/bootstrap/issues/5257\nabbr[data-original-title] {\n  cursor: help;\n  border-bottom: 1px dotted @abbr-border-color;\n}\n.initialism {\n  font-size: 90%;\n  .text-uppercase();\n}\n\n// Blockquotes\nblockquote {\n  padding: (@line-height-computed / 2) @line-height-computed;\n  margin: 0 0 @line-height-computed;\n  font-size: @blockquote-font-size;\n  border-left: 5px solid @blockquote-border-color;\n\n  p,\n  ul,\n  ol {\n    &:last-child {\n      margin-bottom: 0;\n    }\n  }\n\n  // Note: Deprecated small and .small as of v3.1.0\n  // Context: https://github.com/twbs/bootstrap/issues/11660\n  footer,\n  small,\n  .small {\n    display: block;\n    font-size: 80%; // back to default font-size\n    line-height: @line-height-base;\n    color: @blockquote-small-color;\n\n    &:before {\n      content: '\\2014 \\00A0'; // em dash, nbsp\n    }\n  }\n}\n\n// Opposite alignment of blockquote\n//\n// Heads up: `blockquote.pull-right` has been deprecated as of v3.1.0.\n.blockquote-reverse,\nblockquote.pull-right {\n  padding-right: 15px;\n  padding-left: 0;\n  border-right: 5px solid @blockquote-border-color;\n  border-left: 0;\n  text-align: right;\n\n  // Account for citation\n  footer,\n  small,\n  .small {\n    &:before { content: ''; }\n    &:after {\n      content: '\\00A0 \\2014'; // nbsp, em dash\n    }\n  }\n}\n\n// Addresses\naddress {\n  margin-bottom: @line-height-computed;\n  font-style: normal;\n  line-height: @line-height-base;\n}\n","// Typography\n\n.text-emphasis-variant(@color) {\n  color: @color;\n  a&:hover,\n  a&:focus {\n    color: darken(@color, 10%);\n  }\n}\n","// Contextual backgrounds\n\n.bg-variant(@color) {\n  background-color: @color;\n  a&:hover,\n  a&:focus {\n    background-color: darken(@color, 10%);\n  }\n}\n","// Text overflow\n// Requires inline-block or block for proper styling\n\n.text-overflow() {\n  overflow: hidden;\n  text-overflow: ellipsis;\n  white-space: nowrap;\n}\n","//\n// Code (inline and block)\n// --------------------------------------------------\n\n\n// Inline and block code styles\ncode,\nkbd,\npre,\nsamp {\n  font-family: @font-family-monospace;\n}\n\n// Inline code\ncode {\n  padding: 2px 4px;\n  font-size: 90%;\n  color: @code-color;\n  background-color: @code-bg;\n  border-radius: @border-radius-base;\n}\n\n// User input typically entered via keyboard\nkbd {\n  padding: 2px 4px;\n  font-size: 90%;\n  color: @kbd-color;\n  background-color: @kbd-bg;\n  border-radius: @border-radius-small;\n  box-shadow: inset 0 -1px 0 rgba(0,0,0,.25);\n\n  kbd {\n    padding: 0;\n    font-size: 100%;\n    font-weight: bold;\n    box-shadow: none;\n  }\n}\n\n// Blocks of code\npre {\n  display: block;\n  padding: ((@line-height-computed - 1) / 2);\n  margin: 0 0 (@line-height-computed / 2);\n  font-size: (@font-size-base - 1); // 14px to 13px\n  line-height: @line-height-base;\n  word-break: break-all;\n  word-wrap: break-word;\n  color: @pre-color;\n  background-color: @pre-bg;\n  border: 1px solid @pre-border-color;\n  border-radius: @border-radius-base;\n\n  // Account for some code outputs that place code tags in pre tags\n  code {\n    padding: 0;\n    font-size: inherit;\n    color: inherit;\n    white-space: pre-wrap;\n    background-color: transparent;\n    border-radius: 0;\n  }\n}\n\n// Enable scrollable blocks of code\n.pre-scrollable {\n  max-height: @pre-scrollable-max-height;\n  overflow-y: scroll;\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","// 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:  floor((@gutter / 2));\n  padding-right: ceil((@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:  ceil((@gutter / -2));\n  margin-right: floor((@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","// 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:  ceil((@grid-gutter-width / 2));\n      padding-right: floor((@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","//\n// Tables\n// --------------------------------------------------\n\n\ntable {\n  background-color: @table-bg;\n}\ncaption {\n  padding-top: @table-cell-padding;\n  padding-bottom: @table-cell-padding;\n  color: @text-muted;\n  text-align: left;\n}\nth {\n  text-align: left;\n}\n\n\n// Baseline styles\n\n.table {\n  width: 100%;\n  max-width: 100%;\n  margin-bottom: @line-height-computed;\n  // Cells\n  > thead,\n  > tbody,\n  > tfoot {\n    > tr {\n      > th,\n      > td {\n        padding: @table-cell-padding;\n        line-height: @line-height-base;\n        vertical-align: top;\n        border-top: 1px solid @table-border-color;\n      }\n    }\n  }\n  // Bottom align for column headings\n  > thead > tr > th {\n    vertical-align: bottom;\n    border-bottom: 2px solid @table-border-color;\n  }\n  // Remove top border from thead by default\n  > caption + thead,\n  > colgroup + thead,\n  > thead:first-child {\n    > tr:first-child {\n      > th,\n      > td {\n        border-top: 0;\n      }\n    }\n  }\n  // Account for multiple tbody instances\n  > tbody + tbody {\n    border-top: 2px solid @table-border-color;\n  }\n\n  // Nesting\n  .table {\n    background-color: @body-bg;\n  }\n}\n\n\n// Condensed table w/ half padding\n\n.table-condensed {\n  > thead,\n  > tbody,\n  > tfoot {\n    > tr {\n      > th,\n      > td {\n        padding: @table-condensed-cell-padding;\n      }\n    }\n  }\n}\n\n\n// Bordered version\n//\n// Add borders all around the table and between all the columns.\n\n.table-bordered {\n  border: 1px solid @table-border-color;\n  > thead,\n  > tbody,\n  > tfoot {\n    > tr {\n      > th,\n      > td {\n        border: 1px solid @table-border-color;\n      }\n    }\n  }\n  > thead > tr {\n    > th,\n    > td {\n      border-bottom-width: 2px;\n    }\n  }\n}\n\n\n// Zebra-striping\n//\n// Default zebra-stripe styles (alternating gray and transparent backgrounds)\n\n.table-striped {\n  > tbody > tr:nth-of-type(odd) {\n    background-color: @table-bg-accent;\n  }\n}\n\n\n// Hover effect\n//\n// Placed here since it has to come after the potential zebra striping\n\n.table-hover {\n  > tbody > tr:hover {\n    background-color: @table-bg-hover;\n  }\n}\n\n\n// Table cell sizing\n//\n// Reset default table behavior\n\ntable col[class*=\"col-\"] {\n  position: static; // Prevent border hiding in Firefox and IE9-11 (see https://github.com/twbs/bootstrap/issues/11623)\n  float: none;\n  display: table-column;\n}\ntable {\n  td,\n  th {\n    &[class*=\"col-\"] {\n      position: static; // Prevent border hiding in Firefox and IE9-11 (see https://github.com/twbs/bootstrap/issues/11623)\n      float: none;\n      display: table-cell;\n    }\n  }\n}\n\n\n// Table backgrounds\n//\n// Exact selectors below required to override `.table-striped` and prevent\n// inheritance to nested tables.\n\n// Generate the contextual variants\n.table-row-variant(active; @table-bg-active);\n.table-row-variant(success; @state-success-bg);\n.table-row-variant(info; @state-info-bg);\n.table-row-variant(warning; @state-warning-bg);\n.table-row-variant(danger; @state-danger-bg);\n\n\n// Responsive tables\n//\n// Wrap your tables in `.table-responsive` and we'll make them mobile friendly\n// by enabling horizontal scrolling. Only applies <768px. Everything above that\n// will display normally.\n\n.table-responsive {\n  overflow-x: auto;\n  min-height: 0.01%; // Workaround for IE9 bug (see https://github.com/twbs/bootstrap/issues/14837)\n\n  @media screen and (max-width: @screen-xs-max) {\n    width: 100%;\n    margin-bottom: (@line-height-computed * 0.75);\n    overflow-y: hidden;\n    -ms-overflow-style: -ms-autohiding-scrollbar;\n    border: 1px solid @table-border-color;\n\n    // Tighten up spacing\n    > .table {\n      margin-bottom: 0;\n\n      // Ensure the content doesn't wrap\n      > thead,\n      > tbody,\n      > tfoot {\n        > tr {\n          > th,\n          > td {\n            white-space: nowrap;\n          }\n        }\n      }\n    }\n\n    // Special overrides for the bordered tables\n    > .table-bordered {\n      border: 0;\n\n      // Nuke the appropriate borders so that the parent can handle them\n      > thead,\n      > tbody,\n      > tfoot {\n        > tr {\n          > th:first-child,\n          > td:first-child {\n            border-left: 0;\n          }\n          > th:last-child,\n          > td:last-child {\n            border-right: 0;\n          }\n        }\n      }\n\n      // Only nuke the last row's bottom-border in `tbody` and `tfoot` since\n      // chances are there will be only one `tr` in a `thead` and that would\n      // remove the border altogether.\n      > tbody,\n      > tfoot {\n        > tr:last-child {\n          > th,\n          > td {\n            border-bottom: 0;\n          }\n        }\n      }\n\n    }\n  }\n}\n","// Tables\n\n.table-row-variant(@state; @background) {\n  // Exact selectors below required to override `.table-striped` and prevent\n  // inheritance to nested tables.\n  .table > thead > tr,\n  .table > tbody > tr,\n  .table > tfoot > tr {\n    > td.@{state},\n    > th.@{state},\n    &.@{state} > td,\n    &.@{state} > th {\n      background-color: @background;\n    }\n  }\n\n  // Hover states for `.table-hover`\n  // Note: this is not available for cells or rows within `thead` or `tfoot`.\n  .table-hover > tbody > tr {\n    > td.@{state}:hover,\n    > th.@{state}:hover,\n    &.@{state}:hover > td,\n    &:hover > .@{state},\n    &.@{state}:hover > th {\n      background-color: darken(@background, 5%);\n    }\n  }\n}\n","//\n// Forms\n// --------------------------------------------------\n\n\n// Normalize non-controls\n//\n// Restyle and baseline non-control form elements.\n\nfieldset {\n  padding: 0;\n  margin: 0;\n  border: 0;\n  // Chrome and Firefox set a `min-width: min-content;` on fieldsets,\n  // so we reset that to ensure it behaves more like a standard block element.\n  // See https://github.com/twbs/bootstrap/issues/12359.\n  min-width: 0;\n}\n\nlegend {\n  display: block;\n  width: 100%;\n  padding: 0;\n  margin-bottom: @line-height-computed;\n  font-size: (@font-size-base * 1.5);\n  line-height: inherit;\n  color: @legend-color;\n  border: 0;\n  border-bottom: 1px solid @legend-border-color;\n}\n\nlabel {\n  display: inline-block;\n  max-width: 100%; // Force IE8 to wrap long content (see https://github.com/twbs/bootstrap/issues/13141)\n  margin-bottom: 5px;\n  font-weight: bold;\n}\n\n\n// Normalize form controls\n//\n// While most of our form styles require extra classes, some basic normalization\n// is required to ensure optimum display with or without those classes to better\n// address browser inconsistencies.\n\n// Override content-box in Normalize (* isn't specific enough)\ninput[type=\"search\"] {\n  .box-sizing(border-box);\n}\n\n// Position radios and checkboxes better\ninput[type=\"radio\"],\ninput[type=\"checkbox\"] {\n  margin: 4px 0 0;\n  margin-top: 1px \\9; // IE8-9\n  line-height: normal;\n}\n\ninput[type=\"file\"] {\n  display: block;\n}\n\n// Make range inputs behave like textual form controls\ninput[type=\"range\"] {\n  display: block;\n  width: 100%;\n}\n\n// Make multiple select elements height not fixed\nselect[multiple],\nselect[size] {\n  height: auto;\n}\n\n// Focus for file, radio, and checkbox\ninput[type=\"file\"]:focus,\ninput[type=\"radio\"]:focus,\ninput[type=\"checkbox\"]:focus {\n  .tab-focus();\n}\n\n// Adjust output element\noutput {\n  display: block;\n  padding-top: (@padding-base-vertical + 1);\n  font-size: @font-size-base;\n  line-height: @line-height-base;\n  color: @input-color;\n}\n\n\n// Common form controls\n//\n// Shared size and type resets for form controls. Apply `.form-control` to any\n// of the following form controls:\n//\n// select\n// textarea\n// input[type=\"text\"]\n// input[type=\"password\"]\n// input[type=\"datetime\"]\n// input[type=\"datetime-local\"]\n// input[type=\"date\"]\n// input[type=\"month\"]\n// input[type=\"time\"]\n// input[type=\"week\"]\n// input[type=\"number\"]\n// input[type=\"email\"]\n// input[type=\"url\"]\n// input[type=\"search\"]\n// input[type=\"tel\"]\n// input[type=\"color\"]\n\n.form-control {\n  display: block;\n  width: 100%;\n  height: @input-height-base; // Make inputs at least the height of their button counterpart (base line-height + padding + border)\n  padding: @padding-base-vertical @padding-base-horizontal;\n  font-size: @font-size-base;\n  line-height: @line-height-base;\n  color: @input-color;\n  background-color: @input-bg;\n  background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214\n  border: 1px solid @input-border;\n  border-radius: @input-border-radius; // Note: This has no effect on <select>s in some browsers, due to the limited stylability of <select>s in CSS.\n  .box-shadow(inset 0 1px 1px rgba(0,0,0,.075));\n  .transition(~\"border-color ease-in-out .15s, box-shadow ease-in-out .15s\");\n\n  // Customize the `:focus` state to imitate native WebKit styles.\n  .form-control-focus();\n\n  // Placeholder\n  .placeholder();\n\n  // Unstyle the caret on `<select>`s in IE10+.\n  &::-ms-expand {\n    border: 0;\n    background-color: transparent;\n  }\n\n  // Disabled and read-only inputs\n  //\n  // HTML5 says that controls under a fieldset > legend:first-child won't be\n  // disabled if the fieldset is disabled. Due to implementation difficulty, we\n  // don't honor that edge case; we style them as disabled anyway.\n  &[disabled],\n  &[readonly],\n  fieldset[disabled] & {\n    background-color: @input-bg-disabled;\n    opacity: 1; // iOS fix for unreadable disabled content; see https://github.com/twbs/bootstrap/issues/11655\n  }\n\n  &[disabled],\n  fieldset[disabled] & {\n    cursor: @cursor-disabled;\n  }\n\n  // Reset height for `textarea`s\n  textarea& {\n    height: auto;\n  }\n}\n\n\n// Search inputs in iOS\n//\n// This overrides the extra rounded corners on search inputs in iOS so that our\n// `.form-control` class can properly style them. Note that this cannot simply\n// be added to `.form-control` as it's not specific enough. For details, see\n// https://github.com/twbs/bootstrap/issues/11586.\n\ninput[type=\"search\"] {\n  -webkit-appearance: none;\n}\n\n\n// Special styles for iOS temporal inputs\n//\n// In Mobile Safari, setting `display: block` on temporal inputs causes the\n// text within the input to become vertically misaligned. As a workaround, we\n// set a pixel line-height that matches the given height of the input, but only\n// for Safari. See https://bugs.webkit.org/show_bug.cgi?id=139848\n//\n// Note that as of 9.3, iOS doesn't support `week`.\n\n@media screen and (-webkit-min-device-pixel-ratio: 0) {\n  input[type=\"date\"],\n  input[type=\"time\"],\n  input[type=\"datetime-local\"],\n  input[type=\"month\"] {\n    &.form-control {\n      line-height: @input-height-base;\n    }\n\n    &.input-sm,\n    .input-group-sm & {\n      line-height: @input-height-small;\n    }\n\n    &.input-lg,\n    .input-group-lg & {\n      line-height: @input-height-large;\n    }\n  }\n}\n\n\n// Form groups\n//\n// Designed to help with the organization and spacing of vertical forms. For\n// horizontal forms, use the predefined grid classes.\n\n.form-group {\n  margin-bottom: @form-group-margin-bottom;\n}\n\n\n// Checkboxes and radios\n//\n// Indent the labels to position radios/checkboxes as hanging controls.\n\n.radio,\n.checkbox {\n  position: relative;\n  display: block;\n  margin-top: 10px;\n  margin-bottom: 10px;\n\n  label {\n    min-height: @line-height-computed; // Ensure the input doesn't jump when there is no text\n    padding-left: 20px;\n    margin-bottom: 0;\n    font-weight: normal;\n    cursor: pointer;\n  }\n}\n.radio input[type=\"radio\"],\n.radio-inline input[type=\"radio\"],\n.checkbox input[type=\"checkbox\"],\n.checkbox-inline input[type=\"checkbox\"] {\n  position: absolute;\n  margin-left: -20px;\n  margin-top: 4px \\9;\n}\n\n.radio + .radio,\n.checkbox + .checkbox {\n  margin-top: -5px; // Move up sibling radios or checkboxes for tighter spacing\n}\n\n// Radios and checkboxes on same line\n.radio-inline,\n.checkbox-inline {\n  position: relative;\n  display: inline-block;\n  padding-left: 20px;\n  margin-bottom: 0;\n  vertical-align: middle;\n  font-weight: normal;\n  cursor: pointer;\n}\n.radio-inline + .radio-inline,\n.checkbox-inline + .checkbox-inline {\n  margin-top: 0;\n  margin-left: 10px; // space out consecutive inline controls\n}\n\n// Apply same disabled cursor tweak as for inputs\n// Some special care is needed because <label>s don't inherit their parent's `cursor`.\n//\n// Note: Neither radios nor checkboxes can be readonly.\ninput[type=\"radio\"],\ninput[type=\"checkbox\"] {\n  &[disabled],\n  &.disabled,\n  fieldset[disabled] & {\n    cursor: @cursor-disabled;\n  }\n}\n// These classes are used directly on <label>s\n.radio-inline,\n.checkbox-inline {\n  &.disabled,\n  fieldset[disabled] & {\n    cursor: @cursor-disabled;\n  }\n}\n// These classes are used on elements with <label> descendants\n.radio,\n.checkbox {\n  &.disabled,\n  fieldset[disabled] & {\n    label {\n      cursor: @cursor-disabled;\n    }\n  }\n}\n\n\n// Static form control text\n//\n// Apply class to a `p` element to make any string of text align with labels in\n// a horizontal form layout.\n\n.form-control-static {\n  // Size it appropriately next to real form controls\n  padding-top: (@padding-base-vertical + 1);\n  padding-bottom: (@padding-base-vertical + 1);\n  // Remove default margin from `p`\n  margin-bottom: 0;\n  min-height: (@line-height-computed + @font-size-base);\n\n  &.input-lg,\n  &.input-sm {\n    padding-left: 0;\n    padding-right: 0;\n  }\n}\n\n\n// Form control sizing\n//\n// Build on `.form-control` with modifier classes to decrease or increase the\n// height and font-size of form controls.\n//\n// The `.form-group-* form-control` variations are sadly duplicated to avoid the\n// issue documented in https://github.com/twbs/bootstrap/issues/15074.\n\n.input-sm {\n  .input-size(@input-height-small; @padding-small-vertical; @padding-small-horizontal; @font-size-small; @line-height-small; @input-border-radius-small);\n}\n.form-group-sm {\n  .form-control {\n    height: @input-height-small;\n    padding: @padding-small-vertical @padding-small-horizontal;\n    font-size: @font-size-small;\n    line-height: @line-height-small;\n    border-radius: @input-border-radius-small;\n  }\n  select.form-control {\n    height: @input-height-small;\n    line-height: @input-height-small;\n  }\n  textarea.form-control,\n  select[multiple].form-control {\n    height: auto;\n  }\n  .form-control-static {\n    height: @input-height-small;\n    min-height: (@line-height-computed + @font-size-small);\n    padding: (@padding-small-vertical + 1) @padding-small-horizontal;\n    font-size: @font-size-small;\n    line-height: @line-height-small;\n  }\n}\n\n.input-lg {\n  .input-size(@input-height-large; @padding-large-vertical; @padding-large-horizontal; @font-size-large; @line-height-large; @input-border-radius-large);\n}\n.form-group-lg {\n  .form-control {\n    height: @input-height-large;\n    padding: @padding-large-vertical @padding-large-horizontal;\n    font-size: @font-size-large;\n    line-height: @line-height-large;\n    border-radius: @input-border-radius-large;\n  }\n  select.form-control {\n    height: @input-height-large;\n    line-height: @input-height-large;\n  }\n  textarea.form-control,\n  select[multiple].form-control {\n    height: auto;\n  }\n  .form-control-static {\n    height: @input-height-large;\n    min-height: (@line-height-computed + @font-size-large);\n    padding: (@padding-large-vertical + 1) @padding-large-horizontal;\n    font-size: @font-size-large;\n    line-height: @line-height-large;\n  }\n}\n\n\n// Form control feedback states\n//\n// Apply contextual and semantic states to individual form controls.\n\n.has-feedback {\n  // Enable absolute positioning\n  position: relative;\n\n  // Ensure icons don't overlap text\n  .form-control {\n    padding-right: (@input-height-base * 1.25);\n  }\n}\n// Feedback icon (requires .glyphicon classes)\n.form-control-feedback {\n  position: absolute;\n  top: 0;\n  right: 0;\n  z-index: 2; // Ensure icon is above input groups\n  display: block;\n  width: @input-height-base;\n  height: @input-height-base;\n  line-height: @input-height-base;\n  text-align: center;\n  pointer-events: none;\n}\n.input-lg + .form-control-feedback,\n.input-group-lg + .form-control-feedback,\n.form-group-lg .form-control + .form-control-feedback {\n  width: @input-height-large;\n  height: @input-height-large;\n  line-height: @input-height-large;\n}\n.input-sm + .form-control-feedback,\n.input-group-sm + .form-control-feedback,\n.form-group-sm .form-control + .form-control-feedback {\n  width: @input-height-small;\n  height: @input-height-small;\n  line-height: @input-height-small;\n}\n\n// Feedback states\n.has-success {\n  .form-control-validation(@state-success-text; @state-success-text; @state-success-bg);\n}\n.has-warning {\n  .form-control-validation(@state-warning-text; @state-warning-text; @state-warning-bg);\n}\n.has-error {\n  .form-control-validation(@state-danger-text; @state-danger-text; @state-danger-bg);\n}\n\n// Reposition feedback icon if input has visible label above\n.has-feedback label {\n\n  & ~ .form-control-feedback {\n    top: (@line-height-computed + 5); // Height of the `label` and its margin\n  }\n  &.sr-only ~ .form-control-feedback {\n    top: 0;\n  }\n}\n\n\n// Help text\n//\n// Apply to any element you wish to create light text for placement immediately\n// below a form control. Use for general help, formatting, or instructional text.\n\n.help-block {\n  display: block; // account for any element using help-block\n  margin-top: 5px;\n  margin-bottom: 10px;\n  color: lighten(@text-color, 25%); // lighten the text some for contrast\n}\n\n\n// Inline forms\n//\n// Make forms appear inline(-block) by adding the `.form-inline` class. Inline\n// forms begin stacked on extra small (mobile) devices and then go inline when\n// viewports reach <768px.\n//\n// Requires wrapping inputs and labels with `.form-group` for proper display of\n// default HTML form controls and our custom form controls (e.g., input groups).\n//\n// Heads up! This is mixin-ed into `.navbar-form` in navbars.less.\n\n.form-inline {\n\n  // Kick in the inline\n  @media (min-width: @screen-sm-min) {\n    // Inline-block all the things for \"inline\"\n    .form-group {\n      display: inline-block;\n      margin-bottom: 0;\n      vertical-align: middle;\n    }\n\n    // In navbar-form, allow folks to *not* use `.form-group`\n    .form-control {\n      display: inline-block;\n      width: auto; // Prevent labels from stacking above inputs in `.form-group`\n      vertical-align: middle;\n    }\n\n    // Make static controls behave like regular ones\n    .form-control-static {\n      display: inline-block;\n    }\n\n    .input-group {\n      display: inline-table;\n      vertical-align: middle;\n\n      .input-group-addon,\n      .input-group-btn,\n      .form-control {\n        width: auto;\n      }\n    }\n\n    // Input groups need that 100% width though\n    .input-group > .form-control {\n      width: 100%;\n    }\n\n    .control-label {\n      margin-bottom: 0;\n      vertical-align: middle;\n    }\n\n    // Remove default margin on radios/checkboxes that were used for stacking, and\n    // then undo the floating of radios and checkboxes to match.\n    .radio,\n    .checkbox {\n      display: inline-block;\n      margin-top: 0;\n      margin-bottom: 0;\n      vertical-align: middle;\n\n      label {\n        padding-left: 0;\n      }\n    }\n    .radio input[type=\"radio\"],\n    .checkbox input[type=\"checkbox\"] {\n      position: relative;\n      margin-left: 0;\n    }\n\n    // Re-override the feedback icon.\n    .has-feedback .form-control-feedback {\n      top: 0;\n    }\n  }\n}\n\n\n// Horizontal forms\n//\n// Horizontal forms are built on grid classes and allow you to create forms with\n// labels on the left and inputs on the right.\n\n.form-horizontal {\n\n  // Consistent vertical alignment of radios and checkboxes\n  //\n  // Labels also get some reset styles, but that is scoped to a media query below.\n  .radio,\n  .checkbox,\n  .radio-inline,\n  .checkbox-inline {\n    margin-top: 0;\n    margin-bottom: 0;\n    padding-top: (@padding-base-vertical + 1); // Default padding plus a border\n  }\n  // Account for padding we're adding to ensure the alignment and of help text\n  // and other content below items\n  .radio,\n  .checkbox {\n    min-height: (@line-height-computed + (@padding-base-vertical + 1));\n  }\n\n  // Make form groups behave like rows\n  .form-group {\n    .make-row();\n  }\n\n  // Reset spacing and right align labels, but scope to media queries so that\n  // labels on narrow viewports stack the same as a default form example.\n  @media (min-width: @screen-sm-min) {\n    .control-label {\n      text-align: right;\n      margin-bottom: 0;\n      padding-top: (@padding-base-vertical + 1); // Default padding plus a border\n    }\n  }\n\n  // Validation states\n  //\n  // Reposition the icon because it's now within a grid column and columns have\n  // `position: relative;` on them. Also accounts for the grid gutter padding.\n  .has-feedback .form-control-feedback {\n    right: floor((@grid-gutter-width / 2));\n  }\n\n  // Form group sizes\n  //\n  // Quick utility class for applying `.input-lg` and `.input-sm` styles to the\n  // inputs and labels within a `.form-group`.\n  .form-group-lg {\n    @media (min-width: @screen-sm-min) {\n      .control-label {\n        padding-top: (@padding-large-vertical + 1);\n        font-size: @font-size-large;\n      }\n    }\n  }\n  .form-group-sm {\n    @media (min-width: @screen-sm-min) {\n      .control-label {\n        padding-top: (@padding-small-vertical + 1);\n        font-size: @font-size-small;\n      }\n    }\n  }\n}\n","// Form validation states\n//\n// Used in forms.less to generate the form validation CSS for warnings, errors,\n// and successes.\n\n.form-control-validation(@text-color: #555; @border-color: #ccc; @background-color: #f5f5f5) {\n  // Color the label and help text\n  .help-block,\n  .control-label,\n  .radio,\n  .checkbox,\n  .radio-inline,\n  .checkbox-inline,\n  &.radio label,\n  &.checkbox label,\n  &.radio-inline label,\n  &.checkbox-inline label  {\n    color: @text-color;\n  }\n  // Set the border and box shadow on specific inputs to match\n  .form-control {\n    border-color: @border-color;\n    .box-shadow(inset 0 1px 1px rgba(0,0,0,.075)); // Redeclare so transitions work\n    &:focus {\n      border-color: darken(@border-color, 10%);\n      @shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 6px lighten(@border-color, 20%);\n      .box-shadow(@shadow);\n    }\n  }\n  // Set validation states also for addons\n  .input-group-addon {\n    color: @text-color;\n    border-color: @border-color;\n    background-color: @background-color;\n  }\n  // Optional feedback icon\n  .form-control-feedback {\n    color: @text-color;\n  }\n}\n\n\n// Form control focus state\n//\n// Generate a customized focus state and for any input with the specified color,\n// which defaults to the `@input-border-focus` variable.\n//\n// We highly encourage you to not customize the default value, but instead use\n// this to tweak colors on an as-needed basis. This aesthetic change is based on\n// WebKit's default styles, but applicable to a wider range of browsers. Its\n// usability and accessibility should be taken into account with any change.\n//\n// Example usage: change the default blue border and shadow to white for better\n// contrast against a dark gray background.\n.form-control-focus(@color: @input-border-focus) {\n  @color-rgba: rgba(red(@color), green(@color), blue(@color), .6);\n  &:focus {\n    border-color: @color;\n    outline: 0;\n    .box-shadow(~\"inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px @{color-rgba}\");\n  }\n}\n\n// Form control sizing\n//\n// Relative text size, padding, and border-radii changes for form controls. For\n// horizontal sizing, wrap controls in the predefined grid classes. `<select>`\n// element gets special love because it's special, and that's a fact!\n.input-size(@input-height; @padding-vertical; @padding-horizontal; @font-size; @line-height; @border-radius) {\n  height: @input-height;\n  padding: @padding-vertical @padding-horizontal;\n  font-size: @font-size;\n  line-height: @line-height;\n  border-radius: @border-radius;\n\n  select& {\n    height: @input-height;\n    line-height: @input-height;\n  }\n\n  textarea&,\n  select[multiple]& {\n    height: auto;\n  }\n}\n","//\n// Buttons\n// --------------------------------------------------\n\n\n// Base styles\n// --------------------------------------------------\n\n.btn {\n  display: inline-block;\n  margin-bottom: 0; // For input.btn\n  font-weight: @btn-font-weight;\n  text-align: center;\n  vertical-align: middle;\n  touch-action: manipulation;\n  cursor: pointer;\n  background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214\n  border: 1px solid transparent;\n  white-space: nowrap;\n  .button-size(@padding-base-vertical; @padding-base-horizontal; @font-size-base; @line-height-base; @btn-border-radius-base);\n  .user-select(none);\n\n  &,\n  &:active,\n  &.active {\n    &:focus,\n    &.focus {\n      .tab-focus();\n    }\n  }\n\n  &:hover,\n  &:focus,\n  &.focus {\n    color: @btn-default-color;\n    text-decoration: none;\n  }\n\n  &:active,\n  &.active {\n    outline: 0;\n    background-image: none;\n    .box-shadow(inset 0 3px 5px rgba(0,0,0,.125));\n  }\n\n  &.disabled,\n  &[disabled],\n  fieldset[disabled] & {\n    cursor: @cursor-disabled;\n    .opacity(.65);\n    .box-shadow(none);\n  }\n\n  a& {\n    &.disabled,\n    fieldset[disabled] & {\n      pointer-events: none; // Future-proof disabling of clicks on `<a>` elements\n    }\n  }\n}\n\n\n// Alternate buttons\n// --------------------------------------------------\n\n.btn-default {\n  .button-variant(@btn-default-color; @btn-default-bg; @btn-default-border);\n}\n.btn-primary {\n  .button-variant(@btn-primary-color; @btn-primary-bg; @btn-primary-border);\n}\n// Success appears as green\n.btn-success {\n  .button-variant(@btn-success-color; @btn-success-bg; @btn-success-border);\n}\n// Info appears as blue-green\n.btn-info {\n  .button-variant(@btn-info-color; @btn-info-bg; @btn-info-border);\n}\n// Warning appears as orange\n.btn-warning {\n  .button-variant(@btn-warning-color; @btn-warning-bg; @btn-warning-border);\n}\n// Danger and error appear as red\n.btn-danger {\n  .button-variant(@btn-danger-color; @btn-danger-bg; @btn-danger-border);\n}\n\n\n// Link buttons\n// -------------------------\n\n// Make a button look and behave like a link\n.btn-link {\n  color: @link-color;\n  font-weight: normal;\n  border-radius: 0;\n\n  &,\n  &:active,\n  &.active,\n  &[disabled],\n  fieldset[disabled] & {\n    background-color: transparent;\n    .box-shadow(none);\n  }\n  &,\n  &:hover,\n  &:focus,\n  &:active {\n    border-color: transparent;\n  }\n  &:hover,\n  &:focus {\n    color: @link-hover-color;\n    text-decoration: @link-hover-decoration;\n    background-color: transparent;\n  }\n  &[disabled],\n  fieldset[disabled] & {\n    &:hover,\n    &:focus {\n      color: @btn-link-disabled-color;\n      text-decoration: none;\n    }\n  }\n}\n\n\n// Button Sizes\n// --------------------------------------------------\n\n.btn-lg {\n  // line-height: ensure even-numbered height of button next to large input\n  .button-size(@padding-large-vertical; @padding-large-horizontal; @font-size-large; @line-height-large; @btn-border-radius-large);\n}\n.btn-sm {\n  // line-height: ensure proper height of button next to small input\n  .button-size(@padding-small-vertical; @padding-small-horizontal; @font-size-small; @line-height-small; @btn-border-radius-small);\n}\n.btn-xs {\n  .button-size(@padding-xs-vertical; @padding-xs-horizontal; @font-size-small; @line-height-small; @btn-border-radius-small);\n}\n\n\n// Block button\n// --------------------------------------------------\n\n.btn-block {\n  display: block;\n  width: 100%;\n}\n\n// Vertically space out multiple block buttons\n.btn-block + .btn-block {\n  margin-top: 5px;\n}\n\n// Specificity overrides\ninput[type=\"submit\"],\ninput[type=\"reset\"],\ninput[type=\"button\"] {\n  &.btn-block {\n    width: 100%;\n  }\n}\n","// Button variants\n//\n// Easily pump out default styles, as well as :hover, :focus, :active,\n// and disabled options for all buttons\n\n.button-variant(@color; @background; @border) {\n  color: @color;\n  background-color: @background;\n  border-color: @border;\n\n  &:focus,\n  &.focus {\n    color: @color;\n    background-color: darken(@background, 10%);\n        border-color: darken(@border, 25%);\n  }\n  &:hover {\n    color: @color;\n    background-color: darken(@background, 10%);\n        border-color: darken(@border, 12%);\n  }\n  &:active,\n  &.active,\n  .open > .dropdown-toggle& {\n    color: @color;\n    background-color: darken(@background, 10%);\n        border-color: darken(@border, 12%);\n\n    &:hover,\n    &:focus,\n    &.focus {\n      color: @color;\n      background-color: darken(@background, 17%);\n          border-color: darken(@border, 25%);\n    }\n  }\n  &:active,\n  &.active,\n  .open > .dropdown-toggle& {\n    background-image: none;\n  }\n  &.disabled,\n  &[disabled],\n  fieldset[disabled] & {\n    &:hover,\n    &:focus,\n    &.focus {\n      background-color: @background;\n          border-color: @border;\n    }\n  }\n\n  .badge {\n    color: @background;\n    background-color: @color;\n  }\n}\n\n// Button sizes\n.button-size(@padding-vertical; @padding-horizontal; @font-size; @line-height; @border-radius) {\n  padding: @padding-vertical @padding-horizontal;\n  font-size: @font-size;\n  line-height: @line-height;\n  border-radius: @border-radius;\n}\n","// Opacity\n\n.opacity(@opacity) {\n  opacity: @opacity;\n  // IE8 filter\n  @opacity-ie: (@opacity * 100);\n  filter: ~\"alpha(opacity=@{opacity-ie})\";\n}\n","//\n// Component animations\n// --------------------------------------------------\n\n// Heads up!\n//\n// We don't use the `.opacity()` mixin here since it causes a bug with text\n// fields in IE7-8. Source: https://github.com/twbs/bootstrap/pull/3552.\n\n.fade {\n  opacity: 0;\n  .transition(opacity .15s linear);\n  &.in {\n    opacity: 1;\n  }\n}\n\n.collapse {\n  display: none;\n\n  &.in      { display: block; }\n  tr&.in    { display: table-row; }\n  tbody&.in { display: table-row-group; }\n}\n\n.collapsing {\n  position: relative;\n  height: 0;\n  overflow: hidden;\n  .transition-property(~\"height, visibility\");\n  .transition-duration(.35s);\n  .transition-timing-function(ease);\n}\n","//\n// Dropdown menus\n// --------------------------------------------------\n\n\n// Dropdown arrow/caret\n.caret {\n  display: inline-block;\n  width: 0;\n  height: 0;\n  margin-left: 2px;\n  vertical-align: middle;\n  border-top:   @caret-width-base dashed;\n  border-top:   @caret-width-base solid ~\"\\9\"; // IE8\n  border-right: @caret-width-base solid transparent;\n  border-left:  @caret-width-base solid transparent;\n}\n\n// The dropdown wrapper (div)\n.dropup,\n.dropdown {\n  position: relative;\n}\n\n// Prevent the focus on the dropdown toggle when closing dropdowns\n.dropdown-toggle:focus {\n  outline: 0;\n}\n\n// The dropdown menu (ul)\n.dropdown-menu {\n  position: absolute;\n  top: 100%;\n  left: 0;\n  z-index: @zindex-dropdown;\n  display: none; // none by default, but block on \"open\" of the menu\n  float: left;\n  min-width: 160px;\n  padding: 5px 0;\n  margin: 2px 0 0; // override default ul\n  list-style: none;\n  font-size: @font-size-base;\n  text-align: left; // Ensures proper alignment if parent has it changed (e.g., modal footer)\n  background-color: @dropdown-bg;\n  border: 1px solid @dropdown-fallback-border; // IE8 fallback\n  border: 1px solid @dropdown-border;\n  border-radius: @border-radius-base;\n  .box-shadow(0 6px 12px rgba(0,0,0,.175));\n  background-clip: padding-box;\n\n  // Aligns the dropdown menu to right\n  //\n  // Deprecated as of 3.1.0 in favor of `.dropdown-menu-[dir]`\n  &.pull-right {\n    right: 0;\n    left: auto;\n  }\n\n  // Dividers (basically an hr) within the dropdown\n  .divider {\n    .nav-divider(@dropdown-divider-bg);\n  }\n\n  // Links within the dropdown menu\n  > li > a {\n    display: block;\n    padding: 3px 20px;\n    clear: both;\n    font-weight: normal;\n    line-height: @line-height-base;\n    color: @dropdown-link-color;\n    white-space: nowrap; // prevent links from randomly breaking onto new lines\n  }\n}\n\n// Hover/Focus state\n.dropdown-menu > li > a {\n  &:hover,\n  &:focus {\n    text-decoration: none;\n    color: @dropdown-link-hover-color;\n    background-color: @dropdown-link-hover-bg;\n  }\n}\n\n// Active state\n.dropdown-menu > .active > a {\n  &,\n  &:hover,\n  &:focus {\n    color: @dropdown-link-active-color;\n    text-decoration: none;\n    outline: 0;\n    background-color: @dropdown-link-active-bg;\n  }\n}\n\n// Disabled state\n//\n// Gray out text and ensure the hover/focus state remains gray\n\n.dropdown-menu > .disabled > a {\n  &,\n  &:hover,\n  &:focus {\n    color: @dropdown-link-disabled-color;\n  }\n\n  // Nuke hover/focus effects\n  &:hover,\n  &:focus {\n    text-decoration: none;\n    background-color: transparent;\n    background-image: none; // Remove CSS gradient\n    .reset-filter();\n    cursor: @cursor-disabled;\n  }\n}\n\n// Open state for the dropdown\n.open {\n  // Show the menu\n  > .dropdown-menu {\n    display: block;\n  }\n\n  // Remove the outline when :focus is triggered\n  > a {\n    outline: 0;\n  }\n}\n\n// Menu positioning\n//\n// Add extra class to `.dropdown-menu` to flip the alignment of the dropdown\n// menu with the parent.\n.dropdown-menu-right {\n  left: auto; // Reset the default from `.dropdown-menu`\n  right: 0;\n}\n// With v3, we enabled auto-flipping if you have a dropdown within a right\n// aligned nav component. To enable the undoing of that, we provide an override\n// to restore the default dropdown menu alignment.\n//\n// This is only for left-aligning a dropdown menu within a `.navbar-right` or\n// `.pull-right` nav component.\n.dropdown-menu-left {\n  left: 0;\n  right: auto;\n}\n\n// Dropdown section headers\n.dropdown-header {\n  display: block;\n  padding: 3px 20px;\n  font-size: @font-size-small;\n  line-height: @line-height-base;\n  color: @dropdown-header-color;\n  white-space: nowrap; // as with > li > a\n}\n\n// Backdrop to catch body clicks on mobile, etc.\n.dropdown-backdrop {\n  position: fixed;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  top: 0;\n  z-index: (@zindex-dropdown - 10);\n}\n\n// Right aligned dropdowns\n.pull-right > .dropdown-menu {\n  right: 0;\n  left: auto;\n}\n\n// Allow for dropdowns to go bottom up (aka, dropup-menu)\n//\n// Just add .dropup after the standard .dropdown class and you're set, bro.\n// TODO: abstract this so that the navbar fixed styles are not placed here?\n\n.dropup,\n.navbar-fixed-bottom .dropdown {\n  // Reverse the caret\n  .caret {\n    border-top: 0;\n    border-bottom: @caret-width-base dashed;\n    border-bottom: @caret-width-base solid ~\"\\9\"; // IE8\n    content: \"\";\n  }\n  // Different positioning for bottom up menu\n  .dropdown-menu {\n    top: auto;\n    bottom: 100%;\n    margin-bottom: 2px;\n  }\n}\n\n\n// Component alignment\n//\n// Reiterate per navbar.less and the modified component alignment there.\n\n@media (min-width: @grid-float-breakpoint) {\n  .navbar-right {\n    .dropdown-menu {\n      .dropdown-menu-right();\n    }\n    // Necessary for overrides of the default right aligned menu.\n    // Will remove come v4 in all likelihood.\n    .dropdown-menu-left {\n      .dropdown-menu-left();\n    }\n  }\n}\n","// Horizontal dividers\n//\n// Dividers (basically an hr) within dropdowns and nav lists\n\n.nav-divider(@color: #e5e5e5) {\n  height: 1px;\n  margin: ((@line-height-computed / 2) - 1) 0;\n  overflow: hidden;\n  background-color: @color;\n}\n","// Reset filters for IE\n//\n// When you need to remove a gradient background, do not forget to use this to reset\n// the IE filter for IE9 and below.\n\n.reset-filter() {\n  filter: e(%(\"progid:DXImageTransform.Microsoft.gradient(enabled = false)\"));\n}\n","//\n// Button groups\n// --------------------------------------------------\n\n// Make the div behave like a button\n.btn-group,\n.btn-group-vertical {\n  position: relative;\n  display: inline-block;\n  vertical-align: middle; // match .btn alignment given font-size hack above\n  > .btn {\n    position: relative;\n    float: left;\n    // Bring the \"active\" button to the front\n    &:hover,\n    &:focus,\n    &:active,\n    &.active {\n      z-index: 2;\n    }\n  }\n}\n\n// Prevent double borders when buttons are next to each other\n.btn-group {\n  .btn + .btn,\n  .btn + .btn-group,\n  .btn-group + .btn,\n  .btn-group + .btn-group {\n    margin-left: -1px;\n  }\n}\n\n// Optional: Group multiple button groups together for a toolbar\n.btn-toolbar {\n  margin-left: -5px; // Offset the first child's margin\n  &:extend(.clearfix all);\n\n  .btn,\n  .btn-group,\n  .input-group {\n    float: left;\n  }\n  > .btn,\n  > .btn-group,\n  > .input-group {\n    margin-left: 5px;\n  }\n}\n\n.btn-group > .btn:not(:first-child):not(:last-child):not(.dropdown-toggle) {\n  border-radius: 0;\n}\n\n// Set corners individual because sometimes a single button can be in a .btn-group and we need :first-child and :last-child to both match\n.btn-group > .btn:first-child {\n  margin-left: 0;\n  &:not(:last-child):not(.dropdown-toggle) {\n    .border-right-radius(0);\n  }\n}\n// Need .dropdown-toggle since :last-child doesn't apply, given that a .dropdown-menu is used immediately after it\n.btn-group > .btn:last-child:not(:first-child),\n.btn-group > .dropdown-toggle:not(:first-child) {\n  .border-left-radius(0);\n}\n\n// Custom edits for including btn-groups within btn-groups (useful for including dropdown buttons within a btn-group)\n.btn-group > .btn-group {\n  float: left;\n}\n.btn-group > .btn-group:not(:first-child):not(:last-child) > .btn {\n  border-radius: 0;\n}\n.btn-group > .btn-group:first-child:not(:last-child) {\n  > .btn:last-child,\n  > .dropdown-toggle {\n    .border-right-radius(0);\n  }\n}\n.btn-group > .btn-group:last-child:not(:first-child) > .btn:first-child {\n  .border-left-radius(0);\n}\n\n// On active and open, don't show outline\n.btn-group .dropdown-toggle:active,\n.btn-group.open .dropdown-toggle {\n  outline: 0;\n}\n\n\n// Sizing\n//\n// Remix the default button sizing classes into new ones for easier manipulation.\n\n.btn-group-xs > .btn { &:extend(.btn-xs); }\n.btn-group-sm > .btn { &:extend(.btn-sm); }\n.btn-group-lg > .btn { &:extend(.btn-lg); }\n\n\n// Split button dropdowns\n// ----------------------\n\n// Give the line between buttons some depth\n.btn-group > .btn + .dropdown-toggle {\n  padding-left: 8px;\n  padding-right: 8px;\n}\n.btn-group > .btn-lg + .dropdown-toggle {\n  padding-left: 12px;\n  padding-right: 12px;\n}\n\n// The clickable button for toggling the menu\n// Remove the gradient and set the same inset shadow as the :active state\n.btn-group.open .dropdown-toggle {\n  .box-shadow(inset 0 3px 5px rgba(0,0,0,.125));\n\n  // Show no shadow for `.btn-link` since it has no other button styles.\n  &.btn-link {\n    .box-shadow(none);\n  }\n}\n\n\n// Reposition the caret\n.btn .caret {\n  margin-left: 0;\n}\n// Carets in other button sizes\n.btn-lg .caret {\n  border-width: @caret-width-large @caret-width-large 0;\n  border-bottom-width: 0;\n}\n// Upside down carets for .dropup\n.dropup .btn-lg .caret {\n  border-width: 0 @caret-width-large @caret-width-large;\n}\n\n\n// Vertical button groups\n// ----------------------\n\n.btn-group-vertical {\n  > .btn,\n  > .btn-group,\n  > .btn-group > .btn {\n    display: block;\n    float: none;\n    width: 100%;\n    max-width: 100%;\n  }\n\n  // Clear floats so dropdown menus can be properly placed\n  > .btn-group {\n    &:extend(.clearfix all);\n    > .btn {\n      float: none;\n    }\n  }\n\n  > .btn + .btn,\n  > .btn + .btn-group,\n  > .btn-group + .btn,\n  > .btn-group + .btn-group {\n    margin-top: -1px;\n    margin-left: 0;\n  }\n}\n\n.btn-group-vertical > .btn {\n  &:not(:first-child):not(:last-child) {\n    border-radius: 0;\n  }\n  &:first-child:not(:last-child) {\n    .border-top-radius(@btn-border-radius-base);\n    .border-bottom-radius(0);\n  }\n  &:last-child:not(:first-child) {\n    .border-top-radius(0);\n    .border-bottom-radius(@btn-border-radius-base);\n  }\n}\n.btn-group-vertical > .btn-group:not(:first-child):not(:last-child) > .btn {\n  border-radius: 0;\n}\n.btn-group-vertical > .btn-group:first-child:not(:last-child) {\n  > .btn:last-child,\n  > .dropdown-toggle {\n    .border-bottom-radius(0);\n  }\n}\n.btn-group-vertical > .btn-group:last-child:not(:first-child) > .btn:first-child {\n  .border-top-radius(0);\n}\n\n\n// Justified button groups\n// ----------------------\n\n.btn-group-justified {\n  display: table;\n  width: 100%;\n  table-layout: fixed;\n  border-collapse: separate;\n  > .btn,\n  > .btn-group {\n    float: none;\n    display: table-cell;\n    width: 1%;\n  }\n  > .btn-group .btn {\n    width: 100%;\n  }\n\n  > .btn-group .dropdown-menu {\n    left: auto;\n  }\n}\n\n\n// Checkbox and radio options\n//\n// In order to support the browser's form validation feedback, powered by the\n// `required` attribute, we have to \"hide\" the inputs via `clip`. We cannot use\n// `display: none;` or `visibility: hidden;` as that also hides the popover.\n// Simply visually hiding the inputs via `opacity` would leave them clickable in\n// certain cases which is prevented by using `clip` and `pointer-events`.\n// This way, we ensure a DOM element is visible to position the popover from.\n//\n// See https://github.com/twbs/bootstrap/pull/12794 and\n// https://github.com/twbs/bootstrap/pull/14559 for more information.\n\n[data-toggle=\"buttons\"] {\n  > .btn,\n  > .btn-group > .btn {\n    input[type=\"radio\"],\n    input[type=\"checkbox\"] {\n      position: absolute;\n      clip: rect(0,0,0,0);\n      pointer-events: none;\n    }\n  }\n}\n","// Single side border-radius\n\n.border-top-radius(@radius) {\n  border-top-right-radius: @radius;\n   border-top-left-radius: @radius;\n}\n.border-right-radius(@radius) {\n  border-bottom-right-radius: @radius;\n     border-top-right-radius: @radius;\n}\n.border-bottom-radius(@radius) {\n  border-bottom-right-radius: @radius;\n   border-bottom-left-radius: @radius;\n}\n.border-left-radius(@radius) {\n  border-bottom-left-radius: @radius;\n     border-top-left-radius: @radius;\n}\n","//\n// Input groups\n// --------------------------------------------------\n\n// Base styles\n// -------------------------\n.input-group {\n  position: relative; // For dropdowns\n  display: table;\n  border-collapse: separate; // prevent input groups from inheriting border styles from table cells when placed within a table\n\n  // Undo padding and float of grid classes\n  &[class*=\"col-\"] {\n    float: none;\n    padding-left: 0;\n    padding-right: 0;\n  }\n\n  .form-control {\n    // Ensure that the input is always above the *appended* addon button for\n    // proper border colors.\n    position: relative;\n    z-index: 2;\n\n    // IE9 fubars the placeholder attribute in text inputs and the arrows on\n    // select elements in input groups. To fix it, we float the input. Details:\n    // https://github.com/twbs/bootstrap/issues/11561#issuecomment-28936855\n    float: left;\n\n    width: 100%;\n    margin-bottom: 0;\n\n    &:focus {\n      z-index: 3;\n    }\n  }\n}\n\n// Sizing options\n//\n// Remix the default form control sizing classes into new ones for easier\n// manipulation.\n\n.input-group-lg > .form-control,\n.input-group-lg > .input-group-addon,\n.input-group-lg > .input-group-btn > .btn {\n  .input-lg();\n}\n.input-group-sm > .form-control,\n.input-group-sm > .input-group-addon,\n.input-group-sm > .input-group-btn > .btn {\n  .input-sm();\n}\n\n\n// Display as table-cell\n// -------------------------\n.input-group-addon,\n.input-group-btn,\n.input-group .form-control {\n  display: table-cell;\n\n  &:not(:first-child):not(:last-child) {\n    border-radius: 0;\n  }\n}\n// Addon and addon wrapper for buttons\n.input-group-addon,\n.input-group-btn {\n  width: 1%;\n  white-space: nowrap;\n  vertical-align: middle; // Match the inputs\n}\n\n// Text input groups\n// -------------------------\n.input-group-addon {\n  padding: @padding-base-vertical @padding-base-horizontal;\n  font-size: @font-size-base;\n  font-weight: normal;\n  line-height: 1;\n  color: @input-color;\n  text-align: center;\n  background-color: @input-group-addon-bg;\n  border: 1px solid @input-group-addon-border-color;\n  border-radius: @input-border-radius;\n\n  // Sizing\n  &.input-sm {\n    padding: @padding-small-vertical @padding-small-horizontal;\n    font-size: @font-size-small;\n    border-radius: @input-border-radius-small;\n  }\n  &.input-lg {\n    padding: @padding-large-vertical @padding-large-horizontal;\n    font-size: @font-size-large;\n    border-radius: @input-border-radius-large;\n  }\n\n  // Nuke default margins from checkboxes and radios to vertically center within.\n  input[type=\"radio\"],\n  input[type=\"checkbox\"] {\n    margin-top: 0;\n  }\n}\n\n// Reset rounded corners\n.input-group .form-control:first-child,\n.input-group-addon:first-child,\n.input-group-btn:first-child > .btn,\n.input-group-btn:first-child > .btn-group > .btn,\n.input-group-btn:first-child > .dropdown-toggle,\n.input-group-btn:last-child > .btn:not(:last-child):not(.dropdown-toggle),\n.input-group-btn:last-child > .btn-group:not(:last-child) > .btn {\n  .border-right-radius(0);\n}\n.input-group-addon:first-child {\n  border-right: 0;\n}\n.input-group .form-control:last-child,\n.input-group-addon:last-child,\n.input-group-btn:last-child > .btn,\n.input-group-btn:last-child > .btn-group > .btn,\n.input-group-btn:last-child > .dropdown-toggle,\n.input-group-btn:first-child > .btn:not(:first-child),\n.input-group-btn:first-child > .btn-group:not(:first-child) > .btn {\n  .border-left-radius(0);\n}\n.input-group-addon:last-child {\n  border-left: 0;\n}\n\n// Button input groups\n// -------------------------\n.input-group-btn {\n  position: relative;\n  // Jankily prevent input button groups from wrapping with `white-space` and\n  // `font-size` in combination with `inline-block` on buttons.\n  font-size: 0;\n  white-space: nowrap;\n\n  // Negative margin for spacing, position for bringing hovered/focused/actived\n  // element above the siblings.\n  > .btn {\n    position: relative;\n    + .btn {\n      margin-left: -1px;\n    }\n    // Bring the \"active\" button to the front\n    &:hover,\n    &:focus,\n    &:active {\n      z-index: 2;\n    }\n  }\n\n  // Negative margin to only have a 1px border between the two\n  &:first-child {\n    > .btn,\n    > .btn-group {\n      margin-right: -1px;\n    }\n  }\n  &:last-child {\n    > .btn,\n    > .btn-group {\n      z-index: 2;\n      margin-left: -1px;\n    }\n  }\n}\n","//\n// Navs\n// --------------------------------------------------\n\n\n// Base class\n// --------------------------------------------------\n\n.nav {\n  margin-bottom: 0;\n  padding-left: 0; // Override default ul/ol\n  list-style: none;\n  &:extend(.clearfix all);\n\n  > li {\n    position: relative;\n    display: block;\n\n    > a {\n      position: relative;\n      display: block;\n      padding: @nav-link-padding;\n      &:hover,\n      &:focus {\n        text-decoration: none;\n        background-color: @nav-link-hover-bg;\n      }\n    }\n\n    // Disabled state sets text to gray and nukes hover/tab effects\n    &.disabled > a {\n      color: @nav-disabled-link-color;\n\n      &:hover,\n      &:focus {\n        color: @nav-disabled-link-hover-color;\n        text-decoration: none;\n        background-color: transparent;\n        cursor: @cursor-disabled;\n      }\n    }\n  }\n\n  // Open dropdowns\n  .open > a {\n    &,\n    &:hover,\n    &:focus {\n      background-color: @nav-link-hover-bg;\n      border-color: @link-color;\n    }\n  }\n\n  // Nav dividers (deprecated with v3.0.1)\n  //\n  // This should have been removed in v3 with the dropping of `.nav-list`, but\n  // we missed it. We don't currently support this anywhere, but in the interest\n  // of maintaining backward compatibility in case you use it, it's deprecated.\n  .nav-divider {\n    .nav-divider();\n  }\n\n  // Prevent IE8 from misplacing imgs\n  //\n  // See https://github.com/h5bp/html5-boilerplate/issues/984#issuecomment-3985989\n  > li > a > img {\n    max-width: none;\n  }\n}\n\n\n// Tabs\n// -------------------------\n\n// Give the tabs something to sit on\n.nav-tabs {\n  border-bottom: 1px solid @nav-tabs-border-color;\n  > li {\n    float: left;\n    // Make the list-items overlay the bottom border\n    margin-bottom: -1px;\n\n    // Actual tabs (as links)\n    > a {\n      margin-right: 2px;\n      line-height: @line-height-base;\n      border: 1px solid transparent;\n      border-radius: @border-radius-base @border-radius-base 0 0;\n      &:hover {\n        border-color: @nav-tabs-link-hover-border-color @nav-tabs-link-hover-border-color @nav-tabs-border-color;\n      }\n    }\n\n    // Active state, and its :hover to override normal :hover\n    &.active > a {\n      &,\n      &:hover,\n      &:focus {\n        color: @nav-tabs-active-link-hover-color;\n        background-color: @nav-tabs-active-link-hover-bg;\n        border: 1px solid @nav-tabs-active-link-hover-border-color;\n        border-bottom-color: transparent;\n        cursor: default;\n      }\n    }\n  }\n  // pulling this in mainly for less shorthand\n  &.nav-justified {\n    .nav-justified();\n    .nav-tabs-justified();\n  }\n}\n\n\n// Pills\n// -------------------------\n.nav-pills {\n  > li {\n    float: left;\n\n    // Links rendered as pills\n    > a {\n      border-radius: @nav-pills-border-radius;\n    }\n    + li {\n      margin-left: 2px;\n    }\n\n    // Active state\n    &.active > a {\n      &,\n      &:hover,\n      &:focus {\n        color: @nav-pills-active-link-hover-color;\n        background-color: @nav-pills-active-link-hover-bg;\n      }\n    }\n  }\n}\n\n\n// Stacked pills\n.nav-stacked {\n  > li {\n    float: none;\n    + li {\n      margin-top: 2px;\n      margin-left: 0; // no need for this gap between nav items\n    }\n  }\n}\n\n\n// Nav variations\n// --------------------------------------------------\n\n// Justified nav links\n// -------------------------\n\n.nav-justified {\n  width: 100%;\n\n  > li {\n    float: none;\n    > a {\n      text-align: center;\n      margin-bottom: 5px;\n    }\n  }\n\n  > .dropdown .dropdown-menu {\n    top: auto;\n    left: auto;\n  }\n\n  @media (min-width: @screen-sm-min) {\n    > li {\n      display: table-cell;\n      width: 1%;\n      > a {\n        margin-bottom: 0;\n      }\n    }\n  }\n}\n\n// Move borders to anchors instead of bottom of list\n//\n// Mixin for adding on top the shared `.nav-justified` styles for our tabs\n.nav-tabs-justified {\n  border-bottom: 0;\n\n  > li > a {\n    // Override margin from .nav-tabs\n    margin-right: 0;\n    border-radius: @border-radius-base;\n  }\n\n  > .active > a,\n  > .active > a:hover,\n  > .active > a:focus {\n    border: 1px solid @nav-tabs-justified-link-border-color;\n  }\n\n  @media (min-width: @screen-sm-min) {\n    > li > a {\n      border-bottom: 1px solid @nav-tabs-justified-link-border-color;\n      border-radius: @border-radius-base @border-radius-base 0 0;\n    }\n    > .active > a,\n    > .active > a:hover,\n    > .active > a:focus {\n      border-bottom-color: @nav-tabs-justified-active-link-border-color;\n    }\n  }\n}\n\n\n// Tabbable tabs\n// -------------------------\n\n// Hide tabbable panes to start, show them when `.active`\n.tab-content {\n  > .tab-pane {\n    display: none;\n  }\n  > .active {\n    display: block;\n  }\n}\n\n\n// Dropdowns\n// -------------------------\n\n// Specific dropdowns\n.nav-tabs .dropdown-menu {\n  // make dropdown border overlap tab border\n  margin-top: -1px;\n  // Remove the top rounded corners here since there is a hard edge above the menu\n  .border-top-radius(0);\n}\n","//\n// Navbars\n// --------------------------------------------------\n\n\n// Wrapper and base class\n//\n// Provide a static navbar from which we expand to create full-width, fixed, and\n// other navbar variations.\n\n.navbar {\n  position: relative;\n  min-height: @navbar-height; // Ensure a navbar always shows (e.g., without a .navbar-brand in collapsed mode)\n  margin-bottom: @navbar-margin-bottom;\n  border: 1px solid transparent;\n\n  // Prevent floats from breaking the navbar\n  &:extend(.clearfix all);\n\n  @media (min-width: @grid-float-breakpoint) {\n    border-radius: @navbar-border-radius;\n  }\n}\n\n\n// Navbar heading\n//\n// Groups `.navbar-brand` and `.navbar-toggle` into a single component for easy\n// styling of responsive aspects.\n\n.navbar-header {\n  &:extend(.clearfix all);\n\n  @media (min-width: @grid-float-breakpoint) {\n    float: left;\n  }\n}\n\n\n// Navbar collapse (body)\n//\n// Group your navbar content into this for easy collapsing and expanding across\n// various device sizes. By default, this content is collapsed when <768px, but\n// will expand past that for a horizontal display.\n//\n// To start (on mobile devices) the navbar links, forms, and buttons are stacked\n// vertically and include a `max-height` to overflow in case you have too much\n// content for the user's viewport.\n\n.navbar-collapse {\n  overflow-x: visible;\n  padding-right: @navbar-padding-horizontal;\n  padding-left:  @navbar-padding-horizontal;\n  border-top: 1px solid transparent;\n  box-shadow: inset 0 1px 0 rgba(255,255,255,.1);\n  &:extend(.clearfix all);\n  -webkit-overflow-scrolling: touch;\n\n  &.in {\n    overflow-y: auto;\n  }\n\n  @media (min-width: @grid-float-breakpoint) {\n    width: auto;\n    border-top: 0;\n    box-shadow: none;\n\n    &.collapse {\n      display: block !important;\n      height: auto !important;\n      padding-bottom: 0; // Override default setting\n      overflow: visible !important;\n    }\n\n    &.in {\n      overflow-y: visible;\n    }\n\n    // Undo the collapse side padding for navbars with containers to ensure\n    // alignment of right-aligned contents.\n    .navbar-fixed-top &,\n    .navbar-static-top &,\n    .navbar-fixed-bottom & {\n      padding-left: 0;\n      padding-right: 0;\n    }\n  }\n}\n\n.navbar-fixed-top,\n.navbar-fixed-bottom {\n  .navbar-collapse {\n    max-height: @navbar-collapse-max-height;\n\n    @media (max-device-width: @screen-xs-min) and (orientation: landscape) {\n      max-height: 200px;\n    }\n  }\n}\n\n\n// Both navbar header and collapse\n//\n// When a container is present, change the behavior of the header and collapse.\n\n.container,\n.container-fluid {\n  > .navbar-header,\n  > .navbar-collapse {\n    margin-right: -@navbar-padding-horizontal;\n    margin-left:  -@navbar-padding-horizontal;\n\n    @media (min-width: @grid-float-breakpoint) {\n      margin-right: 0;\n      margin-left:  0;\n    }\n  }\n}\n\n\n//\n// Navbar alignment options\n//\n// Display the navbar across the entirety of the page or fixed it to the top or\n// bottom of the page.\n\n// Static top (unfixed, but 100% wide) navbar\n.navbar-static-top {\n  z-index: @zindex-navbar;\n  border-width: 0 0 1px;\n\n  @media (min-width: @grid-float-breakpoint) {\n    border-radius: 0;\n  }\n}\n\n// Fix the top/bottom navbars when screen real estate supports it\n.navbar-fixed-top,\n.navbar-fixed-bottom {\n  position: fixed;\n  right: 0;\n  left: 0;\n  z-index: @zindex-navbar-fixed;\n\n  // Undo the rounded corners\n  @media (min-width: @grid-float-breakpoint) {\n    border-radius: 0;\n  }\n}\n.navbar-fixed-top {\n  top: 0;\n  border-width: 0 0 1px;\n}\n.navbar-fixed-bottom {\n  bottom: 0;\n  margin-bottom: 0; // override .navbar defaults\n  border-width: 1px 0 0;\n}\n\n\n// Brand/project name\n\n.navbar-brand {\n  float: left;\n  padding: @navbar-padding-vertical @navbar-padding-horizontal;\n  font-size: @font-size-large;\n  line-height: @line-height-computed;\n  height: @navbar-height;\n\n  &:hover,\n  &:focus {\n    text-decoration: none;\n  }\n\n  > img {\n    display: block;\n  }\n\n  @media (min-width: @grid-float-breakpoint) {\n    .navbar > .container &,\n    .navbar > .container-fluid & {\n      margin-left: -@navbar-padding-horizontal;\n    }\n  }\n}\n\n\n// Navbar toggle\n//\n// Custom button for toggling the `.navbar-collapse`, powered by the collapse\n// JavaScript plugin.\n\n.navbar-toggle {\n  position: relative;\n  float: right;\n  margin-right: @navbar-padding-horizontal;\n  padding: 9px 10px;\n  .navbar-vertical-align(34px);\n  background-color: transparent;\n  background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214\n  border: 1px solid transparent;\n  border-radius: @border-radius-base;\n\n  // We remove the `outline` here, but later compensate by attaching `:hover`\n  // styles to `:focus`.\n  &:focus {\n    outline: 0;\n  }\n\n  // Bars\n  .icon-bar {\n    display: block;\n    width: 22px;\n    height: 2px;\n    border-radius: 1px;\n  }\n  .icon-bar + .icon-bar {\n    margin-top: 4px;\n  }\n\n  @media (min-width: @grid-float-breakpoint) {\n    display: none;\n  }\n}\n\n\n// Navbar nav links\n//\n// Builds on top of the `.nav` components with its own modifier class to make\n// the nav the full height of the horizontal nav (above 768px).\n\n.navbar-nav {\n  margin: (@navbar-padding-vertical / 2) -@navbar-padding-horizontal;\n\n  > li > a {\n    padding-top:    10px;\n    padding-bottom: 10px;\n    line-height: @line-height-computed;\n  }\n\n  @media (max-width: @grid-float-breakpoint-max) {\n    // Dropdowns get custom display when collapsed\n    .open .dropdown-menu {\n      position: static;\n      float: none;\n      width: auto;\n      margin-top: 0;\n      background-color: transparent;\n      border: 0;\n      box-shadow: none;\n      > li > a,\n      .dropdown-header {\n        padding: 5px 15px 5px 25px;\n      }\n      > li > a {\n        line-height: @line-height-computed;\n        &:hover,\n        &:focus {\n          background-image: none;\n        }\n      }\n    }\n  }\n\n  // Uncollapse the nav\n  @media (min-width: @grid-float-breakpoint) {\n    float: left;\n    margin: 0;\n\n    > li {\n      float: left;\n      > a {\n        padding-top:    @navbar-padding-vertical;\n        padding-bottom: @navbar-padding-vertical;\n      }\n    }\n  }\n}\n\n\n// Navbar form\n//\n// Extension of the `.form-inline` with some extra flavor for optimum display in\n// our navbars.\n\n.navbar-form {\n  margin-left: -@navbar-padding-horizontal;\n  margin-right: -@navbar-padding-horizontal;\n  padding: 10px @navbar-padding-horizontal;\n  border-top: 1px solid transparent;\n  border-bottom: 1px solid transparent;\n  @shadow: inset 0 1px 0 rgba(255,255,255,.1), 0 1px 0 rgba(255,255,255,.1);\n  .box-shadow(@shadow);\n\n  // Mixin behavior for optimum display\n  .form-inline();\n\n  .form-group {\n    @media (max-width: @grid-float-breakpoint-max) {\n      margin-bottom: 5px;\n\n      &:last-child {\n        margin-bottom: 0;\n      }\n    }\n  }\n\n  // Vertically center in expanded, horizontal navbar\n  .navbar-vertical-align(@input-height-base);\n\n  // Undo 100% width for pull classes\n  @media (min-width: @grid-float-breakpoint) {\n    width: auto;\n    border: 0;\n    margin-left: 0;\n    margin-right: 0;\n    padding-top: 0;\n    padding-bottom: 0;\n    .box-shadow(none);\n  }\n}\n\n\n// Dropdown menus\n\n// Menu position and menu carets\n.navbar-nav > li > .dropdown-menu {\n  margin-top: 0;\n  .border-top-radius(0);\n}\n// Menu position and menu caret support for dropups via extra dropup class\n.navbar-fixed-bottom .navbar-nav > li > .dropdown-menu {\n  margin-bottom: 0;\n  .border-top-radius(@navbar-border-radius);\n  .border-bottom-radius(0);\n}\n\n\n// Buttons in navbars\n//\n// Vertically center a button within a navbar (when *not* in a form).\n\n.navbar-btn {\n  .navbar-vertical-align(@input-height-base);\n\n  &.btn-sm {\n    .navbar-vertical-align(@input-height-small);\n  }\n  &.btn-xs {\n    .navbar-vertical-align(22);\n  }\n}\n\n\n// Text in navbars\n//\n// Add a class to make any element properly align itself vertically within the navbars.\n\n.navbar-text {\n  .navbar-vertical-align(@line-height-computed);\n\n  @media (min-width: @grid-float-breakpoint) {\n    float: left;\n    margin-left: @navbar-padding-horizontal;\n    margin-right: @navbar-padding-horizontal;\n  }\n}\n\n\n// Component alignment\n//\n// Repurpose the pull utilities as their own navbar utilities to avoid specificity\n// issues with parents and chaining. Only do this when the navbar is uncollapsed\n// though so that navbar contents properly stack and align in mobile.\n//\n// Declared after the navbar components to ensure more specificity on the margins.\n\n@media (min-width: @grid-float-breakpoint) {\n  .navbar-left  { .pull-left(); }\n  .navbar-right {\n    .pull-right();\n    margin-right: -@navbar-padding-horizontal;\n\n    ~ .navbar-right {\n      margin-right: 0;\n    }\n  }\n}\n\n\n// Alternate navbars\n// --------------------------------------------------\n\n// Default navbar\n.navbar-default {\n  background-color: @navbar-default-bg;\n  border-color: @navbar-default-border;\n\n  .navbar-brand {\n    color: @navbar-default-brand-color;\n    &:hover,\n    &:focus {\n      color: @navbar-default-brand-hover-color;\n      background-color: @navbar-default-brand-hover-bg;\n    }\n  }\n\n  .navbar-text {\n    color: @navbar-default-color;\n  }\n\n  .navbar-nav {\n    > li > a {\n      color: @navbar-default-link-color;\n\n      &:hover,\n      &:focus {\n        color: @navbar-default-link-hover-color;\n        background-color: @navbar-default-link-hover-bg;\n      }\n    }\n    > .active > a {\n      &,\n      &:hover,\n      &:focus {\n        color: @navbar-default-link-active-color;\n        background-color: @navbar-default-link-active-bg;\n      }\n    }\n    > .disabled > a {\n      &,\n      &:hover,\n      &:focus {\n        color: @navbar-default-link-disabled-color;\n        background-color: @navbar-default-link-disabled-bg;\n      }\n    }\n  }\n\n  .navbar-toggle {\n    border-color: @navbar-default-toggle-border-color;\n    &:hover,\n    &:focus {\n      background-color: @navbar-default-toggle-hover-bg;\n    }\n    .icon-bar {\n      background-color: @navbar-default-toggle-icon-bar-bg;\n    }\n  }\n\n  .navbar-collapse,\n  .navbar-form {\n    border-color: @navbar-default-border;\n  }\n\n  // Dropdown menu items\n  .navbar-nav {\n    // Remove background color from open dropdown\n    > .open > a {\n      &,\n      &:hover,\n      &:focus {\n        background-color: @navbar-default-link-active-bg;\n        color: @navbar-default-link-active-color;\n      }\n    }\n\n    @media (max-width: @grid-float-breakpoint-max) {\n      // Dropdowns get custom display when collapsed\n      .open .dropdown-menu {\n        > li > a {\n          color: @navbar-default-link-color;\n          &:hover,\n          &:focus {\n            color: @navbar-default-link-hover-color;\n            background-color: @navbar-default-link-hover-bg;\n          }\n        }\n        > .active > a {\n          &,\n          &:hover,\n          &:focus {\n            color: @navbar-default-link-active-color;\n            background-color: @navbar-default-link-active-bg;\n          }\n        }\n        > .disabled > a {\n          &,\n          &:hover,\n          &:focus {\n            color: @navbar-default-link-disabled-color;\n            background-color: @navbar-default-link-disabled-bg;\n          }\n        }\n      }\n    }\n  }\n\n\n  // Links in navbars\n  //\n  // Add a class to ensure links outside the navbar nav are colored correctly.\n\n  .navbar-link {\n    color: @navbar-default-link-color;\n    &:hover {\n      color: @navbar-default-link-hover-color;\n    }\n  }\n\n  .btn-link {\n    color: @navbar-default-link-color;\n    &:hover,\n    &:focus {\n      color: @navbar-default-link-hover-color;\n    }\n    &[disabled],\n    fieldset[disabled] & {\n      &:hover,\n      &:focus {\n        color: @navbar-default-link-disabled-color;\n      }\n    }\n  }\n}\n\n// Inverse navbar\n\n.navbar-inverse {\n  background-color: @navbar-inverse-bg;\n  border-color: @navbar-inverse-border;\n\n  .navbar-brand {\n    color: @navbar-inverse-brand-color;\n    &:hover,\n    &:focus {\n      color: @navbar-inverse-brand-hover-color;\n      background-color: @navbar-inverse-brand-hover-bg;\n    }\n  }\n\n  .navbar-text {\n    color: @navbar-inverse-color;\n  }\n\n  .navbar-nav {\n    > li > a {\n      color: @navbar-inverse-link-color;\n\n      &:hover,\n      &:focus {\n        color: @navbar-inverse-link-hover-color;\n        background-color: @navbar-inverse-link-hover-bg;\n      }\n    }\n    > .active > a {\n      &,\n      &:hover,\n      &:focus {\n        color: @navbar-inverse-link-active-color;\n        background-color: @navbar-inverse-link-active-bg;\n      }\n    }\n    > .disabled > a {\n      &,\n      &:hover,\n      &:focus {\n        color: @navbar-inverse-link-disabled-color;\n        background-color: @navbar-inverse-link-disabled-bg;\n      }\n    }\n  }\n\n  // Darken the responsive nav toggle\n  .navbar-toggle {\n    border-color: @navbar-inverse-toggle-border-color;\n    &:hover,\n    &:focus {\n      background-color: @navbar-inverse-toggle-hover-bg;\n    }\n    .icon-bar {\n      background-color: @navbar-inverse-toggle-icon-bar-bg;\n    }\n  }\n\n  .navbar-collapse,\n  .navbar-form {\n    border-color: darken(@navbar-inverse-bg, 7%);\n  }\n\n  // Dropdowns\n  .navbar-nav {\n    > .open > a {\n      &,\n      &:hover,\n      &:focus {\n        background-color: @navbar-inverse-link-active-bg;\n        color: @navbar-inverse-link-active-color;\n      }\n    }\n\n    @media (max-width: @grid-float-breakpoint-max) {\n      // Dropdowns get custom display\n      .open .dropdown-menu {\n        > .dropdown-header {\n          border-color: @navbar-inverse-border;\n        }\n        .divider {\n          background-color: @navbar-inverse-border;\n        }\n        > li > a {\n          color: @navbar-inverse-link-color;\n          &:hover,\n          &:focus {\n            color: @navbar-inverse-link-hover-color;\n            background-color: @navbar-inverse-link-hover-bg;\n          }\n        }\n        > .active > a {\n          &,\n          &:hover,\n          &:focus {\n            color: @navbar-inverse-link-active-color;\n            background-color: @navbar-inverse-link-active-bg;\n          }\n        }\n        > .disabled > a {\n          &,\n          &:hover,\n          &:focus {\n            color: @navbar-inverse-link-disabled-color;\n            background-color: @navbar-inverse-link-disabled-bg;\n          }\n        }\n      }\n    }\n  }\n\n  .navbar-link {\n    color: @navbar-inverse-link-color;\n    &:hover {\n      color: @navbar-inverse-link-hover-color;\n    }\n  }\n\n  .btn-link {\n    color: @navbar-inverse-link-color;\n    &:hover,\n    &:focus {\n      color: @navbar-inverse-link-hover-color;\n    }\n    &[disabled],\n    fieldset[disabled] & {\n      &:hover,\n      &:focus {\n        color: @navbar-inverse-link-disabled-color;\n      }\n    }\n  }\n}\n","// Navbar vertical align\n//\n// Vertically center elements in the navbar.\n// Example: an element has a height of 30px, so write out `.navbar-vertical-align(30px);` to calculate the appropriate top margin.\n\n.navbar-vertical-align(@element-height) {\n  margin-top: ((@navbar-height - @element-height) / 2);\n  margin-bottom: ((@navbar-height - @element-height) / 2);\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}\n\n\n// For Affix plugin\n// -------------------------\n\n.affix {\n  position: fixed;\n}\n","//\n// Breadcrumbs\n// --------------------------------------------------\n\n\n.breadcrumb {\n  padding: @breadcrumb-padding-vertical @breadcrumb-padding-horizontal;\n  margin-bottom: @line-height-computed;\n  list-style: none;\n  background-color: @breadcrumb-bg;\n  border-radius: @border-radius-base;\n\n  > li {\n    display: inline-block;\n\n    + li:before {\n      content: \"@{breadcrumb-separator}\\00a0\"; // Unicode space added since inline-block means non-collapsing white-space\n      padding: 0 5px;\n      color: @breadcrumb-color;\n    }\n  }\n\n  > .active {\n    color: @breadcrumb-active-color;\n  }\n}\n","//\n// Pagination (multiple pages)\n// --------------------------------------------------\n.pagination {\n  display: inline-block;\n  padding-left: 0;\n  margin: @line-height-computed 0;\n  border-radius: @border-radius-base;\n\n  > li {\n    display: inline; // Remove list-style and block-level defaults\n    > a,\n    > span {\n      position: relative;\n      float: left; // Collapse white-space\n      padding: @padding-base-vertical @padding-base-horizontal;\n      line-height: @line-height-base;\n      text-decoration: none;\n      color: @pagination-color;\n      background-color: @pagination-bg;\n      border: 1px solid @pagination-border;\n      margin-left: -1px;\n    }\n    &:first-child {\n      > a,\n      > span {\n        margin-left: 0;\n        .border-left-radius(@border-radius-base);\n      }\n    }\n    &:last-child {\n      > a,\n      > span {\n        .border-right-radius(@border-radius-base);\n      }\n    }\n  }\n\n  > li > a,\n  > li > span {\n    &:hover,\n    &:focus {\n      z-index: 2;\n      color: @pagination-hover-color;\n      background-color: @pagination-hover-bg;\n      border-color: @pagination-hover-border;\n    }\n  }\n\n  > .active > a,\n  > .active > span {\n    &,\n    &:hover,\n    &:focus {\n      z-index: 3;\n      color: @pagination-active-color;\n      background-color: @pagination-active-bg;\n      border-color: @pagination-active-border;\n      cursor: default;\n    }\n  }\n\n  > .disabled {\n    > span,\n    > span:hover,\n    > span:focus,\n    > a,\n    > a:hover,\n    > a:focus {\n      color: @pagination-disabled-color;\n      background-color: @pagination-disabled-bg;\n      border-color: @pagination-disabled-border;\n      cursor: @cursor-disabled;\n    }\n  }\n}\n\n// Sizing\n// --------------------------------------------------\n\n// Large\n.pagination-lg {\n  .pagination-size(@padding-large-vertical; @padding-large-horizontal; @font-size-large; @line-height-large; @border-radius-large);\n}\n\n// Small\n.pagination-sm {\n  .pagination-size(@padding-small-vertical; @padding-small-horizontal; @font-size-small; @line-height-small; @border-radius-small);\n}\n","// Pagination\n\n.pagination-size(@padding-vertical; @padding-horizontal; @font-size; @line-height; @border-radius) {\n  > li {\n    > a,\n    > span {\n      padding: @padding-vertical @padding-horizontal;\n      font-size: @font-size;\n      line-height: @line-height;\n    }\n    &:first-child {\n      > a,\n      > span {\n        .border-left-radius(@border-radius);\n      }\n    }\n    &:last-child {\n      > a,\n      > span {\n        .border-right-radius(@border-radius);\n      }\n    }\n  }\n}\n","//\n// Pager pagination\n// --------------------------------------------------\n\n\n.pager {\n  padding-left: 0;\n  margin: @line-height-computed 0;\n  list-style: none;\n  text-align: center;\n  &:extend(.clearfix all);\n  li {\n    display: inline;\n    > a,\n    > span {\n      display: inline-block;\n      padding: 5px 14px;\n      background-color: @pager-bg;\n      border: 1px solid @pager-border;\n      border-radius: @pager-border-radius;\n    }\n\n    > a:hover,\n    > a:focus {\n      text-decoration: none;\n      background-color: @pager-hover-bg;\n    }\n  }\n\n  .next {\n    > a,\n    > span {\n      float: right;\n    }\n  }\n\n  .previous {\n    > a,\n    > span {\n      float: left;\n    }\n  }\n\n  .disabled {\n    > a,\n    > a:hover,\n    > a:focus,\n    > span {\n      color: @pager-disabled-color;\n      background-color: @pager-bg;\n      cursor: @cursor-disabled;\n    }\n  }\n}\n","//\n// Labels\n// --------------------------------------------------\n\n.label {\n  display: inline;\n  padding: .2em .6em .3em;\n  font-size: 75%;\n  font-weight: bold;\n  line-height: 1;\n  color: @label-color;\n  text-align: center;\n  white-space: nowrap;\n  vertical-align: baseline;\n  border-radius: .25em;\n\n  // Add hover effects, but only for links\n  a& {\n    &:hover,\n    &:focus {\n      color: @label-link-hover-color;\n      text-decoration: none;\n      cursor: pointer;\n    }\n  }\n\n  // Empty labels collapse automatically (not available in IE8)\n  &:empty {\n    display: none;\n  }\n\n  // Quick fix for labels in buttons\n  .btn & {\n    position: relative;\n    top: -1px;\n  }\n}\n\n// Colors\n// Contextual variations (linked labels get darker on :hover)\n\n.label-default {\n  .label-variant(@label-default-bg);\n}\n\n.label-primary {\n  .label-variant(@label-primary-bg);\n}\n\n.label-success {\n  .label-variant(@label-success-bg);\n}\n\n.label-info {\n  .label-variant(@label-info-bg);\n}\n\n.label-warning {\n  .label-variant(@label-warning-bg);\n}\n\n.label-danger {\n  .label-variant(@label-danger-bg);\n}\n","// Labels\n\n.label-variant(@color) {\n  background-color: @color;\n\n  &[href] {\n    &:hover,\n    &:focus {\n      background-color: darken(@color, 10%);\n    }\n  }\n}\n","//\n// Badges\n// --------------------------------------------------\n\n\n// Base class\n.badge {\n  display: inline-block;\n  min-width: 10px;\n  padding: 3px 7px;\n  font-size: @font-size-small;\n  font-weight: @badge-font-weight;\n  color: @badge-color;\n  line-height: @badge-line-height;\n  vertical-align: middle;\n  white-space: nowrap;\n  text-align: center;\n  background-color: @badge-bg;\n  border-radius: @badge-border-radius;\n\n  // Empty badges collapse automatically (not available in IE8)\n  &:empty {\n    display: none;\n  }\n\n  // Quick fix for badges in buttons\n  .btn & {\n    position: relative;\n    top: -1px;\n  }\n\n  .btn-xs &,\n  .btn-group-xs > .btn & {\n    top: 0;\n    padding: 1px 5px;\n  }\n\n  // Hover state, but only for links\n  a& {\n    &:hover,\n    &:focus {\n      color: @badge-link-hover-color;\n      text-decoration: none;\n      cursor: pointer;\n    }\n  }\n\n  // Account for badges in navs\n  .list-group-item.active > &,\n  .nav-pills > .active > a > & {\n    color: @badge-active-color;\n    background-color: @badge-active-bg;\n  }\n\n  .list-group-item > & {\n    float: right;\n  }\n\n  .list-group-item > & + & {\n    margin-right: 5px;\n  }\n\n  .nav-pills > li > a > & {\n    margin-left: 3px;\n  }\n}\n","//\n// Jumbotron\n// --------------------------------------------------\n\n\n.jumbotron {\n  padding-top:    @jumbotron-padding;\n  padding-bottom: @jumbotron-padding;\n  margin-bottom: @jumbotron-padding;\n  color: @jumbotron-color;\n  background-color: @jumbotron-bg;\n\n  h1,\n  .h1 {\n    color: @jumbotron-heading-color;\n  }\n\n  p {\n    margin-bottom: (@jumbotron-padding / 2);\n    font-size: @jumbotron-font-size;\n    font-weight: 200;\n  }\n\n  > hr {\n    border-top-color: darken(@jumbotron-bg, 10%);\n  }\n\n  .container &,\n  .container-fluid & {\n    border-radius: @border-radius-large; // Only round corners at higher resolutions if contained in a container\n    padding-left:  (@grid-gutter-width / 2);\n    padding-right: (@grid-gutter-width / 2);\n  }\n\n  .container {\n    max-width: 100%;\n  }\n\n  @media screen and (min-width: @screen-sm-min) {\n    padding-top:    (@jumbotron-padding * 1.6);\n    padding-bottom: (@jumbotron-padding * 1.6);\n\n    .container &,\n    .container-fluid & {\n      padding-left:  (@jumbotron-padding * 2);\n      padding-right: (@jumbotron-padding * 2);\n    }\n\n    h1,\n    .h1 {\n      font-size: @jumbotron-heading-font-size;\n    }\n  }\n}\n","//\n// Thumbnails\n// --------------------------------------------------\n\n\n// Mixin and adjust the regular image class\n.thumbnail {\n  display: block;\n  padding: @thumbnail-padding;\n  margin-bottom: @line-height-computed;\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(border .2s ease-in-out);\n\n  > img,\n  a > img {\n    &:extend(.img-responsive);\n    margin-left: auto;\n    margin-right: auto;\n  }\n\n  // Add a hover state for linked versions only\n  a&:hover,\n  a&:focus,\n  a&.active {\n    border-color: @link-color;\n  }\n\n  // Image captions\n  .caption {\n    padding: @thumbnail-caption-padding;\n    color: @thumbnail-caption-color;\n  }\n}\n","//\n// Alerts\n// --------------------------------------------------\n\n\n// Base styles\n// -------------------------\n\n.alert {\n  padding: @alert-padding;\n  margin-bottom: @line-height-computed;\n  border: 1px solid transparent;\n  border-radius: @alert-border-radius;\n\n  // Headings for larger alerts\n  h4 {\n    margin-top: 0;\n    // Specified for the h4 to prevent conflicts of changing @headings-color\n    color: inherit;\n  }\n\n  // Provide class for links that match alerts\n  .alert-link {\n    font-weight: @alert-link-font-weight;\n  }\n\n  // Improve alignment and spacing of inner content\n  > p,\n  > ul {\n    margin-bottom: 0;\n  }\n\n  > p + p {\n    margin-top: 5px;\n  }\n}\n\n// Dismissible alerts\n//\n// Expand the right padding and account for the close button's positioning.\n\n.alert-dismissable, // The misspelled .alert-dismissable was deprecated in 3.2.0.\n.alert-dismissible {\n  padding-right: (@alert-padding + 20);\n\n  // Adjust close link position\n  .close {\n    position: relative;\n    top: -2px;\n    right: -21px;\n    color: inherit;\n  }\n}\n\n// Alternate styles\n//\n// Generate contextual modifier classes for colorizing the alert.\n\n.alert-success {\n  .alert-variant(@alert-success-bg; @alert-success-border; @alert-success-text);\n}\n\n.alert-info {\n  .alert-variant(@alert-info-bg; @alert-info-border; @alert-info-text);\n}\n\n.alert-warning {\n  .alert-variant(@alert-warning-bg; @alert-warning-border; @alert-warning-text);\n}\n\n.alert-danger {\n  .alert-variant(@alert-danger-bg; @alert-danger-border; @alert-danger-text);\n}\n","// Alerts\n\n.alert-variant(@background; @border; @text-color) {\n  background-color: @background;\n  border-color: @border;\n  color: @text-color;\n\n  hr {\n    border-top-color: darken(@border, 5%);\n  }\n  .alert-link {\n    color: darken(@text-color, 10%);\n  }\n}\n","//\n// Progress bars\n// --------------------------------------------------\n\n\n// Bar animations\n// -------------------------\n\n// WebKit\n@-webkit-keyframes progress-bar-stripes {\n  from  { background-position: 40px 0; }\n  to    { background-position: 0 0; }\n}\n\n// Spec and IE10+\n@keyframes progress-bar-stripes {\n  from  { background-position: 40px 0; }\n  to    { background-position: 0 0; }\n}\n\n\n// Bar itself\n// -------------------------\n\n// Outer container\n.progress {\n  overflow: hidden;\n  height: @line-height-computed;\n  margin-bottom: @line-height-computed;\n  background-color: @progress-bg;\n  border-radius: @progress-border-radius;\n  .box-shadow(inset 0 1px 2px rgba(0,0,0,.1));\n}\n\n// Bar of progress\n.progress-bar {\n  float: left;\n  width: 0%;\n  height: 100%;\n  font-size: @font-size-small;\n  line-height: @line-height-computed;\n  color: @progress-bar-color;\n  text-align: center;\n  background-color: @progress-bar-bg;\n  .box-shadow(inset 0 -1px 0 rgba(0,0,0,.15));\n  .transition(width .6s ease);\n}\n\n// Striped bars\n//\n// `.progress-striped .progress-bar` is deprecated as of v3.2.0 in favor of the\n// `.progress-bar-striped` class, which you just add to an existing\n// `.progress-bar`.\n.progress-striped .progress-bar,\n.progress-bar-striped {\n  #gradient > .striped();\n  background-size: 40px 40px;\n}\n\n// Call animation for the active one\n//\n// `.progress.active .progress-bar` is deprecated as of v3.2.0 in favor of the\n// `.progress-bar.active` approach.\n.progress.active .progress-bar,\n.progress-bar.active {\n  .animation(progress-bar-stripes 2s linear infinite);\n}\n\n\n// Variations\n// -------------------------\n\n.progress-bar-success {\n  .progress-bar-variant(@progress-bar-success-bg);\n}\n\n.progress-bar-info {\n  .progress-bar-variant(@progress-bar-info-bg);\n}\n\n.progress-bar-warning {\n  .progress-bar-variant(@progress-bar-warning-bg);\n}\n\n.progress-bar-danger {\n  .progress-bar-variant(@progress-bar-danger-bg);\n}\n","// Gradients\n\n#gradient {\n\n  // Horizontal gradient, from left to right\n  //\n  // Creates two color stops, start and end, by specifying a color and position for each color stop.\n  // Color stops are not available in IE9 and below.\n  .horizontal(@start-color: #555; @end-color: #333; @start-percent: 0%; @end-percent: 100%) {\n    background-image: -webkit-linear-gradient(left, @start-color @start-percent, @end-color @end-percent); // Safari 5.1-6, Chrome 10+\n    background-image: -o-linear-gradient(left, @start-color @start-percent, @end-color @end-percent); // Opera 12\n    background-image: linear-gradient(to right, @start-color @start-percent, @end-color @end-percent); // Standard, IE10, Firefox 16+, Opera 12.10+, Safari 7+, Chrome 26+\n    background-repeat: repeat-x;\n    filter: e(%(\"progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=1)\",argb(@start-color),argb(@end-color))); // IE9 and down\n  }\n\n  // Vertical gradient, from top to bottom\n  //\n  // Creates two color stops, start and end, by specifying a color and position for each color stop.\n  // Color stops are not available in IE9 and below.\n  .vertical(@start-color: #555; @end-color: #333; @start-percent: 0%; @end-percent: 100%) {\n    background-image: -webkit-linear-gradient(top, @start-color @start-percent, @end-color @end-percent);  // Safari 5.1-6, Chrome 10+\n    background-image: -o-linear-gradient(top, @start-color @start-percent, @end-color @end-percent);  // Opera 12\n    background-image: linear-gradient(to bottom, @start-color @start-percent, @end-color @end-percent); // Standard, IE10, Firefox 16+, Opera 12.10+, Safari 7+, Chrome 26+\n    background-repeat: repeat-x;\n    filter: e(%(\"progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=0)\",argb(@start-color),argb(@end-color))); // IE9 and down\n  }\n\n  .directional(@start-color: #555; @end-color: #333; @deg: 45deg) {\n    background-repeat: repeat-x;\n    background-image: -webkit-linear-gradient(@deg, @start-color, @end-color); // Safari 5.1-6, Chrome 10+\n    background-image: -o-linear-gradient(@deg, @start-color, @end-color); // Opera 12\n    background-image: linear-gradient(@deg, @start-color, @end-color); // Standard, IE10, Firefox 16+, Opera 12.10+, Safari 7+, Chrome 26+\n  }\n  .horizontal-three-colors(@start-color: #00b3ee; @mid-color: #7a43b6; @color-stop: 50%; @end-color: #c3325f) {\n    background-image: -webkit-linear-gradient(left, @start-color, @mid-color @color-stop, @end-color);\n    background-image: -o-linear-gradient(left, @start-color, @mid-color @color-stop, @end-color);\n    background-image: linear-gradient(to right, @start-color, @mid-color @color-stop, @end-color);\n    background-repeat: no-repeat;\n    filter: e(%(\"progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=1)\",argb(@start-color),argb(@end-color))); // IE9 and down, gets no color-stop at all for proper fallback\n  }\n  .vertical-three-colors(@start-color: #00b3ee; @mid-color: #7a43b6; @color-stop: 50%; @end-color: #c3325f) {\n    background-image: -webkit-linear-gradient(@start-color, @mid-color @color-stop, @end-color);\n    background-image: -o-linear-gradient(@start-color, @mid-color @color-stop, @end-color);\n    background-image: linear-gradient(@start-color, @mid-color @color-stop, @end-color);\n    background-repeat: no-repeat;\n    filter: e(%(\"progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=0)\",argb(@start-color),argb(@end-color))); // IE9 and down, gets no color-stop at all for proper fallback\n  }\n  .radial(@inner-color: #555; @outer-color: #333) {\n    background-image: -webkit-radial-gradient(circle, @inner-color, @outer-color);\n    background-image: radial-gradient(circle, @inner-color, @outer-color);\n    background-repeat: no-repeat;\n  }\n  .striped(@color: rgba(255,255,255,.15); @angle: 45deg) {\n    background-image: -webkit-linear-gradient(@angle, @color 25%, transparent 25%, transparent 50%, @color 50%, @color 75%, transparent 75%, transparent);\n    background-image: -o-linear-gradient(@angle, @color 25%, transparent 25%, transparent 50%, @color 50%, @color 75%, transparent 75%, transparent);\n    background-image: linear-gradient(@angle, @color 25%, transparent 25%, transparent 50%, @color 50%, @color 75%, transparent 75%, transparent);\n  }\n}\n","// Progress bars\n\n.progress-bar-variant(@color) {\n  background-color: @color;\n\n  // Deprecated parent class requirement as of v3.2.0\n  .progress-striped & {\n    #gradient > .striped();\n  }\n}\n",".media {\n  // Proper spacing between instances of .media\n  margin-top: 15px;\n\n  &:first-child {\n    margin-top: 0;\n  }\n}\n\n.media,\n.media-body {\n  zoom: 1;\n  overflow: hidden;\n}\n\n.media-body {\n  width: 10000px;\n}\n\n.media-object {\n  display: block;\n\n  // Fix collapse in webkit from max-width: 100% and display: table-cell.\n  &.img-thumbnail {\n    max-width: none;\n  }\n}\n\n.media-right,\n.media > .pull-right {\n  padding-left: 10px;\n}\n\n.media-left,\n.media > .pull-left {\n  padding-right: 10px;\n}\n\n.media-left,\n.media-right,\n.media-body {\n  display: table-cell;\n  vertical-align: top;\n}\n\n.media-middle {\n  vertical-align: middle;\n}\n\n.media-bottom {\n  vertical-align: bottom;\n}\n\n// Reset margins on headings for tighter default spacing\n.media-heading {\n  margin-top: 0;\n  margin-bottom: 5px;\n}\n\n// Media list variation\n//\n// Undo default ul/ol styles\n.media-list {\n  padding-left: 0;\n  list-style: none;\n}\n","//\n// List groups\n// --------------------------------------------------\n\n\n// Base class\n//\n// Easily usable on <ul>, <ol>, or <div>.\n\n.list-group {\n  // No need to set list-style: none; since .list-group-item is block level\n  margin-bottom: 20px;\n  padding-left: 0; // reset padding because ul and ol\n}\n\n\n// Individual list items\n//\n// Use on `li`s or `div`s within the `.list-group` parent.\n\n.list-group-item {\n  position: relative;\n  display: block;\n  padding: 10px 15px;\n  // Place the border on the list items and negative margin up for better styling\n  margin-bottom: -1px;\n  background-color: @list-group-bg;\n  border: 1px solid @list-group-border;\n\n  // Round the first and last items\n  &:first-child {\n    .border-top-radius(@list-group-border-radius);\n  }\n  &:last-child {\n    margin-bottom: 0;\n    .border-bottom-radius(@list-group-border-radius);\n  }\n}\n\n\n// Interactive list items\n//\n// Use anchor or button elements instead of `li`s or `div`s to create interactive items.\n// Includes an extra `.active` modifier class for showing selected items.\n\na.list-group-item,\nbutton.list-group-item {\n  color: @list-group-link-color;\n\n  .list-group-item-heading {\n    color: @list-group-link-heading-color;\n  }\n\n  // Hover state\n  &:hover,\n  &:focus {\n    text-decoration: none;\n    color: @list-group-link-hover-color;\n    background-color: @list-group-hover-bg;\n  }\n}\n\nbutton.list-group-item {\n  width: 100%;\n  text-align: left;\n}\n\n.list-group-item {\n  // Disabled state\n  &.disabled,\n  &.disabled:hover,\n  &.disabled:focus {\n    background-color: @list-group-disabled-bg;\n    color: @list-group-disabled-color;\n    cursor: @cursor-disabled;\n\n    // Force color to inherit for custom content\n    .list-group-item-heading {\n      color: inherit;\n    }\n    .list-group-item-text {\n      color: @list-group-disabled-text-color;\n    }\n  }\n\n  // Active class on item itself, not parent\n  &.active,\n  &.active:hover,\n  &.active:focus {\n    z-index: 2; // Place active items above their siblings for proper border styling\n    color: @list-group-active-color;\n    background-color: @list-group-active-bg;\n    border-color: @list-group-active-border;\n\n    // Force color to inherit for custom content\n    .list-group-item-heading,\n    .list-group-item-heading > small,\n    .list-group-item-heading > .small {\n      color: inherit;\n    }\n    .list-group-item-text {\n      color: @list-group-active-text-color;\n    }\n  }\n}\n\n\n// Contextual variants\n//\n// Add modifier classes to change text and background color on individual items.\n// Organizationally, this must come after the `:hover` states.\n\n.list-group-item-variant(success; @state-success-bg; @state-success-text);\n.list-group-item-variant(info; @state-info-bg; @state-info-text);\n.list-group-item-variant(warning; @state-warning-bg; @state-warning-text);\n.list-group-item-variant(danger; @state-danger-bg; @state-danger-text);\n\n\n// Custom content options\n//\n// Extra classes for creating well-formatted content within `.list-group-item`s.\n\n.list-group-item-heading {\n  margin-top: 0;\n  margin-bottom: 5px;\n}\n.list-group-item-text {\n  margin-bottom: 0;\n  line-height: 1.3;\n}\n","// List Groups\n\n.list-group-item-variant(@state; @background; @color) {\n  .list-group-item-@{state} {\n    color: @color;\n    background-color: @background;\n\n    a&,\n    button& {\n      color: @color;\n\n      .list-group-item-heading {\n        color: inherit;\n      }\n\n      &:hover,\n      &:focus {\n        color: @color;\n        background-color: darken(@background, 5%);\n      }\n      &.active,\n      &.active:hover,\n      &.active:focus {\n        color: #fff;\n        background-color: @color;\n        border-color: @color;\n      }\n    }\n  }\n}\n","//\n// Panels\n// --------------------------------------------------\n\n\n// Base class\n.panel {\n  margin-bottom: @line-height-computed;\n  background-color: @panel-bg;\n  border: 1px solid transparent;\n  border-radius: @panel-border-radius;\n  .box-shadow(0 1px 1px rgba(0,0,0,.05));\n}\n\n// Panel contents\n.panel-body {\n  padding: @panel-body-padding;\n  &:extend(.clearfix all);\n}\n\n// Optional heading\n.panel-heading {\n  padding: @panel-heading-padding;\n  border-bottom: 1px solid transparent;\n  .border-top-radius((@panel-border-radius - 1));\n\n  > .dropdown .dropdown-toggle {\n    color: inherit;\n  }\n}\n\n// Within heading, strip any `h*` tag of its default margins for spacing.\n.panel-title {\n  margin-top: 0;\n  margin-bottom: 0;\n  font-size: ceil((@font-size-base * 1.125));\n  color: inherit;\n\n  > a,\n  > small,\n  > .small,\n  > small > a,\n  > .small > a {\n    color: inherit;\n  }\n}\n\n// Optional footer (stays gray in every modifier class)\n.panel-footer {\n  padding: @panel-footer-padding;\n  background-color: @panel-footer-bg;\n  border-top: 1px solid @panel-inner-border;\n  .border-bottom-radius((@panel-border-radius - 1));\n}\n\n\n// List groups in panels\n//\n// By default, space out list group content from panel headings to account for\n// any kind of custom content between the two.\n\n.panel {\n  > .list-group,\n  > .panel-collapse > .list-group {\n    margin-bottom: 0;\n\n    .list-group-item {\n      border-width: 1px 0;\n      border-radius: 0;\n    }\n\n    // Add border top radius for first one\n    &:first-child {\n      .list-group-item:first-child {\n        border-top: 0;\n        .border-top-radius((@panel-border-radius - 1));\n      }\n    }\n\n    // Add border bottom radius for last one\n    &:last-child {\n      .list-group-item:last-child {\n        border-bottom: 0;\n        .border-bottom-radius((@panel-border-radius - 1));\n      }\n    }\n  }\n  > .panel-heading + .panel-collapse > .list-group {\n    .list-group-item:first-child {\n      .border-top-radius(0);\n    }\n  }\n}\n// Collapse space between when there's no additional content.\n.panel-heading + .list-group {\n  .list-group-item:first-child {\n    border-top-width: 0;\n  }\n}\n.list-group + .panel-footer {\n  border-top-width: 0;\n}\n\n// Tables in panels\n//\n// Place a non-bordered `.table` within a panel (not within a `.panel-body`) and\n// watch it go full width.\n\n.panel {\n  > .table,\n  > .table-responsive > .table,\n  > .panel-collapse > .table {\n    margin-bottom: 0;\n\n    caption {\n      padding-left: @panel-body-padding;\n      padding-right: @panel-body-padding;\n    }\n  }\n  // Add border top radius for first one\n  > .table:first-child,\n  > .table-responsive:first-child > .table:first-child {\n    .border-top-radius((@panel-border-radius - 1));\n\n    > thead:first-child,\n    > tbody:first-child {\n      > tr:first-child {\n        border-top-left-radius: (@panel-border-radius - 1);\n        border-top-right-radius: (@panel-border-radius - 1);\n\n        td:first-child,\n        th:first-child {\n          border-top-left-radius: (@panel-border-radius - 1);\n        }\n        td:last-child,\n        th:last-child {\n          border-top-right-radius: (@panel-border-radius - 1);\n        }\n      }\n    }\n  }\n  // Add border bottom radius for last one\n  > .table:last-child,\n  > .table-responsive:last-child > .table:last-child {\n    .border-bottom-radius((@panel-border-radius - 1));\n\n    > tbody:last-child,\n    > tfoot:last-child {\n      > tr:last-child {\n        border-bottom-left-radius: (@panel-border-radius - 1);\n        border-bottom-right-radius: (@panel-border-radius - 1);\n\n        td:first-child,\n        th:first-child {\n          border-bottom-left-radius: (@panel-border-radius - 1);\n        }\n        td:last-child,\n        th:last-child {\n          border-bottom-right-radius: (@panel-border-radius - 1);\n        }\n      }\n    }\n  }\n  > .panel-body + .table,\n  > .panel-body + .table-responsive,\n  > .table + .panel-body,\n  > .table-responsive + .panel-body {\n    border-top: 1px solid @table-border-color;\n  }\n  > .table > tbody:first-child > tr:first-child th,\n  > .table > tbody:first-child > tr:first-child td {\n    border-top: 0;\n  }\n  > .table-bordered,\n  > .table-responsive > .table-bordered {\n    border: 0;\n    > thead,\n    > tbody,\n    > tfoot {\n      > tr {\n        > th:first-child,\n        > td:first-child {\n          border-left: 0;\n        }\n        > th:last-child,\n        > td:last-child {\n          border-right: 0;\n        }\n      }\n    }\n    > thead,\n    > tbody {\n      > tr:first-child {\n        > td,\n        > th {\n          border-bottom: 0;\n        }\n      }\n    }\n    > tbody,\n    > tfoot {\n      > tr:last-child {\n        > td,\n        > th {\n          border-bottom: 0;\n        }\n      }\n    }\n  }\n  > .table-responsive {\n    border: 0;\n    margin-bottom: 0;\n  }\n}\n\n\n// Collapsible panels (aka, accordion)\n//\n// Wrap a series of panels in `.panel-group` to turn them into an accordion with\n// the help of our collapse JavaScript plugin.\n\n.panel-group {\n  margin-bottom: @line-height-computed;\n\n  // Tighten up margin so it's only between panels\n  .panel {\n    margin-bottom: 0;\n    border-radius: @panel-border-radius;\n\n    + .panel {\n      margin-top: 5px;\n    }\n  }\n\n  .panel-heading {\n    border-bottom: 0;\n\n    + .panel-collapse > .panel-body,\n    + .panel-collapse > .list-group {\n      border-top: 1px solid @panel-inner-border;\n    }\n  }\n\n  .panel-footer {\n    border-top: 0;\n    + .panel-collapse .panel-body {\n      border-bottom: 1px solid @panel-inner-border;\n    }\n  }\n}\n\n\n// Contextual variations\n.panel-default {\n  .panel-variant(@panel-default-border; @panel-default-text; @panel-default-heading-bg; @panel-default-border);\n}\n.panel-primary {\n  .panel-variant(@panel-primary-border; @panel-primary-text; @panel-primary-heading-bg; @panel-primary-border);\n}\n.panel-success {\n  .panel-variant(@panel-success-border; @panel-success-text; @panel-success-heading-bg; @panel-success-border);\n}\n.panel-info {\n  .panel-variant(@panel-info-border; @panel-info-text; @panel-info-heading-bg; @panel-info-border);\n}\n.panel-warning {\n  .panel-variant(@panel-warning-border; @panel-warning-text; @panel-warning-heading-bg; @panel-warning-border);\n}\n.panel-danger {\n  .panel-variant(@panel-danger-border; @panel-danger-text; @panel-danger-heading-bg; @panel-danger-border);\n}\n","// Panels\n\n.panel-variant(@border; @heading-text-color; @heading-bg-color; @heading-border) {\n  border-color: @border;\n\n  & > .panel-heading {\n    color: @heading-text-color;\n    background-color: @heading-bg-color;\n    border-color: @heading-border;\n\n    + .panel-collapse > .panel-body {\n      border-top-color: @border;\n    }\n    .badge {\n      color: @heading-bg-color;\n      background-color: @heading-text-color;\n    }\n  }\n  & > .panel-footer {\n    + .panel-collapse > .panel-body {\n      border-bottom-color: @border;\n    }\n  }\n}\n","// Embeds responsive\n//\n// Credit: Nicolas Gallagher and SUIT CSS.\n\n.embed-responsive {\n  position: relative;\n  display: block;\n  height: 0;\n  padding: 0;\n  overflow: hidden;\n\n  .embed-responsive-item,\n  iframe,\n  embed,\n  object,\n  video {\n    position: absolute;\n    top: 0;\n    left: 0;\n    bottom: 0;\n    height: 100%;\n    width: 100%;\n    border: 0;\n  }\n}\n\n// Modifier class for 16:9 aspect ratio\n.embed-responsive-16by9 {\n  padding-bottom: 56.25%;\n}\n\n// Modifier class for 4:3 aspect ratio\n.embed-responsive-4by3 {\n  padding-bottom: 75%;\n}\n","//\n// Wells\n// --------------------------------------------------\n\n\n// Base class\n.well {\n  min-height: 20px;\n  padding: 19px;\n  margin-bottom: 20px;\n  background-color: @well-bg;\n  border: 1px solid @well-border;\n  border-radius: @border-radius-base;\n  .box-shadow(inset 0 1px 1px rgba(0,0,0,.05));\n  blockquote {\n    border-color: #ddd;\n    border-color: rgba(0,0,0,.15);\n  }\n}\n\n// Sizes\n.well-lg {\n  padding: 24px;\n  border-radius: @border-radius-large;\n}\n.well-sm {\n  padding: 9px;\n  border-radius: @border-radius-small;\n}\n","//\n// Close icons\n// --------------------------------------------------\n\n\n.close {\n  float: right;\n  font-size: (@font-size-base * 1.5);\n  font-weight: @close-font-weight;\n  line-height: 1;\n  color: @close-color;\n  text-shadow: @close-text-shadow;\n  .opacity(.2);\n\n  &:hover,\n  &:focus {\n    color: @close-color;\n    text-decoration: none;\n    cursor: pointer;\n    .opacity(.5);\n  }\n\n  // Additional properties for button version\n  // iOS requires the button element instead of an anchor tag.\n  // If you want the anchor version, it requires `href=\"#\"`.\n  // See https://developer.mozilla.org/en-US/docs/Web/Events/click#Safari_Mobile\n  button& {\n    padding: 0;\n    cursor: pointer;\n    background: transparent;\n    border: 0;\n    -webkit-appearance: none;\n  }\n}\n","//\n// Modals\n// --------------------------------------------------\n\n// .modal-open      - body class for killing the scroll\n// .modal           - container to scroll within\n// .modal-dialog    - positioning shell for the actual modal\n// .modal-content   - actual modal w/ bg and corners and shit\n\n// Kill the scroll on the body\n.modal-open {\n  overflow: hidden;\n}\n\n// Container that the modal scrolls within\n.modal {\n  display: none;\n  overflow: hidden;\n  position: fixed;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: @zindex-modal;\n  -webkit-overflow-scrolling: touch;\n\n  // Prevent Chrome on Windows from adding a focus outline. For details, see\n  // https://github.com/twbs/bootstrap/pull/10951.\n  outline: 0;\n\n  // When fading in the modal, animate it to slide down\n  &.fade .modal-dialog {\n    .translate(0, -25%);\n    .transition-transform(~\"0.3s ease-out\");\n  }\n  &.in .modal-dialog { .translate(0, 0) }\n}\n.modal-open .modal {\n  overflow-x: hidden;\n  overflow-y: auto;\n}\n\n// Shell div to position the modal with bottom padding\n.modal-dialog {\n  position: relative;\n  width: auto;\n  margin: 10px;\n}\n\n// Actual modal\n.modal-content {\n  position: relative;\n  background-color: @modal-content-bg;\n  border: 1px solid @modal-content-fallback-border-color; //old browsers fallback (ie8 etc)\n  border: 1px solid @modal-content-border-color;\n  border-radius: @border-radius-large;\n  .box-shadow(0 3px 9px rgba(0,0,0,.5));\n  background-clip: padding-box;\n  // Remove focus outline from opened modal\n  outline: 0;\n}\n\n// Modal background\n.modal-backdrop {\n  position: fixed;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: @zindex-modal-background;\n  background-color: @modal-backdrop-bg;\n  // Fade for backdrop\n  &.fade { .opacity(0); }\n  &.in { .opacity(@modal-backdrop-opacity); }\n}\n\n// Modal header\n// Top section of the modal w/ title and dismiss\n.modal-header {\n  padding: @modal-title-padding;\n  border-bottom: 1px solid @modal-header-border-color;\n  &:extend(.clearfix all);\n}\n// Close icon\n.modal-header .close {\n  margin-top: -2px;\n}\n\n// Title text within header\n.modal-title {\n  margin: 0;\n  line-height: @modal-title-line-height;\n}\n\n// Modal body\n// Where all modal content resides (sibling of .modal-header and .modal-footer)\n.modal-body {\n  position: relative;\n  padding: @modal-inner-padding;\n}\n\n// Footer (for actions)\n.modal-footer {\n  padding: @modal-inner-padding;\n  text-align: right; // right align buttons\n  border-top: 1px solid @modal-footer-border-color;\n  &:extend(.clearfix all); // clear it in case folks use .pull-* classes on buttons\n\n  // Properly space out buttons\n  .btn + .btn {\n    margin-left: 5px;\n    margin-bottom: 0; // account for input[type=\"submit\"] which gets the bottom margin like all other inputs\n  }\n  // but override that for button groups\n  .btn-group .btn + .btn {\n    margin-left: -1px;\n  }\n  // and override it for block buttons as well\n  .btn-block + .btn-block {\n    margin-left: 0;\n  }\n}\n\n// Measure scrollbar width for padding body during modal show/hide\n.modal-scrollbar-measure {\n  position: absolute;\n  top: -9999px;\n  width: 50px;\n  height: 50px;\n  overflow: scroll;\n}\n\n// Scale up the modal\n@media (min-width: @screen-sm-min) {\n  // Automatically set modal's width for larger viewports\n  .modal-dialog {\n    width: @modal-md;\n    margin: 30px auto;\n  }\n  .modal-content {\n    .box-shadow(0 5px 15px rgba(0,0,0,.5));\n  }\n\n  // Modal sizes\n  .modal-sm { width: @modal-sm; }\n}\n\n@media (min-width: @screen-md-min) {\n  .modal-lg { width: @modal-lg; }\n}\n","//\n// Tooltips\n// --------------------------------------------------\n\n\n// Base class\n.tooltip {\n  position: absolute;\n  z-index: @zindex-tooltip;\n  display: block;\n  // Our parent element can be arbitrary since tooltips are by default inserted as a sibling of their target element.\n  // So reset our font and text properties to avoid inheriting weird values.\n  .reset-text();\n  font-size: @font-size-small;\n\n  .opacity(0);\n\n  &.in     { .opacity(@tooltip-opacity); }\n  &.top    { margin-top:  -3px; padding: @tooltip-arrow-width 0; }\n  &.right  { margin-left:  3px; padding: 0 @tooltip-arrow-width; }\n  &.bottom { margin-top:   3px; padding: @tooltip-arrow-width 0; }\n  &.left   { margin-left: -3px; padding: 0 @tooltip-arrow-width; }\n}\n\n// Wrapper for the tooltip content\n.tooltip-inner {\n  max-width: @tooltip-max-width;\n  padding: 3px 8px;\n  color: @tooltip-color;\n  text-align: center;\n  background-color: @tooltip-bg;\n  border-radius: @border-radius-base;\n}\n\n// Arrows\n.tooltip-arrow {\n  position: absolute;\n  width: 0;\n  height: 0;\n  border-color: transparent;\n  border-style: solid;\n}\n// Note: Deprecated .top-left, .top-right, .bottom-left, and .bottom-right as of v3.3.1\n.tooltip {\n  &.top .tooltip-arrow {\n    bottom: 0;\n    left: 50%;\n    margin-left: -@tooltip-arrow-width;\n    border-width: @tooltip-arrow-width @tooltip-arrow-width 0;\n    border-top-color: @tooltip-arrow-color;\n  }\n  &.top-left .tooltip-arrow {\n    bottom: 0;\n    right: @tooltip-arrow-width;\n    margin-bottom: -@tooltip-arrow-width;\n    border-width: @tooltip-arrow-width @tooltip-arrow-width 0;\n    border-top-color: @tooltip-arrow-color;\n  }\n  &.top-right .tooltip-arrow {\n    bottom: 0;\n    left: @tooltip-arrow-width;\n    margin-bottom: -@tooltip-arrow-width;\n    border-width: @tooltip-arrow-width @tooltip-arrow-width 0;\n    border-top-color: @tooltip-arrow-color;\n  }\n  &.right .tooltip-arrow {\n    top: 50%;\n    left: 0;\n    margin-top: -@tooltip-arrow-width;\n    border-width: @tooltip-arrow-width @tooltip-arrow-width @tooltip-arrow-width 0;\n    border-right-color: @tooltip-arrow-color;\n  }\n  &.left .tooltip-arrow {\n    top: 50%;\n    right: 0;\n    margin-top: -@tooltip-arrow-width;\n    border-width: @tooltip-arrow-width 0 @tooltip-arrow-width @tooltip-arrow-width;\n    border-left-color: @tooltip-arrow-color;\n  }\n  &.bottom .tooltip-arrow {\n    top: 0;\n    left: 50%;\n    margin-left: -@tooltip-arrow-width;\n    border-width: 0 @tooltip-arrow-width @tooltip-arrow-width;\n    border-bottom-color: @tooltip-arrow-color;\n  }\n  &.bottom-left .tooltip-arrow {\n    top: 0;\n    right: @tooltip-arrow-width;\n    margin-top: -@tooltip-arrow-width;\n    border-width: 0 @tooltip-arrow-width @tooltip-arrow-width;\n    border-bottom-color: @tooltip-arrow-color;\n  }\n  &.bottom-right .tooltip-arrow {\n    top: 0;\n    left: @tooltip-arrow-width;\n    margin-top: -@tooltip-arrow-width;\n    border-width: 0 @tooltip-arrow-width @tooltip-arrow-width;\n    border-bottom-color: @tooltip-arrow-color;\n  }\n}\n",".reset-text() {\n  font-family: @font-family-base;\n  // We deliberately do NOT reset font-size.\n  font-style: normal;\n  font-weight: normal;\n  letter-spacing: normal;\n  line-break: auto;\n  line-height: @line-height-base;\n  text-align: left; // Fallback for where `start` is not supported\n  text-align: start;\n  text-decoration: none;\n  text-shadow: none;\n  text-transform: none;\n  white-space: normal;\n  word-break: normal;\n  word-spacing: normal;\n  word-wrap: normal;\n}\n","//\n// Popovers\n// --------------------------------------------------\n\n\n.popover {\n  position: absolute;\n  top: 0;\n  left: 0;\n  z-index: @zindex-popover;\n  display: none;\n  max-width: @popover-max-width;\n  padding: 1px;\n  // Our parent element can be arbitrary since popovers are by default inserted as a sibling of their target element.\n  // So reset our font and text properties to avoid inheriting weird values.\n  .reset-text();\n  font-size: @font-size-base;\n\n  background-color: @popover-bg;\n  background-clip: padding-box;\n  border: 1px solid @popover-fallback-border-color;\n  border: 1px solid @popover-border-color;\n  border-radius: @border-radius-large;\n  .box-shadow(0 5px 10px rgba(0,0,0,.2));\n\n  // Offset the popover to account for the popover arrow\n  &.top     { margin-top: -@popover-arrow-width; }\n  &.right   { margin-left: @popover-arrow-width; }\n  &.bottom  { margin-top: @popover-arrow-width; }\n  &.left    { margin-left: -@popover-arrow-width; }\n}\n\n.popover-title {\n  margin: 0; // reset heading margin\n  padding: 8px 14px;\n  font-size: @font-size-base;\n  background-color: @popover-title-bg;\n  border-bottom: 1px solid darken(@popover-title-bg, 5%);\n  border-radius: (@border-radius-large - 1) (@border-radius-large - 1) 0 0;\n}\n\n.popover-content {\n  padding: 9px 14px;\n}\n\n// Arrows\n//\n// .arrow is outer, .arrow:after is inner\n\n.popover > .arrow {\n  &,\n  &:after {\n    position: absolute;\n    display: block;\n    width: 0;\n    height: 0;\n    border-color: transparent;\n    border-style: solid;\n  }\n}\n.popover > .arrow {\n  border-width: @popover-arrow-outer-width;\n}\n.popover > .arrow:after {\n  border-width: @popover-arrow-width;\n  content: \"\";\n}\n\n.popover {\n  &.top > .arrow {\n    left: 50%;\n    margin-left: -@popover-arrow-outer-width;\n    border-bottom-width: 0;\n    border-top-color: @popover-arrow-outer-fallback-color; // IE8 fallback\n    border-top-color: @popover-arrow-outer-color;\n    bottom: -@popover-arrow-outer-width;\n    &:after {\n      content: \" \";\n      bottom: 1px;\n      margin-left: -@popover-arrow-width;\n      border-bottom-width: 0;\n      border-top-color: @popover-arrow-color;\n    }\n  }\n  &.right > .arrow {\n    top: 50%;\n    left: -@popover-arrow-outer-width;\n    margin-top: -@popover-arrow-outer-width;\n    border-left-width: 0;\n    border-right-color: @popover-arrow-outer-fallback-color; // IE8 fallback\n    border-right-color: @popover-arrow-outer-color;\n    &:after {\n      content: \" \";\n      left: 1px;\n      bottom: -@popover-arrow-width;\n      border-left-width: 0;\n      border-right-color: @popover-arrow-color;\n    }\n  }\n  &.bottom > .arrow {\n    left: 50%;\n    margin-left: -@popover-arrow-outer-width;\n    border-top-width: 0;\n    border-bottom-color: @popover-arrow-outer-fallback-color; // IE8 fallback\n    border-bottom-color: @popover-arrow-outer-color;\n    top: -@popover-arrow-outer-width;\n    &:after {\n      content: \" \";\n      top: 1px;\n      margin-left: -@popover-arrow-width;\n      border-top-width: 0;\n      border-bottom-color: @popover-arrow-color;\n    }\n  }\n\n  &.left > .arrow {\n    top: 50%;\n    right: -@popover-arrow-outer-width;\n    margin-top: -@popover-arrow-outer-width;\n    border-right-width: 0;\n    border-left-color: @popover-arrow-outer-fallback-color; // IE8 fallback\n    border-left-color: @popover-arrow-outer-color;\n    &:after {\n      content: \" \";\n      right: 1px;\n      border-right-width: 0;\n      border-left-color: @popover-arrow-color;\n      bottom: -@popover-arrow-width;\n    }\n  }\n}\n","//\n// Carousel\n// --------------------------------------------------\n\n\n// Wrapper for the slide container and indicators\n.carousel {\n  position: relative;\n}\n\n.carousel-inner {\n  position: relative;\n  overflow: hidden;\n  width: 100%;\n\n  > .item {\n    display: none;\n    position: relative;\n    .transition(.6s ease-in-out left);\n\n    // Account for jankitude on images\n    > img,\n    > a > img {\n      &:extend(.img-responsive);\n      line-height: 1;\n    }\n\n    // WebKit CSS3 transforms for supported devices\n    @media all and (transform-3d), (-webkit-transform-3d) {\n      .transition-transform(~'0.6s ease-in-out');\n      .backface-visibility(~'hidden');\n      .perspective(1000px);\n\n      &.next,\n      &.active.right {\n        .translate3d(100%, 0, 0);\n        left: 0;\n      }\n      &.prev,\n      &.active.left {\n        .translate3d(-100%, 0, 0);\n        left: 0;\n      }\n      &.next.left,\n      &.prev.right,\n      &.active {\n        .translate3d(0, 0, 0);\n        left: 0;\n      }\n    }\n  }\n\n  > .active,\n  > .next,\n  > .prev {\n    display: block;\n  }\n\n  > .active {\n    left: 0;\n  }\n\n  > .next,\n  > .prev {\n    position: absolute;\n    top: 0;\n    width: 100%;\n  }\n\n  > .next {\n    left: 100%;\n  }\n  > .prev {\n    left: -100%;\n  }\n  > .next.left,\n  > .prev.right {\n    left: 0;\n  }\n\n  > .active.left {\n    left: -100%;\n  }\n  > .active.right {\n    left: 100%;\n  }\n\n}\n\n// Left/right controls for nav\n// ---------------------------\n\n.carousel-control {\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  width: @carousel-control-width;\n  .opacity(@carousel-control-opacity);\n  font-size: @carousel-control-font-size;\n  color: @carousel-control-color;\n  text-align: center;\n  text-shadow: @carousel-text-shadow;\n  background-color: rgba(0, 0, 0, 0); // Fix IE9 click-thru bug\n  // We can't have this transition here because WebKit cancels the carousel\n  // animation if you trip this while in the middle of another animation.\n\n  // Set gradients for backgrounds\n  &.left {\n    #gradient > .horizontal(@start-color: rgba(0,0,0,.5); @end-color: rgba(0,0,0,.0001));\n  }\n  &.right {\n    left: auto;\n    right: 0;\n    #gradient > .horizontal(@start-color: rgba(0,0,0,.0001); @end-color: rgba(0,0,0,.5));\n  }\n\n  // Hover/focus state\n  &:hover,\n  &:focus {\n    outline: 0;\n    color: @carousel-control-color;\n    text-decoration: none;\n    .opacity(.9);\n  }\n\n  // Toggles\n  .icon-prev,\n  .icon-next,\n  .glyphicon-chevron-left,\n  .glyphicon-chevron-right {\n    position: absolute;\n    top: 50%;\n    margin-top: -10px;\n    z-index: 5;\n    display: inline-block;\n  }\n  .icon-prev,\n  .glyphicon-chevron-left {\n    left: 50%;\n    margin-left: -10px;\n  }\n  .icon-next,\n  .glyphicon-chevron-right {\n    right: 50%;\n    margin-right: -10px;\n  }\n  .icon-prev,\n  .icon-next {\n    width:  20px;\n    height: 20px;\n    line-height: 1;\n    font-family: serif;\n  }\n\n\n  .icon-prev {\n    &:before {\n      content: '\\2039';// SINGLE LEFT-POINTING ANGLE QUOTATION MARK (U+2039)\n    }\n  }\n  .icon-next {\n    &:before {\n      content: '\\203a';// SINGLE RIGHT-POINTING ANGLE QUOTATION MARK (U+203A)\n    }\n  }\n}\n\n// Optional indicator pips\n//\n// Add an unordered list with the following class and add a list item for each\n// slide your carousel holds.\n\n.carousel-indicators {\n  position: absolute;\n  bottom: 10px;\n  left: 50%;\n  z-index: 15;\n  width: 60%;\n  margin-left: -30%;\n  padding-left: 0;\n  list-style: none;\n  text-align: center;\n\n  li {\n    display: inline-block;\n    width:  10px;\n    height: 10px;\n    margin: 1px;\n    text-indent: -999px;\n    border: 1px solid @carousel-indicator-border-color;\n    border-radius: 10px;\n    cursor: pointer;\n\n    // IE8-9 hack for event handling\n    //\n    // Internet Explorer 8-9 does not support clicks on elements without a set\n    // `background-color`. We cannot use `filter` since that's not viewed as a\n    // background color by the browser. Thus, a hack is needed.\n    // See https://developer.mozilla.org/en-US/docs/Web/Events/click#Internet_Explorer\n    //\n    // For IE8, we set solid black as it doesn't support `rgba()`. For IE9, we\n    // set alpha transparency for the best results possible.\n    background-color: #000 \\9; // IE8\n    background-color: rgba(0,0,0,0); // IE9\n  }\n  .active {\n    margin: 0;\n    width:  12px;\n    height: 12px;\n    background-color: @carousel-indicator-active-bg;\n  }\n}\n\n// Optional captions\n// -----------------------------\n// Hidden by default for smaller viewports\n.carousel-caption {\n  position: absolute;\n  left: 15%;\n  right: 15%;\n  bottom: 20px;\n  z-index: 10;\n  padding-top: 20px;\n  padding-bottom: 20px;\n  color: @carousel-caption-color;\n  text-align: center;\n  text-shadow: @carousel-text-shadow;\n  & .btn {\n    text-shadow: none; // No shadow for button elements in carousel-caption\n  }\n}\n\n\n// Scale up controls for tablets and up\n@media screen and (min-width: @screen-sm-min) {\n\n  // Scale up the controls a smidge\n  .carousel-control {\n    .glyphicon-chevron-left,\n    .glyphicon-chevron-right,\n    .icon-prev,\n    .icon-next {\n      width: (@carousel-control-font-size * 1.5);\n      height: (@carousel-control-font-size * 1.5);\n      margin-top: (@carousel-control-font-size / -2);\n      font-size: (@carousel-control-font-size * 1.5);\n    }\n    .glyphicon-chevron-left,\n    .icon-prev {\n      margin-left: (@carousel-control-font-size / -2);\n    }\n    .glyphicon-chevron-right,\n    .icon-next {\n      margin-right: (@carousel-control-font-size / -2);\n    }\n  }\n\n  // Show and left align the captions\n  .carousel-caption {\n    left: 20%;\n    right: 20%;\n    padding-bottom: 30px;\n  }\n\n  // Move up the indicators\n  .carousel-indicators {\n    bottom: 20px;\n  }\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","// 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 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 (has been 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","//\n// Responsive: Utility classes\n// --------------------------------------------------\n\n\n// IE10 in Windows (Phone) 8\n//\n// Support for responsive views via media queries is kind of borked in IE10, for\n// Surface/desktop in split view and for Windows Phone 8. This particular fix\n// must be accompanied by a snippet of JavaScript to sniff the user agent and\n// apply some conditional CSS to *only* the Surface/desktop Windows 8. Look at\n// our Getting Started page for more information on this bug.\n//\n// For more information, see the following:\n//\n// Issue: https://github.com/twbs/bootstrap/issues/10497\n// Docs: http://getbootstrap.com/getting-started/#support-ie10-width\n// Source: http://timkadlec.com/2013/01/windows-phone-8-and-device-width/\n// Source: http://timkadlec.com/2012/10/ie10-snap-mode-and-responsive-design/\n\n@-ms-viewport {\n  width: device-width;\n}\n\n\n// Visibility utilities\n// Note: Deprecated .visible-xs, .visible-sm, .visible-md, and .visible-lg as of v3.2.0\n.visible-xs,\n.visible-sm,\n.visible-md,\n.visible-lg {\n  .responsive-invisibility();\n}\n\n.visible-xs-block,\n.visible-xs-inline,\n.visible-xs-inline-block,\n.visible-sm-block,\n.visible-sm-inline,\n.visible-sm-inline-block,\n.visible-md-block,\n.visible-md-inline,\n.visible-md-inline-block,\n.visible-lg-block,\n.visible-lg-inline,\n.visible-lg-inline-block {\n  display: none !important;\n}\n\n.visible-xs {\n  @media (max-width: @screen-xs-max) {\n    .responsive-visibility();\n  }\n}\n.visible-xs-block {\n  @media (max-width: @screen-xs-max) {\n    display: block !important;\n  }\n}\n.visible-xs-inline {\n  @media (max-width: @screen-xs-max) {\n    display: inline !important;\n  }\n}\n.visible-xs-inline-block {\n  @media (max-width: @screen-xs-max) {\n    display: inline-block !important;\n  }\n}\n\n.visible-sm {\n  @media (min-width: @screen-sm-min) and (max-width: @screen-sm-max) {\n    .responsive-visibility();\n  }\n}\n.visible-sm-block {\n  @media (min-width: @screen-sm-min) and (max-width: @screen-sm-max) {\n    display: block !important;\n  }\n}\n.visible-sm-inline {\n  @media (min-width: @screen-sm-min) and (max-width: @screen-sm-max) {\n    display: inline !important;\n  }\n}\n.visible-sm-inline-block {\n  @media (min-width: @screen-sm-min) and (max-width: @screen-sm-max) {\n    display: inline-block !important;\n  }\n}\n\n.visible-md {\n  @media (min-width: @screen-md-min) and (max-width: @screen-md-max) {\n    .responsive-visibility();\n  }\n}\n.visible-md-block {\n  @media (min-width: @screen-md-min) and (max-width: @screen-md-max) {\n    display: block !important;\n  }\n}\n.visible-md-inline {\n  @media (min-width: @screen-md-min) and (max-width: @screen-md-max) {\n    display: inline !important;\n  }\n}\n.visible-md-inline-block {\n  @media (min-width: @screen-md-min) and (max-width: @screen-md-max) {\n    display: inline-block !important;\n  }\n}\n\n.visible-lg {\n  @media (min-width: @screen-lg-min) {\n    .responsive-visibility();\n  }\n}\n.visible-lg-block {\n  @media (min-width: @screen-lg-min) {\n    display: block !important;\n  }\n}\n.visible-lg-inline {\n  @media (min-width: @screen-lg-min) {\n    display: inline !important;\n  }\n}\n.visible-lg-inline-block {\n  @media (min-width: @screen-lg-min) {\n    display: inline-block !important;\n  }\n}\n\n.hidden-xs {\n  @media (max-width: @screen-xs-max) {\n    .responsive-invisibility();\n  }\n}\n.hidden-sm {\n  @media (min-width: @screen-sm-min) and (max-width: @screen-sm-max) {\n    .responsive-invisibility();\n  }\n}\n.hidden-md {\n  @media (min-width: @screen-md-min) and (max-width: @screen-md-max) {\n    .responsive-invisibility();\n  }\n}\n.hidden-lg {\n  @media (min-width: @screen-lg-min) {\n    .responsive-invisibility();\n  }\n}\n\n\n// Print utilities\n//\n// Media queries are placed on the inside to be mixin-friendly.\n\n// Note: Deprecated .visible-print as of v3.2.0\n.visible-print {\n  .responsive-invisibility();\n\n  @media print {\n    .responsive-visibility();\n  }\n}\n.visible-print-block {\n  display: none !important;\n\n  @media print {\n    display: block !important;\n  }\n}\n.visible-print-inline {\n  display: none !important;\n\n  @media print {\n    display: inline !important;\n  }\n}\n.visible-print-inline-block {\n  display: none !important;\n\n  @media print {\n    display: inline-block !important;\n  }\n}\n\n.hidden-print {\n  @media print {\n    .responsive-invisibility();\n  }\n}\n","// Responsive utilities\n\n//\n// More easily include all the states for responsive-utilities.less.\n.responsive-visibility() {\n  display: block !important;\n  table&  { display: table !important; }\n  tr&     { display: table-row !important; }\n  th&,\n  td&     { display: table-cell !important; }\n}\n\n.responsive-invisibility() {\n  display: none !important;\n}\n","/* ************************************************************************ */\n/*                                LESS VARIABLES\n**                This stylesheet should only contain variables.\n/* ************************************************************************ */\n\n/*-----------------------------------------------------------------------*/\n/*                          Color palette                                */\n/*-----------------------------------------------------------------------*/\n@mgreen:                          #dae173;\n@morange:                         #d6782b;\n@mdarkblue:                       #232528;\n@mgrey:                           #cccccc;\n@mlightgrey:                      #999999;\n@mdarkbg:                         #16161B;\n@mblue:                           #358fdc;\n@darkerblue:                      #16252c;\n@darkblue:                        #17262d;\n@darkerblue:                      darken(@darkblue,4%);\n@darkblue2:                       #25333a;\n@mediumblue:                      #626d6d;\n@lightblue:                       #abc4c6;\n@pink:                            #ed1e79;\n@red:                             #FF0000;\n\n@fluroblue:                       #00e5f0;\n@fluroorange:                     #ff7300;\n@flureoyellow:                    #fbd925;\n@flurogreen:                      #47ff00;\n@fluropink:                       #e01f74;\n\n@darkgreen:                       #33d375;\n@green:                           #d1e55c;\n@purple:                          #977bf0;\n@lightgray:                       #e6edee;\n@bluegray:                        #abc4c6;\n@bluegray2:                       #35464c;\n\n@brand-success:                  @fluroblue;\n@brand-warning:                  @purple;\n@brand-info:                     @fluroblue;\n@brand-danger:                   @fluropink;\n@brand-primary:                  @fluroblue;\n\n@impac-positive:                 green;\n@impac-negative:                 @pink;\n@impac-positive2:                #3fc4ff;     // lighter colors used for payables-receivables\n@impac-negative2:                #1de9b6;     // lighter colorsused for payables-receivables\n\n// Spacers\n//----------------------------------------\n@top-buffer-height: @grid-gutter-width/2; // bootstrap variable\n.top-buffer-1 { margin-top: @top-buffer-height; }\n.top-buffer-2 { margin-top: 2*@top-buffer-height; }\n.top-buffer-3 { margin-top: 3*@top-buffer-height; }\n.top-buffer-4 { margin-top: 4*@top-buffer-height; }\n.top-buffer-5 { margin-top: 5*@top-buffer-height; }\n.top-buffer-6 { margin-top: 6*@top-buffer-height; }\n.top-buffer-7 { margin-top: 7*@top-buffer-height; }\n.top-buffer-8 { margin-top: 8*@top-buffer-height; }\n.top-buffer-9 { margin-top: 9*@top-buffer-height; }\n.top-buffer-10 { margin-top: 10*@top-buffer-height; }\n\n// Dashboard\n//--------------------------------------\n@impac-dashboard-padding-top:                   50px;\n@impac-dashboard-sm-padding-top:                @impac-dashboard-padding-top * 3;\n@impac-dashboard-margin-left:                   100px;\n@impac-dashboard-borders-color:                 @lightblue;\n\n// Title\n@impac-dashboard-title-color:                   @purple;\n@impac-dashboard-title-label-color:             @darkblue;\n@impac-dashboard-title-label-create-color:      white;\n@impac-dashboard-source-color:                  @impac-dashboard-title-label-color;\n@impac-dashboard-buttons-border-radius:         4px;\n\n// Create\n@impac-dashboard-create-button-color:           @impac-dashboard-title-color;\n\n//Info-text\n@impac-dashboard-info-text-color:               white;\n@impac-dashboard-info-text-background-color:    rgba(23,38,45, 0.7);\n@impac-dashboard-info-text-font-size:           25px;\n@impac-dashboard-info-text-font-weight:         300;\n\n// Dashboard Selector\n  // Tabs\n@impac-dashboard-selector-border:               1px solid @impac-dashboard-borders-color;\n@impac-dashboard-selector-tabs-margin:          0 2px 0 0;\n@impac-dashboard-selector-tabs-padding:         10px 8px 10px 15px;\n@impac-dashboard-selector-tabs-background-color: transparent;\n@impac-dashboard-selector-tabs-active-background-color: #ffffff;\n@impac-dashboard-selector-tabs-color:           black;\n@impac-dashboard-selector-tabs-active-color:    @purple;\n\n// Widget selector\n@impac-dashboard-widget-selector-bg:            #233845;\n@impac-dashboard-widget-selector-text-color:    white;\n@impac-dashboard-widget-selector-widget-item-min-height: 0px;\n\n// Widgets container\n@impac-placeholder-border:                      2px dashed @impac-dashboard-borders-color;\n@impac-widgets-container-side-padding:          0px;\n@impac-padding-between-widgets:                 12px;\n@impac-minimum-widget-size:                     250px;\n@impac-big-widget-size:                         565px;\n\n// Buttons\n@impac-btn-shadded-bg:                         @darkblue;\n@impac-btn-shadded-color:                      @mediumblue;\n\n// Dashboard Modals\n@impac-dashboard-loading-spinner:               white;\n@impac-dashboard-templates-selected-background-color: rgba(29, 197, 57, 0.62);\n\n// Widgets\n//--------------------------------------\n// Global\n@impac-widget-link-color:                      @purple;\n@impac-widget-buttons-color:                   @impac-widget-link-color;\n@impac-widget-tile-selected-color:             @impac-widget-link-color;\n@impac-widget-background-color:                white;\n@impac-widget-border:                          solid 1px darken(@lightgray,10%);\n@impac-widget-text-color:                      #5B6667;\n@impac-widget-text-color-medium:               lighten(@impac-widget-text-color,25%);\n@impac-widget-text-color-light:                lighten(@impac-widget-text-color,40%); //#acb0b1\n@impac-widget-borders-color:                   lighten(@impac-widget-text-color-light,10%); //#f3f4f4\n@impac-widget-scrollbar-color:                 #233845;\n@impac-widget-loading-spinner:                 #67BBE9;\n@impac-widget-reverse-color:                   #1E303B;\n@impac-widget-menus-hover-background-color:    #ececec;\n\n// Title\n@impac-widget-title-text-color:                darken(@impac-widget-text-color,5%);\n@impac-widget-title-bg:                        @impac-widget-background-color;\n@impac-widget-title-border:                    solid 1px @impac-widget-borders-color;\n@impac-widget-title-text-transform:            uppercase;\n@impac-widget-title-text-size:                 12px;\n@impac-widget-title-border-radius:             5px 5px 0px 0px;\n@impac-widget-top-buttons-color:               @impac-widget-text-color-light;\n\n// Content\n@impac-widget-content-border-radius:           0px 0px 5px 5px;\n@impac-widget-lines-container-max-height:      200px;\n\n// Settings\n// Param selector\n@impac-widget-param-selector-color:            @impac-widget-link-color;\n// Hist Mode Choser\n@impac-widget-hist-text-transform:             uppercase;\n@impac-widget-hist-text-size:                  12px;\n@impac-widget-hist-text-color:                 @impac-widget-text-color-light;\n// Params picker\n@impac-widget-params-picker-bg:                @impac-widget-reverse-color;\n@impac-widget-params-picker-unchecked-bg:      #c2c4c4;\n// Limit entries\n@impac-widget-limit-entries-color:             @impac-widget-reverse-color;\n\n// Globals and Mixins\n@impac-widget-selectable-color:                @impac-widget-link-color;\n\n// Edit settings\n@impac-widget-sub-bg-color:                    darken(@impac-widget-background-color,6%);\n@impac-widget-sub-bg-color-light:              lighten(@impac-widget-sub-bg-color,5%); //f3f4f4\n\n// Accounts Comparison\n@impac-widget-accounts-comparison-lines-container-max-height: 220px;\n\n// Sales break-even\n@impac-widget-sales-break-even-bg:             rgb(25,40,49);\n@impac-widget-sales-break-even-text-color:     #1de9b6;\n\n// KPIs\n//--------------------------------------\n// Kpi bar\n@kpis-bar-background-color:                    white;\n@kpis-bar-box-shadow:                          0px 1px 8px -4px;\n// Kpi\n@kpi-background-color:                         white;\n@kpi-triggered-border-bottom:                  4px solid @brand-danger;\n@kpi-max-height:                               95px;\n@kpi-editing-max-height:                       90px; // height to be added to the @kpi-max-height when in editing mode.\n@kpi-content-editing-height-buffer:            5px; // height to be minused from the @kpi-editing-max-height to even the kpi height and the kpi content height.\n// Kpi top-line\n@kpi-top-line-background-color:                grey;\n@kpi-top-line-triggered-background-color:      black;\n@kpi-top-line-height:                          7px;\n@kpi-top-line-box-shadow:                      none;\n// kpi content\n@kpi-text-color:                               grey;\n@kpi-text-triggered-color:                     black;\n@kpi-icon-color:                               grey;\n@kpi-icon-triggered-color:                     black;\n// kpi settings\n@kpi-settings-focus-color:                     @mblue;\n@kpi-settings-error-color:                     @brand-danger;\n@kpi-settings-remove-background:               #4c4749;\n@kpi-settings-remove-background-hover:         darken(@brand-danger, 5%);\n@kpi-settings-alert-config-background:         #4c4749;\n@kpi-settings-alert-config-background-hover:   @mblue;\n@kpi-negative-alert-label-background-color:    lighten(#ff0000, 30%);\n\n// Widgets pop-ups\n//--------------------------------------\n@impac-widget-popup-title-background-color:    #192831;\n@impac-widget-popup-message-background-color:  rgb(244, 248, 249);\n@impac-widget-popup-title-text-color:          white;\n@impac-widget-popup-message-text-color:        @impac-widget-text-color;\n\n// Demo data mode\n@impac-widget-demo-data-link-color:            @mgreen;\n","/* ************************************************************************ */\n/*                                GLOBAL STYLES\n**        This stylesheet should only contain styles applied global or in\n**                            2 or more components.\n/* ************************************************************************ */\n\n// Not ideal: intends to force a scrollbar on the window (not on the body),\n// so that the tooltips appended to body are not making the screen flickering.\n// (see when there is only 1 invoices list widget on the dashboard)\n// It is better if the tooltips can be appended to body because otherwise it's\n// messing the alternate-bg() mixing (by adding a child to the parent element)\nbody {\n  height: 101% !important;\n}\n\n.analytics {\n\n  // ---------------------------------------------------------------------------\n  // --- Titles\n  // ---------------------------------------------------------------------------\n\n  h2 {\n    margin-top: 2px;\n    font-size: 14px;\n    color: @impac-widget-text-color;\n  }\n\n  h3 {\n    margin: 0px;\n    .left-thin();\n  }\n\n  h4 {\n    color: @impac-widget-text-color;\n    font-size: 16px;\n  }\n\n  // ---------------------------------------------------------------------------\n  // --- Colors\n  // ---------------------------------------------------------------------------\n\n  .positive,.green {\n    color: @impac-positive !important;\n  }\n\n  .negative,.red {\n    color: @impac-negative !important;\n  }\n\n  .positive2 {\n    color: @impac-positive2 !important;\n  }\n\n  .negative2 {\n    color: @impac-negative2 !important;\n  }\n\n  // ---------------------------------------------------------------------------\n  // --- Base elements\n  // ---------------------------------------------------------------------------\n\n  a {\n    font-weight: bold;\n    color: @impac-widget-link-color;\n    cursor: pointer;\n  }\n\n  .input-group {\n    width: 100%;\n  }\n\n  select {\n    margin-top: 5px;\n    background-color: @impac-widget-background-color;\n    height: 32px;\n  }\n\n  pre {\n    font-size: 12px;\n    padding: 0px;\n    margin: 1px 0px 8px 0px;\n    border: none;\n    white-space: pre-wrap;\n    word-wrap: break-word;\n    overflow: hidden;\n  }\n\n  .widget-item .content, kpis-bar .kpi {\n    ::-webkit-scrollbar {\n      width: 6px;\n      background-color: transparent;\n    }\n\n    ::-webkit-scrollbar-thumb {\n      background-color: lighten(@impac-widget-scrollbar-color,35%);\n      border-radius: 10px;\n      &:hover {\n        background-color: lighten(@impac-widget-scrollbar-color,40%);\n      }\n    }\n  }\n\n  // ---------------------------------------------------------------------------\n  // --- Common adjustments\n  // ---------------------------------------------------------------------------\n  .nopadding {\n    padding: 0;\n  }\n\n  .nomargin {\n    margin: 0;\n  }\n\n  // ---------------------------------------------------------------------------\n  // --- Custom elements\n  // ---------------------------------------------------------------------------\n\n  .btn.btn-shaded {\n    background-color: @impac-btn-shadded-bg;\n    border: solid 1px darken(@impac-btn-shadded-bg,5%);\n    color: @impac-btn-shadded-color;\n    font-weight: 400;\n\n    &:hover {\n      color: lighten(@impac-btn-shadded-color,5%);\n      background-color: lighten(@impac-btn-shadded-bg,5%);\n    }\n  }\n\n  .price {\n    .center-bold();\n  }\n\n  .currency {\n    .center-thin();\n    color: @impac-widget-text-color-medium;\n  }\n\n  .legend {\n    .center-small();\n    .scrollable();\n    color: @impac-widget-text-color-light;\n  }\n\n  .loader {\n    height: 100%;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    i {\n      .loader-style();\n    }\n    p {\n      margin-top: 10px;\n    }\n  }\n\n  .right-panel {\n    border-left: solid 1px #e6e6e6;\n  }\n\n  .selector {\n    text-transform: uppercase;\n    font-size: 12px;\n    color: @mediumblue;\n    text-align: center\n  }\n\n  .tile {\n    background-color: rgb(247,247,247);\n    box-shadow: 0px 7px 10px -7px #17262d;\n    height: 45px;\n    margin-bottom: 10px;\n    white-space: nowrap;\n    cursor: pointer;\n    &:hover {\n      background-color: darken(#F1F9FF, 3%);\n    }\n    .colored-area {\n      background-color: #3FC4FF;\n      height: 100%;\n      float: right;\n      color: white;\n      text-align: right;\n      padding: 5px 10px;\n      min-width: 8%;\n      &.selected {\n        background-color: @impac-widget-tile-selected-color;\n      }\n    }\n    .main-text {\n      color: @impac-widget-text-color;\n      padding: 20px 0px 0px 5px;\n      height: 100%;\n      font-style: italic;\n      font-weight: bold;\n    }\n  }\n\n  .widget-lines-container {\n    .scrollable();\n    max-height: @impac-widget-lines-container-max-height;\n    text-align: left;\n    font-size: 12px;\n    padding: 0px 15px;\n\n    .row.widget-line {\n      padding: 5px;\n      color: @mediumblue;\n\n      &.header {\n        .font(12px,500,@impac-widget-text-color-medium);\n        text-transform: uppercase;\n      }\n      @media (max-width: @screen-xs-max) {\n        margin: inherit;\n        margin-left: -3px;\n        margin-right: -3px;\n        padding: 2px;\n\n        & > [class*='col-'] {\n          padding-left: 3px;\n          padding-right: 3px;\n        }\n      }\n\n      i.fa {\n        min-width: 12px;\n        min-height: 12px;\n      }\n    }\n\n    .row .dashed {\n      border-bottom: dashed 1px @impac-widget-borders-color;\n      padding-bottom: 3px;\n      margin-bottom: 3px;\n    }\n\n    .row.lines-group {\n      border-top: solid 1px @lightgray;\n    }\n  }\n}\n\n.vertical-scroll {\n  overflow-y: scroll;\n}\n\n.horizontal-scroll {\n  overflow-x: scroll;\n}\n\n// The tooltips should be append to body\n.tooltip.impac-widgets-tooltip .tooltip-inner.ng-binding {\n  text-align: left;\n  background-color: @mdarkblue;\n  max-width: 100%;\n  white-space: nowrap;\n  strong {\n    color: @mgreen;\n  }\n}\n\n.sortable-title {\n  cursor: pointer;\n  div {\n    display: inline-block;\n  }\n}\n\ndiv[ng-messages] {\n  color: @red;\n}\n\n// ---------------------------------------------------------------------------\n// --- Bootstrap overrides\n// ---------------------------------------------------------------------------\n\n.has-error .form-control {\n  border-color: @brand-danger;\n  &:focus { border-color: @brand-danger }\n}\n\n.has-success .form-control {\n  border-color: @brand-success;\n  &:focus { border-color: @brand-success }\n}\n\n// remove gutters from Boostrap row\n.row.no-gutters {\n  margin-right: 0;\n  margin-left: 0;\n}\n\n// remove gutters from Boostrap column\n[class^=\"col-\"].no-gutters,\n[class*=\" col-\"].no-gutters {\n  padding-right: 0;\n  padding-left: 0;\n}\n",".font(@size,@weight,@color) {\n  font-weight:@weight;\n  font-size:@size;\n  color:@color;\n}\n\n.center-bold (@margin-top: 30px) {\n  .font(22px, 900, @impac-widget-text-color);\n  text-align: center;\n  margin-top: @margin-top;\n}\n\n.center-thin () {\n  .font(16px, 300, @impac-widget-text-color);\n  text-align: center;\n}\n\n.center-small () {\n  .font(12px, 300, @impac-widget-text-color);\n  text-align: center;\n}\n\n.left-thin (@margin-top: 0px) {\n  .font(14px, 300, @impac-widget-text-color);\n  text-align: left;\n  margin-top: @margin-top;\n}\n\n.widget-height (@height: @impac-minimum-widget-size) {\n  min-height: @height;\n  @media (min-width: @screen-md-min) {\n    height: @height;\n    .chart-container {\n      max-width: @height + 20px;\n      max-height: @height - 125px;\n      margin: auto;\n    }\n  }\n}\n\n.short-widget () {\n  .widget-height();\n  .edit {\n    max-height: @impac-minimum-widget-size - 20px;\n  }\n}\n\n.tall-widget () {\n  .widget-height(@impac-big-widget-size);\n  .edit {\n    max-height: @impac-big-widget-size - 20px;\n    .widget-lines-container {\n      .scrollable(hidden);\n    }\n  }\n}\n\n.scrollable (@scroll-mode: auto) {\n  overflow-y: @scroll-mode;\n  overflow-x: hidden;\n}\n\n.selectable () {\n  cursor: pointer;\n  border: solid 1px @impac-widget-background-color;\n  .selection-tag {\n    display: block;\n    right: 0px;\n    margin-top: -6px;\n    width: 10px;\n    height: 29px;\n    position: absolute;\n  }\n  &:hover {\n    background-color: lighten(@impac-widget-selectable-color, 22%);\n  }\n  &.no-select {\n    cursor: auto;\n    &:hover { color: @mediumblue; }\n  }\n}\n\n.alternate-bg (@even-color: @impac-widget-sub-bg-color) {\n  &:nth-child(even) {\n    background-color: @even-color;\n  }\n  &:nth-child(odd) {\n    background-color: @impac-widget-background-color;\n  }\n}\n\n.edit-panel-style() {\n  .scrollable();\n  color: @impac-widget-text-color;\n  padding: 2px;\n  font-size: 12px;\n\n  .bottom-buttons {\n    .btn {\n      border-radius: 2px;\n      margin-right: 5px;\n      padding: 3px 13px;\n      text-transform: uppercase;\n      font-size: 12px;\n\n      &.btn-default {\n        background-color: #c2c4c4;\n        border: solid 1px darken(#c2c4c4,10%);\n        color: white;\n        &:hover {\n          border: solid 1px darken(#c2c4c4,20%);\n          background-color: darken(#c2c4c4,10%);\n        }\n      }\n    }\n  }\n\n  h4 {\n    margin: 0;\n    margin-bottom: 8px;\n    text-align: left;\n    .font(12px,normal,@impac-widget-text-color-light);\n  }\n\n  .part {\n    margin-bottom: 8px;\n    padding: 10px 0px;\n    background-color: @impac-widget-sub-bg-color-light;\n    // color: #626d6d;\n    border: solid 1px @impac-widget-borders-color;\n\n    h5 {\n      display: block;\n      margin: 0;\n      margin-bottom: 10px;\n      padding: 0px 15px;\n      text-transform: uppercase;\n      .font(12px,normal,@impac-widget-text-color-light);\n    }\n\n    label {\n      font-weight: normal;\n    }\n\n    select.form-control {\n      margin: 0px;\n      border: solid 1px #acb0b1;\n      outline: none;\n      -webkit-box-shadow: none;\n      font-size: 13px;\n      color: #72728b;\n    }\n  }\n}\n\n.loader-style(@color: @impac-widget-loading-spinner) {\n  color: @color;\n}\n\n.column-gutter(@gutter: @grid-gutter-width) {\n  padding-left: @gutter;\n  padding-right: @gutter;\n}\n\n.widget-popup() {\n  text-align: center;\n  font-size: 13px;\n  color: @impac-widget-popup-message-text-color;\n  \n  .overlay {\n    background-color: white;\n    position: absolute;\n    height: ~\"calc(100% - 4px)\";\n    width: ~\"calc(100% - 4px)\";\n    top: 2px;\n    left: 2px;\n    opacity: 0.6;\n    z-index: 5;\n  }\n\n  .message {\n    z-index: 6;\n    position: absolute;\n    min-height: 160px;\n    padding-bottom: 10px;\n    top: 45px;\n    left: 7%;\n    width: 86%;\n    background-color: @impac-widget-popup-message-background-color;\n    border-radius: 4px;\n    box-shadow: 0px 0px 25px 0px;\n\n    .title {\n      padding: 2px;\n      background-color: @impac-widget-popup-title-background-color;\n      color: @impac-widget-popup-title-text-color;\n      margin: -1px -1px 10px -1px;\n      text-transform: uppercase;\n    }\n  }\n}\n","@media print {\n  body { background-color: white !important; }\n  .analytics {\n    padding-top: 0px !important;\n    #module__dashboard-selector .title-container { margin-top: 20px; }\n    .widget-item {\n      page-break-inside: avoid;\n      .content .chart-container {\n        max-width: 270px;\n        margin: auto;\n        canvas {\n          width: 100% !important;\n          height: 100% !important;\n        }\n      }\n      .right-panel {\n        page-break-inside: avoid;\n        border-left: 0;\n        .chart-container {\n          max-width: inherit;\n          max-height: inherit;\n          canvas {\n            width: 80% !important;\n            height: 80% !important;\n          }\n        }\n      }\n    }\n  }\n  * { transition: none !important; }\n}\n","// NOTE: Do not add styles for the default button or custom injected buttonHtml here.\n//       the parent stylesheet of which this directive is embedded within should\n//       contain the styles.\n\n// Modal kpis alerts settings\n.kpi-alerts-settings {\n  .modal-header { font-size: 20px; }\n\n  .modal-body {\n    line-height: 2;\n\n    ul { margin-top: 10px; }\n\n    ul > li.list-group-item {\n      list-style: none;\n      padding: 6px 15px;\n      color: @impac-widget-text-color-medium;\n      user-select: none;\n\n      .alert-toggle {\n        &:hover { cursor: pointer; }\n      }\n\n      &.active {\n        color: @mblue;\n        font-weight: bold;\n        background-color: transparent;\n        border-color: #c4caca;\n      }\n    }\n\n    .fa.fa-toggle-on, .fa.fa-toggle-off {\n      font-size: 17px;\n      margin-right: 8px;\n    }\n\n    ul.recipients-list {\n      height: 75px;\n      overflow: hidden;\n      overflow-y: scroll;\n      border: 1px solid #c4caca;\n\n      li {\n        border: none;\n      }\n\n    }\n\n    input.recipient-search {\n      color: black;\n      width: 100%;\n    }\n\n    ul.available {\n      margin-top: 0px;\n    }\n  }\n}\n",".analytics {\n  padding-top: @impac-dashboard-padding-top;\n  margin-left: @impac-dashboard-margin-left;\n\n  // Default small screen behaviour to allow for the common use of top-bars\n  @media screen and (max-width: 992px) {\n    padding-top: @impac-dashboard-sm-padding-top;\n  }\n\n  &.pdf-mode { padding-top: 20px; }\n\n  &.show-dhb {\n    transition: opacity 1s;\n    opacity: 1;\n  }\n  &.hide-dhb {\n    opacity: 0;\n  }\n\n  // contains customisable impac logo, and heading text.\n  #dashboard-heading {\n    img {\n      float: left;\n      margin-right: 15px;\n      max-width: 200px;\n      max-height: 150px;\n      &.pdf-mode:hover { cursor: pointer; }\n    }\n    .caption {\n      font-size: 14px;\n      margin: 5px 0px;\n    }\n  }\n\n  #sub-menu {\n    margin-top: 15px;\n    h3 {\n      font-size: 26px;\n      font-weight: normal;\n      margin-bottom: 10px;\n      color: #233845;\n    }\n\n    .fa.fa-times {\n      margin: 6px;\n      color: lighten(#233845, 15%);\n      cursor: pointer;\n      float: right;\n    }\n  }\n\n  #widget-selector {\n    background-color: @impac-dashboard-widget-selector-bg;\n    color: @impac-dashboard-widget-selector-text-color;\n    padding: 0px 45px 10px 45px;\n    margin: 10px -45px;\n    border-radius: 3px;\n\n    -webkit-user-select: none; /* Chrome/Safari */\n    -moz-user-select: none; /* Firefox */\n    -ms-user-select: none; /* IE10+ */\n    /* Rules below not implemented in browsers yet */\n    -o-user-select: none;\n    user-select: none;\n\n    @media (max-width: @screen-xs-max) {\n      padding: 0 15px 10px 15px;\n      margin: 0;\n    }\n\n    .title {\n      padding: 15px 0px;\n      border-bottom: solid 1px lighten(@impac-dashboard-widget-selector-bg,6%);\n      display: flex;\n      align-items: center;\n\n      p.instruction {\n        flex-grow: 1;\n        margin: 0;\n        @media screen and (max-width: @screen-sm-min) {\n          width: 50%;\n          font-size: 13px;\n        }\n      }\n\n      .widget-added.badge {\n        margin-right: 10px;\n        opacity: 0;\n      }\n\n      .fa.close-selector {\n        float: right;\n        cursor: pointer;\n        font-size: 20px;\n        padding: 6px;\n        &:hover {\n          color: @mlightgrey;\n        }\n      }\n    }\n\n    .top-container {\n      margin: 15px 0px;\n      background-color: transparent;\n      border-radius: 3px;\n    }\n\n    .section-header {\n      padding: 10px 20px;\n      font-weight: bold;\n      min-height: 40px;\n      display: flex;\n      align-items: center;\n    }\n\n    .section-lines {\n      overflow-x: hidden;\n      overflow-y: auto;\n      height: 200px;\n      margin-right: -10px;\n      margin-left: 0px;\n\n      p {\n        padding: 5px;\n        margin: 0px;\n        cursor: pointer;\n\n        &:hover, &.selected {\n          color: @impac-dashboard-widget-selector-text-color;\n        }\n      }\n\n      &::-webkit-scrollbar {\n        width: 6px;\n        background-color: transparent;\n      }\n\n      &::-webkit-scrollbar-thumb {\n        background-color: lighten(@impac-dashboard-widget-selector-bg,3%);\n        border-radius: 10px;\n        &:hover {\n          background-color: lighten(@impac-dashboard-widget-selector-bg,6%);\n        }\n      }\n    }\n\n    .categories-section {\n      background-color: darken(@impac-dashboard-widget-selector-bg,6%);\n      padding-bottom: 15px;\n\n      & > .section-lines {\n\n        & > [class*='col-']:first-child {\n          padding: 3px 12px;\n        }\n\n        .line-item:hover {\n          background-color: darken(@impac-dashboard-widget-selector-bg,3%);\n        }\n        .line-item.selected {\n          background-color: @impac-widget-link-color;\n          font-weight: bold;\n          .box-shadow(-2px 2px 10px -4px black);\n        }\n      }\n\n      .arrow-icon {\n        position: absolute;\n        top: 33px;\n        right: -11px;\n        z-index: 1;\n\n        .square {\n          width: 50px;\n          height: 30px;\n          position: absolute;\n          top: 10px;\n          right: 17px;\n          background-color: @impac-widget-link-color;\n        }\n\n        i.fa.fa-caret-right {\n          font-size: 52px;\n          color: @impac-widget-link-color;\n          float: right;\n          position: absolute;\n          top: -1.5px;\n          right: 0px;\n        }\n      }\n    }\n\n    .widgets-section {\n      background-color: darken(@impac-dashboard-widget-selector-bg,3%);\n      padding-bottom: 15px;\n\n      & > .section-header {\n        text-transform: uppercase;\n        font-size: 12px;\n        color: @impac-widget-link-color;\n      }\n\n      & > .section-lines {\n        padding: 3px 0px;\n\n        .fa.fa-plus-circle {\n          float: right;\n          margin-top: 3px;\n        }\n\n        & > .line-items-grid {\n          width: 100%;\n          display: flex;\n          flex-wrap: wrap;\n          height: 0%;\n\n          & > .grid-item {\n            padding: 0 13px;\n            display: flex;\n            flex-grow: 1;\n            // Applies a flex-basis of 1/3 for each grid item (3 columns per row)\n            flex: 0 31.33%;\n            // Creates a small gutter around each grid item\n            margin: 0 1%;\n            align-items: center;\n            border-bottom: solid 1px @impac-dashboard-widget-selector-bg;\n            min-height: @impac-dashboard-widget-selector-widget-item-min-height;\n\n            @media screen and (max-width: @screen-md-min) {\n              flex: 0 100%;\n            }\n\n            &:hover {\n              background-color: darken(@impac-dashboard-widget-selector-bg,6%);\n              font-weight: normal;\n            }\n\n            p.line-item {\n              flex-grow: 1;\n            }\n          }\n        }\n      }\n    }\n\n    .bottom {\n      height: 20px;\n      & > .suggestion {\n        float: right;\n        opacity: 0.7;\n        a {\n          cursor: pointer;\n          &:hover {\n            color: @fluroblue;\n          }\n        }\n        &:hover {\n          opacity: 1;\n        }\n      }\n    }\n  }\n\n  #dashboard-settings-panel {\n    position: relative;\n    margin-top: 5px;\n    & > div {\n      display: flex;\n      justify-content: flex-end;\n      & > * { margin: 0px 3px; }\n    }\n    select {\n      margin: 0;\n      height: 34px;\n      padding-top: 1px;\n    }\n  }\n\n  // no widgets - empty dashboard.\n  #no-widgets-container {\n    position: relative;\n    min-height: 150px;\n\n    // background image asset\n    img.bg {\n      left: 0;\n      top: 0;\n      min-width: 100%;\n      min-height: 100%;\n    }\n\n    // no widgets message that sits above image asset\n    .impac-info-message {\n      position: absolute;\n      top: 0;\n      width: 100%;\n\n      .info-text {\n        font-size: @impac-dashboard-info-text-font-size;\n        font-weight: @impac-dashboard-info-text-font-weight;\n        padding:20px;\n        min-height: 115px;\n        color: @impac-dashboard-info-text-color;\n        border-radius: 10px;\n        background-color: @impac-dashboard-info-text-background-color;\n      }\n    }\n  }\n\n  // parent div section for widgets to be housed.\n  #widgets-section {\n    // container for widgets\n    #widgets-container {\n      // Quick-fix to avoid screen flockering when tooltips are appended to body:\n      // min-height will force a scrollbar to appear...\n      min-height: 700px;\n    }\n\n    .placeHolderBox {\n      margin: @impac-padding-between-widgets;\n      height: 267px;\n      width: 300px;\n      float: left;\n      border: @impac-placeholder-border;\n      background: none;\n    }\n  }\n}\n\n// dashboard failed to load message.\n.analytics.load-failed {\n\n  p { font-size: 22px; }\n\n  .second-msg {\n    p {\n      color: @brand-danger;\n      font-size: 14px;\n    }\n  }\n}\n\n// Tooltips are append to body\n.tooltip.impac-widget-selector-tooltip .tooltip-inner.ng-binding {\n  font-size: 14px;\n}\n\n.impac-widget-suggestion .modal-body {\n  input,textarea {\n    width: 100%;\n    color: black;\n  }\n  textarea {\n    height: 150px;\n  }\n  .thanks-message {\n    color: @mgreen;\n  }\n}\n\n// This style applies to dashboard modals, and also the\n// `accounts-custom-calculation/formula.modal.html` modal.\n.modal-footer .loader {\n  .loader-style(@impac-dashboard-loading-spinner)\n}\n\n",".analytics .dashboard-create {\n  .btn-create {\n    background-color: @impac-dashboard-create-button-color;\n  }\n}\n\n.modal.impac-dashboard-create {\n  h1 { font-size: 24px; }\n  .fa.fa-times {\n    float: right;\n    color: #ccc;\n    cursor: pointer;\n  }\n  .control-label { text-align: left; }\n  .modal-footer {\n    .loader {\n      .loader-style(@impac-dashboard-loading-spinner)\n    }\n  }\n}\n","#module__dashboard-selector {\n  a {\n    font-weight: normal;\n  }\n  // dashboard selector template wrapper div\n  & > div:first-child {\n    border-bottom: @impac-dashboard-selector-border;\n  }\n\n  .buttons-bar-row {\n    margin-top: 54px;\n    &.pdf-mode { margin-top: 0px; }\n  }\n\n  // container for dashboard selector 'dropdown' template\n  .buttons-bar {\n    padding: 0;\n    position: relative;\n\n    .btn {\n      float: right;\n      margin: 3px;\n      border-radius: @impac-dashboard-buttons-border-radius;\n    }\n\n    .title-container {\n      h1 {\n        margin: 0px;\n        color: black;\n        cursor: auto;\n      }\n    }\n\n    .dropdown-container {\n      .dashboard-title {\n        color: @impac-dashboard-title-color;\n        display: inline;\n        cursor: pointer;\n        &:hover {\n          color: darken(@impac-dashboard-title-color,10%);\n        }\n        i.fa.fa-pencil {\n          margin-left: 20px;\n          font-size: 14px;\n          &:hover {\n            color: @mgreen;\n          }\n        }\n      }\n      .dashboard-select {\n        margin: 5px 0px 10px 30px;\n        height: auto;\n        border-left: 1px solid @impac-dashboard-title-color;\n        border-bottom: 1px solid @impac-dashboard-title-color;\n        width: 300px;\n        background-color: @lightgray;\n        cursor: pointer;\n        .option {\n          color: @impac-dashboard-title-label-color;\n          white-space: nowrap;\n          &:hover {\n            background-color: @impac-widget-background-color;\n          }\n          &.dashboard-create {\n            height: 33px;\n            .btn {\n              float: none;\n              width: 100%;\n              text-align: left;\n              margin: 0px;\n              border-radius: 0px;\n            }\n          }\n          i.fa.fa-pencil {\n            float: right;\n            padding-top: 7px;\n            text-align: center;\n            width: 15%;\n            height: 30px;\n            &:hover {\n              color: darken(@impac-dashboard-title-color,10%);\n            }\n          }\n          span.name {\n            width: 85%;\n            height: 30px;\n            display: inline-block;\n            padding: 5px 10px 5px 10px;\n          }\n        }\n      }\n      .change-name {\n        position: absolute;\n        top: 30px;\n        left: 20px;\n        width: 60%;\n        background-color: rgb(23, 38, 45);\n        color: white;\n        padding: 10px;\n        border-radius: 4px;\n        text-align: center;\n        .box-shadow(0px 0px 25px 4px black);\n        z-index: 50;\n        border: solid 1px @impac-widget-background-color;\n\n        .form-control {\n          height: 25px;\n          margin-bottom: 10px;\n        }\n      }\n      .data-source-label {\n        color: @impac-dashboard-source-color;\n        padding-left: 3px;\n        margin: 0px;\n      }\n    }\n\n    .loader-container {\n      padding-left: 10px;\n      .loading-spinner {\n        .loader-style();\n        font-size: 40px;\n      }\n    }\n  }\n\n  // angular bootstrap tabs & pills\n  .nav-tabs {\n    border-bottom: 0;\n  }\n  .nav.nav-tabs,\n  .nav.nav-pills {\n\n    // add new tab\n    li:last-child > a {\n      padding-right: 15px;\n      tab-heading a {\n        position: static;\n      }\n    }\n  }\n\n  // TABS\n  .nav.nav-tabs {\n    // tab\n    li > a {\n      padding: @impac-dashboard-selector-tabs-padding;\n      margin: @impac-dashboard-selector-tabs-margin;\n      background-color: @impac-dashboard-selector-tabs-background-color;\n      border: @impac-dashboard-selector-border;\n      color: @impac-dashboard-selector-tabs-color;\n    }\n    // active tab\n    li.active > a {\n      background-color: @impac-dashboard-selector-tabs-active-background-color;\n      color: @impac-dashboard-selector-tabs-active-color;\n    }\n    // add new tab\n    li:last-child > a {\n      // padding-left: 5px;\n    }\n    li:last-child.active > a {\n      background-color: @impac-dashboard-selector-tabs-background-color;\n    }\n  }\n\n  // PILLS\n  // TODO: Add less variables for customisation.\n  .nav.nav-pills {\n    // tab\n    li > a {\n      min-width: 0px;\n      padding-right: 8px;\n    }\n    // add a new tab\n    li:last-child tab-heading a {\n      margin-left: 2px;\n    }\n    // add a new tab\n    li:last-child.active > a {\n      background-color: #f4f4f4;\n    }\n  }\n  // tab icons\n  tab-heading a.close-link {\n    border-bottom: 0px solid;\n    margin-left: 12px;\n    position: relative;\n    top: -9px;\n    right: 1px;\n    color: @impac-dashboard-selector-tabs-color;\n  }\n  ////////\n}\n","dashboard-templates-selector {\n  .templates-header {\n    display: flex;\n    .templates-toggle {\n      display: flex;\n      flex-grow: 1;\n      justify-content: flex-end;\n      font-size: 20px;\n      i.fa {\n        cursor: pointer;\n        &.fa-toggle-on {\n          color: @impac-widget-link-color;\n        }\n      }\n    }\n  }\n  .templates {\n    border: 1px solid #ccc;\n    box-shadow: inset 0px 0px 1px 0px #ccc;\n    height: 130px;\n    overflow: auto;\n    border-radius: 2px;\n\n    .template {\n      padding: 5px 10px;\n      color: @impac-widget-text-color;\n      border-bottom: 1px solid #ececec;\n      &:hover {\n        cursor: pointer;\n        background-color: lighten(@impac-dashboard-templates-selected-background-color, 20%);\n      }\n      &.selected {\n        background-color: @impac-dashboard-templates-selected-background-color;\n      }\n    }\n  }\n}\n",".analytics .impac-kpi .kpi {\n  position: relative;\n  max-width: 220px;\n  min-height: @kpi-max-height;\n  max-height: @kpi-max-height;\n  background-color: @kpi-background-color;\n  margin: 10px 0 10px 0;\n  border-bottom: 1px solid @kpi-background-color;\n  transition: all .2s ease-in;\n\n  @media screen and (max-width: 768px) {\n    margin-left: auto;\n    margin-right: auto;\n  }\n\n  &.triggered, &.add:hover {\n    border-bottom: @kpi-triggered-border-bottom;\n  }\n\n  &.add {\n    .kpi-text {\n      .emphasis { visibility: hidden; }\n    }\n  }\n\n  &.add:hover {\n    cursor: pointer;\n    .top-line { background-color: @kpi-top-line-triggered-background-color; }\n    .kpi-text {\n      color: @kpi-text-triggered-color;\n      .emphasis { visibility: visible; }\n    }\n    .kpi-icon {\n      color: @kpi-icon-triggered-color;\n      .fa-plus:before {\n        content: \"\\f00c\";\n      }\n    }\n  }\n\n  &.editing {\n    min-height: @kpi-max-height + @kpi-editing-max-height;\n  }\n\n  &:hover { cursor: default; }\n\n  &.static {\n    .kpi-value {\n      display: block;\n      font-size: 14px;\n      font-weight: 700;\n    }\n  }\n\n  .top-line {\n    width: 100%;\n    position: relative;\n    cursor: move;\n    padding: 9px 9px 0px 12px;\n    border-bottom: none;\n    min-height: @kpi-top-line-height;\n    box-shadow: @kpi-top-line-box-shadow;\n    display: -webkit-box;\n    display: -webkit-flex;\n    display: -ms-flexbox;\n    display: flex;\n    -webkit-box-orient: horizontal;\n    -webkit-box-direction: normal;\n    -webkit-flex-direction: row;\n    -ms-flex-direction: row;\n    flex-direction: row;\n    margin-bottom: 5px;\n    background-color: @kpi-top-line-background-color;\n    &.triggered { background-color: @kpi-top-line-triggered-background-color; }\n    transition: background .2s ease-in;\n  }\n\n  .kpi-content {\n    max-height: @kpi-max-height - 5px;\n    &.editing {\n      min-height: @kpi-max-height + @kpi-editing-max-height - @kpi-content-editing-height-buffer;\n      .scrollable();\n    }\n  }\n\n  .kpi-show {\n    white-space: normal;\n    padding: 10px;\n    // small fix for iphone 6 and smaller\n    @media screen and (max-width: 380px) {\n      padding: 10px 3px;\n    }\n\n    .emphasis {\n      white-space: nowrap;\n      overflow: hidden;\n      text-overflow: ellipsis;\n\n      .real-value { color: #676767; }\n    }\n\n    .caption {\n      white-space: nowrap;\n      overflow: hidden;\n      text-overflow: ellipsis;\n    }\n\n    .kpi-text {\n      & > span { display: block; }\n      padding: 7px 0;\n      color: @kpi-text-color;\n      transition: color .2s ease-in;\n      &.triggered { color: @kpi-text-triggered-color; }\n\n      .caption {\n        font-size: 11px;\n        padding-bottom: 2px;\n      }\n\n      @media screen and (max-width: 465px) {\n        .caption { font-size: 10px; }\n        .emphasis { font-size: 11px; }\n      }\n    }\n\n    .kpi-icon {\n      font-size: 16px;\n      padding: 10px 0;\n      color: @kpi-icon-color;\n      transition: color .2s ease-in;\n      &.triggered { color: @kpi-icon-triggered-color; }\n      @media screen and (max-width: 465px) {\n        font-size: 12px;\n        padding: 16px 0;\n      }\n    }\n  }\n\n  .kpi-edit {\n\n    a { color: white; }\n\n    .kpi-name {\n      text-align: center;\n      margin-bottom: 5px;\n      h6 {\n        margin: 0 0 5px 0;\n      }\n    }\n\n    .real-value {\n      text-transform: uppercase;\n      font-size: 10px;\n      text-align: center;\n    }\n\n    .alert-caption {\n      text-align: center;\n      font-size: 11px;\n      background: @kpi-negative-alert-label-background-color;\n      border-radius: 3px;\n      width: 100%;\n      margin: 0 auto 5px auto;\n      box-shadow: none;\n      padding: 2px;\n      color: white;\n    }\n\n\n    .kpi-target-watchable,\n    .kpi-target-unit {\n      text-transform: uppercase;\n      font-weight: 500;\n      font-size: 11px;\n    }\n\n    .kpi-target-watchable {\n      margin-bottom: 20px;\n      color: lighten(@kpi-top-line-background-color, 5%);\n    }\n\n    .kpi-target-unit {\n      position: absolute;\n      top: 6px;\n      right: 0;\n      color: lighten(@kpi-top-line-background-color, 10%);\n    }\n\n    .param-name {\n      .small();\n    }\n\n    .btn.btn-xs {\n      margin-top: 4px;\n    }\n  }\n\n  .kpi-edit,\n  .kpi-no-data {\n    .impac-material(@kpi-settings-focus-color, @kpi-settings-error-color);\n  }\n\n  button.kpi-alerts.im-fab.im-primary {\n    position: absolute;\n    top: -12px;\n    right: 15px;\n    width: 22px;\n    height: 22px;\n    font-size: 13px;\n    background: @kpi-settings-alert-config-background;\n    &:hover {\n      backgroud: @kpi-settings-alert-config-background-hover;\n    }\n  }\n\n  button.kpi-remove.im-fab.im-warn {\n    position: absolute;\n    top: -12px;\n    right: -11px;\n    width: 22px;\n    height: 22px;\n    font-size: 13px;\n    background: @kpi-settings-remove-background;\n    &:hover {\n      background: @kpi-settings-remove-background-hover;\n    }\n  }\n\n  .kpi-data-loader {\n    width: 100%;\n    min-height: 95px;\n  }\n}\n\n.analytics kpis-bar > .key-stats .kpi {\n  min-height: 80px;\n}\n","/* ************************************************************************ */\n/*                                IMPAC MATERIAL\n/*                  ------------------------------------------\n** Mixin material styled form inputs, overriding bootstrap's ungodly round-ness.\n/* ************************************************************************ */\n/* DEMO HTML - use this html to test all impac material features.\n<form>\n  <div class=\"im-form-group\">\n    <select>\n      <option>Value 1</option>\n      <option>Value 2</option>\n    </select>\n    <label for=\"select\" class=\"im-control-label\">Selectbox</label><i class=\"im-bar\"></i>\n  </div>\n  <div class=\"im-form-group\">\n    <input type=\"text\" required/>\n    <label for=\"input\" class=\"im-control-label\">Textfield</label><i class=\"im-bar\"></i>\n    <div class=\"im-messages\">\n      <p>This is an error message</p>\n    </div>\n  </div>\n  <div class=\"im-form-inline\">\n    <div class=\"im-form-group\">\n      <input type=\"text\" required/>\n      <label for=\"input\" class=\"im-control-label\">Inline</label><i class=\"im-bar\"></i>\n    </div>\n    <div class=\"im-form-group\">\n      <input type=\"text\" required/>\n      <label for=\"input\" class=\"im-control-label\">Inline</label><i class=\"im-bar\"></i>\n    </div>\n  </div>\n  <div class=\"im-form-group\">\n    <textarea required></textarea>\n    <label for=\"textarea\" class=\"im-control-label\">Textarea</label><i class=\"im-bar\"></i>\n  </div>\n  <div class=\"im-checkbox\">\n    <label>\n      <input type=\"checkbox\" checked=\"checked\"/><i class=\"im-helper\"></i>I'm the label from a checkbox\n    </label>\n  </div>\n  <div class=\"im-checkbox\">\n    <label>\n      <input type=\"checkbox\"/><i class=\"im-helper\"></i>I'm the label from a checkbox\n    </label>\n  </div>\n  <div class=\"im-form-radio\">\n    <div class=\"im-radio\">\n      <label>\n        <input type=\"radio\" name=\"radio\" checked=\"checked\"/><i class=\"im-helper\"></i>I'm the label from a radio button\n      </label>\n    </div>\n    <div class=\"im-radio\">\n      <label>\n        <input type=\"radio\" name=\"radio\"/><i class=\"im-helper\"></i>I'm the label from a radio button\n      </label>\n    </div>\n  </div>\n  <div class=\"im-checkbox\">\n    <label>\n      <input type=\"checkbox\"/><i class=\"im-helper\"></i>I'm the label from a checkbox\n    </label>\n  </div>\n  <button type=\"button\" class=\"im-fab im-primary\"><i>♥</i></button>\n  <button type=\"button\" class=\"im-fab im-warn\"><i>♥</i></button>\n</form>\n*/\n\n@body-bg: #fff;\n\n// Shadows\n@shadow-inset: inset 0 2px 2px 0 rgba(0,0,0,.14);\n@shadow-0: 0 0 1px rgba(0, 0, 0, 0);\n@shadow-2: 0 2px 2px 0 rgba(0,0,0,.14),0 3px 1px -2px rgba(0,0,0,.2),0 1px 5px 0 rgba(0,0,0,.12);\n@shadow-3: 0 3px 4px 0 rgba(0,0,0,.14),0 3px 3px -2px rgba(0,0,0,.2),0 1px 8px 0 rgba(0,0,0,.12);\n@shadow-4: 0 4px 5px 0 rgba(0,0,0,.14),0 1px 10px 0 rgba(0,0,0,.12),0 2px 4px -1px rgba(0,0,0,.2);\n@shadow-6: 0 6px 10px 0 rgba(0,0,0,.14),0 1px 18px 0 rgba(0,0,0,.12),0 3px 5px -1px rgba(0,0,0,.2);\n@shadow-8: 0 8px 10px 1px rgba(0,0,0,.14),0 3px 14px 2px rgba(0,0,0,.12),0 5px 5px -3px rgba(0,0,0,.2);\n\n// Font Sizes\n@im-font-size: 1.25rem;\n@im-active-font-size: @im-font-size * 0.8;\n@im-active-top: -@im-font-size;\n\n// Margin & Paddings\n@im-gap: @im-font-size * .7;\n@im-spacer: @im-font-size / 8;\n@im-fieldset-margin: 0 0 @im-gap * 2;\n@im-checkbox-gap: @im-font-size * 2;\n@im-checkbox-top: 0;\n@im-radio-margin: @im-font-size / -4;\n\n// Colors\n@im-border-color: #999;\n@im-label-color: lighten(@im-border-color, 10%);\n@im-active-color: darken(@im-border-color, 10%);\n\n// Animation\n@im-transition-speed: 0.28s;\n\n.impac-material (@im-focus-color: #337ab7, @im-error-color: #d9534f, @im-input-color: #333) {\n  /* Flatten der Bootstrap */\n  .well, .navbar-inner, .popover, .btn, .tooltip, input, select, textarea, pre, .progress, .modal, .add-on, .alert, .table-bordered, .nav>.active>a, .dropdown-menu, .tooltip-inner, .badge, .label, .img-polaroid {\n    -moz-box-shadow: none !important;\n    -webkit-box-shadow: none !important;\n    box-shadow: none !important;\n    -webkit-border-radius: 0px !important;\n    -moz-border-radius: 0px !important;\n    border-radius: 0px !important;\n    border-collapse: collapse !important;\n    background-image: none !important;\n  }\n\n  body,\n  input,\n  select,\n  textarea {\n    box-sizing: border-box;\n\n    &::after,\n    &::before {\n      box-sizing: border-box;\n    }\n  }\n\n  input[type=number]::-webkit-inner-spin-button,\n  input[type=number]::-webkit-outer-spin-button {\n    -webkit-appearance: none;\n    margin: 0;\n  }\n\n  a:hover {\n    text-decoration: none;\n  }\n\n  // The Styles for the form\n  fieldset {\n    margin: @im-fieldset-margin;\n    padding: 0;\n    border: none;\n  }\n\n  .im-form-radio,\n  .im-form-group {\n    position: relative;\n    margin-top: (@im-gap * 1.5);\n    margin-bottom: (@im-gap * 1.5);\n  }\n\n  .im-form-inline {\n    display: flex;\n    flex-direction: row;\n    box-sizing: border-box;\n\n    > .im-form-group {\n      display: block;\n      flex: 1;\n      position: relative;\n      vertical-align: middle;\n      margin-left: (@im-gap * .2);\n      margin-right: (@im-gap * .2);\n    }\n\n    > .btn {\n      display: inline-block;\n      margin-bottom: 0;\n    }\n  }\n\n  .im-form-group {\n    input {\n      height: (@im-font-size * 1.9);\n    }\n\n    textarea {\n      resize: none;\n    }\n\n    select {\n      width: 100%;\n      font-size: @im-font-size;\n      height: (@im-font-size * 1.6);\n      padding: @im-spacer @im-spacer (@im-spacer / 2);\n      background: none;\n      border: none;\n      line-height: 1.6;\n      box-shadow: none;\n    }\n\n    .im-control-label {\n      position: absolute;\n      top: (@im-font-size / 4);\n      pointer-events: none;\n      padding-left: @im-spacer;\n      z-index: 1;\n      color: @im-label-color;\n      font-size: @im-font-size;\n      font-weight: normal;\n      transition: all @im-transition-speed ease;\n    }\n\n    .im-bar {\n      position: relative;\n      border-bottom: (@im-font-size / 16) solid @im-border-color;\n      display: block;\n\n      &::before {\n        content: '';\n        height: (@im-font-size / 8);\n        width: 0;\n        left: 50%;\n        bottom: (@im-font-size / -16);\n        position: absolute;\n        background: @im-focus-color;\n        transition: left @im-transition-speed ease, width @im-transition-speed ease;\n        z-index: 2;\n      }\n    }\n\n    input,\n    textarea {\n      display: block;\n      background: none;\n      padding: @im-spacer @im-spacer (@im-spacer / 2);\n      font-size: @im-font-size;\n      border-width: 0;\n      border-color: transparent;\n      line-height: 1.9;\n      width: 100%;\n      color: transparent;\n      transition: all @im-transition-speed ease;\n      box-shadow: none;\n    }\n\n    input[type=\"file\"] {\n      line-height: 1;\n\n      ~ .im-bar {\n        display: none;\n      }\n    }\n\n    select,\n    input:focus,\n    input:valid,\n    input.form-file,\n    input.has-value,\n    textarea:focus,\n    textarea:valid,\n    textarea.form-file,\n    textarea.has-value {\n      color: @im-input-color;\n\n      ~ .im-control-label {\n        font-size: @im-active-font-size;\n        color: @im-active-color;\n        top: @im-active-top;\n        left: 0;\n      }\n    }\n\n    select,\n    input,\n    textarea {\n      &:focus {\n        outline: none;\n\n        ~ .im-control-label {\n          color: @im-focus-color;\n        }\n\n        ~ .im-bar {\n          &::before {\n            width: 100%;\n            left: 0;\n          }\n        }\n      }\n    }\n  }\n\n  // Radio & Checkbox\n  .im-checkbox,\n  .im-form-radio {\n    label {\n      position: relative;\n      cursor: pointer;\n      padding-left: @im-checkbox-gap;\n      text-align: left;\n      color: @im-input-color;\n      display: block;\n    }\n\n    input {\n      width: auto;\n      opacity: 0.00000001;\n      position: absolute;\n      left: 0;\n    }\n  }\n\n  .im-radio {\n    margin-bottom: @im-font-size;\n\n    .im-helper {\n      position: absolute;\n      top: @im-radio-margin;\n      left: @im-radio-margin;\n      cursor: pointer;\n      display: block;\n      font-size: @im-font-size;\n      user-select: none;\n      color: @im-border-color;\n\n      // TODO: improve radio transition - ripple effect like angular md would be cool :)\n      &::before,\n      &::after {\n        content: '';\n        position: absolute;\n        left: 0;\n        top: 0;\n        margin: (@im-spacer * 2);\n        width: @im-font-size;\n        height: @im-font-size;\n        transition: transform @im-transition-speed ease;\n        border-radius: 50%;\n        border: (@im-font-size / 8) solid currentColor;\n      }\n\n      &::after {\n        transform: scale(0);\n        background-color: @im-focus-color;\n        border-color: @im-focus-color;\n      }\n    }\n\n    label:hover .im-helper {\n      color: @im-focus-color;\n    }\n\n    input:checked {\n      ~ .im-helper {\n        &::after {\n            transform: scale(0.5);\n        }\n        &::before {\n          color: @im-focus-color;\n        }\n      }\n    }\n  }\n\n  .im-checkbox {\n    margin-top: (@im-gap * 2);\n    margin-bottom: @im-font-size;\n\n    .im-helper {\n      color: @im-border-color;\n      position: absolute;\n      top: @im-checkbox-top;\n      left: 0;\n      width: @im-font-size;\n      height: @im-font-size;\n      z-index: 0;\n      border: (@im-font-size / 8) solid currentColor;\n      border-radius: (@im-font-size / 16);\n      transition: border-color @im-transition-speed ease;\n\n      &::before,\n      &::after {\n        position: absolute;\n        height: 0;\n        width: (@im-font-size * 0.2);\n        background-color: @im-focus-color;\n        display: block;\n        transform-origin: left top;\n        border-radius: (@im-font-size / 4);\n        content: '';\n        transition: opacity @im-transition-speed ease, height 0s linear @im-transition-speed;\n        opacity: 0;\n      }\n\n      &::before {\n        top: (@im-font-size * 0.65);\n        left: (@im-font-size * 0.38);\n        transform: rotate(-135deg);\n        box-shadow: 0 0 0 (@im-font-size / 16) @body-bg;\n      }\n\n      &::after {\n        top: (@im-font-size * 0.3);\n        left: 0;\n        transform: rotate(-45deg);\n      }\n    }\n\n    label:hover .im-helper {\n      color: @im-focus-color;\n    }\n\n    input:checked {\n      ~ .im-helper {\n        color: @im-focus-color;\n\n        // TODO: improve checked transition.\n        &::after,\n        &::before {\n          opacity: 1;\n          transition: height @im-transition-speed ease;\n        }\n\n        &::after {\n          height: (@im-font-size / 2);\n        }\n\n        &::before {\n          height: (@im-font-size * 1.2);\n          transition-delay: @im-transition-speed;\n        }\n      }\n    }\n  }\n\n  .im-radio + .im-radio,\n  .im-checkbox + .im-checkbox {\n    margin-top: @im-font-size;\n  }\n\n  // Add class onto ng-messages div\n  .im-messages {\n    font-size: @im-font-size / 1.2;\n    color: @im-error-color;\n    overflow: hidden;\n    transition: all @im-transition-speed cubic-bezier(.55,0,.55,.2);\n    opacity: 0;\n    margin-top: 0;\n    padding-top: 5px;\n  }\n\n  .has-error {\n    .legend.legend,\n    &.im-form-group .im-control-label.im-control-label {\n      color: @im-error-color;\n    }\n\n    &.im-form-group,\n    &.im-checkbox,\n    &.im-radio,\n    &.im-form-radio {\n      .im-messages,\n      .im-helper {\n        color: @im-error-color;\n        opacity: 1;\n      }\n    }\n\n    .im-bar {\n      &::before {\n        background: @im-error-color;\n        left: 0;\n        width: 100%;\n      }\n    }\n  }\n\n  .im-button {\n    position: relative;\n    background: lighten(@im-focus-color, 10%);\n    border: 0;\n    font-size: (@im-font-size * 1.1);\n    color: @im-input-color;\n    margin: (@im-gap * .8) 0;\n    padding: (@im-gap / 2) (@im-gap * 2);\n    border-radius: 3px;\n    cursor: pointer;\n    overflow: hidden;\n    box-shadow: @shadow-2;\n\n    span {\n      color: #fff;\n      position: relative;\n      z-index: 1;\n    }\n\n    &:hover {\n      transition: background .1s ease-in;\n      background: darken(@im-focus-color, 5%);\n    }\n\n    &:active {\n      box-shadow: @shadow-inset;\n    }\n\n    a:focus,\n    &:focus {\n      outline: none;\n      text-decoration: none;\n    }\n  }\n\n  button.im-fab {\n    position: relative;\n    height: 46px;\n    width: 46px;\n    flex: 0 0 56px;\n    display: inline-block;\n    padding: 0;\n    margin: 4px;\n    border: 0;\n    border-radius: 100%;\n    overflow: hidden;\n    font-size: 20px;\n    box-shadow: @shadow-4;\n    color: white;\n    &:focus {\n      outline: 0;\n    }\n    &:active {\n      box-shadow: @shadow-inset;\n    }\n    &.im-primary {\n      background: @im-focus-color;\n      &:hover {\n        transition: background .1s ease-in;\n        background: darken(@im-focus-color, 5%);\n      }\n    }\n    &.im-warn {\n      background: @im-error-color;\n      &:hover {\n        transition: background .1s ease-in;\n        background: darken(@im-error-color, 5%);\n      }\n    }\n  }\n\n}\n",".analytics kpis-bar > .kpis {\n  position: relative;\n  .actions {\n    margin-bottom: 12px;\n    @media screen and (max-width: 675px) {\n      position: relative;\n    }\n\n    .impac-material(@kpi-settings-focus-color, @kpi-settings-error-color);\n\n    a { color: white; }\n\n    button.im-fab.add-kpis,\n    button.im-fab.edit-kpis,\n    button.im-fab.toggle-show-content {\n      position: absolute;\n      width: 40px;\n      height: 40px;\n      font-size: 18px;\n      transition: all 0.28s ease-in;\n      &.im-primary {\n        background: #4c4749;\n        &.disabled {\n          background: #b2b5c1;\n          cursor: not-allowed;\n          a { cursor: not-allowed; }\n        }\n        &:hover:not(.disabled) {\n          background: black;\n        }\n      }\n    }\n\n    button.im-fab.toggle-show-content {\n      top: -15px;\n      right: -15px;\n      z-index: 10;\n      @media screen and (max-width: 675px) {\n        top: -30px;\n        right: -14px;\n        bottom: 0;\n      }\n    }\n\n    button.im-fab.add-kpis {\n      top: 30px;\n      right: -15px;\n      z-index: 10;\n      @media screen and (max-width: 675px) {\n        top: -30px;\n        right: 33px;\n        bottom: 0;\n      }\n    }\n\n    button.im-fab.edit-kpis {\n      top: 75px;\n      right: -15px;\n      z-index: 10;\n      &.editing {\n        background: @kpi-settings-focus-color;\n        &:hover:not(.disabled) {\n          background: lighten(@kpi-settings-focus-color, 15%);\n        }\n      }\n      @media screen and (max-width: 675px) {\n        top: -30px;\n        right: 79px;\n        bottom: 0;\n      }\n    }\n  }\n\n  .content-buttons {\n    position: absolute;\n    top: 0;\n    right: 0;\n  }\n\n  .content {\n    padding: 15px;\n    background-color: @kpis-bar-background-color;\n    box-shadow: @kpis-bar-box-shadow;\n\n    @media screen and (min-width: 725px) {\n      padding: 0 60px;\n    }\n\n    @media screen and (max-width: 675px) {\n      margin-top: 25px;\n    }\n\n    .impac-kpi {\n      .column-gutter(5px);\n\n      @media screen and (min-width: 1200px) {\n        padding-left: 20px;\n        padding-right: 20px;\n      }\n\n      .kpi.add {\n        .kpi-show .caption {\n          white-space: inherit;\n        }\n      }\n    }\n\n\n    .title {\n      .text-center {\n        line-height: 3;\n        font-variant: small-caps;\n        font-size: larger;\n      }\n      .badge {\n        position: absolute;\n        top: 8px;\n        left: -10px;\n        background-color: #d1e55c;\n        color: #4f5959;\n        box-shadow: 0px 1px 3px -1px;\n      }\n      .no-kpi-templates {\n        color: #afadb5;\n        font-weight: 500;\n      }\n    }\n\n    .add-bar {\n      border-bottom: dashed 1px;\n    }\n\n    .kpi-loader {\n      display: flex;\n      align-items: center;\n      justify-content: center;\n      min-height: @kpi-max-height + 20px;\n    }\n\n    .dates-picker-container {\n      width: 40%;\n      margin: 0 auto;\n\n      .sdp-from-label,\n      .sdp-to-label {\n        text-transform: uppercase;\n        font-weight: 400;\n      }\n    }\n  }\n}\n\n.analytics kpis-bar {\n  display: block;\n}\n\n.analytics kpis-bar > .key-stats {\n  background-color: white;\n  padding: 5px 0px;\n}\n\n.analytics.pdf-mode kpis-bar > .kpis .actions { display: none; }\n",".widget-item {\n  transition: width 0.3s;\n  padding: @impac-padding-between-widgets;\n  &.pdf-mode {\n    width: 100%;\n    padding: ~\"@{impac-padding-between-widgets} 0px\";\n  }\n}\n\n.widget-item .top-line {\n  position: relative;\n  cursor: move;\n  background-color: @impac-widget-title-bg;\n  padding: 9px 9px 0px 12px;\n  border-radius: @impac-widget-title-border-radius;\n  border: @impac-widget-border;\n  border-bottom: none;\n  min-height: 41px;\n  .box-shadow(0px 1px 8px -4px);\n\n  display: flex;\n  flex-direction: row;\n\n  z-index: 4;\n}\n\n.widget-item {\n  .content {\n    position: relative;\n    padding: 9px;\n    border-radius: @impac-widget-content-border-radius;\n    border: @impac-widget-border;\n    border-top: none;\n    background-color: @impac-widget-background-color;\n\n    vertical-align: top;\n    .box-shadow(0px 1px 8px -4px);\n    .short-widget();\n\n    .edit {\n      .edit-panel-style();\n    }\n\n    &.accessible {\n      height: auto !important;\n      min-height: 250px !important;\n      max-height: auto !important;\n    }\n\n    // Avoid content to leak out of widget's box\n    .content-template-wrapper {\n      height: 100%;\n      overflow: auto;\n      overflow-x: hidden;\n    }\n  }\n\n  &.pdf-mode .content {\n    height: 100% !important;\n    min-height: 250px !important;\n    max-height: none !important;\n    .collapse {\n      display: inherit;\n    }\n    .fa-plus-square-o:before {\n      content: \"\\f147\";\n    }\n    .legend {\n      max-height: none !important;\n    }\n    .chart-container {\n      max-height: none;\n    }\n    .widget-lines-container {\n      max-height: none !important;\n    }\n    .data-not-found .message {\n      position: inherit;\n      width: 100%;\n    }\n  }\n}\n\n.widget-item.pdf-mode .include-to-pdf{\n  &.title {\n    position: absolute;\n    width: ~\"calc(100% - 2*@{impac-padding-between-widgets} )\";\n    z-index: 3;\n    padding-right: 1px;\n    h6 {\n      padding: 10px;\n      background-color: #FFC928;\n      text-align: center;\n      margin: 0;\n    }\n  }\n  &.tick {\n    i {\n      position: absolute;\n      top: 35%;\n      left: 46%;\n      font-size: 100px;\n      opacity: .5;\n      z-index: 2;\n      color: black;\n    }\n  }\n  .widget-hover {\n    position: absolute;\n    width: 100%;\n    height: 100%;\n    padding: 9px;\n    top: 0;\n    right: 0;\n    -webkit-transition: all ease .5s;\n    -moz-transition: all ease .5s;\n    transition: all ease .5s;\n    z-index: 1;\n    &:hover {\n      opacity: .5;\n      background: #CCCFD0;\n    }\n  }\n}\n\n// Fix overflow for large sums/text in .widget-lines-container tables\n.widget-item .widget-lines-container .widget-line > [class*='col-'] {\n  overflow-wrap: break-word;\n}\n",".analytics .widget-item .content .data-not-found,\n.analytics .kpi .data-not-found {\n  text-align: center;\n  font-size: 13px;\n  color: @impac-widget-popup-message-text-color;\n\n  .overlay {\n    background-color: white;\n    position: absolute;\n    height: ~\"calc(100% - 4px)\";\n    width: ~\"calc(100% - 4px)\";\n    top: 2px;\n    left: 2px;\n    opacity: 0.6;\n    z-index: 3;\n  }\n\n  .message {\n    position: absolute;\n    top: 125px;\n    left: 50%;\n    padding-bottom: 10px;\n    transform: translate(-50%, -50%);\n    width: 85%;\n    background-color: @impac-widget-popup-message-background-color;\n    border-radius: 4px;\n    box-shadow: 0px 0px 25px 0px;\n    z-index: 4;\n\n    .title {\n      padding: 2px;\n      background-color: @impac-widget-popup-title-background-color;\n      color: @impac-widget-popup-title-text-color;\n      margin: -1px -1px 10px -1px;\n      text-transform: uppercase;\n    }\n\n    p {\n      margin-left: 5px;\n      margin-right: 5px;\n    }\n\n    .btn { margin-top: 5px; }\n  }\n\n  .example {\n    position: absolute;\n    bottom: 0px;\n    left: 0px;\n    width: 100%;\n    color: @impac-widget-popup-title-text-color;\n    background-color: @impac-widget-popup-title-background-color;\n    padding: 3px;\n    z-index: 6;\n\n    a {\n      font-weight: normal;\n      color: @impac-widget-demo-data-link-color;\n    }\n  }\n}\n\n.analytics .kpi .data-not-found {\n  .message {\n    width: 90%;\n    padding-bottom: 0px;\n    border: solid 1px silver;\n    box-shadow: none;\n    p { margin: 5px; }\n  }\n  .overlay, .title, .btn, .example { display: none; }\n}\n","#duplicate-transactions-list {\n  .top {\n    height: 40px;\n    a.back-link { font-weight: normal; }\n    .pagination { margin: 0px; }\n  }\n\n  .table-striped {\n    tr.origin:nth-of-type(odd) {\n      background-color: #f9f9f9;\n    }\n  }\n\n  .table-container {\n    max-height: ~\"calc(@{impac-big-widget-size} - 60px)\";\n    overflow: auto;\n\n    div[uib-datepicker-popup-wrap] {\n      display: inline-block;\n    }\n\n    input.btn.btn-xs { margin-top: -2px; }\n    button.btn.reset-date { margin-top: -2px; }\n    .fa.fa-times {\n      color: @brand-danger;\n      cursor: pointer;\n    }\n\n    tr.total {\n      font-weight: bold;\n      &.invoices {\n        background-color: lighten(@impac-positive, 20%);\n      }\n      &.bills {\n        background-color: lighten(@impac-negative, 20%);\n      }\n    }\n  }\n}\n","#transactions-add {\n  .widget-popup();\n  .message {\n    top: 30px;\n    left: 35%;\n    width: 30%;\n    .form {\n      padding: 0px 10px;\n      > label,\n      .schedulable-section > label {\n        padding-top: 10px;\n        font-weight: normal;\n        margin-bottom: 3px;\n      }\n      input.form-control, select.form-control {\n        width: 90%;\n        border-radius: 2px;\n        height: 28px;\n        font-size: 13px;\n      }\n      .btn-group {\n        display: block;\n        min-height: 22px;\n        select {\n          border-radius: 2px;\n          height: 28px;\n          margin-top: 0px;\n        }\n      }\n      .disable {\n        color: #888888;\n        font-style: italic;\n      }\n      .never-disable {\n        color: black;\n        font-style: normal;\n      }\n      .repeat-btn {\n        margin-top: 30px;\n        input[type=\"checkbox\"] {\n          vertical-align: text-bottom;\n          margin: 0px;\n        }\n        select { height: 22px; }\n        .btn {\n          float: none;\n          border-color: #888888;\n        }\n      }\n      .schedulable-section {\n        padding: 5px;\n        border: solid 1px silver;\n        margin-top: 0px;\n        background-color: white;\n        .badge {\n          font-weight: normal;\n          background-color: #888888;\n        }\n        .interval-field {\n          width: 40px;\n        }\n        .btn-group {\n          margin-left: 10px;\n          select { height: 22px; }\n          .btn {\n            float: none;\n            border-color: #888888;\n          }\n        }\n      }\n    }\n    .bottom {\n      margin-top: 20px;\n    }\n  }\n}\n","#transactions-list {\n  .top {\n    height: 40px;\n    position: relative;\n\n    .back { position: absolute; }\n    .resource-type {\n      position: absolute;\n      left: ~\"calc(50% - 98px)\";\n      @media (max-width: @screen-xs-max) {\n        left: unset;\n        right: 0;\n      }\n    }\n    .btn-group { display: flex; }\n  }\n\n  .bottom {\n    height: 40px;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    .pagination { margin: 0px; }\n  }\n\n  .table-container {\n    max-height: ~\"calc(@{impac-big-widget-size} - 100px)\";\n    overflow: auto;\n    width: 100%;\n\n    div[uib-datepicker-popup-wrap] {\n      display: inline-block;\n    }\n\n    input.btn.btn-xs { margin-top: -2px; }\n    button.btn.reset-date { margin-top: -2px; }\n\n    .actions {\n      cursor: pointer;\n      .fa.fa-times { color: @brand-danger; }\n    }\n\n    tr.total {\n      font-weight: bold;\n      &.invoices {\n        background-color: lighten(#8eab71, 20%);\n      }\n      &.bills {\n        background-color: lighten(#c76379, 20%);\n      }\n    }\n\n    td > .expected-payment-date {\n      display: flex;\n      .reset-date { margin-left: 3px; }\n    }\n  }\n}\n","#trends-list {\n  .top {\n    height: 40px;\n    a.back-link { font-weight: normal; }\n    .pagination { margin: 0px; }\n  }\n\n  .table-container {\n    max-height: ~\"calc(@{impac-big-widget-size} - 60px)\";\n    overflow: auto;\n\n    div[uib-datepicker-popup-wrap] {\n      display: inline-block;\n    }\n\n    input.btn.btn-xs { margin-top: -2px; }\n    button.btn.reset-date { margin-top: -2px; }\n  }\n}\n","#trends-add {\n  .widget-popup();\n  .message {\n    top: 30px;\n    left: 35%;\n    width: 30%;\n    .form {\n      padding: 0px 10px;\n      > label {\n        padding-top: 10px;\n        font-weight: normal;\n        margin-bottom: 3px;\n      }\n      input.form-control {\n        width: 90%;\n        border-radius: 2px;\n        height: 28px;\n        font-size: 13px;\n      }\n      .btn-group {\n        display: block;\n        min-height: 22px;\n        margin-top: 10px;\n        > .btn {\n          float: none;\n        }\n        input[type=\"radio\"] {\n          margin: 4px 0 10px;\n        }\n      }\n    }\n    .bottom {\n      margin-top: 20px;\n    }\n  }\n}",".analytics .dashboard-settings.currency {\n  text-align: right;\n  select {\n    margin-top: 4px;\n  }\n}\n",".analytics .dashboard-settings.sync-apps {\n  .show-status {\n    margin-right: 5px;\n    color: @impac-widget-text-color-medium;\n    &:hover {\n      cursor: pointer;\n      text-decoration: underline;\n    }\n    .fa.fa-info { margin-right: 2px; }\n  }\n  .status-btn {\n    i {\n      font-size: 16px;\n      &.fa-exclamation-triangle { color: @fluroorange; }\n      &.fa-check { color: @green; }\n    }\n    display: inline-block;\n    cursor: pointer;\n    padding: 5px 7px 5px 0px;\n  }\n\n  .popover {\n    max-width: 550px;\n    .connector {\n      padding: 4px 13px;\n      &.add-seperator { border-bottom: 1px solid #ccc; }\n    }\n    .popover-content {\n      padding: 0;\n    }\n    .popover-footer {\n      border-top: 1px solid #ccc;\n      padding: 4px 13px;\n      p {\n        font-weight: bold;\n        margin: 0;\n      }\n      &.remove-seperator { border: 0; }\n    }\n  }\n\n  .badge { float: right; margin-left: 8px; }\n  .success .badge { background-color: @green; }\n  .pending .badge { background-color: @fluroorange; }\n  .running .badge { background-color: @fluroorange; }\n  .error .badge { background-color: @pink; }\n  .failed .badge { background-color: @pink; }\n  .unknown .badge { background-color: @pink; }\n  .disconnected .badge { background-color: @pink; }\n}\n\n#sync-apps-modal {\n  .modal-header {\n    text-align: center;\n    border: 0;\n    box-shadow: 0px 2px 3px 0px #ccc;\n  }\n  .modal-list {\n    max-height: 280px;\n    overflow-y: auto;\n  }\n  .modal-list-item {\n    border-bottom: 1px solid #ccc;\n    padding: 10px;\n\n    .badge { float: right; }\n    &.success .badge { background-color: @green; }\n    &.pending .badge { background-color: @fluroorange; }\n    &.running .badge { background-color: @fluroorange; }\n    &.error .badge { background-color: @pink; }\n    &.failed .badge { background-color: @pink; }\n    &.unknown .badge { background-color: @pink; }\n    &.disconnected .badge { background-color: @pink; }\n\n    .message {\n      p { margin: 0; }\n      padding: 3px;\n      border-radius: 2px;\n      margin-left: 31px;\n      margin-top: 9px;\n    }\n\n    &.success .message { background-color: rgba(0, 255, 55, 0.08); }\n    &.pending .message { background-color: rgba(255, 118, 0, 0.08); }\n    &.running .message { background-color: rgba(255, 118, 0, 0.08); }\n    &.error .message { background-color: rgba(255, 0, 0, 0.08); }\n    &.failed .message { background-color: rgba(255, 0, 0, 0.08); }\n    &.unknown .message { background-color: rgba(255, 0, 0, 0.08); }\n    &.disconnected .message { background-color: rgba(255, 0, 0, 0.08); }\n\n    &.with-message {\n      cursor: pointer;\n      &:hover {\n        background-color: #ccc;\n      }\n    }\n  }\n  .modal-footer {\n    border: 0;\n  }\n  .fa { padding: 0px 10px; }\n  .fa.error { color: @red; }\n  .fa.warn { color: @fluroorange; }\n  .fa.success { color: @flurogreen; }\n}\n","chart-threshold {\n  .attach-panel {\n    padding: 5px 0;\n    display: flex;\n    justify-content: center;\n    align-items: baseline;\n    background-color: rgba(20, 132, 228, 0.16);\n\n    & > div {\n      padding-right: 5px;\n\n      &.target { text-align: center; }\n    }\n\n    @media (max-width: @screen-md-max) {\n      flex-direction: column;\n      align-items: center;\n      > div {\n        padding: 5px;\n      }\n    }\n\n    .text {\n      text-transform: uppercase;\n      font-weight: bold;\n      color: @impac-widget-text-color;\n      font-size: 13px;\n    }\n\n    input {\n      border-radius: 3px;\n      border: 1px white;\n      padding: 3px;\n\n      &[name=amount] {\n        max-width: 70px;\n      }\n    }\n\n    .currency {\n      font-weight: bold;\n      color: #000;\n    }\n\n    .actions {\n      display: inline-block;\n      padding: 0 2px;\n      button {\n        padding: 3px 6px;\n        display: inline-block;\n        &.loading {\n          padding: 3px 20px;\n        }\n      }\n    }\n  }\n}\n",".analytics widgets-common-confirm-modal {\n  .widget-popup();\n  .message {\n    display: flex;\n    flex-direction: column;\n    justify-content: space-between;\n\n    p { padding: 0px 10px; }\n\n    button.btn { margin-top: 20px; }\n\n    .loader i.fa.fa-spinner {\n      font-size: 26px;\n    }\n  }\n}\n",".currency-conversions {\n  img {\n    width: 15px;\n    cursor: pointer;\n  }\n\n  &.popover .popover-title {\n    background-color: black;\n    color: white;\n  }\n}\n",".analytics .widget-item .editable-title {\n  width: 100%;\n  flex: 1;\n  overflow: hidden;\n  height: 22px;\n\n  .title {\n    text-transform: @impac-widget-title-text-transform;\n    .font(@impac-widget-title-text-size,600,@impac-widget-title-text-color);\n    cursor: text;\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n    line-height: 1.9;\n  }\n\n  .editable-wrap {\n    position: relative;\n    height: 20px;\n    min-width: 100%;\n    // otherwise, white-space is overriden in mno-enterprise\n    white-space: nowrap;\n\n    .editable-controls {\n      min-width: 100%;\n\n      .editable-input {\n        height: 20px;\n        font-size: 12px;\n        text-transform: @impac-widget-title-text-transform;\n        // 65px is .editable-buttons width\n        width: ~\"calc(100% - 65px)\";\n        padding: 0px 3px;\n      }\n\n      .editable-buttons {\n        background-color: @impac-widget-title-bg;\n        button {\n          margin: 0px 0px 0px 5px;\n          height: 20px;\n          padding: 0px 5px;\n        }\n      }\n    }\n  }\n}\n",".analytics .widget-item .info-panel {\n  position: absolute;\n  top: 15px;\n  left: 15px;\n  width: ~\"calc(100% - 30px)\";\n  max-height: ~\"calc(100% - 30px)\";\n  height: 100%;\n  z-index: 100;\n\n  background-color: white;\n  border: dotted 1px #B7CDCE;\n\n  display: flex;\n  flex-direction: column;\n  font-family: \"Lato Semibold\", \"Lato\";\n\n  z-index: 4;\n\n  &:hover { opacity: 1; }\n\n  .i-header {\n    .fa { font-size: 18px; }\n    .fa-info-circle { float: left; }\n    .fa-times-circle { cursor: pointer; float: right; }\n\n    background-color: #FFC928;\n    color: @impac-widget-reverse-color;\n    padding: 8px;\n    text-transform: uppercase;\n    font-family: \"Lato Medium\", \"Lato\";\n    font-size: 12px;\n  }\n\n  .i-content {\n    .scrollable();\n    padding: 5px;\n    text-align: justify;\n    flex: 1;\n\n    .row {\n      margin-bottom: 6px;\n      padding-bottom: 6px;\n      border-bottom: solid 1px @impac-dashboard-borders-color;\n\n      &:last-child {\n        margin-bottom: 0;\n        padding-bottom: 0;\n        border-bottom: none;\n      }\n\n      .key {\n        @media (max-width: @screen-sm-max) { text-align: center; }\n        text-align: right;\n        font-variant: small-caps;\n      }\n\n      .value { text-align: justify; }\n    }\n  }\n}\n",".analytics .time-period-info {\n  font-size: 11px;\n  color: #ABC4C6;\n  text-transform: uppercase;\n}\n",".analytics .widget-item .top-line .top-buttons {\n  text-align: right;\n  margin-top: -1px;\n  white-space: nowrap;\n  padding-left: 10px;\n\n  .top-buttons-wrapper {\n    .top-button {\n      background: transparent;\n      border: none;\n      color: @impac-widget-top-buttons-color;\n      padding: 0;\n      outline: none;\n      width: 17px;\n\n      &:active, &:focus { box-shadow: none; }\n\n      &.btn-info {\n        font-size: 17px;\n        margin-top: 1px;\n        &:hover { color: #FFC928; }\n      }\n      &.btn-export {\n        font-size: 17px;\n        margin-top: 1px;\n        &:hover { color: @mblue; }\n      }\n      &.btn-refresh {\n        font-size: 17px;\n        margin-top: 1px;\n        &:hover { color: @mblue; }\n      }\n      &.btn-edit {\n        font-size: 13px;\n        &:hover, &.edit-mode { color: darken(@mgreen,10%); }\n      }\n      &.btn-close {\n        font-size: 13px;\n        &:hover { color: @pink; }\n      }\n    }\n  }\n}\n",".analytics .widget-item .content .settings.select-account {\n  padding: 0px 5px;\n}",".analytics .settings.accounting-behaviour {\n\n  .btn.btn-primary {\n    background-color: lighten(@impac-widget-link-color, 10%);\n    border: solid 1px @impac-widget-link-color;\n    &.focus, &.active { background-color: @impac-widget-link-color; }\n  }\n\n}\n",".analytics .settings.attach-kpis {\n  .attach-kpi {\n    padding: 8px 5px;\n\n    form .row {\n      padding-bottom: 5px;\n    }\n\n    .attach-kpi-form {\n      background-color: white;\n      border: 1px solid #ddd;\n      padding: 5px;\n    }\n\n    form .row.kpi-description {\n      padding: 10px 2px;\n      span {\n        display: block;\n        font-weight: bold;\n        font-size: 13px;\n      }\n    }\n\n    form.attach-kpi-form {\n      input.attach-target {\n        background-color: white;\n        height: inherit;\n      }\n    }\n\n    .error-messages {\n      color: @brand-danger;\n      width: 120px;\n    }\n  }\n\n  .attached-kpis {\n    padding: 5px;\n  }\n\n  .list-group-item.attached-kpi {\n    padding: 5px 10px;\n\n    .attached-kpi-name {\n      overflow: hidden;\n      width: 75%;\n      display: inline-block;\n      white-space: nowrap;\n      text-overflow: ellipsis;\n      margin-top: 3px;\n      font-size: 13px;\n      font-weight: bold;\n    }\n\n    .actions {\n      padding-top: 2px;\n      .alerts-config {\n        display: inline-block;\n        text-align: left;\n        padding-left: 4px;\n        height: 20px;\n        border-radius: 40px;\n        width: 21px;\n        color: @mblue;\n        background-color: white;\n        border: solid 1px @mblue;\n\n        &:hover { cursor: pointer; }\n      }\n      .edit-attached-kpi {\n        display: inline-block;\n        i {\n          border-radius: 10px;\n          width: 21px;\n          color: @mblue;\n          background-color: white;\n          height: 20px;\n          padding: 3px 5px 5px 5px;\n          border: solid 1px @mblue;\n          &:hover { cursor: pointer; }\n        }\n      }\n      .remove-attached-kpi {\n        display: inline-block;\n        i {\n          border-radius: 10px;\n          width: 21px;\n          color: @brand-danger;\n          background-color: white;\n          height: 20px;\n          padding: 3px 5px 5px 5px;\n          border: solid 1px @brand-danger;\n          &:hover { cursor: pointer; }\n        }\n      }\n    }\n  }\n}\n",".analytics .widget-item .content .settings.select-account {\n  padding: 0px 5px;\n}",".analytics .widget-item .content .settings.chart-filters {\n  .row {\n    margin: 0px;\n  }\n  input[type=\"radio\"] {\n    margin: 0;\n    margin-right: 3px;\n    padding: 0;\n    width: 13px;\n    height: 13px;\n    vertical-align: middle;\n    position: relative;\n    top: -1px;\n    outline: none;\n  }\n  input[type=\"range\"] {\n    height: auto;\n    width: 100%;\n  }\n}\n",".analytics .settings.dates-picker {\n  h5 { display: none; }\n\n  button.btn.btn-sm {\n    line-height: 1;\n    &.date-button { margin: 0px 5px; }\n    &.btn-danger { display: none; }\n    &.btn-info { border-radius: 3px; }\n  }\n\n  .tooltip-inner { text-transform: none; }\n\n  .dropdown-menu > li > div > table { outline: none; }\n}\n",".analytics .settings.forecast-payroll {\n  .widget-lines-container {\n    .widget-line {\n      padding: 5px 10px 5px 18px;\n      .alternate-bg(#f3f4f4);\n      .fa {\n        float: right;\n        font-size: 20px;\n        cursor: pointer;\n        &.fa-toggle-on {\n          color: @impac-widget-link-color;\n        }\n        &.fa-toggle-off {\n          color: @impac-widget-text-color-medium;\n        }\n      }\n    }\n  }\n}\n",".analytics .widget-item .content .settings.hist-mode-choser {\n  max-height: 70px;\n\n  [common-time-period-info] {\n    padding-bottom: 8px;\n  }\n\n  .options {\n    width: 150px;\n    margin: auto;\n    padding-bottom: 8px;\n    border-bottom: solid 1px #e6e6e6;\n    .font(@impac-widget-hist-text-size,500,@impac-widget-hist-text-color);\n    a {\n      .font(@impac-widget-hist-text-size,500,@impac-widget-hist-text-color);\n      text-transform: @impac-widget-hist-text-transform;\n      &.active {\n        color: @impac-widget-link-color;\n      }\n    }\n  }\n  .arrow-container {\n    width: 28px;\n    height: 28px;\n    position: relative;\n    top: -14px;\n    margin: auto;\n    &.right {\n      left: 46px;\n    }\n    &.left {\n      left: -30px;\n    }\n    .arrow-border {\n      border-top: 14px solid #e6e6e6;\n      border-left: 14px solid transparent;\n      border-right: 14px solid transparent;\n      width: 0px;\n      height: 0px;\n    }\n    .arrow {\n      border-top: 14px solid @impac-widget-background-color;\n      border-left: 14px solid transparent;\n      border-right: 14px solid transparent;\n      position: relative;\n      top: 12px;\n      width: 0px;\n      height: 0px;\n    }\n  }\n}\n",".analytics .settings.limit-entries {\n  color: @impac-widget-limit-entries-color;\n  text-transform: uppercase;\n  text-align: center;\n  border-bottom: dashed 1px #E6E6E6;\n  padding-bottom: 8px;\n\n  a.option {\n    &.badge {\n      color: white;\n      background-color: @impac-widget-limit-entries-color;\n    }\n  }\n\n}\n",".analytics .settings.offsets {\n  .offset-value {\n    font-style: italic;\n    font-size: 13px;\n  }\n\n  .offset-value .fa-trash-o {\n    &:hover {\n      color: @brand-danger;\n      cursor: pointer;\n    }\n    margin-left: 10px;\n  }\n\n  input { width: 75%; }\n  button { width: 30px; }\n}\n",".analytics .settings.organizations {\n  .widget-lines-container {\n    .widget-line {\n      padding: 5px 10px 5px 18px;\n      .alternate-bg(#f3f4f4);\n      .fa {\n        float: right;\n        font-size: 20px;\n        cursor: pointer;\n        &.fa-toggle-on, &.fa-check-circle {\n          color: @impac-widget-link-color;\n        }\n        &.fa-toggle-off, &.fa-circle-thin {\n          color: @impac-widget-text-color-medium;\n        }\n      }\n    }\n  }\n}\n",".analytics .widget-item .content .settings.param-selector {\n  display: inline-block;\n\n  &.classic {\n    width: 100%;\n\n    select {\n      width: 100%;\n      height: 25px;\n      border: 1px solid #ccc;\n      text-transform: uppercase;\n      margin: 0px 0px 5px 0px;\n    }\n  }\n\n  a {\n    font-weight: normal;\n    color: @impac-widget-param-selector-color;\n    white-space: nowrap;\n  }\n  .options-container {\n    position: absolute;\n    background-color: white;\n    text-align: left;\n    min-width: 150px;\n    max-height: 200px;\n    z-index: 999;\n    overflow-y: auto;\n    overflow-x: hidden;\n    .box-shadow(rgb(0, 0, 0) 0px 3px 15px -3px);\n\n    .param-selector-label {\n      padding: 3px 5px;\n      .font(inherit,500,black);\n      cursor: text;\n      overflow: hidden;\n      white-space: nowrap;\n      text-overflow: ellipsis;\n      line-height: 1.9;\n    }\n    .param-selector-label:hover {\n      cursor: pointer;\n      background-color: @impac-widget-param-selector-color;\n      color: white;\n    }\n\n    &::-webkit-scrollbar {\n      width: 8px;\n      background-color: darken(@lightgray,5%);\n    }\n\n    &::-webkit-scrollbar-thumb {\n      background-color: @impac-widget-param-selector-color;\n      &:hover {\n        background-color: lighten(@impac-widget-param-selector-color,5%);\n      }\n    }\n  }\n}\n",".analytics .settings.params-checkboxes {\n  padding: 2px 0px;\n  input {\n    margin: 0;\n    height: inherit;\n  }\n  span {\n    margin-left: 5px;\n  }\n  label {\n    display: flex;\n    justify-content: center;\n    line-height: 14px;\n  }\n}\n",".analytics .widget-item .content .settings.params-picker {\n  padding: 0px 10px;\n  .parameter {\n    margin: 0px 3px 3px 0px;\n    padding: 3px 5px;\n    background-color: @impac-widget-params-picker-bg;\n    color: white;\n    border: solid 1px @impac-widget-params-picker-bg;\n    border-radius: 4px;\n    cursor: move;\n    font-weight: bold;\n    white-space: nowrap;\n    float: left;\n    input[type=\"checkbox\"] {\n      margin: 0px -3px 0px 3px;\n      vertical-align: middle;\n      height: inherit;\n      outline: none;\n      cursor: pointer;\n    }\n    .badge {\n      margin-right: 3px;\n      font-size: 10px;\n      background-color: darken(@impac-widget-background-color, 5%);\n      color: @impac-widget-params-picker-bg;\n      padding: 2px 6px;\n    }\n\n    &.unchecked {\n      background-color: inherit;\n      font-weight: normal;\n      color: inherit;\n      border-color: @impac-widget-params-picker-unchecked-bg;\n      .badge {\n        background-color: @impac-widget-params-picker-unchecked-bg;\n        color: white;\n      }\n    }\n  }\n}",".analytics .settings.tag-filter {\n  padding: 0px 5px;\n\n  .btn.btn-default {\n    height: 32px;\n    width: 30px;\n  }\n\n  .tag-lines-container {\n    padding: 0px 10px;\n\n    .tag-line {\n      display: flex;\n      align-items: center;\n      justify-content: flex-end;\n\n      .tags-col { position: static; }\n\n      tags-input {\n        .tags {\n          display: flex;\n          border-radius: 4px;\n          border: solid 1px #ccc;\n          .tag-item {\n            background: #79a2bb;\n            border-radius: 4px;\n            color: white;\n          }\n        }\n      }\n\n      .host { position: static; }\n    }\n  }\n}\n",".analytics .settings.time-period {\n  padding: 0px 5px;\n\n  select {\n    height: 22px;\n    width: 100%;\n  }\n  \n  & > .row {\n    margin: 0px -5px 7px -5px;\n    & > div {\n      padding: 0px 5px;\n      position: static;\n    }\n\n    .sub-setting { padding: 5px; }\n  }\n}\n",".analytics .widget-item .content .settings.width {\n  float: right;\n  font-size: 14px;\n  i {\n    color: silver;\n    cursor: pointer;\n    &.reduce {\n      margin-right: -10px;\n    }\n    &.expand {\n      margin-right: -3px;\n    }\n  }\n}",".analytics .widget-item .content.accounts-assets-liability-summary {\n  .param-selector {\n    text-align: center;\n  }\n  .legend {\n    text-align: left;\n    max-height: 90px;\n\n    .title {\n      text-align: center;\n      border-bottom: dashed 1px @impac-widget-borders-color;\n    }\n  }\n}\n",".analytics .widget-item .content.accounts-assets-summary {\n  .legend {\n    text-align: left;\n    max-height: 115px;\n\n    .title {\n      text-align: center;\n      border-bottom: dashed 1px @impac-widget-borders-color;\n    }\n  }\n}\n",".analytics .widget-item .content.accounts-assets-vs-liabilities {\n  .legend > .title span {\n    margin-left: 3px;\n  }\n}\n",".analytics .widget-item .content.accounts-balance {\n  h3 {\n    .left-thin(30px);\n    text-align: center;\n  }\n\n  .price {\n    .center-bold(0px);\n  }\n}\n",".analytics .widget-item .content.accounts-balance-sheet {\n  .tall-widget();\n  .widget-lines-container {\n    .scrollable(scroll);\n    max-height: 490px;\n    @media (max-width: @screen-xs-max) {\n      .row.widget-line {\n        &:not(:last-child) { border-bottom: dashed 1px @impac-widget-borders-color; }\n      }\n    }\n    .row.widget-line.header > [class*='col-'] { position: static; }\n\n    &.no-scroll {\n      overflow: visible;\n    }\n  }\n\n  .no-data-block {\n    .center-thin();\n    margin: 15px 0px;\n  }\n}\n",".analytics .widget-item .content.accounts-cash-balance {\n  .tall-widget();\n\n  .data-container {\n    height: ~\"calc(@{impac-big-widget-size} - 50px)\";\n    width: 100%;\n  }\n\n  .left-panel {\n    width: 180px;\n    display: inline-block;\n    overflow: auto;\n    max-height: 100%;\n  }\n\n  #cash-balance-legend {\n    .header {\n      .group-item {\n        display: flex;\n        align-items: center;\n        min-height: 45px;\n        margin: 3px;\n        font-size: 13px;\n        padding: 3px;\n        cursor: pointer;\n        user-select: none;\n        &:hover {\n          background-color: @impac-widget-menus-hover-background-color;\n        }\n        i {\n          font-size: 19px;\n          padding: 4px;\n          margin-top: 1px\n        }\n        span { color: @impac-widget-text-color; }\n      }\n    }\n  }\n\n  .legend-item-icon {\n    width: 16px;\n    height: 16px;\n  }\n\n  .right-panel {\n    width: ~\"calc(100% - 180px)\";\n    float: right;\n\n    // Highchart container\n    .cash-balance-chart {\n      height: ~\"calc(@{impac-big-widget-size} - 50px)\";\n    }\n  }\n\n  .dates-picker {\n    display: inline-block;\n    float: right;\n    font-size: 12px;\n  }\n}\n",".analytics .widget-item .content.accounts-cash-projection {\n  .tall-widget();\n\n  .cash-projection-chart {\n    height: ~\"calc(@{impac-big-widget-size} - 50px)\";\n  }\n\n  .highcharts-legend-item {\n    rect.highcharts-point {\n      display: none;\n    }\n\n    span {\n      width: 110px;\n      text-align: center;\n      img {\n        text-align: center;\n        width: 55px;\n        height: 25px;\n      }\n    }\n  }\n\n  .dates-picker {\n    display: inline-block;\n    float: right;\n    font-size: 12px;\n  }\n\n  transactions-list {\n    font-size: 12px;\n  }\n}\n",".analytics .widget-item .content.accounts-cash-summary {\n  .drill-down-widget();\n  .right-panel .widget-lines-container {\n    max-height: 215px;\n  }\n\n  .row.lines-group.cash {\n    border-top: solid 1px;\n    border-bottom: double;\n  }\n}\n","// --- Reusable widget style mixins\n\n// Payroll-Summary - Profit-and-Loss\n.drill-down-widget () {\n  .tall-widget();\n\n  .widget-lines-container {\n    max-height: 540px;\n    .lines-group .widget-line {\n      .selectable();\n    }\n  }\n\n  .right-panel {\n    .widget-lines-container {\n      .scrollable(auto);\n      max-height: 235px;\n    }\n  }\n\n  .no-element {\n    .center-thin();\n  }\n}\n\n// Top customers summary - Sales cycle...\n.simple-summary-widget() {\n  .chart-container {\n    max-width: 410px;\n  }\n  .legend {\n    max-height: 28px;\n  }\n}\n\n// Invoices list - sales list\n.simple-list-widget() {\n  .widget-lines-container {\n    max-height: 230px;\n    .widget-line {\n      .alternate-bg();\n      &.header {\n        background-color: @impac-widget-background-color;\n      }\n    }\n  }\n}\n\n// Workforce-Summary - Salaries-Summary\n.expandable-filterable-widget() {\n  h3.left {\n    @media (min-width: @screen-md-min) { margin-top: 69px; }\n    text-align: center;\n  }\n  h3.reduced-left {\n    @media (min-width: @screen-md-min) { margin-top: 10px; }\n    text-align: center;\n  }\n  h3.right {\n    margin-bottom: 10px;\n    text-align: center;\n  }\n  .price {\n    margin-top: 0;\n  }\n  .widget-lines-container {\n    max-height: 75px;\n    .widget-line {\n      font-size: 11px;\n    }\n  }\n  .right-panel .chart-container {\n    @media (min-width: @screen-xs-min) and (max-width: @screen-sm-max) { max-width: 320px; }\n  }\n}\n\n// Leads funnel - Opportunities funnel\n.funnel-widget() {\n  .tall-widget();\n  .funnel-container {\n    width: 95%;\n    margin: auto;\n    margin-top: 15px;\n    padding-right: 10px;\n    max-height: @impac-big-widget-size - 60px;\n    overflow: auto;\n  }\n  .right-panel {\n    .widget-lines-container {\n      max-height: @impac-big-widget-size - 20px;\n      margin-right: 10px;\n      .widget-line {\n        cursor: default;\n      }\n    }\n  }\n}\n",".analytics .widget-item .content.accounts-class-comparison {\n  .param-selector {\n    text-align: center;\n  }\n  .widget-lines-container {\n    max-height: 94px;\n    color: #626d6d;\n  }\n}\n",".analytics .widget-item .content.accounts-comparison {\n  .tall-widget();\n\n  .chart-container {\n    @media print { max-width: 80% !important; }\n  }\n\n  .add-account {\n    position: absolute;\n    right: 40px;\n    bottom: 30px;\n    width: 160px;\n    select {\n      font-size: 13px;\n      background-color: @impac-widget-link-color;\n      color: @impac-widget-background-color;\n      outline: none;\n      border: none;\n      cursor: pointer;\n      &[disabled] {\n        cursor: not-allowed;\n        background-color: lighten(@impac-widget-link-color,10%);\n        &:hover {\n          background-color: lighten(@impac-widget-link-color,10%);\n        }\n      }\n      &:hover {\n        background-color: darken(@impac-widget-link-color,10%);\n      }\n      option {\n        background-color: @impac-widget-background-color;\n        color: lighten(@impac-widget-text-color,40%);\n        &[disabled] {\n          color: @impac-widget-background-color;\n        }\n      }\n    }\n  }\n  button.close {\n    font-size: 15px;\n  }\n  .legend {\n    text-align: left;\n    max-height: 103px;\n  }\n  .row {\n    margin: 0;\n  }\n  .widget-lines-container {\n    font-size: 11px;\n    max-height: @impac-widget-accounts-comparison-lines-container-max-height;\n    margin-bottom: 65px;\n    overflow: auto;\n  }\n\n  .settings.params-checkboxes {\n    margin-left: 13px;\n  }\n\n  .comparable-error h5 {\n    margin-left: 13px;\n    color: @impac-negative;\n  }\n}\n",".analytics .widget-item .content.accounts-custom-calculation {\n  h3 {\n    margin-top: 85px;\n    text-align: center;\n    font-weight: bold;\n  }\n  .legend { max-height: 125px; }\n}\n\n.analytics.modal-custom-calculation {\n  margin: 0px;\n  padding: 0px;\n}\n\n.analytics.modal-custom-calculation .modal-body {\n  .edit {\n    .edit-panel-style();\n    padding: 5px;\n    overflow: visible;\n  }\n}\n",".analytics .widget-item .content.accounts-detailed-classifications {\n  .tall-widget();\n  .widget-lines-container {\n    .scrollable(scroll);\n    max-height: 540px;\n  }\n\n  .account-class-title {\n    margin-bottom: 8px;\n    margin-left: 11px;\n  }\n\n  .time-period-info {\n    text-align: right;\n  }\n\n  .widget-line.header.sorting  {\n    border-bottom: 1px solid #ccc;\n  }\n}\n\n\n",".analytics .widget-item .content.accounts-expense-weight {\n  .legend {\n    text-align: left;\n    max-height: 115px;\n\n    .title {\n      text-align: center;\n    }\n  }\n}\n",".analytics .widget-item .content.accounts-expenses-revenue {\n  .legend {\n    font-weight: bold;\n  }\n\n  .settings.params-checkboxes {\n    font-size: 12px;\n    margin-left: 0px;\n    text-align: center;\n  }\n}\n",".analytics .widget-item .content.accounts-invoices-list {\n  // component specific styles\n  // -------------------------\n  .tall-widget();\n\n  transactions-list {\n    font-size: 12px;\n  }\n\n}\n",".analytics .widget-item .content.accounts-live-balance {\n  h3 {\n    .center-bold(0px);\n    font-size: 18px;\n    text-align: center;\n    text-shadow: 1px;\n  }\n\n  .statement-title {\n    font-size: 13px;\n    font-weight: 400;\n  }\n\n  .balance-title {\n    font-size: 12px;\n  }\n\n  .currency-centered {\n    .center-small()\n  }\n\n  .headers {\n    text-align: center;\n  }\n\n  .spacer {\n    min-height: 30px;\n  }\n\n  .price {\n    .center-bold(0px);\n  }\n\n  .negative2 {\n    font-size: 14px;\n  }\n}\n",".analytics .widget-item .content.accounts-payable-receivable {\n  h3 {\n    text-align: center;\n  }\n  .legend {\n    font-weight: bold;\n  }\n  .payable {\n    margin-top: 15px;\n  }\n  .price {\n    .center-bold(0px);\n  }\n}",".analytics .widget-item .content.accounts-profit-and-loss {\n  .drill-down-widget();\n\n  .row.lines-group.profit {\n    border-top: solid 1px;\n    border-bottom: double;\n  }\n\n  .right-panel .widget-lines-container {\n    max-height: 215px;\n  }\n\n  .row.widget-line.header > [class*='col-'] { position: static; }\n}\n",".analytics .widget-item .content.accounts-ratios {\n  \n  .left-panel {\n    max-height: 230px;\n    overflow-y: auto; \n\n    .separator {\n      border-bottom: solid 1px @impac-widget-text-color;\n      width: 75%;\n    }\n    .member {\n      padding-top: 20px;\n      padding-bottom: 20px;\n    }\n    .member .price {\n      margin-top: 0px;\n      font-size: 18px;\n    }\n    button { outline: none; }\n  }\n\n  .left-panel.simulation {\n    .member {\n      padding-top: 5px;\n      .legend { display: none; }\n      .price { text-align: right; }\n    }\n    .separator { width: 100%; }\n  }\n}\n",".analytics .widget-item .content.hr-employee-details {\n  font-size: 12px;\n  .details-container {\n    padding: 0px;\n    max-height: none;\n    @media (min-width: @screen-md-min) { max-height: 200px; }\n    .scrollable();\n  }\n  .right-panel {\n    .details-container {\n      @media (min-width: @screen-md-min) { max-height: 220px; }\n    }\n    .legend {\n      margin-bottom: 5px;\n    }\n  }\n  .title {\n    text-align: center;\n    margin-bottom: 10px;\n    font-size: 14px;\n  }\n}\n",".analytics .widget-item .content.hr-employees-list {\n  .legend {\n    margin-bottom: 9px;\n  }\n  .widget-lines-container {\n    text-align: center;\n    .widget-line {\n      .alternate-bg();\n    }\n  }\n  .edit {\n    .widget-lines-container {\n      text-align: left;\n    }\n  }\n}",".analytics .widget-item .content.hr-leaves-balance{\n  .employee-name {\n    text-align: center;\n  }\n  .balance {\n    .center-bold(0px);\n  }\n  h3 {\n    margin-top: 33px;\n    text-align: center;\n  }\n}",".analytics .widget-item .content.hr-leaves-schedule{\n  .fc-button {\n    height: 22px;\n    font-size: 12px;\n    color: @impac-widget-buttons-color;\n    background: white;\n    outline: none;\n    &:hover {\n      color: white;\n      background: @impac-widget-buttons-color;\n    }\n  }\n  .fc-toolbar {\n    margin-bottom: 5px;\n  }\n  .fc-day-grid,.fc-widget-header {\n    font-size: 12px;\n    color: @impac-widget-text-color;\n  }\n}",".analytics .widget-item .content.hr-payroll-summary {\n  .drill-down-widget();\n  .right-panel .widget-lines-container {\n      max-height: 145px;\n  }\n}\n",".analytics .widget-item {\n  .content.hr-salaries-summary {\n    .expandable-filterable-widget();\n  }\n}\n",".analytics .widget-item .content.hr-superannuation-accruals {\n  h3 {\n    margin-top: 63px;\n    text-align: center;\n  }\n  .legend {\n    margin-top: 23px;\n  }\n  .currency {\n    font-size: 14px;\n  }\n  .price {\n    .center-bold(0px);\n  }\n}",".analytics .widget-item .content.hr-timesheets {\n  .currency {\n    font-size: 14px;\n  }\n  .widget-lines-container {\n    max-height: 210px;\n  }\n}",".analytics .widget-item  {\n  .content.hr-workforce-summary {\n    .expandable-filterable-widget();\n  }\n}\n",".analytics .widget-item .content.invoices-aged-payables-receivables {\n  .drill-down-widget();\n\n  .right-panel .widget-lines-container {\n    max-height: 215px;\n  }\n\n  .row.astericks-info {\n    margin-top: 15px;\n  }\n\n  .currency-conversions {\n    float: right;\n    margin-left: 3px;\n  }\n}\n",".analytics .widget-item .content.invoices-list {\n  .simple-list-widget();\n\n  .currency-conversions {\n    float: right;\n    margin-right: 3px;\n    margin-top: -2px;\n  }\n\n  .fa.fa-info-circle {\n    float: right;\n    font-size: 15px;\n  }\n\n  .right-column {\n    padding-left: 0px;\n    padding-right: 0px;\n  }\n}\n",".analytics .widget-item .content.invoices-summary {\n  .simple-summary-widget();\n}",".analytics .widget-item .content.sales-aged {\n  .tall-widget();\n\n  .widget-lines-container {\n    max-height: 238px;\n  }\n}\n",".analytics .widget-item .content.sales-break-even {\n  .price {\n    .center-bold(0px);\n  }\n  .block {\n    margin: 5px;\n    padding: 0px 10px 5px 10px;\n    text-align: left;\n    box-shadow: 0px 7px 10px -7px #17262d;\n    font-size: 12px;\n    form.editable-wrap .editable-controls input {\n      margin-top: 5px;\n      width: 100px;\n    }\n    &.to-date {\n      background-color: @impac-widget-sub-bg-color;\n      color: @impac-widget-text-color;\n    }\n    &.to-breakeven {\n      margin-top: 10px;\n      background-color: @impac-widget-sales-break-even-bg;\n      color: @impac-widget-sales-break-even-text-color;\n      .title {\n        border-bottom: solid 1px lighten(@impac-widget-sales-break-even-bg, 10%);\n      }\n      .define-text {\n        .center-thin();\n        padding-top: 5px;\n        color: @impac-widget-sales-break-even-text-color;\n      }\n      .price {\n        color: @impac-widget-sales-break-even-text-color;\n      }\n    }\n\n    .title {\n      font-size: 13px;\n      text-align: center;\n      font-variant: small-caps;\n      border-bottom: solid 1px @lightgray;\n      font-weight: 300;\n    }\n  }\n}",".analytics .widget-item .content.sales-comparison {\n  .drill-down-widget();\n  .widget-lines-container {\n    max-height: 530px;\n  }\n  .right-panel .widget-lines-container {\n    max-height: 250px;\n  }\n  .currency-conversions {\n    img { margin-top: -2px; }\n  }\n}\n",".analytics .widget-item .content.sales-customer-details {\n  .loader {\n    font-size: 14px;\n  }\n  font-size: 12px;\n  .details-container {\n    padding: 0px;\n    @media (min-width: @screen-md-min) { max-height: 194px; }\n    overflow-y: auto;\n    overflow-x: hidden;\n  }\n  .right-panel {\n    .details-container {\n      @media (min-width: @screen-md-min) { max-height: 230px; }\n    }\n    .legend {\n      margin-bottom: 5px;\n    }\n  }\n  .row.title {\n    text-align: center;\n    margin-bottom: 10px;\n    font-size: 14px;\n  }\n\n  .currency-conversions {\n    float: left;\n    margin-right: 3px;\n  }\n}\n",".analytics .widget-item .content.sales-cycle {\n  .simple-summary-widget();\n}",".analytics .widget-item .content.sales-forecast {\n  .tall-widget();\n  .widget-lines-container {\n    max-height: 275px;\n    .widget-line.main {\n      .selectable();\n    }\n  }\n}\n",".analytics .widget-item .content.sales-growth {\n  .price {\n    .center-bold(0px);\n  }\n  .legend {\n    max-height: 49px;\n    font-size: 14px;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n  }\n}\n",".analytics .widget-item .content.sales-leads-funnel {\n  .funnel-widget();\n}\n",".analytics .widget-item .content.sales-leads-list {\n  .simple-list-widget();\n  .widget-lines-container {\n    .scrollable(scroll);\n  }\n}",".analytics .widget-item .content.sales-list {\n  .simple-list-widget();\n  .widget-lines-container {\n    .scrollable(scroll);\n    max-height: 170px;\n    &.no-scroll {\n      overflow: visible;\n    }\n  }\n  .selector {\n    margin-bottom: 4px;\n  }\n  .currency-conversions {\n    img { margin-top: -2px; }\n  }\n}\n",".analytics .widget-item .content.sales-net-sales {\n  .value-container, .operator {\n    // float: left;\n    // text-align: center;\n    line-height: 85px;\n  }\n\n  // .value-container {\n  //   width: 26%;\n  // }\n\n  .value-container .title {\n    line-height: 20px;\n    font-size: 1.2em;\n    padding: 10px 0px;\n  }\n\n  .value-container .value-box {\n    font-size: 1.3em;\n    border-radius: 10px;\n    // border: solid 1px #E4E4E4;\n    // box-shadow: 1px 1px 1px #C5C5C5;\n    border-top: solid 1px #C4CACA;\n    border-bottom: solid 1px #C4CACA;\n    white-space: nowrap;\n  }\n\n  .operator {\n    // @media (min-width: @screen-md-min) { padding-top: 38px; }\n    padding-top: 38px;\n    // width: 10%;\n    font-size: 1.3em;\n  }\n\n  .values {\n    @media (min-width: @screen-md-min) { margin-top: 25px; }\n  }\n}\n",".analytics .widget-item .content.sales-new-vs-existing-customers {\n\n  .selector .selector-wrap {\n    display: inline-block;\n    margin: 0 5px;\n  }\n  .chart-container {\n    margin-top: 15px;\n  }\n\n  .legend {\n    margin-top: 5px;\n    font-weight: bold;\n    max-height: 77px !important;\n\n    .row { margin: 0px -5px; &>div { padding: 0px 5px; }}\n\n    .total {\n      color: #5B6667;\n      font-size: 14px;\n    }\n  }\n}\n",".analytics .widget-item .content.sales-number-of-leads {\n  .stats {\n    margin-top: 35px;\n    font-size: 18px;\n    .stat {\n      margin: 15px 0px 10px 0px;\n      border-bottom: solid 1px @lightgray;\n      span.title {\n        font-weight: bold;\n      }\n      span.nominal {\n        float: right;\n        text-align: right;\n        font-weight: 300;\n      }\n      span.variation {\n        float: right;\n        width: 50px;\n        text-align: right;\n        font-style: italic;\n        font-size: 14px;\n        font-weight: 300;\n        margin-top: 2px;\n      }\n    }\n  }\n}",".analytics .widget-item .content.sales-opportunities-funnel {\n  .funnel-widget();\n}\n",".analytics .widget-item .content.sales-performance {\n  .drill-down-widget();\n  .right-panel .widget-lines-container {\n  \t max-height: 215px;\n    .widget-line.header {\n      .selectable();\n    }\n  }\n}\n",".analytics .widget-item .content.sales-segmented-turnover {\n  h3.right {\n    margin-top: 55px;\n    text-align: center;\n  }\n  .selector {\n    margin-bottom: 10px;\n  }\n  .analysis {\n    .center-bold(0px);\n  }\n  .widget-lines-container {\n    max-height: 75px;\n    .widget-line {\n      font-size: 11px;\n    }\n  }\n\n  .right-panel {\n    h3 {\n      margin: 15px 10px 5px 10px;\n      text-align: center;\n    }\n\n    .fa.fa-info-circle { float: left; }\n  }\n}\n",".analytics .widget-item .content.sales-summary {\n  .simple-summary-widget();\n  .selector {\n    margin-bottom: 5px;\n  }\n}",".analytics .widget-item .content.sales-top-customers {\n  .selector {\n    border-bottom: dashed 1px #E6E6E6;\n    padding-bottom: 3px;\n    a { font-weight: normal; }\n    .param-selector { display: inline-block; }\n  }\n  .widget-lines-container {\n    max-height: 235px;\n    .widget-line.sub-line { background-color: @impac-widget-sub-bg-color; }\n\n    // Will allow the params selectors to be displayed on top of the container (without being cut on the right)\n    .row > [class*='col-'] { position: static; }\n  }\n  .currency-conversions {\n    img { margin-top: -2px; }\n  }\n}\n",".analytics .widget-item .content.sales-top-opportunities {\n  .opps-container {\n    max-height: 195px;\n    margin-top: 10px;\n    padding-right: 10px;\n    .scrollable();\n    .tile {\n      height: 40px;\n      font-size: 13px;\n      font-weight: 300;\n      .colored-area {\n        width: 10%;\n        text-align: center;\n        font-size: 20px;\n      }\n      .main-text {\n        color: @impac-widget-text-color;\n        padding: 3px 0px 0px 10px;\n      }\n      &.first {\n        height: 55px;\n        font-size: 15px;\n        font-weight: bold;\n        .colored-area {\n          font-size: 26px;\n          padding-top: 10px;\n          background-color: rgb(255, 110, 65);\n        }\n        .main-text {\n          padding-top: 8px;\n        }\n      }\n      &.second {\n        height: 55px;\n        font-size: 15px;\n        font-weight: 500;\n        .colored-area {\n          font-size: 26px;\n          padding-top: 10px;\n          background-color: #1de9b6;\n        }\n        .main-text {\n          padding-top: 8px;\n        }\n      }\n    }\n  }\n}"]} */ +/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["impac-angular.css","../bower_components/bootstrap/less/normalize.less","../bower_components/bootstrap/less/glyphicons.less","../bower_components/bootstrap/less/scaffolding.less","../bower_components/bootstrap/less/mixins/vendor-prefixes.less","../bower_components/bootstrap/less/mixins/tab-focus.less","../bower_components/bootstrap/less/mixins/image.less","../bower_components/bootstrap/less/type.less","../bower_components/bootstrap/less/mixins/text-emphasis.less","../bower_components/bootstrap/less/mixins/background-variant.less","../bower_components/bootstrap/less/mixins/text-overflow.less","../bower_components/bootstrap/less/code.less","../bower_components/bootstrap/less/grid.less","../bower_components/bootstrap/less/mixins/grid.less","../bower_components/bootstrap/less/mixins/grid-framework.less","../bower_components/bootstrap/less/tables.less","../bower_components/bootstrap/less/mixins/table-row.less","../bower_components/bootstrap/less/forms.less","../bower_components/bootstrap/less/mixins/forms.less","../bower_components/bootstrap/less/buttons.less","../bower_components/bootstrap/less/mixins/buttons.less","../bower_components/bootstrap/less/mixins/opacity.less","../bower_components/bootstrap/less/component-animations.less","../bower_components/bootstrap/less/dropdowns.less","../bower_components/bootstrap/less/mixins/nav-divider.less","../bower_components/bootstrap/less/mixins/reset-filter.less","../bower_components/bootstrap/less/button-groups.less","../bower_components/bootstrap/less/mixins/border-radius.less","../bower_components/bootstrap/less/input-groups.less","../bower_components/bootstrap/less/navs.less","../bower_components/bootstrap/less/navbar.less","../bower_components/bootstrap/less/mixins/nav-vertical-align.less","../bower_components/bootstrap/less/utilities.less","../bower_components/bootstrap/less/breadcrumbs.less","../bower_components/bootstrap/less/pagination.less","../bower_components/bootstrap/less/mixins/pagination.less","../bower_components/bootstrap/less/pager.less","../bower_components/bootstrap/less/labels.less","../bower_components/bootstrap/less/mixins/labels.less","../bower_components/bootstrap/less/badges.less","../bower_components/bootstrap/less/jumbotron.less","../bower_components/bootstrap/less/thumbnails.less","../bower_components/bootstrap/less/alerts.less","../bower_components/bootstrap/less/mixins/alerts.less","../bower_components/bootstrap/less/progress-bars.less","../bower_components/bootstrap/less/mixins/gradients.less","../bower_components/bootstrap/less/mixins/progress-bar.less","../bower_components/bootstrap/less/media.less","../bower_components/bootstrap/less/list-group.less","../bower_components/bootstrap/less/mixins/list-group.less","../bower_components/bootstrap/less/panels.less","../bower_components/bootstrap/less/mixins/panels.less","../bower_components/bootstrap/less/responsive-embed.less","../bower_components/bootstrap/less/wells.less","../bower_components/bootstrap/less/close.less","../bower_components/bootstrap/less/modals.less","../bower_components/bootstrap/less/tooltip.less","../bower_components/bootstrap/less/mixins/reset-text.less","../bower_components/bootstrap/less/popovers.less","../bower_components/bootstrap/less/carousel.less","../bower_components/bootstrap/less/mixins/clearfix.less","../bower_components/bootstrap/less/mixins/center-block.less","../bower_components/bootstrap/less/mixins/hide-text.less","../bower_components/bootstrap/less/responsive-utilities.less","../bower_components/bootstrap/less/mixins/responsive-visibility.less","stylesheets/variables.less","stylesheets/globals.less","stylesheets/mixins.less","stylesheets/print.less","components/alerts-config/alerts-config.less","components/dashboard/dashboard.less","components/dashboard-create/dashboard-create.less","components/dashboard-selector/dashboard-selector.less","components/dashboard-templates-selector/dashboard-templates-selector.less","components/kpi/kpi.less","stylesheets/impac-material.less","components/kpis-bar/kpis-bar.less","components/widget/widget.less","components/common/data-not-found/data-not-found.less","components/common/duplicate-transactions-list/duplicate-transactions-list.less","components/common/transactions-add/transactions-add.less","components/common/transactions-list/transactions-list.less","components/common/trends-add/trends-add.less","components/common/trends-list/trends-list.less","components/dashboard-settings/currency/currency.less","components/dashboard-settings/sync-apps/sync-apps.less","components/widgets-common/chart-threshold/chart-threshold.less","components/widgets-common/confirm-modal/confirm-modal.less","components/widgets-common/currency-conversions/currency-conversions.less","components/widgets-common/editable-title/editable-title.less","components/widgets-common/info-panel/info-panel.less","components/widgets-common/time-period-info/time-period-info.less","components/widgets-common/top-buttons/top-buttons.less","components/widgets/accounts-assets-liability-summary/accounts-assets-liability-summary.less","components/widgets/accounts-assets-summary/accounts-assets-summary.less","components/widgets/accounts-assets-vs-liabilities/accounts-assets-vs-liabilities.less","components/widgets/accounts-balance/accounts-balance.less","components/widgets/accounts-balance-sheet/accounts-balance-sheet.less","components/widgets/accounts-cash-balance/accounts-cash-balance.less","components/widgets/accounts-cash-projection/accounts-cash-projection.less","components/widgets/accounts-cash-summary/accounts-cash-summary.less","stylesheets/widget-master-styles.less","components/widgets/accounts-class-comparison/accounts-class-comparison.less","components/widgets/accounts-comparison/accounts-comparison.less","components/widgets/accounts-custom-calculation/accounts-custom-calculation.less","components/widgets/accounts-detailed-classifications/accounts-detailed-classifications.less","components/widgets/accounts-expense-weight/accounts-expense-weight.less","components/widgets/accounts-expenses-revenue/accounts-expenses-revenue.less","components/widgets/accounts-invoices-list/accounts-invoices-list.less","components/widgets/accounts-live-balance/accounts-live-balance.less","components/widgets/accounts-payable-receivable/accounts-payable-receivable.less","components/widgets/accounts-profit-and-loss/accounts-profit-and-loss.less","components/widgets/accounts-ratios/accounts-ratios.less","components/widgets/hr-employee-details/hr-employee-details.less","components/widgets/hr-employees-list/hr-employees-list.less","components/widgets/hr-leaves-balance/hr-leaves-balance.less","components/widgets/hr-leaves-schedule/hr-leaves-schedule.less","components/widgets/hr-payroll-summary/hr-payroll-summary.less","components/widgets/hr-salaries-summary/hr-salaries-summary.less","components/widgets/hr-superannuation-accruals/hr-superannuation-accruals.less","components/widgets/hr-timesheets/hr-timesheets.less","components/widgets/hr-workforce-summary/hr-workforce-summary.less","components/widgets/invoices-aged-payables-receivables/invoices-aged-payables-receivables.less","components/widgets/invoices-list/invoices-list.less","components/widgets/invoices-summary/invoices-summary.less","components/widgets/sales-aged/sales-aged.less","components/widgets/sales-break-even/sales-break-even.less","components/widgets/sales-comparison/sales-comparison.less","components/widgets/sales-customer-details/sales-customer-details.less","components/widgets/sales-cycle/sales-cycle.less","components/widgets/sales-forecast/sales-forecast.less","components/widgets/sales-growth/sales-growth.less","components/widgets/sales-leads-funnel/sales-leads-funnel.less","components/widgets/sales-leads-list/sales-leads-list.less","components/widgets/sales-list/sales-list.less","components/widgets/sales-net-sales/sales-net-sales.less","components/widgets/sales-new-vs-existing-customers/sales-new-vs-existing-customers.less","components/widgets/sales-number-of-leads/sales-number-of-leads.less","components/widgets/sales-opportunities-funnel/sales-opportunities-funnel.less","components/widgets/sales-performance/sales-performance.less","components/widgets/sales-segmented-turnover/sales-segmented-turnover.less","components/widgets/sales-summary/sales-summary.less","components/widgets/sales-top-customers/sales-top-customers.less","components/widgets/sales-top-opportunities/sales-top-opportunities.less","components/widgets-settings/account/account.less","components/widgets-settings/accounting-behaviour/accounting-behaviour.less","components/widgets-settings/attach-kpis/attach-kpis.less","components/widgets-settings/bolt-account/bolt-account.less","components/widgets-settings/chart-filters/chart-filters.less","components/widgets-settings/dates-picker/dates-picker.less","components/widgets-settings/forecast-payroll/forecast-payroll.less","components/widgets-settings/hist-mode/hist-mode.less","components/widgets-settings/limit-entries/limit-entries.less","components/widgets-settings/offsets/offsets.less","components/widgets-settings/organizations/organizations.less","components/widgets-settings/param-selector/param-selector.less","components/widgets-settings/params-checkboxes/params-checkboxes.less","components/widgets-settings/params-picker/params-picker.less","components/widgets-settings/tag-filter/tag-filter.less","components/widgets-settings/time-period/time-period.less","components/widgets-settings/width/width.less"],"names":[],"mappings":"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CFgQ9C;AE/PmC;EAAW,iBAAA;CFkQ9C;AEjQmC;EAAW,iBAAA;CFoQ9C;AEnQmC;EAAW,iBAAA;CFsQ9C;AErQmC;EAAW,iBAAA;CFwQ9C;AEvQmC;EAAW,iBAAA;CF0Q9C;AEzQmC;EAAW,iBAAA;CF4Q9C;AE3QmC;EAAW,iBAAA;CF8Q9C;AE7QmC;EAAW,iBAAA;CFgR9C;AE/QmC;EAAW,iBAAA;CFkR9C;AEjRmC;EAAW,iBAAA;CFoR9C;AEnRmC;EAAW,iBAAA;CFsR9C;AErRmC;EAAW,iBAAA;CFwR9C;AEvRmC;EAAW,iBAAA;CF0R9C;AEzRmC;EAAW,iBAAA;CF4R9C;AE3RmC;EAAW,iBAAA;CF8R9C;AE7RmC;EAAW,iBAAA;CFgS9C;AE/RmC;EAAW,iBAAA;CFkS9C;AEjSmC;EAAW,iBAAA;CFoS9C;AEnSmC;EAAW,iBAAA;CFsS9C;AErSmC;EAAW,iBAAA;CFwS9C;AEvSmC;EAAW,iBAAA;CF0S9C;AEzSmC;EAAW,iBAAA;CF4S9C;AE3SmC;EAAW,iBAAA;CF8S9C;AE7SmC;EAAW,iBAAA;CFgT9C;AE/SmC;EAAW,iBAAA;CFkT9C;AEjTmC;EAAW,iBAAA;CFoT9C;AEnTmC;EAAW,iBAAA;CFsT9C;AErTmC;EAAW,iBAAA;CFwT9C;AEvTmC;EAAW,iBAAA;CF0T9C;AEzTmC;EAAW,iBAAA;CF4T9C;AE3TmC;EAAW,iBAAA;CF8T9C;AE7TmC;EAAW,iBAAA;CFgU9C;AE/TmC;EAAW,iBAAA;CFkU9C;AEjUmC;EAAW,iBAAA;CFoU9C;AEnUmC;EAAW,iBAAA;CFsU9C;AErUmC;EAAW,iBAAA;CFwU9C;AEvUmC;EAAW,iBAAA;CF0U9C;AEzUmC;EAAW,iBAAA;CF4U9C;AE3UmC;EAAW,iBAAA;CF8U9C;AE7UmC;EAAW,iBAAA;CFgV9C;AE/UmC;EAAW,iBAAA;CFkV9C;AEjVmC;EAAW,iBAAA;CFoV9C;AEnVmC;EAAW,iBAAA;CFsV9C;AErVmC;EAAW,iBAAA;CFwV9C;AEvVmC;EAAW,iBAAA;CF0V9C;AEzVmC;EAAW,iBAAA;CF4V9C;AE3VmC;EAAW,iBAAA;CF8V9C;AE7VmC;EAAW,iBAAA;CFgW9C;AE/VmC;EAAW,iBAAA;CFkW9C;AEjWmC;EAAW,iBAAA;CFoW9C;AEnWmC;EAAW,iBAAA;CFsW9C;AErWmC;EAAW,iBAAA;CFwW9C;AEvWmC;EAAW,iBAAA;CF0W9C;AEzWmC;EAAW,iBAAA;CF4W9C;AE3WmC;EAAW,iBAAA;CF8W9C;AE7WmC;EAAW,iBAAA;CFgX9C;AE/WmC;EAAW,iBAAA;CFkX9C;AEjXmC;EAAW,iBAAA;CFoX9C;AEnXmC;EAAW,iBAAA;CFsX9C;AErXmC;EAAW,iBAAA;CFwX9C;AEvXmC;EAAW,iBAAA;CF0X9C;AEzXmC;EAAW,iBAAA;CF4X9C;AE3XmC;EAAW,iBAAA;CF8X9C;AE7XmC;EAAW,iBAAA;CFgY9C;AE/XmC;EAAW,iBAAA;CFkY9C;AEjYmC;EAAW,iBAAA;CFoY9C;AEnYmC;EAAW,iBAAA;CFsY9C;AErYmC;EAAW,iBAAA;CFwY9C;AEvYmC;EAAW,iBAAA;CF0Y9C;AEzYmC;EAAW,iBAAA;CF4Y9C;AE3YmC;EAAW,iBAAA;CF8Y9C;AE7YmC;EAAW,iBAAA;CFgZ9C;AE/YmC;EAAW,iBAAA;CFkZ9C;AEjZmC;EAAW,iBAAA;CFoZ9C;AEnZmC;EAAW,iBAAA;CFsZ9C;AErZmC;EAAW,iBAAA;CFwZ9C;AEvZmC;EAAW,iBAAA;CF0Z9C;AEzZmC;EAAW,iBAAA;CF4Z9C;AE3ZmC;EAAW,iBAAA;CF8Z9C;AE7ZmC;EAAW,iBAAA;CFga9C;AE/ZmC;EAAW,iBAAA;CFka9C;AEjamC;EAAW,iBAAA;CFoa9C;AEnamC;EAAW,iBAAA;CFsa9C;AEramC;EAAW,iBAAA;CFwa9C;AEvamC;EAAW,iBAAA;CF0a9C;AEzamC;EAAW,iBAAA;CF4a9C;AE3amC;EAAW,iBAAA;CF8a9C;AE7amC;EAAW,iBAAA;CFgb9C;AE/amC;EAAW,iBAAA;CFkb9C;AEjbmC;EAAW,iBAAA;CFob9C;AEnbmC;EAAW,iBAAA;CFsb9C;AErbmC;EAAW,iBAAA;CFwb9C;AEvbmC;EAAW,iBAAA;CF0b9C;AEzbmC;EAAW,iBAAA;CF4b9C;AE3bmC;EAAW,iBAAA;CF8b9C;AE7bmC;EAAW,iBAAA;CFgc9C;AE/bmC;EAAW,iBAAA;CFkc9C;AEjcmC;EAAW,iBAAA;CFoc9C;AEncmC;EAAW,iBAAA;CFsc9C;AErcmC;EAAW,iBAAA;CFwc9C;AEvcmC;EAAW,iBAAA;CF0c9C;AEzcmC;EAAW,iBAAA;CF4c9C;AE3cmC;EAAW,iBAAA;CF8c9C;AE7cmC;EAAW,iBAAA;CFgd9C;AE/cmC;EAAW,iBAAA;CFkd9C;AEjdmC;EAAW,iBAAA;CFod9C;AEndmC;EAAW,iBAAA;CFsd9C;AErdmC;EAAW,iBAAA;CFwd9C;AEvdmC;EAAW,iBAAA;CF0d9C;AEzdmC;EAAW,iBAAA;CF4d9C;AE3dmC;EAAW,iBAAA;CF8d9C;AE7dmC;EAAW,iBAAA;CFge9C;AE/dmC;EAAW,iBAAA;CFke9C;AEjemC;EAAW,iBAAA;CFoe9C;AEnemC;EAAW,iBAAA;CFse9C;AEremC;EAAW,iBAAA;CFwe9C;AEvemC;EAAW,iBAAA;CF0e9C;AEzemC;EAAW,iBAAA;CF4e9C;AE3emC;EAAW,iBAAA;CF8e9C;AE7emC;EAAW,iBAAA;CFgf9C;AE/emC;EAAW,iBAAA;CFkf9C;AEjfmC;EAAW,iBAAA;CFof9C;AEnfmC;EAAW,iBAAA;CFsf9C;AErfmC;EAAW,iBAAA;CFwf9C;AEvfmC;EAAW,iBAAA;CF0f9C;AEzfmC;EAAW,iBAAA;CF4f9C;AE3fmC;EAAW,iBAAA;CF8f9C;AE7fmC;EAAW,iBAAA;CFggB9C;AE/fmC;EAAW,iBAAA;CFkgB9C;AEjgBmC;EAAW,iBAAA;CFogB9C;AEngBmC;EAAW,iBAAA;CFsgB9C;AErgBmC;EAAW,iBAAA;CFwgB9C;AEvgBmC;EAAW,iBAAA;CF0gB9C;AEzgBmC;EAAW,iBAAA;CF4gB9C;AE3gBmC;EAAW,iBAAA;CF8gB9C;AE7gBmC;EAAW,iBAAA;CFghB9C;AE/gBmC;EAAW,iBAAA;CFkhB9C;AEjhBmC;EAAW,iBAAA;CFohB9C;AEnhBmC;EAAW,iBAAA;CFshB9C;AErhBmC;EAAW,iBAAA;CFwhB9C;AEvhBmC;EAAW,iBAAA;CF0hB9C;AEzhBmC;EAAW,iBAAA;CF4hB9C;AE3hBmC;EAAW,iBAAA;CF8hB9C;AE7hBmC;EAAW,iBAAA;CFgiB9C;AE/hBmC;EAAW,iBAAA;CFkiB9C;AEjiBmC;EAAW,iBAAA;CFoiB9C;AEniBmC;EAAW,iBAAA;CFsiB9C;AEriBmC;EAAW,iBAAA;CFwiB9C;AEviBmC;EAAW,iBAAA;CF0iB9C;AEziBmC;EAAW,iBAAA;CF4iB9C;AE3iBmC;EAAW,iBAAA;CF8iB9C;AE7iBmC;EAAW,iBAAA;CFgjB9C;AE/iBmC;EAAW,iBAAA;CFkjB9C;AEjjBmC;EAAW,iBAAA;CFojB9C;AEnjBmC;EAAW,iBAAA;CFsjB9C;AErjBmC;EAAW,iBAAA;CFwjB9C;AEvjBmC;EAAW,iBAAA;CF0jB9C;AEzjBmC;EAAW,iBAAA;CF4jB9C;AE3jBmC;EAAW,iBAAA;CF8jB9C;AE7jBmC;EAAW,iBAAA;CFgkB9C;AE/jBmC;EAAW,iBAAA;CFkkB9C;AEjkBmC;EAAW,iBAAA;CFokB9C;AEnkBmC;EAAW,iBAAA;CFskB9C;AErkBmC;EAAW,iBAAA;CFwkB9C;AE/jBmC;EAAW,iBAAA;CFkkB9C;AEjkBmC;EAAW,iBAAA;CFokB9C;AEnkBmC;EAAW,iBAAA;CFskB9C;AErkBmC;EAAW,iBAAA;CFwkB9C;AEvkBmC;EAAW,iBAAA;CF0kB9C;AEzkBmC;EAAW,iBAAA;CF4kB9C;AE3kBmC;EAAW,iBAAA;CF8kB9C;AE7kBmC;EAAW,iBAAA;CFglB9C;AE/kBmC;EAAW,iBAAA;CFklB9C;AEjlBmC;EAAW,iBAAA;CFolB9C;AEnlBmC;EAAW,iBAAA;CFslB9C;AErlBmC;EAAW,iBAAA;CFwlB9C;AEvlBmC;EAAW,iBAAA;CF0lB9C;AEzlBmC;EAAW,iBAAA;CF4lB9C;AE3lBmC;EAAW,iBAAA;CF8lB9C;AE7lBmC;EAAW,iBAAA;CFgmB9C;AE/lBmC;EAAW,iBAAA;CFkmB9C;AEjmBmC;EAAW,iBAAA;CFomB9C;AEnmBmC;EAAW,iBAAA;CFsmB9C;AErmBmC;EAAW,iBAAA;CFwmB9C;AEvmBmC;EAAW,iBAAA;CF0mB9C;AEzmBmC;EAAW,iBAAA;CF4mB9C;AE3mBmC;EAAW,iBAAA;CF8mB9C;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oBAAA;Cdg/CL;Ach+CG;EACE,YAAA;Cdk+CL;Ac39CC;EACE,YAAA;Cd69CH;Ac99CC;EACE,oBAAA;Cdg+CH;Acj+CC;EACE,oBAAA;Cdm+CH;Acp+CC;EACE,WAAA;Cds+CH;Acv+CC;EACE,oBAAA;Cdy+CH;Ac1+CC;EACE,oBAAA;Cd4+CH;Ac7+CC;EACE,WAAA;Cd++CH;Ach/CC;EACE,oBAAA;Cdk/CH;Acn/CC;EACE,oBAAA;Cdq/CH;Act/CC;EACE,WAAA;Cdw/CH;Acz/CC;EACE,oBAAA;Cd2/CH;Ac5/CC;EACE,mBAAA;Cd8/CH;Ach/CC;EACE,YAAA;Cdk/CH;Acn/CC;EACE,oBAAA;Cdq/CH;Act/CC;EACE,oBAAA;Cdw/CH;Acz/CC;EACE,WAAA;Cd2/CH;Ac5/CC;EACE,oBAAA;Cd8/CH;Ac//CC;EACE,oBAAA;CdigDH;AclgDC;EACE,WAAA;CdogDH;AcrgDC;EACE,oBAAA;CdugDH;AcxgDC;EACE,oBAAA;Cd0gDH;Ac3gDC;EACE,WAAA;Cd6gDH;Ac9gDC;EACE,oBAAA;CdghDH;AcjhDC;EACE,mBAAA;CdmhDH;Ac/gDC;EACE,YAAA;CdihDH;AcjiDC;EACE,WAAA;CdmiDH;AcpiDC;EACE,mBAAA;CdsiDH;AcviDC;EACE,mBAAA;CdyiDH;Ac1iDC;EACE,UAAA;Cd4iDH;Ac7iDC;EACE,mBAAA;Cd+iDH;AchjDC;EACE,mBAAA;CdkjDH;AcnjDC;EACE,UAAA;CdqjDH;ActjDC;EACE,mBAAA;CdwjDH;AczjDC;EACE,mBAAA;Cd2jDH;Ac5jDC;EACE,UAAA;Cd8jDH;Ac/jDC;EACE,mBAAA;CdikDH;AclkDC;EACE,kBAAA;CdokDH;AchkDC;EACE,WAAA;CdkkDH;AcpjDC;EACE,kBAAA;CdsjDH;AcvjDC;EACE,0BAAA;CdyjDH;Ac1jDC;EACE,0BAAA;Cd4jDH;Ac7jDC;EACE,iBAAA;Cd+jDH;AchkDC;EACE,0BAAA;CdkkDH;AcnkDC;EACE,0BAAA;CdqkDH;ActkDC;EACE,iBAAA;CdwkDH;AczkDC;EACE,0BAAA;Cd2kDH;Ac5kDC;EACE,0BAAA;Cd8kDH;Ac/kDC;EACE,iBAAA;CdilDH;AcllDC;EACE,0BAAA;CdolDH;AcrlDC;EACE,yBAAA;CdulDH;AcxlDC;EACE,gBAAA;Cd0lDH;AYnmDD;EEzBI;IACE,YAAA;Gd+nDH;EcxnDD;IACE,YAAA;Gd0nDD;Ec3nDD;IACE,oBAAA;Gd6nDD;Ec9nDD;IACE,oBAAA;GdgoDD;EcjoDD;IACE,WAAA;GdmoDD;EcpoDD;IACE,oBAAA;GdsoDD;EcvoDD;IACE,oBAAA;GdyoDD;Ec1oDD;IACE,WAAA;Gd4oDD;Ec7oDD;IACE,oBAAA;Gd+oDD;EchpDD;IACE,oBAAA;GdkpDD;EcnpDD;IACE,WAAA;GdqpDD;EctpDD;IACE,oBAAA;GdwpDD;EczpDD;IACE,mBAAA;Gd2pDD;Ec7oDD;IACE,YAAA;Gd+oDD;EchpDD;IACE,oBAAA;GdkpDD;EcnpDD;IACE,oBAAA;GdqpDD;EctpDD;IACE,WAAA;GdwpDD;EczpDD;IACE,oBAAA;Gd2pDD;Ec5pDD;IACE,oBAAA;Gd8pDD;Ec/pDD;IACE,WAAA;GdiqDD;EclqDD;IACE,oBAAA;GdoqDD;EcrqDD;IACE,oBAAA;GduqDD;EcxqDD;IACE,WAAA;Gd0qDD;Ec3qDD;IACE,oBAAA;Gd6qDD;Ec9qDD;IACE,mBAAA;GdgrDD;Ec5qDD;IACE,YAAA;Gd8qDD;Ec9rDD;IACE,WAAA;GdgsDD;EcjsDD;IACE,mBAAA;GdmsDD;EcpsDD;IACE,mBAAA;GdssDD;EcvsDD;IACE,UAAA;GdysDD;Ec1sDD;IACE,mBAAA;Gd4sDD;Ec7sDD;IACE,mBAAA;Gd+sDD;EchtDD;IACE,UAAA;GdktDD;EcntDD;IACE,mBAAA;GdqtDD;EcttDD;IACE,mBAAA;GdwtDD;EcztDD;IACE,UAAA;Gd2tDD;Ec5tDD;IACE,mBAAA;Gd8tDD;Ec/tDD;IACE,kBAAA;GdiuDD;Ec7tDD;IACE,WAAA;Gd+tDD;EcjtDD;IACE,kBAAA;GdmtDD;EcptDD;IACE,0BAAA;GdstDD;EcvtDD;IACE,0BAAA;GdytDD;Ec1tDD;IACE,iBAAA;Gd4tDD;Ec7tDD;IACE,0BAAA;Gd+tDD;EchuDD;IACE,0BAAA;GdkuDD;EcnuDD;IACE,iBAAA;GdquDD;EctuDD;IACE,0BAAA;GdwuDD;EczuDD;IACE,0BAAA;Gd2uDD;Ec5uDD;IACE,iBAAA;Gd8uDD;Ec/uDD;IACE,0BAAA;GdivDD;EclvDD;IACE,yBAAA;GdovDD;EcrvDD;IACE,gBAAA;GduvDD;CACF;AYxvDD;EElCI;IACE,YAAA;Gd6xDH;EctxDD;IACE,YAAA;GdwxDD;EczxDD;IACE,oBAAA;Gd2xDD;Ec5xDD;IACE,oBAAA;Gd8xDD;Ec/xDD;IACE,WAAA;GdiyDD;EclyDD;IACE,oBAAA;GdoyDD;EcryDD;IACE,oBAAA;GduyDD;EcxyDD;IACE,WAAA;Gd0yDD;Ec3yDD;IACE,oBAAA;Gd6yDD;Ec9yDD;IACE,oBAAA;GdgzDD;EcjzDD;IACE,WAAA;GdmzDD;EcpzDD;IACE,oBAAA;GdszDD;EcvzDD;IACE,mBAAA;GdyzDD;Ec3yDD;IACE,YAAA;Gd6yDD;Ec9yDD;IACE,oBAAA;GdgzDD;EcjzDD;IACE,oBAAA;GdmzDD;EcpzDD;IACE,WAAA;GdszDD;EcvzDD;IACE,oBAAA;GdyzDD;Ec1zDD;IACE,oBAAA;Gd4zDD;Ec7zDD;IACE,WAAA;Gd+zDD;Ech0DD;IACE,oBAAA;Gdk0DD;Ecn0DD;IACE,oBAAA;Gdq0DD;Ect0DD;IACE,WAAA;Gdw0DD;Ecz0DD;IACE,oBAAA;Gd20DD;Ec50DD;IACE,mBAAA;Gd80DD;Ec10DD;IACE,YAAA;Gd40DD;Ec51DD;IACE,WAAA;Gd81DD;Ec/1DD;IACE,mBAAA;Gdi2DD;Ecl2DD;IACE,mBAAA;Gdo2DD;Ecr2DD;IACE,UAAA;Gdu2DD;Ecx2DD;IACE,mBAAA;Gd02DD;Ec32DD;IACE,mBAAA;Gd62DD;Ec92DD;IACE,UAAA;Gdg3DD;Ecj3DD;IACE,mBAAA;Gdm3DD;Ecp3DD;IACE,mBAAA;Gds3DD;Ecv3DD;IACE,UAAA;Gdy3DD;Ec13DD;IACE,mBAAA;Gd43DD;Ec73DD;IACE,kBAAA;Gd+3DD;Ec33DD;IACE,WAAA;Gd63DD;Ec/2DD;IACE,kBAAA;Gdi3DD;Ecl3DD;IACE,0BAAA;Gdo3DD;Ecr3DD;IACE,0BAAA;Gdu3DD;Ecx3DD;IACE,iBAAA;Gd03DD;Ec33DD;IACE,0BAAA;Gd63DD;Ec93DD;IACE,0BAAA;Gdg4DD;Ecj4DD;IACE,iBAAA;Gdm4DD;Ecp4DD;IACE,0BAAA;Gds4DD;Ecv4DD;IACE,0BAAA;Gdy4DD;Ec14DD;IACE,iBAAA;Gd44DD;Ec74DD;IACE,0BAAA;Gd+4DD;Ech5DD;IACE,yBAAA;Gdk5DD;Ecn5DD;IACE,gBAAA;Gdq5DD;CACF;AY74DD;EE3CI;IACE,YAAA;Gd27DH;Ecp7DD;IACE,YAAA;Gds7DD;Ecv7DD;IACE,oBAAA;Gdy7DD;Ec17DD;IACE,oBAAA;Gd47DD;Ec77DD;IACE,WAAA;Gd+7DD;Ech8DD;IACE,oBAAA;Gdk8DD;Ecn8DD;IACE,oBAAA;Gdq8DD;Ect8DD;IACE,WAAA;Gdw8DD;Ecz8DD;IACE,oBAAA;Gd28DD;Ec58DD;IACE,oBAAA;Gd88DD;Ec/8DD;IACE,WAAA;Gdi9DD;Ecl9DD;IACE,oBAAA;Gdo9DD;Ecr9DD;IACE,mBAAA;Gdu9DD;Ecz8DD;IACE,YAAA;Gd28DD;Ec58DD;IACE,oBAAA;Gd88DD;Ec/8DD;IACE,oBAAA;Gdi9DD;Ecl9DD;IACE,WAAA;Gdo9DD;Ecr9DD;IACE,oBAAA;Gdu9DD;Ecx9DD;IACE,oBAAA;Gd09DD;Ec39DD;IACE,WAAA;Gd69DD;Ec99DD;IACE,oBAAA;Gdg+DD;Ecj+DD;IACE,oBAAA;Gdm+DD;Ecp+DD;IACE,WAAA;Gds+DD;Ecv+DD;IACE,oBAAA;Gdy+DD;Ec1+DD;IACE,mBAAA;Gd4+DD;Ecx+DD;IACE,YAAA;Gd0+DD;Ec1/DD;IACE,WAAA;Gd4/DD;Ec7/DD;IACE,mBAAA;Gd+/DD;EchgED;IACE,mBAAA;GdkgED;EcngED;IACE,UAAA;GdqgED;EctgED;IACE,mBAAA;GdwgED;EczgED;IACE,mBAAA;Gd2gED;Ec5gED;IACE,UAAA;Gd8gED;Ec/gED;IACE,mBAAA;GdihED;EclhED;IACE,mBAAA;GdohED;EcrhED;IACE,UAAA;GduhED;EcxhED;IACE,mBAAA;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","file":"impac-angular.css","sourcesContent":["/*\n** All @import's should live in this file!\n*/\n/**\n *  Do not remove this comments bellow. It's the markers used by wiredep to inject\n *  less dependencies when defined in the bower.json of your dependencies\n */\n/*!\n * Bootstrap v3.3.7 (http://getbootstrap.com)\n * Copyright 2011-2016 Twitter, Inc.\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n */\n/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */\nhtml {\n  font-family: sans-serif;\n  -ms-text-size-adjust: 100%;\n  -webkit-text-size-adjust: 100%;\n}\nbody {\n  margin: 0;\n}\narticle,\naside,\ndetails,\nfigcaption,\nfigure,\nfooter,\nheader,\nhgroup,\nmain,\nmenu,\nnav,\nsection,\nsummary {\n  display: block;\n}\naudio,\ncanvas,\nprogress,\nvideo {\n  display: inline-block;\n  vertical-align: baseline;\n}\naudio:not([controls]) {\n  display: none;\n  height: 0;\n}\n[hidden],\ntemplate {\n  display: none;\n}\na {\n  background-color: transparent;\n}\na:active,\na:hover {\n  outline: 0;\n}\nabbr[title] {\n  border-bottom: 1px dotted;\n}\nb,\nstrong {\n  font-weight: bold;\n}\ndfn {\n  font-style: italic;\n}\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0;\n}\nmark {\n  background: #ff0;\n  color: #000;\n}\nsmall {\n  font-size: 80%;\n}\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n}\nsup {\n  top: -0.5em;\n}\nsub {\n  bottom: -0.25em;\n}\nimg {\n  border: 0;\n}\nsvg:not(:root) {\n  overflow: hidden;\n}\nfigure {\n  margin: 1em 40px;\n}\nhr {\n  box-sizing: content-box;\n  height: 0;\n}\npre {\n  overflow: auto;\n}\ncode,\nkbd,\npre,\nsamp {\n  font-family: monospace, monospace;\n  font-size: 1em;\n}\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  color: inherit;\n  font: inherit;\n  margin: 0;\n}\nbutton {\n  overflow: visible;\n}\nbutton,\nselect {\n  text-transform: none;\n}\nbutton,\nhtml input[type=\"button\"],\ninput[type=\"reset\"],\ninput[type=\"submit\"] {\n  -webkit-appearance: button;\n  cursor: pointer;\n}\nbutton[disabled],\nhtml input[disabled] {\n  cursor: default;\n}\nbutton::-moz-focus-inner,\ninput::-moz-focus-inner {\n  border: 0;\n  padding: 0;\n}\ninput {\n  line-height: normal;\n}\ninput[type=\"checkbox\"],\ninput[type=\"radio\"] {\n  box-sizing: border-box;\n  padding: 0;\n}\ninput[type=\"number\"]::-webkit-inner-spin-button,\ninput[type=\"number\"]::-webkit-outer-spin-button {\n  height: auto;\n}\ninput[type=\"search\"] {\n  -webkit-appearance: textfield;\n  box-sizing: content-box;\n}\ninput[type=\"search\"]::-webkit-search-cancel-button,\ninput[type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none;\n}\nfieldset {\n  border: 1px solid #c0c0c0;\n  margin: 0 2px;\n  padding: 0.35em 0.625em 0.75em;\n}\nlegend {\n  border: 0;\n  padding: 0;\n}\ntextarea {\n  overflow: auto;\n}\noptgroup {\n  font-weight: bold;\n}\ntable {\n  border-collapse: collapse;\n  border-spacing: 0;\n}\ntd,\nth {\n  padding: 0;\n}\n@font-face {\n  font-family: 'Glyphicons Halflings';\n  src: url('../fonts/glyphicons-halflings-regular.eot');\n  src: url('../fonts/glyphicons-halflings-regular.eot?#iefix') format('embedded-opentype'), url('../fonts/glyphicons-halflings-regular.woff2') format('woff2'), url('../fonts/glyphicons-halflings-regular.woff') format('woff'), url('../fonts/glyphicons-halflings-regular.ttf') format('truetype'), url('../fonts/glyphicons-halflings-regular.svg#glyphicons_halflingsregular') format('svg');\n}\n.glyphicon {\n  position: relative;\n  top: 1px;\n  display: inline-block;\n  font-family: 'Glyphicons Halflings';\n  font-style: normal;\n  font-weight: normal;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n.glyphicon-asterisk:before {\n  content: \"\\002a\";\n}\n.glyphicon-plus:before {\n  content: \"\\002b\";\n}\n.glyphicon-euro:before,\n.glyphicon-eur:before {\n  content: \"\\20ac\";\n}\n.glyphicon-minus:before {\n  content: \"\\2212\";\n}\n.glyphicon-cloud:before {\n  content: \"\\2601\";\n}\n.glyphicon-envelope:before {\n  content: \"\\2709\";\n}\n.glyphicon-pencil:before {\n  content: \"\\270f\";\n}\n.glyphicon-glass:before {\n  content: \"\\e001\";\n}\n.glyphicon-music:before {\n  content: \"\\e002\";\n}\n.glyphicon-search:before {\n  content: \"\\e003\";\n}\n.glyphicon-heart:before {\n  content: \"\\e005\";\n}\n.glyphicon-star:before {\n  content: \"\\e006\";\n}\n.glyphicon-star-empty:before {\n  content: \"\\e007\";\n}\n.glyphicon-user:before {\n  content: \"\\e008\";\n}\n.glyphicon-film:before {\n  content: \"\\e009\";\n}\n.glyphicon-th-large:before {\n  content: \"\\e010\";\n}\n.glyphicon-th:before {\n  content: \"\\e011\";\n}\n.glyphicon-th-list:before {\n  content: \"\\e012\";\n}\n.glyphicon-ok:before {\n  content: \"\\e013\";\n}\n.glyphicon-remove:before {\n  content: \"\\e014\";\n}\n.glyphicon-zoom-in:before {\n  content: \"\\e015\";\n}\n.glyphicon-zoom-out:before {\n  content: \"\\e016\";\n}\n.glyphicon-off:before {\n  content: \"\\e017\";\n}\n.glyphicon-signal:before {\n  content: \"\\e018\";\n}\n.glyphicon-cog:before {\n  content: \"\\e019\";\n}\n.glyphicon-trash:before {\n  content: \"\\e020\";\n}\n.glyphicon-home:before {\n  content: \"\\e021\";\n}\n.glyphicon-file:before {\n  content: \"\\e022\";\n}\n.glyphicon-time:before {\n  content: \"\\e023\";\n}\n.glyphicon-road:before {\n  content: \"\\e024\";\n}\n.glyphicon-download-alt:before {\n  content: \"\\e025\";\n}\n.glyphicon-download:before {\n  content: \"\\e026\";\n}\n.glyphicon-upload:before {\n  content: \"\\e027\";\n}\n.glyphicon-inbox:before {\n  content: \"\\e028\";\n}\n.glyphicon-play-circle:before {\n  content: \"\\e029\";\n}\n.glyphicon-repeat:before {\n  content: \"\\e030\";\n}\n.glyphicon-refresh:before {\n  content: \"\\e031\";\n}\n.glyphicon-list-alt:before {\n  content: \"\\e032\";\n}\n.glyphicon-lock:before {\n  content: \"\\e033\";\n}\n.glyphicon-flag:before {\n  content: \"\\e034\";\n}\n.glyphicon-headphones:before {\n  content: \"\\e035\";\n}\n.glyphicon-volume-off:before {\n  content: \"\\e036\";\n}\n.glyphicon-volume-down:before {\n  content: \"\\e037\";\n}\n.glyphicon-volume-up:before {\n  content: \"\\e038\";\n}\n.glyphicon-qrcode:before {\n  content: \"\\e039\";\n}\n.glyphicon-barcode:before {\n  content: \"\\e040\";\n}\n.glyphicon-tag:before {\n  content: \"\\e041\";\n}\n.glyphicon-tags:before {\n  content: \"\\e042\";\n}\n.glyphicon-book:before {\n  content: \"\\e043\";\n}\n.glyphicon-bookmark:before {\n  content: \"\\e044\";\n}\n.glyphicon-print:before {\n  content: \"\\e045\";\n}\n.glyphicon-camera:before {\n  content: \"\\e046\";\n}\n.glyphicon-font:before {\n  content: \"\\e047\";\n}\n.glyphicon-bold:before {\n  content: \"\\e048\";\n}\n.glyphicon-italic:before {\n  content: \"\\e049\";\n}\n.glyphicon-text-height:before {\n  content: \"\\e050\";\n}\n.glyphicon-text-width:before {\n  content: \"\\e051\";\n}\n.glyphicon-align-left:before {\n  content: \"\\e052\";\n}\n.glyphicon-align-center:before {\n  content: \"\\e053\";\n}\n.glyphicon-align-right:before {\n  content: \"\\e054\";\n}\n.glyphicon-align-justify:before {\n  content: \"\\e055\";\n}\n.glyphicon-list:before {\n  content: \"\\e056\";\n}\n.glyphicon-indent-left:before {\n  content: \"\\e057\";\n}\n.glyphicon-indent-right:before {\n  content: \"\\e058\";\n}\n.glyphicon-facetime-video:before {\n  content: \"\\e059\";\n}\n.glyphicon-picture:before {\n  content: \"\\e060\";\n}\n.glyphicon-map-marker:before {\n  content: \"\\e062\";\n}\n.glyphicon-adjust:before {\n  content: \"\\e063\";\n}\n.glyphicon-tint:before {\n  content: \"\\e064\";\n}\n.glyphicon-edit:before {\n  content: \"\\e065\";\n}\n.glyphicon-share:before {\n  content: \"\\e066\";\n}\n.glyphicon-check:before {\n  content: \"\\e067\";\n}\n.glyphicon-move:before {\n  content: \"\\e068\";\n}\n.glyphicon-step-backward:before {\n  content: \"\\e069\";\n}\n.glyphicon-fast-backward:before {\n  content: \"\\e070\";\n}\n.glyphicon-backward:before {\n  content: \"\\e071\";\n}\n.glyphicon-play:before {\n  content: \"\\e072\";\n}\n.glyphicon-pause:before {\n  content: \"\\e073\";\n}\n.glyphicon-stop:before {\n  content: \"\\e074\";\n}\n.glyphicon-forward:before {\n  content: \"\\e075\";\n}\n.glyphicon-fast-forward:before {\n  content: \"\\e076\";\n}\n.glyphicon-step-forward:before {\n  content: \"\\e077\";\n}\n.glyphicon-eject:before {\n  content: \"\\e078\";\n}\n.glyphicon-chevron-left:before {\n  content: \"\\e079\";\n}\n.glyphicon-chevron-right:before {\n  content: \"\\e080\";\n}\n.glyphicon-plus-sign:before {\n  content: \"\\e081\";\n}\n.glyphicon-minus-sign:before {\n  content: \"\\e082\";\n}\n.glyphicon-remove-sign:before {\n  content: \"\\e083\";\n}\n.glyphicon-ok-sign:before {\n  content: \"\\e084\";\n}\n.glyphicon-question-sign:before {\n  content: \"\\e085\";\n}\n.glyphicon-info-sign:before {\n  content: \"\\e086\";\n}\n.glyphicon-screenshot:before {\n  content: \"\\e087\";\n}\n.glyphicon-remove-circle:before {\n  content: \"\\e088\";\n}\n.glyphicon-ok-circle:before {\n  content: \"\\e089\";\n}\n.glyphicon-ban-circle:before {\n  content: \"\\e090\";\n}\n.glyphicon-arrow-left:before {\n  content: \"\\e091\";\n}\n.glyphicon-arrow-right:before {\n  content: \"\\e092\";\n}\n.glyphicon-arrow-up:before {\n  content: \"\\e093\";\n}\n.glyphicon-arrow-down:before {\n  content: \"\\e094\";\n}\n.glyphicon-share-alt:before {\n  content: \"\\e095\";\n}\n.glyphicon-resize-full:before {\n  content: \"\\e096\";\n}\n.glyphicon-resize-small:before {\n  content: \"\\e097\";\n}\n.glyphicon-exclamation-sign:before {\n  content: \"\\e101\";\n}\n.glyphicon-gift:before {\n  content: \"\\e102\";\n}\n.glyphicon-leaf:before {\n  content: \"\\e103\";\n}\n.glyphicon-fire:before {\n  content: \"\\e104\";\n}\n.glyphicon-eye-open:before {\n  content: \"\\e105\";\n}\n.glyphicon-eye-close:before {\n  content: \"\\e106\";\n}\n.glyphicon-warning-sign:before {\n  content: \"\\e107\";\n}\n.glyphicon-plane:before {\n  content: \"\\e108\";\n}\n.glyphicon-calendar:before {\n  content: \"\\e109\";\n}\n.glyphicon-random:before {\n  content: \"\\e110\";\n}\n.glyphicon-comment:before {\n  content: \"\\e111\";\n}\n.glyphicon-magnet:before {\n  content: \"\\e112\";\n}\n.glyphicon-chevron-up:before {\n  content: \"\\e113\";\n}\n.glyphicon-chevron-down:before {\n  content: \"\\e114\";\n}\n.glyphicon-retweet:before {\n  content: \"\\e115\";\n}\n.glyphicon-shopping-cart:before {\n  content: \"\\e116\";\n}\n.glyphicon-folder-close:before {\n  content: \"\\e117\";\n}\n.glyphicon-folder-open:before {\n  content: \"\\e118\";\n}\n.glyphicon-resize-vertical:before {\n  content: \"\\e119\";\n}\n.glyphicon-resize-horizontal:before {\n  content: \"\\e120\";\n}\n.glyphicon-hdd:before {\n  content: \"\\e121\";\n}\n.glyphicon-bullhorn:before {\n  content: \"\\e122\";\n}\n.glyphicon-bell:before {\n  content: \"\\e123\";\n}\n.glyphicon-certificate:before {\n  content: \"\\e124\";\n}\n.glyphicon-thumbs-up:before {\n  content: \"\\e125\";\n}\n.glyphicon-thumbs-down:before {\n  content: \"\\e126\";\n}\n.glyphicon-hand-right:before {\n  content: \"\\e127\";\n}\n.glyphicon-hand-left:before {\n  content: \"\\e128\";\n}\n.glyphicon-hand-up:before {\n  content: \"\\e129\";\n}\n.glyphicon-hand-down:before {\n  content: \"\\e130\";\n}\n.glyphicon-circle-arrow-right:before {\n  content: \"\\e131\";\n}\n.glyphicon-circle-arrow-left:before {\n  content: \"\\e132\";\n}\n.glyphicon-circle-arrow-up:before {\n  content: \"\\e133\";\n}\n.glyphicon-circle-arrow-down:before {\n  content: \"\\e134\";\n}\n.glyphicon-globe:before {\n  content: \"\\e135\";\n}\n.glyphicon-wrench:before {\n  content: \"\\e136\";\n}\n.glyphicon-tasks:before {\n  content: \"\\e137\";\n}\n.glyphicon-filter:before {\n  content: \"\\e138\";\n}\n.glyphicon-briefcase:before {\n  content: \"\\e139\";\n}\n.glyphicon-fullscreen:before {\n  content: \"\\e140\";\n}\n.glyphicon-dashboard:before {\n  content: \"\\e141\";\n}\n.glyphicon-paperclip:before {\n  content: \"\\e142\";\n}\n.glyphicon-heart-empty:before {\n  content: \"\\e143\";\n}\n.glyphicon-link:before {\n  content: \"\\e144\";\n}\n.glyphicon-phone:before {\n  content: \"\\e145\";\n}\n.glyphicon-pushpin:before {\n  content: \"\\e146\";\n}\n.glyphicon-usd:before {\n  content: \"\\e148\";\n}\n.glyphicon-gbp:before {\n  content: \"\\e149\";\n}\n.glyphicon-sort:before {\n  content: \"\\e150\";\n}\n.glyphicon-sort-by-alphabet:before {\n  content: \"\\e151\";\n}\n.glyphicon-sort-by-alphabet-alt:before {\n  content: \"\\e152\";\n}\n.glyphicon-sort-by-order:before {\n  content: \"\\e153\";\n}\n.glyphicon-sort-by-order-alt:before {\n  content: \"\\e154\";\n}\n.glyphicon-sort-by-attributes:before {\n  content: \"\\e155\";\n}\n.glyphicon-sort-by-attributes-alt:before {\n  content: \"\\e156\";\n}\n.glyphicon-unchecked:before {\n  content: \"\\e157\";\n}\n.glyphicon-expand:before {\n  content: \"\\e158\";\n}\n.glyphicon-collapse-down:before {\n  content: \"\\e159\";\n}\n.glyphicon-collapse-up:before {\n  content: \"\\e160\";\n}\n.glyphicon-log-in:before {\n  content: \"\\e161\";\n}\n.glyphicon-flash:before {\n  content: \"\\e162\";\n}\n.glyphicon-log-out:before {\n  content: \"\\e163\";\n}\n.glyphicon-new-window:before {\n  content: \"\\e164\";\n}\n.glyphicon-record:before {\n  content: \"\\e165\";\n}\n.glyphicon-save:before {\n  content: \"\\e166\";\n}\n.glyphicon-open:before {\n  content: \"\\e167\";\n}\n.glyphicon-saved:before {\n  content: \"\\e168\";\n}\n.glyphicon-import:before {\n  content: \"\\e169\";\n}\n.glyphicon-export:before {\n  content: \"\\e170\";\n}\n.glyphicon-send:before {\n  content: \"\\e171\";\n}\n.glyphicon-floppy-disk:before {\n  content: \"\\e172\";\n}\n.glyphicon-floppy-saved:before {\n  content: \"\\e173\";\n}\n.glyphicon-floppy-remove:before {\n  content: \"\\e174\";\n}\n.glyphicon-floppy-save:before {\n  content: \"\\e175\";\n}\n.glyphicon-floppy-open:before {\n  content: \"\\e176\";\n}\n.glyphicon-credit-card:before {\n  content: \"\\e177\";\n}\n.glyphicon-transfer:before {\n  content: \"\\e178\";\n}\n.glyphicon-cutlery:before {\n  content: \"\\e179\";\n}\n.glyphicon-header:before {\n  content: \"\\e180\";\n}\n.glyphicon-compressed:before {\n  content: \"\\e181\";\n}\n.glyphicon-earphone:before {\n  content: \"\\e182\";\n}\n.glyphicon-phone-alt:before {\n  content: \"\\e183\";\n}\n.glyphicon-tower:before {\n  content: \"\\e184\";\n}\n.glyphicon-stats:before {\n  content: \"\\e185\";\n}\n.glyphicon-sd-video:before {\n  content: \"\\e186\";\n}\n.glyphicon-hd-video:before {\n  content: \"\\e187\";\n}\n.glyphicon-subtitles:before {\n  content: \"\\e188\";\n}\n.glyphicon-sound-stereo:before {\n  content: \"\\e189\";\n}\n.glyphicon-sound-dolby:before {\n  content: \"\\e190\";\n}\n.glyphicon-sound-5-1:before {\n  content: \"\\e191\";\n}\n.glyphicon-sound-6-1:before {\n  content: \"\\e192\";\n}\n.glyphicon-sound-7-1:before {\n  content: \"\\e193\";\n}\n.glyphicon-copyright-mark:before {\n  content: \"\\e194\";\n}\n.glyphicon-registration-mark:before {\n  content: \"\\e195\";\n}\n.glyphicon-cloud-download:before {\n  content: \"\\e197\";\n}\n.glyphicon-cloud-upload:before {\n  content: \"\\e198\";\n}\n.glyphicon-tree-conifer:before {\n  content: \"\\e199\";\n}\n.glyphicon-tree-deciduous:before {\n  content: \"\\e200\";\n}\n.glyphicon-cd:before {\n  content: \"\\e201\";\n}\n.glyphicon-save-file:before {\n  content: \"\\e202\";\n}\n.glyphicon-open-file:before {\n  content: \"\\e203\";\n}\n.glyphicon-level-up:before {\n  content: \"\\e204\";\n}\n.glyphicon-copy:before {\n  content: \"\\e205\";\n}\n.glyphicon-paste:before {\n  content: \"\\e206\";\n}\n.glyphicon-alert:before {\n  content: \"\\e209\";\n}\n.glyphicon-equalizer:before {\n  content: \"\\e210\";\n}\n.glyphicon-king:before {\n  content: \"\\e211\";\n}\n.glyphicon-queen:before {\n  content: \"\\e212\";\n}\n.glyphicon-pawn:before {\n  content: \"\\e213\";\n}\n.glyphicon-bishop:before {\n  content: \"\\e214\";\n}\n.glyphicon-knight:before {\n  content: \"\\e215\";\n}\n.glyphicon-baby-formula:before {\n  content: \"\\e216\";\n}\n.glyphicon-tent:before {\n  content: \"\\26fa\";\n}\n.glyphicon-blackboard:before {\n  content: \"\\e218\";\n}\n.glyphicon-bed:before {\n  content: \"\\e219\";\n}\n.glyphicon-apple:before {\n  content: \"\\f8ff\";\n}\n.glyphicon-erase:before {\n  content: \"\\e221\";\n}\n.glyphicon-hourglass:before {\n  content: \"\\231b\";\n}\n.glyphicon-lamp:before {\n  content: \"\\e223\";\n}\n.glyphicon-duplicate:before {\n  content: \"\\e224\";\n}\n.glyphicon-piggy-bank:before {\n  content: \"\\e225\";\n}\n.glyphicon-scissors:before {\n  content: \"\\e226\";\n}\n.glyphicon-bitcoin:before {\n  content: \"\\e227\";\n}\n.glyphicon-btc:before {\n  content: \"\\e227\";\n}\n.glyphicon-xbt:before {\n  content: \"\\e227\";\n}\n.glyphicon-yen:before {\n  content: \"\\00a5\";\n}\n.glyphicon-jpy:before {\n  content: \"\\00a5\";\n}\n.glyphicon-ruble:before {\n  content: \"\\20bd\";\n}\n.glyphicon-rub:before {\n  content: \"\\20bd\";\n}\n.glyphicon-scale:before {\n  content: \"\\e230\";\n}\n.glyphicon-ice-lolly:before {\n  content: \"\\e231\";\n}\n.glyphicon-ice-lolly-tasted:before {\n  content: \"\\e232\";\n}\n.glyphicon-education:before {\n  content: \"\\e233\";\n}\n.glyphicon-option-horizontal:before {\n  content: \"\\e234\";\n}\n.glyphicon-option-vertical:before {\n  content: \"\\e235\";\n}\n.glyphicon-menu-hamburger:before {\n  content: \"\\e236\";\n}\n.glyphicon-modal-window:before {\n  content: \"\\e237\";\n}\n.glyphicon-oil:before {\n  content: \"\\e238\";\n}\n.glyphicon-grain:before {\n  content: \"\\e239\";\n}\n.glyphicon-sunglasses:before {\n  content: \"\\e240\";\n}\n.glyphicon-text-size:before {\n  content: \"\\e241\";\n}\n.glyphicon-text-color:before {\n  content: \"\\e242\";\n}\n.glyphicon-text-background:before {\n  content: \"\\e243\";\n}\n.glyphicon-object-align-top:before {\n  content: \"\\e244\";\n}\n.glyphicon-object-align-bottom:before {\n  content: \"\\e245\";\n}\n.glyphicon-object-align-horizontal:before {\n  content: \"\\e246\";\n}\n.glyphicon-object-align-left:before {\n  content: \"\\e247\";\n}\n.glyphicon-object-align-vertical:before {\n  content: \"\\e248\";\n}\n.glyphicon-object-align-right:before {\n  content: \"\\e249\";\n}\n.glyphicon-triangle-right:before {\n  content: \"\\e250\";\n}\n.glyphicon-triangle-left:before {\n  content: \"\\e251\";\n}\n.glyphicon-triangle-bottom:before {\n  content: \"\\e252\";\n}\n.glyphicon-triangle-top:before {\n  content: \"\\e253\";\n}\n.glyphicon-console:before {\n  content: \"\\e254\";\n}\n.glyphicon-superscript:before {\n  content: \"\\e255\";\n}\n.glyphicon-subscript:before {\n  content: \"\\e256\";\n}\n.glyphicon-menu-left:before {\n  content: \"\\e257\";\n}\n.glyphicon-menu-right:before {\n  content: \"\\e258\";\n}\n.glyphicon-menu-down:before {\n  content: \"\\e259\";\n}\n.glyphicon-menu-up:before {\n  content: \"\\e260\";\n}\n* {\n  -webkit-box-sizing: border-box;\n  -moz-box-sizing: border-box;\n  box-sizing: border-box;\n}\n*:before,\n*:after {\n  -webkit-box-sizing: border-box;\n  -moz-box-sizing: border-box;\n  box-sizing: border-box;\n}\nhtml {\n  font-size: 10px;\n  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);\n}\nbody {\n  font-family: \"Helvetica Neue\", Helvetica, Arial, sans-serif;\n  font-size: 14px;\n  line-height: 1.42857143;\n  color: #333333;\n  background-color: #fff;\n}\ninput,\nbutton,\nselect,\ntextarea {\n  font-family: inherit;\n  font-size: inherit;\n  line-height: inherit;\n}\na {\n  color: #00e5f0;\n  text-decoration: none;\n}\na:hover,\na:focus {\n  color: #009ca3;\n  text-decoration: underline;\n}\na:focus {\n  outline: 5px auto -webkit-focus-ring-color;\n  outline-offset: -2px;\n}\nfigure {\n  margin: 0;\n}\nimg {\n  vertical-align: middle;\n}\n.img-responsive,\n.thumbnail > img,\n.thumbnail a > img,\n.carousel-inner > .item > img,\n.carousel-inner > .item > a > img {\n  display: block;\n  max-width: 100%;\n  height: auto;\n}\n.img-rounded {\n  border-radius: 6px;\n}\n.img-thumbnail {\n  padding: 4px;\n  line-height: 1.42857143;\n  background-color: #fff;\n  border: 1px solid #ddd;\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.img-circle {\n  border-radius: 50%;\n}\nhr {\n  margin-top: 20px;\n  margin-bottom: 20px;\n  border: 0;\n  border-top: 1px solid #eeeeee;\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.sr-only-focusable:active,\n.sr-only-focusable:focus {\n  position: static;\n  width: auto;\n  height: auto;\n  margin: 0;\n  overflow: visible;\n  clip: auto;\n}\n[role=\"button\"] {\n  cursor: pointer;\n}\nh1,\nh2,\nh3,\nh4,\nh5,\nh6,\n.h1,\n.h2,\n.h3,\n.h4,\n.h5,\n.h6 {\n  font-family: inherit;\n  font-weight: 500;\n  line-height: 1.1;\n  color: inherit;\n}\nh1 small,\nh2 small,\nh3 small,\nh4 small,\nh5 small,\nh6 small,\n.h1 small,\n.h2 small,\n.h3 small,\n.h4 small,\n.h5 small,\n.h6 small,\nh1 .small,\nh2 .small,\nh3 .small,\nh4 .small,\nh5 .small,\nh6 .small,\n.h1 .small,\n.h2 .small,\n.h3 .small,\n.h4 .small,\n.h5 .small,\n.h6 .small {\n  font-weight: normal;\n  line-height: 1;\n  color: #777777;\n}\nh1,\n.h1,\nh2,\n.h2,\nh3,\n.h3 {\n  margin-top: 20px;\n  margin-bottom: 10px;\n}\nh1 small,\n.h1 small,\nh2 small,\n.h2 small,\nh3 small,\n.h3 small,\nh1 .small,\n.h1 .small,\nh2 .small,\n.h2 .small,\nh3 .small,\n.h3 .small {\n  font-size: 65%;\n}\nh4,\n.h4,\nh5,\n.h5,\nh6,\n.h6 {\n  margin-top: 10px;\n  margin-bottom: 10px;\n}\nh4 small,\n.h4 small,\nh5 small,\n.h5 small,\nh6 small,\n.h6 small,\nh4 .small,\n.h4 .small,\nh5 .small,\n.h5 .small,\nh6 .small,\n.h6 .small {\n  font-size: 75%;\n}\nh1,\n.h1 {\n  font-size: 36px;\n}\nh2,\n.h2 {\n  font-size: 30px;\n}\nh3,\n.h3 {\n  font-size: 24px;\n}\nh4,\n.h4 {\n  font-size: 18px;\n}\nh5,\n.h5 {\n  font-size: 14px;\n}\nh6,\n.h6 {\n  font-size: 12px;\n}\np {\n  margin: 0 0 10px;\n}\n.lead {\n  margin-bottom: 20px;\n  font-size: 16px;\n  font-weight: 300;\n  line-height: 1.4;\n}\n@media (min-width: 768px) {\n  .lead {\n    font-size: 21px;\n  }\n}\nsmall,\n.small {\n  font-size: 85%;\n}\nmark,\n.mark {\n  background-color: #fcf8e3;\n  padding: .2em;\n}\n.text-left {\n  text-align: left;\n}\n.text-right {\n  text-align: right;\n}\n.text-center {\n  text-align: center;\n}\n.text-justify {\n  text-align: justify;\n}\n.text-nowrap {\n  white-space: nowrap;\n}\n.text-lowercase {\n  text-transform: lowercase;\n}\n.text-uppercase {\n  text-transform: uppercase;\n}\n.text-capitalize {\n  text-transform: capitalize;\n}\n.text-muted {\n  color: #777777;\n}\n.text-primary {\n  color: #00e5f0;\n}\na.text-primary:hover,\na.text-primary:focus {\n  color: #00b4bd;\n}\n.text-success {\n  color: #3c763d;\n}\na.text-success:hover,\na.text-success:focus {\n  color: #2b542c;\n}\n.text-info {\n  color: #31708f;\n}\na.text-info:hover,\na.text-info:focus {\n  color: #245269;\n}\n.text-warning {\n  color: #8a6d3b;\n}\na.text-warning:hover,\na.text-warning:focus {\n  color: #66512c;\n}\n.text-danger {\n  color: #a94442;\n}\na.text-danger:hover,\na.text-danger:focus {\n  color: #843534;\n}\n.bg-primary {\n  color: #fff;\n  background-color: #00e5f0;\n}\na.bg-primary:hover,\na.bg-primary:focus {\n  background-color: #00b4bd;\n}\n.bg-success {\n  background-color: #dff0d8;\n}\na.bg-success:hover,\na.bg-success:focus {\n  background-color: #c1e2b3;\n}\n.bg-info {\n  background-color: #d9edf7;\n}\na.bg-info:hover,\na.bg-info:focus {\n  background-color: #afd9ee;\n}\n.bg-warning {\n  background-color: #fcf8e3;\n}\na.bg-warning:hover,\na.bg-warning:focus {\n  background-color: #f7ecb5;\n}\n.bg-danger {\n  background-color: #f2dede;\n}\na.bg-danger:hover,\na.bg-danger:focus {\n  background-color: #e4b9b9;\n}\n.page-header {\n  padding-bottom: 9px;\n  margin: 40px 0 20px;\n  border-bottom: 1px solid #eeeeee;\n}\nul,\nol {\n  margin-top: 0;\n  margin-bottom: 10px;\n}\nul ul,\nol ul,\nul ol,\nol ol {\n  margin-bottom: 0;\n}\n.list-unstyled {\n  padding-left: 0;\n  list-style: none;\n}\n.list-inline {\n  padding-left: 0;\n  list-style: none;\n  margin-left: -5px;\n}\n.list-inline > li {\n  display: inline-block;\n  padding-left: 5px;\n  padding-right: 5px;\n}\ndl {\n  margin-top: 0;\n  margin-bottom: 20px;\n}\ndt,\ndd {\n  line-height: 1.42857143;\n}\ndt {\n  font-weight: bold;\n}\ndd {\n  margin-left: 0;\n}\n@media (min-width: 768px) {\n  .dl-horizontal dt {\n    float: left;\n    width: 160px;\n    clear: left;\n    text-align: right;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n  }\n  .dl-horizontal dd {\n    margin-left: 180px;\n  }\n}\nabbr[title],\nabbr[data-original-title] {\n  cursor: help;\n  border-bottom: 1px dotted #777777;\n}\n.initialism {\n  font-size: 90%;\n  text-transform: uppercase;\n}\nblockquote {\n  padding: 10px 20px;\n  margin: 0 0 20px;\n  font-size: 17.5px;\n  border-left: 5px solid #eeeeee;\n}\nblockquote p:last-child,\nblockquote ul:last-child,\nblockquote ol:last-child {\n  margin-bottom: 0;\n}\nblockquote footer,\nblockquote small,\nblockquote .small {\n  display: block;\n  font-size: 80%;\n  line-height: 1.42857143;\n  color: #777777;\n}\nblockquote footer:before,\nblockquote small:before,\nblockquote .small:before {\n  content: '\\2014 \\00A0';\n}\n.blockquote-reverse,\nblockquote.pull-right {\n  padding-right: 15px;\n  padding-left: 0;\n  border-right: 5px solid #eeeeee;\n  border-left: 0;\n  text-align: right;\n}\n.blockquote-reverse footer:before,\nblockquote.pull-right footer:before,\n.blockquote-reverse small:before,\nblockquote.pull-right small:before,\n.blockquote-reverse .small:before,\nblockquote.pull-right .small:before {\n  content: '';\n}\n.blockquote-reverse footer:after,\nblockquote.pull-right footer:after,\n.blockquote-reverse small:after,\nblockquote.pull-right small:after,\n.blockquote-reverse .small:after,\nblockquote.pull-right .small:after {\n  content: '\\00A0 \\2014';\n}\naddress {\n  margin-bottom: 20px;\n  font-style: normal;\n  line-height: 1.42857143;\n}\ncode,\nkbd,\npre,\nsamp {\n  font-family: Menlo, Monaco, Consolas, \"Courier New\", monospace;\n}\ncode {\n  padding: 2px 4px;\n  font-size: 90%;\n  color: #c7254e;\n  background-color: #f9f2f4;\n  border-radius: 4px;\n}\nkbd {\n  padding: 2px 4px;\n  font-size: 90%;\n  color: #fff;\n  background-color: #333;\n  border-radius: 3px;\n  box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.25);\n}\nkbd kbd {\n  padding: 0;\n  font-size: 100%;\n  font-weight: bold;\n  box-shadow: none;\n}\npre {\n  display: block;\n  padding: 9.5px;\n  margin: 0 0 10px;\n  font-size: 13px;\n  line-height: 1.42857143;\n  word-break: break-all;\n  word-wrap: break-word;\n  color: #333333;\n  background-color: #f5f5f5;\n  border: 1px solid #ccc;\n  border-radius: 4px;\n}\npre code {\n  padding: 0;\n  font-size: inherit;\n  color: inherit;\n  white-space: pre-wrap;\n  background-color: transparent;\n  border-radius: 0;\n}\n.pre-scrollable {\n  max-height: 340px;\n  overflow-y: scroll;\n}\n.container {\n  margin-right: auto;\n  margin-left: auto;\n  padding-left: 15px;\n  padding-right: 15px;\n}\n@media (min-width: 768px) {\n  .container {\n    width: 750px;\n  }\n}\n@media (min-width: 992px) {\n  .container {\n    width: 970px;\n  }\n}\n@media (min-width: 1200px) {\n  .container {\n    width: 1170px;\n  }\n}\n.container-fluid {\n  margin-right: auto;\n  margin-left: auto;\n  padding-left: 15px;\n  padding-right: 15px;\n}\n.row {\n  margin-left: -15px;\n  margin-right: -15px;\n}\n.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.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.col-xs-12 {\n  width: 100%;\n}\n.col-xs-11 {\n  width: 91.66666667%;\n}\n.col-xs-10 {\n  width: 83.33333333%;\n}\n.col-xs-9 {\n  width: 75%;\n}\n.col-xs-8 {\n  width: 66.66666667%;\n}\n.col-xs-7 {\n  width: 58.33333333%;\n}\n.col-xs-6 {\n  width: 50%;\n}\n.col-xs-5 {\n  width: 41.66666667%;\n}\n.col-xs-4 {\n  width: 33.33333333%;\n}\n.col-xs-3 {\n  width: 25%;\n}\n.col-xs-2 {\n  width: 16.66666667%;\n}\n.col-xs-1 {\n  width: 8.33333333%;\n}\n.col-xs-pull-12 {\n  right: 100%;\n}\n.col-xs-pull-11 {\n  right: 91.66666667%;\n}\n.col-xs-pull-10 {\n  right: 83.33333333%;\n}\n.col-xs-pull-9 {\n  right: 75%;\n}\n.col-xs-pull-8 {\n  right: 66.66666667%;\n}\n.col-xs-pull-7 {\n  right: 58.33333333%;\n}\n.col-xs-pull-6 {\n  right: 50%;\n}\n.col-xs-pull-5 {\n  right: 41.66666667%;\n}\n.col-xs-pull-4 {\n  right: 33.33333333%;\n}\n.col-xs-pull-3 {\n  right: 25%;\n}\n.col-xs-pull-2 {\n  right: 16.66666667%;\n}\n.col-xs-pull-1 {\n  right: 8.33333333%;\n}\n.col-xs-pull-0 {\n  right: auto;\n}\n.col-xs-push-12 {\n  left: 100%;\n}\n.col-xs-push-11 {\n  left: 91.66666667%;\n}\n.col-xs-push-10 {\n  left: 83.33333333%;\n}\n.col-xs-push-9 {\n  left: 75%;\n}\n.col-xs-push-8 {\n  left: 66.66666667%;\n}\n.col-xs-push-7 {\n  left: 58.33333333%;\n}\n.col-xs-push-6 {\n  left: 50%;\n}\n.col-xs-push-5 {\n  left: 41.66666667%;\n}\n.col-xs-push-4 {\n  left: 33.33333333%;\n}\n.col-xs-push-3 {\n  left: 25%;\n}\n.col-xs-push-2 {\n  left: 16.66666667%;\n}\n.col-xs-push-1 {\n  left: 8.33333333%;\n}\n.col-xs-push-0 {\n  left: auto;\n}\n.col-xs-offset-12 {\n  margin-left: 100%;\n}\n.col-xs-offset-11 {\n  margin-left: 91.66666667%;\n}\n.col-xs-offset-10 {\n  margin-left: 83.33333333%;\n}\n.col-xs-offset-9 {\n  margin-left: 75%;\n}\n.col-xs-offset-8 {\n  margin-left: 66.66666667%;\n}\n.col-xs-offset-7 {\n  margin-left: 58.33333333%;\n}\n.col-xs-offset-6 {\n  margin-left: 50%;\n}\n.col-xs-offset-5 {\n  margin-left: 41.66666667%;\n}\n.col-xs-offset-4 {\n  margin-left: 33.33333333%;\n}\n.col-xs-offset-3 {\n  margin-left: 25%;\n}\n.col-xs-offset-2 {\n  margin-left: 16.66666667%;\n}\n.col-xs-offset-1 {\n  margin-left: 8.33333333%;\n}\n.col-xs-offset-0 {\n  margin-left: 0%;\n}\n@media (min-width: 768px) {\n  .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  .col-sm-12 {\n    width: 100%;\n  }\n  .col-sm-11 {\n    width: 91.66666667%;\n  }\n  .col-sm-10 {\n    width: 83.33333333%;\n  }\n  .col-sm-9 {\n    width: 75%;\n  }\n  .col-sm-8 {\n    width: 66.66666667%;\n  }\n  .col-sm-7 {\n    width: 58.33333333%;\n  }\n  .col-sm-6 {\n    width: 50%;\n  }\n  .col-sm-5 {\n    width: 41.66666667%;\n  }\n  .col-sm-4 {\n    width: 33.33333333%;\n  }\n  .col-sm-3 {\n    width: 25%;\n  }\n  .col-sm-2 {\n    width: 16.66666667%;\n  }\n  .col-sm-1 {\n    width: 8.33333333%;\n  }\n  .col-sm-pull-12 {\n    right: 100%;\n  }\n  .col-sm-pull-11 {\n    right: 91.66666667%;\n  }\n  .col-sm-pull-10 {\n    right: 83.33333333%;\n  }\n  .col-sm-pull-9 {\n    right: 75%;\n  }\n  .col-sm-pull-8 {\n    right: 66.66666667%;\n  }\n  .col-sm-pull-7 {\n    right: 58.33333333%;\n  }\n  .col-sm-pull-6 {\n    right: 50%;\n  }\n  .col-sm-pull-5 {\n    right: 41.66666667%;\n  }\n  .col-sm-pull-4 {\n    right: 33.33333333%;\n  }\n  .col-sm-pull-3 {\n    right: 25%;\n  }\n  .col-sm-pull-2 {\n    right: 16.66666667%;\n  }\n  .col-sm-pull-1 {\n    right: 8.33333333%;\n  }\n  .col-sm-pull-0 {\n    right: auto;\n  }\n  .col-sm-push-12 {\n    left: 100%;\n  }\n  .col-sm-push-11 {\n    left: 91.66666667%;\n  }\n  .col-sm-push-10 {\n    left: 83.33333333%;\n  }\n  .col-sm-push-9 {\n    left: 75%;\n  }\n  .col-sm-push-8 {\n    left: 66.66666667%;\n  }\n  .col-sm-push-7 {\n    left: 58.33333333%;\n  }\n  .col-sm-push-6 {\n    left: 50%;\n  }\n  .col-sm-push-5 {\n    left: 41.66666667%;\n  }\n  .col-sm-push-4 {\n    left: 33.33333333%;\n  }\n  .col-sm-push-3 {\n    left: 25%;\n  }\n  .col-sm-push-2 {\n    left: 16.66666667%;\n  }\n  .col-sm-push-1 {\n    left: 8.33333333%;\n  }\n  .col-sm-push-0 {\n    left: auto;\n  }\n  .col-sm-offset-12 {\n    margin-left: 100%;\n  }\n  .col-sm-offset-11 {\n    margin-left: 91.66666667%;\n  }\n  .col-sm-offset-10 {\n    margin-left: 83.33333333%;\n  }\n  .col-sm-offset-9 {\n    margin-left: 75%;\n  }\n  .col-sm-offset-8 {\n    margin-left: 66.66666667%;\n  }\n  .col-sm-offset-7 {\n    margin-left: 58.33333333%;\n  }\n  .col-sm-offset-6 {\n    margin-left: 50%;\n  }\n  .col-sm-offset-5 {\n    margin-left: 41.66666667%;\n  }\n  .col-sm-offset-4 {\n    margin-left: 33.33333333%;\n  }\n  .col-sm-offset-3 {\n    margin-left: 25%;\n  }\n  .col-sm-offset-2 {\n    margin-left: 16.66666667%;\n  }\n  .col-sm-offset-1 {\n    margin-left: 8.33333333%;\n  }\n  .col-sm-offset-0 {\n    margin-left: 0%;\n  }\n}\n@media (min-width: 992px) {\n  .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  .col-md-12 {\n    width: 100%;\n  }\n  .col-md-11 {\n    width: 91.66666667%;\n  }\n  .col-md-10 {\n    width: 83.33333333%;\n  }\n  .col-md-9 {\n    width: 75%;\n  }\n  .col-md-8 {\n    width: 66.66666667%;\n  }\n  .col-md-7 {\n    width: 58.33333333%;\n  }\n  .col-md-6 {\n    width: 50%;\n  }\n  .col-md-5 {\n    width: 41.66666667%;\n  }\n  .col-md-4 {\n    width: 33.33333333%;\n  }\n  .col-md-3 {\n    width: 25%;\n  }\n  .col-md-2 {\n    width: 16.66666667%;\n  }\n  .col-md-1 {\n    width: 8.33333333%;\n  }\n  .col-md-pull-12 {\n    right: 100%;\n  }\n  .col-md-pull-11 {\n    right: 91.66666667%;\n  }\n  .col-md-pull-10 {\n    right: 83.33333333%;\n  }\n  .col-md-pull-9 {\n    right: 75%;\n  }\n  .col-md-pull-8 {\n    right: 66.66666667%;\n  }\n  .col-md-pull-7 {\n    right: 58.33333333%;\n  }\n  .col-md-pull-6 {\n    right: 50%;\n  }\n  .col-md-pull-5 {\n    right: 41.66666667%;\n  }\n  .col-md-pull-4 {\n    right: 33.33333333%;\n  }\n  .col-md-pull-3 {\n    right: 25%;\n  }\n  .col-md-pull-2 {\n    right: 16.66666667%;\n  }\n  .col-md-pull-1 {\n    right: 8.33333333%;\n  }\n  .col-md-pull-0 {\n    right: auto;\n  }\n  .col-md-push-12 {\n    left: 100%;\n  }\n  .col-md-push-11 {\n    left: 91.66666667%;\n  }\n  .col-md-push-10 {\n    left: 83.33333333%;\n  }\n  .col-md-push-9 {\n    left: 75%;\n  }\n  .col-md-push-8 {\n    left: 66.66666667%;\n  }\n  .col-md-push-7 {\n    left: 58.33333333%;\n  }\n  .col-md-push-6 {\n    left: 50%;\n  }\n  .col-md-push-5 {\n    left: 41.66666667%;\n  }\n  .col-md-push-4 {\n    left: 33.33333333%;\n  }\n  .col-md-push-3 {\n    left: 25%;\n  }\n  .col-md-push-2 {\n    left: 16.66666667%;\n  }\n  .col-md-push-1 {\n    left: 8.33333333%;\n  }\n  .col-md-push-0 {\n    left: auto;\n  }\n  .col-md-offset-12 {\n    margin-left: 100%;\n  }\n  .col-md-offset-11 {\n    margin-left: 91.66666667%;\n  }\n  .col-md-offset-10 {\n    margin-left: 83.33333333%;\n  }\n  .col-md-offset-9 {\n    margin-left: 75%;\n  }\n  .col-md-offset-8 {\n    margin-left: 66.66666667%;\n  }\n  .col-md-offset-7 {\n    margin-left: 58.33333333%;\n  }\n  .col-md-offset-6 {\n    margin-left: 50%;\n  }\n  .col-md-offset-5 {\n    margin-left: 41.66666667%;\n  }\n  .col-md-offset-4 {\n    margin-left: 33.33333333%;\n  }\n  .col-md-offset-3 {\n    margin-left: 25%;\n  }\n  .col-md-offset-2 {\n    margin-left: 16.66666667%;\n  }\n  .col-md-offset-1 {\n    margin-left: 8.33333333%;\n  }\n  .col-md-offset-0 {\n    margin-left: 0%;\n  }\n}\n@media (min-width: 1200px) {\n  .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  .col-lg-12 {\n    width: 100%;\n  }\n  .col-lg-11 {\n    width: 91.66666667%;\n  }\n  .col-lg-10 {\n    width: 83.33333333%;\n  }\n  .col-lg-9 {\n    width: 75%;\n  }\n  .col-lg-8 {\n    width: 66.66666667%;\n  }\n  .col-lg-7 {\n    width: 58.33333333%;\n  }\n  .col-lg-6 {\n    width: 50%;\n  }\n  .col-lg-5 {\n    width: 41.66666667%;\n  }\n  .col-lg-4 {\n    width: 33.33333333%;\n  }\n  .col-lg-3 {\n    width: 25%;\n  }\n  .col-lg-2 {\n    width: 16.66666667%;\n  }\n  .col-lg-1 {\n    width: 8.33333333%;\n  }\n  .col-lg-pull-12 {\n    right: 100%;\n  }\n  .col-lg-pull-11 {\n    right: 91.66666667%;\n  }\n  .col-lg-pull-10 {\n    right: 83.33333333%;\n  }\n  .col-lg-pull-9 {\n    right: 75%;\n  }\n  .col-lg-pull-8 {\n    right: 66.66666667%;\n  }\n  .col-lg-pull-7 {\n    right: 58.33333333%;\n  }\n  .col-lg-pull-6 {\n    right: 50%;\n  }\n  .col-lg-pull-5 {\n    right: 41.66666667%;\n  }\n  .col-lg-pull-4 {\n    right: 33.33333333%;\n  }\n  .col-lg-pull-3 {\n    right: 25%;\n  }\n  .col-lg-pull-2 {\n    right: 16.66666667%;\n  }\n  .col-lg-pull-1 {\n    right: 8.33333333%;\n  }\n  .col-lg-pull-0 {\n    right: auto;\n  }\n  .col-lg-push-12 {\n    left: 100%;\n  }\n  .col-lg-push-11 {\n    left: 91.66666667%;\n  }\n  .col-lg-push-10 {\n    left: 83.33333333%;\n  }\n  .col-lg-push-9 {\n    left: 75%;\n  }\n  .col-lg-push-8 {\n    left: 66.66666667%;\n  }\n  .col-lg-push-7 {\n    left: 58.33333333%;\n  }\n  .col-lg-push-6 {\n    left: 50%;\n  }\n  .col-lg-push-5 {\n    left: 41.66666667%;\n  }\n  .col-lg-push-4 {\n    left: 33.33333333%;\n  }\n  .col-lg-push-3 {\n    left: 25%;\n  }\n  .col-lg-push-2 {\n    left: 16.66666667%;\n  }\n  .col-lg-push-1 {\n    left: 8.33333333%;\n  }\n  .col-lg-push-0 {\n    left: auto;\n  }\n  .col-lg-offset-12 {\n    margin-left: 100%;\n  }\n  .col-lg-offset-11 {\n    margin-left: 91.66666667%;\n  }\n  .col-lg-offset-10 {\n    margin-left: 83.33333333%;\n  }\n  .col-lg-offset-9 {\n    margin-left: 75%;\n  }\n  .col-lg-offset-8 {\n    margin-left: 66.66666667%;\n  }\n  .col-lg-offset-7 {\n    margin-left: 58.33333333%;\n  }\n  .col-lg-offset-6 {\n    margin-left: 50%;\n  }\n  .col-lg-offset-5 {\n    margin-left: 41.66666667%;\n  }\n  .col-lg-offset-4 {\n    margin-left: 33.33333333%;\n  }\n  .col-lg-offset-3 {\n    margin-left: 25%;\n  }\n  .col-lg-offset-2 {\n    margin-left: 16.66666667%;\n  }\n  .col-lg-offset-1 {\n    margin-left: 8.33333333%;\n  }\n  .col-lg-offset-0 {\n    margin-left: 0%;\n  }\n}\ntable {\n  background-color: transparent;\n}\ncaption {\n  padding-top: 8px;\n  padding-bottom: 8px;\n  color: #777777;\n  text-align: left;\n}\nth {\n  text-align: left;\n}\n.table {\n  width: 100%;\n  max-width: 100%;\n  margin-bottom: 20px;\n}\n.table > thead > tr > th,\n.table > tbody > tr > th,\n.table > tfoot > tr > th,\n.table > thead > tr > td,\n.table > tbody > tr > td,\n.table > tfoot > tr > td {\n  padding: 8px;\n  line-height: 1.42857143;\n  vertical-align: top;\n  border-top: 1px solid #ddd;\n}\n.table > thead > tr > th {\n  vertical-align: bottom;\n  border-bottom: 2px solid #ddd;\n}\n.table > caption + thead > tr:first-child > th,\n.table > colgroup + thead > tr:first-child > th,\n.table > thead:first-child > tr:first-child > th,\n.table > caption + thead > tr:first-child > td,\n.table > colgroup + thead > tr:first-child > td,\n.table > thead:first-child > tr:first-child > td {\n  border-top: 0;\n}\n.table > tbody + tbody {\n  border-top: 2px solid #ddd;\n}\n.table .table {\n  background-color: #fff;\n}\n.table-condensed > thead > tr > th,\n.table-condensed > tbody > tr > th,\n.table-condensed > tfoot > tr > th,\n.table-condensed > thead > tr > td,\n.table-condensed > tbody > tr > td,\n.table-condensed > tfoot > tr > td {\n  padding: 5px;\n}\n.table-bordered {\n  border: 1px solid #ddd;\n}\n.table-bordered > thead > tr > th,\n.table-bordered > tbody > tr > th,\n.table-bordered > tfoot > tr > th,\n.table-bordered > thead > tr > td,\n.table-bordered > tbody > tr > td,\n.table-bordered > tfoot > tr > td {\n  border: 1px solid #ddd;\n}\n.table-bordered > thead > tr > th,\n.table-bordered > thead > tr > td {\n  border-bottom-width: 2px;\n}\n.table-striped > tbody > tr:nth-of-type(odd) {\n  background-color: #f9f9f9;\n}\n.table-hover > tbody > tr:hover {\n  background-color: #f5f5f5;\n}\ntable col[class*=\"col-\"] {\n  position: static;\n  float: none;\n  display: table-column;\n}\ntable td[class*=\"col-\"],\ntable th[class*=\"col-\"] {\n  position: static;\n  float: none;\n  display: table-cell;\n}\n.table > thead > tr > td.active,\n.table > tbody > tr > td.active,\n.table > tfoot > tr > td.active,\n.table > thead > tr > th.active,\n.table > tbody > tr > th.active,\n.table > tfoot > tr > th.active,\n.table > thead > tr.active > td,\n.table > tbody > tr.active > td,\n.table > tfoot > tr.active > td,\n.table > thead > tr.active > th,\n.table > tbody > tr.active > th,\n.table > tfoot > tr.active > th {\n  background-color: #f5f5f5;\n}\n.table-hover > tbody > tr > td.active:hover,\n.table-hover > tbody > tr > th.active:hover,\n.table-hover > tbody > tr.active:hover > td,\n.table-hover > tbody > tr:hover > .active,\n.table-hover > tbody > tr.active:hover > th {\n  background-color: #e8e8e8;\n}\n.table > thead > tr > td.success,\n.table > tbody > tr > td.success,\n.table > tfoot > tr > td.success,\n.table > thead > tr > th.success,\n.table > tbody > tr > th.success,\n.table > tfoot > tr > th.success,\n.table > thead > tr.success > td,\n.table > tbody > tr.success > td,\n.table > tfoot > tr.success > td,\n.table > thead > tr.success > th,\n.table > tbody > tr.success > th,\n.table > tfoot > tr.success > th {\n  background-color: #dff0d8;\n}\n.table-hover > tbody > tr > td.success:hover,\n.table-hover > tbody > tr > th.success:hover,\n.table-hover > tbody > tr.success:hover > td,\n.table-hover > tbody > tr:hover > .success,\n.table-hover > tbody > tr.success:hover > th {\n  background-color: #d0e9c6;\n}\n.table > thead > tr > td.info,\n.table > tbody > tr > td.info,\n.table > tfoot > tr > td.info,\n.table > thead > tr > th.info,\n.table > tbody > tr > th.info,\n.table > tfoot > tr > th.info,\n.table > thead > tr.info > td,\n.table > tbody > tr.info > td,\n.table > tfoot > tr.info > td,\n.table > thead > tr.info > th,\n.table > tbody > tr.info > th,\n.table > tfoot > tr.info > th {\n  background-color: #d9edf7;\n}\n.table-hover > tbody > tr > td.info:hover,\n.table-hover > tbody > tr > th.info:hover,\n.table-hover > tbody > tr.info:hover > td,\n.table-hover > tbody > tr:hover > .info,\n.table-hover > tbody > tr.info:hover > th {\n  background-color: #c4e3f3;\n}\n.table > thead > tr > td.warning,\n.table > tbody > tr > td.warning,\n.table > tfoot > tr > td.warning,\n.table > thead > tr > th.warning,\n.table > tbody > tr > th.warning,\n.table > tfoot > tr > th.warning,\n.table > thead > tr.warning > td,\n.table > tbody > tr.warning > td,\n.table > tfoot > tr.warning > td,\n.table > thead > tr.warning > th,\n.table > tbody > tr.warning > th,\n.table > tfoot > tr.warning > th {\n  background-color: #fcf8e3;\n}\n.table-hover > tbody > tr > td.warning:hover,\n.table-hover > tbody > tr > th.warning:hover,\n.table-hover > tbody > tr.warning:hover > td,\n.table-hover > tbody > tr:hover > .warning,\n.table-hover > tbody > tr.warning:hover > th {\n  background-color: #faf2cc;\n}\n.table > thead > tr > td.danger,\n.table > tbody > tr > td.danger,\n.table > tfoot > tr > td.danger,\n.table > thead > tr > th.danger,\n.table > tbody > tr > th.danger,\n.table > tfoot > tr > th.danger,\n.table > thead > tr.danger > td,\n.table > tbody > tr.danger > td,\n.table > tfoot > tr.danger > td,\n.table > thead > tr.danger > th,\n.table > tbody > tr.danger > th,\n.table > tfoot > tr.danger > th {\n  background-color: #f2dede;\n}\n.table-hover > tbody > tr > td.danger:hover,\n.table-hover > tbody > tr > th.danger:hover,\n.table-hover > tbody > tr.danger:hover > td,\n.table-hover > tbody > tr:hover > .danger,\n.table-hover > tbody > tr.danger:hover > th {\n  background-color: #ebcccc;\n}\n.table-responsive {\n  overflow-x: auto;\n  min-height: 0.01%;\n}\n@media screen and (max-width: 767px) {\n  .table-responsive {\n    width: 100%;\n    margin-bottom: 15px;\n    overflow-y: hidden;\n    -ms-overflow-style: -ms-autohiding-scrollbar;\n    border: 1px solid #ddd;\n  }\n  .table-responsive > .table {\n    margin-bottom: 0;\n  }\n  .table-responsive > .table > thead > tr > th,\n  .table-responsive > .table > tbody > tr > th,\n  .table-responsive > .table > tfoot > tr > th,\n  .table-responsive > .table > thead > tr > td,\n  .table-responsive > .table > tbody > tr > td,\n  .table-responsive > .table > tfoot > tr > td {\n    white-space: nowrap;\n  }\n  .table-responsive > .table-bordered {\n    border: 0;\n  }\n  .table-responsive > .table-bordered > thead > tr > th:first-child,\n  .table-responsive > .table-bordered > tbody > tr > th:first-child,\n  .table-responsive > .table-bordered > tfoot > tr > th:first-child,\n  .table-responsive > .table-bordered > thead > tr > td:first-child,\n  .table-responsive > .table-bordered > tbody > tr > td:first-child,\n  .table-responsive > .table-bordered > tfoot > tr > td:first-child {\n    border-left: 0;\n  }\n  .table-responsive > .table-bordered > thead > tr > th:last-child,\n  .table-responsive > .table-bordered > tbody > tr > th:last-child,\n  .table-responsive > .table-bordered > tfoot > tr > th:last-child,\n  .table-responsive > .table-bordered > thead > tr > td:last-child,\n  .table-responsive > .table-bordered > tbody > tr > td:last-child,\n  .table-responsive > .table-bordered > tfoot > tr > td:last-child {\n    border-right: 0;\n  }\n  .table-responsive > .table-bordered > tbody > tr:last-child > th,\n  .table-responsive > .table-bordered > tfoot > tr:last-child > th,\n  .table-responsive > .table-bordered > tbody > tr:last-child > td,\n  .table-responsive > .table-bordered > tfoot > tr:last-child > td {\n    border-bottom: 0;\n  }\n}\nfieldset {\n  padding: 0;\n  margin: 0;\n  border: 0;\n  min-width: 0;\n}\nlegend {\n  display: block;\n  width: 100%;\n  padding: 0;\n  margin-bottom: 20px;\n  font-size: 21px;\n  line-height: inherit;\n  color: #333333;\n  border: 0;\n  border-bottom: 1px solid #e5e5e5;\n}\nlabel {\n  display: inline-block;\n  max-width: 100%;\n  margin-bottom: 5px;\n  font-weight: bold;\n}\ninput[type=\"search\"] {\n  -webkit-box-sizing: border-box;\n  -moz-box-sizing: border-box;\n  box-sizing: border-box;\n}\ninput[type=\"radio\"],\ninput[type=\"checkbox\"] {\n  margin: 4px 0 0;\n  margin-top: 1px \\9;\n  line-height: normal;\n}\ninput[type=\"file\"] {\n  display: block;\n}\ninput[type=\"range\"] {\n  display: block;\n  width: 100%;\n}\nselect[multiple],\nselect[size] {\n  height: auto;\n}\ninput[type=\"file\"]:focus,\ninput[type=\"radio\"]:focus,\ninput[type=\"checkbox\"]:focus {\n  outline: 5px auto -webkit-focus-ring-color;\n  outline-offset: -2px;\n}\noutput {\n  display: block;\n  padding-top: 7px;\n  font-size: 14px;\n  line-height: 1.42857143;\n  color: #555555;\n}\n.form-control {\n  display: block;\n  width: 100%;\n  height: 34px;\n  padding: 6px 12px;\n  font-size: 14px;\n  line-height: 1.42857143;\n  color: #555555;\n  background-color: #fff;\n  background-image: none;\n  border: 1px solid #ccc;\n  border-radius: 4px;\n  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);\n  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);\n  -webkit-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;\n  -o-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;\n  transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;\n}\n.form-control:focus {\n  border-color: #66afe9;\n  outline: 0;\n  -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102, 175, 233, 0.6);\n  box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102, 175, 233, 0.6);\n}\n.form-control::-moz-placeholder {\n  color: #999;\n  opacity: 1;\n}\n.form-control:-ms-input-placeholder {\n  color: #999;\n}\n.form-control::-webkit-input-placeholder {\n  color: #999;\n}\n.form-control::-ms-expand {\n  border: 0;\n  background-color: transparent;\n}\n.form-control[disabled],\n.form-control[readonly],\nfieldset[disabled] .form-control {\n  background-color: #eeeeee;\n  opacity: 1;\n}\n.form-control[disabled],\nfieldset[disabled] .form-control {\n  cursor: not-allowed;\n}\ntextarea.form-control {\n  height: auto;\n}\ninput[type=\"search\"] {\n  -webkit-appearance: none;\n}\n@media screen and (-webkit-min-device-pixel-ratio: 0) {\n  input[type=\"date\"].form-control,\n  input[type=\"time\"].form-control,\n  input[type=\"datetime-local\"].form-control,\n  input[type=\"month\"].form-control {\n    line-height: 34px;\n  }\n  input[type=\"date\"].input-sm,\n  input[type=\"time\"].input-sm,\n  input[type=\"datetime-local\"].input-sm,\n  input[type=\"month\"].input-sm,\n  .input-group-sm input[type=\"date\"],\n  .input-group-sm input[type=\"time\"],\n  .input-group-sm input[type=\"datetime-local\"],\n  .input-group-sm input[type=\"month\"] {\n    line-height: 30px;\n  }\n  input[type=\"date\"].input-lg,\n  input[type=\"time\"].input-lg,\n  input[type=\"datetime-local\"].input-lg,\n  input[type=\"month\"].input-lg,\n  .input-group-lg input[type=\"date\"],\n  .input-group-lg input[type=\"time\"],\n  .input-group-lg input[type=\"datetime-local\"],\n  .input-group-lg input[type=\"month\"] {\n    line-height: 46px;\n  }\n}\n.form-group {\n  margin-bottom: 15px;\n}\n.radio,\n.checkbox {\n  position: relative;\n  display: block;\n  margin-top: 10px;\n  margin-bottom: 10px;\n}\n.radio label,\n.checkbox label {\n  min-height: 20px;\n  padding-left: 20px;\n  margin-bottom: 0;\n  font-weight: normal;\n  cursor: pointer;\n}\n.radio input[type=\"radio\"],\n.radio-inline input[type=\"radio\"],\n.checkbox input[type=\"checkbox\"],\n.checkbox-inline input[type=\"checkbox\"] {\n  position: absolute;\n  margin-left: -20px;\n  margin-top: 4px \\9;\n}\n.radio + .radio,\n.checkbox + .checkbox {\n  margin-top: -5px;\n}\n.radio-inline,\n.checkbox-inline {\n  position: relative;\n  display: inline-block;\n  padding-left: 20px;\n  margin-bottom: 0;\n  vertical-align: middle;\n  font-weight: normal;\n  cursor: pointer;\n}\n.radio-inline + .radio-inline,\n.checkbox-inline + .checkbox-inline {\n  margin-top: 0;\n  margin-left: 10px;\n}\ninput[type=\"radio\"][disabled],\ninput[type=\"checkbox\"][disabled],\ninput[type=\"radio\"].disabled,\ninput[type=\"checkbox\"].disabled,\nfieldset[disabled] input[type=\"radio\"],\nfieldset[disabled] input[type=\"checkbox\"] {\n  cursor: not-allowed;\n}\n.radio-inline.disabled,\n.checkbox-inline.disabled,\nfieldset[disabled] .radio-inline,\nfieldset[disabled] .checkbox-inline {\n  cursor: not-allowed;\n}\n.radio.disabled label,\n.checkbox.disabled label,\nfieldset[disabled] .radio label,\nfieldset[disabled] .checkbox label {\n  cursor: not-allowed;\n}\n.form-control-static {\n  padding-top: 7px;\n  padding-bottom: 7px;\n  margin-bottom: 0;\n  min-height: 34px;\n}\n.form-control-static.input-lg,\n.form-control-static.input-sm {\n  padding-left: 0;\n  padding-right: 0;\n}\n.input-sm {\n  height: 30px;\n  padding: 5px 10px;\n  font-size: 12px;\n  line-height: 1.5;\n  border-radius: 3px;\n}\nselect.input-sm {\n  height: 30px;\n  line-height: 30px;\n}\ntextarea.input-sm,\nselect[multiple].input-sm {\n  height: auto;\n}\n.form-group-sm .form-control {\n  height: 30px;\n  padding: 5px 10px;\n  font-size: 12px;\n  line-height: 1.5;\n  border-radius: 3px;\n}\n.form-group-sm select.form-control {\n  height: 30px;\n  line-height: 30px;\n}\n.form-group-sm textarea.form-control,\n.form-group-sm select[multiple].form-control {\n  height: auto;\n}\n.form-group-sm .form-control-static {\n  height: 30px;\n  min-height: 32px;\n  padding: 6px 10px;\n  font-size: 12px;\n  line-height: 1.5;\n}\n.input-lg {\n  height: 46px;\n  padding: 10px 16px;\n  font-size: 18px;\n  line-height: 1.3333333;\n  border-radius: 6px;\n}\nselect.input-lg {\n  height: 46px;\n  line-height: 46px;\n}\ntextarea.input-lg,\nselect[multiple].input-lg {\n  height: auto;\n}\n.form-group-lg .form-control {\n  height: 46px;\n  padding: 10px 16px;\n  font-size: 18px;\n  line-height: 1.3333333;\n  border-radius: 6px;\n}\n.form-group-lg select.form-control {\n  height: 46px;\n  line-height: 46px;\n}\n.form-group-lg textarea.form-control,\n.form-group-lg select[multiple].form-control {\n  height: auto;\n}\n.form-group-lg .form-control-static {\n  height: 46px;\n  min-height: 38px;\n  padding: 11px 16px;\n  font-size: 18px;\n  line-height: 1.3333333;\n}\n.has-feedback {\n  position: relative;\n}\n.has-feedback .form-control {\n  padding-right: 42.5px;\n}\n.form-control-feedback {\n  position: absolute;\n  top: 0;\n  right: 0;\n  z-index: 2;\n  display: block;\n  width: 34px;\n  height: 34px;\n  line-height: 34px;\n  text-align: center;\n  pointer-events: none;\n}\n.input-lg + .form-control-feedback,\n.input-group-lg + .form-control-feedback,\n.form-group-lg .form-control + .form-control-feedback {\n  width: 46px;\n  height: 46px;\n  line-height: 46px;\n}\n.input-sm + .form-control-feedback,\n.input-group-sm + .form-control-feedback,\n.form-group-sm .form-control + .form-control-feedback {\n  width: 30px;\n  height: 30px;\n  line-height: 30px;\n}\n.has-success .help-block,\n.has-success .control-label,\n.has-success .radio,\n.has-success .checkbox,\n.has-success .radio-inline,\n.has-success .checkbox-inline,\n.has-success.radio label,\n.has-success.checkbox label,\n.has-success.radio-inline label,\n.has-success.checkbox-inline label {\n  color: #3c763d;\n}\n.has-success .form-control {\n  border-color: #3c763d;\n  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);\n  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);\n}\n.has-success .form-control:focus {\n  border-color: #2b542c;\n  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #67b168;\n  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #67b168;\n}\n.has-success .input-group-addon {\n  color: #3c763d;\n  border-color: #3c763d;\n  background-color: #dff0d8;\n}\n.has-success .form-control-feedback {\n  color: #3c763d;\n}\n.has-warning .help-block,\n.has-warning .control-label,\n.has-warning .radio,\n.has-warning .checkbox,\n.has-warning .radio-inline,\n.has-warning .checkbox-inline,\n.has-warning.radio label,\n.has-warning.checkbox label,\n.has-warning.radio-inline label,\n.has-warning.checkbox-inline label {\n  color: #8a6d3b;\n}\n.has-warning .form-control {\n  border-color: #8a6d3b;\n  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);\n  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);\n}\n.has-warning .form-control:focus {\n  border-color: #66512c;\n  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #c0a16b;\n  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #c0a16b;\n}\n.has-warning .input-group-addon {\n  color: #8a6d3b;\n  border-color: #8a6d3b;\n  background-color: #fcf8e3;\n}\n.has-warning .form-control-feedback {\n  color: #8a6d3b;\n}\n.has-error .help-block,\n.has-error .control-label,\n.has-error .radio,\n.has-error .checkbox,\n.has-error .radio-inline,\n.has-error .checkbox-inline,\n.has-error.radio label,\n.has-error.checkbox label,\n.has-error.radio-inline label,\n.has-error.checkbox-inline label {\n  color: #a94442;\n}\n.has-error .form-control {\n  border-color: #a94442;\n  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);\n  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);\n}\n.has-error .form-control:focus {\n  border-color: #843534;\n  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #ce8483;\n  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px #ce8483;\n}\n.has-error .input-group-addon {\n  color: #a94442;\n  border-color: #a94442;\n  background-color: #f2dede;\n}\n.has-error .form-control-feedback {\n  color: #a94442;\n}\n.has-feedback label ~ .form-control-feedback {\n  top: 25px;\n}\n.has-feedback label.sr-only ~ .form-control-feedback {\n  top: 0;\n}\n.help-block {\n  display: block;\n  margin-top: 5px;\n  margin-bottom: 10px;\n  color: #737373;\n}\n@media (min-width: 768px) {\n  .form-inline .form-group {\n    display: inline-block;\n    margin-bottom: 0;\n    vertical-align: middle;\n  }\n  .form-inline .form-control {\n    display: inline-block;\n    width: auto;\n    vertical-align: middle;\n  }\n  .form-inline .form-control-static {\n    display: inline-block;\n  }\n  .form-inline .input-group {\n    display: inline-table;\n    vertical-align: middle;\n  }\n  .form-inline .input-group .input-group-addon,\n  .form-inline .input-group .input-group-btn,\n  .form-inline .input-group .form-control {\n    width: auto;\n  }\n  .form-inline .input-group > .form-control {\n    width: 100%;\n  }\n  .form-inline .control-label {\n    margin-bottom: 0;\n    vertical-align: middle;\n  }\n  .form-inline .radio,\n  .form-inline .checkbox {\n    display: inline-block;\n    margin-top: 0;\n    margin-bottom: 0;\n    vertical-align: middle;\n  }\n  .form-inline .radio label,\n  .form-inline .checkbox label {\n    padding-left: 0;\n  }\n  .form-inline .radio input[type=\"radio\"],\n  .form-inline .checkbox input[type=\"checkbox\"] {\n    position: relative;\n    margin-left: 0;\n  }\n  .form-inline .has-feedback .form-control-feedback {\n    top: 0;\n  }\n}\n.form-horizontal .radio,\n.form-horizontal .checkbox,\n.form-horizontal .radio-inline,\n.form-horizontal .checkbox-inline {\n  margin-top: 0;\n  margin-bottom: 0;\n  padding-top: 7px;\n}\n.form-horizontal .radio,\n.form-horizontal .checkbox {\n  min-height: 27px;\n}\n.form-horizontal .form-group {\n  margin-left: -15px;\n  margin-right: -15px;\n}\n@media (min-width: 768px) {\n  .form-horizontal .control-label {\n    text-align: right;\n    margin-bottom: 0;\n    padding-top: 7px;\n  }\n}\n.form-horizontal .has-feedback .form-control-feedback {\n  right: 15px;\n}\n@media (min-width: 768px) {\n  .form-horizontal .form-group-lg .control-label {\n    padding-top: 11px;\n    font-size: 18px;\n  }\n}\n@media (min-width: 768px) {\n  .form-horizontal .form-group-sm .control-label {\n    padding-top: 6px;\n    font-size: 12px;\n  }\n}\n.btn {\n  display: inline-block;\n  margin-bottom: 0;\n  font-weight: normal;\n  text-align: center;\n  vertical-align: middle;\n  touch-action: manipulation;\n  cursor: pointer;\n  background-image: none;\n  border: 1px solid transparent;\n  white-space: nowrap;\n  padding: 6px 12px;\n  font-size: 14px;\n  line-height: 1.42857143;\n  border-radius: 4px;\n  -webkit-user-select: none;\n  -moz-user-select: none;\n  -ms-user-select: none;\n  user-select: none;\n}\n.btn:focus,\n.btn:active:focus,\n.btn.active:focus,\n.btn.focus,\n.btn:active.focus,\n.btn.active.focus {\n  outline: 5px auto -webkit-focus-ring-color;\n  outline-offset: -2px;\n}\n.btn:hover,\n.btn:focus,\n.btn.focus {\n  color: #333;\n  text-decoration: none;\n}\n.btn:active,\n.btn.active {\n  outline: 0;\n  background-image: none;\n  -webkit-box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);\n  box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);\n}\n.btn.disabled,\n.btn[disabled],\nfieldset[disabled] .btn {\n  cursor: not-allowed;\n  opacity: 0.65;\n  filter: alpha(opacity=65);\n  -webkit-box-shadow: none;\n  box-shadow: none;\n}\na.btn.disabled,\nfieldset[disabled] a.btn {\n  pointer-events: none;\n}\n.btn-default {\n  color: #333;\n  background-color: #fff;\n  border-color: #ccc;\n}\n.btn-default:focus,\n.btn-default.focus {\n  color: #333;\n  background-color: #e6e6e6;\n  border-color: #8c8c8c;\n}\n.btn-default:hover {\n  color: #333;\n  background-color: #e6e6e6;\n  border-color: #adadad;\n}\n.btn-default:active,\n.btn-default.active,\n.open > .dropdown-toggle.btn-default {\n  color: #333;\n  background-color: #e6e6e6;\n  border-color: #adadad;\n}\n.btn-default:active:hover,\n.btn-default.active:hover,\n.open > .dropdown-toggle.btn-default:hover,\n.btn-default:active:focus,\n.btn-default.active:focus,\n.open > .dropdown-toggle.btn-default:focus,\n.btn-default:active.focus,\n.btn-default.active.focus,\n.open > .dropdown-toggle.btn-default.focus {\n  color: #333;\n  background-color: #d4d4d4;\n  border-color: #8c8c8c;\n}\n.btn-default:active,\n.btn-default.active,\n.open > .dropdown-toggle.btn-default {\n  background-image: none;\n}\n.btn-default.disabled:hover,\n.btn-default[disabled]:hover,\nfieldset[disabled] .btn-default:hover,\n.btn-default.disabled:focus,\n.btn-default[disabled]:focus,\nfieldset[disabled] .btn-default:focus,\n.btn-default.disabled.focus,\n.btn-default[disabled].focus,\nfieldset[disabled] .btn-default.focus {\n  background-color: #fff;\n  border-color: #ccc;\n}\n.btn-default .badge {\n  color: #fff;\n  background-color: #333;\n}\n.btn-primary {\n  color: #fff;\n  background-color: #00e5f0;\n  border-color: #00cdd7;\n}\n.btn-primary:focus,\n.btn-primary.focus {\n  color: #fff;\n  background-color: #00b4bd;\n  border-color: #005357;\n}\n.btn-primary:hover {\n  color: #fff;\n  background-color: #00b4bd;\n  border-color: #009299;\n}\n.btn-primary:active,\n.btn-primary.active,\n.open > .dropdown-toggle.btn-primary {\n  color: #fff;\n  background-color: #00b4bd;\n  border-color: #009299;\n}\n.btn-primary:active:hover,\n.btn-primary.active:hover,\n.open > .dropdown-toggle.btn-primary:hover,\n.btn-primary:active:focus,\n.btn-primary.active:focus,\n.open > .dropdown-toggle.btn-primary:focus,\n.btn-primary:active.focus,\n.btn-primary.active.focus,\n.open > .dropdown-toggle.btn-primary.focus {\n  color: #fff;\n  background-color: #009299;\n  border-color: #005357;\n}\n.btn-primary:active,\n.btn-primary.active,\n.open > .dropdown-toggle.btn-primary {\n  background-image: none;\n}\n.btn-primary.disabled:hover,\n.btn-primary[disabled]:hover,\nfieldset[disabled] .btn-primary:hover,\n.btn-primary.disabled:focus,\n.btn-primary[disabled]:focus,\nfieldset[disabled] .btn-primary:focus,\n.btn-primary.disabled.focus,\n.btn-primary[disabled].focus,\nfieldset[disabled] .btn-primary.focus {\n  background-color: #00e5f0;\n  border-color: #00cdd7;\n}\n.btn-primary .badge {\n  color: #00e5f0;\n  background-color: #fff;\n}\n.btn-success {\n  color: #fff;\n  background-color: #00e5f0;\n  border-color: #00cdd7;\n}\n.btn-success:focus,\n.btn-success.focus {\n  color: #fff;\n  background-color: #00b4bd;\n  border-color: #005357;\n}\n.btn-success:hover {\n  color: #fff;\n  background-color: #00b4bd;\n  border-color: #009299;\n}\n.btn-success:active,\n.btn-success.active,\n.open > .dropdown-toggle.btn-success {\n  color: #fff;\n  background-color: #00b4bd;\n  border-color: #009299;\n}\n.btn-success:active:hover,\n.btn-success.active:hover,\n.open > .dropdown-toggle.btn-success:hover,\n.btn-success:active:focus,\n.btn-success.active:focus,\n.open > .dropdown-toggle.btn-success:focus,\n.btn-success:active.focus,\n.btn-success.active.focus,\n.open > .dropdown-toggle.btn-success.focus {\n  color: #fff;\n  background-color: #009299;\n  border-color: #005357;\n}\n.btn-success:active,\n.btn-success.active,\n.open > .dropdown-toggle.btn-success {\n  background-image: none;\n}\n.btn-success.disabled:hover,\n.btn-success[disabled]:hover,\nfieldset[disabled] .btn-success:hover,\n.btn-success.disabled:focus,\n.btn-success[disabled]:focus,\nfieldset[disabled] .btn-success:focus,\n.btn-success.disabled.focus,\n.btn-success[disabled].focus,\nfieldset[disabled] .btn-success.focus {\n  background-color: #00e5f0;\n  border-color: #00cdd7;\n}\n.btn-success .badge {\n  color: #00e5f0;\n  background-color: #fff;\n}\n.btn-info {\n  color: #fff;\n  background-color: #00e5f0;\n  border-color: #00cdd7;\n}\n.btn-info:focus,\n.btn-info.focus {\n  color: #fff;\n  background-color: #00b4bd;\n  border-color: #005357;\n}\n.btn-info:hover {\n  color: #fff;\n  background-color: #00b4bd;\n  border-color: #009299;\n}\n.btn-info:active,\n.btn-info.active,\n.open > .dropdown-toggle.btn-info {\n  color: #fff;\n  background-color: #00b4bd;\n  border-color: #009299;\n}\n.btn-info:active:hover,\n.btn-info.active:hover,\n.open > .dropdown-toggle.btn-info:hover,\n.btn-info:active:focus,\n.btn-info.active:focus,\n.open > .dropdown-toggle.btn-info:focus,\n.btn-info:active.focus,\n.btn-info.active.focus,\n.open > .dropdown-toggle.btn-info.focus {\n  color: #fff;\n  background-color: #009299;\n  border-color: #005357;\n}\n.btn-info:active,\n.btn-info.active,\n.open > .dropdown-toggle.btn-info {\n  background-image: none;\n}\n.btn-info.disabled:hover,\n.btn-info[disabled]:hover,\nfieldset[disabled] .btn-info:hover,\n.btn-info.disabled:focus,\n.btn-info[disabled]:focus,\nfieldset[disabled] .btn-info:focus,\n.btn-info.disabled.focus,\n.btn-info[disabled].focus,\nfieldset[disabled] .btn-info.focus {\n  background-color: #00e5f0;\n  border-color: #00cdd7;\n}\n.btn-info .badge {\n  color: #00e5f0;\n  background-color: #fff;\n}\n.btn-warning {\n  color: #fff;\n  background-color: #977bf0;\n  border-color: #8564ed;\n}\n.btn-warning:focus,\n.btn-warning.focus {\n  color: #fff;\n  background-color: #734deb;\n  border-color: #3d15bd;\n}\n.btn-warning:hover {\n  color: #fff;\n  background-color: #734deb;\n  border-color: #5a2de7;\n}\n.btn-warning:active,\n.btn-warning.active,\n.open > .dropdown-toggle.btn-warning {\n  color: #fff;\n  background-color: #734deb;\n  border-color: #5a2de7;\n}\n.btn-warning:active:hover,\n.btn-warning.active:hover,\n.open > .dropdown-toggle.btn-warning:hover,\n.btn-warning:active:focus,\n.btn-warning.active:focus,\n.open > .dropdown-toggle.btn-warning:focus,\n.btn-warning:active.focus,\n.btn-warning.active.focus,\n.open > .dropdown-toggle.btn-warning.focus {\n  color: #fff;\n  background-color: #5a2de7;\n  border-color: #3d15bd;\n}\n.btn-warning:active,\n.btn-warning.active,\n.open > .dropdown-toggle.btn-warning {\n  background-image: none;\n}\n.btn-warning.disabled:hover,\n.btn-warning[disabled]:hover,\nfieldset[disabled] .btn-warning:hover,\n.btn-warning.disabled:focus,\n.btn-warning[disabled]:focus,\nfieldset[disabled] .btn-warning:focus,\n.btn-warning.disabled.focus,\n.btn-warning[disabled].focus,\nfieldset[disabled] .btn-warning.focus {\n  background-color: #977bf0;\n  border-color: #8564ed;\n}\n.btn-warning .badge {\n  color: #977bf0;\n  background-color: #fff;\n}\n.btn-danger {\n  color: #fff;\n  background-color: #e01f74;\n  border-color: #ca1c68;\n}\n.btn-danger:focus,\n.btn-danger.focus {\n  color: #fff;\n  background-color: #b3195d;\n  border-color: #5a0c2e;\n}\n.btn-danger:hover {\n  color: #fff;\n  background-color: #b3195d;\n  border-color: #94144d;\n}\n.btn-danger:active,\n.btn-danger.active,\n.open > .dropdown-toggle.btn-danger {\n  color: #fff;\n  background-color: #b3195d;\n  border-color: #94144d;\n}\n.btn-danger:active:hover,\n.btn-danger.active:hover,\n.open > .dropdown-toggle.btn-danger:hover,\n.btn-danger:active:focus,\n.btn-danger.active:focus,\n.open > .dropdown-toggle.btn-danger:focus,\n.btn-danger:active.focus,\n.btn-danger.active.focus,\n.open > .dropdown-toggle.btn-danger.focus {\n  color: #fff;\n  background-color: #94144d;\n  border-color: #5a0c2e;\n}\n.btn-danger:active,\n.btn-danger.active,\n.open > .dropdown-toggle.btn-danger {\n  background-image: none;\n}\n.btn-danger.disabled:hover,\n.btn-danger[disabled]:hover,\nfieldset[disabled] .btn-danger:hover,\n.btn-danger.disabled:focus,\n.btn-danger[disabled]:focus,\nfieldset[disabled] .btn-danger:focus,\n.btn-danger.disabled.focus,\n.btn-danger[disabled].focus,\nfieldset[disabled] .btn-danger.focus {\n  background-color: #e01f74;\n  border-color: #ca1c68;\n}\n.btn-danger .badge {\n  color: #e01f74;\n  background-color: #fff;\n}\n.btn-link {\n  color: #00e5f0;\n  font-weight: normal;\n  border-radius: 0;\n}\n.btn-link,\n.btn-link:active,\n.btn-link.active,\n.btn-link[disabled],\nfieldset[disabled] .btn-link {\n  background-color: transparent;\n  -webkit-box-shadow: none;\n  box-shadow: none;\n}\n.btn-link,\n.btn-link:hover,\n.btn-link:focus,\n.btn-link:active {\n  border-color: transparent;\n}\n.btn-link:hover,\n.btn-link:focus {\n  color: #009ca3;\n  text-decoration: underline;\n  background-color: transparent;\n}\n.btn-link[disabled]:hover,\nfieldset[disabled] .btn-link:hover,\n.btn-link[disabled]:focus,\nfieldset[disabled] .btn-link:focus {\n  color: #777777;\n  text-decoration: none;\n}\n.btn-lg,\n.btn-group-lg > .btn {\n  padding: 10px 16px;\n  font-size: 18px;\n  line-height: 1.3333333;\n  border-radius: 6px;\n}\n.btn-sm,\n.btn-group-sm > .btn {\n  padding: 5px 10px;\n  font-size: 12px;\n  line-height: 1.5;\n  border-radius: 3px;\n}\n.btn-xs,\n.btn-group-xs > .btn {\n  padding: 1px 5px;\n  font-size: 12px;\n  line-height: 1.5;\n  border-radius: 3px;\n}\n.btn-block {\n  display: block;\n  width: 100%;\n}\n.btn-block + .btn-block {\n  margin-top: 5px;\n}\ninput[type=\"submit\"].btn-block,\ninput[type=\"reset\"].btn-block,\ninput[type=\"button\"].btn-block {\n  width: 100%;\n}\n.fade {\n  opacity: 0;\n  -webkit-transition: opacity 0.15s linear;\n  -o-transition: opacity 0.15s linear;\n  transition: opacity 0.15s linear;\n}\n.fade.in {\n  opacity: 1;\n}\n.collapse {\n  display: none;\n}\n.collapse.in {\n  display: block;\n}\ntr.collapse.in {\n  display: table-row;\n}\ntbody.collapse.in {\n  display: table-row-group;\n}\n.collapsing {\n  position: relative;\n  height: 0;\n  overflow: hidden;\n  -webkit-transition-property: height, visibility;\n  transition-property: height, visibility;\n  -webkit-transition-duration: 0.35s;\n  transition-duration: 0.35s;\n  -webkit-transition-timing-function: ease;\n  transition-timing-function: ease;\n}\n.caret {\n  display: inline-block;\n  width: 0;\n  height: 0;\n  margin-left: 2px;\n  vertical-align: middle;\n  border-top: 4px dashed;\n  border-top: 4px solid \\9;\n  border-right: 4px solid transparent;\n  border-left: 4px solid transparent;\n}\n.dropup,\n.dropdown {\n  position: relative;\n}\n.dropdown-toggle:focus {\n  outline: 0;\n}\n.dropdown-menu {\n  position: absolute;\n  top: 100%;\n  left: 0;\n  z-index: 1000;\n  display: none;\n  float: left;\n  min-width: 160px;\n  padding: 5px 0;\n  margin: 2px 0 0;\n  list-style: none;\n  font-size: 14px;\n  text-align: left;\n  background-color: #fff;\n  border: 1px solid #ccc;\n  border: 1px solid rgba(0, 0, 0, 0.15);\n  border-radius: 4px;\n  -webkit-box-shadow: 0 6px 12px rgba(0, 0, 0, 0.175);\n  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.175);\n  background-clip: padding-box;\n}\n.dropdown-menu.pull-right {\n  right: 0;\n  left: auto;\n}\n.dropdown-menu .divider {\n  height: 1px;\n  margin: 9px 0;\n  overflow: hidden;\n  background-color: #e5e5e5;\n}\n.dropdown-menu > li > a {\n  display: block;\n  padding: 3px 20px;\n  clear: both;\n  font-weight: normal;\n  line-height: 1.42857143;\n  color: #333333;\n  white-space: nowrap;\n}\n.dropdown-menu > li > a:hover,\n.dropdown-menu > li > a:focus {\n  text-decoration: none;\n  color: #262626;\n  background-color: #f5f5f5;\n}\n.dropdown-menu > .active > a,\n.dropdown-menu > .active > a:hover,\n.dropdown-menu > .active > a:focus {\n  color: #fff;\n  text-decoration: none;\n  outline: 0;\n  background-color: #00e5f0;\n}\n.dropdown-menu > .disabled > a,\n.dropdown-menu > .disabled > a:hover,\n.dropdown-menu > .disabled > a:focus {\n  color: #777777;\n}\n.dropdown-menu > .disabled > a:hover,\n.dropdown-menu > .disabled > a:focus {\n  text-decoration: none;\n  background-color: transparent;\n  background-image: none;\n  filter: progid:DXImageTransform.Microsoft.gradient(enabled = false);\n  cursor: not-allowed;\n}\n.open > .dropdown-menu {\n  display: block;\n}\n.open > a {\n  outline: 0;\n}\n.dropdown-menu-right {\n  left: auto;\n  right: 0;\n}\n.dropdown-menu-left {\n  left: 0;\n  right: auto;\n}\n.dropdown-header {\n  display: block;\n  padding: 3px 20px;\n  font-size: 12px;\n  line-height: 1.42857143;\n  color: #777777;\n  white-space: nowrap;\n}\n.dropdown-backdrop {\n  position: fixed;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  top: 0;\n  z-index: 990;\n}\n.pull-right > .dropdown-menu {\n  right: 0;\n  left: auto;\n}\n.dropup .caret,\n.navbar-fixed-bottom .dropdown .caret {\n  border-top: 0;\n  border-bottom: 4px dashed;\n  border-bottom: 4px solid \\9;\n  content: \"\";\n}\n.dropup .dropdown-menu,\n.navbar-fixed-bottom .dropdown .dropdown-menu {\n  top: auto;\n  bottom: 100%;\n  margin-bottom: 2px;\n}\n@media (min-width: 768px) {\n  .navbar-right .dropdown-menu {\n    left: auto;\n    right: 0;\n  }\n  .navbar-right .dropdown-menu-left {\n    left: 0;\n    right: auto;\n  }\n}\n.btn-group,\n.btn-group-vertical {\n  position: relative;\n  display: inline-block;\n  vertical-align: middle;\n}\n.btn-group > .btn,\n.btn-group-vertical > .btn {\n  position: relative;\n  float: left;\n}\n.btn-group > .btn:hover,\n.btn-group-vertical > .btn:hover,\n.btn-group > .btn:focus,\n.btn-group-vertical > .btn:focus,\n.btn-group > .btn:active,\n.btn-group-vertical > .btn:active,\n.btn-group > .btn.active,\n.btn-group-vertical > .btn.active {\n  z-index: 2;\n}\n.btn-group .btn + .btn,\n.btn-group .btn + .btn-group,\n.btn-group .btn-group + .btn,\n.btn-group .btn-group + .btn-group {\n  margin-left: -1px;\n}\n.btn-toolbar {\n  margin-left: -5px;\n}\n.btn-toolbar .btn,\n.btn-toolbar .btn-group,\n.btn-toolbar .input-group {\n  float: left;\n}\n.btn-toolbar > .btn,\n.btn-toolbar > .btn-group,\n.btn-toolbar > .input-group {\n  margin-left: 5px;\n}\n.btn-group > .btn:not(:first-child):not(:last-child):not(.dropdown-toggle) {\n  border-radius: 0;\n}\n.btn-group > .btn:first-child {\n  margin-left: 0;\n}\n.btn-group > .btn:first-child:not(:last-child):not(.dropdown-toggle) {\n  border-bottom-right-radius: 0;\n  border-top-right-radius: 0;\n}\n.btn-group > .btn:last-child:not(:first-child),\n.btn-group > .dropdown-toggle:not(:first-child) {\n  border-bottom-left-radius: 0;\n  border-top-left-radius: 0;\n}\n.btn-group > .btn-group {\n  float: left;\n}\n.btn-group > .btn-group:not(:first-child):not(:last-child) > .btn {\n  border-radius: 0;\n}\n.btn-group > .btn-group:first-child:not(:last-child) > .btn:last-child,\n.btn-group > .btn-group:first-child:not(:last-child) > .dropdown-toggle {\n  border-bottom-right-radius: 0;\n  border-top-right-radius: 0;\n}\n.btn-group > .btn-group:last-child:not(:first-child) > .btn:first-child {\n  border-bottom-left-radius: 0;\n  border-top-left-radius: 0;\n}\n.btn-group .dropdown-toggle:active,\n.btn-group.open .dropdown-toggle {\n  outline: 0;\n}\n.btn-group > .btn + .dropdown-toggle {\n  padding-left: 8px;\n  padding-right: 8px;\n}\n.btn-group > .btn-lg + .dropdown-toggle {\n  padding-left: 12px;\n  padding-right: 12px;\n}\n.btn-group.open .dropdown-toggle {\n  -webkit-box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);\n  box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);\n}\n.btn-group.open .dropdown-toggle.btn-link {\n  -webkit-box-shadow: none;\n  box-shadow: none;\n}\n.btn .caret {\n  margin-left: 0;\n}\n.btn-lg .caret {\n  border-width: 5px 5px 0;\n  border-bottom-width: 0;\n}\n.dropup .btn-lg .caret {\n  border-width: 0 5px 5px;\n}\n.btn-group-vertical > .btn,\n.btn-group-vertical > .btn-group,\n.btn-group-vertical > .btn-group > .btn {\n  display: block;\n  float: none;\n  width: 100%;\n  max-width: 100%;\n}\n.btn-group-vertical > .btn-group > .btn {\n  float: none;\n}\n.btn-group-vertical > .btn + .btn,\n.btn-group-vertical > .btn + .btn-group,\n.btn-group-vertical > .btn-group + .btn,\n.btn-group-vertical > .btn-group + .btn-group {\n  margin-top: -1px;\n  margin-left: 0;\n}\n.btn-group-vertical > .btn:not(:first-child):not(:last-child) {\n  border-radius: 0;\n}\n.btn-group-vertical > .btn:first-child:not(:last-child) {\n  border-top-right-radius: 4px;\n  border-top-left-radius: 4px;\n  border-bottom-right-radius: 0;\n  border-bottom-left-radius: 0;\n}\n.btn-group-vertical > .btn:last-child:not(:first-child) {\n  border-top-right-radius: 0;\n  border-top-left-radius: 0;\n  border-bottom-right-radius: 4px;\n  border-bottom-left-radius: 4px;\n}\n.btn-group-vertical > .btn-group:not(:first-child):not(:last-child) > .btn {\n  border-radius: 0;\n}\n.btn-group-vertical > .btn-group:first-child:not(:last-child) > .btn:last-child,\n.btn-group-vertical > .btn-group:first-child:not(:last-child) > .dropdown-toggle {\n  border-bottom-right-radius: 0;\n  border-bottom-left-radius: 0;\n}\n.btn-group-vertical > .btn-group:last-child:not(:first-child) > .btn:first-child {\n  border-top-right-radius: 0;\n  border-top-left-radius: 0;\n}\n.btn-group-justified {\n  display: table;\n  width: 100%;\n  table-layout: fixed;\n  border-collapse: separate;\n}\n.btn-group-justified > .btn,\n.btn-group-justified > .btn-group {\n  float: none;\n  display: table-cell;\n  width: 1%;\n}\n.btn-group-justified > .btn-group .btn {\n  width: 100%;\n}\n.btn-group-justified > .btn-group .dropdown-menu {\n  left: auto;\n}\n[data-toggle=\"buttons\"] > .btn input[type=\"radio\"],\n[data-toggle=\"buttons\"] > .btn-group > .btn input[type=\"radio\"],\n[data-toggle=\"buttons\"] > .btn input[type=\"checkbox\"],\n[data-toggle=\"buttons\"] > .btn-group > .btn input[type=\"checkbox\"] {\n  position: absolute;\n  clip: rect(0, 0, 0, 0);\n  pointer-events: none;\n}\n.input-group {\n  position: relative;\n  display: table;\n  border-collapse: separate;\n}\n.input-group[class*=\"col-\"] {\n  float: none;\n  padding-left: 0;\n  padding-right: 0;\n}\n.input-group .form-control {\n  position: relative;\n  z-index: 2;\n  float: left;\n  width: 100%;\n  margin-bottom: 0;\n}\n.input-group .form-control:focus {\n  z-index: 3;\n}\n.input-group-lg > .form-control,\n.input-group-lg > .input-group-addon,\n.input-group-lg > .input-group-btn > .btn {\n  height: 46px;\n  padding: 10px 16px;\n  font-size: 18px;\n  line-height: 1.3333333;\n  border-radius: 6px;\n}\nselect.input-group-lg > .form-control,\nselect.input-group-lg > .input-group-addon,\nselect.input-group-lg > .input-group-btn > .btn {\n  height: 46px;\n  line-height: 46px;\n}\ntextarea.input-group-lg > .form-control,\ntextarea.input-group-lg > .input-group-addon,\ntextarea.input-group-lg > .input-group-btn > .btn,\nselect[multiple].input-group-lg > .form-control,\nselect[multiple].input-group-lg > .input-group-addon,\nselect[multiple].input-group-lg > .input-group-btn > .btn {\n  height: auto;\n}\n.input-group-sm > .form-control,\n.input-group-sm > .input-group-addon,\n.input-group-sm > .input-group-btn > .btn {\n  height: 30px;\n  padding: 5px 10px;\n  font-size: 12px;\n  line-height: 1.5;\n  border-radius: 3px;\n}\nselect.input-group-sm > .form-control,\nselect.input-group-sm > .input-group-addon,\nselect.input-group-sm > .input-group-btn > .btn {\n  height: 30px;\n  line-height: 30px;\n}\ntextarea.input-group-sm > .form-control,\ntextarea.input-group-sm > .input-group-addon,\ntextarea.input-group-sm > .input-group-btn > .btn,\nselect[multiple].input-group-sm > .form-control,\nselect[multiple].input-group-sm > .input-group-addon,\nselect[multiple].input-group-sm > .input-group-btn > .btn {\n  height: auto;\n}\n.input-group-addon,\n.input-group-btn,\n.input-group .form-control {\n  display: table-cell;\n}\n.input-group-addon:not(:first-child):not(:last-child),\n.input-group-btn:not(:first-child):not(:last-child),\n.input-group .form-control:not(:first-child):not(:last-child) {\n  border-radius: 0;\n}\n.input-group-addon,\n.input-group-btn {\n  width: 1%;\n  white-space: nowrap;\n  vertical-align: middle;\n}\n.input-group-addon {\n  padding: 6px 12px;\n  font-size: 14px;\n  font-weight: normal;\n  line-height: 1;\n  color: #555555;\n  text-align: center;\n  background-color: #eeeeee;\n  border: 1px solid #ccc;\n  border-radius: 4px;\n}\n.input-group-addon.input-sm {\n  padding: 5px 10px;\n  font-size: 12px;\n  border-radius: 3px;\n}\n.input-group-addon.input-lg {\n  padding: 10px 16px;\n  font-size: 18px;\n  border-radius: 6px;\n}\n.input-group-addon input[type=\"radio\"],\n.input-group-addon input[type=\"checkbox\"] {\n  margin-top: 0;\n}\n.input-group .form-control:first-child,\n.input-group-addon:first-child,\n.input-group-btn:first-child > .btn,\n.input-group-btn:first-child > .btn-group > .btn,\n.input-group-btn:first-child > .dropdown-toggle,\n.input-group-btn:last-child > .btn:not(:last-child):not(.dropdown-toggle),\n.input-group-btn:last-child > .btn-group:not(:last-child) > .btn {\n  border-bottom-right-radius: 0;\n  border-top-right-radius: 0;\n}\n.input-group-addon:first-child {\n  border-right: 0;\n}\n.input-group .form-control:last-child,\n.input-group-addon:last-child,\n.input-group-btn:last-child > .btn,\n.input-group-btn:last-child > .btn-group > .btn,\n.input-group-btn:last-child > .dropdown-toggle,\n.input-group-btn:first-child > .btn:not(:first-child),\n.input-group-btn:first-child > .btn-group:not(:first-child) > .btn {\n  border-bottom-left-radius: 0;\n  border-top-left-radius: 0;\n}\n.input-group-addon:last-child {\n  border-left: 0;\n}\n.input-group-btn {\n  position: relative;\n  font-size: 0;\n  white-space: nowrap;\n}\n.input-group-btn > .btn {\n  position: relative;\n}\n.input-group-btn > .btn + .btn {\n  margin-left: -1px;\n}\n.input-group-btn > .btn:hover,\n.input-group-btn > .btn:focus,\n.input-group-btn > .btn:active {\n  z-index: 2;\n}\n.input-group-btn:first-child > .btn,\n.input-group-btn:first-child > .btn-group {\n  margin-right: -1px;\n}\n.input-group-btn:last-child > .btn,\n.input-group-btn:last-child > .btn-group {\n  z-index: 2;\n  margin-left: -1px;\n}\n.nav {\n  margin-bottom: 0;\n  padding-left: 0;\n  list-style: none;\n}\n.nav > li {\n  position: relative;\n  display: block;\n}\n.nav > li > a {\n  position: relative;\n  display: block;\n  padding: 10px 15px;\n}\n.nav > li > a:hover,\n.nav > li > a:focus {\n  text-decoration: none;\n  background-color: #eeeeee;\n}\n.nav > li.disabled > a {\n  color: #777777;\n}\n.nav > li.disabled > a:hover,\n.nav > li.disabled > a:focus {\n  color: #777777;\n  text-decoration: none;\n  background-color: transparent;\n  cursor: not-allowed;\n}\n.nav .open > a,\n.nav .open > a:hover,\n.nav .open > a:focus {\n  background-color: #eeeeee;\n  border-color: #00e5f0;\n}\n.nav .nav-divider {\n  height: 1px;\n  margin: 9px 0;\n  overflow: hidden;\n  background-color: #e5e5e5;\n}\n.nav > li > a > img {\n  max-width: none;\n}\n.nav-tabs {\n  border-bottom: 1px solid #ddd;\n}\n.nav-tabs > li {\n  float: left;\n  margin-bottom: -1px;\n}\n.nav-tabs > li > a {\n  margin-right: 2px;\n  line-height: 1.42857143;\n  border: 1px solid transparent;\n  border-radius: 4px 4px 0 0;\n}\n.nav-tabs > li > a:hover {\n  border-color: #eeeeee #eeeeee #ddd;\n}\n.nav-tabs > li.active > a,\n.nav-tabs > li.active > a:hover,\n.nav-tabs > li.active > a:focus {\n  color: #555555;\n  background-color: #fff;\n  border: 1px solid #ddd;\n  border-bottom-color: transparent;\n  cursor: default;\n}\n.nav-tabs.nav-justified {\n  width: 100%;\n  border-bottom: 0;\n}\n.nav-tabs.nav-justified > li {\n  float: none;\n}\n.nav-tabs.nav-justified > li > a {\n  text-align: center;\n  margin-bottom: 5px;\n}\n.nav-tabs.nav-justified > .dropdown .dropdown-menu {\n  top: auto;\n  left: auto;\n}\n@media (min-width: 768px) {\n  .nav-tabs.nav-justified > li {\n    display: table-cell;\n    width: 1%;\n  }\n  .nav-tabs.nav-justified > li > a {\n    margin-bottom: 0;\n  }\n}\n.nav-tabs.nav-justified > li > a {\n  margin-right: 0;\n  border-radius: 4px;\n}\n.nav-tabs.nav-justified > .active > a,\n.nav-tabs.nav-justified > .active > a:hover,\n.nav-tabs.nav-justified > .active > a:focus {\n  border: 1px solid #ddd;\n}\n@media (min-width: 768px) {\n  .nav-tabs.nav-justified > li > a {\n    border-bottom: 1px solid #ddd;\n    border-radius: 4px 4px 0 0;\n  }\n  .nav-tabs.nav-justified > .active > a,\n  .nav-tabs.nav-justified > .active > a:hover,\n  .nav-tabs.nav-justified > .active > a:focus {\n    border-bottom-color: #fff;\n  }\n}\n.nav-pills > li {\n  float: left;\n}\n.nav-pills > li > a {\n  border-radius: 4px;\n}\n.nav-pills > li + li {\n  margin-left: 2px;\n}\n.nav-pills > li.active > a,\n.nav-pills > li.active > a:hover,\n.nav-pills > li.active > a:focus {\n  color: #fff;\n  background-color: #00e5f0;\n}\n.nav-stacked > li {\n  float: none;\n}\n.nav-stacked > li + li {\n  margin-top: 2px;\n  margin-left: 0;\n}\n.nav-justified {\n  width: 100%;\n}\n.nav-justified > li {\n  float: none;\n}\n.nav-justified > li > a {\n  text-align: center;\n  margin-bottom: 5px;\n}\n.nav-justified > .dropdown .dropdown-menu {\n  top: auto;\n  left: auto;\n}\n@media (min-width: 768px) {\n  .nav-justified > li {\n    display: table-cell;\n    width: 1%;\n  }\n  .nav-justified > li > a {\n    margin-bottom: 0;\n  }\n}\n.nav-tabs-justified {\n  border-bottom: 0;\n}\n.nav-tabs-justified > li > a {\n  margin-right: 0;\n  border-radius: 4px;\n}\n.nav-tabs-justified > .active > a,\n.nav-tabs-justified > .active > a:hover,\n.nav-tabs-justified > .active > a:focus {\n  border: 1px solid #ddd;\n}\n@media (min-width: 768px) {\n  .nav-tabs-justified > li > a {\n    border-bottom: 1px solid #ddd;\n    border-radius: 4px 4px 0 0;\n  }\n  .nav-tabs-justified > .active > a,\n  .nav-tabs-justified > .active > a:hover,\n  .nav-tabs-justified > .active > a:focus {\n    border-bottom-color: #fff;\n  }\n}\n.tab-content > .tab-pane {\n  display: none;\n}\n.tab-content > .active {\n  display: block;\n}\n.nav-tabs .dropdown-menu {\n  margin-top: -1px;\n  border-top-right-radius: 0;\n  border-top-left-radius: 0;\n}\n.navbar {\n  position: relative;\n  min-height: 50px;\n  margin-bottom: 20px;\n  border: 1px solid transparent;\n}\n@media (min-width: 768px) {\n  .navbar {\n    border-radius: 4px;\n  }\n}\n@media (min-width: 768px) {\n  .navbar-header {\n    float: left;\n  }\n}\n.navbar-collapse {\n  overflow-x: visible;\n  padding-right: 15px;\n  padding-left: 15px;\n  border-top: 1px solid transparent;\n  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1);\n  -webkit-overflow-scrolling: touch;\n}\n.navbar-collapse.in {\n  overflow-y: auto;\n}\n@media (min-width: 768px) {\n  .navbar-collapse {\n    width: auto;\n    border-top: 0;\n    box-shadow: none;\n  }\n  .navbar-collapse.collapse {\n    display: block !important;\n    height: auto !important;\n    padding-bottom: 0;\n    overflow: visible !important;\n  }\n  .navbar-collapse.in {\n    overflow-y: visible;\n  }\n  .navbar-fixed-top .navbar-collapse,\n  .navbar-static-top .navbar-collapse,\n  .navbar-fixed-bottom .navbar-collapse {\n    padding-left: 0;\n    padding-right: 0;\n  }\n}\n.navbar-fixed-top .navbar-collapse,\n.navbar-fixed-bottom .navbar-collapse {\n  max-height: 340px;\n}\n@media (max-device-width: 480px) and (orientation: landscape) {\n  .navbar-fixed-top .navbar-collapse,\n  .navbar-fixed-bottom .navbar-collapse {\n    max-height: 200px;\n  }\n}\n.container > .navbar-header,\n.container-fluid > .navbar-header,\n.container > .navbar-collapse,\n.container-fluid > .navbar-collapse {\n  margin-right: -15px;\n  margin-left: -15px;\n}\n@media (min-width: 768px) {\n  .container > .navbar-header,\n  .container-fluid > .navbar-header,\n  .container > .navbar-collapse,\n  .container-fluid > .navbar-collapse {\n    margin-right: 0;\n    margin-left: 0;\n  }\n}\n.navbar-static-top {\n  z-index: 1000;\n  border-width: 0 0 1px;\n}\n@media (min-width: 768px) {\n  .navbar-static-top {\n    border-radius: 0;\n  }\n}\n.navbar-fixed-top,\n.navbar-fixed-bottom {\n  position: fixed;\n  right: 0;\n  left: 0;\n  z-index: 1030;\n}\n@media (min-width: 768px) {\n  .navbar-fixed-top,\n  .navbar-fixed-bottom {\n    border-radius: 0;\n  }\n}\n.navbar-fixed-top {\n  top: 0;\n  border-width: 0 0 1px;\n}\n.navbar-fixed-bottom {\n  bottom: 0;\n  margin-bottom: 0;\n  border-width: 1px 0 0;\n}\n.navbar-brand {\n  float: left;\n  padding: 15px 15px;\n  font-size: 18px;\n  line-height: 20px;\n  height: 50px;\n}\n.navbar-brand:hover,\n.navbar-brand:focus {\n  text-decoration: none;\n}\n.navbar-brand > img {\n  display: block;\n}\n@media (min-width: 768px) {\n  .navbar > .container .navbar-brand,\n  .navbar > .container-fluid .navbar-brand {\n    margin-left: -15px;\n  }\n}\n.navbar-toggle {\n  position: relative;\n  float: right;\n  margin-right: 15px;\n  padding: 9px 10px;\n  margin-top: 8px;\n  margin-bottom: 8px;\n  background-color: transparent;\n  background-image: none;\n  border: 1px solid transparent;\n  border-radius: 4px;\n}\n.navbar-toggle:focus {\n  outline: 0;\n}\n.navbar-toggle .icon-bar {\n  display: block;\n  width: 22px;\n  height: 2px;\n  border-radius: 1px;\n}\n.navbar-toggle .icon-bar + .icon-bar {\n  margin-top: 4px;\n}\n@media (min-width: 768px) {\n  .navbar-toggle {\n    display: none;\n  }\n}\n.navbar-nav {\n  margin: 7.5px -15px;\n}\n.navbar-nav > li > a {\n  padding-top: 10px;\n  padding-bottom: 10px;\n  line-height: 20px;\n}\n@media (max-width: 767px) {\n  .navbar-nav .open .dropdown-menu {\n    position: static;\n    float: none;\n    width: auto;\n    margin-top: 0;\n    background-color: transparent;\n    border: 0;\n    box-shadow: none;\n  }\n  .navbar-nav .open .dropdown-menu > li > a,\n  .navbar-nav .open .dropdown-menu .dropdown-header {\n    padding: 5px 15px 5px 25px;\n  }\n  .navbar-nav .open .dropdown-menu > li > a {\n    line-height: 20px;\n  }\n  .navbar-nav .open .dropdown-menu > li > a:hover,\n  .navbar-nav .open .dropdown-menu > li > a:focus {\n    background-image: none;\n  }\n}\n@media (min-width: 768px) {\n  .navbar-nav {\n    float: left;\n    margin: 0;\n  }\n  .navbar-nav > li {\n    float: left;\n  }\n  .navbar-nav > li > a {\n    padding-top: 15px;\n    padding-bottom: 15px;\n  }\n}\n.navbar-form {\n  margin-left: -15px;\n  margin-right: -15px;\n  padding: 10px 15px;\n  border-top: 1px solid transparent;\n  border-bottom: 1px solid transparent;\n  -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 1px 0 rgba(255, 255, 255, 0.1);\n  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1), 0 1px 0 rgba(255, 255, 255, 0.1);\n  margin-top: 8px;\n  margin-bottom: 8px;\n}\n@media (min-width: 768px) {\n  .navbar-form .form-group {\n    display: inline-block;\n    margin-bottom: 0;\n    vertical-align: middle;\n  }\n  .navbar-form .form-control {\n    display: inline-block;\n    width: auto;\n    vertical-align: middle;\n  }\n  .navbar-form .form-control-static {\n    display: inline-block;\n  }\n  .navbar-form .input-group {\n    display: inline-table;\n    vertical-align: middle;\n  }\n  .navbar-form .input-group .input-group-addon,\n  .navbar-form .input-group .input-group-btn,\n  .navbar-form .input-group .form-control {\n    width: auto;\n  }\n  .navbar-form .input-group > .form-control {\n    width: 100%;\n  }\n  .navbar-form .control-label {\n    margin-bottom: 0;\n    vertical-align: middle;\n  }\n  .navbar-form .radio,\n  .navbar-form .checkbox {\n    display: inline-block;\n    margin-top: 0;\n    margin-bottom: 0;\n    vertical-align: middle;\n  }\n  .navbar-form .radio label,\n  .navbar-form .checkbox label {\n    padding-left: 0;\n  }\n  .navbar-form .radio input[type=\"radio\"],\n  .navbar-form .checkbox input[type=\"checkbox\"] {\n    position: relative;\n    margin-left: 0;\n  }\n  .navbar-form .has-feedback .form-control-feedback {\n    top: 0;\n  }\n}\n@media (max-width: 767px) {\n  .navbar-form .form-group {\n    margin-bottom: 5px;\n  }\n  .navbar-form .form-group:last-child {\n    margin-bottom: 0;\n  }\n}\n@media (min-width: 768px) {\n  .navbar-form {\n    width: auto;\n    border: 0;\n    margin-left: 0;\n    margin-right: 0;\n    padding-top: 0;\n    padding-bottom: 0;\n    -webkit-box-shadow: none;\n    box-shadow: none;\n  }\n}\n.navbar-nav > li > .dropdown-menu {\n  margin-top: 0;\n  border-top-right-radius: 0;\n  border-top-left-radius: 0;\n}\n.navbar-fixed-bottom .navbar-nav > li > .dropdown-menu {\n  margin-bottom: 0;\n  border-top-right-radius: 4px;\n  border-top-left-radius: 4px;\n  border-bottom-right-radius: 0;\n  border-bottom-left-radius: 0;\n}\n.navbar-btn {\n  margin-top: 8px;\n  margin-bottom: 8px;\n}\n.navbar-btn.btn-sm {\n  margin-top: 10px;\n  margin-bottom: 10px;\n}\n.navbar-btn.btn-xs {\n  margin-top: 14px;\n  margin-bottom: 14px;\n}\n.navbar-text {\n  margin-top: 15px;\n  margin-bottom: 15px;\n}\n@media (min-width: 768px) {\n  .navbar-text {\n    float: left;\n    margin-left: 15px;\n    margin-right: 15px;\n  }\n}\n@media (min-width: 768px) {\n  .navbar-left {\n    float: left !important;\n  }\n  .navbar-right {\n    float: right !important;\n    margin-right: -15px;\n  }\n  .navbar-right ~ .navbar-right {\n    margin-right: 0;\n  }\n}\n.navbar-default {\n  background-color: #f8f8f8;\n  border-color: #e7e7e7;\n}\n.navbar-default .navbar-brand {\n  color: #777;\n}\n.navbar-default .navbar-brand:hover,\n.navbar-default .navbar-brand:focus {\n  color: #5e5e5e;\n  background-color: transparent;\n}\n.navbar-default .navbar-text {\n  color: #777;\n}\n.navbar-default .navbar-nav > li > a {\n  color: #777;\n}\n.navbar-default .navbar-nav > li > a:hover,\n.navbar-default .navbar-nav > li > a:focus {\n  color: #333;\n  background-color: transparent;\n}\n.navbar-default .navbar-nav > .active > a,\n.navbar-default .navbar-nav > .active > a:hover,\n.navbar-default .navbar-nav > .active > a:focus {\n  color: #555;\n  background-color: #e7e7e7;\n}\n.navbar-default .navbar-nav > .disabled > a,\n.navbar-default .navbar-nav > .disabled > a:hover,\n.navbar-default .navbar-nav > .disabled > a:focus {\n  color: #ccc;\n  background-color: transparent;\n}\n.navbar-default .navbar-toggle {\n  border-color: #ddd;\n}\n.navbar-default .navbar-toggle:hover,\n.navbar-default .navbar-toggle:focus {\n  background-color: #ddd;\n}\n.navbar-default .navbar-toggle .icon-bar {\n  background-color: #888;\n}\n.navbar-default .navbar-collapse,\n.navbar-default .navbar-form {\n  border-color: #e7e7e7;\n}\n.navbar-default .navbar-nav > .open > a,\n.navbar-default .navbar-nav > .open > a:hover,\n.navbar-default .navbar-nav > .open > a:focus {\n  background-color: #e7e7e7;\n  color: #555;\n}\n@media (max-width: 767px) {\n  .navbar-default .navbar-nav .open .dropdown-menu > li > a {\n    color: #777;\n  }\n  .navbar-default .navbar-nav .open .dropdown-menu > li > a:hover,\n  .navbar-default .navbar-nav .open .dropdown-menu > li > a:focus {\n    color: #333;\n    background-color: transparent;\n  }\n  .navbar-default .navbar-nav .open .dropdown-menu > .active > a,\n  .navbar-default .navbar-nav .open .dropdown-menu > .active > a:hover,\n  .navbar-default .navbar-nav .open .dropdown-menu > .active > a:focus {\n    color: #555;\n    background-color: #e7e7e7;\n  }\n  .navbar-default .navbar-nav .open .dropdown-menu > .disabled > a,\n  .navbar-default .navbar-nav .open .dropdown-menu > .disabled > a:hover,\n  .navbar-default .navbar-nav .open .dropdown-menu > .disabled > a:focus {\n    color: #ccc;\n    background-color: transparent;\n  }\n}\n.navbar-default .navbar-link {\n  color: #777;\n}\n.navbar-default .navbar-link:hover {\n  color: #333;\n}\n.navbar-default .btn-link {\n  color: #777;\n}\n.navbar-default .btn-link:hover,\n.navbar-default .btn-link:focus {\n  color: #333;\n}\n.navbar-default .btn-link[disabled]:hover,\nfieldset[disabled] .navbar-default .btn-link:hover,\n.navbar-default .btn-link[disabled]:focus,\nfieldset[disabled] .navbar-default .btn-link:focus {\n  color: #ccc;\n}\n.navbar-inverse {\n  background-color: #222;\n  border-color: #080808;\n}\n.navbar-inverse .navbar-brand {\n  color: #9d9d9d;\n}\n.navbar-inverse .navbar-brand:hover,\n.navbar-inverse .navbar-brand:focus {\n  color: #fff;\n  background-color: transparent;\n}\n.navbar-inverse .navbar-text {\n  color: #9d9d9d;\n}\n.navbar-inverse .navbar-nav > li > a {\n  color: #9d9d9d;\n}\n.navbar-inverse .navbar-nav > li > a:hover,\n.navbar-inverse .navbar-nav > li > a:focus {\n  color: #fff;\n  background-color: transparent;\n}\n.navbar-inverse .navbar-nav > .active > a,\n.navbar-inverse .navbar-nav > .active > a:hover,\n.navbar-inverse .navbar-nav > .active > a:focus {\n  color: #fff;\n  background-color: #080808;\n}\n.navbar-inverse .navbar-nav > .disabled > a,\n.navbar-inverse .navbar-nav > .disabled > a:hover,\n.navbar-inverse .navbar-nav > .disabled > a:focus {\n  color: #444;\n  background-color: transparent;\n}\n.navbar-inverse .navbar-toggle {\n  border-color: #333;\n}\n.navbar-inverse .navbar-toggle:hover,\n.navbar-inverse .navbar-toggle:focus {\n  background-color: #333;\n}\n.navbar-inverse .navbar-toggle .icon-bar {\n  background-color: #fff;\n}\n.navbar-inverse .navbar-collapse,\n.navbar-inverse .navbar-form {\n  border-color: #101010;\n}\n.navbar-inverse .navbar-nav > .open > a,\n.navbar-inverse .navbar-nav > .open > a:hover,\n.navbar-inverse .navbar-nav > .open > a:focus {\n  background-color: #080808;\n  color: #fff;\n}\n@media (max-width: 767px) {\n  .navbar-inverse .navbar-nav .open .dropdown-menu > .dropdown-header {\n    border-color: #080808;\n  }\n  .navbar-inverse .navbar-nav .open .dropdown-menu .divider {\n    background-color: #080808;\n  }\n  .navbar-inverse .navbar-nav .open .dropdown-menu > li > a {\n    color: #9d9d9d;\n  }\n  .navbar-inverse .navbar-nav .open .dropdown-menu > li > a:hover,\n  .navbar-inverse .navbar-nav .open .dropdown-menu > li > a:focus {\n    color: #fff;\n    background-color: transparent;\n  }\n  .navbar-inverse .navbar-nav .open .dropdown-menu > .active > a,\n  .navbar-inverse .navbar-nav .open .dropdown-menu > .active > a:hover,\n  .navbar-inverse .navbar-nav .open .dropdown-menu > .active > a:focus {\n    color: #fff;\n    background-color: #080808;\n  }\n  .navbar-inverse .navbar-nav .open .dropdown-menu > .disabled > a,\n  .navbar-inverse .navbar-nav .open .dropdown-menu > .disabled > a:hover,\n  .navbar-inverse .navbar-nav .open .dropdown-menu > .disabled > a:focus {\n    color: #444;\n    background-color: transparent;\n  }\n}\n.navbar-inverse .navbar-link {\n  color: #9d9d9d;\n}\n.navbar-inverse .navbar-link:hover {\n  color: #fff;\n}\n.navbar-inverse .btn-link {\n  color: #9d9d9d;\n}\n.navbar-inverse .btn-link:hover,\n.navbar-inverse .btn-link:focus {\n  color: #fff;\n}\n.navbar-inverse .btn-link[disabled]:hover,\nfieldset[disabled] .navbar-inverse .btn-link:hover,\n.navbar-inverse .btn-link[disabled]:focus,\nfieldset[disabled] .navbar-inverse .btn-link:focus {\n  color: #444;\n}\n.breadcrumb {\n  padding: 8px 15px;\n  margin-bottom: 20px;\n  list-style: none;\n  background-color: #f5f5f5;\n  border-radius: 4px;\n}\n.breadcrumb > li {\n  display: inline-block;\n}\n.breadcrumb > li + li:before {\n  content: \"/\\00a0\";\n  padding: 0 5px;\n  color: #ccc;\n}\n.breadcrumb > .active {\n  color: #777777;\n}\n.pagination {\n  display: inline-block;\n  padding-left: 0;\n  margin: 20px 0;\n  border-radius: 4px;\n}\n.pagination > li {\n  display: inline;\n}\n.pagination > li > a,\n.pagination > li > span {\n  position: relative;\n  float: left;\n  padding: 6px 12px;\n  line-height: 1.42857143;\n  text-decoration: none;\n  color: #00e5f0;\n  background-color: #fff;\n  border: 1px solid #ddd;\n  margin-left: -1px;\n}\n.pagination > li:first-child > a,\n.pagination > li:first-child > span {\n  margin-left: 0;\n  border-bottom-left-radius: 4px;\n  border-top-left-radius: 4px;\n}\n.pagination > li:last-child > a,\n.pagination > li:last-child > span {\n  border-bottom-right-radius: 4px;\n  border-top-right-radius: 4px;\n}\n.pagination > li > a:hover,\n.pagination > li > span:hover,\n.pagination > li > a:focus,\n.pagination > li > span:focus {\n  z-index: 2;\n  color: #009ca3;\n  background-color: #eeeeee;\n  border-color: #ddd;\n}\n.pagination > .active > a,\n.pagination > .active > span,\n.pagination > .active > a:hover,\n.pagination > .active > span:hover,\n.pagination > .active > a:focus,\n.pagination > .active > span:focus {\n  z-index: 3;\n  color: #fff;\n  background-color: #00e5f0;\n  border-color: #00e5f0;\n  cursor: default;\n}\n.pagination > .disabled > span,\n.pagination > .disabled > span:hover,\n.pagination > .disabled > span:focus,\n.pagination > .disabled > a,\n.pagination > .disabled > a:hover,\n.pagination > .disabled > a:focus {\n  color: #777777;\n  background-color: #fff;\n  border-color: #ddd;\n  cursor: not-allowed;\n}\n.pagination-lg > li > a,\n.pagination-lg > li > span {\n  padding: 10px 16px;\n  font-size: 18px;\n  line-height: 1.3333333;\n}\n.pagination-lg > li:first-child > a,\n.pagination-lg > li:first-child > span {\n  border-bottom-left-radius: 6px;\n  border-top-left-radius: 6px;\n}\n.pagination-lg > li:last-child > a,\n.pagination-lg > li:last-child > span {\n  border-bottom-right-radius: 6px;\n  border-top-right-radius: 6px;\n}\n.pagination-sm > li > a,\n.pagination-sm > li > span {\n  padding: 5px 10px;\n  font-size: 12px;\n  line-height: 1.5;\n}\n.pagination-sm > li:first-child > a,\n.pagination-sm > li:first-child > span {\n  border-bottom-left-radius: 3px;\n  border-top-left-radius: 3px;\n}\n.pagination-sm > li:last-child > a,\n.pagination-sm > li:last-child > span {\n  border-bottom-right-radius: 3px;\n  border-top-right-radius: 3px;\n}\n.pager {\n  padding-left: 0;\n  margin: 20px 0;\n  list-style: none;\n  text-align: center;\n}\n.pager li {\n  display: inline;\n}\n.pager li > a,\n.pager li > span {\n  display: inline-block;\n  padding: 5px 14px;\n  background-color: #fff;\n  border: 1px solid #ddd;\n  border-radius: 15px;\n}\n.pager li > a:hover,\n.pager li > a:focus {\n  text-decoration: none;\n  background-color: #eeeeee;\n}\n.pager .next > a,\n.pager .next > span {\n  float: right;\n}\n.pager .previous > a,\n.pager .previous > span {\n  float: left;\n}\n.pager .disabled > a,\n.pager .disabled > a:hover,\n.pager .disabled > a:focus,\n.pager .disabled > span {\n  color: #777777;\n  background-color: #fff;\n  cursor: not-allowed;\n}\n.label {\n  display: inline;\n  padding: .2em .6em .3em;\n  font-size: 75%;\n  font-weight: bold;\n  line-height: 1;\n  color: #fff;\n  text-align: center;\n  white-space: nowrap;\n  vertical-align: baseline;\n  border-radius: .25em;\n}\na.label:hover,\na.label:focus {\n  color: #fff;\n  text-decoration: none;\n  cursor: pointer;\n}\n.label:empty {\n  display: none;\n}\n.btn .label {\n  position: relative;\n  top: -1px;\n}\n.label-default {\n  background-color: #777777;\n}\n.label-default[href]:hover,\n.label-default[href]:focus {\n  background-color: #5e5e5e;\n}\n.label-primary {\n  background-color: #00e5f0;\n}\n.label-primary[href]:hover,\n.label-primary[href]:focus {\n  background-color: #00b4bd;\n}\n.label-success {\n  background-color: #00e5f0;\n}\n.label-success[href]:hover,\n.label-success[href]:focus {\n  background-color: #00b4bd;\n}\n.label-info {\n  background-color: #00e5f0;\n}\n.label-info[href]:hover,\n.label-info[href]:focus {\n  background-color: #00b4bd;\n}\n.label-warning {\n  background-color: #977bf0;\n}\n.label-warning[href]:hover,\n.label-warning[href]:focus {\n  background-color: #734deb;\n}\n.label-danger {\n  background-color: #e01f74;\n}\n.label-danger[href]:hover,\n.label-danger[href]:focus {\n  background-color: #b3195d;\n}\n.badge {\n  display: inline-block;\n  min-width: 10px;\n  padding: 3px 7px;\n  font-size: 12px;\n  font-weight: bold;\n  color: #fff;\n  line-height: 1;\n  vertical-align: middle;\n  white-space: nowrap;\n  text-align: center;\n  background-color: #777777;\n  border-radius: 10px;\n}\n.badge:empty {\n  display: none;\n}\n.btn .badge {\n  position: relative;\n  top: -1px;\n}\n.btn-xs .badge,\n.btn-group-xs > .btn .badge {\n  top: 0;\n  padding: 1px 5px;\n}\na.badge:hover,\na.badge:focus {\n  color: #fff;\n  text-decoration: none;\n  cursor: pointer;\n}\n.list-group-item.active > .badge,\n.nav-pills > .active > a > .badge {\n  color: #00e5f0;\n  background-color: #fff;\n}\n.list-group-item > .badge {\n  float: right;\n}\n.list-group-item > .badge + .badge {\n  margin-right: 5px;\n}\n.nav-pills > li > a > .badge {\n  margin-left: 3px;\n}\n.jumbotron {\n  padding-top: 30px;\n  padding-bottom: 30px;\n  margin-bottom: 30px;\n  color: inherit;\n  background-color: #eeeeee;\n}\n.jumbotron h1,\n.jumbotron .h1 {\n  color: inherit;\n}\n.jumbotron p {\n  margin-bottom: 15px;\n  font-size: 21px;\n  font-weight: 200;\n}\n.jumbotron > hr {\n  border-top-color: #d5d5d5;\n}\n.container .jumbotron,\n.container-fluid .jumbotron {\n  border-radius: 6px;\n  padding-left: 15px;\n  padding-right: 15px;\n}\n.jumbotron .container {\n  max-width: 100%;\n}\n@media screen and (min-width: 768px) {\n  .jumbotron {\n    padding-top: 48px;\n    padding-bottom: 48px;\n  }\n  .container .jumbotron,\n  .container-fluid .jumbotron {\n    padding-left: 60px;\n    padding-right: 60px;\n  }\n  .jumbotron h1,\n  .jumbotron .h1 {\n    font-size: 63px;\n  }\n}\n.thumbnail {\n  display: block;\n  padding: 4px;\n  margin-bottom: 20px;\n  line-height: 1.42857143;\n  background-color: #fff;\n  border: 1px solid #ddd;\n  border-radius: 4px;\n  -webkit-transition: border 0.2s ease-in-out;\n  -o-transition: border 0.2s ease-in-out;\n  transition: border 0.2s ease-in-out;\n}\n.thumbnail > img,\n.thumbnail a > img {\n  margin-left: auto;\n  margin-right: auto;\n}\na.thumbnail:hover,\na.thumbnail:focus,\na.thumbnail.active {\n  border-color: #00e5f0;\n}\n.thumbnail .caption {\n  padding: 9px;\n  color: #333333;\n}\n.alert {\n  padding: 15px;\n  margin-bottom: 20px;\n  border: 1px solid transparent;\n  border-radius: 4px;\n}\n.alert h4 {\n  margin-top: 0;\n  color: inherit;\n}\n.alert .alert-link {\n  font-weight: bold;\n}\n.alert > p,\n.alert > ul {\n  margin-bottom: 0;\n}\n.alert > p + p {\n  margin-top: 5px;\n}\n.alert-dismissable,\n.alert-dismissible {\n  padding-right: 35px;\n}\n.alert-dismissable .close,\n.alert-dismissible .close {\n  position: relative;\n  top: -2px;\n  right: -21px;\n  color: inherit;\n}\n.alert-success {\n  background-color: #dff0d8;\n  border-color: #d6e9c6;\n  color: #3c763d;\n}\n.alert-success hr {\n  border-top-color: #c9e2b3;\n}\n.alert-success .alert-link {\n  color: #2b542c;\n}\n.alert-info {\n  background-color: #d9edf7;\n  border-color: #bce8f1;\n  color: #31708f;\n}\n.alert-info hr {\n  border-top-color: #a6e1ec;\n}\n.alert-info .alert-link {\n  color: #245269;\n}\n.alert-warning {\n  background-color: #fcf8e3;\n  border-color: #faebcc;\n  color: #8a6d3b;\n}\n.alert-warning hr {\n  border-top-color: #f7e1b5;\n}\n.alert-warning .alert-link {\n  color: #66512c;\n}\n.alert-danger {\n  background-color: #f2dede;\n  border-color: #ebccd1;\n  color: #a94442;\n}\n.alert-danger hr {\n  border-top-color: #e4b9c0;\n}\n.alert-danger .alert-link {\n  color: #843534;\n}\n@-webkit-keyframes progress-bar-stripes {\n  from {\n    background-position: 40px 0;\n  }\n  to {\n    background-position: 0 0;\n  }\n}\n@keyframes progress-bar-stripes {\n  from {\n    background-position: 40px 0;\n  }\n  to {\n    background-position: 0 0;\n  }\n}\n.progress {\n  overflow: hidden;\n  height: 20px;\n  margin-bottom: 20px;\n  background-color: #f5f5f5;\n  border-radius: 4px;\n  -webkit-box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);\n  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);\n}\n.progress-bar {\n  float: left;\n  width: 0%;\n  height: 100%;\n  font-size: 12px;\n  line-height: 20px;\n  color: #fff;\n  text-align: center;\n  background-color: #00e5f0;\n  -webkit-box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.15);\n  box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.15);\n  -webkit-transition: width 0.6s ease;\n  -o-transition: width 0.6s ease;\n  transition: width 0.6s ease;\n}\n.progress-striped .progress-bar,\n.progress-bar-striped {\n  background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-size: 40px 40px;\n}\n.progress.active .progress-bar,\n.progress-bar.active {\n  -webkit-animation: progress-bar-stripes 2s linear infinite;\n  -o-animation: progress-bar-stripes 2s linear infinite;\n  animation: progress-bar-stripes 2s linear infinite;\n}\n.progress-bar-success {\n  background-color: #00e5f0;\n}\n.progress-striped .progress-bar-success {\n  background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n}\n.progress-bar-info {\n  background-color: #00e5f0;\n}\n.progress-striped .progress-bar-info {\n  background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n}\n.progress-bar-warning {\n  background-color: #977bf0;\n}\n.progress-striped .progress-bar-warning {\n  background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n}\n.progress-bar-danger {\n  background-color: #e01f74;\n}\n.progress-striped .progress-bar-danger {\n  background-image: -webkit-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: -o-linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);\n}\n.media {\n  margin-top: 15px;\n}\n.media:first-child {\n  margin-top: 0;\n}\n.media,\n.media-body {\n  zoom: 1;\n  overflow: hidden;\n}\n.media-body {\n  width: 10000px;\n}\n.media-object {\n  display: block;\n}\n.media-object.img-thumbnail {\n  max-width: none;\n}\n.media-right,\n.media > .pull-right {\n  padding-left: 10px;\n}\n.media-left,\n.media > .pull-left {\n  padding-right: 10px;\n}\n.media-left,\n.media-right,\n.media-body {\n  display: table-cell;\n  vertical-align: top;\n}\n.media-middle {\n  vertical-align: middle;\n}\n.media-bottom {\n  vertical-align: bottom;\n}\n.media-heading {\n  margin-top: 0;\n  margin-bottom: 5px;\n}\n.media-list {\n  padding-left: 0;\n  list-style: none;\n}\n.list-group {\n  margin-bottom: 20px;\n  padding-left: 0;\n}\n.list-group-item {\n  position: relative;\n  display: block;\n  padding: 10px 15px;\n  margin-bottom: -1px;\n  background-color: #fff;\n  border: 1px solid #ddd;\n}\n.list-group-item:first-child {\n  border-top-right-radius: 4px;\n  border-top-left-radius: 4px;\n}\n.list-group-item:last-child {\n  margin-bottom: 0;\n  border-bottom-right-radius: 4px;\n  border-bottom-left-radius: 4px;\n}\na.list-group-item,\nbutton.list-group-item {\n  color: #555;\n}\na.list-group-item .list-group-item-heading,\nbutton.list-group-item .list-group-item-heading {\n  color: #333;\n}\na.list-group-item:hover,\nbutton.list-group-item:hover,\na.list-group-item:focus,\nbutton.list-group-item:focus {\n  text-decoration: none;\n  color: #555;\n  background-color: #f5f5f5;\n}\nbutton.list-group-item {\n  width: 100%;\n  text-align: left;\n}\n.list-group-item.disabled,\n.list-group-item.disabled:hover,\n.list-group-item.disabled:focus {\n  background-color: #eeeeee;\n  color: #777777;\n  cursor: not-allowed;\n}\n.list-group-item.disabled .list-group-item-heading,\n.list-group-item.disabled:hover .list-group-item-heading,\n.list-group-item.disabled:focus .list-group-item-heading {\n  color: inherit;\n}\n.list-group-item.disabled .list-group-item-text,\n.list-group-item.disabled:hover .list-group-item-text,\n.list-group-item.disabled:focus .list-group-item-text {\n  color: #777777;\n}\n.list-group-item.active,\n.list-group-item.active:hover,\n.list-group-item.active:focus {\n  z-index: 2;\n  color: #fff;\n  background-color: #00e5f0;\n  border-color: #00e5f0;\n}\n.list-group-item.active .list-group-item-heading,\n.list-group-item.active:hover .list-group-item-heading,\n.list-group-item.active:focus .list-group-item-heading,\n.list-group-item.active .list-group-item-heading > small,\n.list-group-item.active:hover .list-group-item-heading > small,\n.list-group-item.active:focus .list-group-item-heading > small,\n.list-group-item.active .list-group-item-heading > .small,\n.list-group-item.active:hover .list-group-item-heading > .small,\n.list-group-item.active:focus .list-group-item-heading > .small {\n  color: inherit;\n}\n.list-group-item.active .list-group-item-text,\n.list-group-item.active:hover .list-group-item-text,\n.list-group-item.active:focus .list-group-item-text {\n  color: #bdfcff;\n}\n.list-group-item-success {\n  color: #3c763d;\n  background-color: #dff0d8;\n}\na.list-group-item-success,\nbutton.list-group-item-success {\n  color: #3c763d;\n}\na.list-group-item-success .list-group-item-heading,\nbutton.list-group-item-success .list-group-item-heading {\n  color: inherit;\n}\na.list-group-item-success:hover,\nbutton.list-group-item-success:hover,\na.list-group-item-success:focus,\nbutton.list-group-item-success:focus {\n  color: #3c763d;\n  background-color: #d0e9c6;\n}\na.list-group-item-success.active,\nbutton.list-group-item-success.active,\na.list-group-item-success.active:hover,\nbutton.list-group-item-success.active:hover,\na.list-group-item-success.active:focus,\nbutton.list-group-item-success.active:focus {\n  color: #fff;\n  background-color: #3c763d;\n  border-color: #3c763d;\n}\n.list-group-item-info {\n  color: #31708f;\n  background-color: #d9edf7;\n}\na.list-group-item-info,\nbutton.list-group-item-info {\n  color: #31708f;\n}\na.list-group-item-info .list-group-item-heading,\nbutton.list-group-item-info .list-group-item-heading {\n  color: inherit;\n}\na.list-group-item-info:hover,\nbutton.list-group-item-info:hover,\na.list-group-item-info:focus,\nbutton.list-group-item-info:focus {\n  color: #31708f;\n  background-color: #c4e3f3;\n}\na.list-group-item-info.active,\nbutton.list-group-item-info.active,\na.list-group-item-info.active:hover,\nbutton.list-group-item-info.active:hover,\na.list-group-item-info.active:focus,\nbutton.list-group-item-info.active:focus {\n  color: #fff;\n  background-color: #31708f;\n  border-color: #31708f;\n}\n.list-group-item-warning {\n  color: #8a6d3b;\n  background-color: #fcf8e3;\n}\na.list-group-item-warning,\nbutton.list-group-item-warning {\n  color: #8a6d3b;\n}\na.list-group-item-warning .list-group-item-heading,\nbutton.list-group-item-warning .list-group-item-heading {\n  color: inherit;\n}\na.list-group-item-warning:hover,\nbutton.list-group-item-warning:hover,\na.list-group-item-warning:focus,\nbutton.list-group-item-warning:focus {\n  color: #8a6d3b;\n  background-color: #faf2cc;\n}\na.list-group-item-warning.active,\nbutton.list-group-item-warning.active,\na.list-group-item-warning.active:hover,\nbutton.list-group-item-warning.active:hover,\na.list-group-item-warning.active:focus,\nbutton.list-group-item-warning.active:focus {\n  color: #fff;\n  background-color: #8a6d3b;\n  border-color: #8a6d3b;\n}\n.list-group-item-danger {\n  color: #a94442;\n  background-color: #f2dede;\n}\na.list-group-item-danger,\nbutton.list-group-item-danger {\n  color: #a94442;\n}\na.list-group-item-danger .list-group-item-heading,\nbutton.list-group-item-danger .list-group-item-heading {\n  color: inherit;\n}\na.list-group-item-danger:hover,\nbutton.list-group-item-danger:hover,\na.list-group-item-danger:focus,\nbutton.list-group-item-danger:focus {\n  color: #a94442;\n  background-color: #ebcccc;\n}\na.list-group-item-danger.active,\nbutton.list-group-item-danger.active,\na.list-group-item-danger.active:hover,\nbutton.list-group-item-danger.active:hover,\na.list-group-item-danger.active:focus,\nbutton.list-group-item-danger.active:focus {\n  color: #fff;\n  background-color: #a94442;\n  border-color: #a94442;\n}\n.list-group-item-heading {\n  margin-top: 0;\n  margin-bottom: 5px;\n}\n.list-group-item-text {\n  margin-bottom: 0;\n  line-height: 1.3;\n}\n.panel {\n  margin-bottom: 20px;\n  background-color: #fff;\n  border: 1px solid transparent;\n  border-radius: 4px;\n  -webkit-box-shadow: 0 1px 1px rgba(0, 0, 0, 0.05);\n  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.05);\n}\n.panel-body {\n  padding: 15px;\n}\n.panel-heading {\n  padding: 10px 15px;\n  border-bottom: 1px solid transparent;\n  border-top-right-radius: 3px;\n  border-top-left-radius: 3px;\n}\n.panel-heading > .dropdown .dropdown-toggle {\n  color: inherit;\n}\n.panel-title {\n  margin-top: 0;\n  margin-bottom: 0;\n  font-size: 16px;\n  color: inherit;\n}\n.panel-title > a,\n.panel-title > small,\n.panel-title > .small,\n.panel-title > small > a,\n.panel-title > .small > a {\n  color: inherit;\n}\n.panel-footer {\n  padding: 10px 15px;\n  background-color: #f5f5f5;\n  border-top: 1px solid #ddd;\n  border-bottom-right-radius: 3px;\n  border-bottom-left-radius: 3px;\n}\n.panel > .list-group,\n.panel > .panel-collapse > .list-group {\n  margin-bottom: 0;\n}\n.panel > .list-group .list-group-item,\n.panel > .panel-collapse > .list-group .list-group-item {\n  border-width: 1px 0;\n  border-radius: 0;\n}\n.panel > .list-group:first-child .list-group-item:first-child,\n.panel > .panel-collapse > .list-group:first-child .list-group-item:first-child {\n  border-top: 0;\n  border-top-right-radius: 3px;\n  border-top-left-radius: 3px;\n}\n.panel > .list-group:last-child .list-group-item:last-child,\n.panel > .panel-collapse > .list-group:last-child .list-group-item:last-child {\n  border-bottom: 0;\n  border-bottom-right-radius: 3px;\n  border-bottom-left-radius: 3px;\n}\n.panel > .panel-heading + .panel-collapse > .list-group .list-group-item:first-child {\n  border-top-right-radius: 0;\n  border-top-left-radius: 0;\n}\n.panel-heading + .list-group .list-group-item:first-child {\n  border-top-width: 0;\n}\n.list-group + .panel-footer {\n  border-top-width: 0;\n}\n.panel > .table,\n.panel > .table-responsive > .table,\n.panel > .panel-collapse > .table {\n  margin-bottom: 0;\n}\n.panel > .table caption,\n.panel > .table-responsive > .table caption,\n.panel > .panel-collapse > .table caption {\n  padding-left: 15px;\n  padding-right: 15px;\n}\n.panel > .table:first-child,\n.panel > .table-responsive:first-child > .table:first-child {\n  border-top-right-radius: 3px;\n  border-top-left-radius: 3px;\n}\n.panel > .table:first-child > thead:first-child > tr:first-child,\n.panel > .table-responsive:first-child > .table:first-child > thead:first-child > tr:first-child,\n.panel > .table:first-child > tbody:first-child > tr:first-child,\n.panel > .table-responsive:first-child > .table:first-child > tbody:first-child > tr:first-child {\n  border-top-left-radius: 3px;\n  border-top-right-radius: 3px;\n}\n.panel > .table:first-child > thead:first-child > tr:first-child td:first-child,\n.panel > .table-responsive:first-child > .table:first-child > thead:first-child > tr:first-child td:first-child,\n.panel > .table:first-child > tbody:first-child > tr:first-child td:first-child,\n.panel > .table-responsive:first-child > .table:first-child > tbody:first-child > tr:first-child td:first-child,\n.panel > .table:first-child > thead:first-child > tr:first-child th:first-child,\n.panel > .table-responsive:first-child > .table:first-child > thead:first-child > tr:first-child th:first-child,\n.panel > .table:first-child > tbody:first-child > tr:first-child th:first-child,\n.panel > .table-responsive:first-child > .table:first-child > tbody:first-child > tr:first-child th:first-child {\n  border-top-left-radius: 3px;\n}\n.panel > .table:first-child > thead:first-child > tr:first-child td:last-child,\n.panel > .table-responsive:first-child > .table:first-child > thead:first-child > tr:first-child td:last-child,\n.panel > .table:first-child > tbody:first-child > tr:first-child td:last-child,\n.panel > .table-responsive:first-child > .table:first-child > tbody:first-child > tr:first-child td:last-child,\n.panel > .table:first-child > thead:first-child > tr:first-child th:last-child,\n.panel > .table-responsive:first-child > .table:first-child > thead:first-child > tr:first-child th:last-child,\n.panel > .table:first-child > tbody:first-child > tr:first-child th:last-child,\n.panel > .table-responsive:first-child > .table:first-child > tbody:first-child > tr:first-child th:last-child {\n  border-top-right-radius: 3px;\n}\n.panel > .table:last-child,\n.panel > .table-responsive:last-child > .table:last-child {\n  border-bottom-right-radius: 3px;\n  border-bottom-left-radius: 3px;\n}\n.panel > .table:last-child > tbody:last-child > tr:last-child,\n.panel > .table-responsive:last-child > .table:last-child > tbody:last-child > tr:last-child,\n.panel > .table:last-child > tfoot:last-child > tr:last-child,\n.panel > .table-responsive:last-child > .table:last-child > tfoot:last-child > tr:last-child {\n  border-bottom-left-radius: 3px;\n  border-bottom-right-radius: 3px;\n}\n.panel > .table:last-child > tbody:last-child > tr:last-child td:first-child,\n.panel > .table-responsive:last-child > .table:last-child > tbody:last-child > tr:last-child td:first-child,\n.panel > .table:last-child > tfoot:last-child > tr:last-child td:first-child,\n.panel > .table-responsive:last-child > .table:last-child > tfoot:last-child > tr:last-child td:first-child,\n.panel > .table:last-child > tbody:last-child > tr:last-child th:first-child,\n.panel > .table-responsive:last-child > .table:last-child > tbody:last-child > tr:last-child th:first-child,\n.panel > .table:last-child > tfoot:last-child > tr:last-child th:first-child,\n.panel > .table-responsive:last-child > .table:last-child > tfoot:last-child > tr:last-child th:first-child {\n  border-bottom-left-radius: 3px;\n}\n.panel > .table:last-child > tbody:last-child > tr:last-child td:last-child,\n.panel > .table-responsive:last-child > .table:last-child > tbody:last-child > tr:last-child td:last-child,\n.panel > .table:last-child > tfoot:last-child > tr:last-child td:last-child,\n.panel > .table-responsive:last-child > .table:last-child > tfoot:last-child > tr:last-child td:last-child,\n.panel > .table:last-child > tbody:last-child > tr:last-child th:last-child,\n.panel > .table-responsive:last-child > .table:last-child > tbody:last-child > tr:last-child th:last-child,\n.panel > .table:last-child > tfoot:last-child > tr:last-child th:last-child,\n.panel > .table-responsive:last-child > .table:last-child > tfoot:last-child > tr:last-child th:last-child {\n  border-bottom-right-radius: 3px;\n}\n.panel > .panel-body + .table,\n.panel > .panel-body + .table-responsive,\n.panel > .table + .panel-body,\n.panel > .table-responsive + .panel-body {\n  border-top: 1px solid #ddd;\n}\n.panel > .table > tbody:first-child > tr:first-child th,\n.panel > .table > tbody:first-child > tr:first-child td {\n  border-top: 0;\n}\n.panel > .table-bordered,\n.panel > .table-responsive > .table-bordered {\n  border: 0;\n}\n.panel > .table-bordered > thead > tr > th:first-child,\n.panel > .table-responsive > .table-bordered > thead > tr > th:first-child,\n.panel > .table-bordered > tbody > tr > th:first-child,\n.panel > .table-responsive > .table-bordered > tbody > tr > th:first-child,\n.panel > .table-bordered > tfoot > tr > th:first-child,\n.panel > .table-responsive > .table-bordered > tfoot > tr > th:first-child,\n.panel > .table-bordered > thead > tr > td:first-child,\n.panel > .table-responsive > .table-bordered > thead > tr > td:first-child,\n.panel > .table-bordered > tbody > tr > td:first-child,\n.panel > .table-responsive > .table-bordered > tbody > tr > td:first-child,\n.panel > .table-bordered > tfoot > tr > td:first-child,\n.panel > .table-responsive > .table-bordered > tfoot > tr > td:first-child {\n  border-left: 0;\n}\n.panel > .table-bordered > thead > tr > th:last-child,\n.panel > .table-responsive > .table-bordered > thead > tr > th:last-child,\n.panel > .table-bordered > tbody > tr > th:last-child,\n.panel > .table-responsive > .table-bordered > tbody > tr > th:last-child,\n.panel > .table-bordered > tfoot > tr > th:last-child,\n.panel > .table-responsive > .table-bordered > tfoot > tr > th:last-child,\n.panel > .table-bordered > thead > tr > td:last-child,\n.panel > .table-responsive > .table-bordered > thead > tr > td:last-child,\n.panel > .table-bordered > tbody > tr > td:last-child,\n.panel > .table-responsive > .table-bordered > tbody > tr > td:last-child,\n.panel > .table-bordered > tfoot > tr > td:last-child,\n.panel > .table-responsive > .table-bordered > tfoot > tr > td:last-child {\n  border-right: 0;\n}\n.panel > .table-bordered > thead > tr:first-child > td,\n.panel > .table-responsive > .table-bordered > thead > tr:first-child > td,\n.panel > .table-bordered > tbody > tr:first-child > td,\n.panel > .table-responsive > .table-bordered > tbody > tr:first-child > td,\n.panel > .table-bordered > thead > tr:first-child > th,\n.panel > .table-responsive > .table-bordered > thead > tr:first-child > th,\n.panel > .table-bordered > tbody > tr:first-child > th,\n.panel > .table-responsive > .table-bordered > tbody > tr:first-child > th {\n  border-bottom: 0;\n}\n.panel > .table-bordered > tbody > tr:last-child > td,\n.panel > .table-responsive > .table-bordered > tbody > tr:last-child > td,\n.panel > .table-bordered > tfoot > tr:last-child > td,\n.panel > .table-responsive > .table-bordered > tfoot > tr:last-child > td,\n.panel > .table-bordered > tbody > tr:last-child > th,\n.panel > .table-responsive > .table-bordered > tbody > tr:last-child > th,\n.panel > .table-bordered > tfoot > tr:last-child > th,\n.panel > .table-responsive > .table-bordered > tfoot > tr:last-child > th {\n  border-bottom: 0;\n}\n.panel > .table-responsive {\n  border: 0;\n  margin-bottom: 0;\n}\n.panel-group {\n  margin-bottom: 20px;\n}\n.panel-group .panel {\n  margin-bottom: 0;\n  border-radius: 4px;\n}\n.panel-group .panel + .panel {\n  margin-top: 5px;\n}\n.panel-group .panel-heading {\n  border-bottom: 0;\n}\n.panel-group .panel-heading + .panel-collapse > .panel-body,\n.panel-group .panel-heading + .panel-collapse > .list-group {\n  border-top: 1px solid #ddd;\n}\n.panel-group .panel-footer {\n  border-top: 0;\n}\n.panel-group .panel-footer + .panel-collapse .panel-body {\n  border-bottom: 1px solid #ddd;\n}\n.panel-default {\n  border-color: #ddd;\n}\n.panel-default > .panel-heading {\n  color: #333333;\n  background-color: #f5f5f5;\n  border-color: #ddd;\n}\n.panel-default > .panel-heading + .panel-collapse > .panel-body {\n  border-top-color: #ddd;\n}\n.panel-default > .panel-heading .badge {\n  color: #f5f5f5;\n  background-color: #333333;\n}\n.panel-default > .panel-footer + .panel-collapse > .panel-body {\n  border-bottom-color: #ddd;\n}\n.panel-primary {\n  border-color: #00e5f0;\n}\n.panel-primary > .panel-heading {\n  color: #fff;\n  background-color: #00e5f0;\n  border-color: #00e5f0;\n}\n.panel-primary > .panel-heading + .panel-collapse > .panel-body {\n  border-top-color: #00e5f0;\n}\n.panel-primary > .panel-heading .badge {\n  color: #00e5f0;\n  background-color: #fff;\n}\n.panel-primary > .panel-footer + .panel-collapse > .panel-body {\n  border-bottom-color: #00e5f0;\n}\n.panel-success {\n  border-color: #d6e9c6;\n}\n.panel-success > .panel-heading {\n  color: #3c763d;\n  background-color: #dff0d8;\n  border-color: #d6e9c6;\n}\n.panel-success > .panel-heading + .panel-collapse > .panel-body {\n  border-top-color: #d6e9c6;\n}\n.panel-success > .panel-heading .badge {\n  color: #dff0d8;\n  background-color: #3c763d;\n}\n.panel-success > .panel-footer + .panel-collapse > .panel-body {\n  border-bottom-color: #d6e9c6;\n}\n.panel-info {\n  border-color: #bce8f1;\n}\n.panel-info > .panel-heading {\n  color: #31708f;\n  background-color: #d9edf7;\n  border-color: #bce8f1;\n}\n.panel-info > .panel-heading + .panel-collapse > .panel-body {\n  border-top-color: #bce8f1;\n}\n.panel-info > .panel-heading .badge {\n  color: #d9edf7;\n  background-color: #31708f;\n}\n.panel-info > .panel-footer + .panel-collapse > .panel-body {\n  border-bottom-color: #bce8f1;\n}\n.panel-warning {\n  border-color: #faebcc;\n}\n.panel-warning > .panel-heading {\n  color: #8a6d3b;\n  background-color: #fcf8e3;\n  border-color: #faebcc;\n}\n.panel-warning > .panel-heading + .panel-collapse > .panel-body {\n  border-top-color: #faebcc;\n}\n.panel-warning > .panel-heading .badge {\n  color: #fcf8e3;\n  background-color: #8a6d3b;\n}\n.panel-warning > .panel-footer + .panel-collapse > .panel-body {\n  border-bottom-color: #faebcc;\n}\n.panel-danger {\n  border-color: #ebccd1;\n}\n.panel-danger > .panel-heading {\n  color: #a94442;\n  background-color: #f2dede;\n  border-color: #ebccd1;\n}\n.panel-danger > .panel-heading + .panel-collapse > .panel-body {\n  border-top-color: #ebccd1;\n}\n.panel-danger > .panel-heading .badge {\n  color: #f2dede;\n  background-color: #a94442;\n}\n.panel-danger > .panel-footer + .panel-collapse > .panel-body {\n  border-bottom-color: #ebccd1;\n}\n.embed-responsive {\n  position: relative;\n  display: block;\n  height: 0;\n  padding: 0;\n  overflow: hidden;\n}\n.embed-responsive .embed-responsive-item,\n.embed-responsive iframe,\n.embed-responsive embed,\n.embed-responsive object,\n.embed-responsive video {\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  height: 100%;\n  width: 100%;\n  border: 0;\n}\n.embed-responsive-16by9 {\n  padding-bottom: 56.25%;\n}\n.embed-responsive-4by3 {\n  padding-bottom: 75%;\n}\n.well {\n  min-height: 20px;\n  padding: 19px;\n  margin-bottom: 20px;\n  background-color: #f5f5f5;\n  border: 1px solid #e3e3e3;\n  border-radius: 4px;\n  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05);\n  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05);\n}\n.well blockquote {\n  border-color: #ddd;\n  border-color: rgba(0, 0, 0, 0.15);\n}\n.well-lg {\n  padding: 24px;\n  border-radius: 6px;\n}\n.well-sm {\n  padding: 9px;\n  border-radius: 3px;\n}\n.close {\n  float: right;\n  font-size: 21px;\n  font-weight: bold;\n  line-height: 1;\n  color: #000;\n  text-shadow: 0 1px 0 #fff;\n  opacity: 0.2;\n  filter: alpha(opacity=20);\n}\n.close:hover,\n.close:focus {\n  color: #000;\n  text-decoration: none;\n  cursor: pointer;\n  opacity: 0.5;\n  filter: alpha(opacity=50);\n}\nbutton.close {\n  padding: 0;\n  cursor: pointer;\n  background: transparent;\n  border: 0;\n  -webkit-appearance: none;\n}\n.modal-open {\n  overflow: hidden;\n}\n.modal {\n  display: none;\n  overflow: hidden;\n  position: fixed;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: 1050;\n  -webkit-overflow-scrolling: touch;\n  outline: 0;\n}\n.modal.fade .modal-dialog {\n  -webkit-transform: translate(0, -25%);\n  -ms-transform: translate(0, -25%);\n  -o-transform: translate(0, -25%);\n  transform: translate(0, -25%);\n  -webkit-transition: -webkit-transform 0.3s ease-out;\n  -moz-transition: -moz-transform 0.3s ease-out;\n  -o-transition: -o-transform 0.3s ease-out;\n  transition: transform 0.3s ease-out;\n}\n.modal.in .modal-dialog {\n  -webkit-transform: translate(0, 0);\n  -ms-transform: translate(0, 0);\n  -o-transform: translate(0, 0);\n  transform: translate(0, 0);\n}\n.modal-open .modal {\n  overflow-x: hidden;\n  overflow-y: auto;\n}\n.modal-dialog {\n  position: relative;\n  width: auto;\n  margin: 10px;\n}\n.modal-content {\n  position: relative;\n  background-color: #fff;\n  border: 1px solid #999;\n  border: 1px solid rgba(0, 0, 0, 0.2);\n  border-radius: 6px;\n  -webkit-box-shadow: 0 3px 9px rgba(0, 0, 0, 0.5);\n  box-shadow: 0 3px 9px rgba(0, 0, 0, 0.5);\n  background-clip: padding-box;\n  outline: 0;\n}\n.modal-backdrop {\n  position: fixed;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: 1040;\n  background-color: #000;\n}\n.modal-backdrop.fade {\n  opacity: 0;\n  filter: alpha(opacity=0);\n}\n.modal-backdrop.in {\n  opacity: 0.5;\n  filter: alpha(opacity=50);\n}\n.modal-header {\n  padding: 15px;\n  border-bottom: 1px solid #e5e5e5;\n}\n.modal-header .close {\n  margin-top: -2px;\n}\n.modal-title {\n  margin: 0;\n  line-height: 1.42857143;\n}\n.modal-body {\n  position: relative;\n  padding: 15px;\n}\n.modal-footer {\n  padding: 15px;\n  text-align: right;\n  border-top: 1px solid #e5e5e5;\n}\n.modal-footer .btn + .btn {\n  margin-left: 5px;\n  margin-bottom: 0;\n}\n.modal-footer .btn-group .btn + .btn {\n  margin-left: -1px;\n}\n.modal-footer .btn-block + .btn-block {\n  margin-left: 0;\n}\n.modal-scrollbar-measure {\n  position: absolute;\n  top: -9999px;\n  width: 50px;\n  height: 50px;\n  overflow: scroll;\n}\n@media (min-width: 768px) {\n  .modal-dialog {\n    width: 600px;\n    margin: 30px auto;\n  }\n  .modal-content {\n    -webkit-box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5);\n    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5);\n  }\n  .modal-sm {\n    width: 300px;\n  }\n}\n@media (min-width: 992px) {\n  .modal-lg {\n    width: 900px;\n  }\n}\n.tooltip {\n  position: absolute;\n  z-index: 1070;\n  display: block;\n  font-family: \"Helvetica Neue\", Helvetica, Arial, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  letter-spacing: normal;\n  line-break: auto;\n  line-height: 1.42857143;\n  text-align: left;\n  text-align: start;\n  text-decoration: none;\n  text-shadow: none;\n  text-transform: none;\n  white-space: normal;\n  word-break: normal;\n  word-spacing: normal;\n  word-wrap: normal;\n  font-size: 12px;\n  opacity: 0;\n  filter: alpha(opacity=0);\n}\n.tooltip.in {\n  opacity: 0.9;\n  filter: alpha(opacity=90);\n}\n.tooltip.top {\n  margin-top: -3px;\n  padding: 5px 0;\n}\n.tooltip.right {\n  margin-left: 3px;\n  padding: 0 5px;\n}\n.tooltip.bottom {\n  margin-top: 3px;\n  padding: 5px 0;\n}\n.tooltip.left {\n  margin-left: -3px;\n  padding: 0 5px;\n}\n.tooltip-inner {\n  max-width: 200px;\n  padding: 3px 8px;\n  color: #fff;\n  text-align: center;\n  background-color: #000;\n  border-radius: 4px;\n}\n.tooltip-arrow {\n  position: absolute;\n  width: 0;\n  height: 0;\n  border-color: transparent;\n  border-style: solid;\n}\n.tooltip.top .tooltip-arrow {\n  bottom: 0;\n  left: 50%;\n  margin-left: -5px;\n  border-width: 5px 5px 0;\n  border-top-color: #000;\n}\n.tooltip.top-left .tooltip-arrow {\n  bottom: 0;\n  right: 5px;\n  margin-bottom: -5px;\n  border-width: 5px 5px 0;\n  border-top-color: #000;\n}\n.tooltip.top-right .tooltip-arrow {\n  bottom: 0;\n  left: 5px;\n  margin-bottom: -5px;\n  border-width: 5px 5px 0;\n  border-top-color: #000;\n}\n.tooltip.right .tooltip-arrow {\n  top: 50%;\n  left: 0;\n  margin-top: -5px;\n  border-width: 5px 5px 5px 0;\n  border-right-color: #000;\n}\n.tooltip.left .tooltip-arrow {\n  top: 50%;\n  right: 0;\n  margin-top: -5px;\n  border-width: 5px 0 5px 5px;\n  border-left-color: #000;\n}\n.tooltip.bottom .tooltip-arrow {\n  top: 0;\n  left: 50%;\n  margin-left: -5px;\n  border-width: 0 5px 5px;\n  border-bottom-color: #000;\n}\n.tooltip.bottom-left .tooltip-arrow {\n  top: 0;\n  right: 5px;\n  margin-top: -5px;\n  border-width: 0 5px 5px;\n  border-bottom-color: #000;\n}\n.tooltip.bottom-right .tooltip-arrow {\n  top: 0;\n  left: 5px;\n  margin-top: -5px;\n  border-width: 0 5px 5px;\n  border-bottom-color: #000;\n}\n.popover {\n  position: absolute;\n  top: 0;\n  left: 0;\n  z-index: 1060;\n  display: none;\n  max-width: 276px;\n  padding: 1px;\n  font-family: \"Helvetica Neue\", Helvetica, Arial, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  letter-spacing: normal;\n  line-break: auto;\n  line-height: 1.42857143;\n  text-align: left;\n  text-align: start;\n  text-decoration: none;\n  text-shadow: none;\n  text-transform: none;\n  white-space: normal;\n  word-break: normal;\n  word-spacing: normal;\n  word-wrap: normal;\n  font-size: 14px;\n  background-color: #fff;\n  background-clip: padding-box;\n  border: 1px solid #ccc;\n  border: 1px solid rgba(0, 0, 0, 0.2);\n  border-radius: 6px;\n  -webkit-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);\n  box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);\n}\n.popover.top {\n  margin-top: -10px;\n}\n.popover.right {\n  margin-left: 10px;\n}\n.popover.bottom {\n  margin-top: 10px;\n}\n.popover.left {\n  margin-left: -10px;\n}\n.popover-title {\n  margin: 0;\n  padding: 8px 14px;\n  font-size: 14px;\n  background-color: #f7f7f7;\n  border-bottom: 1px solid #ebebeb;\n  border-radius: 5px 5px 0 0;\n}\n.popover-content {\n  padding: 9px 14px;\n}\n.popover > .arrow,\n.popover > .arrow:after {\n  position: absolute;\n  display: block;\n  width: 0;\n  height: 0;\n  border-color: transparent;\n  border-style: solid;\n}\n.popover > .arrow {\n  border-width: 11px;\n}\n.popover > .arrow:after {\n  border-width: 10px;\n  content: \"\";\n}\n.popover.top > .arrow {\n  left: 50%;\n  margin-left: -11px;\n  border-bottom-width: 0;\n  border-top-color: #999999;\n  border-top-color: rgba(0, 0, 0, 0.25);\n  bottom: -11px;\n}\n.popover.top > .arrow:after {\n  content: \" \";\n  bottom: 1px;\n  margin-left: -10px;\n  border-bottom-width: 0;\n  border-top-color: #fff;\n}\n.popover.right > .arrow {\n  top: 50%;\n  left: -11px;\n  margin-top: -11px;\n  border-left-width: 0;\n  border-right-color: #999999;\n  border-right-color: rgba(0, 0, 0, 0.25);\n}\n.popover.right > .arrow:after {\n  content: \" \";\n  left: 1px;\n  bottom: -10px;\n  border-left-width: 0;\n  border-right-color: #fff;\n}\n.popover.bottom > .arrow {\n  left: 50%;\n  margin-left: -11px;\n  border-top-width: 0;\n  border-bottom-color: #999999;\n  border-bottom-color: rgba(0, 0, 0, 0.25);\n  top: -11px;\n}\n.popover.bottom > .arrow:after {\n  content: \" \";\n  top: 1px;\n  margin-left: -10px;\n  border-top-width: 0;\n  border-bottom-color: #fff;\n}\n.popover.left > .arrow {\n  top: 50%;\n  right: -11px;\n  margin-top: -11px;\n  border-right-width: 0;\n  border-left-color: #999999;\n  border-left-color: rgba(0, 0, 0, 0.25);\n}\n.popover.left > .arrow:after {\n  content: \" \";\n  right: 1px;\n  border-right-width: 0;\n  border-left-color: #fff;\n  bottom: -10px;\n}\n.carousel {\n  position: relative;\n}\n.carousel-inner {\n  position: relative;\n  overflow: hidden;\n  width: 100%;\n}\n.carousel-inner > .item {\n  display: none;\n  position: relative;\n  -webkit-transition: 0.6s ease-in-out left;\n  -o-transition: 0.6s ease-in-out left;\n  transition: 0.6s ease-in-out left;\n}\n.carousel-inner > .item > img,\n.carousel-inner > .item > a > img {\n  line-height: 1;\n}\n@media all and (transform-3d), (-webkit-transform-3d) {\n  .carousel-inner > .item {\n    -webkit-transition: -webkit-transform 0.6s ease-in-out;\n    -moz-transition: -moz-transform 0.6s ease-in-out;\n    -o-transition: -o-transform 0.6s ease-in-out;\n    transition: transform 0.6s ease-in-out;\n    -webkit-backface-visibility: hidden;\n    -moz-backface-visibility: hidden;\n    backface-visibility: hidden;\n    -webkit-perspective: 1000px;\n    -moz-perspective: 1000px;\n    perspective: 1000px;\n  }\n  .carousel-inner > .item.next,\n  .carousel-inner > .item.active.right {\n    -webkit-transform: translate3d(100%, 0, 0);\n    transform: translate3d(100%, 0, 0);\n    left: 0;\n  }\n  .carousel-inner > .item.prev,\n  .carousel-inner > .item.active.left {\n    -webkit-transform: translate3d(-100%, 0, 0);\n    transform: translate3d(-100%, 0, 0);\n    left: 0;\n  }\n  .carousel-inner > .item.next.left,\n  .carousel-inner > .item.prev.right,\n  .carousel-inner > .item.active {\n    -webkit-transform: translate3d(0, 0, 0);\n    transform: translate3d(0, 0, 0);\n    left: 0;\n  }\n}\n.carousel-inner > .active,\n.carousel-inner > .next,\n.carousel-inner > .prev {\n  display: block;\n}\n.carousel-inner > .active {\n  left: 0;\n}\n.carousel-inner > .next,\n.carousel-inner > .prev {\n  position: absolute;\n  top: 0;\n  width: 100%;\n}\n.carousel-inner > .next {\n  left: 100%;\n}\n.carousel-inner > .prev {\n  left: -100%;\n}\n.carousel-inner > .next.left,\n.carousel-inner > .prev.right {\n  left: 0;\n}\n.carousel-inner > .active.left {\n  left: -100%;\n}\n.carousel-inner > .active.right {\n  left: 100%;\n}\n.carousel-control {\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  width: 15%;\n  opacity: 0.5;\n  filter: alpha(opacity=50);\n  font-size: 20px;\n  color: #fff;\n  text-align: center;\n  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);\n  background-color: rgba(0, 0, 0, 0);\n}\n.carousel-control.left {\n  background-image: -webkit-linear-gradient(left, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.0001) 100%);\n  background-image: -o-linear-gradient(left, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.0001) 100%);\n  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.0001) 100%);\n  background-repeat: repeat-x;\n  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#80000000', endColorstr='#00000000', GradientType=1);\n}\n.carousel-control.right {\n  left: auto;\n  right: 0;\n  background-image: -webkit-linear-gradient(left, rgba(0, 0, 0, 0.0001) 0%, rgba(0, 0, 0, 0.5) 100%);\n  background-image: -o-linear-gradient(left, rgba(0, 0, 0, 0.0001) 0%, rgba(0, 0, 0, 0.5) 100%);\n  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.0001) 0%, rgba(0, 0, 0, 0.5) 100%);\n  background-repeat: repeat-x;\n  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000', endColorstr='#80000000', GradientType=1);\n}\n.carousel-control:hover,\n.carousel-control:focus {\n  outline: 0;\n  color: #fff;\n  text-decoration: none;\n  opacity: 0.9;\n  filter: alpha(opacity=90);\n}\n.carousel-control .icon-prev,\n.carousel-control .icon-next,\n.carousel-control .glyphicon-chevron-left,\n.carousel-control .glyphicon-chevron-right {\n  position: absolute;\n  top: 50%;\n  margin-top: -10px;\n  z-index: 5;\n  display: inline-block;\n}\n.carousel-control .icon-prev,\n.carousel-control .glyphicon-chevron-left {\n  left: 50%;\n  margin-left: -10px;\n}\n.carousel-control .icon-next,\n.carousel-control .glyphicon-chevron-right {\n  right: 50%;\n  margin-right: -10px;\n}\n.carousel-control .icon-prev,\n.carousel-control .icon-next {\n  width: 20px;\n  height: 20px;\n  line-height: 1;\n  font-family: serif;\n}\n.carousel-control .icon-prev:before {\n  content: '\\2039';\n}\n.carousel-control .icon-next:before {\n  content: '\\203a';\n}\n.carousel-indicators {\n  position: absolute;\n  bottom: 10px;\n  left: 50%;\n  z-index: 15;\n  width: 60%;\n  margin-left: -30%;\n  padding-left: 0;\n  list-style: none;\n  text-align: center;\n}\n.carousel-indicators li {\n  display: inline-block;\n  width: 10px;\n  height: 10px;\n  margin: 1px;\n  text-indent: -999px;\n  border: 1px solid #fff;\n  border-radius: 10px;\n  cursor: pointer;\n  background-color: #000 \\9;\n  background-color: rgba(0, 0, 0, 0);\n}\n.carousel-indicators .active {\n  margin: 0;\n  width: 12px;\n  height: 12px;\n  background-color: #fff;\n}\n.carousel-caption {\n  position: absolute;\n  left: 15%;\n  right: 15%;\n  bottom: 20px;\n  z-index: 10;\n  padding-top: 20px;\n  padding-bottom: 20px;\n  color: #fff;\n  text-align: center;\n  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);\n}\n.carousel-caption .btn {\n  text-shadow: none;\n}\n@media screen and (min-width: 768px) {\n  .carousel-control .glyphicon-chevron-left,\n  .carousel-control .glyphicon-chevron-right,\n  .carousel-control .icon-prev,\n  .carousel-control .icon-next {\n    width: 30px;\n    height: 30px;\n    margin-top: -10px;\n    font-size: 30px;\n  }\n  .carousel-control .glyphicon-chevron-left,\n  .carousel-control .icon-prev {\n    margin-left: -10px;\n  }\n  .carousel-control .glyphicon-chevron-right,\n  .carousel-control .icon-next {\n    margin-right: -10px;\n  }\n  .carousel-caption {\n    left: 20%;\n    right: 20%;\n    padding-bottom: 30px;\n  }\n  .carousel-indicators {\n    bottom: 20px;\n  }\n}\n.clearfix:before,\n.clearfix:after,\n.dl-horizontal dd:before,\n.dl-horizontal dd:after,\n.container:before,\n.container:after,\n.container-fluid:before,\n.container-fluid:after,\n.row:before,\n.row:after,\n.form-horizontal .form-group:before,\n.form-horizontal .form-group:after,\n.btn-toolbar:before,\n.btn-toolbar:after,\n.btn-group-vertical > .btn-group:before,\n.btn-group-vertical > .btn-group:after,\n.nav:before,\n.nav:after,\n.navbar:before,\n.navbar:after,\n.navbar-header:before,\n.navbar-header:after,\n.navbar-collapse:before,\n.navbar-collapse:after,\n.pager:before,\n.pager:after,\n.panel-body:before,\n.panel-body:after,\n.modal-header:before,\n.modal-header:after,\n.modal-footer:before,\n.modal-footer:after {\n  content: \" \";\n  display: table;\n}\n.clearfix:after,\n.dl-horizontal dd:after,\n.container:after,\n.container-fluid:after,\n.row:after,\n.form-horizontal .form-group:after,\n.btn-toolbar:after,\n.btn-group-vertical > .btn-group:after,\n.nav:after,\n.navbar:after,\n.navbar-header:after,\n.navbar-collapse:after,\n.pager:after,\n.panel-body:after,\n.modal-header:after,\n.modal-footer: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}\n.affix {\n  position: fixed;\n}\n@-ms-viewport {\n  width: device-width;\n}\n.visible-xs,\n.visible-sm,\n.visible-md,\n.visible-lg {\n  display: none !important;\n}\n.visible-xs-block,\n.visible-xs-inline,\n.visible-xs-inline-block,\n.visible-sm-block,\n.visible-sm-inline,\n.visible-sm-inline-block,\n.visible-md-block,\n.visible-md-inline,\n.visible-md-inline-block,\n.visible-lg-block,\n.visible-lg-inline,\n.visible-lg-inline-block {\n  display: none !important;\n}\n@media (max-width: 767px) {\n  .visible-xs {\n    display: block !important;\n  }\n  table.visible-xs {\n    display: table !important;\n  }\n  tr.visible-xs {\n    display: table-row !important;\n  }\n  th.visible-xs,\n  td.visible-xs {\n    display: table-cell !important;\n  }\n}\n@media (max-width: 767px) {\n  .visible-xs-block {\n    display: block !important;\n  }\n}\n@media (max-width: 767px) {\n  .visible-xs-inline {\n    display: inline !important;\n  }\n}\n@media (max-width: 767px) {\n  .visible-xs-inline-block {\n    display: inline-block !important;\n  }\n}\n@media (min-width: 768px) and (max-width: 991px) {\n  .visible-sm {\n    display: block !important;\n  }\n  table.visible-sm {\n    display: table !important;\n  }\n  tr.visible-sm {\n    display: table-row !important;\n  }\n  th.visible-sm,\n  td.visible-sm {\n    display: table-cell !important;\n  }\n}\n@media (min-width: 768px) and (max-width: 991px) {\n  .visible-sm-block {\n    display: block !important;\n  }\n}\n@media (min-width: 768px) and (max-width: 991px) {\n  .visible-sm-inline {\n    display: inline !important;\n  }\n}\n@media (min-width: 768px) and (max-width: 991px) {\n  .visible-sm-inline-block {\n    display: inline-block !important;\n  }\n}\n@media (min-width: 992px) and (max-width: 1199px) {\n  .visible-md {\n    display: block !important;\n  }\n  table.visible-md {\n    display: table !important;\n  }\n  tr.visible-md {\n    display: table-row !important;\n  }\n  th.visible-md,\n  td.visible-md {\n    display: table-cell !important;\n  }\n}\n@media (min-width: 992px) and (max-width: 1199px) {\n  .visible-md-block {\n    display: block !important;\n  }\n}\n@media (min-width: 992px) and (max-width: 1199px) {\n  .visible-md-inline {\n    display: inline !important;\n  }\n}\n@media (min-width: 992px) and (max-width: 1199px) {\n  .visible-md-inline-block {\n    display: inline-block !important;\n  }\n}\n@media (min-width: 1200px) {\n  .visible-lg {\n    display: block !important;\n  }\n  table.visible-lg {\n    display: table !important;\n  }\n  tr.visible-lg {\n    display: table-row !important;\n  }\n  th.visible-lg,\n  td.visible-lg {\n    display: table-cell !important;\n  }\n}\n@media (min-width: 1200px) {\n  .visible-lg-block {\n    display: block !important;\n  }\n}\n@media (min-width: 1200px) {\n  .visible-lg-inline {\n    display: inline !important;\n  }\n}\n@media (min-width: 1200px) {\n  .visible-lg-inline-block {\n    display: inline-block !important;\n  }\n}\n@media (max-width: 767px) {\n  .hidden-xs {\n    display: none !important;\n  }\n}\n@media (min-width: 768px) and (max-width: 991px) {\n  .hidden-sm {\n    display: none !important;\n  }\n}\n@media (min-width: 992px) and (max-width: 1199px) {\n  .hidden-md {\n    display: none !important;\n  }\n}\n@media (min-width: 1200px) {\n  .hidden-lg {\n    display: none !important;\n  }\n}\n.visible-print {\n  display: none !important;\n}\n@media print {\n  .visible-print {\n    display: block !important;\n  }\n  table.visible-print {\n    display: table !important;\n  }\n  tr.visible-print {\n    display: table-row !important;\n  }\n  th.visible-print,\n  td.visible-print {\n    display: table-cell !important;\n  }\n}\n.visible-print-block {\n  display: none !important;\n}\n@media print {\n  .visible-print-block {\n    display: block !important;\n  }\n}\n.visible-print-inline {\n  display: none !important;\n}\n@media print {\n  .visible-print-inline {\n    display: inline !important;\n  }\n}\n.visible-print-inline-block {\n  display: none !important;\n}\n@media print {\n  .visible-print-inline-block {\n    display: inline-block !important;\n  }\n}\n@media print {\n  .hidden-print {\n    display: none !important;\n  }\n}\n/* ************************************************************************ */\n/*                                LESS VARIABLES\n**                This stylesheet should only contain variables.\n/* ************************************************************************ */\n/*-----------------------------------------------------------------------*/\n/*                          Color palette                                */\n/*-----------------------------------------------------------------------*/\n.top-buffer-1 {\n  margin-top: 15px;\n}\n.top-buffer-2 {\n  margin-top: 30px;\n}\n.top-buffer-3 {\n  margin-top: 45px;\n}\n.top-buffer-4 {\n  margin-top: 60px;\n}\n.top-buffer-5 {\n  margin-top: 75px;\n}\n.top-buffer-6 {\n  margin-top: 90px;\n}\n.top-buffer-7 {\n  margin-top: 105px;\n}\n.top-buffer-8 {\n  margin-top: 120px;\n}\n.top-buffer-9 {\n  margin-top: 135px;\n}\n.top-buffer-10 {\n  margin-top: 150px;\n}\n/* ************************************************************************ */\n/*                                IMPAC MATERIAL\n/*                  ------------------------------------------\n** Mixin material styled form inputs, overriding bootstrap's ungodly round-ness.\n/* ************************************************************************ */\n/* DEMO HTML - use this html to test all impac material features.\n<form>\n  <div class=\"im-form-group\">\n    <select>\n      <option>Value 1</option>\n      <option>Value 2</option>\n    </select>\n    <label for=\"select\" class=\"im-control-label\">Selectbox</label><i class=\"im-bar\"></i>\n  </div>\n  <div class=\"im-form-group\">\n    <input type=\"text\" required/>\n    <label for=\"input\" class=\"im-control-label\">Textfield</label><i class=\"im-bar\"></i>\n    <div class=\"im-messages\">\n      <p>This is an error message</p>\n    </div>\n  </div>\n  <div class=\"im-form-inline\">\n    <div class=\"im-form-group\">\n      <input type=\"text\" required/>\n      <label for=\"input\" class=\"im-control-label\">Inline</label><i class=\"im-bar\"></i>\n    </div>\n    <div class=\"im-form-group\">\n      <input type=\"text\" required/>\n      <label for=\"input\" class=\"im-control-label\">Inline</label><i class=\"im-bar\"></i>\n    </div>\n  </div>\n  <div class=\"im-form-group\">\n    <textarea required></textarea>\n    <label for=\"textarea\" class=\"im-control-label\">Textarea</label><i class=\"im-bar\"></i>\n  </div>\n  <div class=\"im-checkbox\">\n    <label>\n      <input type=\"checkbox\" checked=\"checked\"/><i class=\"im-helper\"></i>I'm the label from a checkbox\n    </label>\n  </div>\n  <div class=\"im-checkbox\">\n    <label>\n      <input type=\"checkbox\"/><i class=\"im-helper\"></i>I'm the label from a checkbox\n    </label>\n  </div>\n  <div class=\"im-form-radio\">\n    <div class=\"im-radio\">\n      <label>\n        <input type=\"radio\" name=\"radio\" checked=\"checked\"/><i class=\"im-helper\"></i>I'm the label from a radio button\n      </label>\n    </div>\n    <div class=\"im-radio\">\n      <label>\n        <input type=\"radio\" name=\"radio\"/><i class=\"im-helper\"></i>I'm the label from a radio button\n      </label>\n    </div>\n  </div>\n  <div class=\"im-checkbox\">\n    <label>\n      <input type=\"checkbox\"/><i class=\"im-helper\"></i>I'm the label from a checkbox\n    </label>\n  </div>\n  <button type=\"button\" class=\"im-fab im-primary\"><i>♥</i></button>\n  <button type=\"button\" class=\"im-fab im-warn\"><i>♥</i></button>\n</form>\n*/\n/* ************************************************************************ */\n/*                                GLOBAL STYLES\n**        This stylesheet should only contain styles applied global or in\n**                            2 or more components.\n/* ************************************************************************ */\nbody {\n  height: 101% !important;\n}\n.analytics h2 {\n  margin-top: 2px;\n  font-size: 14px;\n  color: #5B6667;\n}\n.analytics h3 {\n  margin: 0px;\n  font-weight: 300;\n  font-size: 14px;\n  color: #5B6667;\n  text-align: left;\n  margin-top: 0px;\n}\n.analytics h4 {\n  color: #5B6667;\n  font-size: 16px;\n}\n.analytics .positive,\n.analytics .green {\n  color: green !important;\n}\n.analytics .negative,\n.analytics .red {\n  color: #ed1e79 !important;\n}\n.analytics .positive2 {\n  color: #3fc4ff !important;\n}\n.analytics .negative2 {\n  color: #1de9b6 !important;\n}\n.analytics a {\n  font-weight: bold;\n  color: #977bf0;\n  cursor: pointer;\n}\n.analytics .input-group {\n  width: 100%;\n}\n.analytics select {\n  margin-top: 5px;\n  background-color: white;\n  height: 32px;\n}\n.analytics pre {\n  font-size: 12px;\n  padding: 0px;\n  margin: 1px 0px 8px 0px;\n  border: none;\n  white-space: pre-wrap;\n  word-wrap: break-word;\n  overflow: hidden;\n}\n.analytics .widget-item .content ::-webkit-scrollbar,\n.analytics kpis-bar .kpi ::-webkit-scrollbar {\n  width: 6px;\n  background-color: transparent;\n}\n.analytics .widget-item .content ::-webkit-scrollbar-thumb,\n.analytics kpis-bar .kpi ::-webkit-scrollbar-thumb {\n  background-color: #6896b2;\n  border-radius: 10px;\n}\n.analytics .widget-item .content ::-webkit-scrollbar-thumb:hover,\n.analytics kpis-bar .kpi ::-webkit-scrollbar-thumb:hover {\n  background-color: #79a2bb;\n}\n.analytics .nopadding {\n  padding: 0;\n}\n.analytics .nomargin {\n  margin: 0;\n}\n.analytics .btn.btn-shaded {\n  background-color: #17262d;\n  border: solid 1px #0e181c;\n  color: #626d6d;\n  font-weight: 400;\n}\n.analytics .btn.btn-shaded:hover {\n  color: #6e7a7a;\n  background-color: #20343e;\n}\n.analytics .price {\n  font-weight: 900;\n  font-size: 22px;\n  color: #5B6667;\n  text-align: center;\n  margin-top: 30px;\n}\n.analytics .currency {\n  font-weight: 300;\n  font-size: 16px;\n  color: #5B6667;\n  text-align: center;\n  color: #9ba6a7;\n}\n.analytics .legend {\n  font-weight: 300;\n  font-size: 12px;\n  color: #5B6667;\n  text-align: center;\n  overflow-y: auto;\n  overflow-x: hidden;\n  color: #c4caca;\n}\n.analytics .loader {\n  height: 100%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n}\n.analytics .loader i {\n  color: #67BBE9;\n}\n.analytics .loader p {\n  margin-top: 10px;\n}\n.analytics .right-panel {\n  border-left: solid 1px #e6e6e6;\n}\n.analytics .selector {\n  text-transform: uppercase;\n  font-size: 12px;\n  color: #626d6d;\n  text-align: center;\n}\n.analytics .tile {\n  background-color: #f7f7f7;\n  box-shadow: 0px 7px 10px -7px #17262d;\n  height: 45px;\n  margin-bottom: 10px;\n  white-space: nowrap;\n  cursor: pointer;\n}\n.analytics .tile:hover {\n  background-color: #e2f2ff;\n}\n.analytics .tile .colored-area {\n  background-color: #3FC4FF;\n  height: 100%;\n  float: right;\n  color: white;\n  text-align: right;\n  padding: 5px 10px;\n  min-width: 8%;\n}\n.analytics .tile .colored-area.selected {\n  background-color: #977bf0;\n}\n.analytics .tile .main-text {\n  color: #5B6667;\n  padding: 20px 0px 0px 5px;\n  height: 100%;\n  font-style: italic;\n  font-weight: bold;\n}\n.analytics .widget-lines-container {\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: 200px;\n  text-align: left;\n  font-size: 12px;\n  padding: 0px 15px;\n}\n.analytics .widget-lines-container .row.widget-line {\n  padding: 5px;\n  color: #626d6d;\n}\n.analytics .widget-lines-container .row.widget-line.header {\n  font-weight: 500;\n  font-size: 12px;\n  color: #9ba6a7;\n  text-transform: uppercase;\n}\n@media (max-width: 767px) {\n  .analytics .widget-lines-container .row.widget-line {\n    margin: inherit;\n    margin-left: -3px;\n    margin-right: -3px;\n    padding: 2px;\n  }\n  .analytics .widget-lines-container .row.widget-line > [class*='col-'] {\n    padding-left: 3px;\n    padding-right: 3px;\n  }\n}\n.analytics .widget-lines-container .row.widget-line i.fa {\n  min-width: 12px;\n  min-height: 12px;\n}\n.analytics .widget-lines-container .row .dashed {\n  border-bottom: dashed 1px #dfe2e2;\n  padding-bottom: 3px;\n  margin-bottom: 3px;\n}\n.analytics .widget-lines-container .row.lines-group {\n  border-top: solid 1px #e6edee;\n}\n.vertical-scroll {\n  overflow-y: scroll;\n}\n.horizontal-scroll {\n  overflow-x: scroll;\n}\n.tooltip.impac-widgets-tooltip .tooltip-inner.ng-binding {\n  text-align: left;\n  background-color: #232528;\n  max-width: 100%;\n  white-space: nowrap;\n}\n.tooltip.impac-widgets-tooltip .tooltip-inner.ng-binding strong {\n  color: #dae173;\n}\n.sortable-title {\n  cursor: pointer;\n}\n.sortable-title div {\n  display: inline-block;\n}\ndiv[ng-messages] {\n  color: #FF0000;\n}\n.has-error .form-control {\n  border-color: #e01f74;\n}\n.has-error .form-control:focus {\n  border-color: #e01f74;\n}\n.has-success .form-control {\n  border-color: #00e5f0;\n}\n.has-success .form-control:focus {\n  border-color: #00e5f0;\n}\n.row.no-gutters {\n  margin-right: 0;\n  margin-left: 0;\n}\n[class^=\"col-\"].no-gutters,\n[class*=\" col-\"].no-gutters {\n  padding-right: 0;\n  padding-left: 0;\n}\n@media print {\n  body {\n    background-color: white !important;\n  }\n  .analytics {\n    padding-top: 0px !important;\n  }\n  .analytics #module__dashboard-selector .title-container {\n    margin-top: 20px;\n  }\n  .analytics .widget-item {\n    page-break-inside: avoid;\n  }\n  .analytics .widget-item .content .chart-container {\n    max-width: 270px;\n    margin: auto;\n  }\n  .analytics .widget-item .content .chart-container canvas {\n    width: 100% !important;\n    height: 100% !important;\n  }\n  .analytics .widget-item .right-panel {\n    page-break-inside: avoid;\n    border-left: 0;\n  }\n  .analytics .widget-item .right-panel .chart-container {\n    max-width: inherit;\n    max-height: inherit;\n  }\n  .analytics .widget-item .right-panel .chart-container canvas {\n    width: 80% !important;\n    height: 80% !important;\n  }\n  * {\n    transition: none !important;\n  }\n}\n/**\n *  Do not remove this comments bellow. It's the markers used by gulp-inject to inject\n *  all your less files automatically\n */\n/* inject:imports */\n.kpi-alerts-settings .modal-header {\n  font-size: 20px;\n}\n.kpi-alerts-settings .modal-body {\n  line-height: 2;\n}\n.kpi-alerts-settings .modal-body ul {\n  margin-top: 10px;\n}\n.kpi-alerts-settings .modal-body ul > li.list-group-item {\n  list-style: none;\n  padding: 6px 15px;\n  color: #9ba6a7;\n  user-select: none;\n}\n.kpi-alerts-settings .modal-body ul > li.list-group-item .alert-toggle:hover {\n  cursor: pointer;\n}\n.kpi-alerts-settings .modal-body ul > li.list-group-item.active {\n  color: #358fdc;\n  font-weight: bold;\n  background-color: transparent;\n  border-color: #c4caca;\n}\n.kpi-alerts-settings .modal-body .fa.fa-toggle-on,\n.kpi-alerts-settings .modal-body .fa.fa-toggle-off {\n  font-size: 17px;\n  margin-right: 8px;\n}\n.kpi-alerts-settings .modal-body ul.recipients-list {\n  height: 75px;\n  overflow: hidden;\n  overflow-y: scroll;\n  border: 1px solid #c4caca;\n}\n.kpi-alerts-settings .modal-body ul.recipients-list li {\n  border: none;\n}\n.kpi-alerts-settings .modal-body input.recipient-search {\n  color: black;\n  width: 100%;\n}\n.kpi-alerts-settings .modal-body ul.available {\n  margin-top: 0px;\n}\n.analytics {\n  padding-top: 50px;\n  margin-left: 100px;\n}\n@media screen and (max-width: 992px) {\n  .analytics {\n    padding-top: 150px;\n  }\n}\n.analytics.pdf-mode {\n  padding-top: 20px;\n}\n.analytics.show-dhb {\n  transition: opacity 1s;\n  opacity: 1;\n}\n.analytics.hide-dhb {\n  opacity: 0;\n}\n.analytics #dashboard-heading img {\n  float: left;\n  margin-right: 15px;\n  max-width: 200px;\n  max-height: 150px;\n}\n.analytics #dashboard-heading img.pdf-mode:hover {\n  cursor: pointer;\n}\n.analytics #dashboard-heading .caption {\n  font-size: 14px;\n  margin: 5px 0px;\n}\n.analytics #sub-menu {\n  margin-top: 15px;\n}\n.analytics #sub-menu h3 {\n  font-size: 26px;\n  font-weight: normal;\n  margin-bottom: 10px;\n  color: #233845;\n}\n.analytics #sub-menu .fa.fa-times {\n  margin: 6px;\n  color: #3d6178;\n  cursor: pointer;\n  float: right;\n}\n.analytics #widget-selector {\n  background-color: #233845;\n  color: white;\n  padding: 0px 45px 10px 45px;\n  margin: 10px -45px;\n  border-radius: 3px;\n  -webkit-user-select: none;\n  /* Chrome/Safari */\n  -moz-user-select: none;\n  /* Firefox */\n  -ms-user-select: none;\n  /* IE10+ */\n  /* Rules below not implemented in browsers yet */\n  -o-user-select: none;\n  user-select: none;\n}\n@media (max-width: 767px) {\n  .analytics #widget-selector {\n    padding: 0 15px 10px 15px;\n    margin: 0;\n  }\n}\n.analytics #widget-selector .title {\n  padding: 15px 0px;\n  border-bottom: solid 1px #2d4859;\n  display: flex;\n  align-items: center;\n}\n.analytics #widget-selector .title p.instruction {\n  flex-grow: 1;\n  margin: 0;\n}\n@media screen and (max-width: 768px) {\n  .analytics #widget-selector .title p.instruction {\n    width: 50%;\n    font-size: 13px;\n  }\n}\n.analytics #widget-selector .title .widget-added.badge {\n  margin-right: 10px;\n  opacity: 0;\n}\n.analytics #widget-selector .title .fa.close-selector {\n  float: right;\n  cursor: pointer;\n  font-size: 20px;\n  padding: 6px;\n}\n.analytics #widget-selector .title .fa.close-selector:hover {\n  color: #999999;\n}\n.analytics #widget-selector .top-container {\n  margin: 15px 0px;\n  background-color: transparent;\n  border-radius: 3px;\n}\n.analytics #widget-selector .section-header {\n  padding: 10px 20px;\n  font-weight: bold;\n  min-height: 40px;\n  display: flex;\n  align-items: center;\n}\n.analytics #widget-selector .section-lines {\n  overflow-x: hidden;\n  overflow-y: auto;\n  height: 200px;\n  margin-right: -10px;\n  margin-left: 0px;\n}\n.analytics #widget-selector .section-lines p {\n  padding: 5px;\n  margin: 0px;\n  cursor: pointer;\n}\n.analytics #widget-selector .section-lines p:hover,\n.analytics #widget-selector .section-lines p.selected {\n  color: white;\n}\n.analytics #widget-selector .section-lines::-webkit-scrollbar {\n  width: 6px;\n  background-color: transparent;\n}\n.analytics #widget-selector .section-lines::-webkit-scrollbar-thumb {\n  background-color: #28404f;\n  border-radius: 10px;\n}\n.analytics #widget-selector .section-lines::-webkit-scrollbar-thumb:hover {\n  background-color: #2d4859;\n}\n.analytics #widget-selector .categories-section {\n  background-color: #192831;\n  padding-bottom: 15px;\n}\n.analytics #widget-selector .categories-section > .section-lines > [class*='col-']:first-child {\n  padding: 3px 12px;\n}\n.analytics #widget-selector .categories-section > .section-lines .line-item:hover {\n  background-color: #1e303b;\n}\n.analytics #widget-selector .categories-section > .section-lines .line-item.selected {\n  background-color: #977bf0;\n  font-weight: bold;\n  -webkit-box-shadow: -2px 2px 10px -4px black;\n  box-shadow: -2px 2px 10px -4px black;\n}\n.analytics #widget-selector .categories-section .arrow-icon {\n  position: absolute;\n  top: 33px;\n  right: -11px;\n  z-index: 1;\n}\n.analytics #widget-selector .categories-section .arrow-icon .square {\n  width: 50px;\n  height: 30px;\n  position: absolute;\n  top: 10px;\n  right: 17px;\n  background-color: #977bf0;\n}\n.analytics #widget-selector .categories-section .arrow-icon i.fa.fa-caret-right {\n  font-size: 52px;\n  color: #977bf0;\n  float: right;\n  position: absolute;\n  top: -1.5px;\n  right: 0px;\n}\n.analytics #widget-selector .widgets-section {\n  background-color: #1e303b;\n  padding-bottom: 15px;\n}\n.analytics #widget-selector .widgets-section > .section-header {\n  text-transform: uppercase;\n  font-size: 12px;\n  color: #977bf0;\n}\n.analytics #widget-selector .widgets-section > .section-lines {\n  padding: 3px 0px;\n}\n.analytics #widget-selector .widgets-section > .section-lines .fa.fa-plus-circle {\n  float: right;\n  margin-top: 3px;\n}\n.analytics #widget-selector .widgets-section > .section-lines > .line-items-grid {\n  width: 100%;\n  display: flex;\n  flex-wrap: wrap;\n  height: 0%;\n}\n.analytics #widget-selector .widgets-section > .section-lines > .line-items-grid > .grid-item {\n  padding: 0 13px;\n  display: flex;\n  flex-grow: 1;\n  flex: 0 31.33%;\n  margin: 0 1%;\n  align-items: center;\n  border-bottom: solid 1px #233845;\n  min-height: 0px;\n}\n@media screen and (max-width: 992px) {\n  .analytics #widget-selector .widgets-section > .section-lines > .line-items-grid > .grid-item {\n    flex: 0 100%;\n  }\n}\n.analytics #widget-selector .widgets-section > .section-lines > .line-items-grid > .grid-item:hover {\n  background-color: #192831;\n  font-weight: normal;\n}\n.analytics #widget-selector .widgets-section > .section-lines > .line-items-grid > .grid-item p.line-item {\n  flex-grow: 1;\n}\n.analytics #widget-selector .bottom {\n  height: 20px;\n}\n.analytics #widget-selector .bottom > .suggestion {\n  float: right;\n  opacity: 0.7;\n}\n.analytics #widget-selector .bottom > .suggestion a {\n  cursor: pointer;\n}\n.analytics #widget-selector .bottom > .suggestion a:hover {\n  color: #00e5f0;\n}\n.analytics #widget-selector .bottom > .suggestion:hover {\n  opacity: 1;\n}\n.analytics #dashboard-settings-panel {\n  position: relative;\n  margin-top: 5px;\n}\n.analytics #dashboard-settings-panel > div {\n  display: flex;\n  justify-content: flex-end;\n}\n.analytics #dashboard-settings-panel > div > * {\n  margin: 0px 3px;\n}\n.analytics #dashboard-settings-panel select {\n  margin: 0;\n  height: 34px;\n  padding-top: 1px;\n}\n.analytics #no-widgets-container {\n  position: relative;\n  min-height: 150px;\n}\n.analytics #no-widgets-container img.bg {\n  left: 0;\n  top: 0;\n  min-width: 100%;\n  min-height: 100%;\n}\n.analytics #no-widgets-container .impac-info-message {\n  position: absolute;\n  top: 0;\n  width: 100%;\n}\n.analytics #no-widgets-container .impac-info-message .info-text {\n  font-size: 25px;\n  font-weight: 300;\n  padding: 20px;\n  min-height: 115px;\n  color: white;\n  border-radius: 10px;\n  background-color: rgba(23, 38, 45, 0.7);\n}\n.analytics #widgets-section #widgets-container {\n  min-height: 700px;\n}\n.analytics #widgets-section .placeHolderBox {\n  margin: 12px;\n  height: 267px;\n  width: 300px;\n  float: left;\n  border: 2px dashed #abc4c6;\n  background: none;\n}\n.analytics.load-failed p {\n  font-size: 22px;\n}\n.analytics.load-failed .second-msg p {\n  color: #e01f74;\n  font-size: 14px;\n}\n.tooltip.impac-widget-selector-tooltip .tooltip-inner.ng-binding {\n  font-size: 14px;\n}\n.impac-widget-suggestion .modal-body input,\n.impac-widget-suggestion .modal-body textarea {\n  width: 100%;\n  color: black;\n}\n.impac-widget-suggestion .modal-body textarea {\n  height: 150px;\n}\n.impac-widget-suggestion .modal-body .thanks-message {\n  color: #dae173;\n}\n.modal-footer .loader {\n  color: white;\n}\n.analytics .dashboard-create .btn-create {\n  background-color: #977bf0;\n}\n.modal.impac-dashboard-create h1 {\n  font-size: 24px;\n}\n.modal.impac-dashboard-create .fa.fa-times {\n  float: right;\n  color: #ccc;\n  cursor: pointer;\n}\n.modal.impac-dashboard-create .control-label {\n  text-align: left;\n}\n.modal.impac-dashboard-create .modal-footer .loader {\n  color: white;\n}\n#module__dashboard-selector a {\n  font-weight: normal;\n}\n#module__dashboard-selector > div:first-child {\n  border-bottom: 1px solid #abc4c6;\n}\n#module__dashboard-selector .buttons-bar-row {\n  margin-top: 54px;\n}\n#module__dashboard-selector .buttons-bar-row.pdf-mode {\n  margin-top: 0px;\n}\n#module__dashboard-selector .buttons-bar {\n  padding: 0;\n  position: relative;\n}\n#module__dashboard-selector .buttons-bar .btn {\n  float: right;\n  margin: 3px;\n  border-radius: 4px;\n}\n#module__dashboard-selector .buttons-bar .title-container h1 {\n  margin: 0px;\n  color: black;\n  cursor: auto;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-title {\n  color: #977bf0;\n  display: inline;\n  cursor: pointer;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-title:hover {\n  color: #734deb;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-title i.fa.fa-pencil {\n  margin-left: 20px;\n  font-size: 14px;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-title i.fa.fa-pencil:hover {\n  color: #dae173;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select {\n  margin: 5px 0px 10px 30px;\n  height: auto;\n  border-left: 1px solid #977bf0;\n  border-bottom: 1px solid #977bf0;\n  width: 300px;\n  background-color: #e6edee;\n  cursor: pointer;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option {\n  color: #17262d;\n  white-space: nowrap;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option:hover {\n  background-color: white;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option.dashboard-create {\n  height: 33px;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option.dashboard-create .btn {\n  float: none;\n  width: 100%;\n  text-align: left;\n  margin: 0px;\n  border-radius: 0px;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option i.fa.fa-pencil {\n  float: right;\n  padding-top: 7px;\n  text-align: center;\n  width: 15%;\n  height: 30px;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option i.fa.fa-pencil:hover {\n  color: #734deb;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option span.name {\n  width: 85%;\n  height: 30px;\n  display: inline-block;\n  padding: 5px 10px 5px 10px;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .change-name {\n  position: absolute;\n  top: 30px;\n  left: 20px;\n  width: 60%;\n  background-color: #17262d;\n  color: white;\n  padding: 10px;\n  border-radius: 4px;\n  text-align: center;\n  -webkit-box-shadow: 0px 0px 25px 4px black;\n  box-shadow: 0px 0px 25px 4px black;\n  z-index: 50;\n  border: solid 1px white;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .change-name .form-control {\n  height: 25px;\n  margin-bottom: 10px;\n}\n#module__dashboard-selector .buttons-bar .dropdown-container .data-source-label {\n  color: #17262d;\n  padding-left: 3px;\n  margin: 0px;\n}\n#module__dashboard-selector .buttons-bar .loader-container {\n  padding-left: 10px;\n}\n#module__dashboard-selector .buttons-bar .loader-container .loading-spinner {\n  color: #67BBE9;\n  font-size: 40px;\n}\n#module__dashboard-selector .nav-tabs {\n  border-bottom: 0;\n}\n#module__dashboard-selector .nav.nav-tabs li:last-child > a,\n#module__dashboard-selector .nav.nav-pills li:last-child > a {\n  padding-right: 15px;\n}\n#module__dashboard-selector .nav.nav-tabs li:last-child > a tab-heading a,\n#module__dashboard-selector .nav.nav-pills li:last-child > a tab-heading a {\n  position: static;\n}\n#module__dashboard-selector .nav.nav-tabs li > a {\n  padding: 10px 8px 10px 15px;\n  margin: 0 2px 0 0;\n  background-color: transparent;\n  border: 1px solid #abc4c6;\n  color: black;\n}\n#module__dashboard-selector .nav.nav-tabs li.active > a {\n  background-color: #ffffff;\n  color: #977bf0;\n}\n#module__dashboard-selector .nav.nav-tabs li:last-child.active > a {\n  background-color: transparent;\n}\n#module__dashboard-selector .nav.nav-pills li > a {\n  min-width: 0px;\n  padding-right: 8px;\n}\n#module__dashboard-selector .nav.nav-pills li:last-child tab-heading a {\n  margin-left: 2px;\n}\n#module__dashboard-selector .nav.nav-pills li:last-child.active > a {\n  background-color: #f4f4f4;\n}\n#module__dashboard-selector tab-heading a.close-link {\n  border-bottom: 0px solid;\n  margin-left: 12px;\n  position: relative;\n  top: -9px;\n  right: 1px;\n  color: black;\n}\ndashboard-templates-selector .templates-header {\n  display: flex;\n}\ndashboard-templates-selector .templates-header .templates-toggle {\n  display: flex;\n  flex-grow: 1;\n  justify-content: flex-end;\n  font-size: 20px;\n}\ndashboard-templates-selector .templates-header .templates-toggle i.fa {\n  cursor: pointer;\n}\ndashboard-templates-selector .templates-header .templates-toggle i.fa.fa-toggle-on {\n  color: #977bf0;\n}\ndashboard-templates-selector .templates {\n  border: 1px solid #ccc;\n  box-shadow: inset 0px 0px 1px 0px #ccc;\n  height: 130px;\n  overflow: auto;\n  border-radius: 2px;\n}\ndashboard-templates-selector .templates .template {\n  padding: 5px 10px;\n  color: #5B6667;\n  border-bottom: 1px solid #ececec;\n}\ndashboard-templates-selector .templates .template:hover {\n  cursor: pointer;\n  background-color: rgba(96, 232, 119, 0.62);\n}\ndashboard-templates-selector .templates .template.selected {\n  background-color: rgba(29, 197, 57, 0.62);\n}\n.analytics .impac-kpi .kpi {\n  position: relative;\n  max-width: 220px;\n  min-height: 95px;\n  max-height: 95px;\n  background-color: white;\n  margin: 10px 0 10px 0;\n  border-bottom: 1px solid white;\n  transition: all 0.2s ease-in;\n}\n@media screen and (max-width: 768px) {\n  .analytics .impac-kpi .kpi {\n    margin-left: auto;\n    margin-right: auto;\n  }\n}\n.analytics .impac-kpi .kpi.triggered,\n.analytics .impac-kpi .kpi.add:hover {\n  border-bottom: 4px solid #e01f74;\n}\n.analytics .impac-kpi .kpi.add .kpi-text .emphasis {\n  visibility: hidden;\n}\n.analytics .impac-kpi .kpi.add:hover {\n  cursor: pointer;\n}\n.analytics .impac-kpi .kpi.add:hover .top-line {\n  background-color: black;\n}\n.analytics .impac-kpi .kpi.add:hover .kpi-text {\n  color: black;\n}\n.analytics .impac-kpi .kpi.add:hover .kpi-text .emphasis {\n  visibility: visible;\n}\n.analytics .impac-kpi .kpi.add:hover .kpi-icon {\n  color: black;\n}\n.analytics .impac-kpi .kpi.add:hover .kpi-icon .fa-plus:before {\n  content: \"\\f00c\";\n}\n.analytics .impac-kpi .kpi.editing {\n  min-height: 185px;\n}\n.analytics .impac-kpi .kpi:hover {\n  cursor: default;\n}\n.analytics .impac-kpi .kpi.static .kpi-value {\n  display: block;\n  font-size: 14px;\n  font-weight: 700;\n}\n.analytics .impac-kpi .kpi .top-line {\n  width: 100%;\n  position: relative;\n  cursor: move;\n  padding: 9px 9px 0px 12px;\n  border-bottom: none;\n  min-height: 7px;\n  box-shadow: none;\n  display: -webkit-box;\n  display: -webkit-flex;\n  display: -ms-flexbox;\n  display: flex;\n  -webkit-box-orient: horizontal;\n  -webkit-box-direction: normal;\n  -webkit-flex-direction: row;\n  -ms-flex-direction: row;\n  flex-direction: row;\n  margin-bottom: 5px;\n  background-color: grey;\n  transition: background 0.2s ease-in;\n}\n.analytics .impac-kpi .kpi .top-line.triggered {\n  background-color: black;\n}\n.analytics .impac-kpi .kpi .kpi-content {\n  max-height: 90px;\n}\n.analytics .impac-kpi .kpi .kpi-content.editing {\n  min-height: 180px;\n  overflow-y: auto;\n  overflow-x: hidden;\n}\n.analytics .impac-kpi .kpi .kpi-show {\n  white-space: normal;\n  padding: 10px;\n}\n@media screen and (max-width: 380px) {\n  .analytics .impac-kpi .kpi .kpi-show {\n    padding: 10px 3px;\n  }\n}\n.analytics .impac-kpi .kpi .kpi-show .emphasis {\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n}\n.analytics .impac-kpi .kpi .kpi-show .emphasis .real-value {\n  color: #676767;\n}\n.analytics .impac-kpi .kpi .kpi-show .caption {\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n}\n.analytics .impac-kpi .kpi .kpi-show .kpi-text {\n  padding: 7px 0;\n  color: grey;\n  transition: color 0.2s ease-in;\n}\n.analytics .impac-kpi .kpi .kpi-show .kpi-text > span {\n  display: block;\n}\n.analytics .impac-kpi .kpi .kpi-show .kpi-text.triggered {\n  color: black;\n}\n.analytics .impac-kpi .kpi .kpi-show .kpi-text .caption {\n  font-size: 11px;\n  padding-bottom: 2px;\n}\n@media screen and (max-width: 465px) {\n  .analytics .impac-kpi .kpi .kpi-show .kpi-text .caption {\n    font-size: 10px;\n  }\n  .analytics .impac-kpi .kpi .kpi-show .kpi-text .emphasis {\n    font-size: 11px;\n  }\n}\n.analytics .impac-kpi .kpi .kpi-show .kpi-icon {\n  font-size: 16px;\n  padding: 10px 0;\n  color: grey;\n  transition: color 0.2s ease-in;\n}\n.analytics .impac-kpi .kpi .kpi-show .kpi-icon.triggered {\n  color: black;\n}\n@media screen and (max-width: 465px) {\n  .analytics .impac-kpi .kpi .kpi-show .kpi-icon {\n    font-size: 12px;\n    padding: 16px 0;\n  }\n}\n.analytics .impac-kpi .kpi .kpi-edit a {\n  color: white;\n}\n.analytics .impac-kpi .kpi .kpi-edit .kpi-name {\n  text-align: center;\n  margin-bottom: 5px;\n}\n.analytics .impac-kpi .kpi .kpi-edit .kpi-name h6 {\n  margin: 0 0 5px 0;\n}\n.analytics .impac-kpi .kpi .kpi-edit .real-value {\n  text-transform: uppercase;\n  font-size: 10px;\n  text-align: center;\n}\n.analytics .impac-kpi .kpi .kpi-edit .alert-caption {\n  text-align: center;\n  font-size: 11px;\n  background: #ff9999;\n  border-radius: 3px;\n  width: 100%;\n  margin: 0 auto 5px auto;\n  box-shadow: none;\n  padding: 2px;\n  color: white;\n}\n.analytics .impac-kpi .kpi .kpi-edit .kpi-target-watchable,\n.analytics .impac-kpi .kpi .kpi-edit .kpi-target-unit {\n  text-transform: uppercase;\n  font-weight: 500;\n  font-size: 11px;\n}\n.analytics .impac-kpi .kpi .kpi-edit .kpi-target-watchable {\n  margin-bottom: 20px;\n  color: #8d8d8d;\n}\n.analytics .impac-kpi .kpi .kpi-edit .kpi-target-unit {\n  position: absolute;\n  top: 6px;\n  right: 0;\n  color: #9a9a9a;\n}\n.analytics .impac-kpi .kpi .kpi-edit .param-name {\n  font-size: 85%;\n}\n.analytics .impac-kpi .kpi .kpi-edit .btn.btn-xs {\n  margin-top: 4px;\n}\n.analytics .impac-kpi .kpi .kpi-edit,\n.analytics .impac-kpi .kpi .kpi-no-data {\n  /* Flatten der Bootstrap */\n}\n.analytics .impac-kpi .kpi .kpi-edit .well,\n.analytics .impac-kpi .kpi .kpi-no-data .well,\n.analytics .impac-kpi .kpi .kpi-edit .navbar-inner,\n.analytics .impac-kpi .kpi .kpi-no-data .navbar-inner,\n.analytics .impac-kpi .kpi .kpi-edit .popover,\n.analytics .impac-kpi .kpi .kpi-no-data .popover,\n.analytics .impac-kpi .kpi .kpi-edit .btn,\n.analytics .impac-kpi .kpi .kpi-no-data .btn,\n.analytics .impac-kpi .kpi .kpi-edit .tooltip,\n.analytics .impac-kpi .kpi .kpi-no-data .tooltip,\n.analytics .impac-kpi .kpi .kpi-edit input,\n.analytics .impac-kpi .kpi .kpi-no-data input,\n.analytics .impac-kpi .kpi .kpi-edit select,\n.analytics .impac-kpi .kpi .kpi-no-data select,\n.analytics .impac-kpi .kpi .kpi-edit textarea,\n.analytics .impac-kpi .kpi .kpi-no-data textarea,\n.analytics .impac-kpi .kpi .kpi-edit pre,\n.analytics .impac-kpi .kpi .kpi-no-data pre,\n.analytics .impac-kpi .kpi .kpi-edit .progress,\n.analytics .impac-kpi .kpi .kpi-no-data .progress,\n.analytics .impac-kpi .kpi .kpi-edit .modal,\n.analytics .impac-kpi .kpi .kpi-no-data .modal,\n.analytics .impac-kpi .kpi .kpi-edit .add-on,\n.analytics .impac-kpi .kpi .kpi-no-data .add-on,\n.analytics .impac-kpi .kpi .kpi-edit .alert,\n.analytics .impac-kpi .kpi .kpi-no-data .alert,\n.analytics .impac-kpi .kpi .kpi-edit .table-bordered,\n.analytics .impac-kpi .kpi .kpi-no-data .table-bordered,\n.analytics .impac-kpi .kpi .kpi-edit .nav > .active > a,\n.analytics .impac-kpi .kpi .kpi-no-data .nav > .active > a,\n.analytics .impac-kpi .kpi .kpi-edit .dropdown-menu,\n.analytics .impac-kpi .kpi .kpi-no-data .dropdown-menu,\n.analytics .impac-kpi .kpi .kpi-edit .tooltip-inner,\n.analytics .impac-kpi .kpi .kpi-no-data .tooltip-inner,\n.analytics .impac-kpi .kpi .kpi-edit .badge,\n.analytics .impac-kpi .kpi .kpi-no-data .badge,\n.analytics .impac-kpi .kpi .kpi-edit .label,\n.analytics .impac-kpi .kpi .kpi-no-data .label,\n.analytics .impac-kpi .kpi .kpi-edit .img-polaroid,\n.analytics .impac-kpi .kpi .kpi-no-data .img-polaroid {\n  -moz-box-shadow: none !important;\n  -webkit-box-shadow: none !important;\n  box-shadow: none !important;\n  -webkit-border-radius: 0px !important;\n  -moz-border-radius: 0px !important;\n  border-radius: 0px !important;\n  border-collapse: collapse !important;\n  background-image: none !important;\n}\n.analytics .impac-kpi .kpi .kpi-edit body,\n.analytics .impac-kpi .kpi .kpi-no-data body,\n.analytics .impac-kpi .kpi .kpi-edit input,\n.analytics .impac-kpi .kpi .kpi-no-data input,\n.analytics .impac-kpi .kpi .kpi-edit select,\n.analytics .impac-kpi .kpi .kpi-no-data select,\n.analytics .impac-kpi .kpi .kpi-edit textarea,\n.analytics .impac-kpi .kpi .kpi-no-data textarea {\n  box-sizing: border-box;\n}\n.analytics .impac-kpi .kpi .kpi-edit body::after,\n.analytics .impac-kpi .kpi .kpi-no-data body::after,\n.analytics .impac-kpi .kpi .kpi-edit input::after,\n.analytics .impac-kpi .kpi .kpi-no-data input::after,\n.analytics .impac-kpi .kpi .kpi-edit select::after,\n.analytics .impac-kpi .kpi .kpi-no-data select::after,\n.analytics .impac-kpi .kpi .kpi-edit textarea::after,\n.analytics .impac-kpi .kpi .kpi-no-data textarea::after,\n.analytics .impac-kpi .kpi .kpi-edit body::before,\n.analytics .impac-kpi .kpi .kpi-no-data body::before,\n.analytics .impac-kpi .kpi .kpi-edit input::before,\n.analytics .impac-kpi .kpi .kpi-no-data input::before,\n.analytics .impac-kpi .kpi .kpi-edit select::before,\n.analytics .impac-kpi .kpi .kpi-no-data select::before,\n.analytics .impac-kpi .kpi .kpi-edit textarea::before,\n.analytics .impac-kpi .kpi .kpi-no-data textarea::before {\n  box-sizing: border-box;\n}\n.analytics .impac-kpi .kpi .kpi-edit input[type=number]::-webkit-inner-spin-button,\n.analytics .impac-kpi .kpi .kpi-no-data input[type=number]::-webkit-inner-spin-button,\n.analytics .impac-kpi .kpi .kpi-edit input[type=number]::-webkit-outer-spin-button,\n.analytics .impac-kpi .kpi .kpi-no-data input[type=number]::-webkit-outer-spin-button {\n  -webkit-appearance: none;\n  margin: 0;\n}\n.analytics .impac-kpi .kpi .kpi-edit a:hover,\n.analytics .impac-kpi .kpi .kpi-no-data a:hover {\n  text-decoration: none;\n}\n.analytics .impac-kpi .kpi .kpi-edit fieldset,\n.analytics .impac-kpi .kpi .kpi-no-data fieldset {\n  margin: 0 0 1.75rem;\n  padding: 0;\n  border: none;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-radio,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-radio,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group {\n  position: relative;\n  margin-top: 1.3125rem;\n  margin-bottom: 1.3125rem;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-inline,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-inline {\n  display: flex;\n  flex-direction: row;\n  box-sizing: border-box;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-inline > .im-form-group,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-inline > .im-form-group {\n  display: block;\n  flex: 1;\n  position: relative;\n  vertical-align: middle;\n  margin-left: 0.175rem;\n  margin-right: 0.175rem;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-inline > .btn,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-inline > .btn {\n  display: inline-block;\n  margin-bottom: 0;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input {\n  height: 2.375rem;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea {\n  resize: none;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group select,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select {\n  width: 100%;\n  font-size: 1.25rem;\n  height: 2rem;\n  padding: 0.15625rem 0.15625rem 0.078125rem;\n  background: none;\n  border: none;\n  line-height: 1.6;\n  box-shadow: none;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group .im-control-label {\n  position: absolute;\n  top: 0.3125rem;\n  pointer-events: none;\n  padding-left: 0.15625rem;\n  z-index: 1;\n  color: #b3b3b3;\n  font-size: 1.25rem;\n  font-weight: normal;\n  transition: all 0.28s ease;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group .im-bar,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group .im-bar {\n  position: relative;\n  border-bottom: 0.078125rem solid #999;\n  display: block;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group .im-bar::before,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group .im-bar::before {\n  content: '';\n  height: 0.15625rem;\n  width: 0;\n  left: 50%;\n  bottom: -0.078125rem;\n  position: absolute;\n  background: #358fdc;\n  transition: left 0.28s ease, width 0.28s ease;\n  z-index: 2;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea {\n  display: block;\n  background: none;\n  padding: 0.15625rem 0.15625rem 0.078125rem;\n  font-size: 1.25rem;\n  border-width: 0;\n  border-color: transparent;\n  line-height: 1.9;\n  width: 100%;\n  color: transparent;\n  transition: all 0.28s ease;\n  box-shadow: none;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input[type=\"file\"],\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input[type=\"file\"] {\n  line-height: 1;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input[type=\"file\"] ~ .im-bar,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input[type=\"file\"] ~ .im-bar {\n  display: none;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group select,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:focus,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:focus,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:valid,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:valid,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input.form-file,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input.form-file,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input.has-value,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input.has-value,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:focus,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:focus,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:valid,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:valid,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea.form-file,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea.form-file,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea.has-value,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea.has-value {\n  color: #333;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group select ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:focus ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:focus ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:valid ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:valid ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input.form-file ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input.form-file ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input.has-value ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input.has-value ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:focus ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:focus ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:valid ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:valid ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea.form-file ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea.form-file ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea.has-value ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea.has-value ~ .im-control-label {\n  font-size: 1rem;\n  color: #808080;\n  top: -1.25rem;\n  left: 0;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group select:focus,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select:focus,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:focus,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:focus,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:focus,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:focus {\n  outline: none;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group select:focus ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select:focus ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:focus ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:focus ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:focus ~ .im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:focus ~ .im-control-label {\n  color: #358fdc;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group select:focus ~ .im-bar::before,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select:focus ~ .im-bar::before,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:focus ~ .im-bar::before,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:focus ~ .im-bar::before,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:focus ~ .im-bar::before,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:focus ~ .im-bar::before {\n  width: 100%;\n  left: 0;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox label,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-radio label,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-radio label {\n  position: relative;\n  cursor: pointer;\n  padding-left: 2.5rem;\n  text-align: left;\n  color: #333;\n  display: block;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input,\n.analytics .impac-kpi .kpi .kpi-edit .im-form-radio input,\n.analytics .impac-kpi .kpi .kpi-no-data .im-form-radio input {\n  width: auto;\n  opacity: 0.00000001;\n  position: absolute;\n  left: 0;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-radio,\n.analytics .impac-kpi .kpi .kpi-no-data .im-radio {\n  margin-bottom: 1.25rem;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-radio .im-helper,\n.analytics .impac-kpi .kpi .kpi-no-data .im-radio .im-helper {\n  position: absolute;\n  top: -0.3125rem;\n  left: -0.3125rem;\n  cursor: pointer;\n  display: block;\n  font-size: 1.25rem;\n  user-select: none;\n  color: #999;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-radio .im-helper::before,\n.analytics .impac-kpi .kpi .kpi-no-data .im-radio .im-helper::before,\n.analytics .impac-kpi .kpi .kpi-edit .im-radio .im-helper::after,\n.analytics .impac-kpi .kpi .kpi-no-data .im-radio .im-helper::after {\n  content: '';\n  position: absolute;\n  left: 0;\n  top: 0;\n  margin: 0.3125rem;\n  width: 1.25rem;\n  height: 1.25rem;\n  transition: transform 0.28s ease;\n  border-radius: 50%;\n  border: 0.15625rem solid currentColor;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-radio .im-helper::after,\n.analytics .impac-kpi .kpi .kpi-no-data .im-radio .im-helper::after {\n  transform: scale(0);\n  background-color: #358fdc;\n  border-color: #358fdc;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-radio label:hover .im-helper,\n.analytics .impac-kpi .kpi .kpi-no-data .im-radio label:hover .im-helper {\n  color: #358fdc;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-radio input:checked ~ .im-helper::after,\n.analytics .impac-kpi .kpi .kpi-no-data .im-radio input:checked ~ .im-helper::after {\n  transform: scale(0.5);\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-radio input:checked ~ .im-helper::before,\n.analytics .impac-kpi .kpi .kpi-no-data .im-radio input:checked ~ .im-helper::before {\n  color: #358fdc;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox {\n  margin-top: 1.75rem;\n  margin-bottom: 1.25rem;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox .im-helper,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox .im-helper {\n  color: #999;\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 1.25rem;\n  height: 1.25rem;\n  z-index: 0;\n  border: 0.15625rem solid currentColor;\n  border-radius: 0.078125rem;\n  transition: border-color 0.28s ease;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox .im-helper::before,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox .im-helper::before,\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox .im-helper::after,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox .im-helper::after {\n  position: absolute;\n  height: 0;\n  width: 0.25rem;\n  background-color: #358fdc;\n  display: block;\n  transform-origin: left top;\n  border-radius: 0.3125rem;\n  content: '';\n  transition: opacity 0.28s ease, height 0s linear 0.28s;\n  opacity: 0;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox .im-helper::before,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox .im-helper::before {\n  top: 0.8125rem;\n  left: 0.475rem;\n  transform: rotate(-135deg);\n  box-shadow: 0 0 0 0.078125rem #fff;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox .im-helper::after,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox .im-helper::after {\n  top: 0.375rem;\n  left: 0;\n  transform: rotate(-45deg);\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox label:hover .im-helper,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox label:hover .im-helper {\n  color: #358fdc;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input:checked ~ .im-helper,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input:checked ~ .im-helper {\n  color: #358fdc;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input:checked ~ .im-helper::after,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input:checked ~ .im-helper::after,\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input:checked ~ .im-helper::before,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input:checked ~ .im-helper::before {\n  opacity: 1;\n  transition: height 0.28s ease;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input:checked ~ .im-helper::after,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input:checked ~ .im-helper::after {\n  height: 0.625rem;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input:checked ~ .im-helper::before,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input:checked ~ .im-helper::before {\n  height: 1.5rem;\n  transition-delay: 0.28s;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-radio + .im-radio,\n.analytics .impac-kpi .kpi .kpi-no-data .im-radio + .im-radio,\n.analytics .impac-kpi .kpi .kpi-edit .im-checkbox + .im-checkbox,\n.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox + .im-checkbox {\n  margin-top: 1.25rem;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-messages,\n.analytics .impac-kpi .kpi .kpi-no-data .im-messages {\n  font-size: 1.04166667rem;\n  color: #e01f74;\n  overflow: hidden;\n  transition: all 0.28s cubic-bezier(0.55, 0, 0.55, 0.2);\n  opacity: 0;\n  margin-top: 0;\n  padding-top: 5px;\n}\n.analytics .impac-kpi .kpi .kpi-edit .has-error .legend.legend,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error .legend.legend,\n.analytics .impac-kpi .kpi .kpi-edit .has-error.im-form-group .im-control-label.im-control-label,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-form-group .im-control-label.im-control-label {\n  color: #e01f74;\n}\n.analytics .impac-kpi .kpi .kpi-edit .has-error.im-form-group .im-messages,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-form-group .im-messages,\n.analytics .impac-kpi .kpi .kpi-edit .has-error.im-checkbox .im-messages,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-checkbox .im-messages,\n.analytics .impac-kpi .kpi .kpi-edit .has-error.im-radio .im-messages,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-radio .im-messages,\n.analytics .impac-kpi .kpi .kpi-edit .has-error.im-form-radio .im-messages,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-form-radio .im-messages,\n.analytics .impac-kpi .kpi .kpi-edit .has-error.im-form-group .im-helper,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-form-group .im-helper,\n.analytics .impac-kpi .kpi .kpi-edit .has-error.im-checkbox .im-helper,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-checkbox .im-helper,\n.analytics .impac-kpi .kpi .kpi-edit .has-error.im-radio .im-helper,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-radio .im-helper,\n.analytics .impac-kpi .kpi .kpi-edit .has-error.im-form-radio .im-helper,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-form-radio .im-helper {\n  color: #e01f74;\n  opacity: 1;\n}\n.analytics .impac-kpi .kpi .kpi-edit .has-error .im-bar::before,\n.analytics .impac-kpi .kpi .kpi-no-data .has-error .im-bar::before {\n  background: #e01f74;\n  left: 0;\n  width: 100%;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-button,\n.analytics .impac-kpi .kpi .kpi-no-data .im-button {\n  position: relative;\n  background: #60a7e4;\n  border: 0;\n  font-size: 1.375rem;\n  color: #333;\n  margin: 0.7rem 0;\n  padding: 0.4375rem 1.75rem;\n  border-radius: 3px;\n  cursor: pointer;\n  overflow: hidden;\n  box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-button span,\n.analytics .impac-kpi .kpi .kpi-no-data .im-button span {\n  color: #fff;\n  position: relative;\n  z-index: 1;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-button:hover,\n.analytics .impac-kpi .kpi .kpi-no-data .im-button:hover {\n  transition: background 0.1s ease-in;\n  background: #2583d3;\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-button:active,\n.analytics .impac-kpi .kpi .kpi-no-data .im-button:active {\n  box-shadow: inset 0 2px 2px 0 rgba(0, 0, 0, 0.14);\n}\n.analytics .impac-kpi .kpi .kpi-edit .im-button a:focus,\n.analytics .impac-kpi .kpi .kpi-no-data .im-button a:focus,\n.analytics .impac-kpi .kpi .kpi-edit .im-button:focus,\n.analytics .impac-kpi .kpi .kpi-no-data .im-button:focus {\n  outline: none;\n  text-decoration: none;\n}\n.analytics .impac-kpi .kpi .kpi-edit button.im-fab,\n.analytics .impac-kpi .kpi .kpi-no-data button.im-fab {\n  position: relative;\n  height: 46px;\n  width: 46px;\n  flex: 0 0 56px;\n  display: inline-block;\n  padding: 0;\n  margin: 4px;\n  border: 0;\n  border-radius: 100%;\n  overflow: hidden;\n  font-size: 20px;\n  box-shadow: 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12), 0 2px 4px -1px rgba(0, 0, 0, 0.2);\n  color: white;\n}\n.analytics .impac-kpi .kpi .kpi-edit button.im-fab:focus,\n.analytics .impac-kpi .kpi .kpi-no-data button.im-fab:focus {\n  outline: 0;\n}\n.analytics .impac-kpi .kpi .kpi-edit button.im-fab:active,\n.analytics .impac-kpi .kpi .kpi-no-data button.im-fab:active {\n  box-shadow: inset 0 2px 2px 0 rgba(0, 0, 0, 0.14);\n}\n.analytics .impac-kpi .kpi .kpi-edit button.im-fab.im-primary,\n.analytics .impac-kpi .kpi .kpi-no-data button.im-fab.im-primary {\n  background: #358fdc;\n}\n.analytics .impac-kpi .kpi .kpi-edit button.im-fab.im-primary:hover,\n.analytics .impac-kpi .kpi .kpi-no-data button.im-fab.im-primary:hover {\n  transition: background 0.1s ease-in;\n  background: #2583d3;\n}\n.analytics .impac-kpi .kpi .kpi-edit button.im-fab.im-warn,\n.analytics .impac-kpi .kpi .kpi-no-data button.im-fab.im-warn {\n  background: #e01f74;\n}\n.analytics .impac-kpi .kpi .kpi-edit button.im-fab.im-warn:hover,\n.analytics .impac-kpi .kpi .kpi-no-data button.im-fab.im-warn:hover {\n  transition: background 0.1s ease-in;\n  background: #ca1c68;\n}\n.analytics .impac-kpi .kpi button.kpi-alerts.im-fab.im-primary {\n  position: absolute;\n  top: -12px;\n  right: 15px;\n  width: 22px;\n  height: 22px;\n  font-size: 13px;\n  background: #4c4749;\n}\n.analytics .impac-kpi .kpi button.kpi-alerts.im-fab.im-primary:hover {\n  backgroud: #358fdc;\n}\n.analytics .impac-kpi .kpi button.kpi-remove.im-fab.im-warn {\n  position: absolute;\n  top: -12px;\n  right: -11px;\n  width: 22px;\n  height: 22px;\n  font-size: 13px;\n  background: #4c4749;\n}\n.analytics .impac-kpi .kpi button.kpi-remove.im-fab.im-warn:hover {\n  background: #ca1c68;\n}\n.analytics .impac-kpi .kpi .kpi-data-loader {\n  width: 100%;\n  min-height: 95px;\n}\n.analytics kpis-bar > .key-stats .kpi {\n  min-height: 80px;\n}\n.analytics kpis-bar > .kpis {\n  position: relative;\n}\n.analytics kpis-bar > .kpis .actions {\n  margin-bottom: 12px;\n  /* Flatten der Bootstrap */\n}\n@media screen and (max-width: 675px) {\n  .analytics kpis-bar > .kpis .actions {\n    position: relative;\n  }\n}\n.analytics kpis-bar > .kpis .actions .well,\n.analytics kpis-bar > .kpis .actions .navbar-inner,\n.analytics kpis-bar > .kpis .actions .popover,\n.analytics kpis-bar > .kpis .actions .btn,\n.analytics kpis-bar > .kpis .actions .tooltip,\n.analytics kpis-bar > .kpis .actions input,\n.analytics kpis-bar > .kpis .actions select,\n.analytics kpis-bar > .kpis .actions textarea,\n.analytics kpis-bar > .kpis .actions pre,\n.analytics kpis-bar > .kpis .actions .progress,\n.analytics kpis-bar > .kpis .actions .modal,\n.analytics kpis-bar > .kpis .actions .add-on,\n.analytics kpis-bar > .kpis .actions .alert,\n.analytics kpis-bar > .kpis .actions .table-bordered,\n.analytics kpis-bar > .kpis .actions .nav > .active > a,\n.analytics kpis-bar > .kpis .actions .dropdown-menu,\n.analytics kpis-bar > .kpis .actions .tooltip-inner,\n.analytics kpis-bar > .kpis .actions .badge,\n.analytics kpis-bar > .kpis .actions .label,\n.analytics kpis-bar > .kpis .actions .img-polaroid {\n  -moz-box-shadow: none !important;\n  -webkit-box-shadow: none !important;\n  box-shadow: none !important;\n  -webkit-border-radius: 0px !important;\n  -moz-border-radius: 0px !important;\n  border-radius: 0px !important;\n  border-collapse: collapse !important;\n  background-image: none !important;\n}\n.analytics kpis-bar > .kpis .actions body,\n.analytics kpis-bar > .kpis .actions input,\n.analytics kpis-bar > .kpis .actions select,\n.analytics kpis-bar > .kpis .actions textarea {\n  box-sizing: border-box;\n}\n.analytics kpis-bar > .kpis .actions body::after,\n.analytics kpis-bar > .kpis .actions input::after,\n.analytics kpis-bar > .kpis .actions select::after,\n.analytics kpis-bar > .kpis .actions textarea::after,\n.analytics kpis-bar > .kpis .actions body::before,\n.analytics kpis-bar > .kpis .actions input::before,\n.analytics kpis-bar > .kpis .actions select::before,\n.analytics kpis-bar > .kpis .actions textarea::before {\n  box-sizing: border-box;\n}\n.analytics kpis-bar > .kpis .actions input[type=number]::-webkit-inner-spin-button,\n.analytics kpis-bar > .kpis .actions input[type=number]::-webkit-outer-spin-button {\n  -webkit-appearance: none;\n  margin: 0;\n}\n.analytics kpis-bar > .kpis .actions a:hover {\n  text-decoration: none;\n}\n.analytics kpis-bar > .kpis .actions fieldset {\n  margin: 0 0 1.75rem;\n  padding: 0;\n  border: none;\n}\n.analytics kpis-bar > .kpis .actions .im-form-radio,\n.analytics kpis-bar > .kpis .actions .im-form-group {\n  position: relative;\n  margin-top: 1.3125rem;\n  margin-bottom: 1.3125rem;\n}\n.analytics kpis-bar > .kpis .actions .im-form-inline {\n  display: flex;\n  flex-direction: row;\n  box-sizing: border-box;\n}\n.analytics kpis-bar > .kpis .actions .im-form-inline > .im-form-group {\n  display: block;\n  flex: 1;\n  position: relative;\n  vertical-align: middle;\n  margin-left: 0.175rem;\n  margin-right: 0.175rem;\n}\n.analytics kpis-bar > .kpis .actions .im-form-inline > .btn {\n  display: inline-block;\n  margin-bottom: 0;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group input {\n  height: 2.375rem;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group textarea {\n  resize: none;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group select {\n  width: 100%;\n  font-size: 1.25rem;\n  height: 2rem;\n  padding: 0.15625rem 0.15625rem 0.078125rem;\n  background: none;\n  border: none;\n  line-height: 1.6;\n  box-shadow: none;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group .im-control-label {\n  position: absolute;\n  top: 0.3125rem;\n  pointer-events: none;\n  padding-left: 0.15625rem;\n  z-index: 1;\n  color: #b3b3b3;\n  font-size: 1.25rem;\n  font-weight: normal;\n  transition: all 0.28s ease;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group .im-bar {\n  position: relative;\n  border-bottom: 0.078125rem solid #999;\n  display: block;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group .im-bar::before {\n  content: '';\n  height: 0.15625rem;\n  width: 0;\n  left: 50%;\n  bottom: -0.078125rem;\n  position: absolute;\n  background: #358fdc;\n  transition: left 0.28s ease, width 0.28s ease;\n  z-index: 2;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group input,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea {\n  display: block;\n  background: none;\n  padding: 0.15625rem 0.15625rem 0.078125rem;\n  font-size: 1.25rem;\n  border-width: 0;\n  border-color: transparent;\n  line-height: 1.9;\n  width: 100%;\n  color: transparent;\n  transition: all 0.28s ease;\n  box-shadow: none;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group input[type=\"file\"] {\n  line-height: 1;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group input[type=\"file\"] ~ .im-bar {\n  display: none;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group select,\n.analytics kpis-bar > .kpis .actions .im-form-group input:focus,\n.analytics kpis-bar > .kpis .actions .im-form-group input:valid,\n.analytics kpis-bar > .kpis .actions .im-form-group input.form-file,\n.analytics kpis-bar > .kpis .actions .im-form-group input.has-value,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea:focus,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea:valid,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea.form-file,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea.has-value {\n  color: #333;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group select ~ .im-control-label,\n.analytics kpis-bar > .kpis .actions .im-form-group input:focus ~ .im-control-label,\n.analytics kpis-bar > .kpis .actions .im-form-group input:valid ~ .im-control-label,\n.analytics kpis-bar > .kpis .actions .im-form-group input.form-file ~ .im-control-label,\n.analytics kpis-bar > .kpis .actions .im-form-group input.has-value ~ .im-control-label,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea:focus ~ .im-control-label,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea:valid ~ .im-control-label,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea.form-file ~ .im-control-label,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea.has-value ~ .im-control-label {\n  font-size: 1rem;\n  color: #808080;\n  top: -1.25rem;\n  left: 0;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group select:focus,\n.analytics kpis-bar > .kpis .actions .im-form-group input:focus,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea:focus {\n  outline: none;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group select:focus ~ .im-control-label,\n.analytics kpis-bar > .kpis .actions .im-form-group input:focus ~ .im-control-label,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea:focus ~ .im-control-label {\n  color: #358fdc;\n}\n.analytics kpis-bar > .kpis .actions .im-form-group select:focus ~ .im-bar::before,\n.analytics kpis-bar > .kpis .actions .im-form-group input:focus ~ .im-bar::before,\n.analytics kpis-bar > .kpis .actions .im-form-group textarea:focus ~ .im-bar::before {\n  width: 100%;\n  left: 0;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox label,\n.analytics kpis-bar > .kpis .actions .im-form-radio label {\n  position: relative;\n  cursor: pointer;\n  padding-left: 2.5rem;\n  text-align: left;\n  color: #333;\n  display: block;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox input,\n.analytics kpis-bar > .kpis .actions .im-form-radio input {\n  width: auto;\n  opacity: 0.00000001;\n  position: absolute;\n  left: 0;\n}\n.analytics kpis-bar > .kpis .actions .im-radio {\n  margin-bottom: 1.25rem;\n}\n.analytics kpis-bar > .kpis .actions .im-radio .im-helper {\n  position: absolute;\n  top: -0.3125rem;\n  left: -0.3125rem;\n  cursor: pointer;\n  display: block;\n  font-size: 1.25rem;\n  user-select: none;\n  color: #999;\n}\n.analytics kpis-bar > .kpis .actions .im-radio .im-helper::before,\n.analytics kpis-bar > .kpis .actions .im-radio .im-helper::after {\n  content: '';\n  position: absolute;\n  left: 0;\n  top: 0;\n  margin: 0.3125rem;\n  width: 1.25rem;\n  height: 1.25rem;\n  transition: transform 0.28s ease;\n  border-radius: 50%;\n  border: 0.15625rem solid currentColor;\n}\n.analytics kpis-bar > .kpis .actions .im-radio .im-helper::after {\n  transform: scale(0);\n  background-color: #358fdc;\n  border-color: #358fdc;\n}\n.analytics kpis-bar > .kpis .actions .im-radio label:hover .im-helper {\n  color: #358fdc;\n}\n.analytics kpis-bar > .kpis .actions .im-radio input:checked ~ .im-helper::after {\n  transform: scale(0.5);\n}\n.analytics kpis-bar > .kpis .actions .im-radio input:checked ~ .im-helper::before {\n  color: #358fdc;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox {\n  margin-top: 1.75rem;\n  margin-bottom: 1.25rem;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox .im-helper {\n  color: #999;\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 1.25rem;\n  height: 1.25rem;\n  z-index: 0;\n  border: 0.15625rem solid currentColor;\n  border-radius: 0.078125rem;\n  transition: border-color 0.28s ease;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox .im-helper::before,\n.analytics kpis-bar > .kpis .actions .im-checkbox .im-helper::after {\n  position: absolute;\n  height: 0;\n  width: 0.25rem;\n  background-color: #358fdc;\n  display: block;\n  transform-origin: left top;\n  border-radius: 0.3125rem;\n  content: '';\n  transition: opacity 0.28s ease, height 0s linear 0.28s;\n  opacity: 0;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox .im-helper::before {\n  top: 0.8125rem;\n  left: 0.475rem;\n  transform: rotate(-135deg);\n  box-shadow: 0 0 0 0.078125rem #fff;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox .im-helper::after {\n  top: 0.375rem;\n  left: 0;\n  transform: rotate(-45deg);\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox label:hover .im-helper {\n  color: #358fdc;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox input:checked ~ .im-helper {\n  color: #358fdc;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox input:checked ~ .im-helper::after,\n.analytics kpis-bar > .kpis .actions .im-checkbox input:checked ~ .im-helper::before {\n  opacity: 1;\n  transition: height 0.28s ease;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox input:checked ~ .im-helper::after {\n  height: 0.625rem;\n}\n.analytics kpis-bar > .kpis .actions .im-checkbox input:checked ~ .im-helper::before {\n  height: 1.5rem;\n  transition-delay: 0.28s;\n}\n.analytics kpis-bar > .kpis .actions .im-radio + .im-radio,\n.analytics kpis-bar > .kpis .actions .im-checkbox + .im-checkbox {\n  margin-top: 1.25rem;\n}\n.analytics kpis-bar > .kpis .actions .im-messages {\n  font-size: 1.04166667rem;\n  color: #e01f74;\n  overflow: hidden;\n  transition: all 0.28s cubic-bezier(0.55, 0, 0.55, 0.2);\n  opacity: 0;\n  margin-top: 0;\n  padding-top: 5px;\n}\n.analytics kpis-bar > .kpis .actions .has-error .legend.legend,\n.analytics kpis-bar > .kpis .actions .has-error.im-form-group .im-control-label.im-control-label {\n  color: #e01f74;\n}\n.analytics kpis-bar > .kpis .actions .has-error.im-form-group .im-messages,\n.analytics kpis-bar > .kpis .actions .has-error.im-checkbox .im-messages,\n.analytics kpis-bar > .kpis .actions .has-error.im-radio .im-messages,\n.analytics kpis-bar > .kpis .actions .has-error.im-form-radio .im-messages,\n.analytics kpis-bar > .kpis .actions .has-error.im-form-group .im-helper,\n.analytics kpis-bar > .kpis .actions .has-error.im-checkbox .im-helper,\n.analytics kpis-bar > .kpis .actions .has-error.im-radio .im-helper,\n.analytics kpis-bar > .kpis .actions .has-error.im-form-radio .im-helper {\n  color: #e01f74;\n  opacity: 1;\n}\n.analytics kpis-bar > .kpis .actions .has-error .im-bar::before {\n  background: #e01f74;\n  left: 0;\n  width: 100%;\n}\n.analytics kpis-bar > .kpis .actions .im-button {\n  position: relative;\n  background: #60a7e4;\n  border: 0;\n  font-size: 1.375rem;\n  color: #333;\n  margin: 0.7rem 0;\n  padding: 0.4375rem 1.75rem;\n  border-radius: 3px;\n  cursor: pointer;\n  overflow: hidden;\n  box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n}\n.analytics kpis-bar > .kpis .actions .im-button span {\n  color: #fff;\n  position: relative;\n  z-index: 1;\n}\n.analytics kpis-bar > .kpis .actions .im-button:hover {\n  transition: background 0.1s ease-in;\n  background: #2583d3;\n}\n.analytics kpis-bar > .kpis .actions .im-button:active {\n  box-shadow: inset 0 2px 2px 0 rgba(0, 0, 0, 0.14);\n}\n.analytics kpis-bar > .kpis .actions .im-button a:focus,\n.analytics kpis-bar > .kpis .actions .im-button:focus {\n  outline: none;\n  text-decoration: none;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab {\n  position: relative;\n  height: 46px;\n  width: 46px;\n  flex: 0 0 56px;\n  display: inline-block;\n  padding: 0;\n  margin: 4px;\n  border: 0;\n  border-radius: 100%;\n  overflow: hidden;\n  font-size: 20px;\n  box-shadow: 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12), 0 2px 4px -1px rgba(0, 0, 0, 0.2);\n  color: white;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab:focus {\n  outline: 0;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab:active {\n  box-shadow: inset 0 2px 2px 0 rgba(0, 0, 0, 0.14);\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.im-primary {\n  background: #358fdc;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.im-primary:hover {\n  transition: background 0.1s ease-in;\n  background: #2583d3;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.im-warn {\n  background: #e01f74;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.im-warn:hover {\n  transition: background 0.1s ease-in;\n  background: #ca1c68;\n}\n.analytics kpis-bar > .kpis .actions a {\n  color: white;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.add-kpis,\n.analytics kpis-bar > .kpis .actions button.im-fab.edit-kpis,\n.analytics kpis-bar > .kpis .actions button.im-fab.toggle-show-content {\n  position: absolute;\n  width: 40px;\n  height: 40px;\n  font-size: 18px;\n  transition: all 0.28s ease-in;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.add-kpis.im-primary,\n.analytics kpis-bar > .kpis .actions button.im-fab.edit-kpis.im-primary,\n.analytics kpis-bar > .kpis .actions button.im-fab.toggle-show-content.im-primary {\n  background: #4c4749;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.add-kpis.im-primary.disabled,\n.analytics kpis-bar > .kpis .actions button.im-fab.edit-kpis.im-primary.disabled,\n.analytics kpis-bar > .kpis .actions button.im-fab.toggle-show-content.im-primary.disabled {\n  background: #b2b5c1;\n  cursor: not-allowed;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.add-kpis.im-primary.disabled a,\n.analytics kpis-bar > .kpis .actions button.im-fab.edit-kpis.im-primary.disabled a,\n.analytics kpis-bar > .kpis .actions button.im-fab.toggle-show-content.im-primary.disabled a {\n  cursor: not-allowed;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.add-kpis.im-primary:hover:not(.disabled),\n.analytics kpis-bar > .kpis .actions button.im-fab.edit-kpis.im-primary:hover:not(.disabled),\n.analytics kpis-bar > .kpis .actions button.im-fab.toggle-show-content.im-primary:hover:not(.disabled) {\n  background: black;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.toggle-show-content {\n  top: -15px;\n  right: -15px;\n  z-index: 10;\n}\n@media screen and (max-width: 675px) {\n  .analytics kpis-bar > .kpis .actions button.im-fab.toggle-show-content {\n    top: -30px;\n    right: -14px;\n    bottom: 0;\n  }\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.add-kpis {\n  top: 30px;\n  right: -15px;\n  z-index: 10;\n}\n@media screen and (max-width: 675px) {\n  .analytics kpis-bar > .kpis .actions button.im-fab.add-kpis {\n    top: -30px;\n    right: 33px;\n    bottom: 0;\n  }\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.edit-kpis {\n  top: 75px;\n  right: -15px;\n  z-index: 10;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.edit-kpis.editing {\n  background: #358fdc;\n}\n.analytics kpis-bar > .kpis .actions button.im-fab.edit-kpis.editing:hover:not(.disabled) {\n  background: #76b3e7;\n}\n@media screen and (max-width: 675px) {\n  .analytics kpis-bar > .kpis .actions button.im-fab.edit-kpis {\n    top: -30px;\n    right: 79px;\n    bottom: 0;\n  }\n}\n.analytics kpis-bar > .kpis .content-buttons {\n  position: absolute;\n  top: 0;\n  right: 0;\n}\n.analytics kpis-bar > .kpis .content {\n  padding: 15px;\n  background-color: white;\n  box-shadow: 0px 1px 8px -4px;\n}\n@media screen and (min-width: 725px) {\n  .analytics kpis-bar > .kpis .content {\n    padding: 0 60px;\n  }\n}\n@media screen and (max-width: 675px) {\n  .analytics kpis-bar > .kpis .content {\n    margin-top: 25px;\n  }\n}\n.analytics kpis-bar > .kpis .content .impac-kpi {\n  padding-left: 5px;\n  padding-right: 5px;\n}\n@media screen and (min-width: 1200px) {\n  .analytics kpis-bar > .kpis .content .impac-kpi {\n    padding-left: 20px;\n    padding-right: 20px;\n  }\n}\n.analytics kpis-bar > .kpis .content .impac-kpi .kpi.add .kpi-show .caption {\n  white-space: inherit;\n}\n.analytics kpis-bar > .kpis .content .title .text-center {\n  line-height: 3;\n  font-variant: small-caps;\n  font-size: larger;\n}\n.analytics kpis-bar > .kpis .content .title .badge {\n  position: absolute;\n  top: 8px;\n  left: -10px;\n  background-color: #d1e55c;\n  color: #4f5959;\n  box-shadow: 0px 1px 3px -1px;\n}\n.analytics kpis-bar > .kpis .content .title .no-kpi-templates {\n  color: #afadb5;\n  font-weight: 500;\n}\n.analytics kpis-bar > .kpis .content .add-bar {\n  border-bottom: dashed 1px;\n}\n.analytics kpis-bar > .kpis .content .kpi-loader {\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  min-height: 115px;\n}\n.analytics kpis-bar > .kpis .content .dates-picker-container {\n  width: 40%;\n  margin: 0 auto;\n}\n.analytics kpis-bar > .kpis .content .dates-picker-container .sdp-from-label,\n.analytics kpis-bar > .kpis .content .dates-picker-container .sdp-to-label {\n  text-transform: uppercase;\n  font-weight: 400;\n}\n.analytics kpis-bar {\n  display: block;\n}\n.analytics kpis-bar > .key-stats {\n  background-color: white;\n  padding: 5px 0px;\n}\n.analytics.pdf-mode kpis-bar > .kpis .actions {\n  display: none;\n}\n.widget-item {\n  transition: width 0.3s;\n  padding: 12px;\n}\n.widget-item.pdf-mode {\n  width: 100%;\n  padding: 12px 0px;\n}\n.widget-item .top-line {\n  position: relative;\n  cursor: move;\n  background-color: white;\n  padding: 9px 9px 0px 12px;\n  border-radius: 5px 5px 0px 0px;\n  border: solid 1px #c8d7d9;\n  border-bottom: none;\n  min-height: 41px;\n  -webkit-box-shadow: 0px 1px 8px -4px;\n  box-shadow: 0px 1px 8px -4px;\n  display: flex;\n  flex-direction: row;\n  z-index: 4;\n}\n.widget-item .content {\n  position: relative;\n  padding: 9px;\n  border-radius: 0px 0px 5px 5px;\n  border: solid 1px #c8d7d9;\n  border-top: none;\n  background-color: white;\n  vertical-align: top;\n  -webkit-box-shadow: 0px 1px 8px -4px;\n  box-shadow: 0px 1px 8px -4px;\n  min-height: 250px;\n}\n@media (min-width: 992px) {\n  .widget-item .content {\n    height: 250px;\n  }\n  .widget-item .content .chart-container {\n    max-width: 270px;\n    max-height: 125px;\n    margin: auto;\n  }\n}\n.widget-item .content .edit {\n  max-height: 230px;\n}\n.widget-item .content .edit {\n  overflow-y: auto;\n  overflow-x: hidden;\n  color: #5B6667;\n  padding: 2px;\n  font-size: 12px;\n}\n.widget-item .content .edit .bottom-buttons .btn {\n  border-radius: 2px;\n  margin-right: 5px;\n  padding: 3px 13px;\n  text-transform: uppercase;\n  font-size: 12px;\n}\n.widget-item .content .edit .bottom-buttons .btn.btn-default {\n  background-color: #c2c4c4;\n  border: solid 1px #a8abab;\n  color: white;\n}\n.widget-item .content .edit .bottom-buttons .btn.btn-default:hover {\n  border: solid 1px #8e9292;\n  background-color: #a8abab;\n}\n.widget-item .content .edit h4 {\n  margin: 0;\n  margin-bottom: 8px;\n  text-align: left;\n  font-weight: normal;\n  font-size: 12px;\n  color: #c4caca;\n}\n.widget-item .content .edit .part {\n  margin-bottom: 8px;\n  padding: 10px 0px;\n  background-color: #fcfcfc;\n  border: solid 1px #dfe2e2;\n}\n.widget-item .content .edit .part h5 {\n  display: block;\n  margin: 0;\n  margin-bottom: 10px;\n  padding: 0px 15px;\n  text-transform: uppercase;\n  font-weight: normal;\n  font-size: 12px;\n  color: #c4caca;\n}\n.widget-item .content .edit .part label {\n  font-weight: normal;\n}\n.widget-item .content .edit .part select.form-control {\n  margin: 0px;\n  border: solid 1px #acb0b1;\n  outline: none;\n  -webkit-box-shadow: none;\n  font-size: 13px;\n  color: #72728b;\n}\n.widget-item .content.accessible {\n  height: auto !important;\n  min-height: 250px !important;\n  max-height: auto !important;\n}\n.widget-item .content .content-template-wrapper {\n  height: 100%;\n  overflow: auto;\n  overflow-x: hidden;\n}\n.widget-item.pdf-mode .content {\n  height: 100% !important;\n  min-height: 250px !important;\n  max-height: none !important;\n}\n.widget-item.pdf-mode .content .collapse {\n  display: inherit;\n}\n.widget-item.pdf-mode .content .fa-plus-square-o:before {\n  content: \"\\f147\";\n}\n.widget-item.pdf-mode .content .legend {\n  max-height: none !important;\n}\n.widget-item.pdf-mode .content .chart-container {\n  max-height: none;\n}\n.widget-item.pdf-mode .content .widget-lines-container {\n  max-height: none !important;\n}\n.widget-item.pdf-mode .content .data-not-found .message {\n  position: inherit;\n  width: 100%;\n}\n.widget-item.pdf-mode .include-to-pdf.title {\n  position: absolute;\n  width: calc(100% - 2*12px );\n  z-index: 3;\n  padding-right: 1px;\n}\n.widget-item.pdf-mode .include-to-pdf.title h6 {\n  padding: 10px;\n  background-color: #FFC928;\n  text-align: center;\n  margin: 0;\n}\n.widget-item.pdf-mode .include-to-pdf.tick i {\n  position: absolute;\n  top: 35%;\n  left: 46%;\n  font-size: 100px;\n  opacity: .5;\n  z-index: 2;\n  color: black;\n}\n.widget-item.pdf-mode .include-to-pdf .widget-hover {\n  position: absolute;\n  width: 100%;\n  height: 100%;\n  padding: 9px;\n  top: 0;\n  right: 0;\n  -webkit-transition: all ease .5s;\n  -moz-transition: all ease .5s;\n  transition: all ease .5s;\n  z-index: 1;\n}\n.widget-item.pdf-mode .include-to-pdf .widget-hover:hover {\n  opacity: .5;\n  background: #CCCFD0;\n}\n.widget-item .widget-lines-container .widget-line > [class*='col-'] {\n  overflow-wrap: break-word;\n}\n.analytics .widget-item .content .data-not-found,\n.analytics .kpi .data-not-found {\n  text-align: center;\n  font-size: 13px;\n  color: #5B6667;\n}\n.analytics .widget-item .content .data-not-found .overlay,\n.analytics .kpi .data-not-found .overlay {\n  background-color: white;\n  position: absolute;\n  height: calc(100% - 4px);\n  width: calc(100% - 4px);\n  top: 2px;\n  left: 2px;\n  opacity: 0.6;\n  z-index: 3;\n}\n.analytics .widget-item .content .data-not-found .message,\n.analytics .kpi .data-not-found .message {\n  position: absolute;\n  top: 125px;\n  left: 50%;\n  padding-bottom: 10px;\n  transform: translate(-50%, -50%);\n  width: 85%;\n  background-color: #f4f8f9;\n  border-radius: 4px;\n  box-shadow: 0px 0px 25px 0px;\n  z-index: 4;\n}\n.analytics .widget-item .content .data-not-found .message .title,\n.analytics .kpi .data-not-found .message .title {\n  padding: 2px;\n  background-color: #192831;\n  color: white;\n  margin: -1px -1px 10px -1px;\n  text-transform: uppercase;\n}\n.analytics .widget-item .content .data-not-found .message p,\n.analytics .kpi .data-not-found .message p {\n  margin-left: 5px;\n  margin-right: 5px;\n}\n.analytics .widget-item .content .data-not-found .message .btn,\n.analytics .kpi .data-not-found .message .btn {\n  margin-top: 5px;\n}\n.analytics .widget-item .content .data-not-found .example,\n.analytics .kpi .data-not-found .example {\n  position: absolute;\n  bottom: 0px;\n  left: 0px;\n  width: 100%;\n  color: white;\n  background-color: #192831;\n  padding: 3px;\n  z-index: 6;\n}\n.analytics .widget-item .content .data-not-found .example a,\n.analytics .kpi .data-not-found .example a {\n  font-weight: normal;\n  color: #dae173;\n}\n.analytics .kpi .data-not-found .message {\n  width: 90%;\n  padding-bottom: 0px;\n  border: solid 1px silver;\n  box-shadow: none;\n}\n.analytics .kpi .data-not-found .message p {\n  margin: 5px;\n}\n.analytics .kpi .data-not-found .overlay,\n.analytics .kpi .data-not-found .title,\n.analytics .kpi .data-not-found .btn,\n.analytics .kpi .data-not-found .example {\n  display: none;\n}\n#duplicate-transactions-list .top {\n  height: 40px;\n}\n#duplicate-transactions-list .top a.back-link {\n  font-weight: normal;\n}\n#duplicate-transactions-list .top .pagination {\n  margin: 0px;\n}\n#duplicate-transactions-list .table-striped tr.origin:nth-of-type(odd) {\n  background-color: #f9f9f9;\n}\n#duplicate-transactions-list .table-container {\n  max-height: calc(565px - 60px);\n  overflow: auto;\n}\n#duplicate-transactions-list .table-container div[uib-datepicker-popup-wrap] {\n  display: inline-block;\n}\n#duplicate-transactions-list .table-container input.btn.btn-xs {\n  margin-top: -2px;\n}\n#duplicate-transactions-list .table-container button.btn.reset-date {\n  margin-top: -2px;\n}\n#duplicate-transactions-list .table-container .fa.fa-times {\n  color: #e01f74;\n  cursor: pointer;\n}\n#duplicate-transactions-list .table-container tr.total {\n  font-weight: bold;\n}\n#duplicate-transactions-list .table-container tr.total.invoices {\n  background-color: #00e600;\n}\n#duplicate-transactions-list .table-container tr.total.bills {\n  background-color: #f57cb1;\n}\n#transactions-add {\n  text-align: center;\n  font-size: 13px;\n  color: #5B6667;\n}\n#transactions-add .overlay {\n  background-color: white;\n  position: absolute;\n  height: calc(100% - 4px);\n  width: calc(100% - 4px);\n  top: 2px;\n  left: 2px;\n  opacity: 0.6;\n  z-index: 5;\n}\n#transactions-add .message {\n  z-index: 6;\n  position: absolute;\n  min-height: 160px;\n  padding-bottom: 10px;\n  top: 45px;\n  left: 7%;\n  width: 86%;\n  background-color: #f4f8f9;\n  border-radius: 4px;\n  box-shadow: 0px 0px 25px 0px;\n}\n#transactions-add .message .title {\n  padding: 2px;\n  background-color: #192831;\n  color: white;\n  margin: -1px -1px 10px -1px;\n  text-transform: uppercase;\n}\n#transactions-add .message {\n  top: 30px;\n  left: 35%;\n  width: 30%;\n}\n#transactions-add .message .form {\n  padding: 0px 10px;\n}\n#transactions-add .message .form > label,\n#transactions-add .message .form .schedulable-section > label {\n  padding-top: 10px;\n  font-weight: normal;\n  margin-bottom: 3px;\n}\n#transactions-add .message .form input.form-control,\n#transactions-add .message .form select.form-control {\n  width: 90%;\n  border-radius: 2px;\n  height: 28px;\n  font-size: 13px;\n}\n#transactions-add .message .form .btn-group {\n  display: block;\n  min-height: 22px;\n}\n#transactions-add .message .form .btn-group select {\n  border-radius: 2px;\n  height: 28px;\n  margin-top: 0px;\n}\n#transactions-add .message .form .disable {\n  color: #888888;\n  font-style: italic;\n}\n#transactions-add .message .form .never-disable {\n  color: black;\n  font-style: normal;\n}\n#transactions-add .message .form .repeat-btn {\n  margin-top: 30px;\n}\n#transactions-add .message .form .repeat-btn input[type=\"checkbox\"] {\n  vertical-align: text-bottom;\n  margin: 0px;\n}\n#transactions-add .message .form .repeat-btn select {\n  height: 22px;\n}\n#transactions-add .message .form .repeat-btn .btn {\n  float: none;\n  border-color: #888888;\n}\n#transactions-add .message .form .schedulable-section {\n  padding: 5px;\n  border: solid 1px silver;\n  margin-top: 0px;\n  background-color: white;\n}\n#transactions-add .message .form .schedulable-section .badge {\n  font-weight: normal;\n  background-color: #888888;\n}\n#transactions-add .message .form .schedulable-section .interval-field {\n  width: 40px;\n}\n#transactions-add .message .form .schedulable-section .btn-group {\n  margin-left: 10px;\n}\n#transactions-add .message .form .schedulable-section .btn-group select {\n  height: 22px;\n}\n#transactions-add .message .form .schedulable-section .btn-group .btn {\n  float: none;\n  border-color: #888888;\n}\n#transactions-add .message .bottom {\n  margin-top: 20px;\n}\n#transactions-list .top {\n  height: 40px;\n  position: relative;\n}\n#transactions-list .top .back {\n  position: absolute;\n}\n#transactions-list .top .resource-type {\n  position: absolute;\n  left: calc(50% - 98px);\n}\n@media (max-width: 767px) {\n  #transactions-list .top .resource-type {\n    left: unset;\n    right: 0;\n  }\n}\n#transactions-list .top .btn-group {\n  display: flex;\n}\n#transactions-list .bottom {\n  height: 40px;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n}\n#transactions-list .bottom .pagination {\n  margin: 0px;\n}\n#transactions-list .table-container {\n  max-height: calc(565px - 100px);\n  overflow: auto;\n  width: 100%;\n}\n#transactions-list .table-container div[uib-datepicker-popup-wrap] {\n  display: inline-block;\n}\n#transactions-list .table-container input.btn.btn-xs {\n  margin-top: -2px;\n}\n#transactions-list .table-container button.btn.reset-date {\n  margin-top: -2px;\n}\n#transactions-list .table-container .actions {\n  cursor: pointer;\n}\n#transactions-list .table-container .actions .fa.fa-times {\n  color: #e01f74;\n}\n#transactions-list .table-container tr.total {\n  font-weight: bold;\n}\n#transactions-list .table-container tr.total.invoices {\n  background-color: #c1d1b1;\n}\n#transactions-list .table-container tr.total.bills {\n  background-color: #e2aeb9;\n}\n#transactions-list .table-container td > .expected-payment-date {\n  display: flex;\n}\n#transactions-list .table-container td > .expected-payment-date .reset-date {\n  margin-left: 3px;\n}\n#trends-add {\n  text-align: center;\n  font-size: 13px;\n  color: #5B6667;\n}\n#trends-add .overlay {\n  background-color: white;\n  position: absolute;\n  height: calc(100% - 4px);\n  width: calc(100% - 4px);\n  top: 2px;\n  left: 2px;\n  opacity: 0.6;\n  z-index: 5;\n}\n#trends-add .message {\n  z-index: 6;\n  position: absolute;\n  min-height: 160px;\n  padding-bottom: 10px;\n  top: 45px;\n  left: 7%;\n  width: 86%;\n  background-color: #f4f8f9;\n  border-radius: 4px;\n  box-shadow: 0px 0px 25px 0px;\n}\n#trends-add .message .title {\n  padding: 2px;\n  background-color: #192831;\n  color: white;\n  margin: -1px -1px 10px -1px;\n  text-transform: uppercase;\n}\n#trends-add .message {\n  top: 30px;\n  left: 35%;\n  width: 30%;\n}\n#trends-add .message .form {\n  padding: 0px 10px;\n}\n#trends-add .message .form > label {\n  padding-top: 10px;\n  font-weight: normal;\n  margin-bottom: 3px;\n}\n#trends-add .message .form input.form-control {\n  width: 90%;\n  border-radius: 2px;\n  height: 28px;\n  font-size: 13px;\n}\n#trends-add .message .form .btn-group {\n  display: block;\n  min-height: 22px;\n  margin-top: 10px;\n}\n#trends-add .message .form .btn-group > .btn {\n  float: none;\n}\n#trends-add .message .form .btn-group input[type=\"radio\"] {\n  margin: 4px 0 10px;\n}\n#trends-add .message .bottom {\n  margin-top: 20px;\n}\n#trends-list .top {\n  height: 40px;\n}\n#trends-list .top a.back-link {\n  font-weight: normal;\n}\n#trends-list .top .pagination {\n  margin: 0px;\n}\n#trends-list .table-container {\n  max-height: calc(565px - 60px);\n  overflow: auto;\n}\n#trends-list .table-container div[uib-datepicker-popup-wrap] {\n  display: inline-block;\n}\n#trends-list .table-container input.btn.btn-xs {\n  margin-top: -2px;\n}\n#trends-list .table-container button.btn.reset-date {\n  margin-top: -2px;\n}\n.analytics .dashboard-settings.currency {\n  text-align: right;\n}\n.analytics .dashboard-settings.currency select {\n  margin-top: 4px;\n}\n.analytics .dashboard-settings.sync-apps .show-status {\n  margin-right: 5px;\n  color: #9ba6a7;\n}\n.analytics .dashboard-settings.sync-apps .show-status:hover {\n  cursor: pointer;\n  text-decoration: underline;\n}\n.analytics .dashboard-settings.sync-apps .show-status .fa.fa-info {\n  margin-right: 2px;\n}\n.analytics .dashboard-settings.sync-apps .status-btn {\n  display: inline-block;\n  cursor: pointer;\n  padding: 5px 7px 5px 0px;\n}\n.analytics .dashboard-settings.sync-apps .status-btn i {\n  font-size: 16px;\n}\n.analytics .dashboard-settings.sync-apps .status-btn i.fa-exclamation-triangle {\n  color: #ff7300;\n}\n.analytics .dashboard-settings.sync-apps .status-btn i.fa-check {\n  color: #d1e55c;\n}\n.analytics .dashboard-settings.sync-apps .popover {\n  max-width: 550px;\n}\n.analytics .dashboard-settings.sync-apps .popover .connector {\n  padding: 4px 13px;\n}\n.analytics .dashboard-settings.sync-apps .popover .connector.add-seperator {\n  border-bottom: 1px solid #ccc;\n}\n.analytics .dashboard-settings.sync-apps .popover .popover-content {\n  padding: 0;\n}\n.analytics .dashboard-settings.sync-apps .popover .popover-footer {\n  border-top: 1px solid #ccc;\n  padding: 4px 13px;\n}\n.analytics .dashboard-settings.sync-apps .popover .popover-footer p {\n  font-weight: bold;\n  margin: 0;\n}\n.analytics .dashboard-settings.sync-apps .popover .popover-footer.remove-seperator {\n  border: 0;\n}\n.analytics .dashboard-settings.sync-apps .badge {\n  float: right;\n  margin-left: 8px;\n}\n.analytics .dashboard-settings.sync-apps .success .badge {\n  background-color: #d1e55c;\n}\n.analytics .dashboard-settings.sync-apps .pending .badge {\n  background-color: #ff7300;\n}\n.analytics .dashboard-settings.sync-apps .running .badge {\n  background-color: #ff7300;\n}\n.analytics .dashboard-settings.sync-apps .error .badge {\n  background-color: #ed1e79;\n}\n.analytics .dashboard-settings.sync-apps .failed .badge {\n  background-color: #ed1e79;\n}\n.analytics .dashboard-settings.sync-apps .unknown .badge {\n  background-color: #ed1e79;\n}\n.analytics .dashboard-settings.sync-apps .disconnected .badge {\n  background-color: #ed1e79;\n}\n#sync-apps-modal .modal-header {\n  text-align: center;\n  border: 0;\n  box-shadow: 0px 2px 3px 0px #ccc;\n}\n#sync-apps-modal .modal-list {\n  max-height: 280px;\n  overflow-y: auto;\n}\n#sync-apps-modal .modal-list-item {\n  border-bottom: 1px solid #ccc;\n  padding: 10px;\n}\n#sync-apps-modal .modal-list-item .badge {\n  float: right;\n}\n#sync-apps-modal .modal-list-item.success .badge {\n  background-color: #d1e55c;\n}\n#sync-apps-modal .modal-list-item.pending .badge {\n  background-color: #ff7300;\n}\n#sync-apps-modal .modal-list-item.running .badge {\n  background-color: #ff7300;\n}\n#sync-apps-modal .modal-list-item.error .badge {\n  background-color: #ed1e79;\n}\n#sync-apps-modal .modal-list-item.failed .badge {\n  background-color: #ed1e79;\n}\n#sync-apps-modal .modal-list-item.unknown .badge {\n  background-color: #ed1e79;\n}\n#sync-apps-modal .modal-list-item.disconnected .badge {\n  background-color: #ed1e79;\n}\n#sync-apps-modal .modal-list-item .message {\n  padding: 3px;\n  border-radius: 2px;\n  margin-left: 31px;\n  margin-top: 9px;\n}\n#sync-apps-modal .modal-list-item .message p {\n  margin: 0;\n}\n#sync-apps-modal .modal-list-item.success .message {\n  background-color: rgba(0, 255, 55, 0.08);\n}\n#sync-apps-modal .modal-list-item.pending .message {\n  background-color: rgba(255, 118, 0, 0.08);\n}\n#sync-apps-modal .modal-list-item.running .message {\n  background-color: rgba(255, 118, 0, 0.08);\n}\n#sync-apps-modal .modal-list-item.error .message {\n  background-color: rgba(255, 0, 0, 0.08);\n}\n#sync-apps-modal .modal-list-item.failed .message {\n  background-color: rgba(255, 0, 0, 0.08);\n}\n#sync-apps-modal .modal-list-item.unknown .message {\n  background-color: rgba(255, 0, 0, 0.08);\n}\n#sync-apps-modal .modal-list-item.disconnected .message {\n  background-color: rgba(255, 0, 0, 0.08);\n}\n#sync-apps-modal .modal-list-item.with-message {\n  cursor: pointer;\n}\n#sync-apps-modal .modal-list-item.with-message:hover {\n  background-color: #ccc;\n}\n#sync-apps-modal .modal-footer {\n  border: 0;\n}\n#sync-apps-modal .fa {\n  padding: 0px 10px;\n}\n#sync-apps-modal .fa.error {\n  color: #FF0000;\n}\n#sync-apps-modal .fa.warn {\n  color: #ff7300;\n}\n#sync-apps-modal .fa.success {\n  color: #47ff00;\n}\nchart-threshold .attach-panel {\n  padding: 5px 0;\n  display: flex;\n  justify-content: center;\n  align-items: baseline;\n  background-color: rgba(20, 132, 228, 0.16);\n}\nchart-threshold .attach-panel > div {\n  padding-right: 5px;\n}\nchart-threshold .attach-panel > div.target {\n  text-align: center;\n}\n@media (max-width: 1199px) {\n  chart-threshold .attach-panel {\n    flex-direction: column;\n    align-items: center;\n  }\n  chart-threshold .attach-panel > div {\n    padding: 5px;\n  }\n}\nchart-threshold .attach-panel .text {\n  text-transform: uppercase;\n  font-weight: bold;\n  color: #5B6667;\n  font-size: 13px;\n}\nchart-threshold .attach-panel input {\n  border-radius: 3px;\n  border: 1px white;\n  padding: 3px;\n}\nchart-threshold .attach-panel input[name=amount] {\n  max-width: 70px;\n}\nchart-threshold .attach-panel .currency {\n  font-weight: bold;\n  color: #000;\n}\nchart-threshold .attach-panel .actions {\n  display: inline-block;\n  padding: 0 2px;\n}\nchart-threshold .attach-panel .actions button {\n  padding: 3px 6px;\n  display: inline-block;\n}\nchart-threshold .attach-panel .actions button.loading {\n  padding: 3px 20px;\n}\n.analytics widgets-common-confirm-modal {\n  text-align: center;\n  font-size: 13px;\n  color: #5B6667;\n}\n.analytics widgets-common-confirm-modal .overlay {\n  background-color: white;\n  position: absolute;\n  height: calc(100% - 4px);\n  width: calc(100% - 4px);\n  top: 2px;\n  left: 2px;\n  opacity: 0.6;\n  z-index: 5;\n}\n.analytics widgets-common-confirm-modal .message {\n  z-index: 6;\n  position: absolute;\n  min-height: 160px;\n  padding-bottom: 10px;\n  top: 45px;\n  left: 7%;\n  width: 86%;\n  background-color: #f4f8f9;\n  border-radius: 4px;\n  box-shadow: 0px 0px 25px 0px;\n}\n.analytics widgets-common-confirm-modal .message .title {\n  padding: 2px;\n  background-color: #192831;\n  color: white;\n  margin: -1px -1px 10px -1px;\n  text-transform: uppercase;\n}\n.analytics widgets-common-confirm-modal .message {\n  display: flex;\n  flex-direction: column;\n  justify-content: space-between;\n}\n.analytics widgets-common-confirm-modal .message p {\n  padding: 0px 10px;\n}\n.analytics widgets-common-confirm-modal .message button.btn {\n  margin-top: 20px;\n}\n.analytics widgets-common-confirm-modal .message .loader i.fa.fa-spinner {\n  font-size: 26px;\n}\n.currency-conversions img {\n  width: 15px;\n  cursor: pointer;\n}\n.currency-conversions.popover .popover-title {\n  background-color: black;\n  color: white;\n}\n.analytics .widget-item .editable-title {\n  width: 100%;\n  flex: 1;\n  overflow: hidden;\n  height: 22px;\n}\n.analytics .widget-item .editable-title .title {\n  text-transform: uppercase;\n  font-weight: 600;\n  font-size: 12px;\n  color: #4f5959;\n  cursor: text;\n  overflow: hidden;\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  line-height: 1.9;\n}\n.analytics .widget-item .editable-title .editable-wrap {\n  position: relative;\n  height: 20px;\n  min-width: 100%;\n  white-space: nowrap;\n}\n.analytics .widget-item .editable-title .editable-wrap .editable-controls {\n  min-width: 100%;\n}\n.analytics .widget-item .editable-title .editable-wrap .editable-controls .editable-input {\n  height: 20px;\n  font-size: 12px;\n  text-transform: uppercase;\n  width: calc(100% - 65px);\n  padding: 0px 3px;\n}\n.analytics .widget-item .editable-title .editable-wrap .editable-controls .editable-buttons {\n  background-color: white;\n}\n.analytics .widget-item .editable-title .editable-wrap .editable-controls .editable-buttons button {\n  margin: 0px 0px 0px 5px;\n  height: 20px;\n  padding: 0px 5px;\n}\n.analytics .widget-item .info-panel {\n  position: absolute;\n  top: 15px;\n  left: 15px;\n  width: calc(100% - 30px);\n  max-height: calc(100% - 30px);\n  height: 100%;\n  z-index: 100;\n  background-color: white;\n  border: dotted 1px #B7CDCE;\n  display: flex;\n  flex-direction: column;\n  font-family: \"Lato Semibold\", \"Lato\";\n  z-index: 4;\n}\n.analytics .widget-item .info-panel:hover {\n  opacity: 1;\n}\n.analytics .widget-item .info-panel .i-header {\n  background-color: #FFC928;\n  color: #1E303B;\n  padding: 8px;\n  text-transform: uppercase;\n  font-family: \"Lato Medium\", \"Lato\";\n  font-size: 12px;\n}\n.analytics .widget-item .info-panel .i-header .fa {\n  font-size: 18px;\n}\n.analytics .widget-item .info-panel .i-header .fa-info-circle {\n  float: left;\n}\n.analytics .widget-item .info-panel .i-header .fa-times-circle {\n  cursor: pointer;\n  float: right;\n}\n.analytics .widget-item .info-panel .i-content {\n  overflow-y: auto;\n  overflow-x: hidden;\n  padding: 5px;\n  text-align: justify;\n  flex: 1;\n}\n.analytics .widget-item .info-panel .i-content .row {\n  margin-bottom: 6px;\n  padding-bottom: 6px;\n  border-bottom: solid 1px #abc4c6;\n}\n.analytics .widget-item .info-panel .i-content .row:last-child {\n  margin-bottom: 0;\n  padding-bottom: 0;\n  border-bottom: none;\n}\n.analytics .widget-item .info-panel .i-content .row .key {\n  text-align: right;\n  font-variant: small-caps;\n}\n@media (max-width: 991px) {\n  .analytics .widget-item .info-panel .i-content .row .key {\n    text-align: center;\n  }\n}\n.analytics .widget-item .info-panel .i-content .row .value {\n  text-align: justify;\n}\n.analytics .time-period-info {\n  font-size: 11px;\n  color: #ABC4C6;\n  text-transform: uppercase;\n}\n.analytics .widget-item .top-line .top-buttons {\n  text-align: right;\n  margin-top: -1px;\n  white-space: nowrap;\n  padding-left: 10px;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button {\n  background: transparent;\n  border: none;\n  color: #c4caca;\n  padding: 0;\n  outline: none;\n  width: 17px;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button:active,\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button:focus {\n  box-shadow: none;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-info {\n  font-size: 17px;\n  margin-top: 1px;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-info:hover {\n  color: #FFC928;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-export {\n  font-size: 17px;\n  margin-top: 1px;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-export:hover {\n  color: #358fdc;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-refresh {\n  font-size: 17px;\n  margin-top: 1px;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-refresh:hover {\n  color: #358fdc;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-edit {\n  font-size: 13px;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-edit:hover,\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-edit.edit-mode {\n  color: #cfd849;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-close {\n  font-size: 13px;\n}\n.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-close:hover {\n  color: #ed1e79;\n}\n.analytics .widget-item .content.accounts-assets-liability-summary .param-selector {\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-assets-liability-summary .legend {\n  text-align: left;\n  max-height: 90px;\n}\n.analytics .widget-item .content.accounts-assets-liability-summary .legend .title {\n  text-align: center;\n  border-bottom: dashed 1px #dfe2e2;\n}\n.analytics .widget-item .content.accounts-assets-summary .legend {\n  text-align: left;\n  max-height: 115px;\n}\n.analytics .widget-item .content.accounts-assets-summary .legend .title {\n  text-align: center;\n  border-bottom: dashed 1px #dfe2e2;\n}\n.analytics .widget-item .content.accounts-assets-vs-liabilities .legend > .title span {\n  margin-left: 3px;\n}\n.analytics .widget-item .content.accounts-balance h3 {\n  font-weight: 300;\n  font-size: 14px;\n  color: #5B6667;\n  text-align: left;\n  margin-top: 30px;\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-balance .price {\n  font-weight: 900;\n  font-size: 22px;\n  color: #5B6667;\n  text-align: center;\n  margin-top: 0px;\n}\n.analytics .widget-item .content.accounts-balance-sheet {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.accounts-balance-sheet {\n    height: 565px;\n  }\n  .analytics .widget-item .content.accounts-balance-sheet .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.accounts-balance-sheet .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.accounts-balance-sheet .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.accounts-balance-sheet .widget-lines-container {\n  overflow-y: scroll;\n  overflow-x: hidden;\n  max-height: 490px;\n}\n@media (max-width: 767px) {\n  .analytics .widget-item .content.accounts-balance-sheet .widget-lines-container .row.widget-line:not(:last-child) {\n    border-bottom: dashed 1px #dfe2e2;\n  }\n}\n.analytics .widget-item .content.accounts-balance-sheet .widget-lines-container .row.widget-line.header > [class*='col-'] {\n  position: static;\n}\n.analytics .widget-item .content.accounts-balance-sheet .widget-lines-container.no-scroll {\n  overflow: visible;\n}\n.analytics .widget-item .content.accounts-balance-sheet .no-data-block {\n  font-weight: 300;\n  font-size: 16px;\n  color: #5B6667;\n  text-align: center;\n  margin: 15px 0px;\n}\n.analytics .widget-item .content.accounts-cash-balance {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.accounts-cash-balance {\n    height: 565px;\n  }\n  .analytics .widget-item .content.accounts-cash-balance .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.accounts-cash-balance .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.accounts-cash-balance .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.accounts-cash-balance .data-container {\n  height: calc(565px - 50px);\n  width: 100%;\n}\n.analytics .widget-item .content.accounts-cash-balance .left-panel {\n  width: 180px;\n  display: inline-block;\n  overflow: auto;\n  max-height: 100%;\n}\n.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item {\n  display: flex;\n  align-items: center;\n  min-height: 45px;\n  margin: 3px;\n  font-size: 13px;\n  padding: 3px;\n  cursor: pointer;\n  user-select: none;\n}\n.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item:hover {\n  background-color: #ececec;\n}\n.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item i {\n  font-size: 19px;\n  padding: 4px;\n  margin-top: 1px;\n}\n.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item span {\n  color: #5B6667;\n}\n.analytics .widget-item .content.accounts-cash-balance .legend-item-icon {\n  width: 16px;\n  height: 16px;\n}\n.analytics .widget-item .content.accounts-cash-balance .right-panel {\n  width: calc(100% - 180px);\n  float: right;\n}\n.analytics .widget-item .content.accounts-cash-balance .right-panel .cash-balance-chart {\n  height: calc(565px - 50px);\n}\n.analytics .widget-item .content.accounts-cash-balance .dates-picker {\n  display: inline-block;\n  float: right;\n  font-size: 12px;\n}\n.analytics .widget-item .content.accounts-cash-projection {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.accounts-cash-projection {\n    height: 565px;\n  }\n  .analytics .widget-item .content.accounts-cash-projection .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.accounts-cash-projection .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.accounts-cash-projection .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.accounts-cash-projection .cash-projection-chart {\n  height: calc(565px - 50px);\n}\n.analytics .widget-item .content.accounts-cash-projection .highcharts-legend-item rect.highcharts-point {\n  display: none;\n}\n.analytics .widget-item .content.accounts-cash-projection .highcharts-legend-item span {\n  width: 110px;\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-cash-projection .highcharts-legend-item span img {\n  text-align: center;\n  width: 55px;\n  height: 25px;\n}\n.analytics .widget-item .content.accounts-cash-projection .dates-picker {\n  display: inline-block;\n  float: right;\n  font-size: 12px;\n}\n.analytics .widget-item .content.accounts-cash-projection transactions-list {\n  font-size: 12px;\n}\n.analytics .widget-item .content.accounts-cash-summary {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.accounts-cash-summary {\n    height: 565px;\n  }\n  .analytics .widget-item .content.accounts-cash-summary .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.accounts-cash-summary .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.accounts-cash-summary .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.accounts-cash-summary .widget-lines-container {\n  max-height: 540px;\n}\n.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line {\n  cursor: pointer;\n  border: solid 1px white;\n}\n.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line .selection-tag {\n  display: block;\n  right: 0px;\n  margin-top: -6px;\n  width: 10px;\n  height: 29px;\n  position: absolute;\n}\n.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line:hover {\n  background-color: #e6e0fb;\n}\n.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line.no-select {\n  cursor: auto;\n}\n.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line.no-select:hover {\n  color: #626d6d;\n}\n.analytics .widget-item .content.accounts-cash-summary .right-panel .widget-lines-container {\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: 235px;\n}\n.analytics .widget-item .content.accounts-cash-summary .no-element {\n  font-weight: 300;\n  font-size: 16px;\n  color: #5B6667;\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-cash-summary .right-panel .widget-lines-container {\n  max-height: 215px;\n}\n.analytics .widget-item .content.accounts-cash-summary .row.lines-group.cash {\n  border-top: solid 1px;\n  border-bottom: double;\n}\n.analytics .widget-item .content.accounts-class-comparison .param-selector {\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-class-comparison .widget-lines-container {\n  max-height: 94px;\n  color: #626d6d;\n}\n.analytics .widget-item .content.accounts-comparison {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.accounts-comparison {\n    height: 565px;\n  }\n  .analytics .widget-item .content.accounts-comparison .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.accounts-comparison .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.accounts-comparison .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n@media print {\n  .analytics .widget-item .content.accounts-comparison .chart-container {\n    max-width: 80% !important;\n  }\n}\n.analytics .widget-item .content.accounts-comparison .add-account {\n  position: absolute;\n  right: 40px;\n  bottom: 30px;\n  width: 160px;\n}\n.analytics .widget-item .content.accounts-comparison .add-account select {\n  font-size: 13px;\n  background-color: #977bf0;\n  color: white;\n  outline: none;\n  border: none;\n  cursor: pointer;\n}\n.analytics .widget-item .content.accounts-comparison .add-account select[disabled] {\n  cursor: not-allowed;\n  background-color: #bba9f5;\n}\n.analytics .widget-item .content.accounts-comparison .add-account select[disabled]:hover {\n  background-color: #bba9f5;\n}\n.analytics .widget-item .content.accounts-comparison .add-account select:hover {\n  background-color: #734deb;\n}\n.analytics .widget-item .content.accounts-comparison .add-account select option {\n  background-color: white;\n  color: #c4caca;\n}\n.analytics .widget-item .content.accounts-comparison .add-account select option[disabled] {\n  color: white;\n}\n.analytics .widget-item .content.accounts-comparison button.close {\n  font-size: 15px;\n}\n.analytics .widget-item .content.accounts-comparison .legend {\n  text-align: left;\n  max-height: 103px;\n}\n.analytics .widget-item .content.accounts-comparison .row {\n  margin: 0;\n}\n.analytics .widget-item .content.accounts-comparison .widget-lines-container {\n  font-size: 11px;\n  max-height: 220px;\n  margin-bottom: 65px;\n  overflow: auto;\n}\n.analytics .widget-item .content.accounts-comparison .settings.params-checkboxes {\n  margin-left: 13px;\n}\n.analytics .widget-item .content.accounts-comparison .comparable-error h5 {\n  margin-left: 13px;\n  color: #ed1e79;\n}\n.analytics .widget-item .content.accounts-custom-calculation h3 {\n  margin-top: 85px;\n  text-align: center;\n  font-weight: bold;\n}\n.analytics .widget-item .content.accounts-custom-calculation .legend {\n  max-height: 125px;\n}\n.analytics.modal-custom-calculation {\n  margin: 0px;\n  padding: 0px;\n}\n.analytics.modal-custom-calculation .modal-body .edit {\n  overflow-y: auto;\n  overflow-x: hidden;\n  color: #5B6667;\n  padding: 2px;\n  font-size: 12px;\n  padding: 5px;\n  overflow: visible;\n}\n.analytics.modal-custom-calculation .modal-body .edit .bottom-buttons .btn {\n  border-radius: 2px;\n  margin-right: 5px;\n  padding: 3px 13px;\n  text-transform: uppercase;\n  font-size: 12px;\n}\n.analytics.modal-custom-calculation .modal-body .edit .bottom-buttons .btn.btn-default {\n  background-color: #c2c4c4;\n  border: solid 1px #a8abab;\n  color: white;\n}\n.analytics.modal-custom-calculation .modal-body .edit .bottom-buttons .btn.btn-default:hover {\n  border: solid 1px #8e9292;\n  background-color: #a8abab;\n}\n.analytics.modal-custom-calculation .modal-body .edit h4 {\n  margin: 0;\n  margin-bottom: 8px;\n  text-align: left;\n  font-weight: normal;\n  font-size: 12px;\n  color: #c4caca;\n}\n.analytics.modal-custom-calculation .modal-body .edit .part {\n  margin-bottom: 8px;\n  padding: 10px 0px;\n  background-color: #fcfcfc;\n  border: solid 1px #dfe2e2;\n}\n.analytics.modal-custom-calculation .modal-body .edit .part h5 {\n  display: block;\n  margin: 0;\n  margin-bottom: 10px;\n  padding: 0px 15px;\n  text-transform: uppercase;\n  font-weight: normal;\n  font-size: 12px;\n  color: #c4caca;\n}\n.analytics.modal-custom-calculation .modal-body .edit .part label {\n  font-weight: normal;\n}\n.analytics.modal-custom-calculation .modal-body .edit .part select.form-control {\n  margin: 0px;\n  border: solid 1px #acb0b1;\n  outline: none;\n  -webkit-box-shadow: none;\n  font-size: 13px;\n  color: #72728b;\n}\n.analytics .widget-item .content.accounts-detailed-classifications {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.accounts-detailed-classifications {\n    height: 565px;\n  }\n  .analytics .widget-item .content.accounts-detailed-classifications .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.accounts-detailed-classifications .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.accounts-detailed-classifications .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.accounts-detailed-classifications .widget-lines-container {\n  overflow-y: scroll;\n  overflow-x: hidden;\n  max-height: 540px;\n}\n.analytics .widget-item .content.accounts-detailed-classifications .account-class-title {\n  margin-bottom: 8px;\n  margin-left: 11px;\n}\n.analytics .widget-item .content.accounts-detailed-classifications .time-period-info {\n  text-align: right;\n}\n.analytics .widget-item .content.accounts-detailed-classifications .widget-line.header.sorting {\n  border-bottom: 1px solid #ccc;\n}\n.analytics .widget-item .content.accounts-expense-weight .legend {\n  text-align: left;\n  max-height: 115px;\n}\n.analytics .widget-item .content.accounts-expense-weight .legend .title {\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-expenses-revenue .legend {\n  font-weight: bold;\n}\n.analytics .widget-item .content.accounts-expenses-revenue .settings.params-checkboxes {\n  font-size: 12px;\n  margin-left: 0px;\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-invoices-list {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.accounts-invoices-list {\n    height: 565px;\n  }\n  .analytics .widget-item .content.accounts-invoices-list .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.accounts-invoices-list .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.accounts-invoices-list .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.accounts-invoices-list transactions-list {\n  font-size: 12px;\n}\n.analytics .widget-item .content.accounts-live-balance h3 {\n  font-weight: 900;\n  font-size: 22px;\n  color: #5B6667;\n  margin-top: 0px;\n  font-size: 18px;\n  text-align: center;\n  text-shadow: 1px;\n}\n.analytics .widget-item .content.accounts-live-balance .statement-title {\n  font-size: 13px;\n  font-weight: 400;\n}\n.analytics .widget-item .content.accounts-live-balance .balance-title {\n  font-size: 12px;\n}\n.analytics .widget-item .content.accounts-live-balance .currency-centered {\n  font-weight: 300;\n  font-size: 12px;\n  color: #5B6667;\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-live-balance .headers {\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-live-balance .spacer {\n  min-height: 30px;\n}\n.analytics .widget-item .content.accounts-live-balance .price {\n  font-weight: 900;\n  font-size: 22px;\n  color: #5B6667;\n  text-align: center;\n  margin-top: 0px;\n}\n.analytics .widget-item .content.accounts-live-balance .come-back-later {\n  text-align: center;\n  font-size: 11px;\n  opacity: 0.8;\n}\n.analytics .widget-item .content.accounts-live-balance .negative2 {\n  font-size: 14px;\n}\n.analytics .widget-item .content.accounts-payable-receivable h3 {\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-payable-receivable .legend {\n  font-weight: bold;\n}\n.analytics .widget-item .content.accounts-payable-receivable .payable {\n  margin-top: 15px;\n}\n.analytics .widget-item .content.accounts-payable-receivable .price {\n  font-weight: 900;\n  font-size: 22px;\n  color: #5B6667;\n  text-align: center;\n  margin-top: 0px;\n}\n.analytics .widget-item .content.accounts-profit-and-loss {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.accounts-profit-and-loss {\n    height: 565px;\n  }\n  .analytics .widget-item .content.accounts-profit-and-loss .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.accounts-profit-and-loss .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container {\n  max-height: 540px;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line {\n  cursor: pointer;\n  border: solid 1px white;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line .selection-tag {\n  display: block;\n  right: 0px;\n  margin-top: -6px;\n  width: 10px;\n  height: 29px;\n  position: absolute;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line:hover {\n  background-color: #e6e0fb;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line.no-select {\n  cursor: auto;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line.no-select:hover {\n  color: #626d6d;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .right-panel .widget-lines-container {\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: 235px;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .no-element {\n  font-weight: 300;\n  font-size: 16px;\n  color: #5B6667;\n  text-align: center;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .row.lines-group.profit {\n  border-top: solid 1px;\n  border-bottom: double;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .right-panel .widget-lines-container {\n  max-height: 215px;\n}\n.analytics .widget-item .content.accounts-profit-and-loss .row.widget-line.header > [class*='col-'] {\n  position: static;\n}\n.analytics .widget-item .content.accounts-ratios .left-panel {\n  max-height: 230px;\n  overflow-y: auto;\n}\n.analytics .widget-item .content.accounts-ratios .left-panel .separator {\n  border-bottom: solid 1px #5B6667;\n  width: 75%;\n}\n.analytics .widget-item .content.accounts-ratios .left-panel .member {\n  padding-top: 20px;\n  padding-bottom: 20px;\n}\n.analytics .widget-item .content.accounts-ratios .left-panel .member .price {\n  margin-top: 0px;\n  font-size: 18px;\n}\n.analytics .widget-item .content.accounts-ratios .left-panel button {\n  outline: none;\n}\n.analytics .widget-item .content.accounts-ratios .left-panel.simulation .member {\n  padding-top: 5px;\n}\n.analytics .widget-item .content.accounts-ratios .left-panel.simulation .member .legend {\n  display: none;\n}\n.analytics .widget-item .content.accounts-ratios .left-panel.simulation .member .price {\n  text-align: right;\n}\n.analytics .widget-item .content.accounts-ratios .left-panel.simulation .separator {\n  width: 100%;\n}\n.analytics .widget-item .content.hr-employee-details {\n  font-size: 12px;\n}\n.analytics .widget-item .content.hr-employee-details .details-container {\n  padding: 0px;\n  max-height: none;\n  overflow-y: auto;\n  overflow-x: hidden;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.hr-employee-details .details-container {\n    max-height: 200px;\n  }\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.hr-employee-details .right-panel .details-container {\n    max-height: 220px;\n  }\n}\n.analytics .widget-item .content.hr-employee-details .right-panel .legend {\n  margin-bottom: 5px;\n}\n.analytics .widget-item .content.hr-employee-details .title {\n  text-align: center;\n  margin-bottom: 10px;\n  font-size: 14px;\n}\n.analytics .widget-item .content.hr-employees-list .legend {\n  margin-bottom: 9px;\n}\n.analytics .widget-item .content.hr-employees-list .widget-lines-container {\n  text-align: center;\n}\n.analytics .widget-item .content.hr-employees-list .widget-lines-container .widget-line:nth-child(even) {\n  background-color: #f0f0f0;\n}\n.analytics .widget-item .content.hr-employees-list .widget-lines-container .widget-line:nth-child(odd) {\n  background-color: white;\n}\n.analytics .widget-item .content.hr-employees-list .edit .widget-lines-container {\n  text-align: left;\n}\n.analytics .widget-item .content.hr-leaves-balance .employee-name {\n  text-align: center;\n}\n.analytics .widget-item .content.hr-leaves-balance .balance {\n  font-weight: 900;\n  font-size: 22px;\n  color: #5B6667;\n  text-align: center;\n  margin-top: 0px;\n}\n.analytics .widget-item .content.hr-leaves-balance h3 {\n  margin-top: 33px;\n  text-align: center;\n}\n.analytics .widget-item .content.hr-leaves-schedule .fc-button {\n  height: 22px;\n  font-size: 12px;\n  color: #977bf0;\n  background: white;\n  outline: none;\n}\n.analytics .widget-item .content.hr-leaves-schedule .fc-button:hover {\n  color: white;\n  background: #977bf0;\n}\n.analytics .widget-item .content.hr-leaves-schedule .fc-toolbar {\n  margin-bottom: 5px;\n}\n.analytics .widget-item .content.hr-leaves-schedule .fc-day-grid,\n.analytics .widget-item .content.hr-leaves-schedule .fc-widget-header {\n  font-size: 12px;\n  color: #5B6667;\n}\n.analytics .widget-item .content.hr-payroll-summary {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.hr-payroll-summary {\n    height: 565px;\n  }\n  .analytics .widget-item .content.hr-payroll-summary .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.hr-payroll-summary .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.hr-payroll-summary .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.hr-payroll-summary .widget-lines-container {\n  max-height: 540px;\n}\n.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line {\n  cursor: pointer;\n  border: solid 1px white;\n}\n.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line .selection-tag {\n  display: block;\n  right: 0px;\n  margin-top: -6px;\n  width: 10px;\n  height: 29px;\n  position: absolute;\n}\n.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line:hover {\n  background-color: #e6e0fb;\n}\n.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line.no-select {\n  cursor: auto;\n}\n.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line.no-select:hover {\n  color: #626d6d;\n}\n.analytics .widget-item .content.hr-payroll-summary .right-panel .widget-lines-container {\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: 235px;\n}\n.analytics .widget-item .content.hr-payroll-summary .no-element {\n  font-weight: 300;\n  font-size: 16px;\n  color: #5B6667;\n  text-align: center;\n}\n.analytics .widget-item .content.hr-payroll-summary .right-panel .widget-lines-container {\n  max-height: 145px;\n}\n.analytics .widget-item .content.hr-salaries-summary h3.left {\n  text-align: center;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.hr-salaries-summary h3.left {\n    margin-top: 69px;\n  }\n}\n.analytics .widget-item .content.hr-salaries-summary h3.reduced-left {\n  text-align: center;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.hr-salaries-summary h3.reduced-left {\n    margin-top: 10px;\n  }\n}\n.analytics .widget-item .content.hr-salaries-summary h3.right {\n  margin-bottom: 10px;\n  text-align: center;\n}\n.analytics .widget-item .content.hr-salaries-summary .price {\n  margin-top: 0;\n}\n.analytics .widget-item .content.hr-salaries-summary .widget-lines-container {\n  max-height: 75px;\n}\n.analytics .widget-item .content.hr-salaries-summary .widget-lines-container .widget-line {\n  font-size: 11px;\n}\n@media (min-width: 480px) and (max-width: 991px) {\n  .analytics .widget-item .content.hr-salaries-summary .right-panel .chart-container {\n    max-width: 320px;\n  }\n}\n.analytics .widget-item .content.hr-superannuation-accruals h3 {\n  margin-top: 63px;\n  text-align: center;\n}\n.analytics .widget-item .content.hr-superannuation-accruals .legend {\n  margin-top: 23px;\n}\n.analytics .widget-item .content.hr-superannuation-accruals .currency {\n  font-size: 14px;\n}\n.analytics .widget-item .content.hr-superannuation-accruals .price {\n  font-weight: 900;\n  font-size: 22px;\n  color: #5B6667;\n  text-align: center;\n  margin-top: 0px;\n}\n.analytics .widget-item .content.hr-timesheets .currency {\n  font-size: 14px;\n}\n.analytics .widget-item .content.hr-timesheets .widget-lines-container {\n  max-height: 210px;\n}\n.analytics .widget-item .content.hr-workforce-summary h3.left {\n  text-align: center;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.hr-workforce-summary h3.left {\n    margin-top: 69px;\n  }\n}\n.analytics .widget-item .content.hr-workforce-summary h3.reduced-left {\n  text-align: center;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.hr-workforce-summary h3.reduced-left {\n    margin-top: 10px;\n  }\n}\n.analytics .widget-item .content.hr-workforce-summary h3.right {\n  margin-bottom: 10px;\n  text-align: center;\n}\n.analytics .widget-item .content.hr-workforce-summary .price {\n  margin-top: 0;\n}\n.analytics .widget-item .content.hr-workforce-summary .widget-lines-container {\n  max-height: 75px;\n}\n.analytics .widget-item .content.hr-workforce-summary .widget-lines-container .widget-line {\n  font-size: 11px;\n}\n@media (min-width: 480px) and (max-width: 991px) {\n  .analytics .widget-item .content.hr-workforce-summary .right-panel .chart-container {\n    max-width: 320px;\n  }\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.invoices-aged-payables-receivables {\n    height: 565px;\n  }\n  .analytics .widget-item .content.invoices-aged-payables-receivables .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container {\n  max-height: 540px;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line {\n  cursor: pointer;\n  border: solid 1px white;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line .selection-tag {\n  display: block;\n  right: 0px;\n  margin-top: -6px;\n  width: 10px;\n  height: 29px;\n  position: absolute;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line:hover {\n  background-color: #e6e0fb;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line.no-select {\n  cursor: auto;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line.no-select:hover {\n  color: #626d6d;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .right-panel .widget-lines-container {\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: 235px;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .no-element {\n  font-weight: 300;\n  font-size: 16px;\n  color: #5B6667;\n  text-align: center;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .right-panel .widget-lines-container {\n  max-height: 215px;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .row.astericks-info {\n  margin-top: 15px;\n}\n.analytics .widget-item .content.invoices-aged-payables-receivables .currency-conversions {\n  float: right;\n  margin-left: 3px;\n}\n.analytics .widget-item .content.invoices-list .widget-lines-container {\n  max-height: 230px;\n}\n.analytics .widget-item .content.invoices-list .widget-lines-container .widget-line:nth-child(even) {\n  background-color: #f0f0f0;\n}\n.analytics .widget-item .content.invoices-list .widget-lines-container .widget-line:nth-child(odd) {\n  background-color: white;\n}\n.analytics .widget-item .content.invoices-list .widget-lines-container .widget-line.header {\n  background-color: white;\n}\n.analytics .widget-item .content.invoices-list .currency-conversions {\n  float: right;\n  margin-right: 3px;\n  margin-top: -2px;\n}\n.analytics .widget-item .content.invoices-list .fa.fa-info-circle {\n  float: right;\n  font-size: 15px;\n}\n.analytics .widget-item .content.invoices-list .right-column {\n  padding-left: 0px;\n  padding-right: 0px;\n}\n.analytics .widget-item .content.invoices-summary .chart-container {\n  max-width: 410px;\n}\n.analytics .widget-item .content.invoices-summary .legend {\n  max-height: 28px;\n}\n.analytics .widget-item .content.sales-aged {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.sales-aged {\n    height: 565px;\n  }\n  .analytics .widget-item .content.sales-aged .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.sales-aged .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.sales-aged .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.sales-aged .widget-lines-container {\n  max-height: 238px;\n}\n.analytics .widget-item .content.sales-break-even .price {\n  font-weight: 900;\n  font-size: 22px;\n  color: #5B6667;\n  text-align: center;\n  margin-top: 0px;\n}\n.analytics .widget-item .content.sales-break-even .block {\n  margin: 5px;\n  padding: 0px 10px 5px 10px;\n  text-align: left;\n  box-shadow: 0px 7px 10px -7px #17262d;\n  font-size: 12px;\n}\n.analytics .widget-item .content.sales-break-even .block form.editable-wrap .editable-controls input {\n  margin-top: 5px;\n  width: 100px;\n}\n.analytics .widget-item .content.sales-break-even .block.to-date {\n  background-color: #f0f0f0;\n  color: #5B6667;\n}\n.analytics .widget-item .content.sales-break-even .block.to-breakeven {\n  margin-top: 10px;\n  background-color: #192831;\n  color: #1de9b6;\n}\n.analytics .widget-item .content.sales-break-even .block.to-breakeven .title {\n  border-bottom: solid 1px #2a4453;\n}\n.analytics .widget-item .content.sales-break-even .block.to-breakeven .define-text {\n  font-weight: 300;\n  font-size: 16px;\n  color: #5B6667;\n  text-align: center;\n  padding-top: 5px;\n  color: #1de9b6;\n}\n.analytics .widget-item .content.sales-break-even .block.to-breakeven .price {\n  color: #1de9b6;\n}\n.analytics .widget-item .content.sales-break-even .block .title {\n  font-size: 13px;\n  text-align: center;\n  font-variant: small-caps;\n  border-bottom: solid 1px #e6edee;\n  font-weight: 300;\n}\n.analytics .widget-item .content.sales-comparison {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.sales-comparison {\n    height: 565px;\n  }\n  .analytics .widget-item .content.sales-comparison .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.sales-comparison .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.sales-comparison .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.sales-comparison .widget-lines-container {\n  max-height: 540px;\n}\n.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line {\n  cursor: pointer;\n  border: solid 1px white;\n}\n.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line .selection-tag {\n  display: block;\n  right: 0px;\n  margin-top: -6px;\n  width: 10px;\n  height: 29px;\n  position: absolute;\n}\n.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line:hover {\n  background-color: #e6e0fb;\n}\n.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line.no-select {\n  cursor: auto;\n}\n.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line.no-select:hover {\n  color: #626d6d;\n}\n.analytics .widget-item .content.sales-comparison .right-panel .widget-lines-container {\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: 235px;\n}\n.analytics .widget-item .content.sales-comparison .no-element {\n  font-weight: 300;\n  font-size: 16px;\n  color: #5B6667;\n  text-align: center;\n}\n.analytics .widget-item .content.sales-comparison .widget-lines-container {\n  max-height: 530px;\n}\n.analytics .widget-item .content.sales-comparison .right-panel .widget-lines-container {\n  max-height: 250px;\n}\n.analytics .widget-item .content.sales-comparison .currency-conversions img {\n  margin-top: -2px;\n}\n.analytics .widget-item .content.sales-customer-details {\n  font-size: 12px;\n}\n.analytics .widget-item .content.sales-customer-details .loader {\n  font-size: 14px;\n}\n.analytics .widget-item .content.sales-customer-details .details-container {\n  padding: 0px;\n  overflow-y: auto;\n  overflow-x: hidden;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.sales-customer-details .details-container {\n    max-height: 194px;\n  }\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.sales-customer-details .right-panel .details-container {\n    max-height: 230px;\n  }\n}\n.analytics .widget-item .content.sales-customer-details .right-panel .legend {\n  margin-bottom: 5px;\n}\n.analytics .widget-item .content.sales-customer-details .row.title {\n  text-align: center;\n  margin-bottom: 10px;\n  font-size: 14px;\n}\n.analytics .widget-item .content.sales-customer-details .currency-conversions {\n  float: left;\n  margin-right: 3px;\n}\n.analytics .widget-item .content.sales-cycle .chart-container {\n  max-width: 410px;\n}\n.analytics .widget-item .content.sales-cycle .legend {\n  max-height: 28px;\n}\n.analytics .widget-item .content.sales-forecast {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.sales-forecast {\n    height: 565px;\n  }\n  .analytics .widget-item .content.sales-forecast .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.sales-forecast .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.sales-forecast .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.sales-forecast .widget-lines-container {\n  max-height: 275px;\n}\n.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main {\n  cursor: pointer;\n  border: solid 1px white;\n}\n.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main .selection-tag {\n  display: block;\n  right: 0px;\n  margin-top: -6px;\n  width: 10px;\n  height: 29px;\n  position: absolute;\n}\n.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main:hover {\n  background-color: #e6e0fb;\n}\n.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main.no-select {\n  cursor: auto;\n}\n.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main.no-select:hover {\n  color: #626d6d;\n}\n.analytics .widget-item .content.sales-growth .price {\n  font-weight: 900;\n  font-size: 22px;\n  color: #5B6667;\n  text-align: center;\n  margin-top: 0px;\n}\n.analytics .widget-item .content.sales-growth .legend {\n  max-height: 49px;\n  font-size: 14px;\n  text-overflow: ellipsis;\n  white-space: nowrap;\n}\n.analytics .widget-item .content.sales-leads-funnel {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.sales-leads-funnel {\n    height: 565px;\n  }\n  .analytics .widget-item .content.sales-leads-funnel .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.sales-leads-funnel .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.sales-leads-funnel .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.sales-leads-funnel .funnel-container {\n  width: 95%;\n  margin: auto;\n  margin-top: 15px;\n  padding-right: 10px;\n  max-height: 505px;\n  overflow: auto;\n}\n.analytics .widget-item .content.sales-leads-funnel .right-panel .widget-lines-container {\n  max-height: 545px;\n  margin-right: 10px;\n}\n.analytics .widget-item .content.sales-leads-funnel .right-panel .widget-lines-container .widget-line {\n  cursor: default;\n}\n.analytics .widget-item .content.sales-leads-list .widget-lines-container {\n  max-height: 230px;\n}\n.analytics .widget-item .content.sales-leads-list .widget-lines-container .widget-line:nth-child(even) {\n  background-color: #f0f0f0;\n}\n.analytics .widget-item .content.sales-leads-list .widget-lines-container .widget-line:nth-child(odd) {\n  background-color: white;\n}\n.analytics .widget-item .content.sales-leads-list .widget-lines-container .widget-line.header {\n  background-color: white;\n}\n.analytics .widget-item .content.sales-leads-list .widget-lines-container {\n  overflow-y: scroll;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.sales-list .widget-lines-container {\n  max-height: 230px;\n}\n.analytics .widget-item .content.sales-list .widget-lines-container .widget-line:nth-child(even) {\n  background-color: #f0f0f0;\n}\n.analytics .widget-item .content.sales-list .widget-lines-container .widget-line:nth-child(odd) {\n  background-color: white;\n}\n.analytics .widget-item .content.sales-list .widget-lines-container .widget-line.header {\n  background-color: white;\n}\n.analytics .widget-item .content.sales-list .widget-lines-container {\n  overflow-y: scroll;\n  overflow-x: hidden;\n  max-height: 170px;\n}\n.analytics .widget-item .content.sales-list .widget-lines-container.no-scroll {\n  overflow: visible;\n}\n.analytics .widget-item .content.sales-list .selector {\n  margin-bottom: 4px;\n}\n.analytics .widget-item .content.sales-list .currency-conversions img {\n  margin-top: -2px;\n}\n.analytics .widget-item .content.sales-net-sales .value-container,\n.analytics .widget-item .content.sales-net-sales .operator {\n  line-height: 85px;\n}\n.analytics .widget-item .content.sales-net-sales .value-container .title {\n  line-height: 20px;\n  font-size: 1.2em;\n  padding: 10px 0px;\n}\n.analytics .widget-item .content.sales-net-sales .value-container .value-box {\n  font-size: 1.3em;\n  border-radius: 10px;\n  border-top: solid 1px #C4CACA;\n  border-bottom: solid 1px #C4CACA;\n  white-space: nowrap;\n}\n.analytics .widget-item .content.sales-net-sales .operator {\n  padding-top: 38px;\n  font-size: 1.3em;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.sales-net-sales .values {\n    margin-top: 25px;\n  }\n}\n.analytics .widget-item .content.sales-new-vs-existing-customers .selector .selector-wrap {\n  display: inline-block;\n  margin: 0 5px;\n}\n.analytics .widget-item .content.sales-new-vs-existing-customers .chart-container {\n  margin-top: 15px;\n}\n.analytics .widget-item .content.sales-new-vs-existing-customers .legend {\n  margin-top: 5px;\n  font-weight: bold;\n  max-height: 77px !important;\n}\n.analytics .widget-item .content.sales-new-vs-existing-customers .legend .row {\n  margin: 0px -5px;\n}\n.analytics .widget-item .content.sales-new-vs-existing-customers .legend .row > div {\n  padding: 0px 5px;\n}\n.analytics .widget-item .content.sales-new-vs-existing-customers .legend .total {\n  color: #5B6667;\n  font-size: 14px;\n}\n.analytics .widget-item .content.sales-number-of-leads .stats {\n  margin-top: 35px;\n  font-size: 18px;\n}\n.analytics .widget-item .content.sales-number-of-leads .stats .stat {\n  margin: 15px 0px 10px 0px;\n  border-bottom: solid 1px #e6edee;\n}\n.analytics .widget-item .content.sales-number-of-leads .stats .stat span.title {\n  font-weight: bold;\n}\n.analytics .widget-item .content.sales-number-of-leads .stats .stat span.nominal {\n  float: right;\n  text-align: right;\n  font-weight: 300;\n}\n.analytics .widget-item .content.sales-number-of-leads .stats .stat span.variation {\n  float: right;\n  width: 50px;\n  text-align: right;\n  font-style: italic;\n  font-size: 14px;\n  font-weight: 300;\n  margin-top: 2px;\n}\n.analytics .widget-item .content.sales-opportunities-funnel {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.sales-opportunities-funnel {\n    height: 565px;\n  }\n  .analytics .widget-item .content.sales-opportunities-funnel .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.sales-opportunities-funnel .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.sales-opportunities-funnel .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.sales-opportunities-funnel .funnel-container {\n  width: 95%;\n  margin: auto;\n  margin-top: 15px;\n  padding-right: 10px;\n  max-height: 505px;\n  overflow: auto;\n}\n.analytics .widget-item .content.sales-opportunities-funnel .right-panel .widget-lines-container {\n  max-height: 545px;\n  margin-right: 10px;\n}\n.analytics .widget-item .content.sales-opportunities-funnel .right-panel .widget-lines-container .widget-line {\n  cursor: default;\n}\n.analytics .widget-item .content.sales-performance {\n  min-height: 565px;\n}\n@media (min-width: 992px) {\n  .analytics .widget-item .content.sales-performance {\n    height: 565px;\n  }\n  .analytics .widget-item .content.sales-performance .chart-container {\n    max-width: 585px;\n    max-height: 440px;\n    margin: auto;\n  }\n}\n.analytics .widget-item .content.sales-performance .edit {\n  max-height: 545px;\n}\n.analytics .widget-item .content.sales-performance .edit .widget-lines-container {\n  overflow-y: hidden;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.sales-performance .widget-lines-container {\n  max-height: 540px;\n}\n.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line {\n  cursor: pointer;\n  border: solid 1px white;\n}\n.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line .selection-tag {\n  display: block;\n  right: 0px;\n  margin-top: -6px;\n  width: 10px;\n  height: 29px;\n  position: absolute;\n}\n.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line:hover {\n  background-color: #e6e0fb;\n}\n.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line.no-select {\n  cursor: auto;\n}\n.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line.no-select:hover {\n  color: #626d6d;\n}\n.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container {\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: 235px;\n}\n.analytics .widget-item .content.sales-performance .no-element {\n  font-weight: 300;\n  font-size: 16px;\n  color: #5B6667;\n  text-align: center;\n}\n.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container {\n  max-height: 215px;\n}\n.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header {\n  cursor: pointer;\n  border: solid 1px white;\n}\n.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header .selection-tag {\n  display: block;\n  right: 0px;\n  margin-top: -6px;\n  width: 10px;\n  height: 29px;\n  position: absolute;\n}\n.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header:hover {\n  background-color: #e6e0fb;\n}\n.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header.no-select {\n  cursor: auto;\n}\n.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header.no-select:hover {\n  color: #626d6d;\n}\n.analytics .widget-item .content.sales-segmented-turnover h3.right {\n  margin-top: 55px;\n  text-align: center;\n}\n.analytics .widget-item .content.sales-segmented-turnover .selector {\n  margin-bottom: 10px;\n}\n.analytics .widget-item .content.sales-segmented-turnover .analysis {\n  font-weight: 900;\n  font-size: 22px;\n  color: #5B6667;\n  text-align: center;\n  margin-top: 0px;\n}\n.analytics .widget-item .content.sales-segmented-turnover .widget-lines-container {\n  max-height: 75px;\n}\n.analytics .widget-item .content.sales-segmented-turnover .widget-lines-container .widget-line {\n  font-size: 11px;\n}\n.analytics .widget-item .content.sales-segmented-turnover .right-panel h3 {\n  margin: 15px 10px 5px 10px;\n  text-align: center;\n}\n.analytics .widget-item .content.sales-segmented-turnover .right-panel .fa.fa-info-circle {\n  float: left;\n}\n.analytics .widget-item .content.sales-summary .chart-container {\n  max-width: 410px;\n}\n.analytics .widget-item .content.sales-summary .legend {\n  max-height: 28px;\n}\n.analytics .widget-item .content.sales-summary .selector {\n  margin-bottom: 5px;\n}\n.analytics .widget-item .content.sales-top-customers .selector {\n  border-bottom: dashed 1px #E6E6E6;\n  padding-bottom: 3px;\n}\n.analytics .widget-item .content.sales-top-customers .selector a {\n  font-weight: normal;\n}\n.analytics .widget-item .content.sales-top-customers .selector .param-selector {\n  display: inline-block;\n}\n.analytics .widget-item .content.sales-top-customers .widget-lines-container {\n  max-height: 235px;\n}\n.analytics .widget-item .content.sales-top-customers .widget-lines-container .widget-line.sub-line {\n  background-color: #f0f0f0;\n}\n.analytics .widget-item .content.sales-top-customers .widget-lines-container .row > [class*='col-'] {\n  position: static;\n}\n.analytics .widget-item .content.sales-top-customers .currency-conversions img {\n  margin-top: -2px;\n}\n.analytics .widget-item .content.sales-top-opportunities .opps-container {\n  max-height: 195px;\n  margin-top: 10px;\n  padding-right: 10px;\n  overflow-y: auto;\n  overflow-x: hidden;\n}\n.analytics .widget-item .content.sales-top-opportunities .opps-container .tile {\n  height: 40px;\n  font-size: 13px;\n  font-weight: 300;\n}\n.analytics .widget-item .content.sales-top-opportunities .opps-container .tile .colored-area {\n  width: 10%;\n  text-align: center;\n  font-size: 20px;\n}\n.analytics .widget-item .content.sales-top-opportunities .opps-container .tile .main-text {\n  color: #5B6667;\n  padding: 3px 0px 0px 10px;\n}\n.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.first {\n  height: 55px;\n  font-size: 15px;\n  font-weight: bold;\n}\n.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.first .colored-area {\n  font-size: 26px;\n  padding-top: 10px;\n  background-color: #ff6e41;\n}\n.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.first .main-text {\n  padding-top: 8px;\n}\n.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.second {\n  height: 55px;\n  font-size: 15px;\n  font-weight: 500;\n}\n.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.second .colored-area {\n  font-size: 26px;\n  padding-top: 10px;\n  background-color: #1de9b6;\n}\n.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.second .main-text {\n  padding-top: 8px;\n}\n.analytics .widget-item .content .settings.select-account {\n  padding: 0px 5px;\n}\n.analytics .settings.accounting-behaviour .btn.btn-primary {\n  background-color: #bba9f5;\n  border: solid 1px #977bf0;\n}\n.analytics .settings.accounting-behaviour .btn.btn-primary.focus,\n.analytics .settings.accounting-behaviour .btn.btn-primary.active {\n  background-color: #977bf0;\n}\n.analytics .settings.attach-kpis .attach-kpi {\n  padding: 8px 5px;\n}\n.analytics .settings.attach-kpis .attach-kpi form .row {\n  padding-bottom: 5px;\n}\n.analytics .settings.attach-kpis .attach-kpi .attach-kpi-form {\n  background-color: white;\n  border: 1px solid #ddd;\n  padding: 5px;\n}\n.analytics .settings.attach-kpis .attach-kpi form .row.kpi-description {\n  padding: 10px 2px;\n}\n.analytics .settings.attach-kpis .attach-kpi form .row.kpi-description span {\n  display: block;\n  font-weight: bold;\n  font-size: 13px;\n}\n.analytics .settings.attach-kpis .attach-kpi form.attach-kpi-form input.attach-target {\n  background-color: white;\n  height: inherit;\n}\n.analytics .settings.attach-kpis .attach-kpi .error-messages {\n  color: #e01f74;\n  width: 120px;\n}\n.analytics .settings.attach-kpis .attached-kpis {\n  padding: 5px;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi {\n  padding: 5px 10px;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi .attached-kpi-name {\n  overflow: hidden;\n  width: 75%;\n  display: inline-block;\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  margin-top: 3px;\n  font-size: 13px;\n  font-weight: bold;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions {\n  padding-top: 2px;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .alerts-config {\n  display: inline-block;\n  text-align: left;\n  padding-left: 4px;\n  height: 20px;\n  border-radius: 40px;\n  width: 21px;\n  color: #358fdc;\n  background-color: white;\n  border: solid 1px #358fdc;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .alerts-config:hover {\n  cursor: pointer;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .edit-attached-kpi {\n  display: inline-block;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .edit-attached-kpi i {\n  border-radius: 10px;\n  width: 21px;\n  color: #358fdc;\n  background-color: white;\n  height: 20px;\n  padding: 3px 5px 5px 5px;\n  border: solid 1px #358fdc;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .edit-attached-kpi i:hover {\n  cursor: pointer;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .remove-attached-kpi {\n  display: inline-block;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .remove-attached-kpi i {\n  border-radius: 10px;\n  width: 21px;\n  color: #e01f74;\n  background-color: white;\n  height: 20px;\n  padding: 3px 5px 5px 5px;\n  border: solid 1px #e01f74;\n}\n.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .remove-attached-kpi i:hover {\n  cursor: pointer;\n}\n.analytics .widget-item .content .settings.select-account {\n  padding: 0px 5px;\n}\n.analytics .widget-item .content .settings.chart-filters .row {\n  margin: 0px;\n}\n.analytics .widget-item .content .settings.chart-filters input[type=\"radio\"] {\n  margin: 0;\n  margin-right: 3px;\n  padding: 0;\n  width: 13px;\n  height: 13px;\n  vertical-align: middle;\n  position: relative;\n  top: -1px;\n  outline: none;\n}\n.analytics .widget-item .content .settings.chart-filters input[type=\"range\"] {\n  height: auto;\n  width: 100%;\n}\n.analytics .settings.dates-picker h5 {\n  display: none;\n}\n.analytics .settings.dates-picker button.btn.btn-sm {\n  line-height: 1;\n}\n.analytics .settings.dates-picker button.btn.btn-sm.date-button {\n  margin: 0px 5px;\n}\n.analytics .settings.dates-picker button.btn.btn-sm.btn-danger {\n  display: none;\n}\n.analytics .settings.dates-picker button.btn.btn-sm.btn-info {\n  border-radius: 3px;\n}\n.analytics .settings.dates-picker .tooltip-inner {\n  text-transform: none;\n}\n.analytics .settings.dates-picker .dropdown-menu > li > div > table {\n  outline: none;\n}\n.analytics .settings.forecast-payroll .widget-lines-container .widget-line {\n  padding: 5px 10px 5px 18px;\n}\n.analytics .settings.forecast-payroll .widget-lines-container .widget-line:nth-child(even) {\n  background-color: #f3f4f4;\n}\n.analytics .settings.forecast-payroll .widget-lines-container .widget-line:nth-child(odd) {\n  background-color: white;\n}\n.analytics .settings.forecast-payroll .widget-lines-container .widget-line .fa {\n  float: right;\n  font-size: 20px;\n  cursor: pointer;\n}\n.analytics .settings.forecast-payroll .widget-lines-container .widget-line .fa.fa-toggle-on {\n  color: #977bf0;\n}\n.analytics .settings.forecast-payroll .widget-lines-container .widget-line .fa.fa-toggle-off {\n  color: #9ba6a7;\n}\n.analytics .widget-item .content .settings.hist-mode-choser {\n  max-height: 70px;\n}\n.analytics .widget-item .content .settings.hist-mode-choser [common-time-period-info] {\n  padding-bottom: 8px;\n}\n.analytics .widget-item .content .settings.hist-mode-choser .options {\n  width: 150px;\n  margin: auto;\n  padding-bottom: 8px;\n  border-bottom: solid 1px #e6e6e6;\n  font-weight: 500;\n  font-size: 12px;\n  color: #c4caca;\n}\n.analytics .widget-item .content .settings.hist-mode-choser .options a {\n  font-weight: 500;\n  font-size: 12px;\n  color: #c4caca;\n  text-transform: uppercase;\n}\n.analytics .widget-item .content .settings.hist-mode-choser .options a.active {\n  color: #977bf0;\n}\n.analytics .widget-item .content .settings.hist-mode-choser .arrow-container {\n  width: 28px;\n  height: 28px;\n  position: relative;\n  top: -14px;\n  margin: auto;\n}\n.analytics .widget-item .content .settings.hist-mode-choser .arrow-container.right {\n  left: 46px;\n}\n.analytics .widget-item .content .settings.hist-mode-choser .arrow-container.left {\n  left: -30px;\n}\n.analytics .widget-item .content .settings.hist-mode-choser .arrow-container .arrow-border {\n  border-top: 14px solid #e6e6e6;\n  border-left: 14px solid transparent;\n  border-right: 14px solid transparent;\n  width: 0px;\n  height: 0px;\n}\n.analytics .widget-item .content .settings.hist-mode-choser .arrow-container .arrow {\n  border-top: 14px solid white;\n  border-left: 14px solid transparent;\n  border-right: 14px solid transparent;\n  position: relative;\n  top: 12px;\n  width: 0px;\n  height: 0px;\n}\n.analytics .settings.limit-entries {\n  color: #1E303B;\n  text-transform: uppercase;\n  text-align: center;\n  border-bottom: dashed 1px #E6E6E6;\n  padding-bottom: 8px;\n}\n.analytics .settings.limit-entries a.option.badge {\n  color: white;\n  background-color: #1E303B;\n}\n.analytics .settings.offsets .offset-value {\n  font-style: italic;\n  font-size: 13px;\n}\n.analytics .settings.offsets .offset-value .fa-trash-o {\n  margin-left: 10px;\n}\n.analytics .settings.offsets .offset-value .fa-trash-o:hover {\n  color: #e01f74;\n  cursor: pointer;\n}\n.analytics .settings.offsets input {\n  width: 75%;\n}\n.analytics .settings.offsets button {\n  width: 30px;\n}\n.analytics .settings.organizations .widget-lines-container .widget-line {\n  padding: 5px 10px 5px 18px;\n}\n.analytics .settings.organizations .widget-lines-container .widget-line:nth-child(even) {\n  background-color: #f3f4f4;\n}\n.analytics .settings.organizations .widget-lines-container .widget-line:nth-child(odd) {\n  background-color: white;\n}\n.analytics .settings.organizations .widget-lines-container .widget-line .fa {\n  float: right;\n  font-size: 20px;\n  cursor: pointer;\n}\n.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-toggle-on,\n.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-check-circle {\n  color: #977bf0;\n}\n.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-toggle-off,\n.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-circle-thin {\n  color: #9ba6a7;\n}\n.analytics .widget-item .content .settings.param-selector {\n  display: inline-block;\n}\n.analytics .widget-item .content .settings.param-selector.classic {\n  width: 100%;\n}\n.analytics .widget-item .content .settings.param-selector.classic select {\n  width: 100%;\n  height: 25px;\n  border: 1px solid #ccc;\n  text-transform: uppercase;\n  margin: 0px 0px 5px 0px;\n}\n.analytics .widget-item .content .settings.param-selector a {\n  font-weight: normal;\n  color: #977bf0;\n  white-space: nowrap;\n}\n.analytics .widget-item .content .settings.param-selector .options-container {\n  position: absolute;\n  background-color: white;\n  text-align: left;\n  min-width: 150px;\n  max-height: 200px;\n  z-index: 999;\n  overflow-y: auto;\n  overflow-x: hidden;\n  -webkit-box-shadow: #000000 0px 3px 15px -3px;\n  box-shadow: #000000 0px 3px 15px -3px;\n}\n.analytics .widget-item .content .settings.param-selector .options-container .param-selector-label {\n  padding: 3px 5px;\n  font-weight: 500;\n  font-size: inherit;\n  color: black;\n  cursor: text;\n  overflow: hidden;\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  line-height: 1.9;\n}\n.analytics .widget-item .content .settings.param-selector .options-container .param-selector-label:hover {\n  cursor: pointer;\n  background-color: #977bf0;\n  color: white;\n}\n.analytics .widget-item .content .settings.param-selector .options-container::-webkit-scrollbar {\n  width: 8px;\n  background-color: #d7e2e4;\n}\n.analytics .widget-item .content .settings.param-selector .options-container::-webkit-scrollbar-thumb {\n  background-color: #977bf0;\n}\n.analytics .widget-item .content .settings.param-selector .options-container::-webkit-scrollbar-thumb:hover {\n  background-color: #a992f3;\n}\n.analytics .settings.params-checkboxes {\n  padding: 2px 0px;\n}\n.analytics .settings.params-checkboxes input {\n  margin: 0;\n  height: inherit;\n}\n.analytics .settings.params-checkboxes span {\n  margin-left: 5px;\n}\n.analytics .settings.params-checkboxes label {\n  display: flex;\n  justify-content: center;\n  line-height: 14px;\n}\n.analytics .widget-item .content .settings.params-picker {\n  padding: 0px 10px;\n}\n.analytics .widget-item .content .settings.params-picker .parameter {\n  margin: 0px 3px 3px 0px;\n  padding: 3px 5px;\n  background-color: #1E303B;\n  color: white;\n  border: solid 1px #1E303B;\n  border-radius: 4px;\n  cursor: move;\n  font-weight: bold;\n  white-space: nowrap;\n  float: left;\n}\n.analytics .widget-item .content .settings.params-picker .parameter input[type=\"checkbox\"] {\n  margin: 0px -3px 0px 3px;\n  vertical-align: middle;\n  height: inherit;\n  outline: none;\n  cursor: pointer;\n}\n.analytics .widget-item .content .settings.params-picker .parameter .badge {\n  margin-right: 3px;\n  font-size: 10px;\n  background-color: #f2f2f2;\n  color: #1E303B;\n  padding: 2px 6px;\n}\n.analytics .widget-item .content .settings.params-picker .parameter.unchecked {\n  background-color: inherit;\n  font-weight: normal;\n  color: inherit;\n  border-color: #c2c4c4;\n}\n.analytics .widget-item .content .settings.params-picker .parameter.unchecked .badge {\n  background-color: #c2c4c4;\n  color: white;\n}\n.analytics .settings.tag-filter {\n  padding: 0px 5px;\n}\n.analytics .settings.tag-filter .btn.btn-default {\n  height: 32px;\n  width: 30px;\n}\n.analytics .settings.tag-filter .tag-lines-container {\n  padding: 0px 10px;\n}\n.analytics .settings.tag-filter .tag-lines-container .tag-line {\n  display: flex;\n  align-items: center;\n  justify-content: flex-end;\n}\n.analytics .settings.tag-filter .tag-lines-container .tag-line .tags-col {\n  position: static;\n}\n.analytics .settings.tag-filter .tag-lines-container .tag-line tags-input .tags {\n  display: flex;\n  border-radius: 4px;\n  border: solid 1px #ccc;\n}\n.analytics .settings.tag-filter .tag-lines-container .tag-line tags-input .tags .tag-item {\n  background: #79a2bb;\n  border-radius: 4px;\n  color: white;\n}\n.analytics .settings.tag-filter .tag-lines-container .tag-line .host {\n  position: static;\n}\n.analytics .settings.time-period {\n  padding: 0px 5px;\n}\n.analytics .settings.time-period select {\n  height: 22px;\n  width: 100%;\n}\n.analytics .settings.time-period > .row {\n  margin: 0px -5px 7px -5px;\n}\n.analytics .settings.time-period > .row > div {\n  padding: 0px 5px;\n  position: static;\n}\n.analytics .settings.time-period > .row .sub-setting {\n  padding: 5px;\n}\n.analytics .widget-item .content .settings.width {\n  float: right;\n  font-size: 14px;\n}\n.analytics .widget-item .content .settings.width i {\n  color: silver;\n  cursor: pointer;\n}\n.analytics .widget-item .content .settings.width i.reduce {\n  margin-right: -10px;\n}\n.analytics .widget-item .content .settings.width i.expand {\n  margin-right: -3px;\n}\n/* endinject */\n","/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */\n\n//\n// 1. Set default font family to sans-serif.\n// 2. Prevent iOS and IE text size adjust after device orientation change,\n//    without disabling user zoom.\n//\n\nhtml {\n  font-family: sans-serif; // 1\n  -ms-text-size-adjust: 100%; // 2\n  -webkit-text-size-adjust: 100%; // 2\n}\n\n//\n// Remove default margin.\n//\n\nbody {\n  margin: 0;\n}\n\n// HTML5 display definitions\n// ==========================================================================\n\n//\n// Correct `block` display not defined for any HTML5 element in IE 8/9.\n// Correct `block` display not defined for `details` or `summary` in IE 10/11\n// and Firefox.\n// Correct `block` display not defined for `main` in IE 11.\n//\n\narticle,\naside,\ndetails,\nfigcaption,\nfigure,\nfooter,\nheader,\nhgroup,\nmain,\nmenu,\nnav,\nsection,\nsummary {\n  display: block;\n}\n\n//\n// 1. Correct `inline-block` display not defined in IE 8/9.\n// 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.\n//\n\naudio,\ncanvas,\nprogress,\nvideo {\n  display: inline-block; // 1\n  vertical-align: baseline; // 2\n}\n\n//\n// Prevent modern browsers from displaying `audio` without controls.\n// Remove excess height in iOS 5 devices.\n//\n\naudio:not([controls]) {\n  display: none;\n  height: 0;\n}\n\n//\n// Address `[hidden]` styling not present in IE 8/9/10.\n// Hide the `template` element in IE 8/9/10/11, Safari, and Firefox < 22.\n//\n\n[hidden],\ntemplate {\n  display: none;\n}\n\n// Links\n// ==========================================================================\n\n//\n// Remove the gray background color from active links in IE 10.\n//\n\na {\n  background-color: transparent;\n}\n\n//\n// Improve readability of focused elements when they are also in an\n// active/hover state.\n//\n\na:active,\na:hover {\n  outline: 0;\n}\n\n// Text-level semantics\n// ==========================================================================\n\n//\n// Address styling not present in IE 8/9/10/11, Safari, and Chrome.\n//\n\nabbr[title] {\n  border-bottom: 1px dotted;\n}\n\n//\n// Address style set to `bolder` in Firefox 4+, Safari, and Chrome.\n//\n\nb,\nstrong {\n  font-weight: bold;\n}\n\n//\n// Address styling not present in Safari and Chrome.\n//\n\ndfn {\n  font-style: italic;\n}\n\n//\n// Address variable `h1` font-size and margin within `section` and `article`\n// contexts in Firefox 4+, Safari, and Chrome.\n//\n\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0;\n}\n\n//\n// Address styling not present in IE 8/9.\n//\n\nmark {\n  background: #ff0;\n  color: #000;\n}\n\n//\n// Address inconsistent and variable font size in all browsers.\n//\n\nsmall {\n  font-size: 80%;\n}\n\n//\n// Prevent `sub` and `sup` affecting `line-height` in all browsers.\n//\n\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n}\n\nsup {\n  top: -0.5em;\n}\n\nsub {\n  bottom: -0.25em;\n}\n\n// Embedded content\n// ==========================================================================\n\n//\n// Remove border when inside `a` element in IE 8/9/10.\n//\n\nimg {\n  border: 0;\n}\n\n//\n// Correct overflow not hidden in IE 9/10/11.\n//\n\nsvg:not(:root) {\n  overflow: hidden;\n}\n\n// Grouping content\n// ==========================================================================\n\n//\n// Address margin not present in IE 8/9 and Safari.\n//\n\nfigure {\n  margin: 1em 40px;\n}\n\n//\n// Address differences between Firefox and other browsers.\n//\n\nhr {\n  box-sizing: content-box;\n  height: 0;\n}\n\n//\n// Contain overflow in all browsers.\n//\n\npre {\n  overflow: auto;\n}\n\n//\n// Address odd `em`-unit font size rendering in all browsers.\n//\n\ncode,\nkbd,\npre,\nsamp {\n  font-family: monospace, monospace;\n  font-size: 1em;\n}\n\n// Forms\n// ==========================================================================\n\n//\n// Known limitation: by default, Chrome and Safari on OS X allow very limited\n// styling of `select`, unless a `border` property is set.\n//\n\n//\n// 1. Correct color not being inherited.\n//    Known issue: affects color of disabled elements.\n// 2. Correct font properties not being inherited.\n// 3. Address margins set differently in Firefox 4+, Safari, and Chrome.\n//\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  color: inherit; // 1\n  font: inherit; // 2\n  margin: 0; // 3\n}\n\n//\n// Address `overflow` set to `hidden` in IE 8/9/10/11.\n//\n\nbutton {\n  overflow: visible;\n}\n\n//\n// Address inconsistent `text-transform` inheritance for `button` and `select`.\n// All other form control elements do not inherit `text-transform` values.\n// Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.\n// Correct `select` style inheritance in Firefox.\n//\n\nbutton,\nselect {\n  text-transform: none;\n}\n\n//\n// 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`\n//    and `video` controls.\n// 2. Correct inability to style clickable `input` types in iOS.\n// 3. Improve usability and consistency of cursor style between image-type\n//    `input` and others.\n//\n\nbutton,\nhtml input[type=\"button\"], // 1\ninput[type=\"reset\"],\ninput[type=\"submit\"] {\n  -webkit-appearance: button; // 2\n  cursor: pointer; // 3\n}\n\n//\n// Re-set default cursor for disabled elements.\n//\n\nbutton[disabled],\nhtml input[disabled] {\n  cursor: default;\n}\n\n//\n// Remove inner padding and border in Firefox 4+.\n//\n\nbutton::-moz-focus-inner,\ninput::-moz-focus-inner {\n  border: 0;\n  padding: 0;\n}\n\n//\n// Address Firefox 4+ setting `line-height` on `input` using `!important` in\n// the UA stylesheet.\n//\n\ninput {\n  line-height: normal;\n}\n\n//\n// It's recommended that you don't attempt to style these elements.\n// Firefox's implementation doesn't respect box-sizing, padding, or width.\n//\n// 1. Address box sizing set to `content-box` in IE 8/9/10.\n// 2. Remove excess padding in IE 8/9/10.\n//\n\ninput[type=\"checkbox\"],\ninput[type=\"radio\"] {\n  box-sizing: border-box; // 1\n  padding: 0; // 2\n}\n\n//\n// Fix the cursor style for Chrome's increment/decrement buttons. For certain\n// `font-size` values of the `input`, it causes the cursor style of the\n// decrement button to change from `default` to `text`.\n//\n\ninput[type=\"number\"]::-webkit-inner-spin-button,\ninput[type=\"number\"]::-webkit-outer-spin-button {\n  height: auto;\n}\n\n//\n// 1. Address `appearance` set to `searchfield` in Safari and Chrome.\n// 2. Address `box-sizing` set to `border-box` in Safari and Chrome.\n//\n\ninput[type=\"search\"] {\n  -webkit-appearance: textfield; // 1\n  box-sizing: content-box; //2\n}\n\n//\n// Remove inner padding and search cancel button in Safari and Chrome on OS X.\n// Safari (but not Chrome) clips the cancel button when the search input has\n// padding (and `textfield` appearance).\n//\n\ninput[type=\"search\"]::-webkit-search-cancel-button,\ninput[type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none;\n}\n\n//\n// Define consistent border, margin, and padding.\n//\n\nfieldset {\n  border: 1px solid #c0c0c0;\n  margin: 0 2px;\n  padding: 0.35em 0.625em 0.75em;\n}\n\n//\n// 1. Correct `color` not being inherited in IE 8/9/10/11.\n// 2. Remove padding so people aren't caught out if they zero out fieldsets.\n//\n\nlegend {\n  border: 0; // 1\n  padding: 0; // 2\n}\n\n//\n// Remove default vertical scrollbar in IE 8/9/10/11.\n//\n\ntextarea {\n  overflow: auto;\n}\n\n//\n// Don't inherit the `font-weight` (applied by a rule above).\n// NOTE: the default cannot safely be changed in Chrome and Safari on OS X.\n//\n\noptgroup {\n  font-weight: bold;\n}\n\n// Tables\n// ==========================================================================\n\n//\n// Remove most spacing between table cells.\n//\n\ntable {\n  border-collapse: collapse;\n  border-spacing: 0;\n}\n\ntd,\nth {\n  padding: 0;\n}\n","//\n// Glyphicons for Bootstrap\n//\n// Since icons are fonts, they can be placed anywhere text is placed and are\n// thus automatically sized to match the surrounding child. To use, create an\n// inline element with the appropriate classes, like so:\n//\n// <a href=\"#\"><span class=\"glyphicon glyphicon-star\"></span> Star</a>\n\n// Import the fonts\n@font-face {\n  font-family: 'Glyphicons Halflings';\n  src: url('@{icon-font-path}@{icon-font-name}.eot');\n  src: url('@{icon-font-path}@{icon-font-name}.eot?#iefix') format('embedded-opentype'),\n       url('@{icon-font-path}@{icon-font-name}.woff2') format('woff2'),\n       url('@{icon-font-path}@{icon-font-name}.woff') format('woff'),\n       url('@{icon-font-path}@{icon-font-name}.ttf') format('truetype'),\n       url('@{icon-font-path}@{icon-font-name}.svg#@{icon-font-svg-id}') format('svg');\n}\n\n// Catchall baseclass\n.glyphicon {\n  position: relative;\n  top: 1px;\n  display: inline-block;\n  font-family: 'Glyphicons Halflings';\n  font-style: normal;\n  font-weight: normal;\n  line-height: 1;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\n// Individual icons\n.glyphicon-asterisk               { &:before { content: \"\\002a\"; } }\n.glyphicon-plus                   { &:before { content: \"\\002b\"; } }\n.glyphicon-euro,\n.glyphicon-eur                    { &:before { content: \"\\20ac\"; } }\n.glyphicon-minus                  { &:before { content: \"\\2212\"; } }\n.glyphicon-cloud                  { &:before { content: \"\\2601\"; } }\n.glyphicon-envelope               { &:before { content: \"\\2709\"; } }\n.glyphicon-pencil                 { &:before { content: \"\\270f\"; } }\n.glyphicon-glass                  { &:before { content: \"\\e001\"; } }\n.glyphicon-music                  { &:before { content: \"\\e002\"; } }\n.glyphicon-search                 { &:before { content: \"\\e003\"; } }\n.glyphicon-heart                  { &:before { content: \"\\e005\"; } }\n.glyphicon-star                   { &:before { content: \"\\e006\"; } }\n.glyphicon-star-empty             { &:before { content: \"\\e007\"; } }\n.glyphicon-user                   { &:before { content: \"\\e008\"; } }\n.glyphicon-film                   { &:before { content: \"\\e009\"; } }\n.glyphicon-th-large               { &:before { content: \"\\e010\"; } }\n.glyphicon-th                     { &:before { content: \"\\e011\"; } }\n.glyphicon-th-list                { &:before { content: \"\\e012\"; } }\n.glyphicon-ok                     { &:before { content: \"\\e013\"; } }\n.glyphicon-remove                 { &:before { content: \"\\e014\"; } }\n.glyphicon-zoom-in                { &:before { content: \"\\e015\"; } }\n.glyphicon-zoom-out               { &:before { content: \"\\e016\"; } }\n.glyphicon-off                    { &:before { content: \"\\e017\"; } }\n.glyphicon-signal                 { &:before { content: \"\\e018\"; } }\n.glyphicon-cog                    { &:before { content: \"\\e019\"; } }\n.glyphicon-trash                  { &:before { content: \"\\e020\"; } }\n.glyphicon-home                   { &:before { content: \"\\e021\"; } }\n.glyphicon-file                   { &:before { content: \"\\e022\"; } }\n.glyphicon-time                   { &:before { content: \"\\e023\"; } }\n.glyphicon-road                   { &:before { content: \"\\e024\"; } }\n.glyphicon-download-alt           { &:before { content: \"\\e025\"; } }\n.glyphicon-download               { &:before { content: \"\\e026\"; } }\n.glyphicon-upload                 { &:before { content: \"\\e027\"; } }\n.glyphicon-inbox                  { &:before { content: \"\\e028\"; } }\n.glyphicon-play-circle            { &:before { content: \"\\e029\"; } }\n.glyphicon-repeat                 { &:before { content: \"\\e030\"; } }\n.glyphicon-refresh                { &:before { content: \"\\e031\"; } }\n.glyphicon-list-alt               { &:before { content: \"\\e032\"; } }\n.glyphicon-lock                   { &:before { content: \"\\e033\"; } }\n.glyphicon-flag                   { &:before { content: \"\\e034\"; } }\n.glyphicon-headphones             { &:before { content: \"\\e035\"; } }\n.glyphicon-volume-off             { &:before { content: \"\\e036\"; } }\n.glyphicon-volume-down            { &:before { content: \"\\e037\"; } }\n.glyphicon-volume-up              { &:before { content: \"\\e038\"; } }\n.glyphicon-qrcode                 { &:before { content: \"\\e039\"; } }\n.glyphicon-barcode                { &:before { content: \"\\e040\"; } }\n.glyphicon-tag                    { &:before { content: \"\\e041\"; } }\n.glyphicon-tags                   { &:before { content: \"\\e042\"; } }\n.glyphicon-book                   { &:before { content: \"\\e043\"; } }\n.glyphicon-bookmark               { &:before { content: \"\\e044\"; } }\n.glyphicon-print                  { &:before { content: \"\\e045\"; } }\n.glyphicon-camera                 { &:before { content: \"\\e046\"; } }\n.glyphicon-font                   { &:before { content: \"\\e047\"; } }\n.glyphicon-bold                   { &:before { content: \"\\e048\"; } }\n.glyphicon-italic                 { &:before { content: \"\\e049\"; } }\n.glyphicon-text-height            { &:before { content: \"\\e050\"; } }\n.glyphicon-text-width             { &:before { content: \"\\e051\"; } }\n.glyphicon-align-left             { &:before { content: \"\\e052\"; } }\n.glyphicon-align-center           { &:before { content: \"\\e053\"; } }\n.glyphicon-align-right            { &:before { content: \"\\e054\"; } }\n.glyphicon-align-justify          { &:before { content: \"\\e055\"; } }\n.glyphicon-list                   { &:before { content: \"\\e056\"; } }\n.glyphicon-indent-left            { &:before { content: \"\\e057\"; } }\n.glyphicon-indent-right           { &:before { content: \"\\e058\"; } }\n.glyphicon-facetime-video         { &:before { content: \"\\e059\"; } }\n.glyphicon-picture                { &:before { content: \"\\e060\"; } }\n.glyphicon-map-marker             { &:before { content: \"\\e062\"; } }\n.glyphicon-adjust                 { &:before { content: \"\\e063\"; } }\n.glyphicon-tint                   { &:before { content: \"\\e064\"; } }\n.glyphicon-edit                   { &:before { content: \"\\e065\"; } }\n.glyphicon-share                  { &:before { content: \"\\e066\"; } }\n.glyphicon-check                  { &:before { content: \"\\e067\"; } }\n.glyphicon-move                   { &:before { content: \"\\e068\"; } }\n.glyphicon-step-backward          { &:before { content: \"\\e069\"; } }\n.glyphicon-fast-backward          { &:before { content: \"\\e070\"; } }\n.glyphicon-backward               { &:before { content: \"\\e071\"; } }\n.glyphicon-play                   { &:before { content: \"\\e072\"; } }\n.glyphicon-pause                  { &:before { content: \"\\e073\"; } }\n.glyphicon-stop                   { &:before { content: \"\\e074\"; } }\n.glyphicon-forward                { &:before { content: \"\\e075\"; } }\n.glyphicon-fast-forward           { &:before { content: \"\\e076\"; } }\n.glyphicon-step-forward           { &:before { content: \"\\e077\"; } }\n.glyphicon-eject                  { &:before { content: \"\\e078\"; } }\n.glyphicon-chevron-left           { &:before { content: \"\\e079\"; } }\n.glyphicon-chevron-right          { &:before { content: \"\\e080\"; } }\n.glyphicon-plus-sign              { &:before { content: \"\\e081\"; } }\n.glyphicon-minus-sign             { &:before { content: \"\\e082\"; } }\n.glyphicon-remove-sign            { &:before { content: \"\\e083\"; } }\n.glyphicon-ok-sign                { &:before { content: \"\\e084\"; } }\n.glyphicon-question-sign          { &:before { content: \"\\e085\"; } }\n.glyphicon-info-sign              { &:before { content: \"\\e086\"; } }\n.glyphicon-screenshot             { &:before { content: \"\\e087\"; } }\n.glyphicon-remove-circle          { &:before { content: \"\\e088\"; } }\n.glyphicon-ok-circle              { &:before { content: \"\\e089\"; } }\n.glyphicon-ban-circle             { &:before { content: \"\\e090\"; } }\n.glyphicon-arrow-left             { &:before { content: \"\\e091\"; } }\n.glyphicon-arrow-right            { &:before { content: \"\\e092\"; } }\n.glyphicon-arrow-up               { &:before { content: \"\\e093\"; } }\n.glyphicon-arrow-down             { &:before { content: \"\\e094\"; } }\n.glyphicon-share-alt              { &:before { content: \"\\e095\"; } }\n.glyphicon-resize-full            { &:before { content: \"\\e096\"; } }\n.glyphicon-resize-small           { &:before { content: \"\\e097\"; } }\n.glyphicon-exclamation-sign       { &:before { content: \"\\e101\"; } }\n.glyphicon-gift                   { &:before { content: \"\\e102\"; } }\n.glyphicon-leaf                   { &:before { content: \"\\e103\"; } }\n.glyphicon-fire                   { &:before { content: \"\\e104\"; } }\n.glyphicon-eye-open               { &:before { content: \"\\e105\"; } }\n.glyphicon-eye-close              { &:before { content: \"\\e106\"; } }\n.glyphicon-warning-sign           { &:before { content: \"\\e107\"; } }\n.glyphicon-plane                  { &:before { content: \"\\e108\"; } }\n.glyphicon-calendar               { &:before { content: \"\\e109\"; } }\n.glyphicon-random                 { &:before { content: \"\\e110\"; } }\n.glyphicon-comment                { &:before { content: \"\\e111\"; } }\n.glyphicon-magnet                 { &:before { content: \"\\e112\"; } }\n.glyphicon-chevron-up             { &:before { content: \"\\e113\"; } }\n.glyphicon-chevron-down           { &:before { content: \"\\e114\"; } }\n.glyphicon-retweet                { &:before { content: \"\\e115\"; } }\n.glyphicon-shopping-cart          { &:before { content: \"\\e116\"; } }\n.glyphicon-folder-close           { &:before { content: \"\\e117\"; } }\n.glyphicon-folder-open            { &:before { content: \"\\e118\"; } }\n.glyphicon-resize-vertical        { &:before { content: \"\\e119\"; } }\n.glyphicon-resize-horizontal      { &:before { content: \"\\e120\"; } }\n.glyphicon-hdd                    { &:before { content: \"\\e121\"; } }\n.glyphicon-bullhorn               { &:before { content: \"\\e122\"; } }\n.glyphicon-bell                   { &:before { content: \"\\e123\"; } }\n.glyphicon-certificate            { &:before { content: \"\\e124\"; } }\n.glyphicon-thumbs-up              { &:before { content: \"\\e125\"; } }\n.glyphicon-thumbs-down            { &:before { content: \"\\e126\"; } }\n.glyphicon-hand-right             { &:before { content: \"\\e127\"; } }\n.glyphicon-hand-left              { &:before { content: \"\\e128\"; } }\n.glyphicon-hand-up                { &:before { content: \"\\e129\"; } }\n.glyphicon-hand-down              { &:before { content: \"\\e130\"; } }\n.glyphicon-circle-arrow-right     { &:before { content: \"\\e131\"; } }\n.glyphicon-circle-arrow-left      { &:before { content: \"\\e132\"; } }\n.glyphicon-circle-arrow-up        { &:before { content: \"\\e133\"; } }\n.glyphicon-circle-arrow-down      { &:before { content: \"\\e134\"; } }\n.glyphicon-globe                  { &:before { content: \"\\e135\"; } }\n.glyphicon-wrench                 { &:before { content: \"\\e136\"; } }\n.glyphicon-tasks                  { &:before { content: \"\\e137\"; } }\n.glyphicon-filter                 { &:before { content: \"\\e138\"; } }\n.glyphicon-briefcase              { &:before { content: \"\\e139\"; } }\n.glyphicon-fullscreen             { &:before { content: \"\\e140\"; } }\n.glyphicon-dashboard              { &:before { content: \"\\e141\"; } }\n.glyphicon-paperclip              { &:before { content: \"\\e142\"; } }\n.glyphicon-heart-empty            { &:before { content: \"\\e143\"; } }\n.glyphicon-link                   { &:before { content: \"\\e144\"; } }\n.glyphicon-phone                  { &:before { content: \"\\e145\"; } }\n.glyphicon-pushpin                { &:before { content: \"\\e146\"; } }\n.glyphicon-usd                    { &:before { content: \"\\e148\"; } }\n.glyphicon-gbp                    { &:before { content: \"\\e149\"; } }\n.glyphicon-sort                   { &:before { content: \"\\e150\"; } }\n.glyphicon-sort-by-alphabet       { &:before { content: \"\\e151\"; } }\n.glyphicon-sort-by-alphabet-alt   { &:before { content: \"\\e152\"; } }\n.glyphicon-sort-by-order          { &:before { content: \"\\e153\"; } }\n.glyphicon-sort-by-order-alt      { &:before { content: \"\\e154\"; } }\n.glyphicon-sort-by-attributes     { &:before { content: \"\\e155\"; } }\n.glyphicon-sort-by-attributes-alt { &:before { content: \"\\e156\"; } }\n.glyphicon-unchecked              { &:before { content: \"\\e157\"; } }\n.glyphicon-expand                 { &:before { content: \"\\e158\"; } }\n.glyphicon-collapse-down          { &:before { content: \"\\e159\"; } }\n.glyphicon-collapse-up            { &:before { content: \"\\e160\"; } }\n.glyphicon-log-in                 { &:before { content: \"\\e161\"; } }\n.glyphicon-flash                  { &:before { content: \"\\e162\"; } }\n.glyphicon-log-out                { &:before { content: \"\\e163\"; } }\n.glyphicon-new-window             { &:before { content: \"\\e164\"; } }\n.glyphicon-record                 { &:before { content: \"\\e165\"; } }\n.glyphicon-save                   { &:before { content: \"\\e166\"; } }\n.glyphicon-open                   { &:before { content: \"\\e167\"; } }\n.glyphicon-saved                  { &:before { content: \"\\e168\"; } }\n.glyphicon-import                 { &:before { content: \"\\e169\"; } }\n.glyphicon-export                 { &:before { content: \"\\e170\"; } }\n.glyphicon-send                   { &:before { content: \"\\e171\"; } }\n.glyphicon-floppy-disk            { &:before { content: \"\\e172\"; } }\n.glyphicon-floppy-saved           { &:before { content: \"\\e173\"; } }\n.glyphicon-floppy-remove          { &:before { content: \"\\e174\"; } }\n.glyphicon-floppy-save            { &:before { content: \"\\e175\"; } }\n.glyphicon-floppy-open            { &:before { content: \"\\e176\"; } }\n.glyphicon-credit-card            { &:before { content: \"\\e177\"; } }\n.glyphicon-transfer               { &:before { content: \"\\e178\"; } }\n.glyphicon-cutlery                { &:before { content: \"\\e179\"; } }\n.glyphicon-header                 { &:before { content: \"\\e180\"; } }\n.glyphicon-compressed             { &:before { content: \"\\e181\"; } }\n.glyphicon-earphone               { &:before { content: \"\\e182\"; } }\n.glyphicon-phone-alt              { &:before { content: \"\\e183\"; } }\n.glyphicon-tower                  { &:before { content: \"\\e184\"; } }\n.glyphicon-stats                  { &:before { content: \"\\e185\"; } }\n.glyphicon-sd-video               { &:before { content: \"\\e186\"; } }\n.glyphicon-hd-video               { &:before { content: \"\\e187\"; } }\n.glyphicon-subtitles              { &:before { content: \"\\e188\"; } }\n.glyphicon-sound-stereo           { &:before { content: \"\\e189\"; } }\n.glyphicon-sound-dolby            { &:before { content: \"\\e190\"; } }\n.glyphicon-sound-5-1              { &:before { content: \"\\e191\"; } }\n.glyphicon-sound-6-1              { &:before { content: \"\\e192\"; } }\n.glyphicon-sound-7-1              { &:before { content: \"\\e193\"; } }\n.glyphicon-copyright-mark         { &:before { content: \"\\e194\"; } }\n.glyphicon-registration-mark      { &:before { content: \"\\e195\"; } }\n.glyphicon-cloud-download         { &:before { content: \"\\e197\"; } }\n.glyphicon-cloud-upload           { &:before { content: \"\\e198\"; } }\n.glyphicon-tree-conifer           { &:before { content: \"\\e199\"; } }\n.glyphicon-tree-deciduous         { &:before { content: \"\\e200\"; } }\n.glyphicon-cd                     { &:before { content: \"\\e201\"; } }\n.glyphicon-save-file              { &:before { content: \"\\e202\"; } }\n.glyphicon-open-file              { &:before { content: \"\\e203\"; } }\n.glyphicon-level-up               { &:before { content: \"\\e204\"; } }\n.glyphicon-copy                   { &:before { content: \"\\e205\"; } }\n.glyphicon-paste                  { &:before { content: \"\\e206\"; } }\n// The following 2 Glyphicons are omitted for the time being because\n// they currently use Unicode codepoints that are outside the\n// Basic Multilingual Plane (BMP). Older buggy versions of WebKit can't handle\n// non-BMP codepoints in CSS string escapes, and thus can't display these two icons.\n// Notably, the bug affects some older versions of the Android Browser.\n// More info: https://github.com/twbs/bootstrap/issues/10106\n// .glyphicon-door                   { &:before { content: \"\\1f6aa\"; } }\n// .glyphicon-key                    { &:before { content: \"\\1f511\"; } }\n.glyphicon-alert                  { &:before { content: \"\\e209\"; } }\n.glyphicon-equalizer              { &:before { content: \"\\e210\"; } }\n.glyphicon-king                   { &:before { content: \"\\e211\"; } }\n.glyphicon-queen                  { &:before { content: \"\\e212\"; } }\n.glyphicon-pawn                   { &:before { content: \"\\e213\"; } }\n.glyphicon-bishop                 { &:before { content: \"\\e214\"; } }\n.glyphicon-knight                 { &:before { content: \"\\e215\"; } }\n.glyphicon-baby-formula           { &:before { content: \"\\e216\"; } }\n.glyphicon-tent                   { &:before { content: \"\\26fa\"; } }\n.glyphicon-blackboard             { &:before { content: \"\\e218\"; } }\n.glyphicon-bed                    { &:before { content: \"\\e219\"; } }\n.glyphicon-apple                  { &:before { content: \"\\f8ff\"; } }\n.glyphicon-erase                  { &:before { content: \"\\e221\"; } }\n.glyphicon-hourglass              { &:before { content: \"\\231b\"; } }\n.glyphicon-lamp                   { &:before { content: \"\\e223\"; } }\n.glyphicon-duplicate              { &:before { content: \"\\e224\"; } }\n.glyphicon-piggy-bank             { &:before { content: \"\\e225\"; } }\n.glyphicon-scissors               { &:before { content: \"\\e226\"; } }\n.glyphicon-bitcoin                { &:before { content: \"\\e227\"; } }\n.glyphicon-btc                    { &:before { content: \"\\e227\"; } }\n.glyphicon-xbt                    { &:before { content: \"\\e227\"; } }\n.glyphicon-yen                    { &:before { content: \"\\00a5\"; } }\n.glyphicon-jpy                    { &:before { content: \"\\00a5\"; } }\n.glyphicon-ruble                  { &:before { content: \"\\20bd\"; } }\n.glyphicon-rub                    { &:before { content: \"\\20bd\"; } }\n.glyphicon-scale                  { &:before { content: \"\\e230\"; } }\n.glyphicon-ice-lolly              { &:before { content: \"\\e231\"; } }\n.glyphicon-ice-lolly-tasted       { &:before { content: \"\\e232\"; } }\n.glyphicon-education              { &:before { content: \"\\e233\"; } }\n.glyphicon-option-horizontal      { &:before { content: \"\\e234\"; } }\n.glyphicon-option-vertical        { &:before { content: \"\\e235\"; } }\n.glyphicon-menu-hamburger         { &:before { content: \"\\e236\"; } }\n.glyphicon-modal-window           { &:before { content: \"\\e237\"; } }\n.glyphicon-oil                    { &:before { content: \"\\e238\"; } }\n.glyphicon-grain                  { &:before { content: \"\\e239\"; } }\n.glyphicon-sunglasses             { &:before { content: \"\\e240\"; } }\n.glyphicon-text-size              { &:before { content: \"\\e241\"; } }\n.glyphicon-text-color             { &:before { content: \"\\e242\"; } }\n.glyphicon-text-background        { &:before { content: \"\\e243\"; } }\n.glyphicon-object-align-top       { &:before { content: \"\\e244\"; } }\n.glyphicon-object-align-bottom    { &:before { content: \"\\e245\"; } }\n.glyphicon-object-align-horizontal{ &:before { content: \"\\e246\"; } }\n.glyphicon-object-align-left      { &:before { content: \"\\e247\"; } }\n.glyphicon-object-align-vertical  { &:before { content: \"\\e248\"; } }\n.glyphicon-object-align-right     { &:before { content: \"\\e249\"; } }\n.glyphicon-triangle-right         { &:before { content: \"\\e250\"; } }\n.glyphicon-triangle-left          { &:before { content: \"\\e251\"; } }\n.glyphicon-triangle-bottom        { &:before { content: \"\\e252\"; } }\n.glyphicon-triangle-top           { &:before { content: \"\\e253\"; } }\n.glyphicon-console                { &:before { content: \"\\e254\"; } }\n.glyphicon-superscript            { &:before { content: \"\\e255\"; } }\n.glyphicon-subscript              { &:before { content: \"\\e256\"; } }\n.glyphicon-menu-left              { &:before { content: \"\\e257\"; } }\n.glyphicon-menu-right             { &:before { content: \"\\e258\"; } }\n.glyphicon-menu-down              { &:before { content: \"\\e259\"; } }\n.glyphicon-menu-up                { &:before { content: \"\\e260\"; } }\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\n\n// iOS \"clickable elements\" fix for role=\"button\"\n//\n// Fixes \"clickability\" issue (and more generally, the firing of events such as focus as well)\n// for traditionally non-focusable elements with role=\"button\"\n// see https://developer.mozilla.org/en-US/docs/Web/Events/click#Safari_Mobile\n\n[role=\"button\"] {\n  cursor: pointer;\n}\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 have been 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; // Override Firefox's unusual default opacity; 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","// WebKit-style focus\n\n.tab-focus() {\n  // WebKit-specific. Other browsers will keep their default outline style.\n  // (Initially tried to also force default via `outline: initial`,\n  // but that seems to erroneously remove the outline in Firefox altogether.)\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","//\n// Typography\n// --------------------------------------------------\n\n\n// Headings\n// -------------------------\n\nh1, h2, h3, h4, h5, h6,\n.h1, .h2, .h3, .h4, .h5, .h6 {\n  font-family: @headings-font-family;\n  font-weight: @headings-font-weight;\n  line-height: @headings-line-height;\n  color: @headings-color;\n\n  small,\n  .small {\n    font-weight: normal;\n    line-height: 1;\n    color: @headings-small-color;\n  }\n}\n\nh1, .h1,\nh2, .h2,\nh3, .h3 {\n  margin-top: @line-height-computed;\n  margin-bottom: (@line-height-computed / 2);\n\n  small,\n  .small {\n    font-size: 65%;\n  }\n}\nh4, .h4,\nh5, .h5,\nh6, .h6 {\n  margin-top: (@line-height-computed / 2);\n  margin-bottom: (@line-height-computed / 2);\n\n  small,\n  .small {\n    font-size: 75%;\n  }\n}\n\nh1, .h1 { font-size: @font-size-h1; }\nh2, .h2 { font-size: @font-size-h2; }\nh3, .h3 { font-size: @font-size-h3; }\nh4, .h4 { font-size: @font-size-h4; }\nh5, .h5 { font-size: @font-size-h5; }\nh6, .h6 { font-size: @font-size-h6; }\n\n\n// Body text\n// -------------------------\n\np {\n  margin: 0 0 (@line-height-computed / 2);\n}\n\n.lead {\n  margin-bottom: @line-height-computed;\n  font-size: floor((@font-size-base * 1.15));\n  font-weight: 300;\n  line-height: 1.4;\n\n  @media (min-width: @screen-sm-min) {\n    font-size: (@font-size-base * 1.5);\n  }\n}\n\n\n// Emphasis & misc\n// -------------------------\n\n// Ex: (12px small font / 14px base font) * 100% = about 85%\nsmall,\n.small {\n  font-size: floor((100% * @font-size-small / @font-size-base));\n}\n\nmark,\n.mark {\n  background-color: @state-warning-bg;\n  padding: .2em;\n}\n\n// Alignment\n.text-left           { text-align: left; }\n.text-right          { text-align: right; }\n.text-center         { text-align: center; }\n.text-justify        { text-align: justify; }\n.text-nowrap         { white-space: nowrap; }\n\n// Transformation\n.text-lowercase      { text-transform: lowercase; }\n.text-uppercase      { text-transform: uppercase; }\n.text-capitalize     { text-transform: capitalize; }\n\n// Contextual colors\n.text-muted {\n  color: @text-muted;\n}\n.text-primary {\n  .text-emphasis-variant(@brand-primary);\n}\n.text-success {\n  .text-emphasis-variant(@state-success-text);\n}\n.text-info {\n  .text-emphasis-variant(@state-info-text);\n}\n.text-warning {\n  .text-emphasis-variant(@state-warning-text);\n}\n.text-danger {\n  .text-emphasis-variant(@state-danger-text);\n}\n\n// Contextual backgrounds\n// For now we'll leave these alongside the text classes until v4 when we can\n// safely shift things around (per SemVer rules).\n.bg-primary {\n  // Given the contrast here, this is the only class to have its color inverted\n  // automatically.\n  color: #fff;\n  .bg-variant(@brand-primary);\n}\n.bg-success {\n  .bg-variant(@state-success-bg);\n}\n.bg-info {\n  .bg-variant(@state-info-bg);\n}\n.bg-warning {\n  .bg-variant(@state-warning-bg);\n}\n.bg-danger {\n  .bg-variant(@state-danger-bg);\n}\n\n\n// Page header\n// -------------------------\n\n.page-header {\n  padding-bottom: ((@line-height-computed / 2) - 1);\n  margin: (@line-height-computed * 2) 0 @line-height-computed;\n  border-bottom: 1px solid @page-header-border-color;\n}\n\n\n// Lists\n// -------------------------\n\n// Unordered and Ordered lists\nul,\nol {\n  margin-top: 0;\n  margin-bottom: (@line-height-computed / 2);\n  ul,\n  ol {\n    margin-bottom: 0;\n  }\n}\n\n// List options\n\n// Unstyled keeps list items block level, just removes default browser padding and list-style\n.list-unstyled {\n  padding-left: 0;\n  list-style: none;\n}\n\n// Inline turns list items into inline-block\n.list-inline {\n  .list-unstyled();\n  margin-left: -5px;\n\n  > li {\n    display: inline-block;\n    padding-left: 5px;\n    padding-right: 5px;\n  }\n}\n\n// Description Lists\ndl {\n  margin-top: 0; // Remove browser default\n  margin-bottom: @line-height-computed;\n}\ndt,\ndd {\n  line-height: @line-height-base;\n}\ndt {\n  font-weight: bold;\n}\ndd {\n  margin-left: 0; // Undo browser default\n}\n\n// Horizontal description lists\n//\n// Defaults to being stacked without any of the below styles applied, until the\n// grid breakpoint is reached (default of ~768px).\n\n.dl-horizontal {\n  dd {\n    &:extend(.clearfix all); // Clear the floated `dt` if an empty `dd` is present\n  }\n\n  @media (min-width: @dl-horizontal-breakpoint) {\n    dt {\n      float: left;\n      width: (@dl-horizontal-offset - 20);\n      clear: left;\n      text-align: right;\n      .text-overflow();\n    }\n    dd {\n      margin-left: @dl-horizontal-offset;\n    }\n  }\n}\n\n\n// Misc\n// -------------------------\n\n// Abbreviations and acronyms\nabbr[title],\n// Add data-* attribute to help out our tooltip plugin, per https://github.com/twbs/bootstrap/issues/5257\nabbr[data-original-title] {\n  cursor: help;\n  border-bottom: 1px dotted @abbr-border-color;\n}\n.initialism {\n  font-size: 90%;\n  .text-uppercase();\n}\n\n// Blockquotes\nblockquote {\n  padding: (@line-height-computed / 2) @line-height-computed;\n  margin: 0 0 @line-height-computed;\n  font-size: @blockquote-font-size;\n  border-left: 5px solid @blockquote-border-color;\n\n  p,\n  ul,\n  ol {\n    &:last-child {\n      margin-bottom: 0;\n    }\n  }\n\n  // Note: Deprecated small and .small as of v3.1.0\n  // Context: https://github.com/twbs/bootstrap/issues/11660\n  footer,\n  small,\n  .small {\n    display: block;\n    font-size: 80%; // back to default font-size\n    line-height: @line-height-base;\n    color: @blockquote-small-color;\n\n    &:before {\n      content: '\\2014 \\00A0'; // em dash, nbsp\n    }\n  }\n}\n\n// Opposite alignment of blockquote\n//\n// Heads up: `blockquote.pull-right` has been deprecated as of v3.1.0.\n.blockquote-reverse,\nblockquote.pull-right {\n  padding-right: 15px;\n  padding-left: 0;\n  border-right: 5px solid @blockquote-border-color;\n  border-left: 0;\n  text-align: right;\n\n  // Account for citation\n  footer,\n  small,\n  .small {\n    &:before { content: ''; }\n    &:after {\n      content: '\\00A0 \\2014'; // nbsp, em dash\n    }\n  }\n}\n\n// Addresses\naddress {\n  margin-bottom: @line-height-computed;\n  font-style: normal;\n  line-height: @line-height-base;\n}\n","// Typography\n\n.text-emphasis-variant(@color) {\n  color: @color;\n  a&:hover,\n  a&:focus {\n    color: darken(@color, 10%);\n  }\n}\n","// Contextual backgrounds\n\n.bg-variant(@color) {\n  background-color: @color;\n  a&:hover,\n  a&:focus {\n    background-color: darken(@color, 10%);\n  }\n}\n","// Text overflow\n// Requires inline-block or block for proper styling\n\n.text-overflow() {\n  overflow: hidden;\n  text-overflow: ellipsis;\n  white-space: nowrap;\n}\n","//\n// Code (inline and block)\n// --------------------------------------------------\n\n\n// Inline and block code styles\ncode,\nkbd,\npre,\nsamp {\n  font-family: @font-family-monospace;\n}\n\n// Inline code\ncode {\n  padding: 2px 4px;\n  font-size: 90%;\n  color: @code-color;\n  background-color: @code-bg;\n  border-radius: @border-radius-base;\n}\n\n// User input typically entered via keyboard\nkbd {\n  padding: 2px 4px;\n  font-size: 90%;\n  color: @kbd-color;\n  background-color: @kbd-bg;\n  border-radius: @border-radius-small;\n  box-shadow: inset 0 -1px 0 rgba(0,0,0,.25);\n\n  kbd {\n    padding: 0;\n    font-size: 100%;\n    font-weight: bold;\n    box-shadow: none;\n  }\n}\n\n// Blocks of code\npre {\n  display: block;\n  padding: ((@line-height-computed - 1) / 2);\n  margin: 0 0 (@line-height-computed / 2);\n  font-size: (@font-size-base - 1); // 14px to 13px\n  line-height: @line-height-base;\n  word-break: break-all;\n  word-wrap: break-word;\n  color: @pre-color;\n  background-color: @pre-bg;\n  border: 1px solid @pre-border-color;\n  border-radius: @border-radius-base;\n\n  // Account for some code outputs that place code tags in pre tags\n  code {\n    padding: 0;\n    font-size: inherit;\n    color: inherit;\n    white-space: pre-wrap;\n    background-color: transparent;\n    border-radius: 0;\n  }\n}\n\n// Enable scrollable blocks of code\n.pre-scrollable {\n  max-height: @pre-scrollable-max-height;\n  overflow-y: scroll;\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","// 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:  floor((@gutter / 2));\n  padding-right: ceil((@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:  ceil((@gutter / -2));\n  margin-right: floor((@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","// 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:  ceil((@grid-gutter-width / 2));\n      padding-right: floor((@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","//\n// Tables\n// --------------------------------------------------\n\n\ntable {\n  background-color: @table-bg;\n}\ncaption {\n  padding-top: @table-cell-padding;\n  padding-bottom: @table-cell-padding;\n  color: @text-muted;\n  text-align: left;\n}\nth {\n  text-align: left;\n}\n\n\n// Baseline styles\n\n.table {\n  width: 100%;\n  max-width: 100%;\n  margin-bottom: @line-height-computed;\n  // Cells\n  > thead,\n  > tbody,\n  > tfoot {\n    > tr {\n      > th,\n      > td {\n        padding: @table-cell-padding;\n        line-height: @line-height-base;\n        vertical-align: top;\n        border-top: 1px solid @table-border-color;\n      }\n    }\n  }\n  // Bottom align for column headings\n  > thead > tr > th {\n    vertical-align: bottom;\n    border-bottom: 2px solid @table-border-color;\n  }\n  // Remove top border from thead by default\n  > caption + thead,\n  > colgroup + thead,\n  > thead:first-child {\n    > tr:first-child {\n      > th,\n      > td {\n        border-top: 0;\n      }\n    }\n  }\n  // Account for multiple tbody instances\n  > tbody + tbody {\n    border-top: 2px solid @table-border-color;\n  }\n\n  // Nesting\n  .table {\n    background-color: @body-bg;\n  }\n}\n\n\n// Condensed table w/ half padding\n\n.table-condensed {\n  > thead,\n  > tbody,\n  > tfoot {\n    > tr {\n      > th,\n      > td {\n        padding: @table-condensed-cell-padding;\n      }\n    }\n  }\n}\n\n\n// Bordered version\n//\n// Add borders all around the table and between all the columns.\n\n.table-bordered {\n  border: 1px solid @table-border-color;\n  > thead,\n  > tbody,\n  > tfoot {\n    > tr {\n      > th,\n      > td {\n        border: 1px solid @table-border-color;\n      }\n    }\n  }\n  > thead > tr {\n    > th,\n    > td {\n      border-bottom-width: 2px;\n    }\n  }\n}\n\n\n// Zebra-striping\n//\n// Default zebra-stripe styles (alternating gray and transparent backgrounds)\n\n.table-striped {\n  > tbody > tr:nth-of-type(odd) {\n    background-color: @table-bg-accent;\n  }\n}\n\n\n// Hover effect\n//\n// Placed here since it has to come after the potential zebra striping\n\n.table-hover {\n  > tbody > tr:hover {\n    background-color: @table-bg-hover;\n  }\n}\n\n\n// Table cell sizing\n//\n// Reset default table behavior\n\ntable col[class*=\"col-\"] {\n  position: static; // Prevent border hiding in Firefox and IE9-11 (see https://github.com/twbs/bootstrap/issues/11623)\n  float: none;\n  display: table-column;\n}\ntable {\n  td,\n  th {\n    &[class*=\"col-\"] {\n      position: static; // Prevent border hiding in Firefox and IE9-11 (see https://github.com/twbs/bootstrap/issues/11623)\n      float: none;\n      display: table-cell;\n    }\n  }\n}\n\n\n// Table backgrounds\n//\n// Exact selectors below required to override `.table-striped` and prevent\n// inheritance to nested tables.\n\n// Generate the contextual variants\n.table-row-variant(active; @table-bg-active);\n.table-row-variant(success; @state-success-bg);\n.table-row-variant(info; @state-info-bg);\n.table-row-variant(warning; @state-warning-bg);\n.table-row-variant(danger; @state-danger-bg);\n\n\n// Responsive tables\n//\n// Wrap your tables in `.table-responsive` and we'll make them mobile friendly\n// by enabling horizontal scrolling. Only applies <768px. Everything above that\n// will display normally.\n\n.table-responsive {\n  overflow-x: auto;\n  min-height: 0.01%; // Workaround for IE9 bug (see https://github.com/twbs/bootstrap/issues/14837)\n\n  @media screen and (max-width: @screen-xs-max) {\n    width: 100%;\n    margin-bottom: (@line-height-computed * 0.75);\n    overflow-y: hidden;\n    -ms-overflow-style: -ms-autohiding-scrollbar;\n    border: 1px solid @table-border-color;\n\n    // Tighten up spacing\n    > .table {\n      margin-bottom: 0;\n\n      // Ensure the content doesn't wrap\n      > thead,\n      > tbody,\n      > tfoot {\n        > tr {\n          > th,\n          > td {\n            white-space: nowrap;\n          }\n        }\n      }\n    }\n\n    // Special overrides for the bordered tables\n    > .table-bordered {\n      border: 0;\n\n      // Nuke the appropriate borders so that the parent can handle them\n      > thead,\n      > tbody,\n      > tfoot {\n        > tr {\n          > th:first-child,\n          > td:first-child {\n            border-left: 0;\n          }\n          > th:last-child,\n          > td:last-child {\n            border-right: 0;\n          }\n        }\n      }\n\n      // Only nuke the last row's bottom-border in `tbody` and `tfoot` since\n      // chances are there will be only one `tr` in a `thead` and that would\n      // remove the border altogether.\n      > tbody,\n      > tfoot {\n        > tr:last-child {\n          > th,\n          > td {\n            border-bottom: 0;\n          }\n        }\n      }\n\n    }\n  }\n}\n","// Tables\n\n.table-row-variant(@state; @background) {\n  // Exact selectors below required to override `.table-striped` and prevent\n  // inheritance to nested tables.\n  .table > thead > tr,\n  .table > tbody > tr,\n  .table > tfoot > tr {\n    > td.@{state},\n    > th.@{state},\n    &.@{state} > td,\n    &.@{state} > th {\n      background-color: @background;\n    }\n  }\n\n  // Hover states for `.table-hover`\n  // Note: this is not available for cells or rows within `thead` or `tfoot`.\n  .table-hover > tbody > tr {\n    > td.@{state}:hover,\n    > th.@{state}:hover,\n    &.@{state}:hover > td,\n    &:hover > .@{state},\n    &.@{state}:hover > th {\n      background-color: darken(@background, 5%);\n    }\n  }\n}\n","//\n// Forms\n// --------------------------------------------------\n\n\n// Normalize non-controls\n//\n// Restyle and baseline non-control form elements.\n\nfieldset {\n  padding: 0;\n  margin: 0;\n  border: 0;\n  // Chrome and Firefox set a `min-width: min-content;` on fieldsets,\n  // so we reset that to ensure it behaves more like a standard block element.\n  // See https://github.com/twbs/bootstrap/issues/12359.\n  min-width: 0;\n}\n\nlegend {\n  display: block;\n  width: 100%;\n  padding: 0;\n  margin-bottom: @line-height-computed;\n  font-size: (@font-size-base * 1.5);\n  line-height: inherit;\n  color: @legend-color;\n  border: 0;\n  border-bottom: 1px solid @legend-border-color;\n}\n\nlabel {\n  display: inline-block;\n  max-width: 100%; // Force IE8 to wrap long content (see https://github.com/twbs/bootstrap/issues/13141)\n  margin-bottom: 5px;\n  font-weight: bold;\n}\n\n\n// Normalize form controls\n//\n// While most of our form styles require extra classes, some basic normalization\n// is required to ensure optimum display with or without those classes to better\n// address browser inconsistencies.\n\n// Override content-box in Normalize (* isn't specific enough)\ninput[type=\"search\"] {\n  .box-sizing(border-box);\n}\n\n// Position radios and checkboxes better\ninput[type=\"radio\"],\ninput[type=\"checkbox\"] {\n  margin: 4px 0 0;\n  margin-top: 1px \\9; // IE8-9\n  line-height: normal;\n}\n\ninput[type=\"file\"] {\n  display: block;\n}\n\n// Make range inputs behave like textual form controls\ninput[type=\"range\"] {\n  display: block;\n  width: 100%;\n}\n\n// Make multiple select elements height not fixed\nselect[multiple],\nselect[size] {\n  height: auto;\n}\n\n// Focus for file, radio, and checkbox\ninput[type=\"file\"]:focus,\ninput[type=\"radio\"]:focus,\ninput[type=\"checkbox\"]:focus {\n  .tab-focus();\n}\n\n// Adjust output element\noutput {\n  display: block;\n  padding-top: (@padding-base-vertical + 1);\n  font-size: @font-size-base;\n  line-height: @line-height-base;\n  color: @input-color;\n}\n\n\n// Common form controls\n//\n// Shared size and type resets for form controls. Apply `.form-control` to any\n// of the following form controls:\n//\n// select\n// textarea\n// input[type=\"text\"]\n// input[type=\"password\"]\n// input[type=\"datetime\"]\n// input[type=\"datetime-local\"]\n// input[type=\"date\"]\n// input[type=\"month\"]\n// input[type=\"time\"]\n// input[type=\"week\"]\n// input[type=\"number\"]\n// input[type=\"email\"]\n// input[type=\"url\"]\n// input[type=\"search\"]\n// input[type=\"tel\"]\n// input[type=\"color\"]\n\n.form-control {\n  display: block;\n  width: 100%;\n  height: @input-height-base; // Make inputs at least the height of their button counterpart (base line-height + padding + border)\n  padding: @padding-base-vertical @padding-base-horizontal;\n  font-size: @font-size-base;\n  line-height: @line-height-base;\n  color: @input-color;\n  background-color: @input-bg;\n  background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214\n  border: 1px solid @input-border;\n  border-radius: @input-border-radius; // Note: This has no effect on <select>s in some browsers, due to the limited stylability of <select>s in CSS.\n  .box-shadow(inset 0 1px 1px rgba(0,0,0,.075));\n  .transition(~\"border-color ease-in-out .15s, box-shadow ease-in-out .15s\");\n\n  // Customize the `:focus` state to imitate native WebKit styles.\n  .form-control-focus();\n\n  // Placeholder\n  .placeholder();\n\n  // Unstyle the caret on `<select>`s in IE10+.\n  &::-ms-expand {\n    border: 0;\n    background-color: transparent;\n  }\n\n  // Disabled and read-only inputs\n  //\n  // HTML5 says that controls under a fieldset > legend:first-child won't be\n  // disabled if the fieldset is disabled. Due to implementation difficulty, we\n  // don't honor that edge case; we style them as disabled anyway.\n  &[disabled],\n  &[readonly],\n  fieldset[disabled] & {\n    background-color: @input-bg-disabled;\n    opacity: 1; // iOS fix for unreadable disabled content; see https://github.com/twbs/bootstrap/issues/11655\n  }\n\n  &[disabled],\n  fieldset[disabled] & {\n    cursor: @cursor-disabled;\n  }\n\n  // Reset height for `textarea`s\n  textarea& {\n    height: auto;\n  }\n}\n\n\n// Search inputs in iOS\n//\n// This overrides the extra rounded corners on search inputs in iOS so that our\n// `.form-control` class can properly style them. Note that this cannot simply\n// be added to `.form-control` as it's not specific enough. For details, see\n// https://github.com/twbs/bootstrap/issues/11586.\n\ninput[type=\"search\"] {\n  -webkit-appearance: none;\n}\n\n\n// Special styles for iOS temporal inputs\n//\n// In Mobile Safari, setting `display: block` on temporal inputs causes the\n// text within the input to become vertically misaligned. As a workaround, we\n// set a pixel line-height that matches the given height of the input, but only\n// for Safari. See https://bugs.webkit.org/show_bug.cgi?id=139848\n//\n// Note that as of 9.3, iOS doesn't support `week`.\n\n@media screen and (-webkit-min-device-pixel-ratio: 0) {\n  input[type=\"date\"],\n  input[type=\"time\"],\n  input[type=\"datetime-local\"],\n  input[type=\"month\"] {\n    &.form-control {\n      line-height: @input-height-base;\n    }\n\n    &.input-sm,\n    .input-group-sm & {\n      line-height: @input-height-small;\n    }\n\n    &.input-lg,\n    .input-group-lg & {\n      line-height: @input-height-large;\n    }\n  }\n}\n\n\n// Form groups\n//\n// Designed to help with the organization and spacing of vertical forms. For\n// horizontal forms, use the predefined grid classes.\n\n.form-group {\n  margin-bottom: @form-group-margin-bottom;\n}\n\n\n// Checkboxes and radios\n//\n// Indent the labels to position radios/checkboxes as hanging controls.\n\n.radio,\n.checkbox {\n  position: relative;\n  display: block;\n  margin-top: 10px;\n  margin-bottom: 10px;\n\n  label {\n    min-height: @line-height-computed; // Ensure the input doesn't jump when there is no text\n    padding-left: 20px;\n    margin-bottom: 0;\n    font-weight: normal;\n    cursor: pointer;\n  }\n}\n.radio input[type=\"radio\"],\n.radio-inline input[type=\"radio\"],\n.checkbox input[type=\"checkbox\"],\n.checkbox-inline input[type=\"checkbox\"] {\n  position: absolute;\n  margin-left: -20px;\n  margin-top: 4px \\9;\n}\n\n.radio + .radio,\n.checkbox + .checkbox {\n  margin-top: -5px; // Move up sibling radios or checkboxes for tighter spacing\n}\n\n// Radios and checkboxes on same line\n.radio-inline,\n.checkbox-inline {\n  position: relative;\n  display: inline-block;\n  padding-left: 20px;\n  margin-bottom: 0;\n  vertical-align: middle;\n  font-weight: normal;\n  cursor: pointer;\n}\n.radio-inline + .radio-inline,\n.checkbox-inline + .checkbox-inline {\n  margin-top: 0;\n  margin-left: 10px; // space out consecutive inline controls\n}\n\n// Apply same disabled cursor tweak as for inputs\n// Some special care is needed because <label>s don't inherit their parent's `cursor`.\n//\n// Note: Neither radios nor checkboxes can be readonly.\ninput[type=\"radio\"],\ninput[type=\"checkbox\"] {\n  &[disabled],\n  &.disabled,\n  fieldset[disabled] & {\n    cursor: @cursor-disabled;\n  }\n}\n// These classes are used directly on <label>s\n.radio-inline,\n.checkbox-inline {\n  &.disabled,\n  fieldset[disabled] & {\n    cursor: @cursor-disabled;\n  }\n}\n// These classes are used on elements with <label> descendants\n.radio,\n.checkbox {\n  &.disabled,\n  fieldset[disabled] & {\n    label {\n      cursor: @cursor-disabled;\n    }\n  }\n}\n\n\n// Static form control text\n//\n// Apply class to a `p` element to make any string of text align with labels in\n// a horizontal form layout.\n\n.form-control-static {\n  // Size it appropriately next to real form controls\n  padding-top: (@padding-base-vertical + 1);\n  padding-bottom: (@padding-base-vertical + 1);\n  // Remove default margin from `p`\n  margin-bottom: 0;\n  min-height: (@line-height-computed + @font-size-base);\n\n  &.input-lg,\n  &.input-sm {\n    padding-left: 0;\n    padding-right: 0;\n  }\n}\n\n\n// Form control sizing\n//\n// Build on `.form-control` with modifier classes to decrease or increase the\n// height and font-size of form controls.\n//\n// The `.form-group-* form-control` variations are sadly duplicated to avoid the\n// issue documented in https://github.com/twbs/bootstrap/issues/15074.\n\n.input-sm {\n  .input-size(@input-height-small; @padding-small-vertical; @padding-small-horizontal; @font-size-small; @line-height-small; @input-border-radius-small);\n}\n.form-group-sm {\n  .form-control {\n    height: @input-height-small;\n    padding: @padding-small-vertical @padding-small-horizontal;\n    font-size: @font-size-small;\n    line-height: @line-height-small;\n    border-radius: @input-border-radius-small;\n  }\n  select.form-control {\n    height: @input-height-small;\n    line-height: @input-height-small;\n  }\n  textarea.form-control,\n  select[multiple].form-control {\n    height: auto;\n  }\n  .form-control-static {\n    height: @input-height-small;\n    min-height: (@line-height-computed + @font-size-small);\n    padding: (@padding-small-vertical + 1) @padding-small-horizontal;\n    font-size: @font-size-small;\n    line-height: @line-height-small;\n  }\n}\n\n.input-lg {\n  .input-size(@input-height-large; @padding-large-vertical; @padding-large-horizontal; @font-size-large; @line-height-large; @input-border-radius-large);\n}\n.form-group-lg {\n  .form-control {\n    height: @input-height-large;\n    padding: @padding-large-vertical @padding-large-horizontal;\n    font-size: @font-size-large;\n    line-height: @line-height-large;\n    border-radius: @input-border-radius-large;\n  }\n  select.form-control {\n    height: @input-height-large;\n    line-height: @input-height-large;\n  }\n  textarea.form-control,\n  select[multiple].form-control {\n    height: auto;\n  }\n  .form-control-static {\n    height: @input-height-large;\n    min-height: (@line-height-computed + @font-size-large);\n    padding: (@padding-large-vertical + 1) @padding-large-horizontal;\n    font-size: @font-size-large;\n    line-height: @line-height-large;\n  }\n}\n\n\n// Form control feedback states\n//\n// Apply contextual and semantic states to individual form controls.\n\n.has-feedback {\n  // Enable absolute positioning\n  position: relative;\n\n  // Ensure icons don't overlap text\n  .form-control {\n    padding-right: (@input-height-base * 1.25);\n  }\n}\n// Feedback icon (requires .glyphicon classes)\n.form-control-feedback {\n  position: absolute;\n  top: 0;\n  right: 0;\n  z-index: 2; // Ensure icon is above input groups\n  display: block;\n  width: @input-height-base;\n  height: @input-height-base;\n  line-height: @input-height-base;\n  text-align: center;\n  pointer-events: none;\n}\n.input-lg + .form-control-feedback,\n.input-group-lg + .form-control-feedback,\n.form-group-lg .form-control + .form-control-feedback {\n  width: @input-height-large;\n  height: @input-height-large;\n  line-height: @input-height-large;\n}\n.input-sm + .form-control-feedback,\n.input-group-sm + .form-control-feedback,\n.form-group-sm .form-control + .form-control-feedback {\n  width: @input-height-small;\n  height: @input-height-small;\n  line-height: @input-height-small;\n}\n\n// Feedback states\n.has-success {\n  .form-control-validation(@state-success-text; @state-success-text; @state-success-bg);\n}\n.has-warning {\n  .form-control-validation(@state-warning-text; @state-warning-text; @state-warning-bg);\n}\n.has-error {\n  .form-control-validation(@state-danger-text; @state-danger-text; @state-danger-bg);\n}\n\n// Reposition feedback icon if input has visible label above\n.has-feedback label {\n\n  & ~ .form-control-feedback {\n    top: (@line-height-computed + 5); // Height of the `label` and its margin\n  }\n  &.sr-only ~ .form-control-feedback {\n    top: 0;\n  }\n}\n\n\n// Help text\n//\n// Apply to any element you wish to create light text for placement immediately\n// below a form control. Use for general help, formatting, or instructional text.\n\n.help-block {\n  display: block; // account for any element using help-block\n  margin-top: 5px;\n  margin-bottom: 10px;\n  color: lighten(@text-color, 25%); // lighten the text some for contrast\n}\n\n\n// Inline forms\n//\n// Make forms appear inline(-block) by adding the `.form-inline` class. Inline\n// forms begin stacked on extra small (mobile) devices and then go inline when\n// viewports reach <768px.\n//\n// Requires wrapping inputs and labels with `.form-group` for proper display of\n// default HTML form controls and our custom form controls (e.g., input groups).\n//\n// Heads up! This is mixin-ed into `.navbar-form` in navbars.less.\n\n.form-inline {\n\n  // Kick in the inline\n  @media (min-width: @screen-sm-min) {\n    // Inline-block all the things for \"inline\"\n    .form-group {\n      display: inline-block;\n      margin-bottom: 0;\n      vertical-align: middle;\n    }\n\n    // In navbar-form, allow folks to *not* use `.form-group`\n    .form-control {\n      display: inline-block;\n      width: auto; // Prevent labels from stacking above inputs in `.form-group`\n      vertical-align: middle;\n    }\n\n    // Make static controls behave like regular ones\n    .form-control-static {\n      display: inline-block;\n    }\n\n    .input-group {\n      display: inline-table;\n      vertical-align: middle;\n\n      .input-group-addon,\n      .input-group-btn,\n      .form-control {\n        width: auto;\n      }\n    }\n\n    // Input groups need that 100% width though\n    .input-group > .form-control {\n      width: 100%;\n    }\n\n    .control-label {\n      margin-bottom: 0;\n      vertical-align: middle;\n    }\n\n    // Remove default margin on radios/checkboxes that were used for stacking, and\n    // then undo the floating of radios and checkboxes to match.\n    .radio,\n    .checkbox {\n      display: inline-block;\n      margin-top: 0;\n      margin-bottom: 0;\n      vertical-align: middle;\n\n      label {\n        padding-left: 0;\n      }\n    }\n    .radio input[type=\"radio\"],\n    .checkbox input[type=\"checkbox\"] {\n      position: relative;\n      margin-left: 0;\n    }\n\n    // Re-override the feedback icon.\n    .has-feedback .form-control-feedback {\n      top: 0;\n    }\n  }\n}\n\n\n// Horizontal forms\n//\n// Horizontal forms are built on grid classes and allow you to create forms with\n// labels on the left and inputs on the right.\n\n.form-horizontal {\n\n  // Consistent vertical alignment of radios and checkboxes\n  //\n  // Labels also get some reset styles, but that is scoped to a media query below.\n  .radio,\n  .checkbox,\n  .radio-inline,\n  .checkbox-inline {\n    margin-top: 0;\n    margin-bottom: 0;\n    padding-top: (@padding-base-vertical + 1); // Default padding plus a border\n  }\n  // Account for padding we're adding to ensure the alignment and of help text\n  // and other content below items\n  .radio,\n  .checkbox {\n    min-height: (@line-height-computed + (@padding-base-vertical + 1));\n  }\n\n  // Make form groups behave like rows\n  .form-group {\n    .make-row();\n  }\n\n  // Reset spacing and right align labels, but scope to media queries so that\n  // labels on narrow viewports stack the same as a default form example.\n  @media (min-width: @screen-sm-min) {\n    .control-label {\n      text-align: right;\n      margin-bottom: 0;\n      padding-top: (@padding-base-vertical + 1); // Default padding plus a border\n    }\n  }\n\n  // Validation states\n  //\n  // Reposition the icon because it's now within a grid column and columns have\n  // `position: relative;` on them. Also accounts for the grid gutter padding.\n  .has-feedback .form-control-feedback {\n    right: floor((@grid-gutter-width / 2));\n  }\n\n  // Form group sizes\n  //\n  // Quick utility class for applying `.input-lg` and `.input-sm` styles to the\n  // inputs and labels within a `.form-group`.\n  .form-group-lg {\n    @media (min-width: @screen-sm-min) {\n      .control-label {\n        padding-top: (@padding-large-vertical + 1);\n        font-size: @font-size-large;\n      }\n    }\n  }\n  .form-group-sm {\n    @media (min-width: @screen-sm-min) {\n      .control-label {\n        padding-top: (@padding-small-vertical + 1);\n        font-size: @font-size-small;\n      }\n    }\n  }\n}\n","// Form validation states\n//\n// Used in forms.less to generate the form validation CSS for warnings, errors,\n// and successes.\n\n.form-control-validation(@text-color: #555; @border-color: #ccc; @background-color: #f5f5f5) {\n  // Color the label and help text\n  .help-block,\n  .control-label,\n  .radio,\n  .checkbox,\n  .radio-inline,\n  .checkbox-inline,\n  &.radio label,\n  &.checkbox label,\n  &.radio-inline label,\n  &.checkbox-inline label  {\n    color: @text-color;\n  }\n  // Set the border and box shadow on specific inputs to match\n  .form-control {\n    border-color: @border-color;\n    .box-shadow(inset 0 1px 1px rgba(0,0,0,.075)); // Redeclare so transitions work\n    &:focus {\n      border-color: darken(@border-color, 10%);\n      @shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 6px lighten(@border-color, 20%);\n      .box-shadow(@shadow);\n    }\n  }\n  // Set validation states also for addons\n  .input-group-addon {\n    color: @text-color;\n    border-color: @border-color;\n    background-color: @background-color;\n  }\n  // Optional feedback icon\n  .form-control-feedback {\n    color: @text-color;\n  }\n}\n\n\n// Form control focus state\n//\n// Generate a customized focus state and for any input with the specified color,\n// which defaults to the `@input-border-focus` variable.\n//\n// We highly encourage you to not customize the default value, but instead use\n// this to tweak colors on an as-needed basis. This aesthetic change is based on\n// WebKit's default styles, but applicable to a wider range of browsers. Its\n// usability and accessibility should be taken into account with any change.\n//\n// Example usage: change the default blue border and shadow to white for better\n// contrast against a dark gray background.\n.form-control-focus(@color: @input-border-focus) {\n  @color-rgba: rgba(red(@color), green(@color), blue(@color), .6);\n  &:focus {\n    border-color: @color;\n    outline: 0;\n    .box-shadow(~\"inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px @{color-rgba}\");\n  }\n}\n\n// Form control sizing\n//\n// Relative text size, padding, and border-radii changes for form controls. For\n// horizontal sizing, wrap controls in the predefined grid classes. `<select>`\n// element gets special love because it's special, and that's a fact!\n.input-size(@input-height; @padding-vertical; @padding-horizontal; @font-size; @line-height; @border-radius) {\n  height: @input-height;\n  padding: @padding-vertical @padding-horizontal;\n  font-size: @font-size;\n  line-height: @line-height;\n  border-radius: @border-radius;\n\n  select& {\n    height: @input-height;\n    line-height: @input-height;\n  }\n\n  textarea&,\n  select[multiple]& {\n    height: auto;\n  }\n}\n","//\n// Buttons\n// --------------------------------------------------\n\n\n// Base styles\n// --------------------------------------------------\n\n.btn {\n  display: inline-block;\n  margin-bottom: 0; // For input.btn\n  font-weight: @btn-font-weight;\n  text-align: center;\n  vertical-align: middle;\n  touch-action: manipulation;\n  cursor: pointer;\n  background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214\n  border: 1px solid transparent;\n  white-space: nowrap;\n  .button-size(@padding-base-vertical; @padding-base-horizontal; @font-size-base; @line-height-base; @btn-border-radius-base);\n  .user-select(none);\n\n  &,\n  &:active,\n  &.active {\n    &:focus,\n    &.focus {\n      .tab-focus();\n    }\n  }\n\n  &:hover,\n  &:focus,\n  &.focus {\n    color: @btn-default-color;\n    text-decoration: none;\n  }\n\n  &:active,\n  &.active {\n    outline: 0;\n    background-image: none;\n    .box-shadow(inset 0 3px 5px rgba(0,0,0,.125));\n  }\n\n  &.disabled,\n  &[disabled],\n  fieldset[disabled] & {\n    cursor: @cursor-disabled;\n    .opacity(.65);\n    .box-shadow(none);\n  }\n\n  a& {\n    &.disabled,\n    fieldset[disabled] & {\n      pointer-events: none; // Future-proof disabling of clicks on `<a>` elements\n    }\n  }\n}\n\n\n// Alternate buttons\n// --------------------------------------------------\n\n.btn-default {\n  .button-variant(@btn-default-color; @btn-default-bg; @btn-default-border);\n}\n.btn-primary {\n  .button-variant(@btn-primary-color; @btn-primary-bg; @btn-primary-border);\n}\n// Success appears as green\n.btn-success {\n  .button-variant(@btn-success-color; @btn-success-bg; @btn-success-border);\n}\n// Info appears as blue-green\n.btn-info {\n  .button-variant(@btn-info-color; @btn-info-bg; @btn-info-border);\n}\n// Warning appears as orange\n.btn-warning {\n  .button-variant(@btn-warning-color; @btn-warning-bg; @btn-warning-border);\n}\n// Danger and error appear as red\n.btn-danger {\n  .button-variant(@btn-danger-color; @btn-danger-bg; @btn-danger-border);\n}\n\n\n// Link buttons\n// -------------------------\n\n// Make a button look and behave like a link\n.btn-link {\n  color: @link-color;\n  font-weight: normal;\n  border-radius: 0;\n\n  &,\n  &:active,\n  &.active,\n  &[disabled],\n  fieldset[disabled] & {\n    background-color: transparent;\n    .box-shadow(none);\n  }\n  &,\n  &:hover,\n  &:focus,\n  &:active {\n    border-color: transparent;\n  }\n  &:hover,\n  &:focus {\n    color: @link-hover-color;\n    text-decoration: @link-hover-decoration;\n    background-color: transparent;\n  }\n  &[disabled],\n  fieldset[disabled] & {\n    &:hover,\n    &:focus {\n      color: @btn-link-disabled-color;\n      text-decoration: none;\n    }\n  }\n}\n\n\n// Button Sizes\n// --------------------------------------------------\n\n.btn-lg {\n  // line-height: ensure even-numbered height of button next to large input\n  .button-size(@padding-large-vertical; @padding-large-horizontal; @font-size-large; @line-height-large; @btn-border-radius-large);\n}\n.btn-sm {\n  // line-height: ensure proper height of button next to small input\n  .button-size(@padding-small-vertical; @padding-small-horizontal; @font-size-small; @line-height-small; @btn-border-radius-small);\n}\n.btn-xs {\n  .button-size(@padding-xs-vertical; @padding-xs-horizontal; @font-size-small; @line-height-small; @btn-border-radius-small);\n}\n\n\n// Block button\n// --------------------------------------------------\n\n.btn-block {\n  display: block;\n  width: 100%;\n}\n\n// Vertically space out multiple block buttons\n.btn-block + .btn-block {\n  margin-top: 5px;\n}\n\n// Specificity overrides\ninput[type=\"submit\"],\ninput[type=\"reset\"],\ninput[type=\"button\"] {\n  &.btn-block {\n    width: 100%;\n  }\n}\n","// Button variants\n//\n// Easily pump out default styles, as well as :hover, :focus, :active,\n// and disabled options for all buttons\n\n.button-variant(@color; @background; @border) {\n  color: @color;\n  background-color: @background;\n  border-color: @border;\n\n  &:focus,\n  &.focus {\n    color: @color;\n    background-color: darken(@background, 10%);\n        border-color: darken(@border, 25%);\n  }\n  &:hover {\n    color: @color;\n    background-color: darken(@background, 10%);\n        border-color: darken(@border, 12%);\n  }\n  &:active,\n  &.active,\n  .open > .dropdown-toggle& {\n    color: @color;\n    background-color: darken(@background, 10%);\n        border-color: darken(@border, 12%);\n\n    &:hover,\n    &:focus,\n    &.focus {\n      color: @color;\n      background-color: darken(@background, 17%);\n          border-color: darken(@border, 25%);\n    }\n  }\n  &:active,\n  &.active,\n  .open > .dropdown-toggle& {\n    background-image: none;\n  }\n  &.disabled,\n  &[disabled],\n  fieldset[disabled] & {\n    &:hover,\n    &:focus,\n    &.focus {\n      background-color: @background;\n          border-color: @border;\n    }\n  }\n\n  .badge {\n    color: @background;\n    background-color: @color;\n  }\n}\n\n// Button sizes\n.button-size(@padding-vertical; @padding-horizontal; @font-size; @line-height; @border-radius) {\n  padding: @padding-vertical @padding-horizontal;\n  font-size: @font-size;\n  line-height: @line-height;\n  border-radius: @border-radius;\n}\n","// Opacity\n\n.opacity(@opacity) {\n  opacity: @opacity;\n  // IE8 filter\n  @opacity-ie: (@opacity * 100);\n  filter: ~\"alpha(opacity=@{opacity-ie})\";\n}\n","//\n// Component animations\n// --------------------------------------------------\n\n// Heads up!\n//\n// We don't use the `.opacity()` mixin here since it causes a bug with text\n// fields in IE7-8. Source: https://github.com/twbs/bootstrap/pull/3552.\n\n.fade {\n  opacity: 0;\n  .transition(opacity .15s linear);\n  &.in {\n    opacity: 1;\n  }\n}\n\n.collapse {\n  display: none;\n\n  &.in      { display: block; }\n  tr&.in    { display: table-row; }\n  tbody&.in { display: table-row-group; }\n}\n\n.collapsing {\n  position: relative;\n  height: 0;\n  overflow: hidden;\n  .transition-property(~\"height, visibility\");\n  .transition-duration(.35s);\n  .transition-timing-function(ease);\n}\n","//\n// Dropdown menus\n// --------------------------------------------------\n\n\n// Dropdown arrow/caret\n.caret {\n  display: inline-block;\n  width: 0;\n  height: 0;\n  margin-left: 2px;\n  vertical-align: middle;\n  border-top:   @caret-width-base dashed;\n  border-top:   @caret-width-base solid ~\"\\9\"; // IE8\n  border-right: @caret-width-base solid transparent;\n  border-left:  @caret-width-base solid transparent;\n}\n\n// The dropdown wrapper (div)\n.dropup,\n.dropdown {\n  position: relative;\n}\n\n// Prevent the focus on the dropdown toggle when closing dropdowns\n.dropdown-toggle:focus {\n  outline: 0;\n}\n\n// The dropdown menu (ul)\n.dropdown-menu {\n  position: absolute;\n  top: 100%;\n  left: 0;\n  z-index: @zindex-dropdown;\n  display: none; // none by default, but block on \"open\" of the menu\n  float: left;\n  min-width: 160px;\n  padding: 5px 0;\n  margin: 2px 0 0; // override default ul\n  list-style: none;\n  font-size: @font-size-base;\n  text-align: left; // Ensures proper alignment if parent has it changed (e.g., modal footer)\n  background-color: @dropdown-bg;\n  border: 1px solid @dropdown-fallback-border; // IE8 fallback\n  border: 1px solid @dropdown-border;\n  border-radius: @border-radius-base;\n  .box-shadow(0 6px 12px rgba(0,0,0,.175));\n  background-clip: padding-box;\n\n  // Aligns the dropdown menu to right\n  //\n  // Deprecated as of 3.1.0 in favor of `.dropdown-menu-[dir]`\n  &.pull-right {\n    right: 0;\n    left: auto;\n  }\n\n  // Dividers (basically an hr) within the dropdown\n  .divider {\n    .nav-divider(@dropdown-divider-bg);\n  }\n\n  // Links within the dropdown menu\n  > li > a {\n    display: block;\n    padding: 3px 20px;\n    clear: both;\n    font-weight: normal;\n    line-height: @line-height-base;\n    color: @dropdown-link-color;\n    white-space: nowrap; // prevent links from randomly breaking onto new lines\n  }\n}\n\n// Hover/Focus state\n.dropdown-menu > li > a {\n  &:hover,\n  &:focus {\n    text-decoration: none;\n    color: @dropdown-link-hover-color;\n    background-color: @dropdown-link-hover-bg;\n  }\n}\n\n// Active state\n.dropdown-menu > .active > a {\n  &,\n  &:hover,\n  &:focus {\n    color: @dropdown-link-active-color;\n    text-decoration: none;\n    outline: 0;\n    background-color: @dropdown-link-active-bg;\n  }\n}\n\n// Disabled state\n//\n// Gray out text and ensure the hover/focus state remains gray\n\n.dropdown-menu > .disabled > a {\n  &,\n  &:hover,\n  &:focus {\n    color: @dropdown-link-disabled-color;\n  }\n\n  // Nuke hover/focus effects\n  &:hover,\n  &:focus {\n    text-decoration: none;\n    background-color: transparent;\n    background-image: none; // Remove CSS gradient\n    .reset-filter();\n    cursor: @cursor-disabled;\n  }\n}\n\n// Open state for the dropdown\n.open {\n  // Show the menu\n  > .dropdown-menu {\n    display: block;\n  }\n\n  // Remove the outline when :focus is triggered\n  > a {\n    outline: 0;\n  }\n}\n\n// Menu positioning\n//\n// Add extra class to `.dropdown-menu` to flip the alignment of the dropdown\n// menu with the parent.\n.dropdown-menu-right {\n  left: auto; // Reset the default from `.dropdown-menu`\n  right: 0;\n}\n// With v3, we enabled auto-flipping if you have a dropdown within a right\n// aligned nav component. To enable the undoing of that, we provide an override\n// to restore the default dropdown menu alignment.\n//\n// This is only for left-aligning a dropdown menu within a `.navbar-right` or\n// `.pull-right` nav component.\n.dropdown-menu-left {\n  left: 0;\n  right: auto;\n}\n\n// Dropdown section headers\n.dropdown-header {\n  display: block;\n  padding: 3px 20px;\n  font-size: @font-size-small;\n  line-height: @line-height-base;\n  color: @dropdown-header-color;\n  white-space: nowrap; // as with > li > a\n}\n\n// Backdrop to catch body clicks on mobile, etc.\n.dropdown-backdrop {\n  position: fixed;\n  left: 0;\n  right: 0;\n  bottom: 0;\n  top: 0;\n  z-index: (@zindex-dropdown - 10);\n}\n\n// Right aligned dropdowns\n.pull-right > .dropdown-menu {\n  right: 0;\n  left: auto;\n}\n\n// Allow for dropdowns to go bottom up (aka, dropup-menu)\n//\n// Just add .dropup after the standard .dropdown class and you're set, bro.\n// TODO: abstract this so that the navbar fixed styles are not placed here?\n\n.dropup,\n.navbar-fixed-bottom .dropdown {\n  // Reverse the caret\n  .caret {\n    border-top: 0;\n    border-bottom: @caret-width-base dashed;\n    border-bottom: @caret-width-base solid ~\"\\9\"; // IE8\n    content: \"\";\n  }\n  // Different positioning for bottom up menu\n  .dropdown-menu {\n    top: auto;\n    bottom: 100%;\n    margin-bottom: 2px;\n  }\n}\n\n\n// Component alignment\n//\n// Reiterate per navbar.less and the modified component alignment there.\n\n@media (min-width: @grid-float-breakpoint) {\n  .navbar-right {\n    .dropdown-menu {\n      .dropdown-menu-right();\n    }\n    // Necessary for overrides of the default right aligned menu.\n    // Will remove come v4 in all likelihood.\n    .dropdown-menu-left {\n      .dropdown-menu-left();\n    }\n  }\n}\n","// Horizontal dividers\n//\n// Dividers (basically an hr) within dropdowns and nav lists\n\n.nav-divider(@color: #e5e5e5) {\n  height: 1px;\n  margin: ((@line-height-computed / 2) - 1) 0;\n  overflow: hidden;\n  background-color: @color;\n}\n","// Reset filters for IE\n//\n// When you need to remove a gradient background, do not forget to use this to reset\n// the IE filter for IE9 and below.\n\n.reset-filter() {\n  filter: e(%(\"progid:DXImageTransform.Microsoft.gradient(enabled = false)\"));\n}\n","//\n// Button groups\n// --------------------------------------------------\n\n// Make the div behave like a button\n.btn-group,\n.btn-group-vertical {\n  position: relative;\n  display: inline-block;\n  vertical-align: middle; // match .btn alignment given font-size hack above\n  > .btn {\n    position: relative;\n    float: left;\n    // Bring the \"active\" button to the front\n    &:hover,\n    &:focus,\n    &:active,\n    &.active {\n      z-index: 2;\n    }\n  }\n}\n\n// Prevent double borders when buttons are next to each other\n.btn-group {\n  .btn + .btn,\n  .btn + .btn-group,\n  .btn-group + .btn,\n  .btn-group + .btn-group {\n    margin-left: -1px;\n  }\n}\n\n// Optional: Group multiple button groups together for a toolbar\n.btn-toolbar {\n  margin-left: -5px; // Offset the first child's margin\n  &:extend(.clearfix all);\n\n  .btn,\n  .btn-group,\n  .input-group {\n    float: left;\n  }\n  > .btn,\n  > .btn-group,\n  > .input-group {\n    margin-left: 5px;\n  }\n}\n\n.btn-group > .btn:not(:first-child):not(:last-child):not(.dropdown-toggle) {\n  border-radius: 0;\n}\n\n// Set corners individual because sometimes a single button can be in a .btn-group and we need :first-child and :last-child to both match\n.btn-group > .btn:first-child {\n  margin-left: 0;\n  &:not(:last-child):not(.dropdown-toggle) {\n    .border-right-radius(0);\n  }\n}\n// Need .dropdown-toggle since :last-child doesn't apply, given that a .dropdown-menu is used immediately after it\n.btn-group > .btn:last-child:not(:first-child),\n.btn-group > .dropdown-toggle:not(:first-child) {\n  .border-left-radius(0);\n}\n\n// Custom edits for including btn-groups within btn-groups (useful for including dropdown buttons within a btn-group)\n.btn-group > .btn-group {\n  float: left;\n}\n.btn-group > .btn-group:not(:first-child):not(:last-child) > .btn {\n  border-radius: 0;\n}\n.btn-group > .btn-group:first-child:not(:last-child) {\n  > .btn:last-child,\n  > .dropdown-toggle {\n    .border-right-radius(0);\n  }\n}\n.btn-group > .btn-group:last-child:not(:first-child) > .btn:first-child {\n  .border-left-radius(0);\n}\n\n// On active and open, don't show outline\n.btn-group .dropdown-toggle:active,\n.btn-group.open .dropdown-toggle {\n  outline: 0;\n}\n\n\n// Sizing\n//\n// Remix the default button sizing classes into new ones for easier manipulation.\n\n.btn-group-xs > .btn { &:extend(.btn-xs); }\n.btn-group-sm > .btn { &:extend(.btn-sm); }\n.btn-group-lg > .btn { &:extend(.btn-lg); }\n\n\n// Split button dropdowns\n// ----------------------\n\n// Give the line between buttons some depth\n.btn-group > .btn + .dropdown-toggle {\n  padding-left: 8px;\n  padding-right: 8px;\n}\n.btn-group > .btn-lg + .dropdown-toggle {\n  padding-left: 12px;\n  padding-right: 12px;\n}\n\n// The clickable button for toggling the menu\n// Remove the gradient and set the same inset shadow as the :active state\n.btn-group.open .dropdown-toggle {\n  .box-shadow(inset 0 3px 5px rgba(0,0,0,.125));\n\n  // Show no shadow for `.btn-link` since it has no other button styles.\n  &.btn-link {\n    .box-shadow(none);\n  }\n}\n\n\n// Reposition the caret\n.btn .caret {\n  margin-left: 0;\n}\n// Carets in other button sizes\n.btn-lg .caret {\n  border-width: @caret-width-large @caret-width-large 0;\n  border-bottom-width: 0;\n}\n// Upside down carets for .dropup\n.dropup .btn-lg .caret {\n  border-width: 0 @caret-width-large @caret-width-large;\n}\n\n\n// Vertical button groups\n// ----------------------\n\n.btn-group-vertical {\n  > .btn,\n  > .btn-group,\n  > .btn-group > .btn {\n    display: block;\n    float: none;\n    width: 100%;\n    max-width: 100%;\n  }\n\n  // Clear floats so dropdown menus can be properly placed\n  > .btn-group {\n    &:extend(.clearfix all);\n    > .btn {\n      float: none;\n    }\n  }\n\n  > .btn + .btn,\n  > .btn + .btn-group,\n  > .btn-group + .btn,\n  > .btn-group + .btn-group {\n    margin-top: -1px;\n    margin-left: 0;\n  }\n}\n\n.btn-group-vertical > .btn {\n  &:not(:first-child):not(:last-child) {\n    border-radius: 0;\n  }\n  &:first-child:not(:last-child) {\n    .border-top-radius(@btn-border-radius-base);\n    .border-bottom-radius(0);\n  }\n  &:last-child:not(:first-child) {\n    .border-top-radius(0);\n    .border-bottom-radius(@btn-border-radius-base);\n  }\n}\n.btn-group-vertical > .btn-group:not(:first-child):not(:last-child) > .btn {\n  border-radius: 0;\n}\n.btn-group-vertical > .btn-group:first-child:not(:last-child) {\n  > .btn:last-child,\n  > .dropdown-toggle {\n    .border-bottom-radius(0);\n  }\n}\n.btn-group-vertical > .btn-group:last-child:not(:first-child) > .btn:first-child {\n  .border-top-radius(0);\n}\n\n\n// Justified button groups\n// ----------------------\n\n.btn-group-justified {\n  display: table;\n  width: 100%;\n  table-layout: fixed;\n  border-collapse: separate;\n  > .btn,\n  > .btn-group {\n    float: none;\n    display: table-cell;\n    width: 1%;\n  }\n  > .btn-group .btn {\n    width: 100%;\n  }\n\n  > .btn-group .dropdown-menu {\n    left: auto;\n  }\n}\n\n\n// Checkbox and radio options\n//\n// In order to support the browser's form validation feedback, powered by the\n// `required` attribute, we have to \"hide\" the inputs via `clip`. We cannot use\n// `display: none;` or `visibility: hidden;` as that also hides the popover.\n// Simply visually hiding the inputs via `opacity` would leave them clickable in\n// certain cases which is prevented by using `clip` and `pointer-events`.\n// This way, we ensure a DOM element is visible to position the popover from.\n//\n// See https://github.com/twbs/bootstrap/pull/12794 and\n// https://github.com/twbs/bootstrap/pull/14559 for more information.\n\n[data-toggle=\"buttons\"] {\n  > .btn,\n  > .btn-group > .btn {\n    input[type=\"radio\"],\n    input[type=\"checkbox\"] {\n      position: absolute;\n      clip: rect(0,0,0,0);\n      pointer-events: none;\n    }\n  }\n}\n","// Single side border-radius\n\n.border-top-radius(@radius) {\n  border-top-right-radius: @radius;\n   border-top-left-radius: @radius;\n}\n.border-right-radius(@radius) {\n  border-bottom-right-radius: @radius;\n     border-top-right-radius: @radius;\n}\n.border-bottom-radius(@radius) {\n  border-bottom-right-radius: @radius;\n   border-bottom-left-radius: @radius;\n}\n.border-left-radius(@radius) {\n  border-bottom-left-radius: @radius;\n     border-top-left-radius: @radius;\n}\n","//\n// Input groups\n// --------------------------------------------------\n\n// Base styles\n// -------------------------\n.input-group {\n  position: relative; // For dropdowns\n  display: table;\n  border-collapse: separate; // prevent input groups from inheriting border styles from table cells when placed within a table\n\n  // Undo padding and float of grid classes\n  &[class*=\"col-\"] {\n    float: none;\n    padding-left: 0;\n    padding-right: 0;\n  }\n\n  .form-control {\n    // Ensure that the input is always above the *appended* addon button for\n    // proper border colors.\n    position: relative;\n    z-index: 2;\n\n    // IE9 fubars the placeholder attribute in text inputs and the arrows on\n    // select elements in input groups. To fix it, we float the input. Details:\n    // https://github.com/twbs/bootstrap/issues/11561#issuecomment-28936855\n    float: left;\n\n    width: 100%;\n    margin-bottom: 0;\n\n    &:focus {\n      z-index: 3;\n    }\n  }\n}\n\n// Sizing options\n//\n// Remix the default form control sizing classes into new ones for easier\n// manipulation.\n\n.input-group-lg > .form-control,\n.input-group-lg > .input-group-addon,\n.input-group-lg > .input-group-btn > .btn {\n  .input-lg();\n}\n.input-group-sm > .form-control,\n.input-group-sm > .input-group-addon,\n.input-group-sm > .input-group-btn > .btn {\n  .input-sm();\n}\n\n\n// Display as table-cell\n// -------------------------\n.input-group-addon,\n.input-group-btn,\n.input-group .form-control {\n  display: table-cell;\n\n  &:not(:first-child):not(:last-child) {\n    border-radius: 0;\n  }\n}\n// Addon and addon wrapper for buttons\n.input-group-addon,\n.input-group-btn {\n  width: 1%;\n  white-space: nowrap;\n  vertical-align: middle; // Match the inputs\n}\n\n// Text input groups\n// -------------------------\n.input-group-addon {\n  padding: @padding-base-vertical @padding-base-horizontal;\n  font-size: @font-size-base;\n  font-weight: normal;\n  line-height: 1;\n  color: @input-color;\n  text-align: center;\n  background-color: @input-group-addon-bg;\n  border: 1px solid @input-group-addon-border-color;\n  border-radius: @input-border-radius;\n\n  // Sizing\n  &.input-sm {\n    padding: @padding-small-vertical @padding-small-horizontal;\n    font-size: @font-size-small;\n    border-radius: @input-border-radius-small;\n  }\n  &.input-lg {\n    padding: @padding-large-vertical @padding-large-horizontal;\n    font-size: @font-size-large;\n    border-radius: @input-border-radius-large;\n  }\n\n  // Nuke default margins from checkboxes and radios to vertically center within.\n  input[type=\"radio\"],\n  input[type=\"checkbox\"] {\n    margin-top: 0;\n  }\n}\n\n// Reset rounded corners\n.input-group .form-control:first-child,\n.input-group-addon:first-child,\n.input-group-btn:first-child > .btn,\n.input-group-btn:first-child > .btn-group > .btn,\n.input-group-btn:first-child > .dropdown-toggle,\n.input-group-btn:last-child > .btn:not(:last-child):not(.dropdown-toggle),\n.input-group-btn:last-child > .btn-group:not(:last-child) > .btn {\n  .border-right-radius(0);\n}\n.input-group-addon:first-child {\n  border-right: 0;\n}\n.input-group .form-control:last-child,\n.input-group-addon:last-child,\n.input-group-btn:last-child > .btn,\n.input-group-btn:last-child > .btn-group > .btn,\n.input-group-btn:last-child > .dropdown-toggle,\n.input-group-btn:first-child > .btn:not(:first-child),\n.input-group-btn:first-child > .btn-group:not(:first-child) > .btn {\n  .border-left-radius(0);\n}\n.input-group-addon:last-child {\n  border-left: 0;\n}\n\n// Button input groups\n// -------------------------\n.input-group-btn {\n  position: relative;\n  // Jankily prevent input button groups from wrapping with `white-space` and\n  // `font-size` in combination with `inline-block` on buttons.\n  font-size: 0;\n  white-space: nowrap;\n\n  // Negative margin for spacing, position for bringing hovered/focused/actived\n  // element above the siblings.\n  > .btn {\n    position: relative;\n    + .btn {\n      margin-left: -1px;\n    }\n    // Bring the \"active\" button to the front\n    &:hover,\n    &:focus,\n    &:active {\n      z-index: 2;\n    }\n  }\n\n  // Negative margin to only have a 1px border between the two\n  &:first-child {\n    > .btn,\n    > .btn-group {\n      margin-right: -1px;\n    }\n  }\n  &:last-child {\n    > .btn,\n    > .btn-group {\n      z-index: 2;\n      margin-left: -1px;\n    }\n  }\n}\n","//\n// Navs\n// --------------------------------------------------\n\n\n// Base class\n// --------------------------------------------------\n\n.nav {\n  margin-bottom: 0;\n  padding-left: 0; // Override default ul/ol\n  list-style: none;\n  &:extend(.clearfix all);\n\n  > li {\n    position: relative;\n    display: block;\n\n    > a {\n      position: relative;\n      display: block;\n      padding: @nav-link-padding;\n      &:hover,\n      &:focus {\n        text-decoration: none;\n        background-color: @nav-link-hover-bg;\n      }\n    }\n\n    // Disabled state sets text to gray and nukes hover/tab effects\n    &.disabled > a {\n      color: @nav-disabled-link-color;\n\n      &:hover,\n      &:focus {\n        color: @nav-disabled-link-hover-color;\n        text-decoration: none;\n        background-color: transparent;\n        cursor: @cursor-disabled;\n      }\n    }\n  }\n\n  // Open dropdowns\n  .open > a {\n    &,\n    &:hover,\n    &:focus {\n      background-color: @nav-link-hover-bg;\n      border-color: @link-color;\n    }\n  }\n\n  // Nav dividers (deprecated with v3.0.1)\n  //\n  // This should have been removed in v3 with the dropping of `.nav-list`, but\n  // we missed it. We don't currently support this anywhere, but in the interest\n  // of maintaining backward compatibility in case you use it, it's deprecated.\n  .nav-divider {\n    .nav-divider();\n  }\n\n  // Prevent IE8 from misplacing imgs\n  //\n  // See https://github.com/h5bp/html5-boilerplate/issues/984#issuecomment-3985989\n  > li > a > img {\n    max-width: none;\n  }\n}\n\n\n// Tabs\n// -------------------------\n\n// Give the tabs something to sit on\n.nav-tabs {\n  border-bottom: 1px solid @nav-tabs-border-color;\n  > li {\n    float: left;\n    // Make the list-items overlay the bottom border\n    margin-bottom: -1px;\n\n    // Actual tabs (as links)\n    > a {\n      margin-right: 2px;\n      line-height: @line-height-base;\n      border: 1px solid transparent;\n      border-radius: @border-radius-base @border-radius-base 0 0;\n      &:hover {\n        border-color: @nav-tabs-link-hover-border-color @nav-tabs-link-hover-border-color @nav-tabs-border-color;\n      }\n    }\n\n    // Active state, and its :hover to override normal :hover\n    &.active > a {\n      &,\n      &:hover,\n      &:focus {\n        color: @nav-tabs-active-link-hover-color;\n        background-color: @nav-tabs-active-link-hover-bg;\n        border: 1px solid @nav-tabs-active-link-hover-border-color;\n        border-bottom-color: transparent;\n        cursor: default;\n      }\n    }\n  }\n  // pulling this in mainly for less shorthand\n  &.nav-justified {\n    .nav-justified();\n    .nav-tabs-justified();\n  }\n}\n\n\n// Pills\n// -------------------------\n.nav-pills {\n  > li {\n    float: left;\n\n    // Links rendered as pills\n    > a {\n      border-radius: @nav-pills-border-radius;\n    }\n    + li {\n      margin-left: 2px;\n    }\n\n    // Active state\n    &.active > a {\n      &,\n      &:hover,\n      &:focus {\n        color: @nav-pills-active-link-hover-color;\n        background-color: @nav-pills-active-link-hover-bg;\n      }\n    }\n  }\n}\n\n\n// Stacked pills\n.nav-stacked {\n  > li {\n    float: none;\n    + li {\n      margin-top: 2px;\n      margin-left: 0; // no need for this gap between nav items\n    }\n  }\n}\n\n\n// Nav variations\n// --------------------------------------------------\n\n// Justified nav links\n// -------------------------\n\n.nav-justified {\n  width: 100%;\n\n  > li {\n    float: none;\n    > a {\n      text-align: center;\n      margin-bottom: 5px;\n    }\n  }\n\n  > .dropdown .dropdown-menu {\n    top: auto;\n    left: auto;\n  }\n\n  @media (min-width: @screen-sm-min) {\n    > li {\n      display: table-cell;\n      width: 1%;\n      > a {\n        margin-bottom: 0;\n      }\n    }\n  }\n}\n\n// Move borders to anchors instead of bottom of list\n//\n// Mixin for adding on top the shared `.nav-justified` styles for our tabs\n.nav-tabs-justified {\n  border-bottom: 0;\n\n  > li > a {\n    // Override margin from .nav-tabs\n    margin-right: 0;\n    border-radius: @border-radius-base;\n  }\n\n  > .active > a,\n  > .active > a:hover,\n  > .active > a:focus {\n    border: 1px solid @nav-tabs-justified-link-border-color;\n  }\n\n  @media (min-width: @screen-sm-min) {\n    > li > a {\n      border-bottom: 1px solid @nav-tabs-justified-link-border-color;\n      border-radius: @border-radius-base @border-radius-base 0 0;\n    }\n    > .active > a,\n    > .active > a:hover,\n    > .active > a:focus {\n      border-bottom-color: @nav-tabs-justified-active-link-border-color;\n    }\n  }\n}\n\n\n// Tabbable tabs\n// -------------------------\n\n// Hide tabbable panes to start, show them when `.active`\n.tab-content {\n  > .tab-pane {\n    display: none;\n  }\n  > .active {\n    display: block;\n  }\n}\n\n\n// Dropdowns\n// -------------------------\n\n// Specific dropdowns\n.nav-tabs .dropdown-menu {\n  // make dropdown border overlap tab border\n  margin-top: -1px;\n  // Remove the top rounded corners here since there is a hard edge above the menu\n  .border-top-radius(0);\n}\n","//\n// Navbars\n// --------------------------------------------------\n\n\n// Wrapper and base class\n//\n// Provide a static navbar from which we expand to create full-width, fixed, and\n// other navbar variations.\n\n.navbar {\n  position: relative;\n  min-height: @navbar-height; // Ensure a navbar always shows (e.g., without a .navbar-brand in collapsed mode)\n  margin-bottom: @navbar-margin-bottom;\n  border: 1px solid transparent;\n\n  // Prevent floats from breaking the navbar\n  &:extend(.clearfix all);\n\n  @media (min-width: @grid-float-breakpoint) {\n    border-radius: @navbar-border-radius;\n  }\n}\n\n\n// Navbar heading\n//\n// Groups `.navbar-brand` and `.navbar-toggle` into a single component for easy\n// styling of responsive aspects.\n\n.navbar-header {\n  &:extend(.clearfix all);\n\n  @media (min-width: @grid-float-breakpoint) {\n    float: left;\n  }\n}\n\n\n// Navbar collapse (body)\n//\n// Group your navbar content into this for easy collapsing and expanding across\n// various device sizes. By default, this content is collapsed when <768px, but\n// will expand past that for a horizontal display.\n//\n// To start (on mobile devices) the navbar links, forms, and buttons are stacked\n// vertically and include a `max-height` to overflow in case you have too much\n// content for the user's viewport.\n\n.navbar-collapse {\n  overflow-x: visible;\n  padding-right: @navbar-padding-horizontal;\n  padding-left:  @navbar-padding-horizontal;\n  border-top: 1px solid transparent;\n  box-shadow: inset 0 1px 0 rgba(255,255,255,.1);\n  &:extend(.clearfix all);\n  -webkit-overflow-scrolling: touch;\n\n  &.in {\n    overflow-y: auto;\n  }\n\n  @media (min-width: @grid-float-breakpoint) {\n    width: auto;\n    border-top: 0;\n    box-shadow: none;\n\n    &.collapse {\n      display: block !important;\n      height: auto !important;\n      padding-bottom: 0; // Override default setting\n      overflow: visible !important;\n    }\n\n    &.in {\n      overflow-y: visible;\n    }\n\n    // Undo the collapse side padding for navbars with containers to ensure\n    // alignment of right-aligned contents.\n    .navbar-fixed-top &,\n    .navbar-static-top &,\n    .navbar-fixed-bottom & {\n      padding-left: 0;\n      padding-right: 0;\n    }\n  }\n}\n\n.navbar-fixed-top,\n.navbar-fixed-bottom {\n  .navbar-collapse {\n    max-height: @navbar-collapse-max-height;\n\n    @media (max-device-width: @screen-xs-min) and (orientation: landscape) {\n      max-height: 200px;\n    }\n  }\n}\n\n\n// Both navbar header and collapse\n//\n// When a container is present, change the behavior of the header and collapse.\n\n.container,\n.container-fluid {\n  > .navbar-header,\n  > .navbar-collapse {\n    margin-right: -@navbar-padding-horizontal;\n    margin-left:  -@navbar-padding-horizontal;\n\n    @media (min-width: @grid-float-breakpoint) {\n      margin-right: 0;\n      margin-left:  0;\n    }\n  }\n}\n\n\n//\n// Navbar alignment options\n//\n// Display the navbar across the entirety of the page or fixed it to the top or\n// bottom of the page.\n\n// Static top (unfixed, but 100% wide) navbar\n.navbar-static-top {\n  z-index: @zindex-navbar;\n  border-width: 0 0 1px;\n\n  @media (min-width: @grid-float-breakpoint) {\n    border-radius: 0;\n  }\n}\n\n// Fix the top/bottom navbars when screen real estate supports it\n.navbar-fixed-top,\n.navbar-fixed-bottom {\n  position: fixed;\n  right: 0;\n  left: 0;\n  z-index: @zindex-navbar-fixed;\n\n  // Undo the rounded corners\n  @media (min-width: @grid-float-breakpoint) {\n    border-radius: 0;\n  }\n}\n.navbar-fixed-top {\n  top: 0;\n  border-width: 0 0 1px;\n}\n.navbar-fixed-bottom {\n  bottom: 0;\n  margin-bottom: 0; // override .navbar defaults\n  border-width: 1px 0 0;\n}\n\n\n// Brand/project name\n\n.navbar-brand {\n  float: left;\n  padding: @navbar-padding-vertical @navbar-padding-horizontal;\n  font-size: @font-size-large;\n  line-height: @line-height-computed;\n  height: @navbar-height;\n\n  &:hover,\n  &:focus {\n    text-decoration: none;\n  }\n\n  > img {\n    display: block;\n  }\n\n  @media (min-width: @grid-float-breakpoint) {\n    .navbar > .container &,\n    .navbar > .container-fluid & {\n      margin-left: -@navbar-padding-horizontal;\n    }\n  }\n}\n\n\n// Navbar toggle\n//\n// Custom button for toggling the `.navbar-collapse`, powered by the collapse\n// JavaScript plugin.\n\n.navbar-toggle {\n  position: relative;\n  float: right;\n  margin-right: @navbar-padding-horizontal;\n  padding: 9px 10px;\n  .navbar-vertical-align(34px);\n  background-color: transparent;\n  background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214\n  border: 1px solid transparent;\n  border-radius: @border-radius-base;\n\n  // We remove the `outline` here, but later compensate by attaching `:hover`\n  // styles to `:focus`.\n  &:focus {\n    outline: 0;\n  }\n\n  // Bars\n  .icon-bar {\n    display: block;\n    width: 22px;\n    height: 2px;\n    border-radius: 1px;\n  }\n  .icon-bar + .icon-bar {\n    margin-top: 4px;\n  }\n\n  @media (min-width: @grid-float-breakpoint) {\n    display: none;\n  }\n}\n\n\n// Navbar nav links\n//\n// Builds on top of the `.nav` components with its own modifier class to make\n// the nav the full height of the horizontal nav (above 768px).\n\n.navbar-nav {\n  margin: (@navbar-padding-vertical / 2) -@navbar-padding-horizontal;\n\n  > li > a {\n    padding-top:    10px;\n    padding-bottom: 10px;\n    line-height: @line-height-computed;\n  }\n\n  @media (max-width: @grid-float-breakpoint-max) {\n    // Dropdowns get custom display when collapsed\n    .open .dropdown-menu {\n      position: static;\n      float: none;\n      width: auto;\n      margin-top: 0;\n      background-color: transparent;\n      border: 0;\n      box-shadow: none;\n      > li > a,\n      .dropdown-header {\n        padding: 5px 15px 5px 25px;\n      }\n      > li > a {\n        line-height: @line-height-computed;\n        &:hover,\n        &:focus {\n          background-image: none;\n        }\n      }\n    }\n  }\n\n  // Uncollapse the nav\n  @media (min-width: @grid-float-breakpoint) {\n    float: left;\n    margin: 0;\n\n    > li {\n      float: left;\n      > a {\n        padding-top:    @navbar-padding-vertical;\n        padding-bottom: @navbar-padding-vertical;\n      }\n    }\n  }\n}\n\n\n// Navbar form\n//\n// Extension of the `.form-inline` with some extra flavor for optimum display in\n// our navbars.\n\n.navbar-form {\n  margin-left: -@navbar-padding-horizontal;\n  margin-right: -@navbar-padding-horizontal;\n  padding: 10px @navbar-padding-horizontal;\n  border-top: 1px solid transparent;\n  border-bottom: 1px solid transparent;\n  @shadow: inset 0 1px 0 rgba(255,255,255,.1), 0 1px 0 rgba(255,255,255,.1);\n  .box-shadow(@shadow);\n\n  // Mixin behavior for optimum display\n  .form-inline();\n\n  .form-group {\n    @media (max-width: @grid-float-breakpoint-max) {\n      margin-bottom: 5px;\n\n      &:last-child {\n        margin-bottom: 0;\n      }\n    }\n  }\n\n  // Vertically center in expanded, horizontal navbar\n  .navbar-vertical-align(@input-height-base);\n\n  // Undo 100% width for pull classes\n  @media (min-width: @grid-float-breakpoint) {\n    width: auto;\n    border: 0;\n    margin-left: 0;\n    margin-right: 0;\n    padding-top: 0;\n    padding-bottom: 0;\n    .box-shadow(none);\n  }\n}\n\n\n// Dropdown menus\n\n// Menu position and menu carets\n.navbar-nav > li > .dropdown-menu {\n  margin-top: 0;\n  .border-top-radius(0);\n}\n// Menu position and menu caret support for dropups via extra dropup class\n.navbar-fixed-bottom .navbar-nav > li > .dropdown-menu {\n  margin-bottom: 0;\n  .border-top-radius(@navbar-border-radius);\n  .border-bottom-radius(0);\n}\n\n\n// Buttons in navbars\n//\n// Vertically center a button within a navbar (when *not* in a form).\n\n.navbar-btn {\n  .navbar-vertical-align(@input-height-base);\n\n  &.btn-sm {\n    .navbar-vertical-align(@input-height-small);\n  }\n  &.btn-xs {\n    .navbar-vertical-align(22);\n  }\n}\n\n\n// Text in navbars\n//\n// Add a class to make any element properly align itself vertically within the navbars.\n\n.navbar-text {\n  .navbar-vertical-align(@line-height-computed);\n\n  @media (min-width: @grid-float-breakpoint) {\n    float: left;\n    margin-left: @navbar-padding-horizontal;\n    margin-right: @navbar-padding-horizontal;\n  }\n}\n\n\n// Component alignment\n//\n// Repurpose the pull utilities as their own navbar utilities to avoid specificity\n// issues with parents and chaining. Only do this when the navbar is uncollapsed\n// though so that navbar contents properly stack and align in mobile.\n//\n// Declared after the navbar components to ensure more specificity on the margins.\n\n@media (min-width: @grid-float-breakpoint) {\n  .navbar-left  { .pull-left(); }\n  .navbar-right {\n    .pull-right();\n    margin-right: -@navbar-padding-horizontal;\n\n    ~ .navbar-right {\n      margin-right: 0;\n    }\n  }\n}\n\n\n// Alternate navbars\n// --------------------------------------------------\n\n// Default navbar\n.navbar-default {\n  background-color: @navbar-default-bg;\n  border-color: @navbar-default-border;\n\n  .navbar-brand {\n    color: @navbar-default-brand-color;\n    &:hover,\n    &:focus {\n      color: @navbar-default-brand-hover-color;\n      background-color: @navbar-default-brand-hover-bg;\n    }\n  }\n\n  .navbar-text {\n    color: @navbar-default-color;\n  }\n\n  .navbar-nav {\n    > li > a {\n      color: @navbar-default-link-color;\n\n      &:hover,\n      &:focus {\n        color: @navbar-default-link-hover-color;\n        background-color: @navbar-default-link-hover-bg;\n      }\n    }\n    > .active > a {\n      &,\n      &:hover,\n      &:focus {\n        color: @navbar-default-link-active-color;\n        background-color: @navbar-default-link-active-bg;\n      }\n    }\n    > .disabled > a {\n      &,\n      &:hover,\n      &:focus {\n        color: @navbar-default-link-disabled-color;\n        background-color: @navbar-default-link-disabled-bg;\n      }\n    }\n  }\n\n  .navbar-toggle {\n    border-color: @navbar-default-toggle-border-color;\n    &:hover,\n    &:focus {\n      background-color: @navbar-default-toggle-hover-bg;\n    }\n    .icon-bar {\n      background-color: @navbar-default-toggle-icon-bar-bg;\n    }\n  }\n\n  .navbar-collapse,\n  .navbar-form {\n    border-color: @navbar-default-border;\n  }\n\n  // Dropdown menu items\n  .navbar-nav {\n    // Remove background color from open dropdown\n    > .open > a {\n      &,\n      &:hover,\n      &:focus {\n        background-color: @navbar-default-link-active-bg;\n        color: @navbar-default-link-active-color;\n      }\n    }\n\n    @media (max-width: @grid-float-breakpoint-max) {\n      // Dropdowns get custom display when collapsed\n      .open .dropdown-menu {\n        > li > a {\n          color: @navbar-default-link-color;\n          &:hover,\n          &:focus {\n            color: @navbar-default-link-hover-color;\n            background-color: @navbar-default-link-hover-bg;\n          }\n        }\n        > .active > a {\n          &,\n          &:hover,\n          &:focus {\n            color: @navbar-default-link-active-color;\n            background-color: @navbar-default-link-active-bg;\n          }\n        }\n        > .disabled > a {\n          &,\n          &:hover,\n          &:focus {\n            color: @navbar-default-link-disabled-color;\n            background-color: @navbar-default-link-disabled-bg;\n          }\n        }\n      }\n    }\n  }\n\n\n  // Links in navbars\n  //\n  // Add a class to ensure links outside the navbar nav are colored correctly.\n\n  .navbar-link {\n    color: @navbar-default-link-color;\n    &:hover {\n      color: @navbar-default-link-hover-color;\n    }\n  }\n\n  .btn-link {\n    color: @navbar-default-link-color;\n    &:hover,\n    &:focus {\n      color: @navbar-default-link-hover-color;\n    }\n    &[disabled],\n    fieldset[disabled] & {\n      &:hover,\n      &:focus {\n        color: @navbar-default-link-disabled-color;\n      }\n    }\n  }\n}\n\n// Inverse navbar\n\n.navbar-inverse {\n  background-color: @navbar-inverse-bg;\n  border-color: @navbar-inverse-border;\n\n  .navbar-brand {\n    color: @navbar-inverse-brand-color;\n    &:hover,\n    &:focus {\n      color: @navbar-inverse-brand-hover-color;\n      background-color: @navbar-inverse-brand-hover-bg;\n    }\n  }\n\n  .navbar-text {\n    color: @navbar-inverse-color;\n  }\n\n  .navbar-nav {\n    > li > a {\n      color: @navbar-inverse-link-color;\n\n      &:hover,\n      &:focus {\n        color: @navbar-inverse-link-hover-color;\n        background-color: @navbar-inverse-link-hover-bg;\n      }\n    }\n    > .active > a {\n      &,\n      &:hover,\n      &:focus {\n        color: @navbar-inverse-link-active-color;\n        background-color: @navbar-inverse-link-active-bg;\n      }\n    }\n    > .disabled > a {\n      &,\n      &:hover,\n      &:focus {\n        color: @navbar-inverse-link-disabled-color;\n        background-color: @navbar-inverse-link-disabled-bg;\n      }\n    }\n  }\n\n  // Darken the responsive nav toggle\n  .navbar-toggle {\n    border-color: @navbar-inverse-toggle-border-color;\n    &:hover,\n    &:focus {\n      background-color: @navbar-inverse-toggle-hover-bg;\n    }\n    .icon-bar {\n      background-color: @navbar-inverse-toggle-icon-bar-bg;\n    }\n  }\n\n  .navbar-collapse,\n  .navbar-form {\n    border-color: darken(@navbar-inverse-bg, 7%);\n  }\n\n  // Dropdowns\n  .navbar-nav {\n    > .open > a {\n      &,\n      &:hover,\n      &:focus {\n        background-color: @navbar-inverse-link-active-bg;\n        color: @navbar-inverse-link-active-color;\n      }\n    }\n\n    @media (max-width: @grid-float-breakpoint-max) {\n      // Dropdowns get custom display\n      .open .dropdown-menu {\n        > .dropdown-header {\n          border-color: @navbar-inverse-border;\n        }\n        .divider {\n          background-color: @navbar-inverse-border;\n        }\n        > li > a {\n          color: @navbar-inverse-link-color;\n          &:hover,\n          &:focus {\n            color: @navbar-inverse-link-hover-color;\n            background-color: @navbar-inverse-link-hover-bg;\n          }\n        }\n        > .active > a {\n          &,\n          &:hover,\n          &:focus {\n            color: @navbar-inverse-link-active-color;\n            background-color: @navbar-inverse-link-active-bg;\n          }\n        }\n        > .disabled > a {\n          &,\n          &:hover,\n          &:focus {\n            color: @navbar-inverse-link-disabled-color;\n            background-color: @navbar-inverse-link-disabled-bg;\n          }\n        }\n      }\n    }\n  }\n\n  .navbar-link {\n    color: @navbar-inverse-link-color;\n    &:hover {\n      color: @navbar-inverse-link-hover-color;\n    }\n  }\n\n  .btn-link {\n    color: @navbar-inverse-link-color;\n    &:hover,\n    &:focus {\n      color: @navbar-inverse-link-hover-color;\n    }\n    &[disabled],\n    fieldset[disabled] & {\n      &:hover,\n      &:focus {\n        color: @navbar-inverse-link-disabled-color;\n      }\n    }\n  }\n}\n","// Navbar vertical align\n//\n// Vertically center elements in the navbar.\n// Example: an element has a height of 30px, so write out `.navbar-vertical-align(30px);` to calculate the appropriate top margin.\n\n.navbar-vertical-align(@element-height) {\n  margin-top: ((@navbar-height - @element-height) / 2);\n  margin-bottom: ((@navbar-height - @element-height) / 2);\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}\n\n\n// For Affix plugin\n// -------------------------\n\n.affix {\n  position: fixed;\n}\n","//\n// Breadcrumbs\n// --------------------------------------------------\n\n\n.breadcrumb {\n  padding: @breadcrumb-padding-vertical @breadcrumb-padding-horizontal;\n  margin-bottom: @line-height-computed;\n  list-style: none;\n  background-color: @breadcrumb-bg;\n  border-radius: @border-radius-base;\n\n  > li {\n    display: inline-block;\n\n    + li:before {\n      content: \"@{breadcrumb-separator}\\00a0\"; // Unicode space added since inline-block means non-collapsing white-space\n      padding: 0 5px;\n      color: @breadcrumb-color;\n    }\n  }\n\n  > .active {\n    color: @breadcrumb-active-color;\n  }\n}\n","//\n// Pagination (multiple pages)\n// --------------------------------------------------\n.pagination {\n  display: inline-block;\n  padding-left: 0;\n  margin: @line-height-computed 0;\n  border-radius: @border-radius-base;\n\n  > li {\n    display: inline; // Remove list-style and block-level defaults\n    > a,\n    > span {\n      position: relative;\n      float: left; // Collapse white-space\n      padding: @padding-base-vertical @padding-base-horizontal;\n      line-height: @line-height-base;\n      text-decoration: none;\n      color: @pagination-color;\n      background-color: @pagination-bg;\n      border: 1px solid @pagination-border;\n      margin-left: -1px;\n    }\n    &:first-child {\n      > a,\n      > span {\n        margin-left: 0;\n        .border-left-radius(@border-radius-base);\n      }\n    }\n    &:last-child {\n      > a,\n      > span {\n        .border-right-radius(@border-radius-base);\n      }\n    }\n  }\n\n  > li > a,\n  > li > span {\n    &:hover,\n    &:focus {\n      z-index: 2;\n      color: @pagination-hover-color;\n      background-color: @pagination-hover-bg;\n      border-color: @pagination-hover-border;\n    }\n  }\n\n  > .active > a,\n  > .active > span {\n    &,\n    &:hover,\n    &:focus {\n      z-index: 3;\n      color: @pagination-active-color;\n      background-color: @pagination-active-bg;\n      border-color: @pagination-active-border;\n      cursor: default;\n    }\n  }\n\n  > .disabled {\n    > span,\n    > span:hover,\n    > span:focus,\n    > a,\n    > a:hover,\n    > a:focus {\n      color: @pagination-disabled-color;\n      background-color: @pagination-disabled-bg;\n      border-color: @pagination-disabled-border;\n      cursor: @cursor-disabled;\n    }\n  }\n}\n\n// Sizing\n// --------------------------------------------------\n\n// Large\n.pagination-lg {\n  .pagination-size(@padding-large-vertical; @padding-large-horizontal; @font-size-large; @line-height-large; @border-radius-large);\n}\n\n// Small\n.pagination-sm {\n  .pagination-size(@padding-small-vertical; @padding-small-horizontal; @font-size-small; @line-height-small; @border-radius-small);\n}\n","// Pagination\n\n.pagination-size(@padding-vertical; @padding-horizontal; @font-size; @line-height; @border-radius) {\n  > li {\n    > a,\n    > span {\n      padding: @padding-vertical @padding-horizontal;\n      font-size: @font-size;\n      line-height: @line-height;\n    }\n    &:first-child {\n      > a,\n      > span {\n        .border-left-radius(@border-radius);\n      }\n    }\n    &:last-child {\n      > a,\n      > span {\n        .border-right-radius(@border-radius);\n      }\n    }\n  }\n}\n","//\n// Pager pagination\n// --------------------------------------------------\n\n\n.pager {\n  padding-left: 0;\n  margin: @line-height-computed 0;\n  list-style: none;\n  text-align: center;\n  &:extend(.clearfix all);\n  li {\n    display: inline;\n    > a,\n    > span {\n      display: inline-block;\n      padding: 5px 14px;\n      background-color: @pager-bg;\n      border: 1px solid @pager-border;\n      border-radius: @pager-border-radius;\n    }\n\n    > a:hover,\n    > a:focus {\n      text-decoration: none;\n      background-color: @pager-hover-bg;\n    }\n  }\n\n  .next {\n    > a,\n    > span {\n      float: right;\n    }\n  }\n\n  .previous {\n    > a,\n    > span {\n      float: left;\n    }\n  }\n\n  .disabled {\n    > a,\n    > a:hover,\n    > a:focus,\n    > span {\n      color: @pager-disabled-color;\n      background-color: @pager-bg;\n      cursor: @cursor-disabled;\n    }\n  }\n}\n","//\n// Labels\n// --------------------------------------------------\n\n.label {\n  display: inline;\n  padding: .2em .6em .3em;\n  font-size: 75%;\n  font-weight: bold;\n  line-height: 1;\n  color: @label-color;\n  text-align: center;\n  white-space: nowrap;\n  vertical-align: baseline;\n  border-radius: .25em;\n\n  // Add hover effects, but only for links\n  a& {\n    &:hover,\n    &:focus {\n      color: @label-link-hover-color;\n      text-decoration: none;\n      cursor: pointer;\n    }\n  }\n\n  // Empty labels collapse automatically (not available in IE8)\n  &:empty {\n    display: none;\n  }\n\n  // Quick fix for labels in buttons\n  .btn & {\n    position: relative;\n    top: -1px;\n  }\n}\n\n// Colors\n// Contextual variations (linked labels get darker on :hover)\n\n.label-default {\n  .label-variant(@label-default-bg);\n}\n\n.label-primary {\n  .label-variant(@label-primary-bg);\n}\n\n.label-success {\n  .label-variant(@label-success-bg);\n}\n\n.label-info {\n  .label-variant(@label-info-bg);\n}\n\n.label-warning {\n  .label-variant(@label-warning-bg);\n}\n\n.label-danger {\n  .label-variant(@label-danger-bg);\n}\n","// Labels\n\n.label-variant(@color) {\n  background-color: @color;\n\n  &[href] {\n    &:hover,\n    &:focus {\n      background-color: darken(@color, 10%);\n    }\n  }\n}\n","//\n// Badges\n// --------------------------------------------------\n\n\n// Base class\n.badge {\n  display: inline-block;\n  min-width: 10px;\n  padding: 3px 7px;\n  font-size: @font-size-small;\n  font-weight: @badge-font-weight;\n  color: @badge-color;\n  line-height: @badge-line-height;\n  vertical-align: middle;\n  white-space: nowrap;\n  text-align: center;\n  background-color: @badge-bg;\n  border-radius: @badge-border-radius;\n\n  // Empty badges collapse automatically (not available in IE8)\n  &:empty {\n    display: none;\n  }\n\n  // Quick fix for badges in buttons\n  .btn & {\n    position: relative;\n    top: -1px;\n  }\n\n  .btn-xs &,\n  .btn-group-xs > .btn & {\n    top: 0;\n    padding: 1px 5px;\n  }\n\n  // Hover state, but only for links\n  a& {\n    &:hover,\n    &:focus {\n      color: @badge-link-hover-color;\n      text-decoration: none;\n      cursor: pointer;\n    }\n  }\n\n  // Account for badges in navs\n  .list-group-item.active > &,\n  .nav-pills > .active > a > & {\n    color: @badge-active-color;\n    background-color: @badge-active-bg;\n  }\n\n  .list-group-item > & {\n    float: right;\n  }\n\n  .list-group-item > & + & {\n    margin-right: 5px;\n  }\n\n  .nav-pills > li > a > & {\n    margin-left: 3px;\n  }\n}\n","//\n// Jumbotron\n// --------------------------------------------------\n\n\n.jumbotron {\n  padding-top:    @jumbotron-padding;\n  padding-bottom: @jumbotron-padding;\n  margin-bottom: @jumbotron-padding;\n  color: @jumbotron-color;\n  background-color: @jumbotron-bg;\n\n  h1,\n  .h1 {\n    color: @jumbotron-heading-color;\n  }\n\n  p {\n    margin-bottom: (@jumbotron-padding / 2);\n    font-size: @jumbotron-font-size;\n    font-weight: 200;\n  }\n\n  > hr {\n    border-top-color: darken(@jumbotron-bg, 10%);\n  }\n\n  .container &,\n  .container-fluid & {\n    border-radius: @border-radius-large; // Only round corners at higher resolutions if contained in a container\n    padding-left:  (@grid-gutter-width / 2);\n    padding-right: (@grid-gutter-width / 2);\n  }\n\n  .container {\n    max-width: 100%;\n  }\n\n  @media screen and (min-width: @screen-sm-min) {\n    padding-top:    (@jumbotron-padding * 1.6);\n    padding-bottom: (@jumbotron-padding * 1.6);\n\n    .container &,\n    .container-fluid & {\n      padding-left:  (@jumbotron-padding * 2);\n      padding-right: (@jumbotron-padding * 2);\n    }\n\n    h1,\n    .h1 {\n      font-size: @jumbotron-heading-font-size;\n    }\n  }\n}\n","//\n// Thumbnails\n// --------------------------------------------------\n\n\n// Mixin and adjust the regular image class\n.thumbnail {\n  display: block;\n  padding: @thumbnail-padding;\n  margin-bottom: @line-height-computed;\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(border .2s ease-in-out);\n\n  > img,\n  a > img {\n    &:extend(.img-responsive);\n    margin-left: auto;\n    margin-right: auto;\n  }\n\n  // Add a hover state for linked versions only\n  a&:hover,\n  a&:focus,\n  a&.active {\n    border-color: @link-color;\n  }\n\n  // Image captions\n  .caption {\n    padding: @thumbnail-caption-padding;\n    color: @thumbnail-caption-color;\n  }\n}\n","//\n// Alerts\n// --------------------------------------------------\n\n\n// Base styles\n// -------------------------\n\n.alert {\n  padding: @alert-padding;\n  margin-bottom: @line-height-computed;\n  border: 1px solid transparent;\n  border-radius: @alert-border-radius;\n\n  // Headings for larger alerts\n  h4 {\n    margin-top: 0;\n    // Specified for the h4 to prevent conflicts of changing @headings-color\n    color: inherit;\n  }\n\n  // Provide class for links that match alerts\n  .alert-link {\n    font-weight: @alert-link-font-weight;\n  }\n\n  // Improve alignment and spacing of inner content\n  > p,\n  > ul {\n    margin-bottom: 0;\n  }\n\n  > p + p {\n    margin-top: 5px;\n  }\n}\n\n// Dismissible alerts\n//\n// Expand the right padding and account for the close button's positioning.\n\n.alert-dismissable, // The misspelled .alert-dismissable was deprecated in 3.2.0.\n.alert-dismissible {\n  padding-right: (@alert-padding + 20);\n\n  // Adjust close link position\n  .close {\n    position: relative;\n    top: -2px;\n    right: -21px;\n    color: inherit;\n  }\n}\n\n// Alternate styles\n//\n// Generate contextual modifier classes for colorizing the alert.\n\n.alert-success {\n  .alert-variant(@alert-success-bg; @alert-success-border; @alert-success-text);\n}\n\n.alert-info {\n  .alert-variant(@alert-info-bg; @alert-info-border; @alert-info-text);\n}\n\n.alert-warning {\n  .alert-variant(@alert-warning-bg; @alert-warning-border; @alert-warning-text);\n}\n\n.alert-danger {\n  .alert-variant(@alert-danger-bg; @alert-danger-border; @alert-danger-text);\n}\n","// Alerts\n\n.alert-variant(@background; @border; @text-color) {\n  background-color: @background;\n  border-color: @border;\n  color: @text-color;\n\n  hr {\n    border-top-color: darken(@border, 5%);\n  }\n  .alert-link {\n    color: darken(@text-color, 10%);\n  }\n}\n","//\n// Progress bars\n// --------------------------------------------------\n\n\n// Bar animations\n// -------------------------\n\n// WebKit\n@-webkit-keyframes progress-bar-stripes {\n  from  { background-position: 40px 0; }\n  to    { background-position: 0 0; }\n}\n\n// Spec and IE10+\n@keyframes progress-bar-stripes {\n  from  { background-position: 40px 0; }\n  to    { background-position: 0 0; }\n}\n\n\n// Bar itself\n// -------------------------\n\n// Outer container\n.progress {\n  overflow: hidden;\n  height: @line-height-computed;\n  margin-bottom: @line-height-computed;\n  background-color: @progress-bg;\n  border-radius: @progress-border-radius;\n  .box-shadow(inset 0 1px 2px rgba(0,0,0,.1));\n}\n\n// Bar of progress\n.progress-bar {\n  float: left;\n  width: 0%;\n  height: 100%;\n  font-size: @font-size-small;\n  line-height: @line-height-computed;\n  color: @progress-bar-color;\n  text-align: center;\n  background-color: @progress-bar-bg;\n  .box-shadow(inset 0 -1px 0 rgba(0,0,0,.15));\n  .transition(width .6s ease);\n}\n\n// Striped bars\n//\n// `.progress-striped .progress-bar` is deprecated as of v3.2.0 in favor of the\n// `.progress-bar-striped` class, which you just add to an existing\n// `.progress-bar`.\n.progress-striped .progress-bar,\n.progress-bar-striped {\n  #gradient > .striped();\n  background-size: 40px 40px;\n}\n\n// Call animation for the active one\n//\n// `.progress.active .progress-bar` is deprecated as of v3.2.0 in favor of the\n// `.progress-bar.active` approach.\n.progress.active .progress-bar,\n.progress-bar.active {\n  .animation(progress-bar-stripes 2s linear infinite);\n}\n\n\n// Variations\n// -------------------------\n\n.progress-bar-success {\n  .progress-bar-variant(@progress-bar-success-bg);\n}\n\n.progress-bar-info {\n  .progress-bar-variant(@progress-bar-info-bg);\n}\n\n.progress-bar-warning {\n  .progress-bar-variant(@progress-bar-warning-bg);\n}\n\n.progress-bar-danger {\n  .progress-bar-variant(@progress-bar-danger-bg);\n}\n","// Gradients\n\n#gradient {\n\n  // Horizontal gradient, from left to right\n  //\n  // Creates two color stops, start and end, by specifying a color and position for each color stop.\n  // Color stops are not available in IE9 and below.\n  .horizontal(@start-color: #555; @end-color: #333; @start-percent: 0%; @end-percent: 100%) {\n    background-image: -webkit-linear-gradient(left, @start-color @start-percent, @end-color @end-percent); // Safari 5.1-6, Chrome 10+\n    background-image: -o-linear-gradient(left, @start-color @start-percent, @end-color @end-percent); // Opera 12\n    background-image: linear-gradient(to right, @start-color @start-percent, @end-color @end-percent); // Standard, IE10, Firefox 16+, Opera 12.10+, Safari 7+, Chrome 26+\n    background-repeat: repeat-x;\n    filter: e(%(\"progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=1)\",argb(@start-color),argb(@end-color))); // IE9 and down\n  }\n\n  // Vertical gradient, from top to bottom\n  //\n  // Creates two color stops, start and end, by specifying a color and position for each color stop.\n  // Color stops are not available in IE9 and below.\n  .vertical(@start-color: #555; @end-color: #333; @start-percent: 0%; @end-percent: 100%) {\n    background-image: -webkit-linear-gradient(top, @start-color @start-percent, @end-color @end-percent);  // Safari 5.1-6, Chrome 10+\n    background-image: -o-linear-gradient(top, @start-color @start-percent, @end-color @end-percent);  // Opera 12\n    background-image: linear-gradient(to bottom, @start-color @start-percent, @end-color @end-percent); // Standard, IE10, Firefox 16+, Opera 12.10+, Safari 7+, Chrome 26+\n    background-repeat: repeat-x;\n    filter: e(%(\"progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=0)\",argb(@start-color),argb(@end-color))); // IE9 and down\n  }\n\n  .directional(@start-color: #555; @end-color: #333; @deg: 45deg) {\n    background-repeat: repeat-x;\n    background-image: -webkit-linear-gradient(@deg, @start-color, @end-color); // Safari 5.1-6, Chrome 10+\n    background-image: -o-linear-gradient(@deg, @start-color, @end-color); // Opera 12\n    background-image: linear-gradient(@deg, @start-color, @end-color); // Standard, IE10, Firefox 16+, Opera 12.10+, Safari 7+, Chrome 26+\n  }\n  .horizontal-three-colors(@start-color: #00b3ee; @mid-color: #7a43b6; @color-stop: 50%; @end-color: #c3325f) {\n    background-image: -webkit-linear-gradient(left, @start-color, @mid-color @color-stop, @end-color);\n    background-image: -o-linear-gradient(left, @start-color, @mid-color @color-stop, @end-color);\n    background-image: linear-gradient(to right, @start-color, @mid-color @color-stop, @end-color);\n    background-repeat: no-repeat;\n    filter: e(%(\"progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=1)\",argb(@start-color),argb(@end-color))); // IE9 and down, gets no color-stop at all for proper fallback\n  }\n  .vertical-three-colors(@start-color: #00b3ee; @mid-color: #7a43b6; @color-stop: 50%; @end-color: #c3325f) {\n    background-image: -webkit-linear-gradient(@start-color, @mid-color @color-stop, @end-color);\n    background-image: -o-linear-gradient(@start-color, @mid-color @color-stop, @end-color);\n    background-image: linear-gradient(@start-color, @mid-color @color-stop, @end-color);\n    background-repeat: no-repeat;\n    filter: e(%(\"progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=0)\",argb(@start-color),argb(@end-color))); // IE9 and down, gets no color-stop at all for proper fallback\n  }\n  .radial(@inner-color: #555; @outer-color: #333) {\n    background-image: -webkit-radial-gradient(circle, @inner-color, @outer-color);\n    background-image: radial-gradient(circle, @inner-color, @outer-color);\n    background-repeat: no-repeat;\n  }\n  .striped(@color: rgba(255,255,255,.15); @angle: 45deg) {\n    background-image: -webkit-linear-gradient(@angle, @color 25%, transparent 25%, transparent 50%, @color 50%, @color 75%, transparent 75%, transparent);\n    background-image: -o-linear-gradient(@angle, @color 25%, transparent 25%, transparent 50%, @color 50%, @color 75%, transparent 75%, transparent);\n    background-image: linear-gradient(@angle, @color 25%, transparent 25%, transparent 50%, @color 50%, @color 75%, transparent 75%, transparent);\n  }\n}\n","// Progress bars\n\n.progress-bar-variant(@color) {\n  background-color: @color;\n\n  // Deprecated parent class requirement as of v3.2.0\n  .progress-striped & {\n    #gradient > .striped();\n  }\n}\n",".media {\n  // Proper spacing between instances of .media\n  margin-top: 15px;\n\n  &:first-child {\n    margin-top: 0;\n  }\n}\n\n.media,\n.media-body {\n  zoom: 1;\n  overflow: hidden;\n}\n\n.media-body {\n  width: 10000px;\n}\n\n.media-object {\n  display: block;\n\n  // Fix collapse in webkit from max-width: 100% and display: table-cell.\n  &.img-thumbnail {\n    max-width: none;\n  }\n}\n\n.media-right,\n.media > .pull-right {\n  padding-left: 10px;\n}\n\n.media-left,\n.media > .pull-left {\n  padding-right: 10px;\n}\n\n.media-left,\n.media-right,\n.media-body {\n  display: table-cell;\n  vertical-align: top;\n}\n\n.media-middle {\n  vertical-align: middle;\n}\n\n.media-bottom {\n  vertical-align: bottom;\n}\n\n// Reset margins on headings for tighter default spacing\n.media-heading {\n  margin-top: 0;\n  margin-bottom: 5px;\n}\n\n// Media list variation\n//\n// Undo default ul/ol styles\n.media-list {\n  padding-left: 0;\n  list-style: none;\n}\n","//\n// List groups\n// --------------------------------------------------\n\n\n// Base class\n//\n// Easily usable on <ul>, <ol>, or <div>.\n\n.list-group {\n  // No need to set list-style: none; since .list-group-item is block level\n  margin-bottom: 20px;\n  padding-left: 0; // reset padding because ul and ol\n}\n\n\n// Individual list items\n//\n// Use on `li`s or `div`s within the `.list-group` parent.\n\n.list-group-item {\n  position: relative;\n  display: block;\n  padding: 10px 15px;\n  // Place the border on the list items and negative margin up for better styling\n  margin-bottom: -1px;\n  background-color: @list-group-bg;\n  border: 1px solid @list-group-border;\n\n  // Round the first and last items\n  &:first-child {\n    .border-top-radius(@list-group-border-radius);\n  }\n  &:last-child {\n    margin-bottom: 0;\n    .border-bottom-radius(@list-group-border-radius);\n  }\n}\n\n\n// Interactive list items\n//\n// Use anchor or button elements instead of `li`s or `div`s to create interactive items.\n// Includes an extra `.active` modifier class for showing selected items.\n\na.list-group-item,\nbutton.list-group-item {\n  color: @list-group-link-color;\n\n  .list-group-item-heading {\n    color: @list-group-link-heading-color;\n  }\n\n  // Hover state\n  &:hover,\n  &:focus {\n    text-decoration: none;\n    color: @list-group-link-hover-color;\n    background-color: @list-group-hover-bg;\n  }\n}\n\nbutton.list-group-item {\n  width: 100%;\n  text-align: left;\n}\n\n.list-group-item {\n  // Disabled state\n  &.disabled,\n  &.disabled:hover,\n  &.disabled:focus {\n    background-color: @list-group-disabled-bg;\n    color: @list-group-disabled-color;\n    cursor: @cursor-disabled;\n\n    // Force color to inherit for custom content\n    .list-group-item-heading {\n      color: inherit;\n    }\n    .list-group-item-text {\n      color: @list-group-disabled-text-color;\n    }\n  }\n\n  // Active class on item itself, not parent\n  &.active,\n  &.active:hover,\n  &.active:focus {\n    z-index: 2; // Place active items above their siblings for proper border styling\n    color: @list-group-active-color;\n    background-color: @list-group-active-bg;\n    border-color: @list-group-active-border;\n\n    // Force color to inherit for custom content\n    .list-group-item-heading,\n    .list-group-item-heading > small,\n    .list-group-item-heading > .small {\n      color: inherit;\n    }\n    .list-group-item-text {\n      color: @list-group-active-text-color;\n    }\n  }\n}\n\n\n// Contextual variants\n//\n// Add modifier classes to change text and background color on individual items.\n// Organizationally, this must come after the `:hover` states.\n\n.list-group-item-variant(success; @state-success-bg; @state-success-text);\n.list-group-item-variant(info; @state-info-bg; @state-info-text);\n.list-group-item-variant(warning; @state-warning-bg; @state-warning-text);\n.list-group-item-variant(danger; @state-danger-bg; @state-danger-text);\n\n\n// Custom content options\n//\n// Extra classes for creating well-formatted content within `.list-group-item`s.\n\n.list-group-item-heading {\n  margin-top: 0;\n  margin-bottom: 5px;\n}\n.list-group-item-text {\n  margin-bottom: 0;\n  line-height: 1.3;\n}\n","// List Groups\n\n.list-group-item-variant(@state; @background; @color) {\n  .list-group-item-@{state} {\n    color: @color;\n    background-color: @background;\n\n    a&,\n    button& {\n      color: @color;\n\n      .list-group-item-heading {\n        color: inherit;\n      }\n\n      &:hover,\n      &:focus {\n        color: @color;\n        background-color: darken(@background, 5%);\n      }\n      &.active,\n      &.active:hover,\n      &.active:focus {\n        color: #fff;\n        background-color: @color;\n        border-color: @color;\n      }\n    }\n  }\n}\n","//\n// Panels\n// --------------------------------------------------\n\n\n// Base class\n.panel {\n  margin-bottom: @line-height-computed;\n  background-color: @panel-bg;\n  border: 1px solid transparent;\n  border-radius: @panel-border-radius;\n  .box-shadow(0 1px 1px rgba(0,0,0,.05));\n}\n\n// Panel contents\n.panel-body {\n  padding: @panel-body-padding;\n  &:extend(.clearfix all);\n}\n\n// Optional heading\n.panel-heading {\n  padding: @panel-heading-padding;\n  border-bottom: 1px solid transparent;\n  .border-top-radius((@panel-border-radius - 1));\n\n  > .dropdown .dropdown-toggle {\n    color: inherit;\n  }\n}\n\n// Within heading, strip any `h*` tag of its default margins for spacing.\n.panel-title {\n  margin-top: 0;\n  margin-bottom: 0;\n  font-size: ceil((@font-size-base * 1.125));\n  color: inherit;\n\n  > a,\n  > small,\n  > .small,\n  > small > a,\n  > .small > a {\n    color: inherit;\n  }\n}\n\n// Optional footer (stays gray in every modifier class)\n.panel-footer {\n  padding: @panel-footer-padding;\n  background-color: @panel-footer-bg;\n  border-top: 1px solid @panel-inner-border;\n  .border-bottom-radius((@panel-border-radius - 1));\n}\n\n\n// List groups in panels\n//\n// By default, space out list group content from panel headings to account for\n// any kind of custom content between the two.\n\n.panel {\n  > .list-group,\n  > .panel-collapse > .list-group {\n    margin-bottom: 0;\n\n    .list-group-item {\n      border-width: 1px 0;\n      border-radius: 0;\n    }\n\n    // Add border top radius for first one\n    &:first-child {\n      .list-group-item:first-child {\n        border-top: 0;\n        .border-top-radius((@panel-border-radius - 1));\n      }\n    }\n\n    // Add border bottom radius for last one\n    &:last-child {\n      .list-group-item:last-child {\n        border-bottom: 0;\n        .border-bottom-radius((@panel-border-radius - 1));\n      }\n    }\n  }\n  > .panel-heading + .panel-collapse > .list-group {\n    .list-group-item:first-child {\n      .border-top-radius(0);\n    }\n  }\n}\n// Collapse space between when there's no additional content.\n.panel-heading + .list-group {\n  .list-group-item:first-child {\n    border-top-width: 0;\n  }\n}\n.list-group + .panel-footer {\n  border-top-width: 0;\n}\n\n// Tables in panels\n//\n// Place a non-bordered `.table` within a panel (not within a `.panel-body`) and\n// watch it go full width.\n\n.panel {\n  > .table,\n  > .table-responsive > .table,\n  > .panel-collapse > .table {\n    margin-bottom: 0;\n\n    caption {\n      padding-left: @panel-body-padding;\n      padding-right: @panel-body-padding;\n    }\n  }\n  // Add border top radius for first one\n  > .table:first-child,\n  > .table-responsive:first-child > .table:first-child {\n    .border-top-radius((@panel-border-radius - 1));\n\n    > thead:first-child,\n    > tbody:first-child {\n      > tr:first-child {\n        border-top-left-radius: (@panel-border-radius - 1);\n        border-top-right-radius: (@panel-border-radius - 1);\n\n        td:first-child,\n        th:first-child {\n          border-top-left-radius: (@panel-border-radius - 1);\n        }\n        td:last-child,\n        th:last-child {\n          border-top-right-radius: (@panel-border-radius - 1);\n        }\n      }\n    }\n  }\n  // Add border bottom radius for last one\n  > .table:last-child,\n  > .table-responsive:last-child > .table:last-child {\n    .border-bottom-radius((@panel-border-radius - 1));\n\n    > tbody:last-child,\n    > tfoot:last-child {\n      > tr:last-child {\n        border-bottom-left-radius: (@panel-border-radius - 1);\n        border-bottom-right-radius: (@panel-border-radius - 1);\n\n        td:first-child,\n        th:first-child {\n          border-bottom-left-radius: (@panel-border-radius - 1);\n        }\n        td:last-child,\n        th:last-child {\n          border-bottom-right-radius: (@panel-border-radius - 1);\n        }\n      }\n    }\n  }\n  > .panel-body + .table,\n  > .panel-body + .table-responsive,\n  > .table + .panel-body,\n  > .table-responsive + .panel-body {\n    border-top: 1px solid @table-border-color;\n  }\n  > .table > tbody:first-child > tr:first-child th,\n  > .table > tbody:first-child > tr:first-child td {\n    border-top: 0;\n  }\n  > .table-bordered,\n  > .table-responsive > .table-bordered {\n    border: 0;\n    > thead,\n    > tbody,\n    > tfoot {\n      > tr {\n        > th:first-child,\n        > td:first-child {\n          border-left: 0;\n        }\n        > th:last-child,\n        > td:last-child {\n          border-right: 0;\n        }\n      }\n    }\n    > thead,\n    > tbody {\n      > tr:first-child {\n        > td,\n        > th {\n          border-bottom: 0;\n        }\n      }\n    }\n    > tbody,\n    > tfoot {\n      > tr:last-child {\n        > td,\n        > th {\n          border-bottom: 0;\n        }\n      }\n    }\n  }\n  > .table-responsive {\n    border: 0;\n    margin-bottom: 0;\n  }\n}\n\n\n// Collapsible panels (aka, accordion)\n//\n// Wrap a series of panels in `.panel-group` to turn them into an accordion with\n// the help of our collapse JavaScript plugin.\n\n.panel-group {\n  margin-bottom: @line-height-computed;\n\n  // Tighten up margin so it's only between panels\n  .panel {\n    margin-bottom: 0;\n    border-radius: @panel-border-radius;\n\n    + .panel {\n      margin-top: 5px;\n    }\n  }\n\n  .panel-heading {\n    border-bottom: 0;\n\n    + .panel-collapse > .panel-body,\n    + .panel-collapse > .list-group {\n      border-top: 1px solid @panel-inner-border;\n    }\n  }\n\n  .panel-footer {\n    border-top: 0;\n    + .panel-collapse .panel-body {\n      border-bottom: 1px solid @panel-inner-border;\n    }\n  }\n}\n\n\n// Contextual variations\n.panel-default {\n  .panel-variant(@panel-default-border; @panel-default-text; @panel-default-heading-bg; @panel-default-border);\n}\n.panel-primary {\n  .panel-variant(@panel-primary-border; @panel-primary-text; @panel-primary-heading-bg; @panel-primary-border);\n}\n.panel-success {\n  .panel-variant(@panel-success-border; @panel-success-text; @panel-success-heading-bg; @panel-success-border);\n}\n.panel-info {\n  .panel-variant(@panel-info-border; @panel-info-text; @panel-info-heading-bg; @panel-info-border);\n}\n.panel-warning {\n  .panel-variant(@panel-warning-border; @panel-warning-text; @panel-warning-heading-bg; @panel-warning-border);\n}\n.panel-danger {\n  .panel-variant(@panel-danger-border; @panel-danger-text; @panel-danger-heading-bg; @panel-danger-border);\n}\n","// Panels\n\n.panel-variant(@border; @heading-text-color; @heading-bg-color; @heading-border) {\n  border-color: @border;\n\n  & > .panel-heading {\n    color: @heading-text-color;\n    background-color: @heading-bg-color;\n    border-color: @heading-border;\n\n    + .panel-collapse > .panel-body {\n      border-top-color: @border;\n    }\n    .badge {\n      color: @heading-bg-color;\n      background-color: @heading-text-color;\n    }\n  }\n  & > .panel-footer {\n    + .panel-collapse > .panel-body {\n      border-bottom-color: @border;\n    }\n  }\n}\n","// Embeds responsive\n//\n// Credit: Nicolas Gallagher and SUIT CSS.\n\n.embed-responsive {\n  position: relative;\n  display: block;\n  height: 0;\n  padding: 0;\n  overflow: hidden;\n\n  .embed-responsive-item,\n  iframe,\n  embed,\n  object,\n  video {\n    position: absolute;\n    top: 0;\n    left: 0;\n    bottom: 0;\n    height: 100%;\n    width: 100%;\n    border: 0;\n  }\n}\n\n// Modifier class for 16:9 aspect ratio\n.embed-responsive-16by9 {\n  padding-bottom: 56.25%;\n}\n\n// Modifier class for 4:3 aspect ratio\n.embed-responsive-4by3 {\n  padding-bottom: 75%;\n}\n","//\n// Wells\n// --------------------------------------------------\n\n\n// Base class\n.well {\n  min-height: 20px;\n  padding: 19px;\n  margin-bottom: 20px;\n  background-color: @well-bg;\n  border: 1px solid @well-border;\n  border-radius: @border-radius-base;\n  .box-shadow(inset 0 1px 1px rgba(0,0,0,.05));\n  blockquote {\n    border-color: #ddd;\n    border-color: rgba(0,0,0,.15);\n  }\n}\n\n// Sizes\n.well-lg {\n  padding: 24px;\n  border-radius: @border-radius-large;\n}\n.well-sm {\n  padding: 9px;\n  border-radius: @border-radius-small;\n}\n","//\n// Close icons\n// --------------------------------------------------\n\n\n.close {\n  float: right;\n  font-size: (@font-size-base * 1.5);\n  font-weight: @close-font-weight;\n  line-height: 1;\n  color: @close-color;\n  text-shadow: @close-text-shadow;\n  .opacity(.2);\n\n  &:hover,\n  &:focus {\n    color: @close-color;\n    text-decoration: none;\n    cursor: pointer;\n    .opacity(.5);\n  }\n\n  // Additional properties for button version\n  // iOS requires the button element instead of an anchor tag.\n  // If you want the anchor version, it requires `href=\"#\"`.\n  // See https://developer.mozilla.org/en-US/docs/Web/Events/click#Safari_Mobile\n  button& {\n    padding: 0;\n    cursor: pointer;\n    background: transparent;\n    border: 0;\n    -webkit-appearance: none;\n  }\n}\n","//\n// Modals\n// --------------------------------------------------\n\n// .modal-open      - body class for killing the scroll\n// .modal           - container to scroll within\n// .modal-dialog    - positioning shell for the actual modal\n// .modal-content   - actual modal w/ bg and corners and shit\n\n// Kill the scroll on the body\n.modal-open {\n  overflow: hidden;\n}\n\n// Container that the modal scrolls within\n.modal {\n  display: none;\n  overflow: hidden;\n  position: fixed;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: @zindex-modal;\n  -webkit-overflow-scrolling: touch;\n\n  // Prevent Chrome on Windows from adding a focus outline. For details, see\n  // https://github.com/twbs/bootstrap/pull/10951.\n  outline: 0;\n\n  // When fading in the modal, animate it to slide down\n  &.fade .modal-dialog {\n    .translate(0, -25%);\n    .transition-transform(~\"0.3s ease-out\");\n  }\n  &.in .modal-dialog { .translate(0, 0) }\n}\n.modal-open .modal {\n  overflow-x: hidden;\n  overflow-y: auto;\n}\n\n// Shell div to position the modal with bottom padding\n.modal-dialog {\n  position: relative;\n  width: auto;\n  margin: 10px;\n}\n\n// Actual modal\n.modal-content {\n  position: relative;\n  background-color: @modal-content-bg;\n  border: 1px solid @modal-content-fallback-border-color; //old browsers fallback (ie8 etc)\n  border: 1px solid @modal-content-border-color;\n  border-radius: @border-radius-large;\n  .box-shadow(0 3px 9px rgba(0,0,0,.5));\n  background-clip: padding-box;\n  // Remove focus outline from opened modal\n  outline: 0;\n}\n\n// Modal background\n.modal-backdrop {\n  position: fixed;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: @zindex-modal-background;\n  background-color: @modal-backdrop-bg;\n  // Fade for backdrop\n  &.fade { .opacity(0); }\n  &.in { .opacity(@modal-backdrop-opacity); }\n}\n\n// Modal header\n// Top section of the modal w/ title and dismiss\n.modal-header {\n  padding: @modal-title-padding;\n  border-bottom: 1px solid @modal-header-border-color;\n  &:extend(.clearfix all);\n}\n// Close icon\n.modal-header .close {\n  margin-top: -2px;\n}\n\n// Title text within header\n.modal-title {\n  margin: 0;\n  line-height: @modal-title-line-height;\n}\n\n// Modal body\n// Where all modal content resides (sibling of .modal-header and .modal-footer)\n.modal-body {\n  position: relative;\n  padding: @modal-inner-padding;\n}\n\n// Footer (for actions)\n.modal-footer {\n  padding: @modal-inner-padding;\n  text-align: right; // right align buttons\n  border-top: 1px solid @modal-footer-border-color;\n  &:extend(.clearfix all); // clear it in case folks use .pull-* classes on buttons\n\n  // Properly space out buttons\n  .btn + .btn {\n    margin-left: 5px;\n    margin-bottom: 0; // account for input[type=\"submit\"] which gets the bottom margin like all other inputs\n  }\n  // but override that for button groups\n  .btn-group .btn + .btn {\n    margin-left: -1px;\n  }\n  // and override it for block buttons as well\n  .btn-block + .btn-block {\n    margin-left: 0;\n  }\n}\n\n// Measure scrollbar width for padding body during modal show/hide\n.modal-scrollbar-measure {\n  position: absolute;\n  top: -9999px;\n  width: 50px;\n  height: 50px;\n  overflow: scroll;\n}\n\n// Scale up the modal\n@media (min-width: @screen-sm-min) {\n  // Automatically set modal's width for larger viewports\n  .modal-dialog {\n    width: @modal-md;\n    margin: 30px auto;\n  }\n  .modal-content {\n    .box-shadow(0 5px 15px rgba(0,0,0,.5));\n  }\n\n  // Modal sizes\n  .modal-sm { width: @modal-sm; }\n}\n\n@media (min-width: @screen-md-min) {\n  .modal-lg { width: @modal-lg; }\n}\n","//\n// Tooltips\n// --------------------------------------------------\n\n\n// Base class\n.tooltip {\n  position: absolute;\n  z-index: @zindex-tooltip;\n  display: block;\n  // Our parent element can be arbitrary since tooltips are by default inserted as a sibling of their target element.\n  // So reset our font and text properties to avoid inheriting weird values.\n  .reset-text();\n  font-size: @font-size-small;\n\n  .opacity(0);\n\n  &.in     { .opacity(@tooltip-opacity); }\n  &.top    { margin-top:  -3px; padding: @tooltip-arrow-width 0; }\n  &.right  { margin-left:  3px; padding: 0 @tooltip-arrow-width; }\n  &.bottom { margin-top:   3px; padding: @tooltip-arrow-width 0; }\n  &.left   { margin-left: -3px; padding: 0 @tooltip-arrow-width; }\n}\n\n// Wrapper for the tooltip content\n.tooltip-inner {\n  max-width: @tooltip-max-width;\n  padding: 3px 8px;\n  color: @tooltip-color;\n  text-align: center;\n  background-color: @tooltip-bg;\n  border-radius: @border-radius-base;\n}\n\n// Arrows\n.tooltip-arrow {\n  position: absolute;\n  width: 0;\n  height: 0;\n  border-color: transparent;\n  border-style: solid;\n}\n// Note: Deprecated .top-left, .top-right, .bottom-left, and .bottom-right as of v3.3.1\n.tooltip {\n  &.top .tooltip-arrow {\n    bottom: 0;\n    left: 50%;\n    margin-left: -@tooltip-arrow-width;\n    border-width: @tooltip-arrow-width @tooltip-arrow-width 0;\n    border-top-color: @tooltip-arrow-color;\n  }\n  &.top-left .tooltip-arrow {\n    bottom: 0;\n    right: @tooltip-arrow-width;\n    margin-bottom: -@tooltip-arrow-width;\n    border-width: @tooltip-arrow-width @tooltip-arrow-width 0;\n    border-top-color: @tooltip-arrow-color;\n  }\n  &.top-right .tooltip-arrow {\n    bottom: 0;\n    left: @tooltip-arrow-width;\n    margin-bottom: -@tooltip-arrow-width;\n    border-width: @tooltip-arrow-width @tooltip-arrow-width 0;\n    border-top-color: @tooltip-arrow-color;\n  }\n  &.right .tooltip-arrow {\n    top: 50%;\n    left: 0;\n    margin-top: -@tooltip-arrow-width;\n    border-width: @tooltip-arrow-width @tooltip-arrow-width @tooltip-arrow-width 0;\n    border-right-color: @tooltip-arrow-color;\n  }\n  &.left .tooltip-arrow {\n    top: 50%;\n    right: 0;\n    margin-top: -@tooltip-arrow-width;\n    border-width: @tooltip-arrow-width 0 @tooltip-arrow-width @tooltip-arrow-width;\n    border-left-color: @tooltip-arrow-color;\n  }\n  &.bottom .tooltip-arrow {\n    top: 0;\n    left: 50%;\n    margin-left: -@tooltip-arrow-width;\n    border-width: 0 @tooltip-arrow-width @tooltip-arrow-width;\n    border-bottom-color: @tooltip-arrow-color;\n  }\n  &.bottom-left .tooltip-arrow {\n    top: 0;\n    right: @tooltip-arrow-width;\n    margin-top: -@tooltip-arrow-width;\n    border-width: 0 @tooltip-arrow-width @tooltip-arrow-width;\n    border-bottom-color: @tooltip-arrow-color;\n  }\n  &.bottom-right .tooltip-arrow {\n    top: 0;\n    left: @tooltip-arrow-width;\n    margin-top: -@tooltip-arrow-width;\n    border-width: 0 @tooltip-arrow-width @tooltip-arrow-width;\n    border-bottom-color: @tooltip-arrow-color;\n  }\n}\n",".reset-text() {\n  font-family: @font-family-base;\n  // We deliberately do NOT reset font-size.\n  font-style: normal;\n  font-weight: normal;\n  letter-spacing: normal;\n  line-break: auto;\n  line-height: @line-height-base;\n  text-align: left; // Fallback for where `start` is not supported\n  text-align: start;\n  text-decoration: none;\n  text-shadow: none;\n  text-transform: none;\n  white-space: normal;\n  word-break: normal;\n  word-spacing: normal;\n  word-wrap: normal;\n}\n","//\n// Popovers\n// --------------------------------------------------\n\n\n.popover {\n  position: absolute;\n  top: 0;\n  left: 0;\n  z-index: @zindex-popover;\n  display: none;\n  max-width: @popover-max-width;\n  padding: 1px;\n  // Our parent element can be arbitrary since popovers are by default inserted as a sibling of their target element.\n  // So reset our font and text properties to avoid inheriting weird values.\n  .reset-text();\n  font-size: @font-size-base;\n\n  background-color: @popover-bg;\n  background-clip: padding-box;\n  border: 1px solid @popover-fallback-border-color;\n  border: 1px solid @popover-border-color;\n  border-radius: @border-radius-large;\n  .box-shadow(0 5px 10px rgba(0,0,0,.2));\n\n  // Offset the popover to account for the popover arrow\n  &.top     { margin-top: -@popover-arrow-width; }\n  &.right   { margin-left: @popover-arrow-width; }\n  &.bottom  { margin-top: @popover-arrow-width; }\n  &.left    { margin-left: -@popover-arrow-width; }\n}\n\n.popover-title {\n  margin: 0; // reset heading margin\n  padding: 8px 14px;\n  font-size: @font-size-base;\n  background-color: @popover-title-bg;\n  border-bottom: 1px solid darken(@popover-title-bg, 5%);\n  border-radius: (@border-radius-large - 1) (@border-radius-large - 1) 0 0;\n}\n\n.popover-content {\n  padding: 9px 14px;\n}\n\n// Arrows\n//\n// .arrow is outer, .arrow:after is inner\n\n.popover > .arrow {\n  &,\n  &:after {\n    position: absolute;\n    display: block;\n    width: 0;\n    height: 0;\n    border-color: transparent;\n    border-style: solid;\n  }\n}\n.popover > .arrow {\n  border-width: @popover-arrow-outer-width;\n}\n.popover > .arrow:after {\n  border-width: @popover-arrow-width;\n  content: \"\";\n}\n\n.popover {\n  &.top > .arrow {\n    left: 50%;\n    margin-left: -@popover-arrow-outer-width;\n    border-bottom-width: 0;\n    border-top-color: @popover-arrow-outer-fallback-color; // IE8 fallback\n    border-top-color: @popover-arrow-outer-color;\n    bottom: -@popover-arrow-outer-width;\n    &:after {\n      content: \" \";\n      bottom: 1px;\n      margin-left: -@popover-arrow-width;\n      border-bottom-width: 0;\n      border-top-color: @popover-arrow-color;\n    }\n  }\n  &.right > .arrow {\n    top: 50%;\n    left: -@popover-arrow-outer-width;\n    margin-top: -@popover-arrow-outer-width;\n    border-left-width: 0;\n    border-right-color: @popover-arrow-outer-fallback-color; // IE8 fallback\n    border-right-color: @popover-arrow-outer-color;\n    &:after {\n      content: \" \";\n      left: 1px;\n      bottom: -@popover-arrow-width;\n      border-left-width: 0;\n      border-right-color: @popover-arrow-color;\n    }\n  }\n  &.bottom > .arrow {\n    left: 50%;\n    margin-left: -@popover-arrow-outer-width;\n    border-top-width: 0;\n    border-bottom-color: @popover-arrow-outer-fallback-color; // IE8 fallback\n    border-bottom-color: @popover-arrow-outer-color;\n    top: -@popover-arrow-outer-width;\n    &:after {\n      content: \" \";\n      top: 1px;\n      margin-left: -@popover-arrow-width;\n      border-top-width: 0;\n      border-bottom-color: @popover-arrow-color;\n    }\n  }\n\n  &.left > .arrow {\n    top: 50%;\n    right: -@popover-arrow-outer-width;\n    margin-top: -@popover-arrow-outer-width;\n    border-right-width: 0;\n    border-left-color: @popover-arrow-outer-fallback-color; // IE8 fallback\n    border-left-color: @popover-arrow-outer-color;\n    &:after {\n      content: \" \";\n      right: 1px;\n      border-right-width: 0;\n      border-left-color: @popover-arrow-color;\n      bottom: -@popover-arrow-width;\n    }\n  }\n}\n","//\n// Carousel\n// --------------------------------------------------\n\n\n// Wrapper for the slide container and indicators\n.carousel {\n  position: relative;\n}\n\n.carousel-inner {\n  position: relative;\n  overflow: hidden;\n  width: 100%;\n\n  > .item {\n    display: none;\n    position: relative;\n    .transition(.6s ease-in-out left);\n\n    // Account for jankitude on images\n    > img,\n    > a > img {\n      &:extend(.img-responsive);\n      line-height: 1;\n    }\n\n    // WebKit CSS3 transforms for supported devices\n    @media all and (transform-3d), (-webkit-transform-3d) {\n      .transition-transform(~'0.6s ease-in-out');\n      .backface-visibility(~'hidden');\n      .perspective(1000px);\n\n      &.next,\n      &.active.right {\n        .translate3d(100%, 0, 0);\n        left: 0;\n      }\n      &.prev,\n      &.active.left {\n        .translate3d(-100%, 0, 0);\n        left: 0;\n      }\n      &.next.left,\n      &.prev.right,\n      &.active {\n        .translate3d(0, 0, 0);\n        left: 0;\n      }\n    }\n  }\n\n  > .active,\n  > .next,\n  > .prev {\n    display: block;\n  }\n\n  > .active {\n    left: 0;\n  }\n\n  > .next,\n  > .prev {\n    position: absolute;\n    top: 0;\n    width: 100%;\n  }\n\n  > .next {\n    left: 100%;\n  }\n  > .prev {\n    left: -100%;\n  }\n  > .next.left,\n  > .prev.right {\n    left: 0;\n  }\n\n  > .active.left {\n    left: -100%;\n  }\n  > .active.right {\n    left: 100%;\n  }\n\n}\n\n// Left/right controls for nav\n// ---------------------------\n\n.carousel-control {\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  width: @carousel-control-width;\n  .opacity(@carousel-control-opacity);\n  font-size: @carousel-control-font-size;\n  color: @carousel-control-color;\n  text-align: center;\n  text-shadow: @carousel-text-shadow;\n  background-color: rgba(0, 0, 0, 0); // Fix IE9 click-thru bug\n  // We can't have this transition here because WebKit cancels the carousel\n  // animation if you trip this while in the middle of another animation.\n\n  // Set gradients for backgrounds\n  &.left {\n    #gradient > .horizontal(@start-color: rgba(0,0,0,.5); @end-color: rgba(0,0,0,.0001));\n  }\n  &.right {\n    left: auto;\n    right: 0;\n    #gradient > .horizontal(@start-color: rgba(0,0,0,.0001); @end-color: rgba(0,0,0,.5));\n  }\n\n  // Hover/focus state\n  &:hover,\n  &:focus {\n    outline: 0;\n    color: @carousel-control-color;\n    text-decoration: none;\n    .opacity(.9);\n  }\n\n  // Toggles\n  .icon-prev,\n  .icon-next,\n  .glyphicon-chevron-left,\n  .glyphicon-chevron-right {\n    position: absolute;\n    top: 50%;\n    margin-top: -10px;\n    z-index: 5;\n    display: inline-block;\n  }\n  .icon-prev,\n  .glyphicon-chevron-left {\n    left: 50%;\n    margin-left: -10px;\n  }\n  .icon-next,\n  .glyphicon-chevron-right {\n    right: 50%;\n    margin-right: -10px;\n  }\n  .icon-prev,\n  .icon-next {\n    width:  20px;\n    height: 20px;\n    line-height: 1;\n    font-family: serif;\n  }\n\n\n  .icon-prev {\n    &:before {\n      content: '\\2039';// SINGLE LEFT-POINTING ANGLE QUOTATION MARK (U+2039)\n    }\n  }\n  .icon-next {\n    &:before {\n      content: '\\203a';// SINGLE RIGHT-POINTING ANGLE QUOTATION MARK (U+203A)\n    }\n  }\n}\n\n// Optional indicator pips\n//\n// Add an unordered list with the following class and add a list item for each\n// slide your carousel holds.\n\n.carousel-indicators {\n  position: absolute;\n  bottom: 10px;\n  left: 50%;\n  z-index: 15;\n  width: 60%;\n  margin-left: -30%;\n  padding-left: 0;\n  list-style: none;\n  text-align: center;\n\n  li {\n    display: inline-block;\n    width:  10px;\n    height: 10px;\n    margin: 1px;\n    text-indent: -999px;\n    border: 1px solid @carousel-indicator-border-color;\n    border-radius: 10px;\n    cursor: pointer;\n\n    // IE8-9 hack for event handling\n    //\n    // Internet Explorer 8-9 does not support clicks on elements without a set\n    // `background-color`. We cannot use `filter` since that's not viewed as a\n    // background color by the browser. Thus, a hack is needed.\n    // See https://developer.mozilla.org/en-US/docs/Web/Events/click#Internet_Explorer\n    //\n    // For IE8, we set solid black as it doesn't support `rgba()`. For IE9, we\n    // set alpha transparency for the best results possible.\n    background-color: #000 \\9; // IE8\n    background-color: rgba(0,0,0,0); // IE9\n  }\n  .active {\n    margin: 0;\n    width:  12px;\n    height: 12px;\n    background-color: @carousel-indicator-active-bg;\n  }\n}\n\n// Optional captions\n// -----------------------------\n// Hidden by default for smaller viewports\n.carousel-caption {\n  position: absolute;\n  left: 15%;\n  right: 15%;\n  bottom: 20px;\n  z-index: 10;\n  padding-top: 20px;\n  padding-bottom: 20px;\n  color: @carousel-caption-color;\n  text-align: center;\n  text-shadow: @carousel-text-shadow;\n  & .btn {\n    text-shadow: none; // No shadow for button elements in carousel-caption\n  }\n}\n\n\n// Scale up controls for tablets and up\n@media screen and (min-width: @screen-sm-min) {\n\n  // Scale up the controls a smidge\n  .carousel-control {\n    .glyphicon-chevron-left,\n    .glyphicon-chevron-right,\n    .icon-prev,\n    .icon-next {\n      width: (@carousel-control-font-size * 1.5);\n      height: (@carousel-control-font-size * 1.5);\n      margin-top: (@carousel-control-font-size / -2);\n      font-size: (@carousel-control-font-size * 1.5);\n    }\n    .glyphicon-chevron-left,\n    .icon-prev {\n      margin-left: (@carousel-control-font-size / -2);\n    }\n    .glyphicon-chevron-right,\n    .icon-next {\n      margin-right: (@carousel-control-font-size / -2);\n    }\n  }\n\n  // Show and left align the captions\n  .carousel-caption {\n    left: 20%;\n    right: 20%;\n    padding-bottom: 30px;\n  }\n\n  // Move up the indicators\n  .carousel-indicators {\n    bottom: 20px;\n  }\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","// 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 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 (has been 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","//\n// Responsive: Utility classes\n// --------------------------------------------------\n\n\n// IE10 in Windows (Phone) 8\n//\n// Support for responsive views via media queries is kind of borked in IE10, for\n// Surface/desktop in split view and for Windows Phone 8. This particular fix\n// must be accompanied by a snippet of JavaScript to sniff the user agent and\n// apply some conditional CSS to *only* the Surface/desktop Windows 8. Look at\n// our Getting Started page for more information on this bug.\n//\n// For more information, see the following:\n//\n// Issue: https://github.com/twbs/bootstrap/issues/10497\n// Docs: http://getbootstrap.com/getting-started/#support-ie10-width\n// Source: http://timkadlec.com/2013/01/windows-phone-8-and-device-width/\n// Source: http://timkadlec.com/2012/10/ie10-snap-mode-and-responsive-design/\n\n@-ms-viewport {\n  width: device-width;\n}\n\n\n// Visibility utilities\n// Note: Deprecated .visible-xs, .visible-sm, .visible-md, and .visible-lg as of v3.2.0\n.visible-xs,\n.visible-sm,\n.visible-md,\n.visible-lg {\n  .responsive-invisibility();\n}\n\n.visible-xs-block,\n.visible-xs-inline,\n.visible-xs-inline-block,\n.visible-sm-block,\n.visible-sm-inline,\n.visible-sm-inline-block,\n.visible-md-block,\n.visible-md-inline,\n.visible-md-inline-block,\n.visible-lg-block,\n.visible-lg-inline,\n.visible-lg-inline-block {\n  display: none !important;\n}\n\n.visible-xs {\n  @media (max-width: @screen-xs-max) {\n    .responsive-visibility();\n  }\n}\n.visible-xs-block {\n  @media (max-width: @screen-xs-max) {\n    display: block !important;\n  }\n}\n.visible-xs-inline {\n  @media (max-width: @screen-xs-max) {\n    display: inline !important;\n  }\n}\n.visible-xs-inline-block {\n  @media (max-width: @screen-xs-max) {\n    display: inline-block !important;\n  }\n}\n\n.visible-sm {\n  @media (min-width: @screen-sm-min) and (max-width: @screen-sm-max) {\n    .responsive-visibility();\n  }\n}\n.visible-sm-block {\n  @media (min-width: @screen-sm-min) and (max-width: @screen-sm-max) {\n    display: block !important;\n  }\n}\n.visible-sm-inline {\n  @media (min-width: @screen-sm-min) and (max-width: @screen-sm-max) {\n    display: inline !important;\n  }\n}\n.visible-sm-inline-block {\n  @media (min-width: @screen-sm-min) and (max-width: @screen-sm-max) {\n    display: inline-block !important;\n  }\n}\n\n.visible-md {\n  @media (min-width: @screen-md-min) and (max-width: @screen-md-max) {\n    .responsive-visibility();\n  }\n}\n.visible-md-block {\n  @media (min-width: @screen-md-min) and (max-width: @screen-md-max) {\n    display: block !important;\n  }\n}\n.visible-md-inline {\n  @media (min-width: @screen-md-min) and (max-width: @screen-md-max) {\n    display: inline !important;\n  }\n}\n.visible-md-inline-block {\n  @media (min-width: @screen-md-min) and (max-width: @screen-md-max) {\n    display: inline-block !important;\n  }\n}\n\n.visible-lg {\n  @media (min-width: @screen-lg-min) {\n    .responsive-visibility();\n  }\n}\n.visible-lg-block {\n  @media (min-width: @screen-lg-min) {\n    display: block !important;\n  }\n}\n.visible-lg-inline {\n  @media (min-width: @screen-lg-min) {\n    display: inline !important;\n  }\n}\n.visible-lg-inline-block {\n  @media (min-width: @screen-lg-min) {\n    display: inline-block !important;\n  }\n}\n\n.hidden-xs {\n  @media (max-width: @screen-xs-max) {\n    .responsive-invisibility();\n  }\n}\n.hidden-sm {\n  @media (min-width: @screen-sm-min) and (max-width: @screen-sm-max) {\n    .responsive-invisibility();\n  }\n}\n.hidden-md {\n  @media (min-width: @screen-md-min) and (max-width: @screen-md-max) {\n    .responsive-invisibility();\n  }\n}\n.hidden-lg {\n  @media (min-width: @screen-lg-min) {\n    .responsive-invisibility();\n  }\n}\n\n\n// Print utilities\n//\n// Media queries are placed on the inside to be mixin-friendly.\n\n// Note: Deprecated .visible-print as of v3.2.0\n.visible-print {\n  .responsive-invisibility();\n\n  @media print {\n    .responsive-visibility();\n  }\n}\n.visible-print-block {\n  display: none !important;\n\n  @media print {\n    display: block !important;\n  }\n}\n.visible-print-inline {\n  display: none !important;\n\n  @media print {\n    display: inline !important;\n  }\n}\n.visible-print-inline-block {\n  display: none !important;\n\n  @media print {\n    display: inline-block !important;\n  }\n}\n\n.hidden-print {\n  @media print {\n    .responsive-invisibility();\n  }\n}\n","// Responsive utilities\n\n//\n// More easily include all the states for responsive-utilities.less.\n.responsive-visibility() {\n  display: block !important;\n  table&  { display: table !important; }\n  tr&     { display: table-row !important; }\n  th&,\n  td&     { display: table-cell !important; }\n}\n\n.responsive-invisibility() {\n  display: none !important;\n}\n","/* ************************************************************************ */\n/*                                LESS VARIABLES\n**                This stylesheet should only contain variables.\n/* ************************************************************************ */\n\n/*-----------------------------------------------------------------------*/\n/*                          Color palette                                */\n/*-----------------------------------------------------------------------*/\n@mgreen:                          #dae173;\n@morange:                         #d6782b;\n@mdarkblue:                       #232528;\n@mgrey:                           #cccccc;\n@mlightgrey:                      #999999;\n@mdarkbg:                         #16161B;\n@mblue:                           #358fdc;\n@darkerblue:                      #16252c;\n@darkblue:                        #17262d;\n@darkerblue:                      darken(@darkblue,4%);\n@darkblue2:                       #25333a;\n@mediumblue:                      #626d6d;\n@lightblue:                       #abc4c6;\n@pink:                            #ed1e79;\n@red:                             #FF0000;\n\n@fluroblue:                       #00e5f0;\n@fluroorange:                     #ff7300;\n@flureoyellow:                    #fbd925;\n@flurogreen:                      #47ff00;\n@fluropink:                       #e01f74;\n\n@darkgreen:                       #33d375;\n@green:                           #d1e55c;\n@purple:                          #977bf0;\n@lightgray:                       #e6edee;\n@bluegray:                        #abc4c6;\n@bluegray2:                       #35464c;\n\n@brand-success:                  @fluroblue;\n@brand-warning:                  @purple;\n@brand-info:                     @fluroblue;\n@brand-danger:                   @fluropink;\n@brand-primary:                  @fluroblue;\n\n@impac-positive:                 green;\n@impac-negative:                 @pink;\n@impac-positive2:                #3fc4ff;     // lighter colors used for payables-receivables\n@impac-negative2:                #1de9b6;     // lighter colorsused for payables-receivables\n\n// Spacers\n//----------------------------------------\n@top-buffer-height: @grid-gutter-width/2; // bootstrap variable\n.top-buffer-1 { margin-top: @top-buffer-height; }\n.top-buffer-2 { margin-top: 2*@top-buffer-height; }\n.top-buffer-3 { margin-top: 3*@top-buffer-height; }\n.top-buffer-4 { margin-top: 4*@top-buffer-height; }\n.top-buffer-5 { margin-top: 5*@top-buffer-height; }\n.top-buffer-6 { margin-top: 6*@top-buffer-height; }\n.top-buffer-7 { margin-top: 7*@top-buffer-height; }\n.top-buffer-8 { margin-top: 8*@top-buffer-height; }\n.top-buffer-9 { margin-top: 9*@top-buffer-height; }\n.top-buffer-10 { margin-top: 10*@top-buffer-height; }\n\n// Dashboard\n//--------------------------------------\n@impac-dashboard-padding-top:                   50px;\n@impac-dashboard-sm-padding-top:                @impac-dashboard-padding-top * 3;\n@impac-dashboard-margin-left:                   100px;\n@impac-dashboard-borders-color:                 @lightblue;\n\n// Title\n@impac-dashboard-title-color:                   @purple;\n@impac-dashboard-title-label-color:             @darkblue;\n@impac-dashboard-title-label-create-color:      white;\n@impac-dashboard-source-color:                  @impac-dashboard-title-label-color;\n@impac-dashboard-buttons-border-radius:         4px;\n\n// Create\n@impac-dashboard-create-button-color:           @impac-dashboard-title-color;\n\n//Info-text\n@impac-dashboard-info-text-color:               white;\n@impac-dashboard-info-text-background-color:    rgba(23,38,45, 0.7);\n@impac-dashboard-info-text-font-size:           25px;\n@impac-dashboard-info-text-font-weight:         300;\n\n// Dashboard Selector\n  // Tabs\n@impac-dashboard-selector-border:               1px solid @impac-dashboard-borders-color;\n@impac-dashboard-selector-tabs-margin:          0 2px 0 0;\n@impac-dashboard-selector-tabs-padding:         10px 8px 10px 15px;\n@impac-dashboard-selector-tabs-background-color: transparent;\n@impac-dashboard-selector-tabs-active-background-color: #ffffff;\n@impac-dashboard-selector-tabs-color:           black;\n@impac-dashboard-selector-tabs-active-color:    @purple;\n\n// Widget selector\n@impac-dashboard-widget-selector-bg:            #233845;\n@impac-dashboard-widget-selector-text-color:    white;\n@impac-dashboard-widget-selector-widget-item-min-height: 0px;\n\n// Widgets container\n@impac-placeholder-border:                      2px dashed @impac-dashboard-borders-color;\n@impac-widgets-container-side-padding:          0px;\n@impac-padding-between-widgets:                 12px;\n@impac-minimum-widget-size:                     250px;\n@impac-big-widget-size:                         565px;\n\n// Buttons\n@impac-btn-shadded-bg:                         @darkblue;\n@impac-btn-shadded-color:                      @mediumblue;\n\n// Dashboard Modals\n@impac-dashboard-loading-spinner:               white;\n@impac-dashboard-templates-selected-background-color: rgba(29, 197, 57, 0.62);\n\n// Widgets\n//--------------------------------------\n// Global\n@impac-widget-link-color:                      @purple;\n@impac-widget-buttons-color:                   @impac-widget-link-color;\n@impac-widget-tile-selected-color:             @impac-widget-link-color;\n@impac-widget-background-color:                white;\n@impac-widget-border:                          solid 1px darken(@lightgray,10%);\n@impac-widget-text-color:                      #5B6667;\n@impac-widget-text-color-medium:               lighten(@impac-widget-text-color,25%);\n@impac-widget-text-color-light:                lighten(@impac-widget-text-color,40%); //#acb0b1\n@impac-widget-borders-color:                   lighten(@impac-widget-text-color-light,10%); //#f3f4f4\n@impac-widget-scrollbar-color:                 #233845;\n@impac-widget-loading-spinner:                 #67BBE9;\n@impac-widget-reverse-color:                   #1E303B;\n@impac-widget-menus-hover-background-color:    #ececec;\n\n// Title\n@impac-widget-title-text-color:                darken(@impac-widget-text-color,5%);\n@impac-widget-title-bg:                        @impac-widget-background-color;\n@impac-widget-title-border:                    solid 1px @impac-widget-borders-color;\n@impac-widget-title-text-transform:            uppercase;\n@impac-widget-title-text-size:                 12px;\n@impac-widget-title-border-radius:             5px 5px 0px 0px;\n@impac-widget-top-buttons-color:               @impac-widget-text-color-light;\n\n// Content\n@impac-widget-content-border-radius:           0px 0px 5px 5px;\n@impac-widget-lines-container-max-height:      200px;\n\n// Settings\n// Param selector\n@impac-widget-param-selector-color:            @impac-widget-link-color;\n// Hist Mode Choser\n@impac-widget-hist-text-transform:             uppercase;\n@impac-widget-hist-text-size:                  12px;\n@impac-widget-hist-text-color:                 @impac-widget-text-color-light;\n// Params picker\n@impac-widget-params-picker-bg:                @impac-widget-reverse-color;\n@impac-widget-params-picker-unchecked-bg:      #c2c4c4;\n// Limit entries\n@impac-widget-limit-entries-color:             @impac-widget-reverse-color;\n\n// Globals and Mixins\n@impac-widget-selectable-color:                @impac-widget-link-color;\n\n// Edit settings\n@impac-widget-sub-bg-color:                    darken(@impac-widget-background-color,6%);\n@impac-widget-sub-bg-color-light:              lighten(@impac-widget-sub-bg-color,5%); //f3f4f4\n\n// Accounts Comparison\n@impac-widget-accounts-comparison-lines-container-max-height: 220px;\n\n// Sales break-even\n@impac-widget-sales-break-even-bg:             rgb(25,40,49);\n@impac-widget-sales-break-even-text-color:     #1de9b6;\n\n// KPIs\n//--------------------------------------\n// Kpi bar\n@kpis-bar-background-color:                    white;\n@kpis-bar-box-shadow:                          0px 1px 8px -4px;\n// Kpi\n@kpi-background-color:                         white;\n@kpi-triggered-border-bottom:                  4px solid @brand-danger;\n@kpi-max-height:                               95px;\n@kpi-editing-max-height:                       90px; // height to be added to the @kpi-max-height when in editing mode.\n@kpi-content-editing-height-buffer:            5px; // height to be minused from the @kpi-editing-max-height to even the kpi height and the kpi content height.\n// Kpi top-line\n@kpi-top-line-background-color:                grey;\n@kpi-top-line-triggered-background-color:      black;\n@kpi-top-line-height:                          7px;\n@kpi-top-line-box-shadow:                      none;\n// kpi content\n@kpi-text-color:                               grey;\n@kpi-text-triggered-color:                     black;\n@kpi-icon-color:                               grey;\n@kpi-icon-triggered-color:                     black;\n// kpi settings\n@kpi-settings-focus-color:                     @mblue;\n@kpi-settings-error-color:                     @brand-danger;\n@kpi-settings-remove-background:               #4c4749;\n@kpi-settings-remove-background-hover:         darken(@brand-danger, 5%);\n@kpi-settings-alert-config-background:         #4c4749;\n@kpi-settings-alert-config-background-hover:   @mblue;\n@kpi-negative-alert-label-background-color:    lighten(#ff0000, 30%);\n\n// Widgets pop-ups\n//--------------------------------------\n@impac-widget-popup-title-background-color:    #192831;\n@impac-widget-popup-message-background-color:  rgb(244, 248, 249);\n@impac-widget-popup-title-text-color:          white;\n@impac-widget-popup-message-text-color:        @impac-widget-text-color;\n\n// Demo data mode\n@impac-widget-demo-data-link-color:            @mgreen;\n","/* ************************************************************************ */\n/*                                GLOBAL STYLES\n**        This stylesheet should only contain styles applied global or in\n**                            2 or more components.\n/* ************************************************************************ */\n\n// Not ideal: intends to force a scrollbar on the window (not on the body),\n// so that the tooltips appended to body are not making the screen flickering.\n// (see when there is only 1 invoices list widget on the dashboard)\n// It is better if the tooltips can be appended to body because otherwise it's\n// messing the alternate-bg() mixing (by adding a child to the parent element)\nbody {\n  height: 101% !important;\n}\n\n.analytics {\n\n  // ---------------------------------------------------------------------------\n  // --- Titles\n  // ---------------------------------------------------------------------------\n\n  h2 {\n    margin-top: 2px;\n    font-size: 14px;\n    color: @impac-widget-text-color;\n  }\n\n  h3 {\n    margin: 0px;\n    .left-thin();\n  }\n\n  h4 {\n    color: @impac-widget-text-color;\n    font-size: 16px;\n  }\n\n  // ---------------------------------------------------------------------------\n  // --- Colors\n  // ---------------------------------------------------------------------------\n\n  .positive,.green {\n    color: @impac-positive !important;\n  }\n\n  .negative,.red {\n    color: @impac-negative !important;\n  }\n\n  .positive2 {\n    color: @impac-positive2 !important;\n  }\n\n  .negative2 {\n    color: @impac-negative2 !important;\n  }\n\n  // ---------------------------------------------------------------------------\n  // --- Base elements\n  // ---------------------------------------------------------------------------\n\n  a {\n    font-weight: bold;\n    color: @impac-widget-link-color;\n    cursor: pointer;\n  }\n\n  .input-group {\n    width: 100%;\n  }\n\n  select {\n    margin-top: 5px;\n    background-color: @impac-widget-background-color;\n    height: 32px;\n  }\n\n  pre {\n    font-size: 12px;\n    padding: 0px;\n    margin: 1px 0px 8px 0px;\n    border: none;\n    white-space: pre-wrap;\n    word-wrap: break-word;\n    overflow: hidden;\n  }\n\n  .widget-item .content, kpis-bar .kpi {\n    ::-webkit-scrollbar {\n      width: 6px;\n      background-color: transparent;\n    }\n\n    ::-webkit-scrollbar-thumb {\n      background-color: lighten(@impac-widget-scrollbar-color,35%);\n      border-radius: 10px;\n      &:hover {\n        background-color: lighten(@impac-widget-scrollbar-color,40%);\n      }\n    }\n  }\n\n  // ---------------------------------------------------------------------------\n  // --- Common adjustments\n  // ---------------------------------------------------------------------------\n  .nopadding {\n    padding: 0;\n  }\n\n  .nomargin {\n    margin: 0;\n  }\n\n  // ---------------------------------------------------------------------------\n  // --- Custom elements\n  // ---------------------------------------------------------------------------\n\n  .btn.btn-shaded {\n    background-color: @impac-btn-shadded-bg;\n    border: solid 1px darken(@impac-btn-shadded-bg,5%);\n    color: @impac-btn-shadded-color;\n    font-weight: 400;\n\n    &:hover {\n      color: lighten(@impac-btn-shadded-color,5%);\n      background-color: lighten(@impac-btn-shadded-bg,5%);\n    }\n  }\n\n  .price {\n    .center-bold();\n  }\n\n  .currency {\n    .center-thin();\n    color: @impac-widget-text-color-medium;\n  }\n\n  .legend {\n    .center-small();\n    .scrollable();\n    color: @impac-widget-text-color-light;\n  }\n\n  .loader {\n    height: 100%;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    i {\n      .loader-style();\n    }\n    p {\n      margin-top: 10px;\n    }\n  }\n\n  .right-panel {\n    border-left: solid 1px #e6e6e6;\n  }\n\n  .selector {\n    text-transform: uppercase;\n    font-size: 12px;\n    color: @mediumblue;\n    text-align: center\n  }\n\n  .tile {\n    background-color: rgb(247,247,247);\n    box-shadow: 0px 7px 10px -7px #17262d;\n    height: 45px;\n    margin-bottom: 10px;\n    white-space: nowrap;\n    cursor: pointer;\n    &:hover {\n      background-color: darken(#F1F9FF, 3%);\n    }\n    .colored-area {\n      background-color: #3FC4FF;\n      height: 100%;\n      float: right;\n      color: white;\n      text-align: right;\n      padding: 5px 10px;\n      min-width: 8%;\n      &.selected {\n        background-color: @impac-widget-tile-selected-color;\n      }\n    }\n    .main-text {\n      color: @impac-widget-text-color;\n      padding: 20px 0px 0px 5px;\n      height: 100%;\n      font-style: italic;\n      font-weight: bold;\n    }\n  }\n\n  .widget-lines-container {\n    .scrollable();\n    max-height: @impac-widget-lines-container-max-height;\n    text-align: left;\n    font-size: 12px;\n    padding: 0px 15px;\n\n    .row.widget-line {\n      padding: 5px;\n      color: @mediumblue;\n\n      &.header {\n        .font(12px,500,@impac-widget-text-color-medium);\n        text-transform: uppercase;\n      }\n      @media (max-width: @screen-xs-max) {\n        margin: inherit;\n        margin-left: -3px;\n        margin-right: -3px;\n        padding: 2px;\n\n        & > [class*='col-'] {\n          padding-left: 3px;\n          padding-right: 3px;\n        }\n      }\n\n      i.fa {\n        min-width: 12px;\n        min-height: 12px;\n      }\n    }\n\n    .row .dashed {\n      border-bottom: dashed 1px @impac-widget-borders-color;\n      padding-bottom: 3px;\n      margin-bottom: 3px;\n    }\n\n    .row.lines-group {\n      border-top: solid 1px @lightgray;\n    }\n  }\n}\n\n.vertical-scroll {\n  overflow-y: scroll;\n}\n\n.horizontal-scroll {\n  overflow-x: scroll;\n}\n\n// The tooltips should be append to body\n.tooltip.impac-widgets-tooltip .tooltip-inner.ng-binding {\n  text-align: left;\n  background-color: @mdarkblue;\n  max-width: 100%;\n  white-space: nowrap;\n  strong {\n    color: @mgreen;\n  }\n}\n\n.sortable-title {\n  cursor: pointer;\n  div {\n    display: inline-block;\n  }\n}\n\ndiv[ng-messages] {\n  color: @red;\n}\n\n// ---------------------------------------------------------------------------\n// --- Bootstrap overrides\n// ---------------------------------------------------------------------------\n\n.has-error .form-control {\n  border-color: @brand-danger;\n  &:focus { border-color: @brand-danger }\n}\n\n.has-success .form-control {\n  border-color: @brand-success;\n  &:focus { border-color: @brand-success }\n}\n\n// remove gutters from Boostrap row\n.row.no-gutters {\n  margin-right: 0;\n  margin-left: 0;\n}\n\n// remove gutters from Boostrap column\n[class^=\"col-\"].no-gutters,\n[class*=\" col-\"].no-gutters {\n  padding-right: 0;\n  padding-left: 0;\n}\n",".font(@size,@weight,@color) {\n  font-weight:@weight;\n  font-size:@size;\n  color:@color;\n}\n\n.center-bold (@margin-top: 30px) {\n  .font(22px, 900, @impac-widget-text-color);\n  text-align: center;\n  margin-top: @margin-top;\n}\n\n.center-thin () {\n  .font(16px, 300, @impac-widget-text-color);\n  text-align: center;\n}\n\n.center-small () {\n  .font(12px, 300, @impac-widget-text-color);\n  text-align: center;\n}\n\n.left-thin (@margin-top: 0px) {\n  .font(14px, 300, @impac-widget-text-color);\n  text-align: left;\n  margin-top: @margin-top;\n}\n\n.widget-height (@height: @impac-minimum-widget-size) {\n  min-height: @height;\n  @media (min-width: @screen-md-min) {\n    height: @height;\n    .chart-container {\n      max-width: @height + 20px;\n      max-height: @height - 125px;\n      margin: auto;\n    }\n  }\n}\n\n.short-widget () {\n  .widget-height();\n  .edit {\n    max-height: @impac-minimum-widget-size - 20px;\n  }\n}\n\n.tall-widget () {\n  .widget-height(@impac-big-widget-size);\n  .edit {\n    max-height: @impac-big-widget-size - 20px;\n    .widget-lines-container {\n      .scrollable(hidden);\n    }\n  }\n}\n\n.scrollable (@scroll-mode: auto) {\n  overflow-y: @scroll-mode;\n  overflow-x: hidden;\n}\n\n.selectable () {\n  cursor: pointer;\n  border: solid 1px @impac-widget-background-color;\n  .selection-tag {\n    display: block;\n    right: 0px;\n    margin-top: -6px;\n    width: 10px;\n    height: 29px;\n    position: absolute;\n  }\n  &:hover {\n    background-color: lighten(@impac-widget-selectable-color, 22%);\n  }\n  &.no-select {\n    cursor: auto;\n    &:hover { color: @mediumblue; }\n  }\n}\n\n.alternate-bg (@even-color: @impac-widget-sub-bg-color) {\n  &:nth-child(even) {\n    background-color: @even-color;\n  }\n  &:nth-child(odd) {\n    background-color: @impac-widget-background-color;\n  }\n}\n\n.edit-panel-style() {\n  .scrollable();\n  color: @impac-widget-text-color;\n  padding: 2px;\n  font-size: 12px;\n\n  .bottom-buttons {\n    .btn {\n      border-radius: 2px;\n      margin-right: 5px;\n      padding: 3px 13px;\n      text-transform: uppercase;\n      font-size: 12px;\n\n      &.btn-default {\n        background-color: #c2c4c4;\n        border: solid 1px darken(#c2c4c4,10%);\n        color: white;\n        &:hover {\n          border: solid 1px darken(#c2c4c4,20%);\n          background-color: darken(#c2c4c4,10%);\n        }\n      }\n    }\n  }\n\n  h4 {\n    margin: 0;\n    margin-bottom: 8px;\n    text-align: left;\n    .font(12px,normal,@impac-widget-text-color-light);\n  }\n\n  .part {\n    margin-bottom: 8px;\n    padding: 10px 0px;\n    background-color: @impac-widget-sub-bg-color-light;\n    // color: #626d6d;\n    border: solid 1px @impac-widget-borders-color;\n\n    h5 {\n      display: block;\n      margin: 0;\n      margin-bottom: 10px;\n      padding: 0px 15px;\n      text-transform: uppercase;\n      .font(12px,normal,@impac-widget-text-color-light);\n    }\n\n    label {\n      font-weight: normal;\n    }\n\n    select.form-control {\n      margin: 0px;\n      border: solid 1px #acb0b1;\n      outline: none;\n      -webkit-box-shadow: none;\n      font-size: 13px;\n      color: #72728b;\n    }\n  }\n}\n\n.loader-style(@color: @impac-widget-loading-spinner) {\n  color: @color;\n}\n\n.column-gutter(@gutter: @grid-gutter-width) {\n  padding-left: @gutter;\n  padding-right: @gutter;\n}\n\n.widget-popup() {\n  text-align: center;\n  font-size: 13px;\n  color: @impac-widget-popup-message-text-color;\n  \n  .overlay {\n    background-color: white;\n    position: absolute;\n    height: ~\"calc(100% - 4px)\";\n    width: ~\"calc(100% - 4px)\";\n    top: 2px;\n    left: 2px;\n    opacity: 0.6;\n    z-index: 5;\n  }\n\n  .message {\n    z-index: 6;\n    position: absolute;\n    min-height: 160px;\n    padding-bottom: 10px;\n    top: 45px;\n    left: 7%;\n    width: 86%;\n    background-color: @impac-widget-popup-message-background-color;\n    border-radius: 4px;\n    box-shadow: 0px 0px 25px 0px;\n\n    .title {\n      padding: 2px;\n      background-color: @impac-widget-popup-title-background-color;\n      color: @impac-widget-popup-title-text-color;\n      margin: -1px -1px 10px -1px;\n      text-transform: uppercase;\n    }\n  }\n}\n","@media print {\n  body { background-color: white !important; }\n  .analytics {\n    padding-top: 0px !important;\n    #module__dashboard-selector .title-container { margin-top: 20px; }\n    .widget-item {\n      page-break-inside: avoid;\n      .content .chart-container {\n        max-width: 270px;\n        margin: auto;\n        canvas {\n          width: 100% !important;\n          height: 100% !important;\n        }\n      }\n      .right-panel {\n        page-break-inside: avoid;\n        border-left: 0;\n        .chart-container {\n          max-width: inherit;\n          max-height: inherit;\n          canvas {\n            width: 80% !important;\n            height: 80% !important;\n          }\n        }\n      }\n    }\n  }\n  * { transition: none !important; }\n}\n","// NOTE: Do not add styles for the default button or custom injected buttonHtml here.\n//       the parent stylesheet of which this directive is embedded within should\n//       contain the styles.\n\n// Modal kpis alerts settings\n.kpi-alerts-settings {\n  .modal-header { font-size: 20px; }\n\n  .modal-body {\n    line-height: 2;\n\n    ul { margin-top: 10px; }\n\n    ul > li.list-group-item {\n      list-style: none;\n      padding: 6px 15px;\n      color: @impac-widget-text-color-medium;\n      user-select: none;\n\n      .alert-toggle {\n        &:hover { cursor: pointer; }\n      }\n\n      &.active {\n        color: @mblue;\n        font-weight: bold;\n        background-color: transparent;\n        border-color: #c4caca;\n      }\n    }\n\n    .fa.fa-toggle-on, .fa.fa-toggle-off {\n      font-size: 17px;\n      margin-right: 8px;\n    }\n\n    ul.recipients-list {\n      height: 75px;\n      overflow: hidden;\n      overflow-y: scroll;\n      border: 1px solid #c4caca;\n\n      li {\n        border: none;\n      }\n\n    }\n\n    input.recipient-search {\n      color: black;\n      width: 100%;\n    }\n\n    ul.available {\n      margin-top: 0px;\n    }\n  }\n}\n",".analytics {\n  padding-top: @impac-dashboard-padding-top;\n  margin-left: @impac-dashboard-margin-left;\n\n  // Default small screen behaviour to allow for the common use of top-bars\n  @media screen and (max-width: 992px) {\n    padding-top: @impac-dashboard-sm-padding-top;\n  }\n\n  &.pdf-mode { padding-top: 20px; }\n\n  &.show-dhb {\n    transition: opacity 1s;\n    opacity: 1;\n  }\n  &.hide-dhb {\n    opacity: 0;\n  }\n\n  // contains customisable impac logo, and heading text.\n  #dashboard-heading {\n    img {\n      float: left;\n      margin-right: 15px;\n      max-width: 200px;\n      max-height: 150px;\n      &.pdf-mode:hover { cursor: pointer; }\n    }\n    .caption {\n      font-size: 14px;\n      margin: 5px 0px;\n    }\n  }\n\n  #sub-menu {\n    margin-top: 15px;\n    h3 {\n      font-size: 26px;\n      font-weight: normal;\n      margin-bottom: 10px;\n      color: #233845;\n    }\n\n    .fa.fa-times {\n      margin: 6px;\n      color: lighten(#233845, 15%);\n      cursor: pointer;\n      float: right;\n    }\n  }\n\n  #widget-selector {\n    background-color: @impac-dashboard-widget-selector-bg;\n    color: @impac-dashboard-widget-selector-text-color;\n    padding: 0px 45px 10px 45px;\n    margin: 10px -45px;\n    border-radius: 3px;\n\n    -webkit-user-select: none; /* Chrome/Safari */\n    -moz-user-select: none; /* Firefox */\n    -ms-user-select: none; /* IE10+ */\n    /* Rules below not implemented in browsers yet */\n    -o-user-select: none;\n    user-select: none;\n\n    @media (max-width: @screen-xs-max) {\n      padding: 0 15px 10px 15px;\n      margin: 0;\n    }\n\n    .title {\n      padding: 15px 0px;\n      border-bottom: solid 1px lighten(@impac-dashboard-widget-selector-bg,6%);\n      display: flex;\n      align-items: center;\n\n      p.instruction {\n        flex-grow: 1;\n        margin: 0;\n        @media screen and (max-width: @screen-sm-min) {\n          width: 50%;\n          font-size: 13px;\n        }\n      }\n\n      .widget-added.badge {\n        margin-right: 10px;\n        opacity: 0;\n      }\n\n      .fa.close-selector {\n        float: right;\n        cursor: pointer;\n        font-size: 20px;\n        padding: 6px;\n        &:hover {\n          color: @mlightgrey;\n        }\n      }\n    }\n\n    .top-container {\n      margin: 15px 0px;\n      background-color: transparent;\n      border-radius: 3px;\n    }\n\n    .section-header {\n      padding: 10px 20px;\n      font-weight: bold;\n      min-height: 40px;\n      display: flex;\n      align-items: center;\n    }\n\n    .section-lines {\n      overflow-x: hidden;\n      overflow-y: auto;\n      height: 200px;\n      margin-right: -10px;\n      margin-left: 0px;\n\n      p {\n        padding: 5px;\n        margin: 0px;\n        cursor: pointer;\n\n        &:hover, &.selected {\n          color: @impac-dashboard-widget-selector-text-color;\n        }\n      }\n\n      &::-webkit-scrollbar {\n        width: 6px;\n        background-color: transparent;\n      }\n\n      &::-webkit-scrollbar-thumb {\n        background-color: lighten(@impac-dashboard-widget-selector-bg,3%);\n        border-radius: 10px;\n        &:hover {\n          background-color: lighten(@impac-dashboard-widget-selector-bg,6%);\n        }\n      }\n    }\n\n    .categories-section {\n      background-color: darken(@impac-dashboard-widget-selector-bg,6%);\n      padding-bottom: 15px;\n\n      & > .section-lines {\n\n        & > [class*='col-']:first-child {\n          padding: 3px 12px;\n        }\n\n        .line-item:hover {\n          background-color: darken(@impac-dashboard-widget-selector-bg,3%);\n        }\n        .line-item.selected {\n          background-color: @impac-widget-link-color;\n          font-weight: bold;\n          .box-shadow(-2px 2px 10px -4px black);\n        }\n      }\n\n      .arrow-icon {\n        position: absolute;\n        top: 33px;\n        right: -11px;\n        z-index: 1;\n\n        .square {\n          width: 50px;\n          height: 30px;\n          position: absolute;\n          top: 10px;\n          right: 17px;\n          background-color: @impac-widget-link-color;\n        }\n\n        i.fa.fa-caret-right {\n          font-size: 52px;\n          color: @impac-widget-link-color;\n          float: right;\n          position: absolute;\n          top: -1.5px;\n          right: 0px;\n        }\n      }\n    }\n\n    .widgets-section {\n      background-color: darken(@impac-dashboard-widget-selector-bg,3%);\n      padding-bottom: 15px;\n\n      & > .section-header {\n        text-transform: uppercase;\n        font-size: 12px;\n        color: @impac-widget-link-color;\n      }\n\n      & > .section-lines {\n        padding: 3px 0px;\n\n        .fa.fa-plus-circle {\n          float: right;\n          margin-top: 3px;\n        }\n\n        & > .line-items-grid {\n          width: 100%;\n          display: flex;\n          flex-wrap: wrap;\n          height: 0%;\n\n          & > .grid-item {\n            padding: 0 13px;\n            display: flex;\n            flex-grow: 1;\n            // Applies a flex-basis of 1/3 for each grid item (3 columns per row)\n            flex: 0 31.33%;\n            // Creates a small gutter around each grid item\n            margin: 0 1%;\n            align-items: center;\n            border-bottom: solid 1px @impac-dashboard-widget-selector-bg;\n            min-height: @impac-dashboard-widget-selector-widget-item-min-height;\n\n            @media screen and (max-width: @screen-md-min) {\n              flex: 0 100%;\n            }\n\n            &:hover {\n              background-color: darken(@impac-dashboard-widget-selector-bg,6%);\n              font-weight: normal;\n            }\n\n            p.line-item {\n              flex-grow: 1;\n            }\n          }\n        }\n      }\n    }\n\n    .bottom {\n      height: 20px;\n      & > .suggestion {\n        float: right;\n        opacity: 0.7;\n        a {\n          cursor: pointer;\n          &:hover {\n            color: @fluroblue;\n          }\n        }\n        &:hover {\n          opacity: 1;\n        }\n      }\n    }\n  }\n\n  #dashboard-settings-panel {\n    position: relative;\n    margin-top: 5px;\n    & > div {\n      display: flex;\n      justify-content: flex-end;\n      & > * { margin: 0px 3px; }\n    }\n    select {\n      margin: 0;\n      height: 34px;\n      padding-top: 1px;\n    }\n  }\n\n  // no widgets - empty dashboard.\n  #no-widgets-container {\n    position: relative;\n    min-height: 150px;\n\n    // background image asset\n    img.bg {\n      left: 0;\n      top: 0;\n      min-width: 100%;\n      min-height: 100%;\n    }\n\n    // no widgets message that sits above image asset\n    .impac-info-message {\n      position: absolute;\n      top: 0;\n      width: 100%;\n\n      .info-text {\n        font-size: @impac-dashboard-info-text-font-size;\n        font-weight: @impac-dashboard-info-text-font-weight;\n        padding:20px;\n        min-height: 115px;\n        color: @impac-dashboard-info-text-color;\n        border-radius: 10px;\n        background-color: @impac-dashboard-info-text-background-color;\n      }\n    }\n  }\n\n  // parent div section for widgets to be housed.\n  #widgets-section {\n    // container for widgets\n    #widgets-container {\n      // Quick-fix to avoid screen flockering when tooltips are appended to body:\n      // min-height will force a scrollbar to appear...\n      min-height: 700px;\n    }\n\n    .placeHolderBox {\n      margin: @impac-padding-between-widgets;\n      height: 267px;\n      width: 300px;\n      float: left;\n      border: @impac-placeholder-border;\n      background: none;\n    }\n  }\n}\n\n// dashboard failed to load message.\n.analytics.load-failed {\n\n  p { font-size: 22px; }\n\n  .second-msg {\n    p {\n      color: @brand-danger;\n      font-size: 14px;\n    }\n  }\n}\n\n// Tooltips are append to body\n.tooltip.impac-widget-selector-tooltip .tooltip-inner.ng-binding {\n  font-size: 14px;\n}\n\n.impac-widget-suggestion .modal-body {\n  input,textarea {\n    width: 100%;\n    color: black;\n  }\n  textarea {\n    height: 150px;\n  }\n  .thanks-message {\n    color: @mgreen;\n  }\n}\n\n// This style applies to dashboard modals, and also the\n// `accounts-custom-calculation/formula.modal.html` modal.\n.modal-footer .loader {\n  .loader-style(@impac-dashboard-loading-spinner)\n}\n\n",".analytics .dashboard-create {\n  .btn-create {\n    background-color: @impac-dashboard-create-button-color;\n  }\n}\n\n.modal.impac-dashboard-create {\n  h1 { font-size: 24px; }\n  .fa.fa-times {\n    float: right;\n    color: #ccc;\n    cursor: pointer;\n  }\n  .control-label { text-align: left; }\n  .modal-footer {\n    .loader {\n      .loader-style(@impac-dashboard-loading-spinner)\n    }\n  }\n}\n","#module__dashboard-selector {\n  a {\n    font-weight: normal;\n  }\n  // dashboard selector template wrapper div\n  & > div:first-child {\n    border-bottom: @impac-dashboard-selector-border;\n  }\n\n  .buttons-bar-row {\n    margin-top: 54px;\n    &.pdf-mode { margin-top: 0px; }\n  }\n\n  // container for dashboard selector 'dropdown' template\n  .buttons-bar {\n    padding: 0;\n    position: relative;\n\n    .btn {\n      float: right;\n      margin: 3px;\n      border-radius: @impac-dashboard-buttons-border-radius;\n    }\n\n    .title-container {\n      h1 {\n        margin: 0px;\n        color: black;\n        cursor: auto;\n      }\n    }\n\n    .dropdown-container {\n      .dashboard-title {\n        color: @impac-dashboard-title-color;\n        display: inline;\n        cursor: pointer;\n        &:hover {\n          color: darken(@impac-dashboard-title-color,10%);\n        }\n        i.fa.fa-pencil {\n          margin-left: 20px;\n          font-size: 14px;\n          &:hover {\n            color: @mgreen;\n          }\n        }\n      }\n      .dashboard-select {\n        margin: 5px 0px 10px 30px;\n        height: auto;\n        border-left: 1px solid @impac-dashboard-title-color;\n        border-bottom: 1px solid @impac-dashboard-title-color;\n        width: 300px;\n        background-color: @lightgray;\n        cursor: pointer;\n        .option {\n          color: @impac-dashboard-title-label-color;\n          white-space: nowrap;\n          &:hover {\n            background-color: @impac-widget-background-color;\n          }\n          &.dashboard-create {\n            height: 33px;\n            .btn {\n              float: none;\n              width: 100%;\n              text-align: left;\n              margin: 0px;\n              border-radius: 0px;\n            }\n          }\n          i.fa.fa-pencil {\n            float: right;\n            padding-top: 7px;\n            text-align: center;\n            width: 15%;\n            height: 30px;\n            &:hover {\n              color: darken(@impac-dashboard-title-color,10%);\n            }\n          }\n          span.name {\n            width: 85%;\n            height: 30px;\n            display: inline-block;\n            padding: 5px 10px 5px 10px;\n          }\n        }\n      }\n      .change-name {\n        position: absolute;\n        top: 30px;\n        left: 20px;\n        width: 60%;\n        background-color: rgb(23, 38, 45);\n        color: white;\n        padding: 10px;\n        border-radius: 4px;\n        text-align: center;\n        .box-shadow(0px 0px 25px 4px black);\n        z-index: 50;\n        border: solid 1px @impac-widget-background-color;\n\n        .form-control {\n          height: 25px;\n          margin-bottom: 10px;\n        }\n      }\n      .data-source-label {\n        color: @impac-dashboard-source-color;\n        padding-left: 3px;\n        margin: 0px;\n      }\n    }\n\n    .loader-container {\n      padding-left: 10px;\n      .loading-spinner {\n        .loader-style();\n        font-size: 40px;\n      }\n    }\n  }\n\n  // angular bootstrap tabs & pills\n  .nav-tabs {\n    border-bottom: 0;\n  }\n  .nav.nav-tabs,\n  .nav.nav-pills {\n\n    // add new tab\n    li:last-child > a {\n      padding-right: 15px;\n      tab-heading a {\n        position: static;\n      }\n    }\n  }\n\n  // TABS\n  .nav.nav-tabs {\n    // tab\n    li > a {\n      padding: @impac-dashboard-selector-tabs-padding;\n      margin: @impac-dashboard-selector-tabs-margin;\n      background-color: @impac-dashboard-selector-tabs-background-color;\n      border: @impac-dashboard-selector-border;\n      color: @impac-dashboard-selector-tabs-color;\n    }\n    // active tab\n    li.active > a {\n      background-color: @impac-dashboard-selector-tabs-active-background-color;\n      color: @impac-dashboard-selector-tabs-active-color;\n    }\n    // add new tab\n    li:last-child > a {\n      // padding-left: 5px;\n    }\n    li:last-child.active > a {\n      background-color: @impac-dashboard-selector-tabs-background-color;\n    }\n  }\n\n  // PILLS\n  // TODO: Add less variables for customisation.\n  .nav.nav-pills {\n    // tab\n    li > a {\n      min-width: 0px;\n      padding-right: 8px;\n    }\n    // add a new tab\n    li:last-child tab-heading a {\n      margin-left: 2px;\n    }\n    // add a new tab\n    li:last-child.active > a {\n      background-color: #f4f4f4;\n    }\n  }\n  // tab icons\n  tab-heading a.close-link {\n    border-bottom: 0px solid;\n    margin-left: 12px;\n    position: relative;\n    top: -9px;\n    right: 1px;\n    color: @impac-dashboard-selector-tabs-color;\n  }\n  ////////\n}\n","dashboard-templates-selector {\n  .templates-header {\n    display: flex;\n    .templates-toggle {\n      display: flex;\n      flex-grow: 1;\n      justify-content: flex-end;\n      font-size: 20px;\n      i.fa {\n        cursor: pointer;\n        &.fa-toggle-on {\n          color: @impac-widget-link-color;\n        }\n      }\n    }\n  }\n  .templates {\n    border: 1px solid #ccc;\n    box-shadow: inset 0px 0px 1px 0px #ccc;\n    height: 130px;\n    overflow: auto;\n    border-radius: 2px;\n\n    .template {\n      padding: 5px 10px;\n      color: @impac-widget-text-color;\n      border-bottom: 1px solid #ececec;\n      &:hover {\n        cursor: pointer;\n        background-color: lighten(@impac-dashboard-templates-selected-background-color, 20%);\n      }\n      &.selected {\n        background-color: @impac-dashboard-templates-selected-background-color;\n      }\n    }\n  }\n}\n",".analytics .impac-kpi .kpi {\n  position: relative;\n  max-width: 220px;\n  min-height: @kpi-max-height;\n  max-height: @kpi-max-height;\n  background-color: @kpi-background-color;\n  margin: 10px 0 10px 0;\n  border-bottom: 1px solid @kpi-background-color;\n  transition: all .2s ease-in;\n\n  @media screen and (max-width: 768px) {\n    margin-left: auto;\n    margin-right: auto;\n  }\n\n  &.triggered, &.add:hover {\n    border-bottom: @kpi-triggered-border-bottom;\n  }\n\n  &.add {\n    .kpi-text {\n      .emphasis { visibility: hidden; }\n    }\n  }\n\n  &.add:hover {\n    cursor: pointer;\n    .top-line { background-color: @kpi-top-line-triggered-background-color; }\n    .kpi-text {\n      color: @kpi-text-triggered-color;\n      .emphasis { visibility: visible; }\n    }\n    .kpi-icon {\n      color: @kpi-icon-triggered-color;\n      .fa-plus:before {\n        content: \"\\f00c\";\n      }\n    }\n  }\n\n  &.editing {\n    min-height: @kpi-max-height + @kpi-editing-max-height;\n  }\n\n  &:hover { cursor: default; }\n\n  &.static {\n    .kpi-value {\n      display: block;\n      font-size: 14px;\n      font-weight: 700;\n    }\n  }\n\n  .top-line {\n    width: 100%;\n    position: relative;\n    cursor: move;\n    padding: 9px 9px 0px 12px;\n    border-bottom: none;\n    min-height: @kpi-top-line-height;\n    box-shadow: @kpi-top-line-box-shadow;\n    display: -webkit-box;\n    display: -webkit-flex;\n    display: -ms-flexbox;\n    display: flex;\n    -webkit-box-orient: horizontal;\n    -webkit-box-direction: normal;\n    -webkit-flex-direction: row;\n    -ms-flex-direction: row;\n    flex-direction: row;\n    margin-bottom: 5px;\n    background-color: @kpi-top-line-background-color;\n    &.triggered { background-color: @kpi-top-line-triggered-background-color; }\n    transition: background .2s ease-in;\n  }\n\n  .kpi-content {\n    max-height: @kpi-max-height - 5px;\n    &.editing {\n      min-height: @kpi-max-height + @kpi-editing-max-height - @kpi-content-editing-height-buffer;\n      .scrollable();\n    }\n  }\n\n  .kpi-show {\n    white-space: normal;\n    padding: 10px;\n    // small fix for iphone 6 and smaller\n    @media screen and (max-width: 380px) {\n      padding: 10px 3px;\n    }\n\n    .emphasis {\n      white-space: nowrap;\n      overflow: hidden;\n      text-overflow: ellipsis;\n\n      .real-value { color: #676767; }\n    }\n\n    .caption {\n      white-space: nowrap;\n      overflow: hidden;\n      text-overflow: ellipsis;\n    }\n\n    .kpi-text {\n      & > span { display: block; }\n      padding: 7px 0;\n      color: @kpi-text-color;\n      transition: color .2s ease-in;\n      &.triggered { color: @kpi-text-triggered-color; }\n\n      .caption {\n        font-size: 11px;\n        padding-bottom: 2px;\n      }\n\n      @media screen and (max-width: 465px) {\n        .caption { font-size: 10px; }\n        .emphasis { font-size: 11px; }\n      }\n    }\n\n    .kpi-icon {\n      font-size: 16px;\n      padding: 10px 0;\n      color: @kpi-icon-color;\n      transition: color .2s ease-in;\n      &.triggered { color: @kpi-icon-triggered-color; }\n      @media screen and (max-width: 465px) {\n        font-size: 12px;\n        padding: 16px 0;\n      }\n    }\n  }\n\n  .kpi-edit {\n\n    a { color: white; }\n\n    .kpi-name {\n      text-align: center;\n      margin-bottom: 5px;\n      h6 {\n        margin: 0 0 5px 0;\n      }\n    }\n\n    .real-value {\n      text-transform: uppercase;\n      font-size: 10px;\n      text-align: center;\n    }\n\n    .alert-caption {\n      text-align: center;\n      font-size: 11px;\n      background: @kpi-negative-alert-label-background-color;\n      border-radius: 3px;\n      width: 100%;\n      margin: 0 auto 5px auto;\n      box-shadow: none;\n      padding: 2px;\n      color: white;\n    }\n\n\n    .kpi-target-watchable,\n    .kpi-target-unit {\n      text-transform: uppercase;\n      font-weight: 500;\n      font-size: 11px;\n    }\n\n    .kpi-target-watchable {\n      margin-bottom: 20px;\n      color: lighten(@kpi-top-line-background-color, 5%);\n    }\n\n    .kpi-target-unit {\n      position: absolute;\n      top: 6px;\n      right: 0;\n      color: lighten(@kpi-top-line-background-color, 10%);\n    }\n\n    .param-name {\n      .small();\n    }\n\n    .btn.btn-xs {\n      margin-top: 4px;\n    }\n  }\n\n  .kpi-edit,\n  .kpi-no-data {\n    .impac-material(@kpi-settings-focus-color, @kpi-settings-error-color);\n  }\n\n  button.kpi-alerts.im-fab.im-primary {\n    position: absolute;\n    top: -12px;\n    right: 15px;\n    width: 22px;\n    height: 22px;\n    font-size: 13px;\n    background: @kpi-settings-alert-config-background;\n    &:hover {\n      backgroud: @kpi-settings-alert-config-background-hover;\n    }\n  }\n\n  button.kpi-remove.im-fab.im-warn {\n    position: absolute;\n    top: -12px;\n    right: -11px;\n    width: 22px;\n    height: 22px;\n    font-size: 13px;\n    background: @kpi-settings-remove-background;\n    &:hover {\n      background: @kpi-settings-remove-background-hover;\n    }\n  }\n\n  .kpi-data-loader {\n    width: 100%;\n    min-height: 95px;\n  }\n}\n\n.analytics kpis-bar > .key-stats .kpi {\n  min-height: 80px;\n}\n","/* ************************************************************************ */\n/*                                IMPAC MATERIAL\n/*                  ------------------------------------------\n** Mixin material styled form inputs, overriding bootstrap's ungodly round-ness.\n/* ************************************************************************ */\n/* DEMO HTML - use this html to test all impac material features.\n<form>\n  <div class=\"im-form-group\">\n    <select>\n      <option>Value 1</option>\n      <option>Value 2</option>\n    </select>\n    <label for=\"select\" class=\"im-control-label\">Selectbox</label><i class=\"im-bar\"></i>\n  </div>\n  <div class=\"im-form-group\">\n    <input type=\"text\" required/>\n    <label for=\"input\" class=\"im-control-label\">Textfield</label><i class=\"im-bar\"></i>\n    <div class=\"im-messages\">\n      <p>This is an error message</p>\n    </div>\n  </div>\n  <div class=\"im-form-inline\">\n    <div class=\"im-form-group\">\n      <input type=\"text\" required/>\n      <label for=\"input\" class=\"im-control-label\">Inline</label><i class=\"im-bar\"></i>\n    </div>\n    <div class=\"im-form-group\">\n      <input type=\"text\" required/>\n      <label for=\"input\" class=\"im-control-label\">Inline</label><i class=\"im-bar\"></i>\n    </div>\n  </div>\n  <div class=\"im-form-group\">\n    <textarea required></textarea>\n    <label for=\"textarea\" class=\"im-control-label\">Textarea</label><i class=\"im-bar\"></i>\n  </div>\n  <div class=\"im-checkbox\">\n    <label>\n      <input type=\"checkbox\" checked=\"checked\"/><i class=\"im-helper\"></i>I'm the label from a checkbox\n    </label>\n  </div>\n  <div class=\"im-checkbox\">\n    <label>\n      <input type=\"checkbox\"/><i class=\"im-helper\"></i>I'm the label from a checkbox\n    </label>\n  </div>\n  <div class=\"im-form-radio\">\n    <div class=\"im-radio\">\n      <label>\n        <input type=\"radio\" name=\"radio\" checked=\"checked\"/><i class=\"im-helper\"></i>I'm the label from a radio button\n      </label>\n    </div>\n    <div class=\"im-radio\">\n      <label>\n        <input type=\"radio\" name=\"radio\"/><i class=\"im-helper\"></i>I'm the label from a radio button\n      </label>\n    </div>\n  </div>\n  <div class=\"im-checkbox\">\n    <label>\n      <input type=\"checkbox\"/><i class=\"im-helper\"></i>I'm the label from a checkbox\n    </label>\n  </div>\n  <button type=\"button\" class=\"im-fab im-primary\"><i>♥</i></button>\n  <button type=\"button\" class=\"im-fab im-warn\"><i>♥</i></button>\n</form>\n*/\n\n@body-bg: #fff;\n\n// Shadows\n@shadow-inset: inset 0 2px 2px 0 rgba(0,0,0,.14);\n@shadow-0: 0 0 1px rgba(0, 0, 0, 0);\n@shadow-2: 0 2px 2px 0 rgba(0,0,0,.14),0 3px 1px -2px rgba(0,0,0,.2),0 1px 5px 0 rgba(0,0,0,.12);\n@shadow-3: 0 3px 4px 0 rgba(0,0,0,.14),0 3px 3px -2px rgba(0,0,0,.2),0 1px 8px 0 rgba(0,0,0,.12);\n@shadow-4: 0 4px 5px 0 rgba(0,0,0,.14),0 1px 10px 0 rgba(0,0,0,.12),0 2px 4px -1px rgba(0,0,0,.2);\n@shadow-6: 0 6px 10px 0 rgba(0,0,0,.14),0 1px 18px 0 rgba(0,0,0,.12),0 3px 5px -1px rgba(0,0,0,.2);\n@shadow-8: 0 8px 10px 1px rgba(0,0,0,.14),0 3px 14px 2px rgba(0,0,0,.12),0 5px 5px -3px rgba(0,0,0,.2);\n\n// Font Sizes\n@im-font-size: 1.25rem;\n@im-active-font-size: @im-font-size * 0.8;\n@im-active-top: -@im-font-size;\n\n// Margin & Paddings\n@im-gap: @im-font-size * .7;\n@im-spacer: @im-font-size / 8;\n@im-fieldset-margin: 0 0 @im-gap * 2;\n@im-checkbox-gap: @im-font-size * 2;\n@im-checkbox-top: 0;\n@im-radio-margin: @im-font-size / -4;\n\n// Colors\n@im-border-color: #999;\n@im-label-color: lighten(@im-border-color, 10%);\n@im-active-color: darken(@im-border-color, 10%);\n\n// Animation\n@im-transition-speed: 0.28s;\n\n.impac-material (@im-focus-color: #337ab7, @im-error-color: #d9534f, @im-input-color: #333) {\n  /* Flatten der Bootstrap */\n  .well, .navbar-inner, .popover, .btn, .tooltip, input, select, textarea, pre, .progress, .modal, .add-on, .alert, .table-bordered, .nav>.active>a, .dropdown-menu, .tooltip-inner, .badge, .label, .img-polaroid {\n    -moz-box-shadow: none !important;\n    -webkit-box-shadow: none !important;\n    box-shadow: none !important;\n    -webkit-border-radius: 0px !important;\n    -moz-border-radius: 0px !important;\n    border-radius: 0px !important;\n    border-collapse: collapse !important;\n    background-image: none !important;\n  }\n\n  body,\n  input,\n  select,\n  textarea {\n    box-sizing: border-box;\n\n    &::after,\n    &::before {\n      box-sizing: border-box;\n    }\n  }\n\n  input[type=number]::-webkit-inner-spin-button,\n  input[type=number]::-webkit-outer-spin-button {\n    -webkit-appearance: none;\n    margin: 0;\n  }\n\n  a:hover {\n    text-decoration: none;\n  }\n\n  // The Styles for the form\n  fieldset {\n    margin: @im-fieldset-margin;\n    padding: 0;\n    border: none;\n  }\n\n  .im-form-radio,\n  .im-form-group {\n    position: relative;\n    margin-top: (@im-gap * 1.5);\n    margin-bottom: (@im-gap * 1.5);\n  }\n\n  .im-form-inline {\n    display: flex;\n    flex-direction: row;\n    box-sizing: border-box;\n\n    > .im-form-group {\n      display: block;\n      flex: 1;\n      position: relative;\n      vertical-align: middle;\n      margin-left: (@im-gap * .2);\n      margin-right: (@im-gap * .2);\n    }\n\n    > .btn {\n      display: inline-block;\n      margin-bottom: 0;\n    }\n  }\n\n  .im-form-group {\n    input {\n      height: (@im-font-size * 1.9);\n    }\n\n    textarea {\n      resize: none;\n    }\n\n    select {\n      width: 100%;\n      font-size: @im-font-size;\n      height: (@im-font-size * 1.6);\n      padding: @im-spacer @im-spacer (@im-spacer / 2);\n      background: none;\n      border: none;\n      line-height: 1.6;\n      box-shadow: none;\n    }\n\n    .im-control-label {\n      position: absolute;\n      top: (@im-font-size / 4);\n      pointer-events: none;\n      padding-left: @im-spacer;\n      z-index: 1;\n      color: @im-label-color;\n      font-size: @im-font-size;\n      font-weight: normal;\n      transition: all @im-transition-speed ease;\n    }\n\n    .im-bar {\n      position: relative;\n      border-bottom: (@im-font-size / 16) solid @im-border-color;\n      display: block;\n\n      &::before {\n        content: '';\n        height: (@im-font-size / 8);\n        width: 0;\n        left: 50%;\n        bottom: (@im-font-size / -16);\n        position: absolute;\n        background: @im-focus-color;\n        transition: left @im-transition-speed ease, width @im-transition-speed ease;\n        z-index: 2;\n      }\n    }\n\n    input,\n    textarea {\n      display: block;\n      background: none;\n      padding: @im-spacer @im-spacer (@im-spacer / 2);\n      font-size: @im-font-size;\n      border-width: 0;\n      border-color: transparent;\n      line-height: 1.9;\n      width: 100%;\n      color: transparent;\n      transition: all @im-transition-speed ease;\n      box-shadow: none;\n    }\n\n    input[type=\"file\"] {\n      line-height: 1;\n\n      ~ .im-bar {\n        display: none;\n      }\n    }\n\n    select,\n    input:focus,\n    input:valid,\n    input.form-file,\n    input.has-value,\n    textarea:focus,\n    textarea:valid,\n    textarea.form-file,\n    textarea.has-value {\n      color: @im-input-color;\n\n      ~ .im-control-label {\n        font-size: @im-active-font-size;\n        color: @im-active-color;\n        top: @im-active-top;\n        left: 0;\n      }\n    }\n\n    select,\n    input,\n    textarea {\n      &:focus {\n        outline: none;\n\n        ~ .im-control-label {\n          color: @im-focus-color;\n        }\n\n        ~ .im-bar {\n          &::before {\n            width: 100%;\n            left: 0;\n          }\n        }\n      }\n    }\n  }\n\n  // Radio & Checkbox\n  .im-checkbox,\n  .im-form-radio {\n    label {\n      position: relative;\n      cursor: pointer;\n      padding-left: @im-checkbox-gap;\n      text-align: left;\n      color: @im-input-color;\n      display: block;\n    }\n\n    input {\n      width: auto;\n      opacity: 0.00000001;\n      position: absolute;\n      left: 0;\n    }\n  }\n\n  .im-radio {\n    margin-bottom: @im-font-size;\n\n    .im-helper {\n      position: absolute;\n      top: @im-radio-margin;\n      left: @im-radio-margin;\n      cursor: pointer;\n      display: block;\n      font-size: @im-font-size;\n      user-select: none;\n      color: @im-border-color;\n\n      // TODO: improve radio transition - ripple effect like angular md would be cool :)\n      &::before,\n      &::after {\n        content: '';\n        position: absolute;\n        left: 0;\n        top: 0;\n        margin: (@im-spacer * 2);\n        width: @im-font-size;\n        height: @im-font-size;\n        transition: transform @im-transition-speed ease;\n        border-radius: 50%;\n        border: (@im-font-size / 8) solid currentColor;\n      }\n\n      &::after {\n        transform: scale(0);\n        background-color: @im-focus-color;\n        border-color: @im-focus-color;\n      }\n    }\n\n    label:hover .im-helper {\n      color: @im-focus-color;\n    }\n\n    input:checked {\n      ~ .im-helper {\n        &::after {\n            transform: scale(0.5);\n        }\n        &::before {\n          color: @im-focus-color;\n        }\n      }\n    }\n  }\n\n  .im-checkbox {\n    margin-top: (@im-gap * 2);\n    margin-bottom: @im-font-size;\n\n    .im-helper {\n      color: @im-border-color;\n      position: absolute;\n      top: @im-checkbox-top;\n      left: 0;\n      width: @im-font-size;\n      height: @im-font-size;\n      z-index: 0;\n      border: (@im-font-size / 8) solid currentColor;\n      border-radius: (@im-font-size / 16);\n      transition: border-color @im-transition-speed ease;\n\n      &::before,\n      &::after {\n        position: absolute;\n        height: 0;\n        width: (@im-font-size * 0.2);\n        background-color: @im-focus-color;\n        display: block;\n        transform-origin: left top;\n        border-radius: (@im-font-size / 4);\n        content: '';\n        transition: opacity @im-transition-speed ease, height 0s linear @im-transition-speed;\n        opacity: 0;\n      }\n\n      &::before {\n        top: (@im-font-size * 0.65);\n        left: (@im-font-size * 0.38);\n        transform: rotate(-135deg);\n        box-shadow: 0 0 0 (@im-font-size / 16) @body-bg;\n      }\n\n      &::after {\n        top: (@im-font-size * 0.3);\n        left: 0;\n        transform: rotate(-45deg);\n      }\n    }\n\n    label:hover .im-helper {\n      color: @im-focus-color;\n    }\n\n    input:checked {\n      ~ .im-helper {\n        color: @im-focus-color;\n\n        // TODO: improve checked transition.\n        &::after,\n        &::before {\n          opacity: 1;\n          transition: height @im-transition-speed ease;\n        }\n\n        &::after {\n          height: (@im-font-size / 2);\n        }\n\n        &::before {\n          height: (@im-font-size * 1.2);\n          transition-delay: @im-transition-speed;\n        }\n      }\n    }\n  }\n\n  .im-radio + .im-radio,\n  .im-checkbox + .im-checkbox {\n    margin-top: @im-font-size;\n  }\n\n  // Add class onto ng-messages div\n  .im-messages {\n    font-size: @im-font-size / 1.2;\n    color: @im-error-color;\n    overflow: hidden;\n    transition: all @im-transition-speed cubic-bezier(.55,0,.55,.2);\n    opacity: 0;\n    margin-top: 0;\n    padding-top: 5px;\n  }\n\n  .has-error {\n    .legend.legend,\n    &.im-form-group .im-control-label.im-control-label {\n      color: @im-error-color;\n    }\n\n    &.im-form-group,\n    &.im-checkbox,\n    &.im-radio,\n    &.im-form-radio {\n      .im-messages,\n      .im-helper {\n        color: @im-error-color;\n        opacity: 1;\n      }\n    }\n\n    .im-bar {\n      &::before {\n        background: @im-error-color;\n        left: 0;\n        width: 100%;\n      }\n    }\n  }\n\n  .im-button {\n    position: relative;\n    background: lighten(@im-focus-color, 10%);\n    border: 0;\n    font-size: (@im-font-size * 1.1);\n    color: @im-input-color;\n    margin: (@im-gap * .8) 0;\n    padding: (@im-gap / 2) (@im-gap * 2);\n    border-radius: 3px;\n    cursor: pointer;\n    overflow: hidden;\n    box-shadow: @shadow-2;\n\n    span {\n      color: #fff;\n      position: relative;\n      z-index: 1;\n    }\n\n    &:hover {\n      transition: background .1s ease-in;\n      background: darken(@im-focus-color, 5%);\n    }\n\n    &:active {\n      box-shadow: @shadow-inset;\n    }\n\n    a:focus,\n    &:focus {\n      outline: none;\n      text-decoration: none;\n    }\n  }\n\n  button.im-fab {\n    position: relative;\n    height: 46px;\n    width: 46px;\n    flex: 0 0 56px;\n    display: inline-block;\n    padding: 0;\n    margin: 4px;\n    border: 0;\n    border-radius: 100%;\n    overflow: hidden;\n    font-size: 20px;\n    box-shadow: @shadow-4;\n    color: white;\n    &:focus {\n      outline: 0;\n    }\n    &:active {\n      box-shadow: @shadow-inset;\n    }\n    &.im-primary {\n      background: @im-focus-color;\n      &:hover {\n        transition: background .1s ease-in;\n        background: darken(@im-focus-color, 5%);\n      }\n    }\n    &.im-warn {\n      background: @im-error-color;\n      &:hover {\n        transition: background .1s ease-in;\n        background: darken(@im-error-color, 5%);\n      }\n    }\n  }\n\n}\n",".analytics kpis-bar > .kpis {\n  position: relative;\n  .actions {\n    margin-bottom: 12px;\n    @media screen and (max-width: 675px) {\n      position: relative;\n    }\n\n    .impac-material(@kpi-settings-focus-color, @kpi-settings-error-color);\n\n    a { color: white; }\n\n    button.im-fab.add-kpis,\n    button.im-fab.edit-kpis,\n    button.im-fab.toggle-show-content {\n      position: absolute;\n      width: 40px;\n      height: 40px;\n      font-size: 18px;\n      transition: all 0.28s ease-in;\n      &.im-primary {\n        background: #4c4749;\n        &.disabled {\n          background: #b2b5c1;\n          cursor: not-allowed;\n          a { cursor: not-allowed; }\n        }\n        &:hover:not(.disabled) {\n          background: black;\n        }\n      }\n    }\n\n    button.im-fab.toggle-show-content {\n      top: -15px;\n      right: -15px;\n      z-index: 10;\n      @media screen and (max-width: 675px) {\n        top: -30px;\n        right: -14px;\n        bottom: 0;\n      }\n    }\n\n    button.im-fab.add-kpis {\n      top: 30px;\n      right: -15px;\n      z-index: 10;\n      @media screen and (max-width: 675px) {\n        top: -30px;\n        right: 33px;\n        bottom: 0;\n      }\n    }\n\n    button.im-fab.edit-kpis {\n      top: 75px;\n      right: -15px;\n      z-index: 10;\n      &.editing {\n        background: @kpi-settings-focus-color;\n        &:hover:not(.disabled) {\n          background: lighten(@kpi-settings-focus-color, 15%);\n        }\n      }\n      @media screen and (max-width: 675px) {\n        top: -30px;\n        right: 79px;\n        bottom: 0;\n      }\n    }\n  }\n\n  .content-buttons {\n    position: absolute;\n    top: 0;\n    right: 0;\n  }\n\n  .content {\n    padding: 15px;\n    background-color: @kpis-bar-background-color;\n    box-shadow: @kpis-bar-box-shadow;\n\n    @media screen and (min-width: 725px) {\n      padding: 0 60px;\n    }\n\n    @media screen and (max-width: 675px) {\n      margin-top: 25px;\n    }\n\n    .impac-kpi {\n      .column-gutter(5px);\n\n      @media screen and (min-width: 1200px) {\n        padding-left: 20px;\n        padding-right: 20px;\n      }\n\n      .kpi.add {\n        .kpi-show .caption {\n          white-space: inherit;\n        }\n      }\n    }\n\n\n    .title {\n      .text-center {\n        line-height: 3;\n        font-variant: small-caps;\n        font-size: larger;\n      }\n      .badge {\n        position: absolute;\n        top: 8px;\n        left: -10px;\n        background-color: #d1e55c;\n        color: #4f5959;\n        box-shadow: 0px 1px 3px -1px;\n      }\n      .no-kpi-templates {\n        color: #afadb5;\n        font-weight: 500;\n      }\n    }\n\n    .add-bar {\n      border-bottom: dashed 1px;\n    }\n\n    .kpi-loader {\n      display: flex;\n      align-items: center;\n      justify-content: center;\n      min-height: @kpi-max-height + 20px;\n    }\n\n    .dates-picker-container {\n      width: 40%;\n      margin: 0 auto;\n\n      .sdp-from-label,\n      .sdp-to-label {\n        text-transform: uppercase;\n        font-weight: 400;\n      }\n    }\n  }\n}\n\n.analytics kpis-bar {\n  display: block;\n}\n\n.analytics kpis-bar > .key-stats {\n  background-color: white;\n  padding: 5px 0px;\n}\n\n.analytics.pdf-mode kpis-bar > .kpis .actions { display: none; }\n",".widget-item {\n  transition: width 0.3s;\n  padding: @impac-padding-between-widgets;\n  &.pdf-mode {\n    width: 100%;\n    padding: ~\"@{impac-padding-between-widgets} 0px\";\n  }\n}\n\n.widget-item .top-line {\n  position: relative;\n  cursor: move;\n  background-color: @impac-widget-title-bg;\n  padding: 9px 9px 0px 12px;\n  border-radius: @impac-widget-title-border-radius;\n  border: @impac-widget-border;\n  border-bottom: none;\n  min-height: 41px;\n  .box-shadow(0px 1px 8px -4px);\n\n  display: flex;\n  flex-direction: row;\n\n  z-index: 4;\n}\n\n.widget-item {\n  .content {\n    position: relative;\n    padding: 9px;\n    border-radius: @impac-widget-content-border-radius;\n    border: @impac-widget-border;\n    border-top: none;\n    background-color: @impac-widget-background-color;\n\n    vertical-align: top;\n    .box-shadow(0px 1px 8px -4px);\n    .short-widget();\n\n    .edit {\n      .edit-panel-style();\n    }\n\n    &.accessible {\n      height: auto !important;\n      min-height: 250px !important;\n      max-height: auto !important;\n    }\n\n    // Avoid content to leak out of widget's box\n    .content-template-wrapper {\n      height: 100%;\n      overflow: auto;\n      overflow-x: hidden;\n    }\n  }\n\n  &.pdf-mode .content {\n    height: 100% !important;\n    min-height: 250px !important;\n    max-height: none !important;\n    .collapse {\n      display: inherit;\n    }\n    .fa-plus-square-o:before {\n      content: \"\\f147\";\n    }\n    .legend {\n      max-height: none !important;\n    }\n    .chart-container {\n      max-height: none;\n    }\n    .widget-lines-container {\n      max-height: none !important;\n    }\n    .data-not-found .message {\n      position: inherit;\n      width: 100%;\n    }\n  }\n}\n\n.widget-item.pdf-mode .include-to-pdf{\n  &.title {\n    position: absolute;\n    width: ~\"calc(100% - 2*@{impac-padding-between-widgets} )\";\n    z-index: 3;\n    padding-right: 1px;\n    h6 {\n      padding: 10px;\n      background-color: #FFC928;\n      text-align: center;\n      margin: 0;\n    }\n  }\n  &.tick {\n    i {\n      position: absolute;\n      top: 35%;\n      left: 46%;\n      font-size: 100px;\n      opacity: .5;\n      z-index: 2;\n      color: black;\n    }\n  }\n  .widget-hover {\n    position: absolute;\n    width: 100%;\n    height: 100%;\n    padding: 9px;\n    top: 0;\n    right: 0;\n    -webkit-transition: all ease .5s;\n    -moz-transition: all ease .5s;\n    transition: all ease .5s;\n    z-index: 1;\n    &:hover {\n      opacity: .5;\n      background: #CCCFD0;\n    }\n  }\n}\n\n// Fix overflow for large sums/text in .widget-lines-container tables\n.widget-item .widget-lines-container .widget-line > [class*='col-'] {\n  overflow-wrap: break-word;\n}\n",".analytics .widget-item .content .data-not-found,\n.analytics .kpi .data-not-found {\n  text-align: center;\n  font-size: 13px;\n  color: @impac-widget-popup-message-text-color;\n\n  .overlay {\n    background-color: white;\n    position: absolute;\n    height: ~\"calc(100% - 4px)\";\n    width: ~\"calc(100% - 4px)\";\n    top: 2px;\n    left: 2px;\n    opacity: 0.6;\n    z-index: 3;\n  }\n\n  .message {\n    position: absolute;\n    top: 125px;\n    left: 50%;\n    padding-bottom: 10px;\n    transform: translate(-50%, -50%);\n    width: 85%;\n    background-color: @impac-widget-popup-message-background-color;\n    border-radius: 4px;\n    box-shadow: 0px 0px 25px 0px;\n    z-index: 4;\n\n    .title {\n      padding: 2px;\n      background-color: @impac-widget-popup-title-background-color;\n      color: @impac-widget-popup-title-text-color;\n      margin: -1px -1px 10px -1px;\n      text-transform: uppercase;\n    }\n\n    p {\n      margin-left: 5px;\n      margin-right: 5px;\n    }\n\n    .btn { margin-top: 5px; }\n  }\n\n  .example {\n    position: absolute;\n    bottom: 0px;\n    left: 0px;\n    width: 100%;\n    color: @impac-widget-popup-title-text-color;\n    background-color: @impac-widget-popup-title-background-color;\n    padding: 3px;\n    z-index: 6;\n\n    a {\n      font-weight: normal;\n      color: @impac-widget-demo-data-link-color;\n    }\n  }\n}\n\n.analytics .kpi .data-not-found {\n  .message {\n    width: 90%;\n    padding-bottom: 0px;\n    border: solid 1px silver;\n    box-shadow: none;\n    p { margin: 5px; }\n  }\n  .overlay, .title, .btn, .example { display: none; }\n}\n","#duplicate-transactions-list {\n  .top {\n    height: 40px;\n    a.back-link { font-weight: normal; }\n    .pagination { margin: 0px; }\n  }\n\n  .table-striped {\n    tr.origin:nth-of-type(odd) {\n      background-color: #f9f9f9;\n    }\n  }\n\n  .table-container {\n    max-height: ~\"calc(@{impac-big-widget-size} - 60px)\";\n    overflow: auto;\n\n    div[uib-datepicker-popup-wrap] {\n      display: inline-block;\n    }\n\n    input.btn.btn-xs { margin-top: -2px; }\n    button.btn.reset-date { margin-top: -2px; }\n    .fa.fa-times {\n      color: @brand-danger;\n      cursor: pointer;\n    }\n\n    tr.total {\n      font-weight: bold;\n      &.invoices {\n        background-color: lighten(@impac-positive, 20%);\n      }\n      &.bills {\n        background-color: lighten(@impac-negative, 20%);\n      }\n    }\n  }\n}\n","#transactions-add {\n  .widget-popup();\n  .message {\n    top: 30px;\n    left: 35%;\n    width: 30%;\n    .form {\n      padding: 0px 10px;\n      > label,\n      .schedulable-section > label {\n        padding-top: 10px;\n        font-weight: normal;\n        margin-bottom: 3px;\n      }\n      input.form-control, select.form-control {\n        width: 90%;\n        border-radius: 2px;\n        height: 28px;\n        font-size: 13px;\n      }\n      .btn-group {\n        display: block;\n        min-height: 22px;\n        select {\n          border-radius: 2px;\n          height: 28px;\n          margin-top: 0px;\n        }\n      }\n      .disable {\n        color: #888888;\n        font-style: italic;\n      }\n      .never-disable {\n        color: black;\n        font-style: normal;\n      }\n      .repeat-btn {\n        margin-top: 30px;\n        input[type=\"checkbox\"] {\n          vertical-align: text-bottom;\n          margin: 0px;\n        }\n        select { height: 22px; }\n        .btn {\n          float: none;\n          border-color: #888888;\n        }\n      }\n      .schedulable-section {\n        padding: 5px;\n        border: solid 1px silver;\n        margin-top: 0px;\n        background-color: white;\n        .badge {\n          font-weight: normal;\n          background-color: #888888;\n        }\n        .interval-field {\n          width: 40px;\n        }\n        .btn-group {\n          margin-left: 10px;\n          select { height: 22px; }\n          .btn {\n            float: none;\n            border-color: #888888;\n          }\n        }\n      }\n    }\n    .bottom {\n      margin-top: 20px;\n    }\n  }\n}\n","#transactions-list {\n  .top {\n    height: 40px;\n    position: relative;\n\n    .back { position: absolute; }\n    .resource-type {\n      position: absolute;\n      left: ~\"calc(50% - 98px)\";\n      @media (max-width: @screen-xs-max) {\n        left: unset;\n        right: 0;\n      }\n    }\n    .btn-group { display: flex; }\n  }\n\n  .bottom {\n    height: 40px;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    .pagination { margin: 0px; }\n  }\n\n  .table-container {\n    max-height: ~\"calc(@{impac-big-widget-size} - 100px)\";\n    overflow: auto;\n    width: 100%;\n\n    div[uib-datepicker-popup-wrap] {\n      display: inline-block;\n    }\n\n    input.btn.btn-xs { margin-top: -2px; }\n    button.btn.reset-date { margin-top: -2px; }\n\n    .actions {\n      cursor: pointer;\n      .fa.fa-times { color: @brand-danger; }\n    }\n\n    tr.total {\n      font-weight: bold;\n      &.invoices {\n        background-color: lighten(#8eab71, 20%);\n      }\n      &.bills {\n        background-color: lighten(#c76379, 20%);\n      }\n    }\n\n    td > .expected-payment-date {\n      display: flex;\n      .reset-date { margin-left: 3px; }\n    }\n  }\n}\n","#trends-add {\n  .widget-popup();\n  .message {\n    top: 30px;\n    left: 35%;\n    width: 30%;\n    .form {\n      padding: 0px 10px;\n      > label {\n        padding-top: 10px;\n        font-weight: normal;\n        margin-bottom: 3px;\n      }\n      input.form-control {\n        width: 90%;\n        border-radius: 2px;\n        height: 28px;\n        font-size: 13px;\n      }\n      .btn-group {\n        display: block;\n        min-height: 22px;\n        margin-top: 10px;\n        > .btn {\n          float: none;\n        }\n        input[type=\"radio\"] {\n          margin: 4px 0 10px;\n        }\n      }\n    }\n    .bottom {\n      margin-top: 20px;\n    }\n  }\n}","#trends-list {\n  .top {\n    height: 40px;\n    a.back-link { font-weight: normal; }\n    .pagination { margin: 0px; }\n  }\n\n  .table-container {\n    max-height: ~\"calc(@{impac-big-widget-size} - 60px)\";\n    overflow: auto;\n\n    div[uib-datepicker-popup-wrap] {\n      display: inline-block;\n    }\n\n    input.btn.btn-xs { margin-top: -2px; }\n    button.btn.reset-date { margin-top: -2px; }\n  }\n}\n",".analytics .dashboard-settings.currency {\n  text-align: right;\n  select {\n    margin-top: 4px;\n  }\n}\n",".analytics .dashboard-settings.sync-apps {\n  .show-status {\n    margin-right: 5px;\n    color: @impac-widget-text-color-medium;\n    &:hover {\n      cursor: pointer;\n      text-decoration: underline;\n    }\n    .fa.fa-info { margin-right: 2px; }\n  }\n  .status-btn {\n    i {\n      font-size: 16px;\n      &.fa-exclamation-triangle { color: @fluroorange; }\n      &.fa-check { color: @green; }\n    }\n    display: inline-block;\n    cursor: pointer;\n    padding: 5px 7px 5px 0px;\n  }\n\n  .popover {\n    max-width: 550px;\n    .connector {\n      padding: 4px 13px;\n      &.add-seperator { border-bottom: 1px solid #ccc; }\n    }\n    .popover-content {\n      padding: 0;\n    }\n    .popover-footer {\n      border-top: 1px solid #ccc;\n      padding: 4px 13px;\n      p {\n        font-weight: bold;\n        margin: 0;\n      }\n      &.remove-seperator { border: 0; }\n    }\n  }\n\n  .badge { float: right; margin-left: 8px; }\n  .success .badge { background-color: @green; }\n  .pending .badge { background-color: @fluroorange; }\n  .running .badge { background-color: @fluroorange; }\n  .error .badge { background-color: @pink; }\n  .failed .badge { background-color: @pink; }\n  .unknown .badge { background-color: @pink; }\n  .disconnected .badge { background-color: @pink; }\n}\n\n#sync-apps-modal {\n  .modal-header {\n    text-align: center;\n    border: 0;\n    box-shadow: 0px 2px 3px 0px #ccc;\n  }\n  .modal-list {\n    max-height: 280px;\n    overflow-y: auto;\n  }\n  .modal-list-item {\n    border-bottom: 1px solid #ccc;\n    padding: 10px;\n\n    .badge { float: right; }\n    &.success .badge { background-color: @green; }\n    &.pending .badge { background-color: @fluroorange; }\n    &.running .badge { background-color: @fluroorange; }\n    &.error .badge { background-color: @pink; }\n    &.failed .badge { background-color: @pink; }\n    &.unknown .badge { background-color: @pink; }\n    &.disconnected .badge { background-color: @pink; }\n\n    .message {\n      p { margin: 0; }\n      padding: 3px;\n      border-radius: 2px;\n      margin-left: 31px;\n      margin-top: 9px;\n    }\n\n    &.success .message { background-color: rgba(0, 255, 55, 0.08); }\n    &.pending .message { background-color: rgba(255, 118, 0, 0.08); }\n    &.running .message { background-color: rgba(255, 118, 0, 0.08); }\n    &.error .message { background-color: rgba(255, 0, 0, 0.08); }\n    &.failed .message { background-color: rgba(255, 0, 0, 0.08); }\n    &.unknown .message { background-color: rgba(255, 0, 0, 0.08); }\n    &.disconnected .message { background-color: rgba(255, 0, 0, 0.08); }\n\n    &.with-message {\n      cursor: pointer;\n      &:hover {\n        background-color: #ccc;\n      }\n    }\n  }\n  .modal-footer {\n    border: 0;\n  }\n  .fa { padding: 0px 10px; }\n  .fa.error { color: @red; }\n  .fa.warn { color: @fluroorange; }\n  .fa.success { color: @flurogreen; }\n}\n","chart-threshold {\n  .attach-panel {\n    padding: 5px 0;\n    display: flex;\n    justify-content: center;\n    align-items: baseline;\n    background-color: rgba(20, 132, 228, 0.16);\n\n    & > div {\n      padding-right: 5px;\n\n      &.target { text-align: center; }\n    }\n\n    @media (max-width: @screen-md-max) {\n      flex-direction: column;\n      align-items: center;\n      > div {\n        padding: 5px;\n      }\n    }\n\n    .text {\n      text-transform: uppercase;\n      font-weight: bold;\n      color: @impac-widget-text-color;\n      font-size: 13px;\n    }\n\n    input {\n      border-radius: 3px;\n      border: 1px white;\n      padding: 3px;\n\n      &[name=amount] {\n        max-width: 70px;\n      }\n    }\n\n    .currency {\n      font-weight: bold;\n      color: #000;\n    }\n\n    .actions {\n      display: inline-block;\n      padding: 0 2px;\n      button {\n        padding: 3px 6px;\n        display: inline-block;\n        &.loading {\n          padding: 3px 20px;\n        }\n      }\n    }\n  }\n}\n",".analytics widgets-common-confirm-modal {\n  .widget-popup();\n  .message {\n    display: flex;\n    flex-direction: column;\n    justify-content: space-between;\n\n    p { padding: 0px 10px; }\n\n    button.btn { margin-top: 20px; }\n\n    .loader i.fa.fa-spinner {\n      font-size: 26px;\n    }\n  }\n}\n",".currency-conversions {\n  img {\n    width: 15px;\n    cursor: pointer;\n  }\n\n  &.popover .popover-title {\n    background-color: black;\n    color: white;\n  }\n}\n",".analytics .widget-item .editable-title {\n  width: 100%;\n  flex: 1;\n  overflow: hidden;\n  height: 22px;\n\n  .title {\n    text-transform: @impac-widget-title-text-transform;\n    .font(@impac-widget-title-text-size,600,@impac-widget-title-text-color);\n    cursor: text;\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n    line-height: 1.9;\n  }\n\n  .editable-wrap {\n    position: relative;\n    height: 20px;\n    min-width: 100%;\n    // otherwise, white-space is overriden in mno-enterprise\n    white-space: nowrap;\n\n    .editable-controls {\n      min-width: 100%;\n\n      .editable-input {\n        height: 20px;\n        font-size: 12px;\n        text-transform: @impac-widget-title-text-transform;\n        // 65px is .editable-buttons width\n        width: ~\"calc(100% - 65px)\";\n        padding: 0px 3px;\n      }\n\n      .editable-buttons {\n        background-color: @impac-widget-title-bg;\n        button {\n          margin: 0px 0px 0px 5px;\n          height: 20px;\n          padding: 0px 5px;\n        }\n      }\n    }\n  }\n}\n",".analytics .widget-item .info-panel {\n  position: absolute;\n  top: 15px;\n  left: 15px;\n  width: ~\"calc(100% - 30px)\";\n  max-height: ~\"calc(100% - 30px)\";\n  height: 100%;\n  z-index: 100;\n\n  background-color: white;\n  border: dotted 1px #B7CDCE;\n\n  display: flex;\n  flex-direction: column;\n  font-family: \"Lato Semibold\", \"Lato\";\n\n  z-index: 4;\n\n  &:hover { opacity: 1; }\n\n  .i-header {\n    .fa { font-size: 18px; }\n    .fa-info-circle { float: left; }\n    .fa-times-circle { cursor: pointer; float: right; }\n\n    background-color: #FFC928;\n    color: @impac-widget-reverse-color;\n    padding: 8px;\n    text-transform: uppercase;\n    font-family: \"Lato Medium\", \"Lato\";\n    font-size: 12px;\n  }\n\n  .i-content {\n    .scrollable();\n    padding: 5px;\n    text-align: justify;\n    flex: 1;\n\n    .row {\n      margin-bottom: 6px;\n      padding-bottom: 6px;\n      border-bottom: solid 1px @impac-dashboard-borders-color;\n\n      &:last-child {\n        margin-bottom: 0;\n        padding-bottom: 0;\n        border-bottom: none;\n      }\n\n      .key {\n        @media (max-width: @screen-sm-max) { text-align: center; }\n        text-align: right;\n        font-variant: small-caps;\n      }\n\n      .value { text-align: justify; }\n    }\n  }\n}\n",".analytics .time-period-info {\n  font-size: 11px;\n  color: #ABC4C6;\n  text-transform: uppercase;\n}\n",".analytics .widget-item .top-line .top-buttons {\n  text-align: right;\n  margin-top: -1px;\n  white-space: nowrap;\n  padding-left: 10px;\n\n  .top-buttons-wrapper {\n    .top-button {\n      background: transparent;\n      border: none;\n      color: @impac-widget-top-buttons-color;\n      padding: 0;\n      outline: none;\n      width: 17px;\n\n      &:active, &:focus { box-shadow: none; }\n\n      &.btn-info {\n        font-size: 17px;\n        margin-top: 1px;\n        &:hover { color: #FFC928; }\n      }\n      &.btn-export {\n        font-size: 17px;\n        margin-top: 1px;\n        &:hover { color: @mblue; }\n      }\n      &.btn-refresh {\n        font-size: 17px;\n        margin-top: 1px;\n        &:hover { color: @mblue; }\n      }\n      &.btn-edit {\n        font-size: 13px;\n        &:hover, &.edit-mode { color: darken(@mgreen,10%); }\n      }\n      &.btn-close {\n        font-size: 13px;\n        &:hover { color: @pink; }\n      }\n    }\n  }\n}\n",".analytics .widget-item .content.accounts-assets-liability-summary {\n  .param-selector {\n    text-align: center;\n  }\n  .legend {\n    text-align: left;\n    max-height: 90px;\n\n    .title {\n      text-align: center;\n      border-bottom: dashed 1px @impac-widget-borders-color;\n    }\n  }\n}\n",".analytics .widget-item .content.accounts-assets-summary {\n  .legend {\n    text-align: left;\n    max-height: 115px;\n\n    .title {\n      text-align: center;\n      border-bottom: dashed 1px @impac-widget-borders-color;\n    }\n  }\n}\n",".analytics .widget-item .content.accounts-assets-vs-liabilities {\n  .legend > .title span {\n    margin-left: 3px;\n  }\n}\n",".analytics .widget-item .content.accounts-balance {\n  h3 {\n    .left-thin(30px);\n    text-align: center;\n  }\n\n  .price {\n    .center-bold(0px);\n  }\n}\n",".analytics .widget-item .content.accounts-balance-sheet {\n  .tall-widget();\n  .widget-lines-container {\n    .scrollable(scroll);\n    max-height: 490px;\n    @media (max-width: @screen-xs-max) {\n      .row.widget-line {\n        &:not(:last-child) { border-bottom: dashed 1px @impac-widget-borders-color; }\n      }\n    }\n    .row.widget-line.header > [class*='col-'] { position: static; }\n\n    &.no-scroll {\n      overflow: visible;\n    }\n  }\n\n  .no-data-block {\n    .center-thin();\n    margin: 15px 0px;\n  }\n}\n",".analytics .widget-item .content.accounts-cash-balance {\n  .tall-widget();\n\n  .data-container {\n    height: ~\"calc(@{impac-big-widget-size} - 50px)\";\n    width: 100%;\n  }\n\n  .left-panel {\n    width: 180px;\n    display: inline-block;\n    overflow: auto;\n    max-height: 100%;\n  }\n\n  #cash-balance-legend {\n    .header {\n      .group-item {\n        display: flex;\n        align-items: center;\n        min-height: 45px;\n        margin: 3px;\n        font-size: 13px;\n        padding: 3px;\n        cursor: pointer;\n        user-select: none;\n        &:hover {\n          background-color: @impac-widget-menus-hover-background-color;\n        }\n        i {\n          font-size: 19px;\n          padding: 4px;\n          margin-top: 1px\n        }\n        span { color: @impac-widget-text-color; }\n      }\n    }\n  }\n\n  .legend-item-icon {\n    width: 16px;\n    height: 16px;\n  }\n\n  .right-panel {\n    width: ~\"calc(100% - 180px)\";\n    float: right;\n\n    // Highchart container\n    .cash-balance-chart {\n      height: ~\"calc(@{impac-big-widget-size} - 50px)\";\n    }\n  }\n\n  .dates-picker {\n    display: inline-block;\n    float: right;\n    font-size: 12px;\n  }\n}\n",".analytics .widget-item .content.accounts-cash-projection {\n  .tall-widget();\n\n  .cash-projection-chart {\n    height: ~\"calc(@{impac-big-widget-size} - 50px)\";\n  }\n\n  .highcharts-legend-item {\n    rect.highcharts-point {\n      display: none;\n    }\n\n    span {\n      width: 110px;\n      text-align: center;\n      img {\n        text-align: center;\n        width: 55px;\n        height: 25px;\n      }\n    }\n  }\n\n  .dates-picker {\n    display: inline-block;\n    float: right;\n    font-size: 12px;\n  }\n\n  transactions-list {\n    font-size: 12px;\n  }\n}\n",".analytics .widget-item .content.accounts-cash-summary {\n  .drill-down-widget();\n  .right-panel .widget-lines-container {\n    max-height: 215px;\n  }\n\n  .row.lines-group.cash {\n    border-top: solid 1px;\n    border-bottom: double;\n  }\n}\n","// --- Reusable widget style mixins\n\n// Payroll-Summary - Profit-and-Loss\n.drill-down-widget () {\n  .tall-widget();\n\n  .widget-lines-container {\n    max-height: 540px;\n    .lines-group .widget-line {\n      .selectable();\n    }\n  }\n\n  .right-panel {\n    .widget-lines-container {\n      .scrollable(auto);\n      max-height: 235px;\n    }\n  }\n\n  .no-element {\n    .center-thin();\n  }\n}\n\n// Top customers summary - Sales cycle...\n.simple-summary-widget() {\n  .chart-container {\n    max-width: 410px;\n  }\n  .legend {\n    max-height: 28px;\n  }\n}\n\n// Invoices list - sales list\n.simple-list-widget() {\n  .widget-lines-container {\n    max-height: 230px;\n    .widget-line {\n      .alternate-bg();\n      &.header {\n        background-color: @impac-widget-background-color;\n      }\n    }\n  }\n}\n\n// Workforce-Summary - Salaries-Summary\n.expandable-filterable-widget() {\n  h3.left {\n    @media (min-width: @screen-md-min) { margin-top: 69px; }\n    text-align: center;\n  }\n  h3.reduced-left {\n    @media (min-width: @screen-md-min) { margin-top: 10px; }\n    text-align: center;\n  }\n  h3.right {\n    margin-bottom: 10px;\n    text-align: center;\n  }\n  .price {\n    margin-top: 0;\n  }\n  .widget-lines-container {\n    max-height: 75px;\n    .widget-line {\n      font-size: 11px;\n    }\n  }\n  .right-panel .chart-container {\n    @media (min-width: @screen-xs-min) and (max-width: @screen-sm-max) { max-width: 320px; }\n  }\n}\n\n// Leads funnel - Opportunities funnel\n.funnel-widget() {\n  .tall-widget();\n  .funnel-container {\n    width: 95%;\n    margin: auto;\n    margin-top: 15px;\n    padding-right: 10px;\n    max-height: @impac-big-widget-size - 60px;\n    overflow: auto;\n  }\n  .right-panel {\n    .widget-lines-container {\n      max-height: @impac-big-widget-size - 20px;\n      margin-right: 10px;\n      .widget-line {\n        cursor: default;\n      }\n    }\n  }\n}\n",".analytics .widget-item .content.accounts-class-comparison {\n  .param-selector {\n    text-align: center;\n  }\n  .widget-lines-container {\n    max-height: 94px;\n    color: #626d6d;\n  }\n}\n",".analytics .widget-item .content.accounts-comparison {\n  .tall-widget();\n\n  .chart-container {\n    @media print { max-width: 80% !important; }\n  }\n\n  .add-account {\n    position: absolute;\n    right: 40px;\n    bottom: 30px;\n    width: 160px;\n    select {\n      font-size: 13px;\n      background-color: @impac-widget-link-color;\n      color: @impac-widget-background-color;\n      outline: none;\n      border: none;\n      cursor: pointer;\n      &[disabled] {\n        cursor: not-allowed;\n        background-color: lighten(@impac-widget-link-color,10%);\n        &:hover {\n          background-color: lighten(@impac-widget-link-color,10%);\n        }\n      }\n      &:hover {\n        background-color: darken(@impac-widget-link-color,10%);\n      }\n      option {\n        background-color: @impac-widget-background-color;\n        color: lighten(@impac-widget-text-color,40%);\n        &[disabled] {\n          color: @impac-widget-background-color;\n        }\n      }\n    }\n  }\n  button.close {\n    font-size: 15px;\n  }\n  .legend {\n    text-align: left;\n    max-height: 103px;\n  }\n  .row {\n    margin: 0;\n  }\n  .widget-lines-container {\n    font-size: 11px;\n    max-height: @impac-widget-accounts-comparison-lines-container-max-height;\n    margin-bottom: 65px;\n    overflow: auto;\n  }\n\n  .settings.params-checkboxes {\n    margin-left: 13px;\n  }\n\n  .comparable-error h5 {\n    margin-left: 13px;\n    color: @impac-negative;\n  }\n}\n",".analytics .widget-item .content.accounts-custom-calculation {\n  h3 {\n    margin-top: 85px;\n    text-align: center;\n    font-weight: bold;\n  }\n  .legend { max-height: 125px; }\n}\n\n.analytics.modal-custom-calculation {\n  margin: 0px;\n  padding: 0px;\n}\n\n.analytics.modal-custom-calculation .modal-body {\n  .edit {\n    .edit-panel-style();\n    padding: 5px;\n    overflow: visible;\n  }\n}\n",".analytics .widget-item .content.accounts-detailed-classifications {\n  .tall-widget();\n  .widget-lines-container {\n    .scrollable(scroll);\n    max-height: 540px;\n  }\n\n  .account-class-title {\n    margin-bottom: 8px;\n    margin-left: 11px;\n  }\n\n  .time-period-info {\n    text-align: right;\n  }\n\n  .widget-line.header.sorting  {\n    border-bottom: 1px solid #ccc;\n  }\n}\n\n\n",".analytics .widget-item .content.accounts-expense-weight {\n  .legend {\n    text-align: left;\n    max-height: 115px;\n\n    .title {\n      text-align: center;\n    }\n  }\n}\n",".analytics .widget-item .content.accounts-expenses-revenue {\n  .legend {\n    font-weight: bold;\n  }\n\n  .settings.params-checkboxes {\n    font-size: 12px;\n    margin-left: 0px;\n    text-align: center;\n  }\n}\n",".analytics .widget-item .content.accounts-invoices-list {\n  // component specific styles\n  // -------------------------\n  .tall-widget();\n\n  transactions-list {\n    font-size: 12px;\n  }\n\n}\n",".analytics .widget-item .content.accounts-live-balance {\n  h3 {\n    .center-bold(0px);\n    font-size: 18px;\n    text-align: center;\n    text-shadow: 1px;\n  }\n\n  .statement-title {\n    font-size: 13px;\n    font-weight: 400;\n  }\n\n  .balance-title {\n    font-size: 12px;\n  }\n\n  .currency-centered {\n    .center-small()\n  }\n\n  .headers {\n    text-align: center;\n  }\n\n  .spacer {\n    min-height: 30px;\n  }\n\n  .price {\n    .center-bold(0px);\n  }\n\n  .come-back-later {\n    text-align: center;\n    font-size: 11px;\n    opacity: 0.8;\n  }\n\n  .negative2 {\n    font-size: 14px;\n  }\n}\n",".analytics .widget-item .content.accounts-payable-receivable {\n  h3 {\n    text-align: center;\n  }\n  .legend {\n    font-weight: bold;\n  }\n  .payable {\n    margin-top: 15px;\n  }\n  .price {\n    .center-bold(0px);\n  }\n}",".analytics .widget-item .content.accounts-profit-and-loss {\n  .drill-down-widget();\n\n  .row.lines-group.profit {\n    border-top: solid 1px;\n    border-bottom: double;\n  }\n\n  .right-panel .widget-lines-container {\n    max-height: 215px;\n  }\n\n  .row.widget-line.header > [class*='col-'] { position: static; }\n}\n",".analytics .widget-item .content.accounts-ratios {\n  \n  .left-panel {\n    max-height: 230px;\n    overflow-y: auto; \n\n    .separator {\n      border-bottom: solid 1px @impac-widget-text-color;\n      width: 75%;\n    }\n    .member {\n      padding-top: 20px;\n      padding-bottom: 20px;\n    }\n    .member .price {\n      margin-top: 0px;\n      font-size: 18px;\n    }\n    button { outline: none; }\n  }\n\n  .left-panel.simulation {\n    .member {\n      padding-top: 5px;\n      .legend { display: none; }\n      .price { text-align: right; }\n    }\n    .separator { width: 100%; }\n  }\n}\n",".analytics .widget-item .content.hr-employee-details {\n  font-size: 12px;\n  .details-container {\n    padding: 0px;\n    max-height: none;\n    @media (min-width: @screen-md-min) { max-height: 200px; }\n    .scrollable();\n  }\n  .right-panel {\n    .details-container {\n      @media (min-width: @screen-md-min) { max-height: 220px; }\n    }\n    .legend {\n      margin-bottom: 5px;\n    }\n  }\n  .title {\n    text-align: center;\n    margin-bottom: 10px;\n    font-size: 14px;\n  }\n}\n",".analytics .widget-item .content.hr-employees-list {\n  .legend {\n    margin-bottom: 9px;\n  }\n  .widget-lines-container {\n    text-align: center;\n    .widget-line {\n      .alternate-bg();\n    }\n  }\n  .edit {\n    .widget-lines-container {\n      text-align: left;\n    }\n  }\n}",".analytics .widget-item .content.hr-leaves-balance{\n  .employee-name {\n    text-align: center;\n  }\n  .balance {\n    .center-bold(0px);\n  }\n  h3 {\n    margin-top: 33px;\n    text-align: center;\n  }\n}",".analytics .widget-item .content.hr-leaves-schedule{\n  .fc-button {\n    height: 22px;\n    font-size: 12px;\n    color: @impac-widget-buttons-color;\n    background: white;\n    outline: none;\n    &:hover {\n      color: white;\n      background: @impac-widget-buttons-color;\n    }\n  }\n  .fc-toolbar {\n    margin-bottom: 5px;\n  }\n  .fc-day-grid,.fc-widget-header {\n    font-size: 12px;\n    color: @impac-widget-text-color;\n  }\n}",".analytics .widget-item .content.hr-payroll-summary {\n  .drill-down-widget();\n  .right-panel .widget-lines-container {\n      max-height: 145px;\n  }\n}\n",".analytics .widget-item {\n  .content.hr-salaries-summary {\n    .expandable-filterable-widget();\n  }\n}\n",".analytics .widget-item .content.hr-superannuation-accruals {\n  h3 {\n    margin-top: 63px;\n    text-align: center;\n  }\n  .legend {\n    margin-top: 23px;\n  }\n  .currency {\n    font-size: 14px;\n  }\n  .price {\n    .center-bold(0px);\n  }\n}",".analytics .widget-item .content.hr-timesheets {\n  .currency {\n    font-size: 14px;\n  }\n  .widget-lines-container {\n    max-height: 210px;\n  }\n}",".analytics .widget-item  {\n  .content.hr-workforce-summary {\n    .expandable-filterable-widget();\n  }\n}\n",".analytics .widget-item .content.invoices-aged-payables-receivables {\n  .drill-down-widget();\n\n  .right-panel .widget-lines-container {\n    max-height: 215px;\n  }\n\n  .row.astericks-info {\n    margin-top: 15px;\n  }\n\n  .currency-conversions {\n    float: right;\n    margin-left: 3px;\n  }\n}\n",".analytics .widget-item .content.invoices-list {\n  .simple-list-widget();\n\n  .currency-conversions {\n    float: right;\n    margin-right: 3px;\n    margin-top: -2px;\n  }\n\n  .fa.fa-info-circle {\n    float: right;\n    font-size: 15px;\n  }\n\n  .right-column {\n    padding-left: 0px;\n    padding-right: 0px;\n  }\n}\n",".analytics .widget-item .content.invoices-summary {\n  .simple-summary-widget();\n}",".analytics .widget-item .content.sales-aged {\n  .tall-widget();\n\n  .widget-lines-container {\n    max-height: 238px;\n  }\n}\n",".analytics .widget-item .content.sales-break-even {\n  .price {\n    .center-bold(0px);\n  }\n  .block {\n    margin: 5px;\n    padding: 0px 10px 5px 10px;\n    text-align: left;\n    box-shadow: 0px 7px 10px -7px #17262d;\n    font-size: 12px;\n    form.editable-wrap .editable-controls input {\n      margin-top: 5px;\n      width: 100px;\n    }\n    &.to-date {\n      background-color: @impac-widget-sub-bg-color;\n      color: @impac-widget-text-color;\n    }\n    &.to-breakeven {\n      margin-top: 10px;\n      background-color: @impac-widget-sales-break-even-bg;\n      color: @impac-widget-sales-break-even-text-color;\n      .title {\n        border-bottom: solid 1px lighten(@impac-widget-sales-break-even-bg, 10%);\n      }\n      .define-text {\n        .center-thin();\n        padding-top: 5px;\n        color: @impac-widget-sales-break-even-text-color;\n      }\n      .price {\n        color: @impac-widget-sales-break-even-text-color;\n      }\n    }\n\n    .title {\n      font-size: 13px;\n      text-align: center;\n      font-variant: small-caps;\n      border-bottom: solid 1px @lightgray;\n      font-weight: 300;\n    }\n  }\n}",".analytics .widget-item .content.sales-comparison {\n  .drill-down-widget();\n  .widget-lines-container {\n    max-height: 530px;\n  }\n  .right-panel .widget-lines-container {\n    max-height: 250px;\n  }\n  .currency-conversions {\n    img { margin-top: -2px; }\n  }\n}\n",".analytics .widget-item .content.sales-customer-details {\n  .loader {\n    font-size: 14px;\n  }\n  font-size: 12px;\n  .details-container {\n    padding: 0px;\n    @media (min-width: @screen-md-min) { max-height: 194px; }\n    overflow-y: auto;\n    overflow-x: hidden;\n  }\n  .right-panel {\n    .details-container {\n      @media (min-width: @screen-md-min) { max-height: 230px; }\n    }\n    .legend {\n      margin-bottom: 5px;\n    }\n  }\n  .row.title {\n    text-align: center;\n    margin-bottom: 10px;\n    font-size: 14px;\n  }\n\n  .currency-conversions {\n    float: left;\n    margin-right: 3px;\n  }\n}\n",".analytics .widget-item .content.sales-cycle {\n  .simple-summary-widget();\n}",".analytics .widget-item .content.sales-forecast {\n  .tall-widget();\n  .widget-lines-container {\n    max-height: 275px;\n    .widget-line.main {\n      .selectable();\n    }\n  }\n}\n",".analytics .widget-item .content.sales-growth {\n  .price {\n    .center-bold(0px);\n  }\n  .legend {\n    max-height: 49px;\n    font-size: 14px;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n  }\n}\n",".analytics .widget-item .content.sales-leads-funnel {\n  .funnel-widget();\n}\n",".analytics .widget-item .content.sales-leads-list {\n  .simple-list-widget();\n  .widget-lines-container {\n    .scrollable(scroll);\n  }\n}",".analytics .widget-item .content.sales-list {\n  .simple-list-widget();\n  .widget-lines-container {\n    .scrollable(scroll);\n    max-height: 170px;\n    &.no-scroll {\n      overflow: visible;\n    }\n  }\n  .selector {\n    margin-bottom: 4px;\n  }\n  .currency-conversions {\n    img { margin-top: -2px; }\n  }\n}\n",".analytics .widget-item .content.sales-net-sales {\n  .value-container, .operator {\n    // float: left;\n    // text-align: center;\n    line-height: 85px;\n  }\n\n  // .value-container {\n  //   width: 26%;\n  // }\n\n  .value-container .title {\n    line-height: 20px;\n    font-size: 1.2em;\n    padding: 10px 0px;\n  }\n\n  .value-container .value-box {\n    font-size: 1.3em;\n    border-radius: 10px;\n    // border: solid 1px #E4E4E4;\n    // box-shadow: 1px 1px 1px #C5C5C5;\n    border-top: solid 1px #C4CACA;\n    border-bottom: solid 1px #C4CACA;\n    white-space: nowrap;\n  }\n\n  .operator {\n    // @media (min-width: @screen-md-min) { padding-top: 38px; }\n    padding-top: 38px;\n    // width: 10%;\n    font-size: 1.3em;\n  }\n\n  .values {\n    @media (min-width: @screen-md-min) { margin-top: 25px; }\n  }\n}\n",".analytics .widget-item .content.sales-new-vs-existing-customers {\n\n  .selector .selector-wrap {\n    display: inline-block;\n    margin: 0 5px;\n  }\n  .chart-container {\n    margin-top: 15px;\n  }\n\n  .legend {\n    margin-top: 5px;\n    font-weight: bold;\n    max-height: 77px !important;\n\n    .row { margin: 0px -5px; &>div { padding: 0px 5px; }}\n\n    .total {\n      color: #5B6667;\n      font-size: 14px;\n    }\n  }\n}\n",".analytics .widget-item .content.sales-number-of-leads {\n  .stats {\n    margin-top: 35px;\n    font-size: 18px;\n    .stat {\n      margin: 15px 0px 10px 0px;\n      border-bottom: solid 1px @lightgray;\n      span.title {\n        font-weight: bold;\n      }\n      span.nominal {\n        float: right;\n        text-align: right;\n        font-weight: 300;\n      }\n      span.variation {\n        float: right;\n        width: 50px;\n        text-align: right;\n        font-style: italic;\n        font-size: 14px;\n        font-weight: 300;\n        margin-top: 2px;\n      }\n    }\n  }\n}",".analytics .widget-item .content.sales-opportunities-funnel {\n  .funnel-widget();\n}\n",".analytics .widget-item .content.sales-performance {\n  .drill-down-widget();\n  .right-panel .widget-lines-container {\n  \t max-height: 215px;\n    .widget-line.header {\n      .selectable();\n    }\n  }\n}\n",".analytics .widget-item .content.sales-segmented-turnover {\n  h3.right {\n    margin-top: 55px;\n    text-align: center;\n  }\n  .selector {\n    margin-bottom: 10px;\n  }\n  .analysis {\n    .center-bold(0px);\n  }\n  .widget-lines-container {\n    max-height: 75px;\n    .widget-line {\n      font-size: 11px;\n    }\n  }\n\n  .right-panel {\n    h3 {\n      margin: 15px 10px 5px 10px;\n      text-align: center;\n    }\n\n    .fa.fa-info-circle { float: left; }\n  }\n}\n",".analytics .widget-item .content.sales-summary {\n  .simple-summary-widget();\n  .selector {\n    margin-bottom: 5px;\n  }\n}",".analytics .widget-item .content.sales-top-customers {\n  .selector {\n    border-bottom: dashed 1px #E6E6E6;\n    padding-bottom: 3px;\n    a { font-weight: normal; }\n    .param-selector { display: inline-block; }\n  }\n  .widget-lines-container {\n    max-height: 235px;\n    .widget-line.sub-line { background-color: @impac-widget-sub-bg-color; }\n\n    // Will allow the params selectors to be displayed on top of the container (without being cut on the right)\n    .row > [class*='col-'] { position: static; }\n  }\n  .currency-conversions {\n    img { margin-top: -2px; }\n  }\n}\n",".analytics .widget-item .content.sales-top-opportunities {\n  .opps-container {\n    max-height: 195px;\n    margin-top: 10px;\n    padding-right: 10px;\n    .scrollable();\n    .tile {\n      height: 40px;\n      font-size: 13px;\n      font-weight: 300;\n      .colored-area {\n        width: 10%;\n        text-align: center;\n        font-size: 20px;\n      }\n      .main-text {\n        color: @impac-widget-text-color;\n        padding: 3px 0px 0px 10px;\n      }\n      &.first {\n        height: 55px;\n        font-size: 15px;\n        font-weight: bold;\n        .colored-area {\n          font-size: 26px;\n          padding-top: 10px;\n          background-color: rgb(255, 110, 65);\n        }\n        .main-text {\n          padding-top: 8px;\n        }\n      }\n      &.second {\n        height: 55px;\n        font-size: 15px;\n        font-weight: 500;\n        .colored-area {\n          font-size: 26px;\n          padding-top: 10px;\n          background-color: #1de9b6;\n        }\n        .main-text {\n          padding-top: 8px;\n        }\n      }\n    }\n  }\n}",".analytics .widget-item .content .settings.select-account {\n  padding: 0px 5px;\n}",".analytics .settings.accounting-behaviour {\n\n  .btn.btn-primary {\n    background-color: lighten(@impac-widget-link-color, 10%);\n    border: solid 1px @impac-widget-link-color;\n    &.focus, &.active { background-color: @impac-widget-link-color; }\n  }\n\n}\n",".analytics .settings.attach-kpis {\n  .attach-kpi {\n    padding: 8px 5px;\n\n    form .row {\n      padding-bottom: 5px;\n    }\n\n    .attach-kpi-form {\n      background-color: white;\n      border: 1px solid #ddd;\n      padding: 5px;\n    }\n\n    form .row.kpi-description {\n      padding: 10px 2px;\n      span {\n        display: block;\n        font-weight: bold;\n        font-size: 13px;\n      }\n    }\n\n    form.attach-kpi-form {\n      input.attach-target {\n        background-color: white;\n        height: inherit;\n      }\n    }\n\n    .error-messages {\n      color: @brand-danger;\n      width: 120px;\n    }\n  }\n\n  .attached-kpis {\n    padding: 5px;\n  }\n\n  .list-group-item.attached-kpi {\n    padding: 5px 10px;\n\n    .attached-kpi-name {\n      overflow: hidden;\n      width: 75%;\n      display: inline-block;\n      white-space: nowrap;\n      text-overflow: ellipsis;\n      margin-top: 3px;\n      font-size: 13px;\n      font-weight: bold;\n    }\n\n    .actions {\n      padding-top: 2px;\n      .alerts-config {\n        display: inline-block;\n        text-align: left;\n        padding-left: 4px;\n        height: 20px;\n        border-radius: 40px;\n        width: 21px;\n        color: @mblue;\n        background-color: white;\n        border: solid 1px @mblue;\n\n        &:hover { cursor: pointer; }\n      }\n      .edit-attached-kpi {\n        display: inline-block;\n        i {\n          border-radius: 10px;\n          width: 21px;\n          color: @mblue;\n          background-color: white;\n          height: 20px;\n          padding: 3px 5px 5px 5px;\n          border: solid 1px @mblue;\n          &:hover { cursor: pointer; }\n        }\n      }\n      .remove-attached-kpi {\n        display: inline-block;\n        i {\n          border-radius: 10px;\n          width: 21px;\n          color: @brand-danger;\n          background-color: white;\n          height: 20px;\n          padding: 3px 5px 5px 5px;\n          border: solid 1px @brand-danger;\n          &:hover { cursor: pointer; }\n        }\n      }\n    }\n  }\n}\n",".analytics .widget-item .content .settings.select-account {\n  padding: 0px 5px;\n}",".analytics .widget-item .content .settings.chart-filters {\n  .row {\n    margin: 0px;\n  }\n  input[type=\"radio\"] {\n    margin: 0;\n    margin-right: 3px;\n    padding: 0;\n    width: 13px;\n    height: 13px;\n    vertical-align: middle;\n    position: relative;\n    top: -1px;\n    outline: none;\n  }\n  input[type=\"range\"] {\n    height: auto;\n    width: 100%;\n  }\n}\n",".analytics .settings.dates-picker {\n  h5 { display: none; }\n\n  button.btn.btn-sm {\n    line-height: 1;\n    &.date-button { margin: 0px 5px; }\n    &.btn-danger { display: none; }\n    &.btn-info { border-radius: 3px; }\n  }\n\n  .tooltip-inner { text-transform: none; }\n\n  .dropdown-menu > li > div > table { outline: none; }\n}\n",".analytics .settings.forecast-payroll {\n  .widget-lines-container {\n    .widget-line {\n      padding: 5px 10px 5px 18px;\n      .alternate-bg(#f3f4f4);\n      .fa {\n        float: right;\n        font-size: 20px;\n        cursor: pointer;\n        &.fa-toggle-on {\n          color: @impac-widget-link-color;\n        }\n        &.fa-toggle-off {\n          color: @impac-widget-text-color-medium;\n        }\n      }\n    }\n  }\n}\n",".analytics .widget-item .content .settings.hist-mode-choser {\n  max-height: 70px;\n\n  [common-time-period-info] {\n    padding-bottom: 8px;\n  }\n\n  .options {\n    width: 150px;\n    margin: auto;\n    padding-bottom: 8px;\n    border-bottom: solid 1px #e6e6e6;\n    .font(@impac-widget-hist-text-size,500,@impac-widget-hist-text-color);\n    a {\n      .font(@impac-widget-hist-text-size,500,@impac-widget-hist-text-color);\n      text-transform: @impac-widget-hist-text-transform;\n      &.active {\n        color: @impac-widget-link-color;\n      }\n    }\n  }\n  .arrow-container {\n    width: 28px;\n    height: 28px;\n    position: relative;\n    top: -14px;\n    margin: auto;\n    &.right {\n      left: 46px;\n    }\n    &.left {\n      left: -30px;\n    }\n    .arrow-border {\n      border-top: 14px solid #e6e6e6;\n      border-left: 14px solid transparent;\n      border-right: 14px solid transparent;\n      width: 0px;\n      height: 0px;\n    }\n    .arrow {\n      border-top: 14px solid @impac-widget-background-color;\n      border-left: 14px solid transparent;\n      border-right: 14px solid transparent;\n      position: relative;\n      top: 12px;\n      width: 0px;\n      height: 0px;\n    }\n  }\n}\n",".analytics .settings.limit-entries {\n  color: @impac-widget-limit-entries-color;\n  text-transform: uppercase;\n  text-align: center;\n  border-bottom: dashed 1px #E6E6E6;\n  padding-bottom: 8px;\n\n  a.option {\n    &.badge {\n      color: white;\n      background-color: @impac-widget-limit-entries-color;\n    }\n  }\n\n}\n",".analytics .settings.offsets {\n  .offset-value {\n    font-style: italic;\n    font-size: 13px;\n  }\n\n  .offset-value .fa-trash-o {\n    &:hover {\n      color: @brand-danger;\n      cursor: pointer;\n    }\n    margin-left: 10px;\n  }\n\n  input { width: 75%; }\n  button { width: 30px; }\n}\n",".analytics .settings.organizations {\n  .widget-lines-container {\n    .widget-line {\n      padding: 5px 10px 5px 18px;\n      .alternate-bg(#f3f4f4);\n      .fa {\n        float: right;\n        font-size: 20px;\n        cursor: pointer;\n        &.fa-toggle-on, &.fa-check-circle {\n          color: @impac-widget-link-color;\n        }\n        &.fa-toggle-off, &.fa-circle-thin {\n          color: @impac-widget-text-color-medium;\n        }\n      }\n    }\n  }\n}\n",".analytics .widget-item .content .settings.param-selector {\n  display: inline-block;\n\n  &.classic {\n    width: 100%;\n\n    select {\n      width: 100%;\n      height: 25px;\n      border: 1px solid #ccc;\n      text-transform: uppercase;\n      margin: 0px 0px 5px 0px;\n    }\n  }\n\n  a {\n    font-weight: normal;\n    color: @impac-widget-param-selector-color;\n    white-space: nowrap;\n  }\n  .options-container {\n    position: absolute;\n    background-color: white;\n    text-align: left;\n    min-width: 150px;\n    max-height: 200px;\n    z-index: 999;\n    overflow-y: auto;\n    overflow-x: hidden;\n    .box-shadow(rgb(0, 0, 0) 0px 3px 15px -3px);\n\n    .param-selector-label {\n      padding: 3px 5px;\n      .font(inherit,500,black);\n      cursor: text;\n      overflow: hidden;\n      white-space: nowrap;\n      text-overflow: ellipsis;\n      line-height: 1.9;\n    }\n    .param-selector-label:hover {\n      cursor: pointer;\n      background-color: @impac-widget-param-selector-color;\n      color: white;\n    }\n\n    &::-webkit-scrollbar {\n      width: 8px;\n      background-color: darken(@lightgray,5%);\n    }\n\n    &::-webkit-scrollbar-thumb {\n      background-color: @impac-widget-param-selector-color;\n      &:hover {\n        background-color: lighten(@impac-widget-param-selector-color,5%);\n      }\n    }\n  }\n}\n",".analytics .settings.params-checkboxes {\n  padding: 2px 0px;\n  input {\n    margin: 0;\n    height: inherit;\n  }\n  span {\n    margin-left: 5px;\n  }\n  label {\n    display: flex;\n    justify-content: center;\n    line-height: 14px;\n  }\n}\n",".analytics .widget-item .content .settings.params-picker {\n  padding: 0px 10px;\n  .parameter {\n    margin: 0px 3px 3px 0px;\n    padding: 3px 5px;\n    background-color: @impac-widget-params-picker-bg;\n    color: white;\n    border: solid 1px @impac-widget-params-picker-bg;\n    border-radius: 4px;\n    cursor: move;\n    font-weight: bold;\n    white-space: nowrap;\n    float: left;\n    input[type=\"checkbox\"] {\n      margin: 0px -3px 0px 3px;\n      vertical-align: middle;\n      height: inherit;\n      outline: none;\n      cursor: pointer;\n    }\n    .badge {\n      margin-right: 3px;\n      font-size: 10px;\n      background-color: darken(@impac-widget-background-color, 5%);\n      color: @impac-widget-params-picker-bg;\n      padding: 2px 6px;\n    }\n\n    &.unchecked {\n      background-color: inherit;\n      font-weight: normal;\n      color: inherit;\n      border-color: @impac-widget-params-picker-unchecked-bg;\n      .badge {\n        background-color: @impac-widget-params-picker-unchecked-bg;\n        color: white;\n      }\n    }\n  }\n}",".analytics .settings.tag-filter {\n  padding: 0px 5px;\n\n  .btn.btn-default {\n    height: 32px;\n    width: 30px;\n  }\n\n  .tag-lines-container {\n    padding: 0px 10px;\n\n    .tag-line {\n      display: flex;\n      align-items: center;\n      justify-content: flex-end;\n\n      .tags-col { position: static; }\n\n      tags-input {\n        .tags {\n          display: flex;\n          border-radius: 4px;\n          border: solid 1px #ccc;\n          .tag-item {\n            background: #79a2bb;\n            border-radius: 4px;\n            color: white;\n          }\n        }\n      }\n\n      .host { position: static; }\n    }\n  }\n}\n",".analytics .settings.time-period {\n  padding: 0px 5px;\n\n  select {\n    height: 22px;\n    width: 100%;\n  }\n  \n  & > .row {\n    margin: 0px -5px 7px -5px;\n    & > div {\n      padding: 0px 5px;\n      position: static;\n    }\n\n    .sub-setting { padding: 5px; }\n  }\n}\n",".analytics .widget-item .content .settings.width {\n  float: right;\n  font-size: 14px;\n  i {\n    color: silver;\n    cursor: pointer;\n    &.reduce {\n      margin-right: -10px;\n    }\n    &.expand {\n      margin-right: -3px;\n    }\n  }\n}"]} */ diff --git a/dist/impac-angular.js b/dist/impac-angular.js index 29e8fc4a..6ecc92c2 100644 --- a/dist/impac-angular.js +++ b/dist/impac-angular.js @@ -1,6 +1,6 @@ /** * impac-angular - Impac! Front-End Library - * @version v1.7.5 + * @version v1.7.6 * @git git://github.com/maestrano/impac-angular.git * @license Copyright 2017 Maestrano Pty Ltd */ @@ -217,8 +217,8 @@ $templateCache.put("common/data-not-found.tmpl.html","
\n
\n
\n \n
\n
\n
\n \n \n
\n
\n
\n
    \n
\n
\n
\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n
#CodeTitleStatusTransaction dateDue dateExpected payment dateAmountShall we reconcile?
{{ $index + 1 }}{{ dupTrx.transaction_number }}{{ dupTrx.title }}{{ dupTrx.status }}{{ dupTrx.trxDateUTC }}{{ dupTrx.dueDateUTC }}{{ dupTrx.expectedPaymentDateUTC }}{{ dupTrx.amount | mnoCurrency : dupTrx.currency }}\n \n \n
{{ dupTrx.reconciliation_target.transaction_number }}{{ dupTrx.reconciliation_target.title }}{{ dupTrx.reconciliation_target.status }}{{ dupTrx.reconciliation_target.trxDateUTC }}{{ dupTrx.reconciliation_target.dueDateUTC }}{{ dupTrx.reconciliation_target.expectedPaymentDateUTC }}{{ dupTrx.reconciliation_target.amount | mnoCurrency : dupTrx.reconciliation_target.currency }}
\n
\n
\n"); $templateCache.put("common/transactions-add.tmpl.html","
\n
\n
\n
Create schedule for transaction
\n
Create a manual transaction
\n\n
\n \n \n\n \n \n\n \n \n\n
\n \n
\n \n
\n
\n\n
\n \n \n
\n \n \n
\n
\n\n
\n \n
\n
\n
\n
\n \n \n
\n
\n\n \n
\n
\n \n \n
\n
\n \n \n
\n
\n \n \n
\n
\n
\n
\n\n
\n \n \n
\n
\n
\n"); $templateCache.put("common/transactions-list.tmpl.html","
\n
\n
\n \n
\n
\n
\n \n \n
\n
\n
\n
\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n
{{ $ctrl.currentAttributes.resourcesType == \'invoices\' ? \'Customer\' : \'Supplier\' }}CodeTitleStatusTransaction dateDue dateExpected payment dateAmountBalance\n
{{ trx.contact_name }}{{ trx.transaction_number }}{{ trx.title }}{{ trx.status }}{{ trx.trxDateUTC }}{{ trx.dueDateUTC }}\n
\n \n \n
\n
{{ trx.amount | mnoCurrency : trx.currency }}{{ trx.balance | mnoCurrency : trx.currency }}\n \n \n \n
TOTAL{{ $ctrl.totalAmount | mnoCurrency : $ctrl.currency }}{{ $ctrl.totalBalance | mnoCurrency : $ctrl.currency }}
\n
\n\n \n \n \n impac.widget.common.confirm-modal.delete_schedule.title\n \n \n

impac.widget.common.confirm-modal.delete_schedule.message

\n

impac.widget.common.confirm-modal.delete_schedule.explanation

\n
\n
\n\n \n \n \n impac.widget.common.confirm-modal.delete_trx.title\n \n \n

\n
\n
\n\n \n\n
\n
\n
    \n
\n
\n
\n"); -$templateCache.put("common/trends-list.tmpl.html","
\n
\n
\n \n
\n
\n
    \n
\n
\n
\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n
NameRatePeriodicityStart DateLast apply date\n \n
{{trend.name}}\n \n {{trend.rate}}%\n %\n {{trend.period}}\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n
\n
\n
\n"); $templateCache.put("common/trends-add.tmpl.html","
\n
\n
\n
Add data from historical trend
\n\n
\n
\n %
\n\n
\n \n\n
\n \n\n
\n Forever
\n For {{$ctrl.period()}}
\n Until \n
\n\n
\n \n
\n\n
\n \n \n
\n
\n
\n"); +$templateCache.put("common/trends-list.tmpl.html","
\n
\n
\n \n
\n
\n
    \n
\n
\n
\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n
NameRatePeriodicityStart DateLast apply date\n \n
{{trend.name}}\n \n {{trend.rate}}%\n %\n {{trend.period}}\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n
\n
\n
\n"); $templateCache.put("dashboard-settings/currency.tmpl.html","
\n \n
\n"); $templateCache.put("dashboard-settings/pdf-mode.tmpl.html","
\n
\n \n
\n\n
\n \n \n
\n
\n"); $templateCache.put("dashboard-settings/sync-apps.tmpl.html","\n
\n \n \n impac.components.sync_apps.syncing\n impac.components.sync_apps.show_sync_status\n \n\n
\n \n
\n\n
\n \n
\n\n \n\n
\n\n\n\n\n\n\n"); @@ -229,26 +229,6 @@ $templateCache.put("widgets-common/editable-title.tmpl.html","
\n\n
\n \n \n {{\'impac.widget.info_panel.information\' | translate}} {{ getWidgetTemplateName() | titleize }}\n
\n\n
\n
\n\n
\n {{i.key}}\n
\n\n
\n {{i.value}}\n
\n\n
\n
\n\n
\n"); $templateCache.put("widgets-common/time-period-info.tmpl.html","
\n {{date}}\n
\n"); $templateCache.put("widgets-common/top-buttons.tmpl.html","
\n
\n\n \n\n \n\n \n\n \n\n \n
\n
\n"); -$templateCache.put("widgets-settings/account.tmpl.html","
{{label}}
\n
\n \n
\n
\n \n \n \n
\n impac.widget.settings.attach_kpis.kpi_target_require\n impac.widget.settings.attach_kpis.kpi_target_number\n
\n
\n
\n \n
\n
\n \n
\n\n
\n
impac.widget.settings.attach_kpis.attached_alerts
\n
\n
{{\'impac.widget.settings.attach_kpis.keep\' | translate}} {{formatAttachedKpiTitle(kpi) | titleize}}
\n
\n \n
\n \n
\n
\n
\n
\n\n\n"); -$templateCache.put("widgets-settings/bolt-account.tmpl.html","
{{label}}
\n
\n \n
\n"); -$templateCache.put("widgets-settings/chart-filters.tmpl.html","
\n
impac.widget.settings.chart_filters.title
\n
\n
\n \n \n
\n
\n \n
\n
\n
\n
\n \n \n
\n
\n \n
\n
\n
\n"); -$templateCache.put("widgets-settings/dates-picker.tmpl.html","\n
impac.widget.settings.dates_picker.title
\n \n\n"); -$templateCache.put("widgets-settings/forecast-payroll.tmpl.html","
\n
impac.widget.settings.forecast_payroll.title
\n\n
\n
\n {{\'impac.widget.account_cash_projection.forecast_payroll.aggregate\' | translate}}\n \n
\n
\n
\n"); -$templateCache.put("widgets-settings/hist-mode.tmpl.html","
\n
\n\n \n\n
\n
\n
\n
\n
\n"); -$templateCache.put("widgets-settings/limit-entries.tmpl.html","
\n {{ (entriesLabel ? \'impac.widget.settings.limit_entries.top\' : \'impac.widget.settings.limit_entries.display\') | translate }}\n\n \n {{ $index!=0 ? \' |\' : \'\' }} \n {{ option }}\n \n\n \n | \n {{ max }}\n \n\n {{entriesLabel || (\'impac.widget.settings.limit_entries.entries\' | translate)}}\n
"); -$templateCache.put("widgets-settings/offsets.tmpl.html","
\n
\n \n + {{ intervalsCount }} {{ periodWord }}{{ intervalsCount > 1 ? \'s\' : \'\' }} x {{ offsetValue | mnoCurrency : currency}}\n
\n\n
\n \n \n
\n
\n"); -$templateCache.put("widgets-settings/organizations.tmpl.html","
\n
impac.widget.settings.organizations.select_companies
\n\n
\n
\n {{org.label}}\n \n\n \n
\n
\n
\n"); -$templateCache.put("widgets-settings/param-selector-classic.tmpl.html","\n \n\n"); -$templateCache.put("widgets-settings/param-selector.tmpl.html","\n {{((selected.labelTranslate | translate | titleize) || (selected.label | titleize)) | truncate : getTruncateValue() : \"...\" : false}} \n
\n
\n {{(option.labelTranslate | translate | titleize) || (option.label | titleize)}}\n
\n
\n
\n"); -$templateCache.put("widgets-settings/params-checkboxes.tmpl.html","
\n \n
\n"); -$templateCache.put("widgets-settings/params-picker.tmpl.html","
{{formattedParam | titleize}}
\n
\n
{{description}}
\n
\n \n {{$index + 1}}\n {{parameter.label | titleize}}\n \n \n
\n
\n \n
\n
\n"); -$templateCache.put("widgets-settings/tag-filter.tmpl.html","
impac.widget.settings.tag-filter.filter_title
\n
\n\n
\n
\n
\n 0\" translate>impac.widget.settings.tag-filter.add_filter\n AND\n
\n
\n \n \n \n
\n
\n \n
\n
\n\n
\n
\n \n
\n
\n
\n
\n"); -$templateCache.put("widgets-settings/time-period.tmpl.html","
impac.widget.settings.time_period.title
\n
\n\n \n
\n
\n impac.widget.settings.time_period.time_range\n
\n
\n
\n\n \n
\n
\n
\n
\n
\n\n \n
\n
\n
\n
\n
\n\n \n
\n
\n impac.widget.settings.time_period.chart_interval\n \n
\n"); -$templateCache.put("widgets-settings/time-slider.tmpl.html","
\n
\n
\n
\n {{fromDate() | momentDate : \'time-slider\'}} - {{toDate() | momentDate : \'time-slider\'}}\n
\n
\n \n
\n
\n
\n"); -$templateCache.put("widgets-settings/width.tmpl.html","\n\n"); $templateCache.put("widgets/accounts-accounting-values.tmpl.html","
\n\n
\n

impac.widget.accounting_values.turnover.settings.title

\n\n
\n
\n\n
\n \n \n
\n
\n\n
\n
\n
\n\n
\n
\n {{ getCurrentPrice() | mnoCurrency : currency_unit : false }}\n
\n
{{currency}}
\n
{{legend}}
\n
\n\n
\n
\n
{{legend}}
\n
\n
\n\n
\n
\n\n
\n"); $templateCache.put("widgets/accounts-assets-liability-summary.tmpl.html","
\n
\n

impac.widget.acc_ass_liab_smry.settings.title

\n\n
\n\n
\n \n \n
\n
\n\n
\n
\n \n
\n \n
\n
\n
{{widget.content.summary[0].company}} {{classification}}
\n
{{classification}} repartition
\n \n {{valuePair.label}}: {{valuePair.total | mnoCurrency : getCurrency()}}\n
\n
\n
\n
\n
\n
\n
\n"); $templateCache.put("widgets/accounts-assets-summary.tmpl.html","
\n\n
\n

impac.widget.acc_ass_smry.settings.title

\n\n
\n\n
\n \n \n
\n
\n\n
\n
\n
\n
\n
{{widget.content.summary[0].company}} {{classification}}
\n
{{classification}} repartition
\n \n {{valuePair.label}}: {{valuePair.total | mnoCurrency : getCurrency()}}\n
\n
\n
\n
\n\n
\n
\n\n
\n"); @@ -266,7 +246,7 @@ $templateCache.put("widgets/accounts-detailed-classifications.tmpl.html","
\n\n
\n

impac.widget.account_expense_weight.settings.title

\n\n
\n
\n
\n\n
\n \n \n
\n
\n\n
\n \n
\n\n
\n
\n\n
\n
\n
\n\n
\n
\n {{getName()}} to {{getComparator() | titleize}}\n
{{widget.content.summary[0].ratio | mnoCurrency : \'%\'}}
\n
\n 1\">\n {{sum.company}}: {{sum.ratio | mnoCurrency : \'%\'}}\n
\n
\n
\n
\n\n
\n
\n\n
\n"); $templateCache.put("widgets/accounts-expenses-revenue.tmpl.html","
\n\n
\n

impac.widget.accounts_expenses_revenue.settings.title

\n\n
\n
\n\n
\n \n \n
\n
\n\n
\n
\n
\n\n
\n
\n
\n\n
\n \n impac.widget.accounts_expenses_revenue.expenses -\n impac.widget.accounts_expenses_revenue.revenue\n \n \n impac.widget.accounts_expenses_revenue.net_profit\n \n
\n\n
\n\n
\n {{\'impac.widget.accounts_expenses_revenue.expenses\' | translate}}: {{getCurrentExpenses() | mnoCurrency : getCurrency()}}\n
\n {{\'impac.widget.accounts_expenses_revenue.revenue\' | translate}}: {{getCurrentRevenue() | mnoCurrency : getCurrency()}}\n
\n
\n\n
\n
\n\n
\n"); $templateCache.put("widgets/accounts-invoices-list.tmpl.html","
\n \n
\n

Widget settings

\n\n
\n\n
\n \n \n
\n
\n\n \n
\n \n
\n \n \n
\n\n \n
\n
\n
\n
\n
\n \n

\n
\n
\n"); -$templateCache.put("widgets/accounts-live-balance.tmpl.html","
\n \n
\n

Widget settings

\n\n
\n
\n\n \n
\n \n \n
\n
\n\n \n
\n
\n

{{widget.selectedAccount.name}}

\n
{{getCurrency()}}
\n
\n
\n
\n {{getStatementBalance().column_7 ? (getStatementBalance().column_7 | mnoCurrency : getCurrency() : false) : \'Statement Not Available\' }}\n
\n
Statement Balance
\n
\n
\n {{getTotal().column_5 ? (getTotal().column_5 | mnoCurrency : getCurrency() : false) : \'N/A\' }}\n
\n
Balance in Xero
\n
\n
\n\n
\n
\n
\n"); +$templateCache.put("widgets/accounts-live-balance.tmpl.html","
\n \n
\n

Widget settings

\n\n
\n
\n\n \n
\n \n \n
\n
\n\n \n
\n
\n

{{widget.selectedAccount.name}}

\n
{{getCurrency()}}
\n
\n
\n
\n {{getStatementBalance().column_7 === \'not_ready\' ? \"We\'re preparing your data...please come back later\" : (getStatementBalance().column_7 | mnoCurrency : getCurrency() : false) }}\n
\n
Statement Balance
\n
\n
\n {{getTotal().column_5 ? (getTotal().column_5 | mnoCurrency : getCurrency() : false) : \'0.00\' }}\n
\n
Balance in Xero
\n
\n
\n\n
\n
\n
\n"); $templateCache.put("widgets/accounts-payable-receivable.tmpl.html","
\n\n
\n

impac.widget.accounts_payable_receivable.settings.title

\n\n
\n
\n\n
\n \n \n
\n
\n\n
\n
\n
\n\n
\n
\n

impac.widget.accounts_payable_receivable.receivables.title

\n
\n {{getCurrentReceivable() | mnoCurrency : getCurrency() : false}}\n
\n
{{getCurrency()}}
\n
\n\n
\n

impac.widget.accounts_payable_receivable.payables.title

\n
\n {{getCurrentPayable() | mnoCurrency : getCurrency() : false}}\n
\n
{{getCurrency()}}
\n
\n
\n\n
\n
\n
\n impac.widget.accounts_payable_receivable.payable -\n impac.widget.accounts_payable_receivable.receivable\n
\n
\n
\n\n
\n
\n\n
\n"); $templateCache.put("widgets/accounts-profit-and-loss.tmpl.html","
\n\n
\n

impac.widget.accounts_profit_and_loss.settings.title

\n\n
\n
\n
\n\n
\n \n \n
\n
\n\n
\n\n
\n
\n\n
\n\n
\n \n
\n
\n \n
\n
\n\n \n
\n
\n {{\'impac.widget.accounts_profit_and_loss.accounts\' | translate}}\n \n
\n
\n {{\'impac.widget.accounts_profit_and_loss.prof_loss\' | translate}}\n \n
\n
\n\n \n
0}\">\n
\n\n \n
\n
\n \n
\n
\n {{getName(statement) | titleize}}\n
\n
\n {{getAmount(statement) | mnoCurrency : statement.currency}}\n
\n\n
\n
\n\n \n
\n
\n
\n
\n {{account.name}}\n
\n
\n {{getAmount(account) | mnoCurrency : account.currency}}\n
\n\n
\n
\n
\n
\n\n
\n
\n\n
\n
\n impac.widget.settings.tag-filter.report_filtered\n
\n
\n\n
\n\n
\n\n
\n\n
\n

{{::period_translation}} {{\'impac.widget.accounts_profit_and_loss.prof_and_loss\' | translate}}

\n
{{getName(selectedElements[0]) | titleize}}
\n\n
\n
\n
\n\n
\n\n \n
\n \n \n
0\" class=\"clearfix dashed\">
\n\n
\n \n
\n
\n {{date | momentDate : widget.metadata.hist_parameters.period}}\n
\n
\n \n
\n
\n {{selectedElements[0].totals[$index] | mnoCurrency : selectedElements[0].currency}}\n
\n
\n
\n
\n
\n\n \n
\n \n
\n {{date | momentDate : widget.metadata.hist_parameters.period}}\n
\n \n
\n {{selectedElements[0].totals[$index] | mnoCurrency : selectedElements[0].currency}}\n
\n
\n
\n\n
\n
\n
\n \n {{getName(element) | titleize}}\n
\n
\n \n {{getAmount(element) | mnoCurrency : element.currency}}\n \n
\n
\n
\n
\n\n
\n impac.widget.accounts_profit_and_loss.no_elements_selected\n
\n
\n\n
\n\n
\n
\n\n
\n"); $templateCache.put("widgets/accounts-ratios.tmpl.html","\n
\n \n
\n

Widget settings

\n\n
\n
\n\n \n
\n \n \n
\n
\n\n \n
\n \n
\n\n \n
\n
\n\n
\n
\n {{ totalNumerator | mnoCurrency : widget.content.layout.currency }}\n
\n\n
\n {{ calculatedNumerator | mnoCurrency : widget.content.layout.currency }}\n
\n\n
\n {{ widget.content.layout.numerator }}\n
\n\n
\n
\n\n
\n\n
\n
\n {{ totalDenominator | mnoCurrency : widget.content.layout.currency }}\n
\n\n
\n {{ calculatedDenominator | mnoCurrency : widget.content.layout.currency }}\n
\n\n
\n {{ widget.content.layout.denominator }}\n
\n\n
\n
\n\n
\n \n \n \n
\n
\n\n \n
\n
\n\n
\n
\n {{ totalRatio | mnoCurrency : \'(ratio)\' : false }}\n
\n
{{ widget.content.layout.ratio }}
\n
\n\n
\n
\n
{{ widget.content.layout.ratio }}
\n
\n
\n\n
\n\n
\n
\n
\n"); @@ -303,7 +283,27 @@ $templateCache.put("widgets/sales-performance.tmpl.html","
\n\n
\n

impac.widget.sales_turnover.settings.title

\n\n
\n
\n\n
\n \n \n
\n
\n\n
\n\n
\n
\n
\n\n
{{\'impac.widget.sales_turnover.filter\' | translate}}
\n
\n
\n
\n\n
\n\n
\n
impac.widget.sales_turnover.average_price
\n
\n\n
\n
\n \n
\n
\n {{getRangeLabel(range.label)}}\n
\n
\n {{range.percentage}}%\n
\n
\n
\n\n
\n\n
\n \n

{{getMaxRange().percentage.toFixed()}}% {{\'impac.widget.sales_turnover.of_your_revenue\' | translate}} {{getMaxRange().label.split(\'-\')[0] | mnoCurrency : widget.content.currency}} {{\'impac.widget.sales_turnover.and\' | translate}} {{getMaxRange().label.split(\'-\')[1] | mnoCurrency : widget.content.currency}}.

\n
{{::analysisTranslate}}
\n
\n
\n\n
\n
\n\n
\n"); $templateCache.put("widgets/sales-summary.tmpl.html","
\n\n
\n

impac.widget.sales_summary.settings.title

\n\n
\n
\n\n
\n \n \n
\n
\n\n
\n\n
\n \n \n
\n\n
\n
\n
\n\n
\n
\n\n
\n"); $templateCache.put("widgets/sales-top-customers.tmpl.html","
\n
\n

impac.widget.sales_top_customers.settings.title

\n\n
\n
\n\n
\n \n \n
\n
\n\n
\n\n
\n \n\n \n
\n
\n #\n
\n
impac.widget.sales_top_customers.customer_name
\n
\n
\n
\n
\n\n \n
\n
\n\n
\n
\n {{$index + 1}}\n
\n
\n {{entity.name}}\n
\n
\n \n \n {{ getHeaderField().getValue(entity) | mnoCurrency : entity.currency }}\n \n \n {{ getHeaderField().getValue(entity) }}\n \n
\n
\n\n
\n
\n \n {{field.label}}: {{field.getValue(entity) | mnoCurrency : entity.currency}}\n \n \n {{field.label}}: {{field.getValue(entity)}}\n
\n
\n\n
\n
\n\n
\n
\n\n
\n"); -$templateCache.put("widgets/sales-top-opportunities.tmpl.html","
\n\n
\n

impac.widget.sales_opportunities.settings.title

\n\n
\n\n
\n \n \n
\n
\n\n
\n\n
\n\n
\n {{\'impac.widget.sales_opportunities.total_potential\' | translate}} {{widget.content.total_potential | mnoCurrency : widget.content.currency || \"AUD\"}} - {{widget.content.eligible_opportunities}} {{\'impac.widget.sales_opportunities.eligible_opportunities\' | translate}}\n
\n\n
\n
\n
{{$index +1 }}
\n
\n {{opp.name | titleize}}\n
\n {{getOppDetails(opp)}}\n
\n
\n
\n\n
\n\n
\n
\n\n
\n");}]); +$templateCache.put("widgets/sales-top-opportunities.tmpl.html","
\n\n
\n

impac.widget.sales_opportunities.settings.title

\n\n
\n\n
\n \n \n
\n
\n\n
\n\n
\n\n
\n {{\'impac.widget.sales_opportunities.total_potential\' | translate}} {{widget.content.total_potential | mnoCurrency : widget.content.currency || \"AUD\"}} - {{widget.content.eligible_opportunities}} {{\'impac.widget.sales_opportunities.eligible_opportunities\' | translate}}\n
\n\n
\n
\n
{{$index +1 }}
\n
\n {{opp.name | titleize}}\n
\n {{getOppDetails(opp)}}\n
\n
\n
\n\n
\n\n
\n
\n\n
\n"); +$templateCache.put("widgets-settings/account.tmpl.html","
{{label}}
\n
\n \n
\n
\n \n \n \n
\n impac.widget.settings.attach_kpis.kpi_target_require\n impac.widget.settings.attach_kpis.kpi_target_number\n
\n
\n
\n \n
\n
\n \n
\n\n
\n
impac.widget.settings.attach_kpis.attached_alerts
\n
\n
{{\'impac.widget.settings.attach_kpis.keep\' | translate}} {{formatAttachedKpiTitle(kpi) | titleize}}
\n
\n \n
\n \n
\n
\n
\n
\n\n
\n"); +$templateCache.put("widgets-settings/bolt-account.tmpl.html","
{{label}}
\n
\n \n
\n"); +$templateCache.put("widgets-settings/chart-filters.tmpl.html","
\n
impac.widget.settings.chart_filters.title
\n
\n
\n \n \n
\n
\n \n
\n
\n
\n
\n \n \n
\n
\n \n
\n
\n
\n"); +$templateCache.put("widgets-settings/dates-picker.tmpl.html","\n
impac.widget.settings.dates_picker.title
\n \n\n"); +$templateCache.put("widgets-settings/forecast-payroll.tmpl.html","
\n
impac.widget.settings.forecast_payroll.title
\n\n
\n
\n {{\'impac.widget.account_cash_projection.forecast_payroll.aggregate\' | translate}}\n \n
\n
\n
\n"); +$templateCache.put("widgets-settings/hist-mode.tmpl.html","
\n
\n\n \n\n
\n
\n
\n
\n
\n"); +$templateCache.put("widgets-settings/limit-entries.tmpl.html","
\n {{ (entriesLabel ? \'impac.widget.settings.limit_entries.top\' : \'impac.widget.settings.limit_entries.display\') | translate }}\n\n \n {{ $index!=0 ? \' |\' : \'\' }} \n {{ option }}\n \n\n \n | \n {{ max }}\n \n\n {{entriesLabel || (\'impac.widget.settings.limit_entries.entries\' | translate)}}\n
"); +$templateCache.put("widgets-settings/offsets.tmpl.html","
\n
\n \n + {{ intervalsCount }} {{ periodWord }}{{ intervalsCount > 1 ? \'s\' : \'\' }} x {{ offsetValue | mnoCurrency : currency}}\n
\n\n
\n \n \n
\n
\n"); +$templateCache.put("widgets-settings/organizations.tmpl.html","
\n
impac.widget.settings.organizations.select_companies
\n\n
\n
\n {{org.label}}\n \n\n \n
\n
\n
\n"); +$templateCache.put("widgets-settings/param-selector-classic.tmpl.html","\n \n\n"); +$templateCache.put("widgets-settings/param-selector.tmpl.html","\n {{((selected.labelTranslate | translate | titleize) || (selected.label | titleize)) | truncate : getTruncateValue() : \"...\" : false}} \n
\n
\n {{(option.labelTranslate | translate | titleize) || (option.label | titleize)}}\n
\n
\n
\n"); +$templateCache.put("widgets-settings/params-checkboxes.tmpl.html","
\n \n
\n"); +$templateCache.put("widgets-settings/params-picker.tmpl.html","
{{formattedParam | titleize}}
\n
\n
{{description}}
\n
\n \n {{$index + 1}}\n {{parameter.label | titleize}}\n \n \n
\n
\n \n
\n
\n"); +$templateCache.put("widgets-settings/tag-filter.tmpl.html","
impac.widget.settings.tag-filter.filter_title
\n
\n\n
\n
\n
\n 0\" translate>impac.widget.settings.tag-filter.add_filter\n AND\n
\n
\n \n \n \n
\n
\n \n
\n
\n\n
\n
\n \n
\n
\n
\n
\n"); +$templateCache.put("widgets-settings/time-period.tmpl.html","
impac.widget.settings.time_period.title
\n
\n\n \n
\n
\n impac.widget.settings.time_period.time_range\n
\n
\n
\n\n \n
\n
\n
\n
\n
\n\n \n
\n
\n
\n
\n
\n\n \n
\n
\n impac.widget.settings.time_period.chart_interval\n \n
\n"); +$templateCache.put("widgets-settings/time-slider.tmpl.html","
\n
\n
\n
\n {{fromDate() | momentDate : \'time-slider\'}} - {{toDate() | momentDate : \'time-slider\'}}\n
\n
\n \n
\n
\n
\n"); +$templateCache.put("widgets-settings/width.tmpl.html","\n\n");}]); (function() { var module; @@ -363,7 +363,7 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
= 0); + }); + options = { + scaleBeginAtZero: all_values_are_positive, + showXLabels: false, + currency: data.currency + }; + chartData = ChartFormatterSvc.combinedBarChart(inputData, options, false); + return $scope.drawTrigger.notify(chartData); } }; - w.settings.push(setting); - return $scope.deferred.resolve($scope.parentWidget); + return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('settingAccount', ["$templateCache", "$translate", function($templateCache, $translate) { + module.directive('widgetAccountsAccountingValues', function() { return { restrict: 'A', - scope: { - parentWidget: '=', - deferred: '=', - label: '@', - showLabel: '=?', - onAccountSelected: '&' - }, - link: function(scope, element) { - if (!scope.label) { - return scope.label = $translate.instant('impac.widget.settings.account.label'); - } - }, - template: $templateCache.get('widgets-settings/account.tmpl.html'), - controller: 'SettingAccountCtrl' + controller: 'WidgetAccountsAccountingValuesCtrl' }; - }]); + }); }).call(this); (function() { var module; - module = angular.module('impac.components.widgets-settings.accounting-behaviour', []); + module = angular.module('impac.components.widgets.accounts-assets-liability-summary', []); - module.directive('settingAccountingBehaviour', ["$templateCache", "$timeout", function($templateCache, $timeout) { - return { - restrict: 'A', - scope: { - parentWidget: '=', - deferred: '=', - defaultBehaviour: '=?' - }, - template: $templateCache.get('widgets-settings/accounting-behaviour.tmpl.html'), - link: function(scope) { - var setting, w; - w = scope.parentWidget; - setting = {}; - setting.key = "accounting-behaviour"; - setting.initialize = function() { - return $timeout(function() { - if ((scope.defaultBehaviour != null) && scope.defaultBehaviour === 'pnl') { - return scope.selectedBehaviour = 'pnl'; - } else { - return scope.selectedBehaviour = 'bls'; - } - }); - }; - setting.toMetadata = function() { + module.controller('WidgetAccountsAssetsLiabilitySummaryCtrl', ["$scope", "$q", "ChartFormatterSvc", "$translate", function($scope, $q, ChartFormatterSvc, $translate) { + var settingsPromises, w; + w = $scope.widget; + $scope.orgDeferred = $q.defer(); + $scope.chartDeferred = $q.defer(); + $scope.paramSelectorDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise, $scope.chartDeferred.promise, $scope.paramSelectorDeferred.promise]; + w.initContext = function() { + $scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.summary); + if (!w.metadata.classification) { + w.metadata.classification = "ASSET"; + } + $translate('impac.widget.acc_ass_liab_smry.' + w.metadata.classification.toLowerCase() + '.many').then(function(result) { + return $scope.classification = result; + }); + $translate(['impac.widget.acc_ass_liab_smry.accounts.asset', 'impac.widget.acc_ass_liab_smry.accounts.liability']).then(function(translation) { + $scope.accountsOptions = [ + { + label: translation['impac.widget.acc_ass_liab_smry.accounts.asset'], + value: 'ASSET' + }, { + label: translation['impac.widget.acc_ass_liab_smry.accounts.liability'], + value: 'LIABILITY' + } + ]; + if (!$scope.selectedAccountsOption) { + return $scope.selectedAccountsOption = angular.copy(_.find($scope.accountsOptions, { + value: w.metadata.classification + })); + } + }); + if ($scope.isDataFound) { + if (w.metadata.organization_ids.length > 1) { + return $scope.dataSource = w.content.repartition; + } else { + return $scope.dataSource = w.content.summary; + } + } + }; + $scope.getCurrency = function() { + if ($scope.isDataFound) { + return w.content.currency; + } + }; + $scope.getAccountColor = function(elem) { + if ($scope.isDataFound) { + return ChartFormatterSvc.getColor(_.indexOf($scope.dataSource, elem)); + } + }; + $scope.drawTrigger = $q.defer(); + w.format = function() { + var chartData, pieData, pieOptions; + if ($scope.isDataFound) { + pieData = _.map($scope.dataSource, function(company) { return { - accounting_behaviour: scope.selectedBehaviour + label: company.label, + value: company.total }; + }); + pieOptions = { + percentageInnerCutout: 50, + tooltipFontSize: 12 }; - w.settings.push(setting); - return scope.deferred.resolve(setting); + chartData = ChartFormatterSvc.pieChart(pieData, pieOptions); + return $scope.drawTrigger.notify(chartData); } }; + return $scope.widgetDeferred.resolve(settingsPromises); }]); + module.directive('widgetAccountsAssetsLiabilitySummary', function() { + return { + restrict: 'A', + controller: 'WidgetAccountsAssetsLiabilitySummaryCtrl' + }; + }); + }).call(this); (function() { var module; - module = angular.module('impac.components.widgets-settings.accounts-list', []); + module = angular.module('impac.components.widgets.accounts-assets-summary', []); - module.controller('SettingAccountsListCtrl', ["$scope", "$timeout", "ImpacWidgetsSvc", function($scope, $timeout, ImpacWidgetsSvc) { - var restoreSavedAccounts, setting, w; - w = $scope.parentWidget; - w.moveAccountToAnotherList = function(account, src, dst, triggerUpdate) { - if (triggerUpdate == null) { - triggerUpdate = true; - } - if (_.isEmpty(src) || _.isEmpty(account)) { - return; + module.controller('WidgetAccountsAssetsSummaryCtrl', ["$scope", "$q", "ChartFormatterSvc", "$translate", function($scope, $q, ChartFormatterSvc, $translate) { + var settingsPromises, w; + w = $scope.widget; + $scope.orgDeferred = $q.defer(); + $scope.chartDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise, $scope.chartDeferred.promise]; + w.initContext = function() { + $scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.summary); + if ($scope.isDataFound) { + if (w.metadata.organization_ids.length > 1) { + $scope.dataSource = w.content.repartition; + } else { + $scope.dataSource = w.content.summary; + } } - dst || (dst = []); - _.remove(src, function(acc) { - return account.uid === acc.uid; - }); - dst.push(account); - if (triggerUpdate) { - ImpacWidgetsSvc.updateWidgetSettings(w, false); + if (!w.metadata.classification) { + w.metadata.classification = "ASSET"; } - return null; + return $translate('impac.widget.acc_ass_smry.' + w.metadata.classification.toLowerCase() + ".many").then(function(result) { + return $scope.classification = result; + }); }; - setting = {}; - setting.key = "accounts-list"; - setting.initialize = function() { - setting.isInitialized = false; - w.remainingAccounts = []; - w.selectedAccounts = []; - if ((w.content != null) && !_.isEmpty(w.content.complete_list)) { - w.remainingAccounts = angular.copy(w.content.complete_list); - return $timeout(function() { - restoreSavedAccounts(); - return setting.isInitialized = true; - }); + $scope.getCurrency = function() { + if ($scope.isDataFound) { + return w.content.currency; } }; - setting.toMetadata = function() { - if (setting.isInitialized) { - return { - accounts_list: _.map(w.selectedAccounts, (function(acc) { - return acc.uid; - })) - }; + $scope.getAccountColor = function(elem) { + if ($scope.isDataFound) { + return ChartFormatterSvc.getColor(_.indexOf($scope.dataSource, elem)); } }; - restoreSavedAccounts = function() { - var acc, accUid, accountsList, i, len, results; - if (_.isEmpty(w.metadata.accounts_list) && _.isEmpty($scope.accountsList)) { - return; - } - accountsList = _.isEmpty($scope.accountsList) ? w.metadata.accounts_list : $scope.accountsList; - results = []; - for (i = 0, len = accountsList.length; i < len; i++) { - accUid = accountsList[i]; - acc = _.find(w.content.complete_list, function(acc) { - return acc.uid === accUid; + $scope.drawTrigger = $q.defer(); + w.format = function() { + var chartData, pieData, pieOptions; + if ($scope.isDataFound) { + pieData = _.map($scope.dataSource, function(company) { + return { + label: company.label, + value: company.total + }; }); - results.push(w.moveAccountToAnotherList(acc, w.remainingAccounts, w.selectedAccounts, false)); + pieOptions = { + percentageInnerCutout: 50, + tooltipFontSize: 12 + }; + chartData = ChartFormatterSvc.pieChart(pieData, pieOptions); + return $scope.drawTrigger.notify(chartData); } - return results; }; - w.settings.push(setting); - return $scope.deferred.resolve($scope.parentWidget); + return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('settingAccountsList', function() { + module.directive('widgetAccountsAssetsSummary', function() { return { restrict: 'A', - scope: { - parentWidget: '=', - deferred: '=', - accountsList: '=?' - }, - controller: 'SettingAccountsListCtrl' + controller: 'WidgetAccountsAssetsSummaryCtrl' }; }); }).call(this); - -/* - * Attach KPIs onto widget with a form for picking target mode and value. View widget's - * attached KPIs, manage set targets, alerts and delete. - * **NOTE: this component is not in use, and requires fixes/improvements to be used.** - */ - (function() { var module; - module = angular.module('impac.components.widgets-settings.attach-kpis', []); + module = angular.module('impac.components.widgets.accounts-assets-vs-liabilities', []); - module.directive('settingAttachKpis', ["$templateCache", "ImpacWidgetsSvc", "ImpacKpisSvc", "$translate", function($templateCache, ImpacWidgetsSvc, ImpacKpisSvc, $translate) { - return { - restrict: 'A', - scope: { - parentWidget: '=', - attachedKpis: '=?', - widgetEngine: '=', - widgetId: '=', - extraParams: '=?', - deferred: '=', - showExtraParam: '=?' - }, - template: $templateCache.get('widgets-settings/attach-kpis.tmpl.html'), - controller: ["$scope", function($scope) { - var loadKpisData, settings, w; - w = $scope.parentWidget; - settings = {}; - settings.initialize = function() { - return loadKpisData(); - }; - settings.toMetadata = function() {}; - w.settings.push(settings); - $scope.formatKpiName = function(endpoint) { - return ImpacKpisSvc.formatKpiName(endpoint); - }; - $scope.hasValidTarget = function() { - return ImpacKpisSvc.validateKpiTarget($scope.kpi); - }; - $scope.attachKpi = function() { - var param, paramValues, params, ref, target0; - params = {}; - if (!$scope.hasValidTarget()) { - return; - } - target0 = {}; - target0[$scope.kpi.limit.mode] = $scope.kpi.limit.value; - params.targets = {}; - params.targets[$scope.kpi.watchables[0]] = [target0]; - params.widget_id = $scope.widgetId; - ref = $scope.extraParams; - for (param in ref) { - paramValues = ref[param]; - params.extra_params || (params.extra_params = {}); - params.extra_params[param] = paramValues.uid; - } - console.log('attachKpis: ', $scope.kpi.endpoint, $scope.elementWatched, params); - return ImpacKpisSvc.create('impac', $scope.kpi.endpoint, $scope.elementWatched, params).then(function(kpi) { - console.log('attached KPI: ', kpi); - return $scope.attachedKpis.push(kpi); - }); - }; - $scope.deleteKpi = function(kpi) { - return ImpacKpisSvc["delete"](kpi, { - widget_id: $scope.widgetId - }).then(function() { - return _.remove($scope.attachedKpis, function(k) { - return k.id === kpi.id; - }); - }); - }; - $scope.formatAttachedKpiTitle = function(kpi) { - if (!(kpi.data && kpi.targets && $scope.elementWatched)) { - return ''; + module.controller('WidgetAccountsAssetsVsLiabilitiesCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "$translate", function($scope, $q, ChartFormatterSvc, $filter, $translate) { + var settingsPromises, w; + w = $scope.widget; + $scope.orgDeferred = $q.defer(); + $scope.chartDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise, $scope.chartDeferred.promise]; + $translate(['impac.widget.acc_ass_vs_liab.asset.one', 'impac.widget.acc_ass_vs_liab.liability.one']).then(function(translation) { + return $scope.classificationTranslation = { + "ASSET": translation['impac.widget.acc_ass_vs_liab.asset.one'].toUpperCase(), + "LIABILITY": translation['impac.widget.acc_ass_vs_liab.liability.one'].toUpperCase() + }; + }); + w.initContext = function() { + var index; + $scope.isDataFound = (w.content != null) && !_.isEmpty(w.content.summary) && !_.isEmpty(w.content.companies); + if ($scope.isDataFound) { + index = 0; + $scope.companiesList = _.map(w.content.companies, function(company) { + var assetSum, liabilitiesSum, result; + assetSum = _.find(w.content.summary, (function(sum) { + return sum.classification === "ASSET"; + })); + liabilitiesSum = _.find(w.content.summary, (function(sum) { + return sum.classification === "LIABILITY"; + })); + result = { + company: company, + assets: assetSum != null ? assetSum.totals[index] : 0.0, + liabilities: liabilitiesSum != null ? liabilitiesSum.totals[index] : 0.0, + currency: w.content.currency + }; + index++; + return result; + }); + return $scope.titleTranslation; + } + }; + $scope.assetsColor = ChartFormatterSvc.getColor(0); + $scope.liabilitiesColor = ChartFormatterSvc.getColor(1); + $scope.drawTrigger = $q.defer(); + w.format = function() { + var chartData, datasets, inputData, options; + if ($scope.isDataFound) { + datasets = _.map(w.content.summary, function(sum) { + if (_.includes(['ASSET', 'LIABILITY'], sum.classification)) { + return { + title: $scope.classificationTranslation[sum.classification], + values: sum.totals + }; } - return ImpacKpisSvc.formatKpiTarget(kpi.targets[$scope.elementWatched][0], kpi.data[$scope.elementWatched].unit, $scope.possibleTargets); + }); + datasets = _.sortByOrder(datasets, ['title']); + inputData = { + labels: w.content.companies, + datasets: _.compact(datasets) }; - $scope.attachedKpis || ($scope.attachedKpis = []); - $scope.possibleTargets = [ - { - label: $translate.instant('impac.widget.settings.attach_kpis.over'), - mode: 'min' - }, { - label: $translate.instant('impac.widget.settings.attach_kpis.below'), - mode: 'max' - } - ]; - $scope.kpi = { - limit: { - mode: $scope.possibleTargets[0].mode - } + options = { + showTooltips: false, + showXLabels: false, + barValueSpacing: Math.max(8 - w.content.companies.length, 1) }; - ImpacKpisSvc.getAttachableKpis($scope.widgetEngine).then(function(kpiTemplates) { - $scope.availableKpis = angular.copy(kpiTemplates); - angular.extend($scope.kpi, $scope.availableKpis[0]); - $scope.selectedParam = _.keys($scope.extraParams)[0]; - return $scope.elementWatched = ($scope.kpi.watchables != null) && $scope.kpi.watchables[0]; - }); - loadKpisData = function() {}; - loadKpisData(); - return $scope.deferred.resolve($scope.parentWidget); - }] + chartData = ChartFormatterSvc.combinedBarChart(inputData, options); + return $scope.drawTrigger.notify(chartData); + } }; + return $scope.widgetDeferred.resolve(settingsPromises); }]); -}).call(this); - -(function() { - var module; + module.directive('widgetAccountsAssetsVsLiabilities', function() { + return { + restrict: 'A', + controller: 'WidgetAccountsAssetsVsLiabilitiesCtrl' + }; + }); - module = angular.module('impac.components.widgets-settings.bolt-account', []); +}).call(this); - module.controller('SettingBoltAccountCtrl', ["$scope", "$filter", function($scope, $filter) { - var formatAmount, setOptions, setSelected, setting, w; - w = $scope.parentWidget; - setting = {}; - setting.key = "bolt-account"; - setting.isInitialized = false; - setting.initialize = function() { - if (w.content.settings.selectors.length !== 0) { - w.accountList = setOptions(); - } - w.selectedAccount = setSelected(); - if ((w.content != null) && (w.accountList != null) && (w.metadata != null) && (w.metadata.account_uid != null)) { - w.selectedAccount = setSelected(w.metadata.account_uid); - return setting.isInitialized = true; - } +(function() { + var module; + + module = angular.module('impac.components.widgets.accounts-balance', []); + + module.controller('WidgetAccountsBalanceCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", function($scope, $q, ChartFormatterSvc, $filter) { + var settingsPromises, w; + w = $scope.widget; + $scope.orgDeferred = $q.defer(); + $scope.accountBackDeferred = $q.defer(); + $scope.accountFrontDeferred = $q.defer(); + $scope.timePeriodDeferred = $q.defer(); + $scope.histModeDeferred = $q.defer(); + $scope.chartDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise, $scope.accountBackDeferred, $scope.accountFrontDeferred, $scope.timePeriodDeferred.promise, $scope.histModeDeferred.promise, $scope.chartDeferred.promise]; + $scope.kpiExtraParams = {}; + $scope.isDataFound = true; + w.initContext = function() { + return $scope.isDataFound = (w.content != null) && !_.isEmpty(w.content.account_list); }; - setting.toMetadata = function() { + $scope.getName = function() { if (w.selectedAccount != null) { - return { - account_uid: w.selectedAccount.account_id - }; + return w.selectedAccount.name; } }; - setOptions = function(name) { - if (name == null) { - name = 'account'; + $scope.getBehaviour = function() { + return (w.selectedAccount != null) && w.selectedAccount.accounting_behaviour; + }; + $scope.getCurrentBalance = function() { + if (w.selectedAccount != null) { + if ($scope.getBehaviour() === 'pnl') { + return _.sum(w.selectedAccount.balances); + } else { + return _.last(w.selectedAccount.balances); + } + } else { + return 0.0; } - return _.find(w.content.settings.selectors, function(selector) { - return selector.name === name; - }).options; }; - setSelected = function(selected) { - if (selected == null) { - selected = 'total_uid'; + $scope.getCurrency = function() { + if (w.selectedAccount != null) { + return w.selectedAccount.currency; } - return _.find(w.accountList, function(acc) { - return acc.account_id === selected; + }; + $scope.displayAccount = function() { + return $scope.updateSettings(false).then(function() { + return w.format(); }); }; - formatAmount = function(anAccount) { - var balance; - balance = null; - return $filter('mnoCurrency')(balance, anAccount.currency); + $scope.updateKpiExtraParams = function(key, value) { + return $scope.kpiExtraParams[key] = angular.copy(value); }; - $scope.formatLabel = function(anAccount) { - if (anAccount.currency != null) { - return anAccount.name + " (" + anAccount.currency + ")"; - } else { - return "" + anAccount.name; + $scope.drawTrigger = $q.defer(); + w.format = function() { + var all_values_are_positive, barData, chartData, data, dates, datesSource, lineData, options, period; + if ($scope.isDataFound && (w.selectedAccount != null)) { + data = angular.copy(w.selectedAccount); + datesSource = data.dates || w.content.dates; + period = null; + if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { + period = w.metadata.hist_parameters.period; + } + dates = _.map(datesSource, function(date) { + return $filter('momentDate')(date, period); + }); + lineData = { + title: data.name, + labels: dates, + values: data.balances + }; + barData = { + labels: dates, + datasets: [ + { + title: data.name, + values: data.balances + } + ] + }; + all_values_are_positive = true; + angular.forEach(data.balances, function(value) { + return all_values_are_positive && (all_values_are_positive = value >= 0); + }); + options = { + scaleBeginAtZero: all_values_are_positive, + showXLabels: false + }; + chartData = ChartFormatterSvc.lineChart([lineData], options); + if ($scope.getBehaviour() === 'pnl') { + chartData = ChartFormatterSvc.combinedBarChart(barData, options, false); + } + return $scope.drawTrigger.notify(chartData); } }; - w.settings.push(setting); - return $scope.deferred.resolve($scope.parentWidget); + return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('settingBoltAccount', ["$templateCache", "$translate", function($templateCache, $translate) { + module.directive('widgetAccountsBalance', function() { return { restrict: 'A', - scope: { - parentWidget: '=', - deferred: '=', - label: '@', - showLabel: '=?', - onAccountSelected: '&' - }, - link: function(scope, element) { - if (!scope.label) { - return scope.label = $translate.instant('impac.widget.settings.bolt-account.label'); - } - }, - template: $templateCache.get('widgets-settings/bolt-account.tmpl.html'), - controller: 'SettingBoltAccountCtrl' + controller: 'WidgetAccountsBalanceCtrl' }; - }]); + }); }).call(this); (function() { var module; - module = angular.module('impac.components.widgets-settings.chart-filters', []); + module = angular.module('impac.components.widgets.accounts-balance-sheet', []); - module.controller('SettingChartFiltersCtrl', ["$scope", function($scope) { - var setting, w; - w = $scope.parentWidget; - setting = {}; - setting.key = "chart-filters"; - setting.isInitialized = false; - setting.initialize = function() { - if ((w.content != null) && (w.content.chart_filter != null) && ($scope.filterCriteria = w.content.chart_filter.criteria)) { - $scope.maxEntities = w.content.chart_filter.max; - $scope.entityType = w.content.chart_filter.entity_type; - $scope.filterLabel = w.content.chart_filter.filter_label.replace(/_/g, " "); - if ($scope.filterCriteria === "number") { - $scope.filterValuePercentage = 80; - $scope.filterValueNumber = w.content.chart_filter.value; + module.controller('WidgetAccountsBalanceSheetCtrl', ["$scope", "$q", "ImpacWidgetsSvc", "ImpacMainSvc", "ImpacUtilities", "$translate", "ImpacTheming", function($scope, $q, ImpacWidgetsSvc, ImpacMainSvc, ImpacUtilities, $translate, ImpacTheming) { + var initDates, settingsPromises, sortAccountsBy, sortData, translateCategories, unCollapsedSetting, w; + w = $scope.widget; + $scope.orgDeferred = $q.defer(); + $scope.datesPickerDeferred = $q.defer(); + $scope.tagFilterDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise, $scope.datesPickerDeferred.promise, $scope.tagFilterDeferred.promise]; + $scope.datesPickerTemplate = "
\n
\n \n
\n
\n \n
\n
"; + $scope.ascending = true; + $scope.sortedColumn = 'account'; + $scope.filterTagsEnabled = ImpacTheming.get().widgetSettings.tagging.enabled; + $scope.isReportFiltered = function() { + return (w.metadata != null) && (w.metadata.filter_query != null) && Object.keys(w.metadata.filter_query).length > 0; + }; + initDates = function() { + $scope.fromDate = w.metadata.hist_parameters.from; + $scope.toDate = w.metadata.hist_parameters.to; + return $scope.keepToday = w.metadata.hist_parameters.keep_today; + }; + if (!((w.metadata != null) && (w.metadata.hist_parameters != null))) { + w.metadata || (w.metadata = {}); + w.metadata.hist_parameters = { + to: moment().format('YYYY-MM-DD'), + keep_today: true, + period: 'RANGE' + }; + ImpacMainSvc.load().then(function(config) { + var fyEndMonth; + fyEndMonth = parseInt(config.currentOrganization.financial_year_end_month) || 6; + w.metadata.hist_parameters.from = moment(ImpacUtilities.financialYearDates(fyEndMonth).end, 'YYYY-MM-DD').subtract(1, 'year').format('YYYY-MM-DD'); + return initDates(); + }); + } else { + initDates(); + } + w.initContext = function() { + if ($scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.summary) && !_.isEmpty(w.content.dates)) { + $scope.dates = w.content.dates; + $scope.unCollapsed = w.metadata.unCollapsed || []; + translateCategories(Object.keys(w.content.summary)).then(function(categories) { + $scope.categories = categories; + return sortData(); + }); + } + return initDates(); + }; + $scope.toggleCollapsed = function(categoryName) { + if (categoryName != null) { + if (_.find($scope.unCollapsed, (function(name) { + return categoryName === name; + }))) { + $scope.unCollapsed = _.reject($scope.unCollapsed, function(name) { + return name === categoryName; + }); } else { - $scope.filterValuePercentage = w.content.chart_filter.value; - $scope.filterValueNumber = Math.round($scope.maxEntities / 2); + $scope.unCollapsed.push(categoryName); } - return setting.isInitialized = true; + return ImpacWidgetsSvc.updateWidgetSettings(w, false); } }; - setting.toMetadata = function() { - var filterValue; - if ((w.content != null) && (w.content.chart_filter != null)) { - if ($scope.filterCriteria === "percentage") { - filterValue = $scope.filterValuePercentage; + $scope.isCollapsed = function(categoryName) { + if (categoryName != null) { + if (_.find($scope.unCollapsed, (function(name) { + return categoryName === name; + }))) { + return false; } else { - filterValue = $scope.filterValueNumber; + return true; } - return { - chart_filter: { - criteria: $scope.filterCriteria, - value: filterValue - } - }; - } else { - return {}; } }; - w.settings.push(setting); - return $scope.deferred.resolve($scope.parentWidget); - }]); - - module.directive('settingChartFilters', ["$templateCache", function($templateCache) { - return { - restrict: 'A', - scope: { - parentWidget: '=', - deferred: '=' - }, - template: $templateCache.get('widgets-settings/chart-filters.tmpl.html'), - controller: 'SettingChartFiltersCtrl' - }; - }]); - -}).call(this); - -(function() { - var module; - - module = angular.module('impac.components.widgets-settings.dates-picker', []); - - module.directive('settingDatesPicker', ["$templateCache", "$filter", "ImpacWidgetsSvc", "$timeout", "$compile", function($templateCache, $filter, ImpacWidgetsSvc, $timeout, $compile) { - return { - restrict: 'A', - scope: { - parentWidget: '=?', - deferred: '=', - fromDate: '=from', - toDate: '=to', - keepToday: '=', - onUse: '&?', - onChangeCb: '&?onChange', - minDate: '=?', - updateOnPick: '=?', - template: '=?', - period: '=?' - }, - template: $templateCache.get('widgets-settings/dates-picker.tmpl.html'), - link: function(scope, element) { - var applyHtml, buildDates, fromDateHtml, isToToday, setting, templatesContainer, toDateHtml, w; - w = scope.parentWidget; - setting = {}; - setting.key = "dates-picker"; - scope.setting = setting; - scope.calendarFrom = { - opened: false, - value: new Date(new Date().getFullYear(), 0, 1), - toggle: function() { - scope.calendarFrom.opened = !scope.calendarFrom.opened; - return scope.calendarTo.opened = false; - } - }; - scope.calendarTo = { - opened: false, - value: new Date(), - toggle: function() { - scope.calendarFrom.opened = false; - return scope.calendarTo.opened = !scope.calendarTo.opened; - } - }; - scope.template || (scope.template = "
\n
\n impac.widget.settings.dates_picker.from \n
\n
\n impac.widget.settings.dates_picker.to \n
\n
"); - fromDateHtml = "
\n \n
"; - toDateHtml = "
\n \n
"; - applyHtml = ""; - scope.template = scope.template.replace(/>/, " ng-click='onUse()'>"); - scope.template = scope.template.replace(/]*)>/g, "" + (fromDateHtml.replace('ATTRS', '$1'))); - scope.template = scope.template.replace(/]*)>/g, "" + (toDateHtml.replace('ATTRS', '$1'))); - scope.template = scope.template.replace(/]*)>/g, "" + (applyHtml.replace('ATTRS', '$1'))); - templatesContainer = element.find('#template-container'); - templatesContainer.html(scope.template).show(); - $compile(templatesContainer.contents())(scope); - setting.initialize = function() { - return $timeout(function() { - var d, m, parsedFrom, parsedTo, y; - scope.changed = false; - if (Date.parse(scope.fromDate)) { - parsedFrom = scope.fromDate.split('-'); - y = parsedFrom[0]; - m = parsedFrom[1] - 1; - d = parsedFrom[2]; - scope.calendarFrom.value = new Date(y, m, d); - } else { - scope.calendarFrom.value = new Date(new Date().getFullYear(), 0, 1); - } - if (Date.parse(scope.toDate) && !scope.keepToday) { - parsedTo = scope.toDate.split('-'); - y = parsedTo[0]; - m = parsedTo[1] - 1; - d = parsedTo[2]; - return scope.calendarTo.value = new Date(y, m, d); - } else { - return scope.calendarTo.value = new Date(); - } - }); - }; - isToToday = function() { - return (scope.calendarTo.value.getFullYear() === new Date().getFullYear()) && (scope.calendarTo.value.getMonth() === new Date().getMonth()) && (scope.calendarTo.value.getDate() === new Date().getDate()); - }; - setting.toMetadata = function() { + translateCategories = function(categories) { + var translationPromises; + translationPromises = _.map(categories, function(category) { + return $translate('impac.widget.account_balance_sheets.' + category.toLowerCase()).then(function(translation) { return { - hist_parameters: { - from: $filter('date')(scope.calendarFrom.value, 'yyyy-MM-dd'), - to: $filter('date')(scope.calendarTo.value, 'yyyy-MM-dd'), - period: scope.period || "RANGE", - keep_today: isToToday() - } + label: translation, + key: category }; - }; - scope.onChange = function() { - scope.showApplyButton(); - if (!_.isUndefined(scope.onChangeCb)) { - return scope.onChangeCb()(buildDates()); - } - }; - buildDates = function() { + }, function() { return { - from: $filter('date')(scope.calendarFrom.value, 'yyyy-MM-dd'), - to: $filter('date')(scope.calendarTo.value, 'yyyy-MM-dd'), - keepToday: isToToday() + label: category.toLowerCase(), + key: category }; - }; - scope.showApplyButton = function() { - if (scope.updateOnPick) { - return scope.applyChanges(); - } else { - return scope.changed = true; - } - }; - scope.applyChanges = function() { - ImpacWidgetsSvc.updateWidgetSettings(w, true); - return scope.changed = false; - }; - scope.showTitle = function() { - return element.hasClass('part'); - }; - if (w) { - w.settings.push(setting); + }); + }); + return $q.all(translationPromises); + }; + sortAccountsBy = function(getElem) { + return angular.forEach($scope.categories, function(cat) { + var sElem; + sElem = w.content.summary[cat.key]; + if (sElem.accounts) { + return sElem.accounts.sort(function(a, b) { + var res; + res = getElem(a) > getElem(b) ? 1 : getElem(a) < getElem(b) ? -1 : 0; + if (!$scope.ascending) { + res *= -1; + } + return res; + }); } - return scope.deferred.resolve(setting); - } + }); }; - }]); - -}).call(this); - -(function() { - var module; - - module = angular.module('impac.components.widgets-settings.forecast-payroll', []); - - module.controller('SettingForecastPayrollCtrl', ["$scope", "ImpacDashboardsSvc", function($scope, ImpacDashboardsSvc) { - var setting, w; - w = $scope.parentWidget; - $scope.selectedForecastPayroll = false; - $scope.toggleForecastPayroll = function() { - return $scope.selectedForecastPayroll = !$scope.selectedForecastPayroll; + sortData = function() { + if (_.isEmpty($scope.categories)) { + return; + } + if ($scope.sortedColumn === 'account') { + return sortAccountsBy(function(el) { + return el.name; + }); + } else if ($scope.sortedColumn === 'total1') { + return sortAccountsBy(function(el) { + return el.totals[1]; + }); + } else if ($scope.sortedColumn === 'total2') { + return sortAccountsBy(function(el) { + return el.totals[0]; + }); + } }; - $scope.isToggleForecastPayroll = function() { - return $scope.selectedForecastPayroll; + $scope.sort = function(col) { + if ($scope.sortedColumn === col) { + $scope.ascending = !$scope.ascending; + } else { + $scope.ascending = true; + $scope.sortedColumn = col; + } + return sortData(); }; - setting = {}; - setting.key = "forecast_payroll"; - setting.isInitialized = false; - setting.initialize = function() { - return ImpacDashboardsSvc.load().then(function(config) { - var currentDashboard; - currentDashboard = config.currentDashboard; - if (!((w.metadata != null) && (w.metadata.forecast_payroll != null))) { - return; - } - $scope.selectedForecastPayroll = w.metadata.forecast_payroll; - return setting.isInitialized = true; - }); + unCollapsedSetting = {}; + unCollapsedSetting.initialized = false; + unCollapsedSetting.initialize = function() { + return unCollapsedSetting.initialized = true; }; - setting.toMetadata = function() { + unCollapsedSetting.toMetadata = function() { return { - forecast_payroll: $scope.selectedForecastPayroll + unCollapsed: $scope.unCollapsed }; }; - w.settings.push(setting); - return $scope.deferred.resolve($scope.parentWidget); + w.settings.push(unCollapsedSetting); + return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('settingForecastPayroll', ["$templateCache", function($templateCache) { + module.directive('widgetAccountsBalanceSheet', function() { return { restrict: 'A', - scope: { - parentWidget: '=', - mode: '@?', - deferred: '=', - onSelect: '&?' - }, - template: $templateCache.get('widgets-settings/forecast-payroll.tmpl.html'), - controller: 'SettingForecastPayrollCtrl' + controller: 'WidgetAccountsBalanceSheetCtrl' }; - }]); + }); }).call(this); (function() { var module; - module = angular.module('impac.components.widgets-settings.formula', []); + module = angular.module('impac.components.widgets.accounts-cash-balance', []); - module.controller('SettingFormulaCtrl', ["$scope", "$filter", "$timeout", "$translate", function($scope, $filter, $timeout, $translate) { - var AUTHORIZED_REGEXP, evaluateFormula, formatFormula, getFormula, interpolateInFormula, isRatio, prepareFormula, setting, translateEvaluatedFormula, w; - w = $scope.parentWidget; - w.formula = ''; - AUTHORIZED_REGEXP = new RegExp("^(\\{|\\d|\\}|\\/|\\+|-|\\*|\\(|\\)|\\s|\\.)*$"); - setting = {}; - setting.key = "formula"; - setting.isInitialized = false; - setting.initialize = function() { - if ((w.metadata != null) && (w.metadata.formula != null)) { - w.formula = w.metadata.formula; - return $timeout(function() { - prepareFormula(); - return setting.isInitialized = true; - }); - } else { - return w.formula = ''; - } - }; - setting.toMetadata = function() { - prepareFormula(); - if (w.isFormulaCorrect) { - return { - formula: w.formula - }; - } else { - return { - formula: '' - }; - } + module.controller('WidgetAccountsCashBalanceCtrl', ["$scope", "$q", "$timeout", "$filter", "ImpacTheming", "ImpacAssets", "ImpacWidgetsSvc", "HighchartsFactory", function($scope, $q, $timeout, $filter, ImpacTheming, ImpacAssets, ImpacWidgetsSvc, HighchartsFactory) { + var getPeriod, getSerieByAccount, onZoom, setSeriesColors, settingsPromises, updateLocked, w, zoomMetadata; + w = $scope.widget; + $scope.orgDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise]; + getPeriod = function() { + return (w.metadata != null) && (w.metadata.hist_parameters != null) && w.metadata.hist_parameters.period || 'MONTHLY'; }; - getFormula = function() { - return w.formula; + w.initContext = function() { + var hist; + $scope.isDataFound = w.content.chart != null; + $scope.groupedTable = w.content.grouped_table; + setSeriesColors(w.content.chart.series, { + positive: '#3FC4FF', + negative: '#e50228' + }); + if (hist = w.metadata.hist_parameters) { + $scope.fromDate = hist.from; + return $scope.toDate = hist.to; + } }; - w.formatAmount = function(anAccount) { - return $filter('mnoCurrency')(anAccount.current_balance, anAccount.currency); + $scope.legendItemOnClick = function(account) { + var serie, visibility; + serie = ($scope.chart != null) && ($scope.chart.hc != null) && getSerieByAccount($scope.chart.hc.series, account); + if (!serie) { + return; + } + visibility = serie.visible ? false : true; + return serie.setVisible(visibility); }; - $scope.$watch(getFormula, function(e) { - return prepareFormula(); - }); - prepareFormula = function() { - var evaluatedFormula, interpolatedFormula; - interpolatedFormula = interpolateInFormula(w.formula, w.selectedAccounts, 'current_balance'); - if ((evaluatedFormula = evaluateFormula(interpolatedFormula))) { - w.evaluatedFormula = formatFormula(evaluatedFormula, w.formula, w.selectedAccounts); - w.legend = interpolateInFormula(w.formula, w.selectedAccounts, 'name'); - w.isFormulaCorrect = true; + $scope.getLegendItemCheckBox = function(account) { + var serie; + serie = ($scope.chart != null) && ($scope.chart.hc != null) && getSerieByAccount($scope.chart.hc.series, account); + if (!serie) { + return 'fa-check-square-o'; + } + if (serie.visible) { + return 'fa-check-square-o'; } else { - w.evaluatedFormula = 'invalid expression'; - w.legend = '...'; - w.isFormulaCorrect = false; + return 'fa-square-o'; } - return w.evaluatedFormulaTranslate = translateEvaluatedFormula(w.evaluatedFormula); }; - w.evaluatedFormula_History = function(index) { - var account, i, interpolation, j, len, pattern, ref; - interpolation = w.formula; - ref = w.selectedAccounts; - for (i = j = 0, len = ref.length; j < len; i = ++j) { - account = ref[i]; - pattern = new RegExp("\\{" + (i + 1) + "\\}", 'g'); - interpolation = interpolation.replace(pattern, " " + account['balances'][index] + " "); + $scope.getLegendItemIcon = function(account) { + var serie; + serie = ($scope.chart != null) && ($scope.chart.hc != null) && getSerieByAccount($scope.chart.hc.series, account); + if (serie.type === 'area') { + return ImpacAssets.get('areaLegendIcon'); + } else { + return ImpacAssets.get('plotLineLegendIcon'); } - return evaluateFormula(interpolation); }; - translateEvaluatedFormula = function(formula) { - switch (formula) { - case 'invalid expression': - return $translate.instant('impac.widget.formula.invalid_expression'); - case 'Infinity': - return $translate.instant('impac.widget.formula.infinity'); - case '-Infinity': - return $translate.instant('impac.widget.formula.minus_infinity'); - default: - return formula; + $scope.getLegendItemColor = function(account) { + var serie; + serie = ($scope.chart != null) && ($scope.chart.hc != null) && getSerieByAccount($scope.chart.hc.series, account); + if (!serie) { + return '#000'; } + return serie.color; }; - interpolateInFormula = function(sourceFormula, selectedAccounts, accountMember) { - var account, i, interpolation, j, len, pattern; - interpolation = sourceFormula; - if (_.isEmpty(selectedAccounts)) { - return interpolation; - } - for (i = j = 0, len = selectedAccounts.length; j < len; i = ++j) { - account = selectedAccounts[i]; - pattern = new RegExp("\\{" + (i + 1) + "\\}", 'g'); - interpolation = interpolation.replace(pattern, " " + account[accountMember] + " "); - } - return interpolation; + getSerieByAccount = function(series, account) { + return _.find(series, function(serie) { + return (serie.id || serie.options && serie.options.id) === account.id; + }); }; - evaluateFormula = function(interpolatedFormula) { - var e, evaluation; - if (!interpolatedFormula.match(AUTHORIZED_REGEXP)) { - return false; - } - try { - evaluation = eval(interpolatedFormula).toFixed(2); - if (isFinite(evaluation)) { - return evaluation; - } else { - return false; + setSeriesColors = function(series, chartColors) { + var bias, groupedSeries, i, palette, results, serie; + groupedSeries = _.groupBy(series, function(serie) { + return serie.bias; + }); + results = []; + for (bias in groupedSeries) { + series = groupedSeries[bias]; + if (!chartColors[bias]) { + continue; } - } catch (error) { - e = error; - return false; + palette = ImpacTheming.color.generateShadesPalette(chartColors[bias], series.length); + results.push((function() { + var j, len, results1; + results1 = []; + for (i = j = 0, len = series.length; j < len; i = ++j) { + serie = series[i]; + results1.push(serie.color = palette[i]); + } + return results1; + })()); } + return results; }; - isRatio = function(sourceFormula) { - return sourceFormula.match(/\//g); + $scope.chartId = function() { + return "cashBalanceChart-" + w.id; }; - formatFormula = function(evaluation, sourceFormula, selectedAccounts) { - var currency, firstAccount; - if (isRatio(sourceFormula) || _.isEmpty(selectedAccounts)) { - return evaluation; - } - firstAccount = selectedAccounts[0]; - if (!(currency = firstAccount.currency)) { - return evaluation; + updateLocked = false; + zoomMetadata = {}; + onZoom = function(event) { + zoomMetadata = angular.merge(w.metadata, { + xAxis: { + max: event.max, + min: event.min + } + }); + if (!updateLocked) { + updateLocked = true; + return $timeout(function() { + return ImpacWidgetsSvc.update(w, { + metadata: zoomMetadata + }, false)["finally"](function() { + return updateLocked = false; + }); + }, 1000); } - return $filter('mnoCurrency')(evaluation, currency); }; - w.settings.push(setting); - return $scope.deferred.resolve($scope.parentWidget); + w.format = function() { + return $timeout(function() { + var _highChartOptions; + _highChartOptions = { + chartType: 'line', + currency: w.metadata.currency, + period: getPeriod(), + showToday: true, + showLegend: false + }; + $scope.chart = new HighchartsFactory($scope.chartId(), w.content.chart.series, _highChartOptions); + $scope.chart.addXAxisOptions({ + defaults: w.metadata.xAxis, + callback: onZoom + }); + $scope.chart.removeLegend(); + return $scope.chart.render(); + }); + }; + return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('settingFormula', function() { + module.directive('widgetAccountsCashBalance', function() { return { restrict: 'A', - scope: { - parentWidget: '=', - deferred: '=' - }, - controller: 'SettingFormulaCtrl' + controller: 'WidgetAccountsCashBalanceCtrl' }; }); }).call(this); (function() { - var module, - indexOf = [].indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; }; + var module; - module = angular.module('impac.components.widgets-settings.hist-mode', []); + module = angular.module('impac.components.widgets.accounts-cash-projection', []); - module.controller('SettingHistModeCtrl', ["$scope", "$translate", "$timeout", "ImpacWidgetsSvc", "ImpacTheming", "ImpacUtilities", function($scope, $translate, $timeout, ImpacWidgetsSvc, ImpacTheming, ImpacUtilities) { - var buildCurrentLabel, setting, w; - w = $scope.parentWidget; - w.isHistoryMode = w.metadata && w.metadata.hist_parameters && w.metadata.hist_parameters.mode === 'history'; - $scope.forwardParams = { - accountingBehaviour: function() { - return $scope.accountingBehaviour; + module.controller('WidgetAccountsCashProjectionCtrl', ["$scope", "$q", "$filter", "$timeout", "ImpacKpisSvc", "ImpacWidgetsSvc", "ImpacAssets", "HighchartsFactory", "BoltResources", "ImpacMainSvc", function($scope, $q, $filter, $timeout, ImpacKpisSvc, ImpacWidgetsSvc, ImpacAssets, HighchartsFactory, BoltResources, ImpacMainSvc) { + var createUser, dateFilter, imgSrc, imgTemplate, legendFormatter, loadContacts, onClickBar, onClickLegend, onZoom, settingsPromises, todayUTC, updateLocked, w, zoomMetadata; + w = $scope.widget; + todayUTC = moment().startOf('day').add(moment().utcOffset(), 'minutes'); + updateLocked = false; + zoomMetadata = {}; + w.metadata.ranges = ['-60d', '-30d']; + dateFilter = function(timestamp) { + var pickedDate; + pickedDate = moment.utc(timestamp); + if (pickedDate <= todayUTC) { + return "lte " + (pickedDate.format('YYYY-MM-DD')); + } else { + return pickedDate.format('YYYY-MM-DD'); } }; - $scope.toggleHistMode = function(mode) { - var ref; - if ((w.isHistoryMode && mode === 'history') || (!w.isHistoryMode && mode === 'current')) { - return; - } - w.isHistoryMode = !w.isHistoryMode; - ImpacWidgetsSvc.updateWidgetSettings(w, false); - return ref = $scope.onToggle(), indexOf.call(angular.isDefined($scope.onToggle), ref) >= 0; + imgSrc = function(name) { + return ImpacAssets.get(_.camelCase(name + 'LegendIcon')); }; - buildCurrentLabel = function() { - var label, labels, needPrefix, prefix; - labels = ImpacTheming.get().widgetSettings.histModeChoser.currentLabels; - if (($scope.accountingBehaviour != null) && labels[$scope.accountingBehaviour]) { - needPrefix = !$scope.endDate || ($scope.endDate === moment().format('YYYY-MM-DD')); - label = labels[$scope.accountingBehaviour]; - prefix = labels[$scope.accountingBehaviour] + '.prefix'; - return $translate([prefix, label]).then(function(translations) { - return $scope.currentLabel = needPrefix ? translations[prefix] + " " + translations[label] : translations[label]; - }); - } else { - return $translate(labels["default"]).then(function(label) { - return $scope.currentLabel = label; + imgTemplate = function(src, name) { + return "
" + name; + }; + $scope.chartId = function() { + return "cashProjectionChart-" + w.id; + }; + $scope.orgDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise]; + $scope.trxList = { + display: false, + updated: false, + transactions: [] + }; + $scope.contacts = []; + $scope.trxList.show = function() { + return $scope.trxList.display = true; + }; + $scope.trxList.hide = function() { + $scope.trxList.display = false; + if ($scope.trxList.updated) { + return ImpacWidgetsSvc.show(w).then(function() { + return $scope.trxList.updated = false; }); } }; - setting = {}; - setting.key = "hist-mode"; - setting.isInitialized = false; - setting.initialize = function() { - return $timeout(function() { - var mode; - if ((w.metadata != null) && (w.metadata.hist_parameters != null) && (mode = w.metadata.hist_parameters.mode)) { - w.isHistoryMode = mode === 'history' ? true : false; + $scope.trxList.fetch = function(currentPage) { + var params; + if (currentPage == null) { + currentPage = 1; + } + params = angular.merge($scope.trxList.params, { + metadata: _.pick(w.metadata, 'organization_ids'), + page: { + number: currentPage + }, + sort: '-expected_payment_date', + currency: w.metadata.currency + }); + return BoltResources.index(w.metadata.bolt_path, $scope.trxList.resources, params).then(function(response) { + var contactName, i, len, ref, trx; + _.remove($scope.trxList.transactions, function() { + return true; + }); + ref = response.data.data; + for (i = 0, len = ref.length; i < len; i++) { + trx = ref[i]; + contactName = ''; + if (trx.relationships && trx.relationships.contact && trx.relationships.contact.data) { + contactName = _.find(response.data.included, function(includedContact) { + return includedContact.id === trx.relationships.contact.data.id; + }).attributes.name; + } + $scope.trxList.transactions.push(angular.merge(trx.attributes, { + id: trx.id, + contact_name: contactName + })); } - buildCurrentLabel(); - $scope.forwardParams.histParams = w.metadata && w.metadata.hist_parameters; - setting.isInitialized = true; - return $scope; + return $scope.trxList.totalRecords = response.data.meta.record_count; + })["finally"](function() { + return $scope.trxList.show(); }); }; - setting.toMetadata = function() { - var mode; - mode = w.isHistoryMode ? 'history' : 'current'; - return { - hist_parameters: { - mode: mode - } + $scope.trxList.updateParams = function(resources, filter) { + $scope.trxList.resources = resources; + return $scope.trxList.params = { + include: 'contact', + fields: { + contacts: 'name' + }, + filter: filter }; }; - w.settings.push(setting); - return $scope.deferred.resolve($scope.parentWidget); - }]); - - module.directive('settingHistMode', ["$templateCache", function($templateCache) { - return { - restrict: 'A', - scope: { - parentWidget: '=', - deferred: '=', - onToggle: '&', - accountingBehaviour: '@?', - endDate: '=?' - }, - template: $templateCache.get('widgets-settings/hist-mode.tmpl.html'), - controller: 'SettingHistModeCtrl' - }; - }]); - -}).call(this); - -(function() { - var module; - - module = angular.module('impac.components.widgets-settings.limit-entries', []); - - module.controller('SettingLimitEntriesCtrl', ["$scope", function($scope) { - var setting; - setting = {}; - setting.key = 'limit-entries'; - setting.initialize = function() { - return true; - }; - setting.toMetadata = function() { - return { - limit_entries: $scope.selected + $scope.trxList.showAll = function(resources) { + var filter; + if (resources == null) { + resources = 'invoices'; + } + filter = { + status: ['AUTHORISED', 'APPROVED', 'SUBMITTED', 'FORECAST'], + reconciliation_status: 'UNRECONCILED' }; + $scope.trxList.updateParams(resources, filter); + return $scope.trxList.fetch(); }; - $scope.parentWidget.settings.push(setting); - return $scope.deferred.resolve(setting); - }]); - - module.directive('settingLimitEntries', ["$templateCache", "ImpacWidgetsSvc", function($templateCache, ImpacWidgetsSvc) { - return { - restrict: 'A', - scope: { - parentWidget: '=', - deferred: '=', - selected: '=', - max: '=?', - options: '=?', - entriesLabel: '=?' - }, - link: function(scope, elements, attrs) { - if (!((scope.options != null) && scope.options.length > 0)) { - scope.options = [5, 15, 50]; - } - scope.selectOption = function(anOption) { - scope.selected = anOption; - return ImpacWidgetsSvc.updateWidgetSettings(scope.parentWidget, false); - }; - return scope.isOptionValid = function(anOption) { - return (scope.max == null) || anOption < scope.max; - }; - }, - controller: 'SettingLimitEntriesCtrl', - template: $templateCache.get('widgets-settings/limit-entries.tmpl.html') + $scope.trxList.updateExpectedDate = function(trxId, date) { + return BoltResources.update(w.metadata.bolt_path, $scope.trxList.resources, trxId, { + expected_payment_date: moment(date).format('YYYY-MM-DD') + }).then(function() { + return $scope.trxList.updated = true; + }); }; - }]); - -}).call(this); - -(function() { - var module; - - module = angular.module('impac.components.widgets-settings.offsets', []); - - module.directive('settingOffsets', ["$templateCache", "ImpacUtilities", function($templateCache, ImpacUtilities) { - return { - restrict: 'A', - scope: { - parentWidget: '=', - deferred: '=', - offsetsKey: '@', - initialOffsets: '=', - currency: '=', - intervalsCount: '=', - period: '=', - showIntervalsMult: '=', - textPlaceholder: '@?' - }, - template: $templateCache.get('widgets-settings/offsets.tmpl.html'), - link: function(scope) { - var authorized_regex, computedFormula, placeholder, setting, w; - w = scope.parentWidget; - authorized_regex = new RegExp("^(\\{|\\d|\\}|\\/|\\+|-|\\*|\\(|\\)|\\s|\\.)*$"); - setting = { - key: "offsets-" + scope.offsetsKey - }; - setting.initialize = function() { - var i, len, offsetValue, ref; - scope.offsets = []; - ref = scope.initialOffsets || []; - for (i = 0, len = ref.length; i < len; i++) { - offsetValue = ref[i]; - scope.offsets.push(offsetValue); - } - scope.offsetFormula = ""; - scope.periodWord = ImpacUtilities.getPeriodWord(scope.period); - return scope.placeholder = placeholder(scope.period || 'MONTHLY'); - }; - setting.toMetadata = function() { - var metadata; - metadata = { - offset: {} - }; - metadata.offset[scope.offsetsKey] = scope.offsets; - return metadata; - }; - scope.addOffset = function() { - var result; - result = computedFormula(); - if (result) { - scope.offsets.push(result); - } - return scope.offsetFormula = ""; - }; - scope.removeOffset = function(offsetIndex) { - return scope.offsets.splice(offsetIndex, 1); - }; - scope.addOffsetOnEnter = function(event) { - if (event.keyCode === 13) { - return scope.addOffset(); - } - }; - placeholder = function(inputPeriod) { - var period; - if (scope.textPlaceholder != null) { - return scope.textPlaceholder; - } - period = inputPeriod.charAt(0).toUpperCase() + inputPeriod.slice(1).toLowerCase(); - return period + " adjustment"; - }; - computedFormula = function() { - if (scope.offsetFormula.match(authorized_regex)) { - return eval(scope.offsetFormula); - } - }; - if (w) { - w.settings.push(setting); - } - return scope.deferred.resolve(setting); + $scope.trxList.changeResourcesType = function(resourcesType) { + if (resourcesType === $scope.trxList.resources) { + return; } + $scope.trxList.resources = resourcesType; + return $scope.trxList.fetch(); }; - }]); - -}).call(this); - -(function() { - var module; - - module = angular.module('impac.components.widgets-settings.organizations', []); - - module.controller('SettingOrganizationsCtrl', ["$scope", "$log", "ImpacDashboardsSvc", "ImpacMainSvc", "ImpacWidgetsSvc", function($scope, $log, ImpacDashboardsSvc, ImpacMainSvc, ImpacWidgetsSvc) { - var resetSelectedOrgs, setting, w; - w = $scope.parentWidget; - w.selectedOrganizations = {}; - $scope.mode || ($scope.mode = 'multiple'); - $scope.multiOrgMode = function() { - return $scope.mode === 'multiple'; + $scope.trxList.deleteTransaction = function(resourcesType, trxId) { + return BoltResources.destroy(w.metadata.bolt_path, resourcesType, trxId).then(function() { + return $scope.trxList.updated = true; + }); }; - $scope.singleOrgMode = function() { - return $scope.mode === 'single'; + $scope.trxList.updateSchedulableTransactions = function(resourcesType, trx) { + return $scope.trxList.updated = true; }; - resetSelectedOrgs = function() { - return w.selectedOrganizations = _.mapValues(w.selectedOrganizations, function() { - return false; + $scope.trxList.deleteChildrenTransactions = function(resourcesType, trxId) { + return BoltResources.update(w.metadata.bolt_path, resourcesType, trxId, { + recurring: false + }).then(function() { + return $scope.trxList.updated = true; }); }; - $scope.isOrganizationSelected = function(orgUid) { - return !!w.selectedOrganizations[orgUid]; + $scope.trendList = { + display: false, + updated: false, + trends: [], + params: {} }; - $scope.toggleSelectOrganization = function(orgUid) { - if ($scope.multiOrgMode()) { - w.selectedOrganizations[orgUid] = !w.selectedOrganizations[orgUid]; - if (angular.isDefined($scope.onSelect)) { - return $scope.onSelect({ - orgs: w.selectedOrganizations - }); - } - } else if ($scope.singleOrgMode()) { - resetSelectedOrgs(); - return w.selectedOrganizations[orgUid] = true; - } + $scope.trendList.show = function() { + return $scope.trendList.display = true; }; - setting = {}; - setting.key = "organizations"; - setting.isInitialized = false; - setting.initialize = function() { - return ImpacDashboardsSvc.load().then(function(config) { - var currentDashboard, currentOrganization, forceReload, i, len, org, ref, widgetOrgIds; - currentDashboard = config.currentDashboard; - $scope.dashboardOrganizations = _.sortBy(currentDashboard.data_sources, function(org) { - return org.label.toLowerCase(); + $scope.trendList.hide = function() { + $scope.trendList.display = false; + if ($scope.trendList.updated) { + return ImpacWidgetsSvc.show(w).then(function() { + return $scope.trendList.updated = false; }); - if (!((w.metadata != null) && (w.metadata.organization_ids != null))) { - return; + } + }; + $scope.trendList.fetch = function(currentPage) { + var params; + if (currentPage == null) { + currentPage = 1; + } + params = angular.merge($scope.trendList.params, { + metadata: _.pick(w.metadata, 'organization_ids'), + page: { + number: currentPage } - widgetOrgIds = w.metadata.organization_ids; - if ($scope.singleOrgMode()) { - resetSelectedOrgs(); - if (widgetOrgIds.length > 1) { - currentOrganization = ImpacMainSvc.config.currentOrganization; - w.selectedOrganizations[currentOrganization.uid] = true; - forceReload = true; - } else { - w.selectedOrganizations[widgetOrgIds[0]] = true; - } - } else if ($scope.multiOrgMode()) { - ref = $scope.dashboardOrganizations; - for (i = 0, len = ref.length; i < len; i++) { - org = ref[i]; - w.selectedOrganizations[org.uid] = _.contains(widgetOrgIds, org.uid); + }); + return BoltResources.index(w.metadata.bolt_path, 'trends', params).then(function(response) { + var i, len, ref, trend; + _.remove($scope.trendList.trends, function() { + return true; + }); + ref = response.data.data; + for (i = 0, len = ref.length; i < len; i++) { + trend = ref[i]; + if (!trend.period) { + trend.period = 'once'; } + $scope.trendList.trends.push(angular.merge(trend.attributes, { + id: trend.id + })); } - setting.isInitialized = true; - if (forceReload) { - return ImpacWidgetsSvc.updateWidgetSettings(w, true); - } + return $scope.trendList.totalRecords = response.data.meta.record_count; + })["finally"](function() { + return $scope.trendList.show(); }); }; - setting.toMetadata = function() { - var newOrganizations; - newOrganizations = _.compact(_.map(w.selectedOrganizations, function(checked, uid) { - if (checked) { - return uid; - } - })); - if (_.isEmpty(newOrganizations)) { - newOrganizations = [_.first($scope.dashboardOrganizations).uid]; - } - return { - organization_ids: newOrganizations - }; + $scope.trendList.showAll = function() { + return $scope.trendList.fetch(); }; - w.settings.push(setting); - return $scope.deferred.resolve($scope.parentWidget); - }]); - - module.directive('settingOrganizations', ["$templateCache", function($templateCache) { - return { - restrict: 'A', - scope: { - parentWidget: '=', - mode: '@?', - deferred: '=', - onSelect: '&?' - }, - template: $templateCache.get('widgets-settings/organizations.tmpl.html'), - controller: 'SettingOrganizationsCtrl' + $scope.trendList.updateTrend = function(trend) { + if (trend.period === 'once') { + trend.period = null; + } + return BoltResources.update(w.metadata.bolt_path, 'trends', trend.id, _.omit(trend, 'id')).then(function() { + return $scope.trendList.updated = true; + }); }; - }]); - -}).call(this); - -(function() { - var module; - - module = angular.module('impac.components.widgets-settings.param-selector', []); - - module.controller('SettingParamSelectorCtrl', ["$scope", "ImpacWidgetsSvc", function($scope, ImpacWidgetsSvc) { - var setting, w; - $scope.showOptions = false; - $scope.toggleShowOptions = function() { - return $scope.showOptions = !$scope.showOptions; + $scope.trendList.deleteTrend = function(trendId) { + _.remove($scope.trendList.trends, function(trend) { + return trend.id === trendId; + }); + return BoltResources.destroy(w.metadata.bolt_path, 'trends', trendId).then(function() { + return $scope.trendList.updated = true; + }); }; - $scope.onInit = function() { - $scope.selectedOption = {}; - return angular.extend($scope.selectedOption, $scope.selected); + $scope.chartDeferred = $q.defer(); + $scope.chartPromise = $scope.chartDeferred.promise; + $scope.addForecastPopup = { + resourcesType: 'invoices', + display: false, + hide: function() { + return this.display = false; + }, + show: function() { + return this.display = true; + } }; - $scope.selectOption = function(anOption) { - if (anOption.value !== $scope.selected.value) { - angular.extend($scope.selected, anOption); - ImpacWidgetsSvc.updateWidgetSettings($scope.parentWidget, !$scope.noReload); - if (angular.isDefined($scope.onSelect)) { - $scope.onSelect(); + $scope.addForecastPopup.createTransaction = function(trx, resourcesType) { + return BoltResources.create(w.metadata.bolt_path, resourcesType, { + title: trx.title, + transaction_number: "FOR-" + (Math.ceil(Math.random() * 10000)), + amount: trx.amount, + balance: trx.amount, + transaction_date: moment().format('YYYY-MM-DD'), + due_date: moment(trx.datePicker.date).format('YYYY-MM-DD'), + status: 'FORECAST', + recurring: trx.recurring, + recurring_pattern: trx.recurring_pattern, + recurring_end_date: trx.recurring_end_date ? moment(trx.recurring_end_date).format('YYYY-MM-DD') : null, + reconciliation_status: 'UNRECONCILED', + currency: w.metadata.currency + }, { + company: { + data: { + type: 'companies', + id: $scope.firstCompanyId + } + }, + contact: { + data: { + type: 'contacts', + id: trx.contact.id + } } - } - return $scope.toggleShowOptions(); + }).then(function() { + return ImpacWidgetsSvc.show(w); + }); }; - $scope.getTruncateValue = function() { - return parseInt($scope.truncateNo) || 20; + $scope.dupTrxList = { + display: false, + updated: false, + transactions: [] }; - w = $scope.parentWidget; - setting = {}; - setting.key = "param-selector"; - setting.isInitialized = false; - setting.initialize = function() { - if (w.content != null) { - return setting.isInitialized = true; - } + $scope.dupTrxList.show = function() { + return $scope.dupTrxList.display = true; }; - setting.toMetadata = function() { - var param; - param = {}; - if (!_.isEmpty($scope.selected)) { - param[$scope.param] = $scope.selected.value; + $scope.dupTrxList.hide = function() { + $scope.dupTrxList.display = false; + if ($scope.dupTrxList.updated) { + return ImpacWidgetsSvc.show(w).then(function() { + return $scope.dupTrxList.updated = false; + }); } - return param; }; - w.settings.push(setting); - return $scope.deferred.resolve($scope.parentWidget); - }]); - - module.directive('settingParamSelector', ["$templateCache", function($templateCache) { - return { - restrict: 'A', - scope: { - parentWidget: '=', - deferred: '=', - param: '@', - options: '=', - selected: '=', - truncateNo: '@', - onSelect: '&' - }, - link: function(scope, elements, attrs) { - scope.noReload = typeof attrs.noReload !== 'undefined'; - return scope.truncateNo = attrs.truncateNo || 20; - }, - template: function(elements, attrs) { - return $templateCache.get(attrs.classic ? 'widgets-settings/param-selector-classic.tmpl.html' : 'widgets-settings/param-selector.tmpl.html'); - }, - controller: 'SettingParamSelectorCtrl' + $scope.dupTrxList.fetch = function(currentPage) { + var params; + if (currentPage == null) { + currentPage = 1; + } + params = angular.merge($scope.dupTrxList.params, { + metadata: _.pick(w.metadata, 'organization_ids'), + page: { + number: currentPage + } + }); + return BoltResources.index(w.metadata.bolt_path, $scope.dupTrxList.resources, params).then(function(response) { + var i, len, ref, trx; + _.remove($scope.dupTrxList.transactions, function() { + return true; + }); + ref = response.data.data; + for (i = 0, len = ref.length; i < len; i++) { + trx = ref[i]; + $scope.dupTrxList.transactions.push(angular.merge(trx.attributes, { + id: trx.id + })); + } + return $scope.dupTrxList.totalRecords = response.data.meta.record_count; + })["finally"](function() { + return $scope.dupTrxList.show(); + }); }; - }]); - -}).call(this); - -(function() { - var module; - - module = angular.module('impac.components.widgets-settings.params-checkboxes', []); - - module.controller('SettingParamsCheckboxesCtrl', ["$scope", function($scope) { - var setting, w; - w = $scope.parentWidget; - setting = {}; - setting.key = "params-checkboxes"; - setting.initialize = function() {}; - setting.toMetadata = function() { - var param; - param = {}; - param[$scope.param] = _.map($scope.options, function(opt) { - return { - id: opt.id, - value: opt.value - }; + $scope.dupTrxList.updateParams = function(resources, filter) { + $scope.dupTrxList.resources = resources; + return $scope.dupTrxList.params = { + filter: filter + }; + }; + $scope.dupTrxList.showAll = function(resources) { + var filter; + if (resources == null) { + resources = 'invoices'; + } + filter = { + status: ['FORECAST'], + reconciliation_status: 'RECONCILING' + }; + $scope.dupTrxList.updateParams(resources, filter); + return $scope.dupTrxList.fetch(); + }; + $scope.dupTrxList.updateDuplicateTransaction = function(dupTrxId, action) { + _.remove($scope.dupTrxList.transactions, function(dupTrx) { + return dupTrx.id === dupTrxId; + }); + return BoltResources.patch(w.metadata.bolt_path, $scope.dupTrxList.resources, dupTrxId, action).then(function() { + return $scope.dupTrxList.updated = true; }); - return param; }; - w.settings.push(setting); - return $scope.deferred.resolve($scope.parentWidget); - }]); - - module.directive('settingParamsCheckboxes', ["$templateCache", function($templateCache) { - return { - restrict: 'A', - scope: { - parentWidget: '=', - deferred: '=', - param: '@', - options: '=' + $scope.dupTrxList.changeResourcesType = function(resourcesType) { + if (resourcesType === $scope.dupTrxList.resources) { + return; + } + $scope.dupTrxList.resources = resourcesType; + return $scope.dupTrxList.fetch(); + }; + $scope.addTrendPopup = { + display: false, + show: function() { + return this.display = true; }, - template: $templateCache.get('widgets-settings/params-checkboxes.tmpl.html'), - controller: 'SettingParamsCheckboxesCtrl' + hide: function() { + return this.display = false; + } }; - }]); - -}).call(this); - -(function() { - var module; - - module = angular.module('impac.components.widgets-settings.params-picker', []); - - module.controller('SettingParamsPickerCtrl', ["$scope", function($scope) { - var setting, w; - w = $scope.parentWidget; - setting = {}; - setting.key = "params-picker"; - setting.isInitialized = false; - setting.initialize = function() { - $scope.sortableOptions = { - 'ui-floating': true, - tolerance: 'pointer' - }; - $scope.applyToDashboard = w.metadata[$scope.param] && w.metadata[$scope.param].reach === 'dashboard'; - $scope.toggleReach = function() { - return setting.reach = $scope.applyToDashboard ? 'dashboard' : 'widget'; - }; - $scope.toggleReach(); - if (_.isEmpty($scope.options)) { - return setting.isInitialized = true; + $scope.addTrendPopup.lastDate = function(offset, periodicity) { + var period; + period = null; + if (offset === -1) { + return; + } + switch (periodicity) { + case 'once': + return null; + case 'daily': + period = 'days'; + break; + case 'weekly': + period = 'weeks'; + break; + case 'monthly': + period = 'months'; + break; + case 'yearly': + period = 'years'; } + return moment().add(offset, period).format('YYYY-MM-DD'); }; - setting.toMetadata = function() { - var param; - param = {}; - param[$scope.param] = { - values: _.compact(_.map($scope.options, function(statusOption) { - if (statusOption.selected) { - return statusOption.value || statusOption.label; + $scope.addTrendPopup.createTrend = function(trend) { + var last_apply_date; + if (Number.isInteger(trend.untilDate)) { + last_apply_date = $scope.addTrendPopup.lastDate(trend.untilDate, trend.period); + } else { + last_apply_date = trend.untilDate; + } + return BoltResources.create(w.metadata.bolt_path, 'trends', { + name: trend.name, + rate: trend.rate, + period: trend.period === 'once' ? null : trend.period, + start_date: trend.startDate, + last_apply_date: last_apply_date + }, { + company: { + data: { + type: 'companies', + id: $scope.firstCompanyId } - })), - reach: setting.reach - }; - return param; + }, + user: { + data: { + type: 'users', + id: $scope.userId + } + } + }).then(function() { + return ImpacWidgetsSvc.show(w); + }); }; - w.settings.push(setting); - return $scope.deferred.resolve($scope.parentWidget); - }]); - - module.directive('settingParamsPicker', ["$templateCache", "$translate", function($templateCache, $translate) { - return { - restrict: 'A', - scope: { - parentWidget: '=', - deferred: '=', - param: '@', - options: '=', - hasReach: '=', - description: '@' - }, - link: function(scope, elements, attrs) { - var paramText; - paramText = $translate.instant('impac.widget.settings.params-picker.' + scope.param); - scope.formattedParam = _.includes(paramText, 'impac.widget.settings.params-picker') ? scope.param.replace(/_/g, ' ') : paramText; - if (scope.description == null) { - return scope.description = $translate.instant('impac.widget.settings.params-picker.description'); + onClickBar = function(event) { + var filter, resources, series; + series = this; + resources = (function() { + switch (series.userOptions.stack) { + case 'Payables': + return 'bills'; + case 'Receivables': + return 'invoices'; } - }, - template: $templateCache.get('widgets-settings/params-picker.tmpl.html'), - controller: 'SettingParamsPickerCtrl' + })(); + if (resources == null) { + return; + } + filter = { + expected_payment_date: dateFilter(event.point.x), + status: ['AUTHORISED', 'APPROVED', 'SUBMITTED', 'FORECAST'], + reconciliation_status: 'UNRECONCILED' + }; + $scope.trxList.updateParams(resources, filter); + return $scope.trxList.fetch(); }; - }]); - + legendFormatter = function() { + var name; + name = this.name; + if (name !== 'Projected cash') { + return imgTemplate(imgSrc(name), name); + } + return imgTemplate(imgSrc(name), name) + '
' + imgTemplate(imgSrc('cashFlow'), 'Cash flow'); + }; + onZoom = function(event) { + zoomMetadata = angular.merge(w.metadata, { + xAxis: { + max: event.max, + min: event.min + } + }); + if (!updateLocked) { + updateLocked = true; + return $timeout(function() { + return ImpacWidgetsSvc.update(w, { + metadata: zoomMetadata + }, false)["finally"](function() { + return updateLocked = false; + }); + }, 1000); + } + }; + onClickLegend = function() { + var i, len, ref, results, s, series; + series = this; + ref = $scope.chart.hc.series; + results = []; + for (i = 0, len = ref.length; i < len; i++) { + s = ref[i]; + if (s.userOptions.linkedTo !== series.name) { + continue; + } + if (series.visible) { + results.push(s.hide()); + } else { + results.push(s.show()); + } + } + return results; + }; + loadContacts = function() { + return BoltResources.index(w.metadata.bolt_path, 'contacts', { + metadata: _.pick(w.metadata, 'organization_ids') + }).then(function(response) { + return $scope.contacts = response.data.data; + }); + }; + createUser = function() { + if ($scope.firstCompanyId) { + return BoltResources.create(w.metadata.bolt_path, 'users', { + first_name: ImpacMainSvc.config.userData.name, + last_name: ImpacMainSvc.config.userData.surname, + email: ImpacMainSvc.config.userData.email + }, { + companies: { + data: [ + { + type: 'companies', + id: $scope.firstCompanyId + } + ] + } + }).then(function(response) { + return $scope.userId = response.data.data.id; + }); + } + }; + w.initContext = function() { + var cashFlowSerie; + cashFlowSerie = _.find(w.content.chart.series, function(serie) { + return serie.name === "Cash flow"; + }); + cashFlowSerie.data = []; + cashFlowSerie.type = 'area'; + cashFlowSerie.showInLegend = false; + BoltResources.index(w.metadata.bolt_path, 'companies', { + metadata: _.pick(w.metadata, 'organization_ids') + }).then(function(response) { + if (_.isEmpty(response.data.data)) { + w.demoData = true; + } else { + w.demoData = false; + $scope.firstCompanyId = response.data.data[0].id; + } + return loadContacts(); + }); + return BoltResources.index(w.metadata.bolt_path, 'users', { + filter: { + email: ImpacMainSvc.config.userData.email + }, + metadata: _.pick(w.metadata, 'organization_ids') + }).then(function(response) { + if (response.data.meta.record_count > 0) { + return $scope.userId = response.data.data[0].id; + } else { + return createUser(); + } + }); + }; + w.format = function() { + var _highChartOptions; + _highChartOptions = { + chartType: 'line', + currency: w.metadata.currency, + showToday: true + }; + $scope.chart = new HighchartsFactory($scope.chartId(), w.content.chart.series, _highChartOptions); + $scope.chart.addCustomLegend(legendFormatter); + $scope.chart.addSeriesEvent('click', onClickBar); + $scope.chart.addSeriesEvent('legendItemClick', onClickLegend); + $scope.chart.addXAxisOptions({ + defaults: w.metadata.xAxis, + callback: onZoom + }); + $scope.chart.render(); + return $scope.chartDeferred.notify($scope.chart); + }; + return $scope.widgetDeferred.resolve(settingsPromises); + }]); + + module.directive('widgetAccountsCashProjection', function() { + return { + restrict: 'A', + controller: 'WidgetAccountsCashProjectionCtrl' + }; + }); + }).call(this); (function() { var module; - module = angular.module('impac.components.widgets-settings.tag-filter', ['ngTagsInput']); + module = angular.module('impac.components.widgets.accounts-cash-summary', []); - module.directive('settingTagFilter', ["$templateCache", "$timeout", function($templateCache, $timeout) { - return { - restrict: 'A', - scope: { - parentWidget: '=', - deferred: '=' - }, - template: $templateCache.get('widgets-settings/tag-filter.tmpl.html'), - link: function(scope) { - var asciiParseTag, filterToSettingTags, initiateAutoComplete, loadRules, setting, w; - w = scope.parentWidget; - setting = {}; - setting.key = "tag-filter"; - scope.settingsTags = []; - setting.initialize = function() { - return $timeout(function() { - loadRules(); - initiateAutoComplete(); - return true; - }); - }; - setting.toMetadata = function() { - var filterQuery, filterQueryRules; - filterQueryRules = []; - filterQuery = { - condition: 'OR', - rules: filterQueryRules - }; - angular.forEach(scope.settingsTags, function(settingsTag) { - var filterQueryCondition; - filterQueryCondition = { - condition: 'AND', - rules: [] - }; - angular.forEach(settingsTag.tags, function(filterItem) { - var ruleTag; - ruleTag = asciiParseTag(filterItem, true); - return filterQueryCondition.rules.push(ruleTag); + module.controller('WidgetAccountsCashSummaryCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "ImpacWidgetsSvc", "$translate", function($scope, $q, ChartFormatterSvc, $filter, ImpacWidgetsSvc, $translate) { + var fetchElement, getIdentifier, matchElementToSelectedElement, selectedElementSetting, settingsPromises, sortAccountsBy, sortData, unCollapsedSetting, w; + w = $scope.widget; + $scope.orgDeferred = $q.defer(); + $scope.timePeriodDeferred = $q.defer(); + $scope.widthDeferred = $q.defer(); + $scope.chartDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise, $scope.timePeriodDeferred.promise, $scope.widthDeferred.promise, $scope.chartDeferred.promise]; + $scope.ascending = true; + $scope.sortedColumn = 'account'; + w.initContext = function() { + if ($scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.summary) && !_.isEmpty(w.content.dates)) { + $scope.dates = w.content.dates; + $scope.unCollapsed = w.metadata.unCollapsed || []; + _.map(w.content.summary, function(statement) { + if (statement.name != null) { + return $translate('impac.widget.account_cash_smry.summary.' + statement.name.toLowerCase()).then(function(translation) { + return statement.label = translation; }); - if (settingsTag.tags.length !== 0) { - return filterQueryRules.push(filterQueryCondition); - } - }); - if (filterQuery.rules.length === 0) { - filterQuery = {}; - } - return { - filter_query: filterQuery - }; - }; - filterToSettingTags = function(filterQuery) { - var settingsTags; - if (_.isEmpty(filterQuery)) { - return; } - settingsTags = []; - angular.forEach(filterQuery.rules, function(filterQueryRule) { - var settingRule; - settingRule = { - operator: 'OR', - tags: [] - }; - angular.forEach(filterQueryRule.rules, function(rule) { - var ruletag, tagtext; - rule = asciiParseTag(rule); - tagtext = _.compact([rule.name, rule.value]).join(":"); - ruletag = { - value: rule.value, - text: tagtext - }; - if (rule.name != null) { - ruletag.name = rule.name; - } - return settingRule.tags.push(ruletag); - }); - return settingsTags.push(settingRule); + }); + $translate('impac.widget.account_cash_smry.cash_flow.' + $scope.widget.metadata.hist_parameters.period.toLowerCase()).then(function(translation) { + return $scope.widget.metadata.hist_parameters.period_translation = translation; + }); + if (w.metadata.selectedElement) { + $scope.selectedElement = _.find(w.content.summary, function(statement) { + return statement.name === w.metadata.selectedElement; }); - return settingsTags; - }; - loadRules = function() { - if (_.isEmpty(w.metadata.filter_query)) { - return; - } - return scope.settingsTags = filterToSettingTags(w.metadata.filter_query); - }; - initiateAutoComplete = function() { - var autotags, org, tag_hash, tags; - tags = w.content.available_tags || []; - autotags = []; - for (org in tags) { - tag_hash = tags[org]; - angular.forEach(tag_hash.tag_references, function(tag_ref) { - tag_ref = asciiParseTag(tag_ref); - return angular.forEach(tag_ref.tag_reference_values, function(tag) { - var ruletag, tagtext; - tag = asciiParseTag(tag); - tagtext = _.compact([tag_ref.name, tag.value]).join(":"); - ruletag = { - text: tagtext, - value: tag.value - }; - if (tag_ref.name != null) { - ruletag.name = tag_ref.name; - } - return autotags.push(ruletag); - }); - }); - } - return scope.loadTagList = function(query) { - return _.filter(autotags, function(e) { - return e.text.toLowerCase().indexOf(query.toLowerCase()) > -1; - }); - }; - }; - asciiParseTag = function(rule, encode) { - var meth; - if (encode == null) { - encode = false; - } - meth = encode ? encodeURIComponent : decodeURIComponent; - return _.inject(rule, function(res, v, k) { - if (_.isString(v)) { - return (res[k] = meth(v)) && res; - } else { - return (res[k] = v) && res; + $scope.selectedElement || ($scope.selectedElement = fetchElement(w.content.summary)); + } + return sortData(); + } + }; + $scope.getLastDate = function() { + if ($scope.dates != null) { + return $scope.dates[$scope.dates.length - 1]; + } + }; + $scope.getPrevDate = function() { + if ($scope.dates != null) { + return $scope.dates[$scope.dates.length - 2]; + } + }; + $scope.getLastValue = function(element) { + if (element.cash_flows != null) { + return _.last(element.cash_flows); + } + }; + $scope.formatVariance = function(aVariance) { + if (aVariance != null) { + if (aVariance > 0) { + return "+" + aVariance + " %"; + } else { + return aVariance + " %"; + } + } else { + return "-"; + } + }; + $scope.getLastVariance = function(element) { + if ((element.variances != null) && (_.last(element.variances) != null)) { + return $scope.formatVariance(_.last(element.variances)); + } else { + return "-"; + } + }; + $scope.getVarianceClassColor = function(aVariance) { + if (parseInt(aVariance) > 0) { + return 'positive'; + } else if (parseInt(aVariance) < 0) { + return 'negative'; + } else { + return null; + } + }; + $scope.getName = function(element) { + if ((element != null) && (element.name != null)) { + return element.name.replace(/_/g, " "); + } + }; + $scope.sort = function(col) { + if ($scope.sortedColumn === col) { + $scope.ascending = !$scope.ascending; + } else { + $scope.ascending = true; + $scope.sortedColumn = col; + } + return sortData(); + }; + $scope.toggleSelectedElement = function(element, statementName) { + if (statementName == null) { + statementName = null; + } + if ($scope.isSelected(element, statementName)) { + $scope.selectedElement = null; + if (w.isExpanded()) { + return w.toggleExpanded(); + } else { + return ImpacWidgetsSvc.updateWidgetSettings(w, false); + } + } else { + $scope.selectedElement = angular.copy(element); + $scope.selectedElement.category = statementName; + w.format(); + if (!w.isExpanded()) { + return w.toggleExpanded(); + } else { + return ImpacWidgetsSvc.updateWidgetSettings(w, false); + } + } + }; + $scope.isSelected = function(element, statementName) { + if (statementName == null) { + statementName = null; + } + return (element != null) && ($scope.selectedElement != null) && (matchElementToSelectedElement(element, statementName, $scope.selectedElement)); + }; + $scope.toggleCollapsed = function(element) { + if ((element != null) && (element.name != null)) { + if (_.find($scope.unCollapsed, (function(name) { + return element.name === name; + }))) { + $scope.unCollapsed = _.reject($scope.unCollapsed, function(name) { + return name === element.name; + }); + } else { + $scope.unCollapsed.push(element.name); + } + return ImpacWidgetsSvc.updateWidgetSettings(w, false); + } + }; + $scope.isCollapsed = function(element) { + if ((element != null) && (element.name != null)) { + if (_.find($scope.unCollapsed, (function(name) { + return element.name === name; + }))) { + return false; + } else { + return true; + } + if ($scope.selectedElement == null) { + return w.width = 6; + } + } + }; + $scope.getSelectLineColor = function(elem) { + return ChartFormatterSvc.getColor(0); + }; + fetchElement = function(statements) { + var element, i, len, statement; + for (i = 0, len = statements.length; i < len; i++) { + statement = statements[i]; + if (statement.accounts == null) { + continue; + } + element = _.find(statement.accounts, function(acc) { + return getIdentifier(acc, statement.name) === w.metadata.selectedElement; + }); + if (element != null) { + element = angular.merge(angular.copy(element), { + category: statement.name + }); + return element; + } + } + }; + matchElementToSelectedElement = function(element, elementCategory, sElem) { + if (elementCategory == null) { + elementCategory = null; + } + return getIdentifier(element, elementCategory) === getIdentifier(sElem); + }; + getIdentifier = function(element, category) { + var id; + if (category == null) { + category = null; + } + id = element.id || element.name; + category || (category = element.category); + if (!category) { + return id; + } + return category + "-" + id; + }; + sortAccountsBy = function(getElem) { + return angular.forEach(w.content.summary, function(sElem) { + if (sElem.accounts) { + return sElem.accounts.sort(function(a, b) { + var res; + res = getElem(a) > getElem(b) ? 1 : getElem(a) < getElem(b) ? -1 : 0; + if (!$scope.ascending) { + res *= -1; } - }, {}); - }; - scope.addRule = function() { - return scope.settingsTags.push({ - 'operator': 'OR', - 'tags': [] + return res; }); + } + }); + }; + sortData = function() { + if ($scope.sortedColumn === 'account') { + return sortAccountsBy(function(el) { + return el.name; + }); + } else if ($scope.sortedColumn === 'total') { + return sortAccountsBy(function(el) { + return $scope.getLastValue(el); + }); + } else if ($scope.sortedColumn === 'variance') { + return sortAccountsBy(function(el) { + return $scope.getLastVariance(el); + }); + } + }; + $scope.drawTrigger = $q.defer(); + w.format = function() { + var all_values_are_positive, chartData, data, dates, inputData, options, period; + if ($scope.isDataFound && ($scope.selectedElement != null)) { + data = angular.copy($scope.selectedElement); + period = null; + if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { + period = w.metadata.hist_parameters.period; + } + dates = _.map(w.content.dates, function(date) { + return $filter('momentDate')(date, period); + }); + inputData = { + labels: dates, + datasets: [ + { + title: data.label, + values: data.cash_flows + } + ] }; - scope.delRule = function(index) { - return scope.settingsTags.splice(index, 1); + all_values_are_positive = true; + angular.forEach(data.cash_flows, function(value) { + return all_values_are_positive && (all_values_are_positive = value >= 0); + }); + options = { + scaleBeginAtZero: all_values_are_positive, + showXLabels: true }; - w.settings.push(setting); - return scope.deferred.resolve(setting); + chartData = ChartFormatterSvc.combinedBarChart(inputData, options); + return $scope.drawTrigger.notify(chartData); } }; - }]); - -}).call(this); - -(function() { - var module; - - module = angular.module('impac.components.widgets-settings.time-period', []); - - module.directive('settingTimePeriod', ["$templateCache", "$q", "$log", "$timeout", "$filter", "ImpacTheming", "$translate", function($templateCache, $q, $log, $timeout, $filter, ImpacTheming, $translate) { + unCollapsedSetting = {}; + unCollapsedSetting.initialized = false; + unCollapsedSetting.initialize = function() { + return unCollapsedSetting.initialized = true; + }; + unCollapsedSetting.toMetadata = function() { + return { + unCollapsed: $scope.unCollapsed + }; + }; + w.settings.push(unCollapsedSetting); + selectedElementSetting = {}; + selectedElementSetting.initialized = false; + selectedElementSetting.initialize = function() { + return selectedElementSetting.initialized = true; + }; + selectedElementSetting.toMetadata = function() { + if ($scope.selectedElement == null) { + return { + selectedElement: null + }; + } + return { + selectedElement: getIdentifier($scope.selectedElement) + }; + }; + w.settings.push(selectedElementSetting); + return $scope.widgetDeferred.resolve(settingsPromises); + }]); + + module.directive('widgetAccountsCashSummary', function() { return { restrict: 'A', - scope: { - parentWidget: '=', - deferred: '=', - histParams: '=?', - hideChartInterval: '=?', - applyChangesCallback: '&?' - }, - template: $templateCache.get('widgets-settings/time-period.tmpl.html'), - link: function(scope) { - var getPeriod, getSetting, getUsedSettingKey, initPeriod, initUsedSetting, settingsPromises, updateFromDate, updateTimeRangePeriod, w; - w = scope.parentWidget; - scope.timePeriodSetting = { - key: "time-period", - settings: [], - isEditMode: true - }; - scope.timeSliderDeferred = $q.defer(); - scope.datesPickerDeferred = $q.defer(); - scope.timePresetsDeferred = $q.defer(); - settingsPromises = [scope.timeSliderDeferred.promise, scope.datesPickerDeferred.promise, scope.timePresetsDeferred.promise]; - scope.resetPreset = $q.defer(); - $translate(["impac.widget.settings.time_period.period.daily", "impac.widget.settings.time_period.period.weekly", "impac.widget.settings.time_period.period.monthly", "impac.widget.settings.time_period.period.quarterly", "impac.widget.settings.time_period.period.yearly", "impac.widget.settings.time_period.period.days", "impac.widget.settings.time_period.period.weeks", "impac.widget.settings.time_period.period.months", "impac.widget.settings.time_period.period.quarters", "impac.widget.settings.time_period.period.years"]).then(function(translations) { - return scope.periods = [ - { - label: translations["impac.widget.settings.time_period.period.daily"], - plural: "days", - value: "DAILY" - }, { - label: translations["impac.widget.settings.time_period.period.weekly"], - plural: "weeks", - value: "WEEKLY" - }, { - label: translations["impac.widget.settings.time_period.period.monthly"], - plural: "months", - value: "MONTHLY" - }, { - label: translations["impac.widget.settings.time_period.period.quarterly"], - plural: "quarters", - value: "QUARTERLY" - }, { - label: translations["impac.widget.settings.time_period.period.yearly"], - plural: "years", - value: "YEARLY" - } - ]; + controller: 'WidgetAccountsCashSummaryCtrl' + }; + }); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets.accounts-class-comparison', []); + + module.controller('WidgetAccountsClassComparisonCtrl', ["$scope", "$q", "$filter", "ChartFormatterSvc", "$translate", function($scope, $q, $filter, ChartFormatterSvc, $translate) { + var settingsPromises, translate, w; + w = $scope.widget; + $scope.orgDeferred = $q.defer(); + $scope.chartDeferred = $q.defer(); + $scope.paramSelectorDeferred = $q.defer(); + $scope.timePeriodDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise, $scope.chartDeferred.promise, $scope.paramSelectorDeferred.promise, $scope.timePeriodDeferred.promise]; + $scope.timePeriodInfoParams = { + accountingBehaviour: 'pnl', + histParams: {} + }; + translate = function(word) { + var translation; + word = word.toLowerCase(); + translation = $translate.instant('impac.widget.account_class_comp.klass.' + word); + if (_.includes(translation, 'impac.widget.account_class_comp.klass')) { + return _.capitalize(word); + } else { + return translation; + } + }; + w.initContext = function() { + $scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.summary) && !_.isEmpty(w.content.companies); + if ($scope.isDataFound) { + $scope.timePeriodInfoParams.histParams = w.metadata && w.metadata.hist_parameters; + $scope.classifications = _.map(w.content.summary, function(summary) { + var klass; + klass = summary.classification; + return { + label: translate(klass), + labelTranslate: summary.classification_key != null ? summary.classification_key : void 0, + value: klass + }; }); - scope.maxNumberOfPeriods = 20; - if ((ImpacTheming.get().widgetSettings != null) && (ImpacTheming.get().widgetSettings.timePeriod != null) && !_.isEmpty(ImpacTheming.get().widgetSettings.timePeriod.presets)) { - scope.presets = angular.copy(ImpacTheming.get().widgetSettings.timePeriod.presets); + if (!$scope.selectedClassification) { + return $scope.selectedClassification = angular.copy(_.find($scope.classifications, { + value: w.metadata.classification || $scope.classifications[0].value + })); } - scope.applyPreset = function(histParams) { - initPeriod(histParams); - return initUsedSetting(histParams); - }; - scope.timePeriodSetting.initialize = function() { - return $timeout(function() { - initPeriod(); - getSetting('time-presets').initialize(); - return scope.showApplyButton = angular.isDefined(scope.applyChangesCallback); - }); - }; - scope.timePeriodSetting.toMetadata = function() { - var histParams, metadata, sourceSetting; - sourceSetting = getSetting(getUsedSettingKey()); - if (sourceSetting != null) { - histParams = sourceSetting.toMetadata().hist_parameters; - } - histParams.period = getPeriod(); - if ((scope.histParams != null) && (scope.histParams.mode != null)) { - histParams.mode = scope.histParams.mode; - } - metadata = { - hist_parameters: histParams - }; - return metadata; - }; - scope.titleize = function(word) { - if (word !== "FYEARLY") { - return "" + (word.slice(0, 1).toUpperCase()) + (word.slice(1).toLowerCase()); - } else { - return "Yearly (financial)"; - } - }; - getPeriod = function() { - if (scope.timePeriodSetting.period != null) { - return scope.timePeriodSetting.period; - } else { - return initPeriod(); - } - }; - scope.isTimeSliderUsed = function() { - return getUsedSettingKey() === 'time-slider'; - }; - scope.isDatesPickerUsed = function() { - return getUsedSettingKey() === 'dates-picker'; + } + }; + $scope.getTotals = function() { + var amount; + if (!$scope.selectedClassification) { + return []; + } + return amount = _.find(w.content.summary, function(sum) { + return sum.classification === $scope.selectedClassification.value; + }).totals; + }; + $scope.getAmount = function(index) { + var amount; + amount = $scope.getTotals()[index]; + return $filter('mnoCurrency')(amount, w.content.currency); + }; + $scope.getAccountColor = function(anEntity) { + return ChartFormatterSvc.getColor(_.indexOf(w.content.companies, anEntity)); + }; + $scope.drawTrigger = $q.defer(); + w.format = function() { + var chartData, inputData, options; + if ($scope.isDataFound) { + inputData = {}; + inputData.labels = w.content.companies; + inputData.values = $scope.getTotals(); + if (inputData.labels.length > 15) { + inputData.labels.length = 15; + } + if (inputData.values.length > 15) { + inputData.values.length = 15; + } + options = { + showTooltips: false, + showXLabels: false, + barValueSpacing: Math.max(8 - w.content.companies.length, 1) }; - getUsedSettingKey = function() { - if (scope.usedSetting != null) { - return scope.usedSetting; - } else { - return initUsedSetting(); + chartData = ChartFormatterSvc.barChart(inputData, options); + return $scope.drawTrigger.notify(chartData); + } + }; + return $scope.widgetDeferred.resolve(settingsPromises); + }]); + + module.directive('widgetAccountsClassComparison', function() { + return { + restrict: 'A', + controller: 'WidgetAccountsClassComparisonCtrl' + }; + }); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets.accounts-comparison', []); + + module.controller('WidgetAccountsComparisonCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "$timeout", "$translate", function($scope, $q, ChartFormatterSvc, $filter, $timeout, $translate) { + var gatherSavedAccounts, scanAccountsForMultiOrgData, settingsPromises, w; + w = $scope.widget; + $scope.orgDeferred = $q.defer(); + $scope.accountsListDeferred = $q.defer(); + $scope.chartDeferred = $q.defer(); + $scope.paramsCheckboxesDeferred = $q.defer(); + $scope.timePeriodDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise, $scope.accountsListDeferred.promise, $scope.chartDeferred.promise, $scope.paramsCheckboxesDeferred.promise, $scope.timePeriodDeferred.promise]; + w.initContext = function() { + $scope.movedAccount = []; + return $translate('impac.widget.account_comp.compare_mode_opt').then(function(label) { + $scope.comparisonModeOptions = [ + { + id: 'compare_accounts', + label: label, + value: false, + onChangeCallback: $scope.updateSettings } - }; - getSetting = function(key) { - return _.find(scope.timePeriodSetting.settings, function(set) { - return set.key === key; + ]; + if (angular.isDefined(w.metadata.comparison_mode) && (w.metadata.organization_ids != null) && w.metadata.organization_ids.length > 1) { + angular.merge($scope.comparisonModeOptions, w.metadata.comparison_mode); + } + $scope.savedAccountsList = gatherSavedAccounts(); + $scope.isDataFound = (w.content != null) && !_.isEmpty(w.content.complete_list) || $scope.isComparisonMode(); + $scope.noComparableAccounts = $scope.isComparisonMode() && (w.content != null) && _.isEmpty(w.content.complete_list); + return $scope.canSelectComparisonMode = scanAccountsForMultiOrgData(); + }); + }; + scanAccountsForMultiOrgData = function() { + if (w.content == null) { + return false; + } + return _.uniq(_.pluck(w.content.complete_list, 'org_name')).length > 1; + }; + $scope.isComparisonMode = function() { + return _.result(_.find($scope.comparisonModeOptions, 'id', 'compare_accounts'), 'value') || false; + }; + $scope.hasAccountsSelected = function() { + return w.selectedAccounts && w.selectedAccounts.length > 0; + }; + $scope.getAccountColor = function(anAccount) { + if ($scope.isComparisonMode()) { + return ChartFormatterSvc.getColor(_.indexOf(w.selectedAccounts[0].accounts, anAccount)); + } else { + return ChartFormatterSvc.getColor(_.indexOf(w.selectedAccounts, anAccount)); + } + }; + $scope.addAccount = function(anAccount) { + if (!anAccount) { + return; + } + w.moveAccountToAnotherList(anAccount, w.remainingAccounts, w.selectedAccounts); + $scope.savedAccountsList.push(anAccount.uid); + return w.format(); + }; + $scope.removeAccount = function(anAccount) { + if (!anAccount) { + return; + } + w.moveAccountToAnotherList(anAccount, w.selectedAccounts, w.remainingAccounts); + $scope.savedAccountsList.splice($scope.savedAccountsList.indexOf(anAccount.uid), 1); + return w.format(); + }; + $scope.formatAmount = function(anAccount) { + return $filter('mnoCurrency')(anAccount.current_balance, anAccount.currency); + }; + gatherSavedAccounts = function() { + var areGrouped, group, i, len, savedUids, uid; + savedUids = w.metadata.accounts_list; + if (_.isEmpty(savedUids)) { + return []; + } + areGrouped = savedUids[0].indexOf(':') >= 0; + if (!$scope.isComparisonMode() && areGrouped) { + return _.flatten(_.map(savedUids, function(a) { + return a.split(':'); + })); + } else if ($scope.isComparisonMode() && !areGrouped) { + for (i = 0, len = savedUids.length; i < len; i++) { + uid = savedUids[i]; + group = _.find(w.content.complete_list, function(group) { + return group.uid.indexOf(uid) >= 0; }); - }; - initPeriod = function(histParams) { - if (histParams == null) { - histParams = null; - } - if (histParams == null) { - histParams = scope.histParams; - } - if ((histParams != null) && (histParams.period != null) && _.find(scope.periods, function(period) { - return period.value === histParams.period; - })) { - scope.timePeriodSetting.period = angular.copy(histParams.period); - } else { - scope.timePeriodSetting.period = "MONTHLY"; - } - return scope.timePeriodSetting.period; - }; - initUsedSetting = function(histParams) { - var minDate, newLetter, pattern, tr; - if (histParams == null) { - histParams = null; - } - if (histParams == null) { - histParams = scope.histParams; + if (group) { + return [group.uid]; } - if ((histParams != null) && (histParams.from != null)) { - scope.usedSetting = 'dates-picker'; - scope.toDate = histParams.to; - minDate = scope.getMinDate(scope.toDate); - if (moment(histParams.from, "YYYY-MM-DD").isBefore(minDate)) { - scope.fromDate = minDate; - } else { - scope.fromDate = histParams.from; + } + return []; + } else { + return savedUids; + } + }; + $scope.drawTrigger = $q.defer(); + w.format = function() { + var inputData; + inputData = { + labels: [], + values: [] + }; + return $timeout(function() { + var account, chartData, groupedAccount, i, j, len, len1, options, ref, ref1; + ref = w.selectedAccounts; + for (i = 0, len = ref.length; i < len; i++) { + account = ref[i]; + if ($scope.isComparisonMode()) { + ref1 = account.accounts; + for (j = 0, len1 = ref1.length; j < len1; j++) { + groupedAccount = ref1[j]; + inputData.labels.push(groupedAccount.name); + inputData.values.push(groupedAccount.current_balance); } - scope.keepToday = histParams.keep_today; - getSetting('dates-picker').initialize(); } else { - scope.usedSetting = 'time-slider'; - if ((histParams != null) && (histParams.time_range != null)) { - tr = histParams.time_range; - pattern = /([a-z])/; - newLetter = pattern.exec(tr)[1]; - scope.timePeriodSetting.period = angular.copy(_.find(scope.periods, function(p) { - return p.value.slice(0, 1).toLowerCase() === newLetter; - }).value); - scope.timePeriodSetting.timeRange = tr; - } - getSetting('time-slider').initialize(); - } - return scope.usedSetting; - }; - scope.updateSettings = function() { - if (scope.usedSetting === 'time-slider') { - scope.resetPreset.notify('choose-period'); - } else if (scope.usedSetting === 'dates-picker') { - scope.resetPreset.notify('choose-dates'); - } - updateTimeRangePeriod(); - return updateFromDate(); - }; - updateTimeRangePeriod = function() { - var periodLetter, set, tr; - if (scope.isTimeSliderUsed()) { - set = getSetting('time-slider'); - tr = set.toMetadata().hist_parameters.time_range; - periodLetter = getPeriod().slice(0, 1).toLowerCase(); - scope.timePeriodSetting.timeRange = tr.replace(/[a-z]/, periodLetter); - set.initialize(); - } - return scope.timePeriodSetting.timeRange; - }; - updateFromDate = function() { - var fromDate, minDate, set, toDate; - if (scope.isDatesPickerUsed()) { - set = getSetting('dates-picker'); - fromDate = set.toMetadata().hist_parameters.from; - toDate = set.toMetadata().hist_parameters.to; - minDate = scope.getMinDate(); - if (moment(fromDate, "YYYY-MM-DD").isBefore(minDate)) { - scope.toDate = toDate; - scope.fromDate = minDate; - set.initialize(); - } - } - return scope.fromDate; - }; - scope.useTimeSlider = function() { - scope.usedSetting = 'time-slider'; - return scope.updateSettings(); - }; - scope.useDatesPicker = function() { - scope.usedSetting = 'dates-picker'; - return scope.updateSettings(); - }; - scope.getMinDate = function(toDate) { - var currentPeriod, periodWord, sourceSetting, to; - if (toDate == null) { - toDate = void 0; - } - to = moment(); - if (toDate != null) { - to = moment(toDate, "YYYY-MM-DD"); - } else if ((scope.usedSetting != null) && scope.isDatesPickerUsed()) { - sourceSetting = getSetting('dates-picker'); - to = moment(sourceSetting.toMetadata().hist_parameters.to, "YYYY-MM-DD"); - } - currentPeriod = getPeriod(); - periodWord = _.find(scope.periods, function(period) { - return currentPeriod === period.value; - }).plural; - return to.subtract(scope.maxNumberOfPeriods, periodWord); - }; - scope.formattedMinDate = function(toDate) { - if (toDate == null) { - toDate = void 0; + inputData.labels.push(account.name); + inputData.values.push(account.current_balance); } - return $filter('momentDate')(scope.getMinDate(toDate), 'time-period'); + } + while (inputData.values.length < 15) { + inputData.labels.push(""); + inputData.values.push(null); + } + options = { + showTooltips: false, + showXLabels: false, + barDatasetSpacing: 9 }; - w.settings.push(scope.timePeriodSetting); - return $q.all(settingsPromises).then(function() { - return scope.deferred.resolve(scope.timePeriodSetting); - }); - } + chartData = ChartFormatterSvc.barChart(inputData, options); + return $scope.drawTrigger.notify(chartData); + }, 500); }; + return $scope.widgetDeferred.resolve(settingsPromises); }]); + module.directive('widgetAccountsComparison', function() { + return { + restrict: 'A', + controller: 'WidgetAccountsComparisonCtrl' + }; + }); + }).call(this); (function() { var module; - module = angular.module('impac.components.widgets-settings.time-presets', []); + module = angular.module('impac.components.widgets.accounts-custom-calculation', []); - module.directive('settingTimePresets', ["$templateCache", "ImpacMainSvc", "$timeout", "ImpacUtilities", "ImpacTheming", "$translate", function($templateCache, ImpacMainSvc, $timeout, ImpacUtilities, ImpacTheming, $translate) { - return { - restrict: 'A', - scope: { - parentWidget: '=', - deferred: '=', - presets: '=?', - onSelect: '&?', - onChooseDates: '&?', - onChoosePeriod: '&?', - histParams: '=?', - resetPromise: '=?' - }, - template: $templateCache.get('widgets-settings/time-presets.tmpl.html'), - link: function(scope) { - var fyEndMonth, initPreset, showSlider, w; - w = scope.parentWidget; - scope.setting = {}; - scope.setting.key = "time-presets"; - scope.financialYearEndMonth = 6; - fyEndMonth = scope.financialYearEndMonth; - ImpacMainSvc.load().then(function() { - return fyEndMonth = ImpacMainSvc.getFinancialYearEndMonth(); - })["finally"](function() { - var fyStartDate, prevFyEndDate, prevFyStartDate, toDate; - fyStartDate = ImpacUtilities.financialYearDates(fyEndMonth).start; - prevFyStartDate = moment(ImpacUtilities.financialYearDates(fyEndMonth).start, 'YYYY-MM-DD').subtract(1, 'year').format('YYYY-MM-DD'); - prevFyEndDate = moment(ImpacUtilities.financialYearDates(fyEndMonth).end, 'YYYY-MM-DD').subtract(1, 'year').format('YYYY-MM-DD'); - toDate = moment().format('YYYY-MM-DD'); - return $translate(['impac.common.period.preset_in_words.calendar_year_to_date', 'impac.common.period.preset_in_words.financial_year_to_date', 'impac.common.period.preset_in_words.previous_financial_year', 'impac.common.period.preset_in_words.last_6_months', 'impac.common.period.preset_in_words.last_4_quarters', 'impac.common.period.preset_in_words.last_4_weeks', 'impac.common.period.preset_in_words.choose_period', 'impac.common.period.preset_in_words.choose_dates']).then(function(translations) { - scope.presets || (scope.presets = [ - { - label: translations['impac.common.period.preset_in_words.calendar_year_to_date'], - value: { - from: moment().startOf('year').format('YYYY-MM-DD'), - to: toDate, - period: 'MONTHLY' - } - }, { - label: translations['impac.common.period.preset_in_words.financial_year_to_date'], - value: { - from: fyStartDate, - to: toDate, - period: 'MONTHLY' - } - }, { - label: translations['impac.common.period.preset_in_words.previous_financial_year'], - value: { - from: prevFyStartDate, - to: prevFyEndDate, - period: 'MONTHLY' - } - }, { - label: translations['impac.common.period.preset_in_words.last_6_months'], - value: { - time_range: '-6m', - to: toDate - } - }, { - label: translations['impac.common.period.preset_in_words.last_4_quarters'], - value: { - time_range: '-4q', - to: toDate - } - }, { - label: translations['impac.common.period.preset_in_words.last_4_weeks'], - value: { - time_range: '-4w', - to: toDate - } - } - ]); - if (angular.isDefined(scope.onChooseDates) && showSlider()) { - scope.presets.unshift({ - label: translations['impac.common.period.preset_in_words.choose_period'], - value: 'choose-period' - }); - } - if (angular.isDefined(scope.onChooseDates)) { - return scope.presets.unshift({ - label: translations['impac.common.period.preset_in_words.choose_dates'], - value: 'choose-dates' - }); - } - }); - }); - if (scope.resetPromise != null) { - scope.resetPromise.then(null, null, function(key) { - return scope.selectedPreset = _.find(scope.presets, function(p) { - return p.value === key; - }); - }); + module.controller('WidgetAccountsCustomCalculationCtrl', ["$scope", "$timeout", "$uibModal", "$q", "$templateCache", "$filter", "ImpacWidgetsSvc", "ChartFormatterSvc", function($scope, $timeout, $uibModal, $q, $templateCache, $filter, ImpacWidgetsSvc, ChartFormatterSvc) { + var settingsPromises, w; + w = $scope.widget; + $scope.orgDeferred = $q.defer(); + $scope.accountsListDeferred = $q.defer(); + $scope.formulaDeferred = $q.defer(); + $scope.histModeDeferred = $q.defer(); + $scope.chartDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise, $scope.accountsListDeferred.promise, $scope.formulaDeferred.promise, $scope.histModeDeferred.promise, $scope.chartDeferred.promise]; + w.initContext = function() { + $scope.movedAccount = {}; + return $scope.isDataFound = (w.content != null) && !_.isEmpty(w.content.complete_list); + }; + $scope.drawTrigger = $q.defer(); + w.format = function() { + return $timeout(function() { + var all_values_are_positive, chartData, data, dates, inputData, options, period; + all_values_are_positive = true; + inputData = []; + period = null; + if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { + period = w.metadata.hist_parameters.period; } - showSlider = function() { - return (ImpacTheming.get().widgetSettings != null) && (ImpacTheming.get().widgetSettings.timePeriod != null) && ImpacTheming.get().widgetSettings.timePeriod.showSlider; - }; - initPreset = function() { - if (scope.histParams != null) { - scope.selectedPreset = _.find(scope.presets, function(p) { - return _.every(p.value, function(v, k) { - return scope.histParams[k] === (angular.isFunction(v) ? v(fyEndMonth) : v); - }); - }); - if ((scope.selectedPreset == null) && (scope.histParams.time_range != null) && showSlider()) { - scope.selectedPreset = scope.presets[1]; - } - } - if (scope.selectedPreset == null) { - return scope.selectedPreset = scope.presets[0]; - } - }; - scope.presetSelected = function() { - if ((scope.selectedPreset != null) && (scope.selectedPreset.value === "choose-dates")) { - return scope.onChooseDates(); - } else if ((scope.selectedPreset != null) && (scope.selectedPreset.value === "choose-period")) { - return scope.onChoosePeriod(); - } else { - return scope.onSelect({ - histParams: scope.setting.toMetadata().hist_parameters - }); - } - }; - scope.setting.initialize = function() { - initPreset(); - scope.presetSelected(); - return true; - }; - scope.setting.toMetadata = function() { - var result; - result = {}; - if (!_.isEmpty(scope.selectedPreset.value)) { - _.forEach(scope.selectedPreset.value, function(value, key) { - if (angular.isFunction(value)) { - return result[key] = value(fyEndMonth); - } else { - return result[key] = value; - } - }); - } - return { - hist_parameters: result - }; + dates = _.map(w.content.dates, function(date) { + return $filter('momentDate')(date, period); + }); + data = _.map(w.content.dates, function(date, index) { + var value; + value = w.evaluatedFormula_History(index); + all_values_are_positive && (all_values_are_positive = value >= 0); + return value; + }); + inputData.push({ + title: 'Test Data', + labels: dates, + values: data + }); + options = { + scaleBeginAtZero: all_values_are_positive, + showXLabels: false, + datasetFill: true, + pointDot: true }; - w.settings.push(scope.setting); - return scope.deferred.resolve(scope.setting); + chartData = ChartFormatterSvc.lineChart(inputData, options); + return $scope.drawTrigger.notify(chartData); + }, 500); + }; + $scope.addAccountToFormula = function(account) { + if (account == null) { + return; + } + if (w.selectedAccounts.length > 0) { + w.formula += " + {" + (w.selectedAccounts.length + 1) + "}"; + } else { + w.formula = "{1}"; + } + return w.moveAccountToAnotherList(account, w.remainingAccounts, w.selectedAccounts, false); + }; + $scope.removeAccountFromFormula = function(account) { + var diffAccountIndex, diffAccountUid, i, indexPattern, newFormula, nextUids, prevUids, removePattern; + prevUids = _.map(w.selectedAccounts, function(e) { + return e.uid; + }); + nextUids = _.reject(prevUids, function(e) { + return e === account.uid; + }); + diffAccountUid = _.first(_.difference(prevUids, nextUids)); + diffAccountIndex = _.indexOf(prevUids, diffAccountUid) + 1; + if (diffAccountIndex === 1) { + removePattern = "{" + diffAccountIndex + "\\}\\s*(-|\\*|\\/|\\+)*\\s*"; + } else { + removePattern = "\\s*(-|\\*|\\/|\\+)*\\s*\\{" + diffAccountIndex + "\\}"; + } + newFormula = angular.copy(w.formula).replace(new RegExp(removePattern, 'g'), ''); + i = diffAccountIndex + 1; + while (i <= prevUids.length) { + indexPattern = "\\{" + i + "\\}"; + newFormula = newFormula.replace(new RegExp(indexPattern, 'g'), "{" + (i - 1) + "}"); + i++; + } + w.formula = angular.copy(newFormula); + return w.moveAccountToAnotherList(account, w.selectedAccounts, w.remainingAccounts, false); + }; + $scope.formulaModal = $scope.$new(); + $scope.formulaModal.config = { + backdrop: 'static', + template: $templateCache.get('widgets/accounts-custom-calculation/formula.modal.html'), + size: 'lg', + scope: $scope.formulaModal, + keyboard: false + }; + $scope.formulaModal.open = function() { + var self; + self = $scope.formulaModal; + self.modalOrgDeferred = $q.defer(); + self.timePeriodDeferred = $q.defer(); + _.remove(w.settings, (function(set) { + return set.key === "organizations"; + })); + self.instance = $uibModal.open(self.config); + return $q.all([self.modalOrgDeferred.promise, self.timePeriodDeferred.promise]).then(function(success) { + return $scope.initSettings(); + }); + }; + $scope.reloadAccountsLists = function(orgs) { + if ((orgs != null) && _.some(_.values(orgs))) { + return $scope.updateWidgetSettings(); } }; + $scope.updateWidgetSettings = function() { + return ImpacWidgetsSvc.updateWidgetSettings(w); + }; + $scope.formulaModal.cancel = function() { + $scope.initSettings(); + return $scope.formulaModal.close(); + }; + $scope.formulaModal.proceed = function() { + ImpacWidgetsSvc.updateWidgetSettings(w); + return $scope.formulaModal.close(); + }; + $scope.formulaModal.close = function() { + return $scope.formulaModal.instance.close(); + }; + $scope.$watch((function() { + return w.isEditMode; + }), function(result, prev) { + if (result && !prev) { + return $scope.formulaModal.open(); + } + }); + return $scope.widgetDeferred.resolve(settingsPromises); }]); + module.directive('widgetAccountsCustomCalculation', function() { + return { + restrict: 'A', + controller: 'WidgetAccountsCustomCalculationCtrl' + }; + }); + }).call(this); (function() { var module; - module = angular.module('impac.components.widgets-settings.time-slider', []); + module = angular.module('impac.components.widgets.accounts-detailed-classifications', []); - module.directive('settingTimeSlider', ["$templateCache", "$timeout", "ImpacMainSvc", "ImpacUtilities", "ImpacTheming", function($templateCache, $timeout, ImpacMainSvc, ImpacUtilities, ImpacTheming) { - return { - restrict: 'A', - scope: { - parentWidget: '=', - deferred: '=', - timeRange: '=?', - onUse: '&?' - }, - template: $templateCache.get('widgets-settings/time-slider.tmpl.html'), - link: function(scope) { - var PERIODS, getNumberOfPeriods, getPeriod, getPeriodWord, getTimeRange, initFinancialYearEndMonth, initNumberOfPeriods, initPeriod, setting, w; - w = scope.parentWidget; - setting = {}; - setting.key = "time-slider"; - PERIODS = ['d', 'w', 'm', 'q', 'y', 'f']; - setting.initialize = function() { - return $timeout(function() { - initNumberOfPeriods(); - initPeriod(); - initFinancialYearEndMonth(); - return true; + module.controller('WidgetAccountsDetailedClassificationsCtrl', ["$scope", "$q", "ImpacWidgetsSvc", function($scope, $q, ImpacWidgetsSvc) { + var settingsPromises, sortAccountsBy, sortData, unCollapsedSetting, w; + w = $scope.widget; + $scope.orgDeferred = $q.defer(); + $scope.timePeriodDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise, $scope.timePeriodDeferred.promise]; + $scope.timePeriodInfoParams = { + accountingBehaviour: 'pnl', + histParams: {} + }; + $scope.ascending = true; + $scope.sortedColumn = 'account'; + w.initContext = function() { + $scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.companies); + if ($scope.isDataFound) { + $scope.timePeriodInfoParams.histParams = w.metadata && w.metadata.hist_parameters; + $scope.unCollapsed = w.metadata.unCollapsed || []; + if (w.content.companies.length === 1) { + $scope.multiEntity = false; + $scope.dataSource = _.map(w.content.companies[0].classifications, function(klass) { + return { + label: klass.name, + value: klass.total, + currency: klass.currency, + entries: _.map(klass.accounts, function(acc) { + return { + label: acc.name, + value: acc.balance, + currency: acc.currency + }; + }) + }; }); - }; - setting.toMetadata = function() { - var histParams; - histParams = { - to: scope.toDate().format('YYYY-MM-DD'), - time_range: getTimeRange() - }; - if (getPeriod() === 'f') { - histParams.from = scope.fromDate().format('YYYY-MM-DD'); - } - return { - hist_parameters: histParams - }; - }; - initNumberOfPeriods = function() { - var n, nPattern, tr; - tr = scope.timeRange; - scope.numberOfPeriods = moment().month(); - if (tr == null) { - return scope.numberOfPeriods; - } - nPattern = /^-?([0-9]{1,2})[a-z]?$/; - n = nPattern.exec(tr); - if ((n != null) && n[1] && parseInt(n[1])) { - scope.numberOfPeriods = parseInt(n[1]); - } - return scope.numberOfPeriods; - }; - initPeriod = function() { - var p, pPattern, period, tr; - tr = scope.timeRange; - scope.period = "m"; - if (tr == null) { - return "m"; - } - pPattern = /^-?[0-9]{0,2}([a-z])$/; - p = pPattern.exec(tr); - period = _.find(PERIODS, function(authPeriod) { - return (p != null) && (p[1] === authPeriod); + } else { + $scope.multiEntity = true; + $scope.dataSource = _.map(w.content.companies, function(company) { + return { + label: company.name, + entries: _.map(company.classifications, function(klass) { + return { + label: klass.name, + value: klass.total, + currency: klass.currency + }; + }) + }; }); - if (period != null) { - scope.period = period; - } - return scope.period; - }; - initFinancialYearEndMonth = function() { - scope.financialYearEndMonth = 6; - return ImpacMainSvc.load().then(function(config) { - if ((config != null) && (config.currentOrganization != null) && parseInt(config.currentOrganization.financial_year_end_month)) { - return scope.financialYearEndMonth = parseInt(config.currentOrganization.financial_year_end_month); - } + } + return sortData(); + } + }; + $scope.toggleCollapsed = function(groupName) { + if (groupName != null) { + if (_.find($scope.unCollapsed, (function(name) { + return groupName === name; + }))) { + $scope.unCollapsed = _.reject($scope.unCollapsed, function(name) { + return name === groupName; }); - }; - getPeriod = function() { - if (scope.period != null) { - return scope.period; - } else { - return initPeriod(); - } - }; - getPeriodWord = function() { - return ImpacUtilities.getPeriodWord(getPeriod()); - }; - getNumberOfPeriods = function() { - if (scope.numberOfPeriods != null) { - return scope.numberOfPeriods; - } else { - return initNumberOfPeriods(); - } - }; - getTimeRange = function() { - var n, p; - n = getNumberOfPeriods(); - p = getPeriod(); - return "-" + n + p; - }; - scope.formatPeriod = function() { - return ImpacUtilities.formatPeriod(getNumberOfPeriods(), getPeriod()); - }; - scope.fromDate = function() { - var financialYearStartYear, n, word; - n = getNumberOfPeriods(); - word = getPeriodWord(); - if (word.slice(0, 1) === "f") { - financialYearStartYear = moment().year() - 1; - if (moment().month() >= 6) { - financialYearStartYear = moment().year(); + } else { + $scope.unCollapsed.push(groupName); + } + return ImpacWidgetsSvc.updateWidgetSettings(w, false); + } + }; + $scope.isCollapsed = function(groupName) { + if (groupName != null) { + if (_.find($scope.unCollapsed, (function(name) { + return groupName === name; + }))) { + return false; + } else { + return true; + } + } + }; + sortAccountsBy = function(getElem) { + return angular.forEach($scope.dataSource, function(sElem) { + if (sElem.entries) { + return sElem.entries.sort(function(a, b) { + var res; + res = getElem(a) > getElem(b) ? 1 : getElem(a) < getElem(b) ? -1 : 0; + if (!$scope.ascending) { + res *= -1; } - financialYearStartYear = financialYearStartYear - n; - return moment(financialYearStartYear + "-" + (scope.financialYearEndMonth + 1) + "-01", "YYYY-M-DD"); - } else if (word.slice(0, 1) === "w") { - return moment().subtract(n, word).startOf('isoweek'); - } else { - return moment().subtract(n, word).startOf(word); - } - }; - scope.toDate = function() { - return moment(); - }; - w.settings.push(setting); - return scope.deferred.resolve(setting); + return res; + }); + } + }); + }; + sortData = function() { + if ($scope.sortedColumn === 'account') { + return sortAccountsBy(function(el) { + return el.label; + }); + } else if ($scope.sortedColumn === 'total') { + return sortAccountsBy(function(el) { + return el.value; + }); + } + }; + $scope.sort = function(col) { + if ($scope.sortedColumn === col) { + $scope.ascending = !$scope.ascending; + } else { + $scope.ascending = true; + $scope.sortedColumn = col; } + return sortData(); }; + unCollapsedSetting = {}; + unCollapsedSetting.initialized = false; + unCollapsedSetting.initialize = function() { + return unCollapsedSetting.initialized = true; + }; + unCollapsedSetting.toMetadata = function() { + return { + unCollapsed: $scope.unCollapsed + }; + }; + w.settings.push(unCollapsedSetting); + return $scope.widgetDeferred.resolve(settingsPromises); }]); + module.directive('widgetAccountsDetailedClassifications', function() { + return { + restrict: 'A', + controller: 'WidgetAccountsDetailedClassificationsCtrl' + }; + }); + }).call(this); (function() { var module; - module = angular.module('impac.components.widgets-settings.width', []); + module = angular.module('impac.components.widgets.accounts-expense-weight', []); - module.controller('SettingWidthCtrl', ["$scope", "$element", "$timeout", "$log", "ImpacWidgetsSvc", "ImpacDashboardsSvc", function($scope, $element, $timeout, $log, ImpacWidgetsSvc, ImpacDashboardsSvc) { - var elem, hideOnResize, i, len, ref, setting, w; - w = $scope.parentWidget; - setting = {}; - setting.key = "width"; - setting.isInitialized = false; - ref = $element.parents(); - for (i = 0, len = ref.length; i < len; i++) { - elem = ref[i]; - if (angular.element(elem).hasClass('content')) { - $scope.contentElements = angular.element(elem).children(); - break; - } - } - hideOnResize = function(elements) { - var j, len1; - if (!(elements && elements.length > 0)) { - return; - } - for (j = 0, len1 = elements.length; j < len1; j++) { - elem = elements[j]; - angular.element(elem).animate({ - opacity: 0 - }, 0); - } - return $timeout(function() { - var k, len2, results; - results = []; - for (k = 0, len2 = elements.length; k < len2; k++) { - elem = elements[k]; - results.push(angular.element(elem).animate({ - opacity: 1 - }, 200)); - } - return results; - }, 300); - }; - w.toggleExpanded = function(save) { - if (save == null) { - save = true; - } - $scope.expanded = !$scope.expanded; - if (save) { - ImpacWidgetsSvc.updateWidgetSettings(w, false, true); - } - hideOnResize($scope.contentElements); - if ($scope.expanded) { - return w.width = parseInt($scope.max); - } else { - return w.width = parseInt($scope.min); - } + module.controller('WidgetAccountsExpenseWeightCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "$translate", "$timeout", function($scope, $q, ChartFormatterSvc, $filter, $translate, $timeout) { + var settingsPromises, w; + w = $scope.widget; + $scope.orgDeferred = $q.defer(); + $scope.timePeriodDeferred = $q.defer(); + $scope.accountBackDeferred = $q.defer(); + $scope.accountFrontDeferred = $q.defer(); + $scope.chartDeferred = $q.defer(); + $scope.histModeDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise, $scope.timePeriodDeferred, $scope.accountBackDeferred, $scope.accountFrontDeferred, $scope.chartDeferred.promise, $scope.histModeDeferred.promise]; + $scope.forwardParams = { + accountingBehaviour: 'pnl' }; - w.isExpanded = function() { - return $scope.expanded; + w.initContext = function() { + $scope.isDataFound = (w.content != null) && !_.isEmpty(w.content.account_list); + return $scope.forwardParams.histParams = w.metadata && w.metadata.hist_parameters; }; - setting.initialize = function() { - if (w.width != null) { - $scope.expanded = w.width === parseInt($scope.max); - return setting.isInitialized = true; + $scope.getName = function() { + if (w.selectedAccount != null) { + return w.selectedAccount.name; } }; - setting.toMetadata = function() { - var newWidth; - if ($scope.expanded) { - newWidth = $scope.max; - } else { - newWidth = $scope.min; + $scope.getComparator = function() { + switch (w.metadata.comparator) { + case 'turnover': + return $translate.instant("impac.widget.account_expense_weight.comparator.turnover"); + default: + return $translate.instant("impac.widget.account_expense_weight.comparator.total_exp"); } - return { - width: parseInt(newWidth) - }; }; - ImpacDashboardsSvc.pdfModeEnabled().then(null, null, function() { - $scope.pdfMode = true; - $scope.initiallyExpanded = !!$scope.expanded; - if (!$scope.initiallyExpanded) { - return w.toggleExpanded(false); - } - }); - ImpacDashboardsSvc.pdfModeCanceled().then(null, null, function() { - $scope.pdfMode = false; - if (!$scope.initiallyExpanded) { - return w.toggleExpanded(false); + $scope.displayAccount = function() { + return $scope.updateSettings(false).then(function() { + return $timeout(function() { + return w.format(); + }); + }); + }; + $scope.drawTrigger = $q.defer(); + w.format = function() { + var all_values_are_positive, chartData, companies, datasets, dates, inputData, lineData, lineOptions, options, period, ratios; + if ($scope.isDataFound && (w.content.summary != null)) { + if (w.isHistoryMode) { + period = null; + if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { + period = w.metadata.hist_parameters.period; + } + dates = _.map(w.content.dates, function(date) { + return $filter('momentDate')(date, period); + }); + datasets = _.map(w.content.summary, function(s) { + return { + title: s.company, + values: s.ratios + }; + }); + all_values_are_positive = true; + angular.forEach(w.content.summary, function(s) { + return angular.forEach(s.ratios, function(ratio) { + return all_values_are_positive && (all_values_are_positive = ratio >= 0); + }); + }); + lineData = { + labels: dates, + datasets: datasets + }; + lineOptions = { + scaleBeginAtZero: all_values_are_positive, + showXLabels: false, + currency: "(ratio)" + }; + chartData = ChartFormatterSvc.combinedBarChart(lineData, lineOptions, false, true); + } else { + companies = _.map(w.content.summary, function(s) { + return s.company; + }); + ratios = _.map(w.content.summary, function(s) { + return s.ratio; + }); + if (companies.length === 1) { + companies.push(companies[0]); + ratios.push(ratios[0]); + } + inputData = { + labels: companies, + values: ratios + }; + options = { + scales: { + yAxes: [ + { + ticks: { + suggestedMin: 0, + suggestedMax: 100, + maxTicksLimit: 5 + } + } + ] + }, + showXLabels: false, + pointDot: false, + currency: '%' + }; + chartData = ChartFormatterSvc.lineChart([inputData], options); + } + return $scope.drawTrigger.notify(chartData); } - }); - w.settings.push(setting); - return $scope.deferred.resolve($scope.parentWidget); + }; + return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('settingWidth', ["$templateCache", function($templateCache) { + module.directive('widgetAccountsExpenseWeight', function() { return { restrict: 'A', - scope: { - parentWidget: '=', - deferred: '=', - min: '@', - max: '@' - }, - template: $templateCache.get('widgets-settings/width.tmpl.html'), - controller: 'SettingWidthCtrl' + controller: 'WidgetAccountsExpenseWeightCtrl' }; - }]); + }); }).call(this); (function() { var module; - module = angular.module('impac.components.widgets.accounts-accounting-values', []); + module = angular.module('impac.components.widgets.accounts-expenses-revenue', []); - module.controller('WidgetAccountsAccountingValuesCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "$translate", function($scope, $q, ChartFormatterSvc, $filter, $translate) { + module.controller('WidgetAccountsExpensesRevenueCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "$translate", function($scope, $q, ChartFormatterSvc, $filter, $translate) { var settingsPromises, w; w = $scope.widget; $scope.orgDeferred = $q.defer(); $scope.timePeriodDeferred = $q.defer(); $scope.histModeDeferred = $q.defer(); $scope.chartDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.timePeriodDeferred.promise, $scope.histModeDeferred.promise, $scope.chartDeferred.promise]; + $scope.paramsCheckboxesDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise, $scope.timePeriodDeferred.promise, $scope.histModeDeferred.promise, $scope.chartDeferred.promise, $scope.paramsCheckboxesDeferred.promise]; w.initContext = function() { - $scope.isDataFound = (w.content != null) && (w.content.accounting != null); - $scope.getLegend(); - return $scope.getCurrency(); + $scope.isDataFound = (w.content != null) && (w.content.values != null); + $scope.displayOptions = [ + { + id: 'show_net_profit', + label: $translate.instant('impac.widget.accounts_expenses_revenue.show_net_profit'), + value: false, + onChangeCallback: $scope.toggleDisplayNetProfit + } + ]; + if (angular.isDefined((w.metadata != null) && (w.metadata.display != null))) { + angular.merge($scope.displayOptions, w.metadata.display); + } + return $scope.isNetProfitDisplayed = !!$scope.displayOptions[0].value; }; - $scope.getCurrentPrice = function() { + $scope.getCurrentRevenue = function() { if ($scope.isDataFound) { - return w.content.accounting.total_period; + return _.sum(w.content.values.revenue); } }; - $scope.getCurrency = function() { + $scope.getCurrentExpenses = function() { if ($scope.isDataFound) { - if (w.content.accounting.currency_key != null) { - return $translate(w.content.accounting.currency_key).then(function(translation) { - $scope.currency = translation; - return $scope.currency_unit = w.content.accounting.currency; - }); - } else { - $scope.currency = w.content.accounting.currency; - return $scope.currency_unit = w.content.accounting.currency; - } + return _.sum(w.content.values.expenses); } }; - $scope.getLegend = function() { + $scope.getCurrency = function() { if ($scope.isDataFound) { - if (w.content.accounting.legend_key != null) { - return $translate(w.content.accounting.legend_key).then(function(translation) { - return $scope.legend = translation; - }); - } else { - return $scope.legend = w.content.accounting.legend; - } + return w.content.currency; } }; + $scope.toggleDisplayNetProfit = function() { + $scope.isNetProfitDisplayed = !!$scope.displayOptions[0].value; + $scope.updateSettings(false); + return w.format(); + }; $scope.drawTrigger = $q.defer(); w.format = function() { - var all_values_are_positive, chartData, data, dates, inputData, options, period; + var all_values_are_positive, chartData, datasets, dates, lineData, lineOptions, period, pieData, pieOptions; if ($scope.isDataFound) { - data = angular.copy(w.content.accounting); - period = null; - if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { - period = w.metadata.hist_parameters.period; - } - dates = _.map(data.dates, function(date) { - return $filter('momentDate')(date, period); - }); - inputData = { - labels: dates, - datasets: [ - { - title: data.type, - values: data.values - } - ] - }; - all_values_are_positive = true; - angular.forEach(data.values, function(value) { - return all_values_are_positive && (all_values_are_positive = value >= 0); - }); - options = { - scaleBeginAtZero: all_values_are_positive, - showXLabels: false, - currency: data.currency - }; - chartData = ChartFormatterSvc.combinedBarChart(inputData, options, false); + if (w.isHistoryMode) { + period = null; + if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { + period = w.metadata.hist_parameters.period; + } + dates = _.map(w.content.dates, function(date) { + return $filter('momentDate')(date, period); + }); + if ($scope.isNetProfitDisplayed) { + datasets = [ + { + title: $translate.instant('impac.widget.accounts_expenses_revenue.net_profit') + (" (" + ($scope.getCurrency()) + ")"), + values: w.content.values.net_profit + } + ]; + all_values_are_positive = true; + angular.forEach(w.content.values.net_profit, function(value) { + return all_values_are_positive && (all_values_are_positive = value >= 0); + }); + } else { + datasets = [ + { + title: $translate.instant('impac.widget.accounts_expenses_revenue.expenses') + (" (" + ($scope.getCurrency()) + ")"), + values: w.content.values.expenses + }, { + title: $translate.instant('impac.widget.accounts_expenses_revenue.revenue') + (" (" + ($scope.getCurrency()) + ")"), + values: w.content.values.revenue + } + ]; + all_values_are_positive = true; + angular.forEach(w.content.values.expenses, function(value) { + return all_values_are_positive && (all_values_are_positive = value >= 0); + }); + angular.forEach(w.content.values.revenue, function(value) { + return all_values_are_positive && (all_values_are_positive = value >= 0); + }); + } + lineData = { + labels: dates, + datasets: datasets + }; + lineOptions = { + scaleBeginAtZero: all_values_are_positive, + showXLabels: false + }; + chartData = ChartFormatterSvc.combinedBarChart(lineData, lineOptions, false, true); + } else { + pieData = [ + { + label: $translate.instant('impac.widget.accounts_expenses_revenue.expenses') + (" (" + ($scope.getCurrency()) + ")"), + value: $scope.getCurrentExpenses() + }, { + label: $translate.instant('impac.widget.accounts_expenses_revenue.revenue') + (" (" + ($scope.getCurrency()) + ")"), + value: $scope.getCurrentRevenue() + } + ]; + pieOptions = { + tooltipFontSize: 12, + percentageInnerCutout: 0 + }; + chartData = ChartFormatterSvc.pieChart(pieData, pieOptions, true); + } return $scope.drawTrigger.notify(chartData); } }; return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetAccountsAccountingValues', function() { + module.directive('widgetAccountsExpensesRevenue', function() { return { restrict: 'A', - controller: 'WidgetAccountsAccountingValuesCtrl' + controller: 'WidgetAccountsExpensesRevenueCtrl' }; }); @@ -8967,82 +9203,98 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
1) { - return $scope.dataSource = w.content.repartition; - } else { - return $scope.dataSource = w.content.summary; - } - } - }; - $scope.getCurrency = function() { - if ($scope.isDataFound) { - return w.content.currency; - } }; - $scope.getAccountColor = function(elem) { - if ($scope.isDataFound) { - return ChartFormatterSvc.getColor(_.indexOf($scope.dataSource, elem)); + $scope.trxList.changeResourcesType = function(resourcesType) { + if (resourcesType === $scope.trxList.resources) { + return; } + $scope.trxList.resources = resourcesType; + return $scope.trxList.fetch(); }; - $scope.drawTrigger = $q.defer(); - w.format = function() { - var chartData, pieData, pieOptions; - if ($scope.isDataFound) { - pieData = _.map($scope.dataSource, function(company) { - return { - label: company.label, - value: company.total - }; - }); - pieOptions = { - percentageInnerCutout: 50, - tooltipFontSize: 12 - }; - chartData = ChartFormatterSvc.pieChart(pieData, pieOptions); - return $scope.drawTrigger.notify(chartData); - } + w.initContext = function() { + return $scope.trxList.fetch(); }; return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetAccountsAssetsLiabilitySummary', function() { + module.directive('widgetAccountsInvoicesList', function() { return { restrict: 'A', - controller: 'WidgetAccountsAssetsLiabilitySummaryCtrl' + controller: 'WidgetAccountsInvoicesListCtrl' }; }); @@ -9051,147 +9303,79 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
1) { - $scope.dataSource = w.content.repartition; - } else { - $scope.dataSource = w.content.summary; - } - } - if (!w.metadata.classification) { - w.metadata.classification = "ASSET"; - } - return $translate('impac.widget.acc_ass_smry.' + w.metadata.classification.toLowerCase() + ".many").then(function(result) { - return $scope.classification = result; - }); + return $scope.isDataFound = w.content != null; }; $scope.getCurrency = function() { - if ($scope.isDataFound) { - return w.content.currency; + if (w.selectedAccount != null) { + return w.selectedAccount.currency; } }; - $scope.getAccountColor = function(elem) { - if ($scope.isDataFound) { - return ChartFormatterSvc.getColor(_.indexOf($scope.dataSource, elem)); + $scope.getOpeningBalance = function() { + if (w.content != null) { + return _.find(w.content.figure.metrics, function(metric) { + return metric.label === 'opening'; + }); } }; - $scope.drawTrigger = $q.defer(); - w.format = function() { - var chartData, pieData, pieOptions; - if ($scope.isDataFound) { - pieData = _.map($scope.dataSource, function(company) { - return { - label: company.label, - value: company.total - }; - }); - pieOptions = { - percentageInnerCutout: 50, - tooltipFontSize: 12 - }; - chartData = ChartFormatterSvc.pieChart(pieData, pieOptions); - return $scope.drawTrigger.notify(chartData); + $scope.getClosingBalance = function() { + if (w.content != null) { + return _.find(w.content.figure.metrics, function(metric) { + return metric.label === 'closing'; + }); } }; - return $scope.widgetDeferred.resolve(settingsPromises); - }]); - - module.directive('widgetAccountsAssetsSummary', function() { - return { - restrict: 'A', - controller: 'WidgetAccountsAssetsSummaryCtrl' - }; - }); - -}).call(this); - -(function() { - var module; - - module = angular.module('impac.components.widgets.accounts-assets-vs-liabilities', []); - - module.controller('WidgetAccountsAssetsVsLiabilitiesCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "$translate", function($scope, $q, ChartFormatterSvc, $filter, $translate) { - var settingsPromises, w; - w = $scope.widget; - $scope.orgDeferred = $q.defer(); - $scope.chartDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.chartDeferred.promise]; - $translate(['impac.widget.acc_ass_vs_liab.asset.one', 'impac.widget.acc_ass_vs_liab.liability.one']).then(function(translation) { - return $scope.classificationTranslation = { - "ASSET": translation['impac.widget.acc_ass_vs_liab.asset.one'].toUpperCase(), - "LIABILITY": translation['impac.widget.acc_ass_vs_liab.liability.one'].toUpperCase() - }; - }); - w.initContext = function() { - var index; - $scope.isDataFound = (w.content != null) && !_.isEmpty(w.content.summary) && !_.isEmpty(w.content.companies); - if ($scope.isDataFound) { - index = 0; - $scope.companiesList = _.map(w.content.companies, function(company) { - var assetSum, liabilitiesSum, result; - assetSum = _.find(w.content.summary, (function(sum) { - return sum.classification === "ASSET"; - })); - liabilitiesSum = _.find(w.content.summary, (function(sum) { - return sum.classification === "LIABILITY"; - })); - result = { - company: company, - assets: assetSum != null ? assetSum.totals[index] : 0.0, - liabilities: liabilitiesSum != null ? liabilitiesSum.totals[index] : 0.0, - currency: w.content.currency - }; - index++; - return result; + $scope.getTotal = function() { + var summary; + if (w.content != null) { + summary = _.find(w.content.table.tables, function(table) { + return table.table_title === 'Bank Summary'; + }); + } + if (w.selectedAccount != null) { + return _.find(summary.table_rows, function(row) { + var name_match; + name_match = w.selectedAccount.name === 'All Accounts' ? 'Total' : w.selectedAccount.name; + return row.column_1 === name_match; }); - return $scope.titleTranslation; } }; - $scope.assetsColor = ChartFormatterSvc.getColor(0); - $scope.liabilitiesColor = ChartFormatterSvc.getColor(1); - $scope.drawTrigger = $q.defer(); - w.format = function() { - var chartData, datasets, inputData, options; - if ($scope.isDataFound) { - datasets = _.map(w.content.summary, function(sum) { - if (_.includes(['ASSET', 'LIABILITY'], sum.classification)) { - return { - title: $scope.classificationTranslation[sum.classification], - values: sum.totals - }; - } + $scope.getStatementBalance = function() { + var statement; + if (w.content != null) { + statement = _.find(w.content.table.tables, function(table) { + return table.table_title === 'Bank Statement'; + }); + } + if (statement) { + return _.find(statement.table_rows, function(row) { + return row.column_2 === "Closing Balance"; }); - datasets = _.sortByOrder(datasets, ['title']); - inputData = { - labels: w.content.companies, - datasets: _.compact(datasets) - }; - options = { - showTooltips: false, - showXLabels: false, - barValueSpacing: Math.max(8 - w.content.companies.length, 1) - }; - chartData = ChartFormatterSvc.combinedBarChart(inputData, options); - return $scope.drawTrigger.notify(chartData); } }; + $scope.displayAccount = function() { + return $scope.updateSettings(false).then(function() { + return w.format(); + }); + }; + w.format = function() {}; return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetAccountsAssetsVsLiabilities', function() { + module.directive('widgetAccountsLiveBalance', function() { return { restrict: 'A', - controller: 'WidgetAccountsAssetsVsLiabilitiesCtrl' + controller: 'WidgetAccountsLiveBalanceCtrl' }; }); @@ -9200,104 +9384,89 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
= 0); - }); - options = { + ref = w.content.values.payables; + for (i = 0, len = ref.length; i < len; i++) { + value = ref[i]; + all_values_are_positive && (all_values_are_positive = value >= 0); + } + ref1 = w.content.values.receivables; + for (j = 0, len1 = ref1.length; j < len1; j++) { + value = ref1[j]; + all_values_are_positive && (all_values_are_positive = value >= 0); + } + lineOptions = { scaleBeginAtZero: all_values_are_positive, showXLabels: false }; - chartData = ChartFormatterSvc.lineChart([lineData], options); - if ($scope.getBehaviour() === 'pnl') { - chartData = ChartFormatterSvc.combinedBarChart(barData, options, false); - } - return $scope.drawTrigger.notify(chartData); + return $translate(['impac.widget.accounts_payable_receivable.payable', 'impac.widget.accounts_payable_receivable.receivable']).then(function(translation) { + var chartData, lineData; + lineData = [ + { + title: translation['impac.widget.accounts_payable_receivable.payable'], + labels: dates, + values: w.content.values.payables + }, { + title: translation['impac.widget.accounts_payable_receivable.receivable'], + labels: dates, + values: w.content.values.receivables + } + ]; + chartData = ChartFormatterSvc.lineChart(lineData, lineOptions, true); + return $scope.drawTrigger.notify(chartData); + }); } }; return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetAccountsBalance', function() { + module.directive('widgetAccountsPayableReceivable', function() { return { restrict: 'A', - controller: 'WidgetAccountsBalanceCtrl' + controller: 'WidgetAccountsPayableReceivableCtrl' }; }); @@ -9306,72 +9475,183 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
\n
\n \n
\n
\n \n
\n
"; + settingsPromises = [$scope.orgDeferred.promise, $scope.timePeriodDeferred.promise, $scope.widthDeferred.promise, $scope.chartDeferred.promise, $scope.paramSelectorDeferred.promise, $scope.tagFilterDeferred.promise]; $scope.ascending = true; $scope.sortedColumn = 'account'; $scope.filterTagsEnabled = ImpacTheming.get().widgetSettings.tagging.enabled; - $scope.isReportFiltered = function() { - return (w.metadata != null) && (w.metadata.filter_query != null) && Object.keys(w.metadata.filter_query).length > 0; - }; - initDates = function() { - $scope.fromDate = w.metadata.hist_parameters.from; - $scope.toDate = w.metadata.hist_parameters.to; - return $scope.keepToday = w.metadata.hist_parameters.keep_today; + setAmountDisplayed = function() { + return $scope.amountDisplayed = angular.copy(_.find($scope.amountDisplayedOptions, function(o) { + return w.metadata && o.value === w.metadata.amount_displayed; + }) || $scope.amountDisplayedOptions[1]); + }; + $translate(['impac.widget.accounts_profit_and_loss.last_period', 'impac.widget.accounts_profit_and_loss.total_for_period']).then(function(translation) { + $scope.amountDisplayedOptions = [ + { + label: translation['impac.widget.accounts_profit_and_loss.last_period'], + value: 'last' + }, { + label: translation['impac.widget.accounts_profit_and_loss.total_for_period'], + value: 'total' + } + ]; + return setAmountDisplayed(); + }); + periodName = (h = $scope.widget.metadata.hist_parameters) && h.period ? h.period.toLowerCase() : 'monthly'; + $translate('impac.widget.settings.time_period.period.' + periodName).then(function(translation) { + return $scope.period_translation = _.capitalize(translation.toLowerCase()); + }); + $scope.isReportFiltered = function() { + return (w.metadata != null) && (w.metadata.filter_query != null) && Object.keys(w.metadata.filter_query).length > 0; }; - if (!((w.metadata != null) && (w.metadata.hist_parameters != null))) { - w.metadata || (w.metadata = {}); - w.metadata.hist_parameters = { - to: moment().format('YYYY-MM-DD'), - keep_today: true, - period: 'RANGE' - }; - ImpacMainSvc.load().then(function(config) { - var fyEndMonth; - fyEndMonth = parseInt(config.currentOrganization.financial_year_end_month) || 6; - w.metadata.hist_parameters.from = moment(ImpacUtilities.financialYearDates(fyEndMonth).end, 'YYYY-MM-DD').subtract(1, 'year').format('YYYY-MM-DD'); - return initDates(); - }); - } else { - initDates(); - } w.initContext = function() { + var dates, firstDate, foundElem, histParams, i, lastDate, len, ref, sElemId; if ($scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.summary) && !_.isEmpty(w.content.dates)) { $scope.dates = w.content.dates; $scope.unCollapsed = w.metadata.unCollapsed || []; - translateCategories(Object.keys(w.content.summary)).then(function(categories) { - $scope.categories = categories; - return sortData(); + if (w.metadata && (histParams = w.metadata.hist_parameters)) { + dates = ImpacUtilities.selectedTimeRange(histParams); + firstDate = $filter('momentDate')(dates.from, getPeriod()); + lastDate = $filter('momentDate')(dates.to, getPeriod()); + $scope.amountDisplayedOptions[1].label = firstDate + " to " + lastDate; + $scope.amountDisplayedOptions[0].label = lastDate; + } + setAmountDisplayed(); + if (!_.isEmpty(w.metadata.selectedElements)) { + $scope.selectedElements = []; + ref = w.metadata.selectedElements; + for (i = 0, len = ref.length; i < len; i++) { + sElemId = ref[i]; + foundElem = _.find(w.content.summary, function(statement) { + return statement.name === sElemId; + }); + foundElem || (foundElem = fetchElement(w.content.summary, sElemId)); + if (foundElem) { + $scope.selectedElements.push(foundElem); + } + } + } + if (!_.any($scope.selectedElements)) { + w.width = 6; + } + return sortData(); + } + }; + $scope.getElementChartColor = function(index) { + return ChartFormatterSvc.getColor(index); + }; + getPeriod = function() { + if ((w.metadata != null) && (w.metadata.hist_parameters != null) && (w.metadata.hist_parameters.period != null)) { + return w.metadata.hist_parameters.period; + } else { + return 'MONTHLY'; + } + }; + getLastAmount = function(element) { + if (element.totals != null) { + return _.last(element.totals); + } + }; + getTotalAmount = function(element) { + if (element.totals != null) { + return _.sum(element.totals); + } + }; + $scope.getAmount = function(element) { + switch ($scope.amountDisplayed.value) { + case 'total': + return getTotalAmount(element); + default: + return getLastAmount(element); + } + }; + $scope.getClassColor = function(aTotal) { + if (parseInt(aTotal) > 0) { + return 'positive'; + } else if (parseInt(aTotal) < 0) { + return 'negative'; + } else { + return null; + } + }; + $scope.getName = function(element) { + if ((element != null) && (element.name != null)) { + return element.name.replace(/_/g, " "); + } + }; + $scope.sort = function(col) { + if ($scope.sortedColumn === col) { + $scope.ascending = !$scope.ascending; + } else { + $scope.ascending = true; + $scope.sortedColumn = col; + } + return sortData(); + }; + $scope.toggleSelectedElement = function(element, statementName) { + var selectedElement; + if (statementName == null) { + statementName = null; + } + if ($scope.isSelected(element, statementName)) { + $scope.selectedElements = _.reject($scope.selectedElements, function(sElem) { + return matchElementToSelectedElement(element, statementName, sElem); }); + w.format(); + if (w.isExpanded() && $scope.selectedElements.length === 0) { + return w.toggleExpanded(); + } else { + return ImpacWidgetsSvc.updateWidgetSettings(w, false); + } + } else { + selectedElement = angular.copy(element); + selectedElement.category = statementName; + $scope.selectedElements || ($scope.selectedElements = []); + $scope.selectedElements.push(selectedElement); + w.format(); + if (!w.isExpanded()) { + return w.toggleExpanded(); + } else { + return ImpacWidgetsSvc.updateWidgetSettings(w, false); + } } - return initDates(); }; - $scope.toggleCollapsed = function(categoryName) { - if (categoryName != null) { + $scope.isSelected = function(element, statementName) { + if (statementName == null) { + statementName = null; + } + return (element != null) && _.any($scope.selectedElements, function(sElem) { + return matchElementToSelectedElement(element, statementName, sElem); + }); + }; + $scope.toggleCollapsed = function(element) { + if ((element != null) && (element.name != null)) { if (_.find($scope.unCollapsed, (function(name) { - return categoryName === name; + return element.name === name; }))) { $scope.unCollapsed = _.reject($scope.unCollapsed, function(name) { - return name === categoryName; + return name === element.name; }); } else { - $scope.unCollapsed.push(categoryName); + $scope.unCollapsed.push(element.name); } return ImpacWidgetsSvc.updateWidgetSettings(w, false); } }; - $scope.isCollapsed = function(categoryName) { - if (categoryName != null) { + $scope.isCollapsed = function(element) { + if ((element != null) && (element.name != null)) { if (_.find($scope.unCollapsed, (function(name) { - return categoryName === name; + return element.name === name; }))) { return false; } else { @@ -9379,27 +9659,59 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
0; + }; + matchElementToSelectedElement = function(element, elementCategory, sElem) { + if (elementCategory == null) { + elementCategory = null; + } + return getIdentifier(element, elementCategory) === getIdentifier(sElem); + }; + fetchElement = function(statements, sElemId) { + var element, i, len, statement; + for (i = 0, len = statements.length; i < len; i++) { + statement = statements[i]; + if (statement.accounts == null) { + continue; + } + element = _.find(statement.accounts, function(acc) { + return getIdentifier(acc, statement.name) === sElemId; + }); + if (element != null) { + element = angular.merge(angular.copy(element), { + category: statement.name + }); + return element; + } + } + }; + getIdentifier = function(element, category) { + var id; + if (category == null) { + category = null; + } + id = element.id || element.name; + category || (category = element.category); + if (!category) { + return id; + } + return category + "-" + id; }; sortAccountsBy = function(getElem) { - return angular.forEach($scope.categories, function(cat) { - var sElem; - sElem = w.content.summary[cat.key]; + return angular.forEach(w.content.summary, function(sElem) { if (sElem.accounts) { return sElem.accounts.sort(function(a, b) { var res; @@ -9413,50 +9725,84 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
0) { + all_values_are_positive = true; + inputData = []; + angular.forEach($scope.selectedElements, function(sElem) { + var data, dates, period; + data = angular.copy(sElem); + period = null; + if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { + period = w.metadata.hist_parameters.period; + } + dates = _.map(w.content.dates, function(date) { + return $filter('momentDate')(date, period); + }); + inputData.push({ + title: data.name, + labels: dates, + values: data.totals + }); + return angular.forEach(data.totals, function(value) { + return all_values_are_positive && (all_values_are_positive = value >= 0); + }); + }); + options = { + scaleBeginAtZero: all_values_are_positive, + showXLabels: true, + datasetFill: $scope.selectedElements.length === 1, + pointDot: $scope.selectedElements.length === 1 + }; + chartData = ChartFormatterSvc.lineChart(inputData, options); + return $scope.drawTrigger.notify(chartData); + } + }; + unCollapsedSetting = {}; + unCollapsedSetting.initialized = false; + unCollapsedSetting.initialize = function() { + return unCollapsedSetting.initialized = true; + }; + unCollapsedSetting.toMetadata = function() { return { unCollapsed: $scope.unCollapsed }; }; w.settings.push(unCollapsedSetting); + selectedElementsSetting = {}; + selectedElementsSetting.initialized = false; + selectedElementsSetting.initialize = function() { + return selectedElementsSetting.initialized = true; + }; + selectedElementsSetting.toMetadata = function() { + var selectedElementsMetadata; + selectedElementsMetadata = _.map($scope.selectedElements, function(element) { + return getIdentifier(element); + }); + return { + selectedElements: selectedElementsMetadata + }; + }; + w.settings.push(selectedElementsSetting); return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetAccountsBalanceSheet', function() { + module.directive('widgetAccountsProfitAndLoss', function() { return { restrict: 'A', - controller: 'WidgetAccountsBalanceSheetCtrl' + controller: 'WidgetAccountsProfitAndLossCtrl' }; }); @@ -9465,145 +9811,251 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","

" + name; + $scope.getEmployeeEarnings = function(anEmployee) { + if (anEmployee.salary != null) { + return $filter('mnoCurrency')(anEmployee.salary.amount, w.content.total.currency); + } else { + return '-'; + } }; - $scope.chartId = function() { - return "cashProjectionChart-" + w.id; + return $scope.widgetDeferred.resolve(settingsPromises); + }]); + + module.directive('widgetHrEmployeesList', function() { + return { + restrict: 'A', + controller: 'WidgetHrEmployeesListCtrl' }; + }); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets.hr-leaves-balance', []); + + module.controller('WidgetHrLeavesBalanceCtrl', ["$scope", "$q", "$translate", function($scope, $q, $translate) { + var employee, name, settingsPromises, w; + w = $scope.widget; $scope.orgDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise]; - $scope.trxList = { - display: false, - updated: false, - transactions: [] - }; - $scope.contacts = []; - $scope.trxList.show = function() { - return $scope.trxList.display = true; - }; - $scope.trxList.hide = function() { - $scope.trxList.display = false; - if ($scope.trxList.updated) { - return ImpacWidgetsSvc.show(w).then(function() { - return $scope.trxList.updated = false; + $scope.paramSelectorDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise, $scope.paramSelectorDeferred.promise]; + w.initContext = function() { + if ($scope.isDataFound = !_.isEmpty(w.content) && !_.isEmpty(w.content.employees)) { + $scope.employeesOptions = _.map(w.content.employees, function(e) { + return { + value: e.uid, + label: e.lastname + " " + e.firstname + }; }); + return $scope.selectedEmployee = { + value: $scope.getEmployee().uid, + label: ($scope.getEmployee().lastname) + " " + ($scope.getEmployee().firstname) + }; } }; - $scope.trxList.fetch = function(currentPage) { - var params; - if (currentPage == null) { - currentPage = 1; - } - params = angular.merge($scope.trxList.params, { - metadata: _.pick(w.metadata, 'organization_ids'), - page: { - number: currentPage - }, - sort: '-expected_payment_date', - currency: w.metadata.currency - }); - return BoltResources.index(w.metadata.bolt_path, $scope.trxList.resources, params).then(function(response) { - var contactName, i, len, ref, trx; - _.remove($scope.trxList.transactions, function() { - return true; - }); - ref = response.data.data; - for (i = 0, len = ref.length; i < len; i++) { - trx = ref[i]; - contactName = ''; - if (trx.relationships && trx.relationships.contact && trx.relationships.contact.data) { - contactName = _.find(response.data.included, function(includedContact) { - return includedContact.id === trx.relationships.contact.data.id; - }).attributes.name; - } - $scope.trxList.transactions.push(angular.merge(trx.attributes, { - id: trx.id, - contact_name: contactName - })); - } - return $scope.trxList.totalRecords = response.data.meta.record_count; - })["finally"](function() { - return $scope.trxList.show(); - }); - }; - $scope.trxList.updateParams = function(resources, filter) { - $scope.trxList.resources = resources; - return $scope.trxList.params = { - include: 'contact', - fields: { - contacts: 'name' - }, - filter: filter - }; - }; - $scope.trxList.showAll = function(resources) { - var filter; - if (resources == null) { - resources = 'invoices'; + $scope.getEmployee = function() { + var e; + if (!$scope.isDataFound) { + return false; } - filter = { - status: ['AUTHORISED', 'APPROVED', 'SUBMITTED', 'FORECAST'], - reconciliation_status: 'UNRECONCILED' - }; - $scope.trxList.updateParams(resources, filter); - return $scope.trxList.fetch(); + e = w.content.employees[0]; + if (w.metadata && w.metadata.employee_id) { + e = _.find(w.content.employees, function(e) { + return e.uid === w.metadata.employee_id; + }) || w.content.employees[0]; + } + return angular.copy(e); }; - $scope.trxList.updateExpectedDate = function(trxId, date) { - return BoltResources.update(w.metadata.bolt_path, $scope.trxList.resources, trxId, { - expected_payment_date: moment(date).format('YYYY-MM-DD') - }).then(function() { - return $scope.trxList.updated = true; + employee = $scope.getEmployee(); + name = employee && employee.leaves[0].name; + if (name) { + $scope.vacationLeaves_translation = name; + } else { + $translate('impac.widget.hr_leaves_balance.vacation_leaves').then(function(translation) { + return $scope.vacationLeaves_translation = translation; + }); + } + name = employee && employee.leaves[1].name; + if (name) { + $scope.sickLeaves_translation = name; + } else { + $translate('impac.widget.hr_leaves_balance.sick_leaves').then(function(translation) { + return $scope.sickLeaves_translation = translation; }); + } + return $scope.widgetDeferred.resolve(settingsPromises); + }]); + + module.directive('widgetHrLeavesBalance', function() { + return { + restrict: 'A', + controller: 'WidgetHrLeavesBalanceCtrl' }; - $scope.trxList.changeResourcesType = function(resourcesType) { - if (resourcesType === $scope.trxList.resources) { - return; + }); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets.hr-leaves-schedule', []); + + module.controller('WidgetHrLeavesScheduleCtrl', ["$scope", "$q", "ChartFormatterSvc", function($scope, $q, ChartFormatterSvc) { + var settingsPromises, w; + w = $scope.widget; + $scope.orgDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise]; + w.initContext = function() { + var eventsArray; + if ($scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.summary)) { + eventsArray = []; + angular.forEach(w.content.summary, function(leave) { + return eventsArray.push({ + title: leave.employee_name + " - " + leave.title, + start: leave.start_date, + end: leave.end_date + }); + }); + return $scope.eventSources = angular.copy(eventsArray); } - $scope.trxList.resources = resourcesType; - return $scope.trxList.fetch(); }; - $scope.trxList.deleteTransaction = function(resourcesType, trxId) { - return BoltResources.destroy(w.metadata.bolt_path, resourcesType, trxId).then(function() { - return $scope.trxList.updated = true; - }); + return $scope.widgetDeferred.resolve(settingsPromises); + }]); + + module.directive('widgetHrLeavesSchedule', function() { + return { + restrict: 'A', + controller: 'WidgetHrLeavesScheduleCtrl' }; - $scope.trxList.updateSchedulableTransactions = function(resourcesType, trx) { - return $scope.trxList.updated = true; + }); + + module.directive('widgetComponentCalendar', ["$tranlate", function($tranlate) { + return { + scope: { + events: '=ngModel' + }, + restrict: 'A', + link: function(scope, element) { + var calendarOptions, getEvents; + scope.eventSources = []; + calendarOptions = { + header: { + left: $tranlate.instant('impac.common.action.calendar.left'), + center: $tranlate.instant('impac.common.action.calendar.center'), + right: $tranlate.instant('impac.common.action.calendar.right') + }, + contentHeight: 204 + }; + getEvents = function() { + return scope.events; + }; + return scope.$watch(getEvents, function(events) { + if (events.length > 0) { + element.fullCalendar('destroy'); + angular.extend(calendarOptions, { + events: scope.events + }); + return element.fullCalendar(calendarOptions); + } + }, true); + } }; - $scope.trxList.deleteChildrenTransactions = function(resourcesType, trxId) { - return BoltResources.update(w.metadata.bolt_path, resourcesType, trxId, { - recurring: false - }).then(function() { - return $scope.trxList.updated = true; - }); + }]); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets.hr-payroll-summary', []); + + module.controller('WidgetHrPayrollSummaryCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "ImpacWidgetsSvc", "$translate", function($scope, $q, ChartFormatterSvc, $filter, ImpacWidgetsSvc, $translate) { + var fetchElement, getIdentifier, h, matchElementToSelectedElement, periodName, selectedElementsSetting, settingsPromises, sortData, sortEmployeesBy, unCollapsedSetting, w; + w = $scope.widget; + $scope.orgDeferred = $q.defer(); + $scope.timePeriodDeferred = $q.defer(); + $scope.widthDeferred = $q.defer(); + $scope.histModeDeferred = $q.defer(); + $scope.chartDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise, $scope.timePeriodDeferred.promise, $scope.widthDeferred.promise, $scope.histModeDeferred.promise, $scope.chartDeferred.promise]; + $scope.ascending = true; + $scope.sortedColumn = 'employee'; + periodName = (h = $scope.widget.metadata.hist_parameters) && h.period ? h.period.toLowerCase() : 'monthly'; + $scope.periodTranslation = $translate.instant("impac.widget.settings.time_period.period." + periodName); + w.initContext = function() { + var foundElem, i, len, ref, sElemId; + if ($scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.summary) && !_.isEmpty(w.content.dates)) { + $scope.unCollapsed = w.metadata.unCollapsed || []; + if (!_.isEmpty(w.metadata.selectedElements)) { + $scope.selectedElements = []; + ref = w.metadata.selectedElements; + for (i = 0, len = ref.length; i < len; i++) { + sElemId = ref[i]; + foundElem = _.find(w.content.summary, function(statement) { + return statement.name === sElemId; + }); + foundElem || (foundElem = fetchElement(w.content.summary, sElemId)); + if (foundElem) { + $scope.selectedElements.push(foundElem); + } + } + } + if (!(($scope.selectedElements != null) && $scope.selectedElements.length > 0)) { + w.width = 6; + } + return sortData(); + } }; - $scope.trendList = { - display: false, - updated: false, - trends: [], - params: {} + $scope.getElementChartColor = function(index) { + return ChartFormatterSvc.getColor(index); }; - $scope.trendList.show = function() { - return $scope.trendList.display = true; + $scope.getLastValue = function(element) { + return (element.totals && element.totals[element.totals.length - 1]) || 0; }; - $scope.trendList.hide = function() { - $scope.trendList.display = false; - if ($scope.trendList.updated) { - return ImpacWidgetsSvc.show(w).then(function() { - return $scope.trendList.updated = false; - }); + $scope.getTotalSum = function(element) { + if (element.totals != null) { + return _.reduce(element.totals, function(memo, num) { + return memo + num; + }, 0); } }; - $scope.trendList.fetch = function(currentPage) { - var params; - if (currentPage == null) { - currentPage = 1; - } - params = angular.merge($scope.trendList.params, { - metadata: _.pick(w.metadata, 'organization_ids'), - page: { - number: currentPage + $scope.getName = function(element) { + if ((element != null) && (element.name != null)) { + if (element.name === "total_leaves") { + return $translate.instant('impac.widget.hr_payroll_summary.total_leaves'); } - }); - return BoltResources.index(w.metadata.bolt_path, 'trends', params).then(function(response) { - var i, len, ref, trend; - _.remove($scope.trendList.trends, function() { - return true; - }); - ref = response.data.data; - for (i = 0, len = ref.length; i < len; i++) { - trend = ref[i]; - if (!trend.period) { - trend.period = 'once'; - } - $scope.trendList.trends.push(angular.merge(trend.attributes, { - id: trend.id - })); + if (element.name === "total_super") { + return $translate.instant('impac.widget.hr_payroll_summary.total_superannuation'); } - return $scope.trendList.totalRecords = response.data.meta.record_count; - })["finally"](function() { - return $scope.trendList.show(); - }); - }; - $scope.trendList.showAll = function() { - return $scope.trendList.fetch(); - }; - $scope.trendList.updateTrend = function(trend) { - if (trend.period === 'once') { - trend.period = null; - } - return BoltResources.update(w.metadata.bolt_path, 'trends', trend.id, _.omit(trend, 'id')).then(function() { - return $scope.trendList.updated = true; - }); - }; - $scope.trendList.deleteTrend = function(trendId) { - _.remove($scope.trendList.trends, function(trend) { - return trend.id === trendId; - }); - return BoltResources.destroy(w.metadata.bolt_path, 'trends', trendId).then(function() { - return $scope.trendList.updated = true; - }); - }; - $scope.chartDeferred = $q.defer(); - $scope.chartPromise = $scope.chartDeferred.promise; - $scope.addForecastPopup = { - resourcesType: 'invoices', - display: false, - hide: function() { - return this.display = false; - }, - show: function() { - return this.display = true; + if (element.name === "total_reimbursement") { + return $translate.instant('impac.widget.hr_payroll_summary.total_reimbursements'); + } + if (element.name === "total_tax") { + return $translate.instant('impac.widget.hr_payroll_summary.total_taxes'); + } + if (element.name === "total_timeoff") { + return $translate.instant('impac.widget.hr_payroll_summary.total_time_off'); + } + return element.name.replace(/_/g, " "); } }; - $scope.addForecastPopup.createTransaction = function(trx, resourcesType) { - return BoltResources.create(w.metadata.bolt_path, resourcesType, { - title: trx.title, - transaction_number: "FOR-" + (Math.ceil(Math.random() * 10000)), - amount: trx.amount, - balance: trx.amount, - transaction_date: moment().format('YYYY-MM-DD'), - due_date: moment(trx.datePicker.date).format('YYYY-MM-DD'), - status: 'FORECAST', - recurring: trx.recurring, - recurring_pattern: trx.recurring_pattern, - recurring_end_date: trx.recurring_end_date ? moment(trx.recurring_end_date).format('YYYY-MM-DD') : null, - reconciliation_status: 'UNRECONCILED', - currency: w.metadata.currency - }, { - company: { - data: { - type: 'companies', - id: $scope.firstCompanyId - } - }, - contact: { - data: { - type: 'contacts', - id: trx.contact.id - } + $scope.getTrackedField = function() { + var allFieldsEquals, field; + if (!_.isEmpty($scope.selectedElements) && ($scope.selectedElements[0].id != null)) { + field = $scope.selectedElements[0].id.split('-')[0]; + allFieldsEquals = true; + angular.forEach($scope.selectedElements, function(element) { + return allFieldsEquals && (allFieldsEquals = element.id && field === element.id.split('-')[0]); + }); + if (allFieldsEquals) { + return $scope.getName({ + name: field + }); + } else { + return null; } - }).then(function() { - return ImpacWidgetsSvc.show(w); - }); + } }; - $scope.dupTrxList = { - display: false, - updated: false, - transactions: [] + $scope.formatDate = function(date) { + if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { + return $filter('momentDate')(date, w.metadata.hist_parameters.period); + } else { + return $filter('momentDate')(date, 'default'); + } }; - $scope.dupTrxList.show = function() { - return $scope.dupTrxList.display = true; + $scope.sort = function(col) { + if ($scope.sortedColumn === col) { + $scope.ascending = !$scope.ascending; + } else { + $scope.ascending = true; + $scope.sortedColumn = col; + } + return sortData(); }; - $scope.dupTrxList.hide = function() { - $scope.dupTrxList.display = false; - if ($scope.dupTrxList.updated) { - return ImpacWidgetsSvc.show(w).then(function() { - return $scope.dupTrxList.updated = false; + $scope.toggleSelectedElement = function(element, statementName) { + var selectedElement; + if (statementName == null) { + statementName = null; + } + if ($scope.isSelected(element, statementName)) { + $scope.selectedElements = _.reject($scope.selectedElements, function(sElem) { + return matchElementToSelectedElement(element, statementName, sElem); }); + w.format(); + if (w.isExpanded() && $scope.selectedElements.length === 0) { + return w.toggleExpanded(); + } else { + return ImpacWidgetsSvc.updateWidgetSettings(w, false); + } + } else { + selectedElement = angular.copy(element); + selectedElement.category = statementName; + $scope.selectedElements || ($scope.selectedElements = []); + $scope.selectedElements.push(selectedElement); + w.format(); + if (!w.isExpanded()) { + return w.toggleExpanded(); + } else { + return ImpacWidgetsSvc.updateWidgetSettings(w, false); + } } }; - $scope.dupTrxList.fetch = function(currentPage) { - var params; - if (currentPage == null) { - currentPage = 1; + $scope.isSelected = function(element, statementName) { + if (statementName == null) { + statementName = null; } - params = angular.merge($scope.dupTrxList.params, { - metadata: _.pick(w.metadata, 'organization_ids'), - page: { - number: currentPage - } + return (element != null) && _.any($scope.selectedElements, function(sElem) { + return matchElementToSelectedElement(element, statementName, sElem); }); - return BoltResources.index(w.metadata.bolt_path, $scope.dupTrxList.resources, params).then(function(response) { - var i, len, ref, trx; - _.remove($scope.dupTrxList.transactions, function() { + }; + $scope.toggleCollapsed = function(element) { + if ((element != null) && (element.name != null)) { + if (_.find($scope.unCollapsed, (function(name) { + return element.name === name; + }))) { + $scope.unCollapsed = _.reject($scope.unCollapsed, function(name) { + return name === element.name; + }); + } else { + $scope.unCollapsed.push(element.name); + } + return ImpacWidgetsSvc.updateWidgetSettings(w, false); + } + }; + $scope.isCollapsed = function(element) { + if ((element != null) && (element.name != null)) { + if (_.find($scope.unCollapsed, (function(name) { + return element.name === name; + }))) { + return false; + } else { return true; - }); - ref = response.data.data; - for (i = 0, len = ref.length; i < len; i++) { - trx = ref[i]; - $scope.dupTrxList.transactions.push(angular.merge(trx.attributes, { - id: trx.id - })); } - return $scope.dupTrxList.totalRecords = response.data.meta.record_count; - })["finally"](function() { - return $scope.dupTrxList.show(); - }); + } }; - $scope.dupTrxList.updateParams = function(resources, filter) { - $scope.dupTrxList.resources = resources; - return $scope.dupTrxList.params = { - filter: filter - }; + $scope.hasElements = function() { + return ($scope.selectedElements != null) && $scope.selectedElements.length > 0; }; - $scope.dupTrxList.showAll = function(resources) { - var filter; - if (resources == null) { - resources = 'invoices'; + $scope.getSelectLineColor = function(element, statementName) { + var sElem; + if (statementName == null) { + statementName = null; } - filter = { - status: ['FORECAST'], - reconciliation_status: 'RECONCILING' - }; - $scope.dupTrxList.updateParams(resources, filter); - return $scope.dupTrxList.fetch(); - }; - $scope.dupTrxList.updateDuplicateTransaction = function(dupTrxId, action) { - _.remove($scope.dupTrxList.transactions, function(dupTrx) { - return dupTrx.id === dupTrxId; - }); - return BoltResources.patch(w.metadata.bolt_path, $scope.dupTrxList.resources, dupTrxId, action).then(function() { - return $scope.dupTrxList.updated = true; + sElem = _.find($scope.selectedElements, function(sElem) { + return matchElementToSelectedElement(element, statementName, sElem); }); - }; - $scope.dupTrxList.changeResourcesType = function(resourcesType) { - if (resourcesType === $scope.dupTrxList.resources) { - return; + if ($scope.hasElements()) { + return ChartFormatterSvc.getColor(_.indexOf($scope.selectedElements, sElem)); } - $scope.dupTrxList.resources = resourcesType; - return $scope.dupTrxList.fetch(); }; - $scope.addTrendPopup = { - display: false, - show: function() { - return this.display = true; - }, - hide: function() { - return this.display = false; + matchElementToSelectedElement = function(element, elementCategory, sElem) { + if (elementCategory == null) { + elementCategory = null; } + return getIdentifier(element, elementCategory) === getIdentifier(sElem); }; - $scope.addTrendPopup.lastDate = function(offset, periodicity) { - var period; - period = null; - if (offset === -1) { - return; - } - switch (periodicity) { - case 'once': - return null; - case 'daily': - period = 'days'; - break; - case 'weekly': - period = 'weeks'; - break; - case 'monthly': - period = 'months'; - break; - case 'yearly': - period = 'years'; - } - return moment().add(offset, period).format('YYYY-MM-DD'); - }; - $scope.addTrendPopup.createTrend = function(trend) { - var last_apply_date; - if (Number.isInteger(trend.untilDate)) { - last_apply_date = $scope.addTrendPopup.lastDate(trend.untilDate, trend.period); - } else { - last_apply_date = trend.untilDate; - } - return BoltResources.create(w.metadata.bolt_path, 'trends', { - name: trend.name, - rate: trend.rate, - period: trend.period === 'once' ? null : trend.period, - start_date: trend.startDate, - last_apply_date: last_apply_date - }, { - company: { - data: { - type: 'companies', - id: $scope.firstCompanyId - } - }, - user: { - data: { - type: 'users', - id: $scope.userId - } + fetchElement = function(statements, sElemId) { + var element, i, len, statement; + for (i = 0, len = statements.length; i < len; i++) { + statement = statements[i]; + if (statement.employees == null) { + continue; } - }).then(function() { - return ImpacWidgetsSvc.show(w); - }); - }; - onClickBar = function(event) { - var filter, resources, series; - series = this; - resources = (function() { - switch (series.userOptions.stack) { - case 'Payables': - return 'bills'; - case 'Receivables': - return 'invoices'; + element = _.find(statement.employees, function(e) { + return getIdentifier(e, statement.name) === sElemId; + }); + if (element != null) { + element = angular.merge(angular.copy(element), { + category: statement.name + }); + return element; } - })(); - if (resources == null) { - return; } - filter = { - expected_payment_date: dateFilter(event.point.x), - status: ['AUTHORISED', 'APPROVED', 'SUBMITTED', 'FORECAST'], - reconciliation_status: 'UNRECONCILED' - }; - $scope.trxList.updateParams(resources, filter); - return $scope.trxList.fetch(); }; - legendFormatter = function() { - var name; - name = this.name; - if (name !== 'Projected cash') { - return imgTemplate(imgSrc(name), name); + getIdentifier = function(element, category) { + var id; + if (category == null) { + category = null; } - return imgTemplate(imgSrc(name), name) + '
' + imgTemplate(imgSrc('cashFlow'), 'Cash flow'); + id = element.id || element.name; + category || (category = element.category); + if (!category) { + return id; + } + return category + "-" + id; }; - onZoom = function(event) { - zoomMetadata = angular.merge(w.metadata, { - xAxis: { - max: event.max, - min: event.min + sortEmployeesBy = function(getElem) { + return angular.forEach(w.content.summary, function(sElem) { + if (sElem.employees) { + return sElem.employees.sort(function(a, b) { + var res; + res = getElem(a) > getElem(b) ? 1 : getElem(a) < getElem(b) ? -1 : 0; + if (!$scope.ascending) { + res *= -1; + } + return res; + }); } }); - if (!updateLocked) { - updateLocked = true; - return $timeout(function() { - return ImpacWidgetsSvc.update(w, { - metadata: zoomMetadata - }, false)["finally"](function() { - return updateLocked = false; - }); - }, 1000); + }; + sortData = function() { + if ($scope.sortedColumn === 'employee') { + return sortEmployeesBy(function(el) { + return el.name; + }); + } else if ($scope.sortedColumn === 'total') { + return sortEmployeesBy(function(el) { + return $scope.getLastValue(el); + }); } }; - onClickLegend = function() { - var i, len, ref, results, s, series; - series = this; - ref = $scope.chart.hc.series; - results = []; - for (i = 0, len = ref.length; i < len; i++) { - s = ref[i]; - if (s.userOptions.linkedTo !== series.name) { - continue; - } - if (series.visible) { - results.push(s.hide()); + $scope.drawTrigger = $q.defer(); + w.format = function() { + var all_values_are_positive, chartData, inputData, labels, options, pieData, pieOptions; + if ($scope.isDataFound && $scope.hasElements()) { + if (w.isHistoryMode) { + all_values_are_positive = true; + inputData = []; + labels = _.map(w.content.dates, function(date) { + if (w.metadata.hist_parameters && w.metadata.hist_parameters.period === "YEARLY") { + return $filter('momentDate')(date, 'YEARLY'); + } else if (w.metadata.hist_parameters && w.metadata.hist_parameters.period === "QUARTERLY") { + return $filter('momentDate')(date, 'QUARTERLY'); + } else if (w.metadata.hist_parameters && w.metadata.hist_parameters.period === "MONTHLY") { + return $filter('momentDate')(date, 'MONTHLY'); + } else if (w.metadata.hist_parameters && w.metadata.hist_parameters.period === "WEEKLY") { + return $filter('momentDate')(date, 'WEEKLY'); + } else if (w.metadata.hist_parameters && w.metadata.hist_parameters.period === "DAILY") { + return $filter('momentDate')(date, 'DAILY'); + } else { + return $filter('momentDate')(date, 'default'); + } + }); + angular.forEach($scope.selectedElements, function(sElem) { + var data; + data = angular.copy(sElem); + inputData.push({ + title: data.name, + labels: labels, + values: data.totals + }); + return angular.forEach(data.totals, function(value) { + return all_values_are_positive && (all_values_are_positive = value >= 0); + }); + }); + options = { + scaleBeginAtZero: all_values_are_positive, + showXLabels: true, + datasetFill: $scope.selectedElements.length === 1, + pointDot: $scope.selectedElements.length === 1, + currency: 'hide' + }; + chartData = ChartFormatterSvc.lineChart(inputData, options); } else { - results.push(s.show()); + pieData = _.map($scope.selectedElements, function(elem) { + return { + label: $filter('titleize')($scope.getName({ + name: elem.name + })), + value: $scope.getLastValue(elem) + }; + }); + pieOptions = { + showTooltips: true, + percentageInnerCutout: 50, + tooltipFontSize: 12, + currency: 'hide' + }; + chartData = ChartFormatterSvc.pieChart(pieData, pieOptions); } + return $scope.drawTrigger.notify(chartData); } - return results; }; - loadContacts = function() { - return BoltResources.index(w.metadata.bolt_path, 'contacts', { - metadata: _.pick(w.metadata, 'organization_ids') - }).then(function(response) { - return $scope.contacts = response.data.data; - }); + unCollapsedSetting = {}; + unCollapsedSetting.initialized = false; + unCollapsedSetting.initialize = function() { + return unCollapsedSetting.initialized = true; }; - createUser = function() { - if ($scope.firstCompanyId) { - return BoltResources.create(w.metadata.bolt_path, 'users', { - first_name: ImpacMainSvc.config.userData.name, - last_name: ImpacMainSvc.config.userData.surname, - email: ImpacMainSvc.config.userData.email - }, { - companies: { - data: [ - { - type: 'companies', - id: $scope.firstCompanyId - } - ] - } - }).then(function(response) { - return $scope.userId = response.data.data.id; - }); - } + unCollapsedSetting.toMetadata = function() { + return { + unCollapsed: $scope.unCollapsed + }; }; - w.initContext = function() { - var cashFlowSerie; - cashFlowSerie = _.find(w.content.chart.series, function(serie) { - return serie.name === "Cash flow"; + w.settings.push(unCollapsedSetting); + selectedElementsSetting = {}; + selectedElementsSetting.initialized = false; + selectedElementsSetting.initialize = function() { + return selectedElementsSetting.initialized = true; + }; + selectedElementsSetting.toMetadata = function() { + var selectedElementsMetadata; + selectedElementsMetadata = _.map($scope.selectedElements, function(element) { + return getIdentifier(element); }); - cashFlowSerie.data = []; - cashFlowSerie.type = 'area'; - cashFlowSerie.showInLegend = false; - BoltResources.index(w.metadata.bolt_path, 'companies', { - metadata: _.pick(w.metadata, 'organization_ids') - }).then(function(response) { - if (_.isEmpty(response.data.data)) { - w.demoData = true; - } else { - w.demoData = false; - $scope.firstCompanyId = response.data.data[0].id; - } - return loadContacts(); - }); - return BoltResources.index(w.metadata.bolt_path, 'users', { - filter: { - email: ImpacMainSvc.config.userData.email - }, - metadata: _.pick(w.metadata, 'organization_ids') - }).then(function(response) { - if (response.data.meta.record_count > 0) { - return $scope.userId = response.data.data[0].id; - } else { - return createUser(); - } - }); - }; - w.format = function() { - var _highChartOptions; - _highChartOptions = { - chartType: 'line', - currency: w.metadata.currency, - showToday: true + return { + selectedElements: selectedElementsMetadata }; - $scope.chart = new HighchartsFactory($scope.chartId(), w.content.chart.series, _highChartOptions); - $scope.chart.addCustomLegend(legendFormatter); - $scope.chart.addSeriesEvent('click', onClickBar); - $scope.chart.addSeriesEvent('legendItemClick', onClickLegend); - $scope.chart.addXAxisOptions({ - defaults: w.metadata.xAxis, - callback: onZoom - }); - $scope.chart.render(); - return $scope.chartDeferred.notify($scope.chart); }; + w.settings.push(selectedElementsSetting); return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetAccountsCashProjection', function() { + module.directive('widgetHrPayrollSummary', function() { return { restrict: 'A', - controller: 'WidgetAccountsCashProjectionCtrl' + controller: 'WidgetHrPayrollSummaryCtrl' }; }); @@ -10153,288 +10607,194 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
0) { - return "+" + aVariance + " %"; - } else { - return aVariance + " %"; + $scope.getPeriod = function() { + var period, period_param; + if ($scope.isDataFound && w.metadata && w.metadata.hist_parameters) { + period_param = w.metadata.hist_parameters.period || "MONTHLY"; + period = "day"; + if (period_param !== "DAILY") { + period = period_param.substr(0, period_param.length - 2).toLowerCase(); } - } else { - return "-"; - } - }; - $scope.getLastVariance = function(element) { - if ((element.variances != null) && (_.last(element.variances) != null)) { - return $scope.formatVariance(_.last(element.variances)); - } else { - return "-"; - } - }; - $scope.getVarianceClassColor = function(aVariance) { - if (parseInt(aVariance) > 0) { - return 'positive'; - } else if (parseInt(aVariance) < 0) { - return 'negative'; - } else { - return null; + return "(current " + period + ")"; } }; - $scope.getName = function(element) { - if ((element != null) && (element.name != null)) { - return element.name.replace(/_/g, " "); + $scope.drawTrigger = $q.defer(); + w.format = function() { + var all_values_are_positive, chartData, dates, inputData, options, period; + if ($scope.isDataFound) { + period = null; + if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { + period = w.metadata.hist_parameters.period; + } + dates = _.map(w.content.dates, function(date) { + return $filter('momentDate')(date, period); + }); + inputData = { + title: $translate.instant('impac.widget.hr_payroll_taxes.payroll_taxes'), + labels: dates, + values: w.content.total_tax + }; + all_values_are_positive = true; + angular.forEach(w.content.total_tax, function(value) { + return all_values_are_positive && (all_values_are_positive = value >= 0); + }); + options = { + scaleBeginAtZero: all_values_are_positive, + showXLabels: false + }; + chartData = ChartFormatterSvc.lineChart([inputData], options); + return $scope.drawTrigger.notify(chartData); } }; - $scope.sort = function(col) { - if ($scope.sortedColumn === col) { - $scope.ascending = !$scope.ascending; - } else { - $scope.ascending = true; - $scope.sortedColumn = col; - } - return sortData(); + return $scope.widgetDeferred.resolve(settingsPromises); + }]); + + module.directive('widgetHrPayrollTaxes', function() { + return { + restrict: 'A', + controller: 'WidgetHrPayrollTaxesCtrl' }; - $scope.toggleSelectedElement = function(element, statementName) { - if (statementName == null) { - statementName = null; - } - if ($scope.isSelected(element, statementName)) { - $scope.selectedElement = null; - if (w.isExpanded()) { - return w.toggleExpanded(); - } else { - return ImpacWidgetsSvc.updateWidgetSettings(w, false); - } - } else { - $scope.selectedElement = angular.copy(element); - $scope.selectedElement.category = statementName; - w.format(); - if (!w.isExpanded()) { - return w.toggleExpanded(); - } else { - return ImpacWidgetsSvc.updateWidgetSettings(w, false); - } + }); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets.hr-salaries-summary', []); + + module.controller('WidgetHrSalariesSummaryCtrl', ["$scope", "$q", "ChartFormatterSvc", "$translate", function($scope, $q, ChartFormatterSvc, $translate) { + var settingsPromises, w; + w = $scope.widget; + $scope.orgDeferred = $q.defer(); + $scope.widthDeferred = $q.defer(); + $scope.paramSelectorDeferred1 = $q.defer(); + $scope.paramSelectorDeferred2 = $q.defer(); + $scope.chartDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise, $scope.widthDeferred.promise, $scope.paramSelectorDeferred1.promise, $scope.paramSelectorDeferred2.promise, $scope.chartDeferred.promise]; + w.initContext = function() { + $scope.isDataFound = !_.isEmpty(w.content) && (w.content.summary != null) && !_.isEmpty(w.content.summary.data); + if ($scope.isDataFound) { + $scope.periodOptions = [ + { + label: _.capitalize($translate.instant("impac.widget.settings.time_period.period.yearly").toLowerCase()), + value: "yearly" + }, { + label: _.capitalize($translate.instant("impac.widget.settings.time_period.period.monthly").toLowerCase()), + value: "monthly" + }, { + label: _.capitalize($translate.instant("impac.widget.settings.time_period.period.weekly").toLowerCase()), + value: "weekly" + }, { + label: _.capitalize($translate.instant("impac.widget.settings.time_period.period.daily").toLowerCase()), + value: "daily" + } + ]; + $scope.filterOptions = [ + { + label: $translate.instant("impac.common.label.gender"), + value: "gender" + }, { + label: $translate.instant("impac.common.label.age_range"), + value: "age_range" + }, { + label: $translate.instant("impac.common.label.job_title"), + value: "job_title" + } + ]; + $scope.period = angular.copy(_.find($scope.periodOptions, function(o) { + return o.value === w.content.total.period.toLowerCase(); + }) || $scope.periodOptions[0]); + return $scope.filter = angular.copy(_.find($scope.filterOptions, function(o) { + return o.value === w.content.summary.filter; + }) || $scope.filterOptions[0]); } }; - $scope.isSelected = function(element, statementName) { - if (statementName == null) { - statementName = null; - } - return (element != null) && ($scope.selectedElement != null) && (matchElementToSelectedElement(element, statementName, $scope.selectedElement)); - }; - $scope.toggleCollapsed = function(element) { - if ((element != null) && (element.name != null)) { - if (_.find($scope.unCollapsed, (function(name) { - return element.name === name; - }))) { - $scope.unCollapsed = _.reject($scope.unCollapsed, function(name) { - return name === element.name; - }); - } else { - $scope.unCollapsed.push(element.name); - } - return ImpacWidgetsSvc.updateWidgetSettings(w, false); - } - }; - $scope.isCollapsed = function(element) { - if ((element != null) && (element.name != null)) { - if (_.find($scope.unCollapsed, (function(name) { - return element.name === name; - }))) { - return false; - } else { - return true; - } - if ($scope.selectedElement == null) { - return w.width = 6; - } - } - }; - $scope.getSelectLineColor = function(elem) { - return ChartFormatterSvc.getColor(0); - }; - fetchElement = function(statements) { - var element, i, len, statement; - for (i = 0, len = statements.length; i < len; i++) { - statement = statements[i]; - if (statement.accounts == null) { - continue; - } - element = _.find(statement.accounts, function(acc) { - return getIdentifier(acc, statement.name) === w.metadata.selectedElement; - }); - if (element != null) { - element = angular.merge(angular.copy(element), { - category: statement.name - }); - return element; - } - } - }; - matchElementToSelectedElement = function(element, elementCategory, sElem) { - if (elementCategory == null) { - elementCategory = null; - } - return getIdentifier(element, elementCategory) === getIdentifier(sElem); - }; - getIdentifier = function(element, category) { - var id; - if (category == null) { - category = null; - } - id = element.id || element.name; - category || (category = element.category); - if (!category) { - return id; - } - return category + "-" + id; - }; - sortAccountsBy = function(getElem) { - return angular.forEach(w.content.summary, function(sElem) { - if (sElem.accounts) { - return sElem.accounts.sort(function(a, b) { - var res; - res = getElem(a) > getElem(b) ? 1 : getElem(a) < getElem(b) ? -1 : 0; - if (!$scope.ascending) { - res *= -1; - } - return res; - }); - } - }); - }; - sortData = function() { - if ($scope.sortedColumn === 'account') { - return sortAccountsBy(function(el) { - return el.name; - }); - } else if ($scope.sortedColumn === 'total') { - return sortAccountsBy(function(el) { - return $scope.getLastValue(el); - }); - } else if ($scope.sortedColumn === 'variance') { - return sortAccountsBy(function(el) { - return $scope.getLastVariance(el); - }); - } + $scope.getColorByIndex = function(index) { + return ChartFormatterSvc.getColor(index); }; $scope.drawTrigger = $q.defer(); w.format = function() { - var all_values_are_positive, chartData, data, dates, inputData, options, period; - if ($scope.isDataFound && ($scope.selectedElement != null)) { - data = angular.copy($scope.selectedElement); - period = null; - if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { - period = w.metadata.hist_parameters.period; - } - dates = _.map(w.content.dates, function(date) { - return $filter('momentDate')(date, period); - }); - inputData = { - labels: dates, - datasets: [ + var barData, barOptions, chartData, lineData, lineOptions; + if ($scope.isDataFound) { + barData = { + labels: _.map(w.content.summary.data, function(elem) { + return elem.label; + }), + values: _.map(w.content.summary.data, function(elem) { + return elem.value; + }) + }; + if ($scope.filter.value === 'gender') { + barOptions = { + showTooltips: false + }; + chartData = ChartFormatterSvc.barChart(barData, barOptions); + } else if ($scope.filter.value === 'job_title') { + barOptions = { + showTooltips: false, + showXLabels: false, + barDatasetSpacing: 15 + }; + chartData = ChartFormatterSvc.barChart(barData, barOptions); + } else if ($scope.filter.value === 'age_range') { + if (_.last(barData.labels) === "unknown") { + barData.labels.pop(); + barData.values.pop(); + } + lineData = [ { - title: data.label, - values: data.cash_flows + title: "Average salary", + labels: barData.labels, + values: barData.values } - ] - }; - all_values_are_positive = true; - angular.forEach(data.cash_flows, function(value) { - return all_values_are_positive && (all_values_are_positive = value >= 0); - }); - options = { - scaleBeginAtZero: all_values_are_positive, - showXLabels: true - }; - chartData = ChartFormatterSvc.combinedBarChart(inputData, options); + ]; + lineOptions = { + scaleBeginAtZero: true, + showXLabels: false + }; + chartData = ChartFormatterSvc.lineChart(lineData, lineOptions); + } else { + return { + error: { + message: "wrong filter", + code: 400 + } + }; + } return $scope.drawTrigger.notify(chartData); } }; - unCollapsedSetting = {}; - unCollapsedSetting.initialized = false; - unCollapsedSetting.initialize = function() { - return unCollapsedSetting.initialized = true; - }; - unCollapsedSetting.toMetadata = function() { - return { - unCollapsed: $scope.unCollapsed - }; - }; - w.settings.push(unCollapsedSetting); - selectedElementSetting = {}; - selectedElementSetting.initialized = false; - selectedElementSetting.initialize = function() { - return selectedElementSetting.initialized = true; - }; - selectedElementSetting.toMetadata = function() { - if ($scope.selectedElement == null) { - return { - selectedElement: null - }; - } - return { - selectedElement: getIdentifier($scope.selectedElement) - }; - }; - w.settings.push(selectedElementSetting); return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetAccountsCashSummary', function() { + module.directive('widgetHrSalariesSummary', function() { return { restrict: 'A', - controller: 'WidgetAccountsCashSummaryCtrl' + controller: 'WidgetHrSalariesSummaryCtrl' }; }); @@ -10443,96 +10803,48 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
15) { - inputData.labels.length = 15; - } - if (inputData.values.length > 15) { - inputData.values.length = 15; - } - options = { - showTooltips: false, - showXLabels: false, - barValueSpacing: Math.max(8 - w.content.companies.length, 1) - }; - chartData = ChartFormatterSvc.barChart(inputData, options); - return $scope.drawTrigger.notify(chartData); + e = w.content.employees[0]; + if (w.metadata && w.metadata.employee_id) { + e = _.find(w.content.employees, function(e) { + return e.uid === w.metadata.employee_id; + }) || w.content.employees[0]; } + return angular.copy(e); }; return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetAccountsClassComparison', function() { + module.directive('widgetHrSuperannuationAccruals', function() { return { restrict: 'A', - controller: 'WidgetAccountsClassComparisonCtrl' + controller: 'WidgetHrSuperannuationAccrualsCtrl' }; }); @@ -10541,145 +10853,101 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
1) { - angular.merge($scope.comparisonModeOptions, w.metadata.comparison_mode); - } - $scope.savedAccountsList = gatherSavedAccounts(); - $scope.isDataFound = (w.content != null) && !_.isEmpty(w.content.complete_list) || $scope.isComparisonMode(); - $scope.noComparableAccounts = $scope.isComparisonMode() && (w.content != null) && _.isEmpty(w.content.complete_list); - return $scope.canSelectComparisonMode = scanAccountsForMultiOrgData(); - }); - }; - scanAccountsForMultiOrgData = function() { - if (w.content == null) { - return false; + if ($scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.employees) && !_.isEmpty(w.content.dates)) { + $scope.employeesOptions = _.map(w.content.employees, function(e) { + return { + value: e.id, + label: e.lastname + " " + e.firstname + }; + }); + $scope.selectedEmployee = { + value: $scope.getEmployee().id, + label: ($scope.getEmployee().lastname) + " " + ($scope.getEmployee().firstname) + }; + return $scope.unCollapsed = w.metadata.unCollapsed || []; } - return _.uniq(_.pluck(w.content.complete_list, 'org_name')).length > 1; }; - $scope.isComparisonMode = function() { - return _.result(_.find($scope.comparisonModeOptions, 'id', 'compare_accounts'), 'value') || false; + $scope.toggleCollapsed = function(categoryName) { + if (categoryName != null) { + if (_.find($scope.unCollapsed, (function(name) { + return categoryName === name; + }))) { + $scope.unCollapsed = _.reject($scope.unCollapsed, function(name) { + return name === categoryName; + }); + } else { + $scope.unCollapsed.push(categoryName); + } + return ImpacWidgetsSvc.updateWidgetSettings(w, false); + } }; - $scope.hasAccountsSelected = function() { - return w.selectedAccounts && w.selectedAccounts.length > 0; + $scope.isCollapsed = function(categoryName) { + if (categoryName != null) { + if (_.find($scope.unCollapsed, (function(name) { + return categoryName === name; + }))) { + return false; + } else { + return true; + } + } }; - $scope.getAccountColor = function(anAccount) { - if ($scope.isComparisonMode()) { - return ChartFormatterSvc.getColor(_.indexOf(w.selectedAccounts[0].accounts, anAccount)); + $scope.getEmployee = function() { + if (!$scope.isDataFound) { + return false; + } + if (w.metadata && w.metadata.employee_id) { + return _.find(w.content.employees, function(e) { + return e.id === w.metadata.employee_id; + }) || w.content.employees[0]; } else { - return ChartFormatterSvc.getColor(_.indexOf(w.selectedAccounts, anAccount)); + return w.content.employees[0]; } }; - $scope.addAccount = function(anAccount) { - if (!anAccount) { - return; + $scope.getEmployeeTimeWorked = function() { + var employee; + if (employee = $scope.getEmployee()) { + return _.find(w.content.employees, function(e) { + return e.id === employee.id; + }).total_time_worked; } - w.moveAccountToAnotherList(anAccount, w.remainingAccounts, w.selectedAccounts); - $scope.savedAccountsList.push(anAccount.uid); - return w.format(); }; - $scope.removeAccount = function(anAccount) { - if (!anAccount) { - return; + $scope.getEmployeeTimeOff = function() { + var employee; + if (employee = $scope.getEmployee()) { + return _.find(w.content.employees, function(e) { + return e.id === employee.id; + }).total_time_off; } - w.moveAccountToAnotherList(anAccount, w.selectedAccounts, w.remainingAccounts); - $scope.savedAccountsList.splice($scope.savedAccountsList.indexOf(anAccount.uid), 1); - return w.format(); - }; - $scope.formatAmount = function(anAccount) { - return $filter('mnoCurrency')(anAccount.current_balance, anAccount.currency); }; - gatherSavedAccounts = function() { - var areGrouped, group, i, len, savedUids, uid; - savedUids = w.metadata.accounts_list; - if (_.isEmpty(savedUids)) { - return []; - } - areGrouped = savedUids[0].indexOf(':') >= 0; - if (!$scope.isComparisonMode() && areGrouped) { - return _.flatten(_.map(savedUids, function(a) { - return a.split(':'); - })); - } else if ($scope.isComparisonMode() && !areGrouped) { - for (i = 0, len = savedUids.length; i < len; i++) { - uid = savedUids[i]; - group = _.find(w.content.complete_list, function(group) { - return group.uid.indexOf(uid) >= 0; - }); - if (group) { - return [group.uid]; - } - } - return []; - } else { - return savedUids; - } + unCollapsedSetting = {}; + unCollapsedSetting.initialized = false; + unCollapsedSetting.initialize = function() { + return unCollapsedSetting.initialized = true; }; - $scope.drawTrigger = $q.defer(); - w.format = function() { - var inputData; - inputData = { - labels: [], - values: [] + unCollapsedSetting.toMetadata = function() { + return { + unCollapsed: $scope.unCollapsed }; - return $timeout(function() { - var account, chartData, groupedAccount, i, j, len, len1, options, ref, ref1; - ref = w.selectedAccounts; - for (i = 0, len = ref.length; i < len; i++) { - account = ref[i]; - if ($scope.isComparisonMode()) { - ref1 = account.accounts; - for (j = 0, len1 = ref1.length; j < len1; j++) { - groupedAccount = ref1[j]; - inputData.labels.push(groupedAccount.name); - inputData.values.push(groupedAccount.current_balance); - } - } else { - inputData.labels.push(account.name); - inputData.values.push(account.current_balance); - } - } - while (inputData.values.length < 15) { - inputData.labels.push(""); - inputData.values.push(null); - } - options = { - showTooltips: false, - showXLabels: false, - barDatasetSpacing: 9 - }; - chartData = ChartFormatterSvc.barChart(inputData, options); - return $scope.drawTrigger.notify(chartData); - }, 500); }; + w.settings.push(unCollapsedSetting); return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetAccountsComparison', function() { + module.directive('widgetHrTimesheets', function() { return { restrict: 'A', - controller: 'WidgetAccountsComparisonCtrl' + controller: 'WidgetHrTimesheetsCtrl' }; }); @@ -10688,145 +10956,125 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
= 0); - return value; - }); - inputData.push({ - title: 'Test Data', - labels: dates, - values: data - }); - options = { - scaleBeginAtZero: all_values_are_positive, - showXLabels: false, - datasetFill: true, - pointDot: true - }; - chartData = ChartFormatterSvc.lineChart(inputData, options); - return $scope.drawTrigger.notify(chartData); - }, 500); - }; - $scope.addAccountToFormula = function(account) { - if (account == null) { - return; - } - if (w.selectedAccounts.length > 0) { - w.formula += " + {" + (w.selectedAccounts.length + 1) + "}"; - } else { - w.formula = "{1}"; + $scope.isDataFound = !_.isEmpty(w.content) && (w.content.summary != null) && !_.isEmpty(w.content.summary.data); + if ($scope.isDataFound) { + $scope.periodOptions = [ + { + label: _.capitalize($translate.instant("impac.widget.settings.time_period.period.yearly").toLowerCase()), + value: "yearly" + }, { + label: _.capitalize($translate.instant("impac.widget.settings.time_period.period.monthly").toLowerCase()), + value: "monthly" + }, { + label: _.capitalize($translate.instant("impac.widget.settings.time_period.period.weekly").toLowerCase()), + value: "weekly" + }, { + label: _.capitalize($translate.instant("impac.widget.settings.time_period.period.daily").toLowerCase()), + value: "daily" + } + ]; + $scope.filterOptions = [ + { + label: $translate.instant("impac.common.label.gender"), + value: "gender" + }, { + label: $translate.instant("impac.common.label.age_range"), + value: "age_range" + }, { + label: $translate.instant("impac.common.label.salary_range"), + value: "salary_range" + }, { + label: $translate.instant("impac.common.label.job_title"), + value: "job_title" + } + ]; + $scope.period = angular.copy(_.find($scope.periodOptions, function(o) { + return o.value === w.content.total.period.toLowerCase(); + }) || $scope.periodOptions[0]); + return $scope.filter = angular.copy(_.find($scope.filterOptions, function(o) { + return o.value === w.content.summary.filter; + }) || $scope.filterOptions[0]); } - return w.moveAccountToAnotherList(account, w.remainingAccounts, w.selectedAccounts, false); }; - $scope.removeAccountFromFormula = function(account) { - var diffAccountIndex, diffAccountUid, i, indexPattern, newFormula, nextUids, prevUids, removePattern; - prevUids = _.map(w.selectedAccounts, function(e) { - return e.uid; - }); - nextUids = _.reject(prevUids, function(e) { - return e === account.uid; - }); - diffAccountUid = _.first(_.difference(prevUids, nextUids)); - diffAccountIndex = _.indexOf(prevUids, diffAccountUid) + 1; - if (diffAccountIndex === 1) { - removePattern = "{" + diffAccountIndex + "\\}\\s*(-|\\*|\\/|\\+)*\\s*"; - } else { - removePattern = "\\s*(-|\\*|\\/|\\+)*\\s*\\{" + diffAccountIndex + "\\}"; - } - newFormula = angular.copy(w.formula).replace(new RegExp(removePattern, 'g'), ''); - i = diffAccountIndex + 1; - while (i <= prevUids.length) { - indexPattern = "\\{" + i + "\\}"; - newFormula = newFormula.replace(new RegExp(indexPattern, 'g'), "{" + (i - 1) + "}"); - i++; + $scope.getTotalWorkforce = function() { + if ($scope.isDataFound) { + return w.content.total.amount; } - w.formula = angular.copy(newFormula); - return w.moveAccountToAnotherList(account, w.selectedAccounts, w.remainingAccounts, false); - }; - $scope.formulaModal = $scope.$new(); - $scope.formulaModal.config = { - backdrop: 'static', - template: $templateCache.get('widgets/accounts-custom-calculation/formula.modal.html'), - size: 'lg', - scope: $scope.formulaModal, - keyboard: false - }; - $scope.formulaModal.open = function() { - var self; - self = $scope.formulaModal; - self.modalOrgDeferred = $q.defer(); - self.timePeriodDeferred = $q.defer(); - _.remove(w.settings, (function(set) { - return set.key === "organizations"; - })); - self.instance = $uibModal.open(self.config); - return $q.all([self.modalOrgDeferred.promise, self.timePeriodDeferred.promise]).then(function(success) { - return $scope.initSettings(); - }); }; - $scope.reloadAccountsLists = function(orgs) { - if ((orgs != null) && _.some(_.values(orgs))) { - return $scope.updateWidgetSettings(); + $scope.getNumberOfEmployees = function() { + if ($scope.isDataFound) { + return w.content.total.employees; } }; - $scope.updateWidgetSettings = function() { - return ImpacWidgetsSvc.updateWidgetSettings(w); - }; - $scope.formulaModal.cancel = function() { - $scope.initSettings(); - return $scope.formulaModal.close(); + $scope.getCurrency = function() { + if ($scope.isDataFound) { + return w.content.total.currency; + } }; - $scope.formulaModal.proceed = function() { - ImpacWidgetsSvc.updateWidgetSettings(w); - return $scope.formulaModal.close(); + $scope.formatSalaryRange = function(aRange) { + var range1, range2; + range1 = $filter('mnoCurrency')(aRange.label.split('-')[0], aRange.currency, false); + range2 = $filter('mnoCurrency')(aRange.label.split('-')[1], aRange.currency, false); + return [range1, range2].join(" - "); }; - $scope.formulaModal.close = function() { - return $scope.formulaModal.instance.close(); + $scope.getColorByIndex = function(index) { + return ChartFormatterSvc.getColor(index); }; - $scope.$watch((function() { - return w.isEditMode; - }), function(result, prev) { - if (result && !prev) { - return $scope.formulaModal.open(); + $scope.drawTrigger = $q.defer(); + w.format = function() { + var barData, barOptions, chartData, pieData, pieOptions; + if ($scope.isDataFound) { + if ($scope.filter.value === 'salary_range') { + barData = { + labels: _.map(w.content.summary.data, function(elem) { + return $scope.formatSalaryRange(elem); + }), + values: _.map(w.content.summary.data, function(elem) { + return elem.value; + }) + }; + barOptions = { + showTooltips: false, + showXLabels: false, + barDatasetSpacing: 15 + }; + chartData = ChartFormatterSvc.barChart(barData, barOptions); + } else { + pieData = _.map(w.content.summary.data, function(elem) { + return { + label: elem.label, + value: elem.value + }; + }); + pieOptions = { + showTooltips: true, + percentageInnerCutout: 50, + tooltipFontSize: 12 + }; + chartData = ChartFormatterSvc.pieChart(pieData, pieOptions); + } + return $scope.drawTrigger.notify(chartData); } - }); + }; return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetAccountsCustomCalculation', function() { + module.directive('widgetHrWorkforceSummary', function() { return { restrict: 'A', - controller: 'WidgetAccountsCustomCalculationCtrl' + controller: 'WidgetHrWorkforceSummaryCtrl' }; }); @@ -10835,77 +11083,156 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
0)) { + w.width = 6; } return sortData(); } }; - $scope.toggleCollapsed = function(groupName) { - if (groupName != null) { + $scope.getElementChartColor = function(index) { + if (index != null) { + return ChartFormatterSvc.getColor(index); + } + }; + $scope.getLastValue = function(element) { + if ((element != null) && (element.totals != null)) { + return _.last(element.totals); + } + }; + $scope.getTotalSum = function(element) { + if ((element != null) && (element.totals != null)) { + return _.reduce(element.totals, function(memo, num) { + return memo + num; + }, 0); + } + }; + $scope.getName = function(element) { + if ((element != null) && (element.name != null)) { + return element.name.replace(/_/g, " "); + } + }; + $scope.getPeriod = function() { + var period, period_param; + if ($scope.isDataFound && w.metadata && w.metadata.hist_parameters) { + period_param = w.metadata.hist_parameters.period || "MONTHLY"; + period = "day"; + if (period_param !== "DAILY") { + period = period_param.substr(0, period_param.length - 2).toLowerCase(); + } + return "current " + period; + } else { + return "current month"; + } + }; + $scope.getOldestInvoice = function(element) { + var idx; + idx = _.findIndex(element.totals, function(invoice) { + return invoice !== 0; + }); + return w.content.dates[idx] || null; + }; + $scope.sort = function(col) { + if ($scope.sortedColumn === col) { + $scope.ascending = !$scope.ascending; + } else { + $scope.ascending = true; + $scope.sortedColumn = col; + } + return sortData(); + }; + $scope.toggleSelectedElement = function(element, statementName) { + if (statementName == null) { + statementName = null; + } + if ($scope.isSelected(element, statementName)) { + $scope.selectedElements = _.reject($scope.selectedElements, function(sElem) { + return matchElementToSelectedElement(element, statementName, sElem); + }); + w.format(); + if (w.isExpanded() && $scope.selectedElements.length === 0) { + return w.toggleExpanded(); + } else { + return ImpacWidgetsSvc.updateWidgetSettings(w, false); + } + } else { + $scope.selectedElements || ($scope.selectedElements = []); + if (statementName) { + element.category = statementName; + } + $scope.selectedElements.push(element); + w.format(); + if (!w.isExpanded()) { + return w.toggleExpanded(); + } else { + return ImpacWidgetsSvc.updateWidgetSettings(w, false); + } + } + }; + $scope.isSelected = function(element, statementName) { + if (statementName == null) { + statementName = null; + } + return (element != null) && _.any($scope.selectedElements, function(sElem) { + return matchElementToSelectedElement(element, statementName, sElem); + }); + }; + $scope.toggleCollapsed = function(element) { + if ((element != null) && (element.name != null)) { if (_.find($scope.unCollapsed, (function(name) { - return groupName === name; + return element.name === name; }))) { $scope.unCollapsed = _.reject($scope.unCollapsed, function(name) { - return name === groupName; + return name === element.name; }); } else { - $scope.unCollapsed.push(groupName); + $scope.unCollapsed.push(element.name); } return ImpacWidgetsSvc.updateWidgetSettings(w, false); } }; - $scope.isCollapsed = function(groupName) { - if (groupName != null) { + $scope.isCollapsed = function(element) { + if ((element != null) && (element.name != null)) { if (_.find($scope.unCollapsed, (function(name) { - return groupName === name; + return element.name === name; }))) { return false; } else { @@ -10913,182 +11240,299 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
getElem(b) ? 1 : getElem(a) < getElem(b) ? -1 : 0; - if (!$scope.ascending) { - res *= -1; - } - return res; + $scope.getSelectLineColor = function(element, statementName) { + var sElem; + if (statementName == null) { + statementName = null; + } + sElem = _.find($scope.selectedElements, function(sElem) { + return matchElementToSelectedElement(element, statementName, sElem); + }); + if ($scope.hasElements()) { + return ChartFormatterSvc.getColor(_.indexOf($scope.selectedElements, sElem)); + } + }; + $scope.hasElements = function() { + return ($scope.selectedElements != null) && $scope.selectedElements.length > 0; + }; + matchElementToSelectedElement = function(element, elementCategory, sElem) { + if (elementCategory == null) { + elementCategory = null; + } + return getIdentifier(element, elementCategory) === getIdentifier(sElem); + }; + fetchElement = function(statements, sElemId) { + var element, elements, i, len, statement; + for (i = 0, len = statements.length; i < len; i++) { + statement = statements[i]; + elements = statement.suppliers || statement.customers; + if (_.isEmpty(elements)) { + continue; + } + element = _.find(elements, function(elem) { + return getIdentifier(elem, statement.name) === sElemId; + }); + if (element != null) { + element = angular.merge(angular.copy(element), { + category: statement.name }); + return element; + } + } + }; + getIdentifier = function(element, category) { + var id; + if (category == null) { + category = null; + } + id = element.id || element.name; + category || (category = element.category); + if (!category) { + return id; + } + return category + "-" + id; + }; + sortBy = function(data, getElem) { + return data.sort(function(a, b) { + var res; + res = getElem(a) > getElem(b) ? 1 : getElem(a) < getElem(b) ? -1 : 0; + if (!$scope.ascending) { + res *= -1; } + return res; }); }; + sortByInvoiceCallback = function(el) { + var date; + date = $scope.getOldestInvoice(el); + if (date && _.isString(date)) { + date = date.match(/[^_\W]+\s?/g).join(''); + } + return new Date(date); + }; sortData = function() { - if ($scope.sortedColumn === 'account') { - return sortAccountsBy(function(el) { - return el.label; + if ($scope.sortedColumn === 'customer') { + sortBy(w.content.payables.suppliers, function(el) { + return el.name; + }); + return sortBy(w.content.receivables.customers, function(el) { + return el.name; }); } else if ($scope.sortedColumn === 'total') { - return sortAccountsBy(function(el) { - return el.value; + sortBy(w.content.payables.suppliers, function(el) { + return $scope.getTotalSum(el); }); + return sortBy(w.content.receivables.customers, function(el) { + return $scope.getTotalSum(el); + }); + } else if ($scope.sortedColumn === 'invoice') { + sortBy(w.content.payables.suppliers, sortByInvoiceCallback); + return sortBy(w.content.receivables.customers, sortByInvoiceCallback); } }; - $scope.sort = function(col) { - if ($scope.sortedColumn === col) { - $scope.ascending = !$scope.ascending; - } else { - $scope.ascending = true; - $scope.sortedColumn = col; + buildFxTotals = function() { + var contact, contactFxTotals, fxTotal, i, j, len, len1, ref, ref1, results; + ref = _.union(w.content.payables.suppliers, w.content.receivables.customers); + results = []; + for (i = 0, len = ref.length; i < len; i++) { + contact = ref[i]; + contactFxTotals = []; + ref1 = contact.fx_totals; + for (j = 0, len1 = ref1.length; j < len1; j++) { + fxTotal = ref1[j]; + if (!_.isEmpty(fxTotal)) { + _.mapKeys(fxTotal, function(total, currency) { + if (currency !== w.metadata.currency) { + return contactFxTotals.push({ + currency: currency, + amount: total.amount, + rate: total.rate + }); + } + }); + } + } + if (!_.isEmpty(contactFxTotals)) { + results.push(contact.formattedFxTotals = contactFxTotals); + } else { + results.push(void 0); + } } - return sortData(); - }; - unCollapsedSetting = {}; - unCollapsedSetting.initialized = false; - unCollapsedSetting.initialize = function() { - return unCollapsedSetting.initialized = true; - }; - unCollapsedSetting.toMetadata = function() { - return { - unCollapsed: $scope.unCollapsed - }; - }; - w.settings.push(unCollapsedSetting); - return $scope.widgetDeferred.resolve(settingsPromises); - }]); - - module.directive('widgetAccountsDetailedClassifications', function() { - return { - restrict: 'A', - controller: 'WidgetAccountsDetailedClassificationsCtrl' + return results; }; - }); - -}).call(this); - + $scope.drawTrigger = $q.defer(); + w.format = function() { + var all_values_are_positive, chartData, dates, inputData, options, period; + if ($scope.isDataFound && ($scope.selectedElements != null) && $scope.selectedElements.length > 0) { + all_values_are_positive = true; + inputData = []; + period = null; + if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { + period = w.metadata.hist_parameters.period; + } + dates = _.map(w.content.dates, function(date, index) { + return $filter('momentDate')(date, period); + }); + angular.forEach($scope.selectedElements, function(sElem) { + var data; + data = angular.copy(sElem); + inputData.push({ + title: data.name, + labels: dates, + values: data.totals + }); + return angular.forEach(data.totals, function(value) { + return all_values_are_positive && (all_values_are_positive = value >= 0); + }); + }); + options = { + scaleBeginAtZero: all_values_are_positive, + showXLabels: true, + datasetFill: $scope.selectedElements.length === 1, + pointDot: $scope.selectedElements.length === 1 + }; + chartData = ChartFormatterSvc.lineChart(inputData, options); + return $scope.drawTrigger.notify(chartData); + } + }; + unCollapsedSetting = {}; + unCollapsedSetting.initialized = false; + unCollapsedSetting.initialize = function() { + return unCollapsedSetting.initialized = true; + }; + unCollapsedSetting.toMetadata = function() { + return { + unCollapsed: $scope.unCollapsed + }; + }; + w.settings.push(unCollapsedSetting); + selectedElementsSetting = {}; + selectedElementsSetting.initialized = false; + selectedElementsSetting.initialize = function() { + return selectedElementsSetting.initialized = true; + }; + selectedElementsSetting.toMetadata = function() { + var selectedElementsMetadata; + selectedElementsMetadata = _.map($scope.selectedElements, function(element) { + return getIdentifier(element); + }); + return { + selectedElements: selectedElementsMetadata + }; + }; + w.settings.push(selectedElementsSetting); + return $scope.widgetDeferred.resolve(settingsPromises); + }]); + + module.directive('widgetInvoicesAgedPayablesReceivables', function() { + return { + restrict: 'A', + controller: 'WidgetInvoicesAgedPayablesReceivablesCtrl' + }; + }); + +}).call(this); + (function() { var module; - module = angular.module('impac.components.widgets.accounts-expense-weight', []); + module = angular.module('impac.components.widgets.invoices-list', []); - module.controller('WidgetAccountsExpenseWeightCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "$translate", "$timeout", function($scope, $q, ChartFormatterSvc, $filter, $translate, $timeout) { - var settingsPromises, w; + module.controller('WidgetInvoicesListCtrl', ["$scope", "$q", "$sce", "$filter", "ImpacUtilities", "$translate", function($scope, $q, $sce, $filter, ImpacUtilities, $translate) { + var buildFxTotals, initInvoicesTooltips, settingsPromises, w; w = $scope.widget; $scope.orgDeferred = $q.defer(); - $scope.timePeriodDeferred = $q.defer(); - $scope.accountBackDeferred = $q.defer(); - $scope.accountFrontDeferred = $q.defer(); - $scope.chartDeferred = $q.defer(); - $scope.histModeDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.timePeriodDeferred, $scope.accountBackDeferred, $scope.accountFrontDeferred, $scope.chartDeferred.promise, $scope.histModeDeferred.promise]; - $scope.forwardParams = { - accountingBehaviour: 'pnl' - }; + $scope.limitEntriesDeferred = $q.defer(); + $scope.datesPickerDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise, $scope.limitEntriesDeferred.promise, $scope.datesPickerDeferred.promise]; w.initContext = function() { - $scope.isDataFound = (w.content != null) && !_.isEmpty(w.content.account_list); - return $scope.forwardParams.histParams = w.metadata && w.metadata.hist_parameters; - }; - $scope.getName = function() { - if (w.selectedAccount != null) { - return w.selectedAccount.name; + var dates, datesRange; + $scope.isDataFound = !_.isEmpty(w.content) && !_.isEmpty(w.content.entities); + if ($scope.isDataFound && $scope.orderBy === 'due ') { + if ($scope.entityType === 'suppliers') { + $scope.limitEntriesLabel = $translate.instant('impac.widget.invoices_list.limit_entries_label.creditors'); + } else { + $scope.limitEntriesLabel = $translate.instant('impac.widget.invoices_list.limit_entries_label.debtors'); + } } - }; - $scope.getComparator = function() { - switch (w.metadata.comparator) { - case 'turnover': - return $translate.instant("impac.widget.account_expense_weight.comparator.turnover"); - default: - return $translate.instant("impac.widget.account_expense_weight.comparator.total_exp"); + if ((w.metadata != null) && (w.metadata.limit_entries != null)) { + $scope.limitEntriesSelected = w.metadata.limit_entries; + } + if ($scope.isDataFound) { + dates = _.flatten(_.map(w.content.entities, (function(e) { + return _.map(e.invoices, (function(i) { + return i.invoice_date; + })); + }))); + datesRange = ImpacUtilities.getDatesRange(dates); + $scope.defaultFrom = $filter('date')(datesRange[0], 'yyyy-MM-dd'); + $scope.defaultTo = $filter('date')(datesRange[1], 'yyyy-MM-dd'); + initInvoicesTooltips(w.content.entities); + buildFxTotals(); + return $scope.ratesDate = moment.now(); } }; - $scope.displayAccount = function() { - return $scope.updateSettings(false).then(function() { - return $timeout(function() { - return w.format(); + $scope.entityType = w.metadata.entity; + $scope.entityTypeCap = _.capitalize(w.metadata.entity); + if (_.isEmpty(w.metadata.order_by) || w.metadata.order_by === 'name' || w.metadata.order_by === 'total_invoiced') { + $scope.orderBy = ''; + } else { + $scope.orderBy = _.last(w.metadata.order_by.split('_')).concat(" "); + } + $scope.invoiceTooltips = {}; + initInvoicesTooltips = function(entities) { + return _.each(entities, function(entity) { + var count, tooltip; + tooltip = ["" + entity.name + ""]; + count = 1; + _.each(entity.invoices, function(i) { + var amountDetail, formattedInvoiced, formattedPaid, invCurrency, txn; + txn = i.transaction_no !== "" ? " (" + i.transaction_no + ")" : ""; + invCurrency = Object.keys(i.fx_totals)[0]; + formattedInvoiced = $filter('mnoCurrency')(i.fx_totals[invCurrency].invoiced, invCurrency, true); + if (i.tooltip_status === "partially paid") { + formattedPaid = $filter('mnoCurrency')(i.fx_totals[invCurrency].paid, invCurrency, true); + amountDetail = " (" + formattedPaid + " on " + formattedInvoiced + ")"; + } else { + amountDetail = " (" + formattedInvoiced + ")"; + } + tooltip.push("#" + count + txn + " - " + i.tooltip_status + amountDetail); + return count++; }); + return $scope.invoiceTooltips[entity.id] = $sce.trustAsHtml(tooltip.join("
")); }); }; - $scope.drawTrigger = $q.defer(); - w.format = function() { - var all_values_are_positive, chartData, companies, datasets, dates, inputData, lineData, lineOptions, options, period, ratios; - if ($scope.isDataFound && (w.content.summary != null)) { - if (w.isHistoryMode) { - period = null; - if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { - period = w.metadata.hist_parameters.period; - } - dates = _.map(w.content.dates, function(date) { - return $filter('momentDate')(date, period); - }); - datasets = _.map(w.content.summary, function(s) { - return { - title: s.company, - values: s.ratios - }; - }); - all_values_are_positive = true; - angular.forEach(w.content.summary, function(s) { - return angular.forEach(s.ratios, function(ratio) { - return all_values_are_positive && (all_values_are_positive = ratio >= 0); + buildFxTotals = function() { + var contact, contactFxTotals, j, len, ref, results; + ref = w.content.entities; + results = []; + for (j = 0, len = ref.length; j < len; j++) { + contact = ref[j]; + contactFxTotals = []; + _.mapKeys(contact.fx_totals, function(total, currency) { + if (currency !== w.metadata.currency) { + return contactFxTotals.push({ + currency: currency, + amount: total.invoiced, + rate: total.rate }); - }); - lineData = { - labels: dates, - datasets: datasets - }; - lineOptions = { - scaleBeginAtZero: all_values_are_positive, - showXLabels: false, - currency: "(ratio)" - }; - chartData = ChartFormatterSvc.combinedBarChart(lineData, lineOptions, false, true); - } else { - companies = _.map(w.content.summary, function(s) { - return s.company; - }); - ratios = _.map(w.content.summary, function(s) { - return s.ratio; - }); - if (companies.length === 1) { - companies.push(companies[0]); - ratios.push(ratios[0]); } - inputData = { - labels: companies, - values: ratios - }; - options = { - scales: { - yAxes: [ - { - ticks: { - suggestedMin: 0, - suggestedMax: 100, - maxTicksLimit: 5 - } - } - ] - }, - showXLabels: false, - pointDot: false, - currency: '%' - }; - chartData = ChartFormatterSvc.lineChart([inputData], options); + }); + if (!_.isEmpty(contactFxTotals)) { + results.push(contact.formattedFxTotals = contactFxTotals); + } else { + results.push(void 0); } - return $scope.drawTrigger.notify(chartData); } + return results; }; return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetAccountsExpenseWeight', function() { + module.directive('widgetInvoicesList', function() { return { restrict: 'A', - controller: 'WidgetAccountsExpenseWeightCtrl' + controller: 'WidgetInvoicesListCtrl' }; }); @@ -11097,128 +11541,146 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
= 0 && anIndex < w.content.aged_sales[$scope.filter.value].length) { + return w.content.aged_sales[$scope.filter.value][anIndex]; + } + }; + $scope.getLastDate = function() { if ($scope.isDataFound) { - return w.content.currency; + return _.last(w.content.dates); } }; - $scope.toggleDisplayNetProfit = function() { - $scope.isNetProfitDisplayed = !!$scope.displayOptions[0].value; - $scope.updateSettings(false); - return w.format(); + $scope.getClassColor = function(prev, value) { + if (value < prev) { + return 'negative'; + } else if (value > prev) { + return 'positive'; + } else { + return null; + } }; $scope.drawTrigger = $q.defer(); w.format = function() { - var all_values_are_positive, chartData, datasets, dates, lineData, lineOptions, period, pieData, pieOptions; + var all_values_are_positive, chartData, inputData, options, period, values; if ($scope.isDataFound) { - if (w.isHistoryMode) { - period = null; - if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { - period = w.metadata.hist_parameters.period; - } - dates = _.map(w.content.dates, function(date) { - return $filter('momentDate')(date, period); + all_values_are_positive = true; + inputData = []; + values = w.content.aged_sales[$scope.filter.value]; + period = null; + if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { + period = w.metadata.hist_parameters.period; + } + $scope.formattedDates = _.map(w.content.dates, function(date) { + return $filter('momentDate')(date, period); + }); + inputData.push({ + title: $scope.filter.label, + labels: $scope.formattedDates, + values: values + }); + angular.forEach(values, function(value) { + return all_values_are_positive && (all_values_are_positive = value >= 0); + }); + options = { + scaleBeginAtZero: all_values_are_positive, + showXLabels: true, + datasetFill: true, + pointDot: true + }; + if ($scope.filter.value.indexOf('quantity') > -1) { + angular.merge(options, { + currency: 'hide' }); - if ($scope.isNetProfitDisplayed) { - datasets = [ - { - title: $translate.instant('impac.widget.accounts_expenses_revenue.net_profit') + (" (" + ($scope.getCurrency()) + ")"), - values: w.content.values.net_profit - } - ]; - all_values_are_positive = true; - angular.forEach(w.content.values.net_profit, function(value) { - return all_values_are_positive && (all_values_are_positive = value >= 0); - }); - } else { - datasets = [ - { - title: $translate.instant('impac.widget.accounts_expenses_revenue.expenses') + (" (" + ($scope.getCurrency()) + ")"), - values: w.content.values.expenses - }, { - title: $translate.instant('impac.widget.accounts_expenses_revenue.revenue') + (" (" + ($scope.getCurrency()) + ")"), - values: w.content.values.revenue - } - ]; - all_values_are_positive = true; - angular.forEach(w.content.values.expenses, function(value) { - return all_values_are_positive && (all_values_are_positive = value >= 0); - }); - angular.forEach(w.content.values.revenue, function(value) { - return all_values_are_positive && (all_values_are_positive = value >= 0); - }); - } - lineData = { - labels: dates, - datasets: datasets - }; - lineOptions = { - scaleBeginAtZero: all_values_are_positive, - showXLabels: false - }; - chartData = ChartFormatterSvc.combinedBarChart(lineData, lineOptions, false, true); - } else { - pieData = [ - { - label: $translate.instant('impac.widget.accounts_expenses_revenue.expenses') + (" (" + ($scope.getCurrency()) + ")"), - value: $scope.getCurrentExpenses() - }, { - label: $translate.instant('impac.widget.accounts_expenses_revenue.revenue') + (" (" + ($scope.getCurrency()) + ")"), - value: $scope.getCurrentRevenue() - } - ]; - pieOptions = { - tooltipFontSize: 12, - percentageInnerCutout: 0 - }; - chartData = ChartFormatterSvc.pieChart(pieData, pieOptions, true); } + chartData = ChartFormatterSvc.lineChart(inputData, options); return $scope.drawTrigger.notify(chartData); } }; return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetAccountsExpensesRevenue', function() { + module.directive('widgetSalesAged', function() { return { restrict: 'A', - controller: 'WidgetAccountsExpensesRevenueCtrl' + controller: 'WidgetSalesAgedCtrl' }; }); @@ -11227,179 +11689,73 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
" + ($filter('date')(date, 'd-MM-yy')); + } else { + return w.content.break_even.projected_date; + } } }; - $scope.getOpeningBalance = function() { - if (w.content != null) { - return _.find(w.content.figure.metrics, function(metric) { - return metric.label === 'opening'; - }); + $scope.getOpportunitiesToClose = function() { + var opps; + if ($scope.isDataFound && w.content.break_even) { + if (("" + w.content.break_even.opportunities_to_close).match('>')) { + opps = angular.copy(w.content.break_even.opportunities_to_close).replace('>', ''); + return "> " + opps; + } else { + return w.content.break_even.opportunities_to_close; + } } }; - $scope.getClosingBalance = function() { - if (w.content != null) { - return _.find(w.content.figure.metrics, function(metric) { - return metric.label === 'closing'; - }); + $scope.isTargetMet = function() { + if ($scope.isDataFound && w.content.break_even) { + return w.content.break_even.variance < 0; } }; - $scope.getTotal = function() { - var summary; - if (w.content != null) { - summary = _.find(w.content.table.tables, function(table) { - return table.table_title === 'Bank Summary'; - }); - } - if (w.selectedAccount != null) { - return _.find(summary.table_rows, function(row) { - var name_match; - name_match = w.selectedAccount.name === 'All Accounts' ? 'Total' : w.selectedAccount.name; - return row.column_1 === name_match; - }); + $scope.getVariance = function() { + if ($scope.isDataFound && w.content.break_even) { + return Math.abs(w.content.break_even.variance); } }; - $scope.getStatementBalance = function() { - var statement; - if (w.content != null) { - statement = _.find(w.content.table.tables, function(table) { - return table.table_title === 'Bank Statement'; - }); - } - if (statement) { - return _.find(statement.table_rows, function(row) { - return row.column_2 === "Closing Balance"; - }); - } + thresholdSetting = {}; + thresholdSetting.initialized = false; + thresholdSetting.initialize = function() { + return thresholdSetting.initialized = true; }; - $scope.displayAccount = function() { - return $scope.updateSettings(false).then(function() { - return w.format(); - }); + thresholdSetting.toMetadata = function() { + return { + threshold: $scope.threshold + }; }; - w.format = function() {}; + w.settings.push(thresholdSetting); return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetAccountsLiveBalance', function() { + module.directive('widgetSalesBreakEven', function() { return { restrict: 'A', - controller: 'WidgetAccountsLiveBalanceCtrl' + controller: 'WidgetSalesBreakEvenCtrl' }; }); @@ -11408,228 +11764,109 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
= 0); - } - ref1 = w.content.values.receivables; - for (j = 0, len1 = ref1.length; j < len1; j++) { - value = ref1[j]; - all_values_are_positive && (all_values_are_positive = value >= 0); - } - lineOptions = { - scaleBeginAtZero: all_values_are_positive, - showXLabels: false - }; - return $translate(['impac.widget.accounts_payable_receivable.payable', 'impac.widget.accounts_payable_receivable.receivable']).then(function(translation) { - var chartData, lineData; - lineData = [ - { - title: translation['impac.widget.accounts_payable_receivable.payable'], - labels: dates, - values: w.content.values.payables - }, { - title: translation['impac.widget.accounts_payable_receivable.receivable'], - labels: dates, - values: w.content.values.receivables - } - ]; - chartData = ChartFormatterSvc.lineChart(lineData, lineOptions, true); - return $scope.drawTrigger.notify(chartData); - }); - } - }; - return $scope.widgetDeferred.resolve(settingsPromises); - }]); - - module.directive('widgetAccountsPayableReceivable', function() { - return { - restrict: 'A', - controller: 'WidgetAccountsPayableReceivableCtrl' - }; - }); - -}).call(this); - -(function() { - var module; - - module = angular.module('impac.components.widgets.accounts-profit-and-loss', []); - - module.controller('WidgetAccountsProfitAndLossCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "ImpacWidgetsSvc", "ImpacUtilities", "$translate", "ImpacTheming", function($scope, $q, ChartFormatterSvc, $filter, ImpacWidgetsSvc, ImpacUtilities, $translate, ImpacTheming) { - var fetchElement, getIdentifier, getLastAmount, getPeriod, getTotalAmount, h, matchElementToSelectedElement, periodName, selectedElementsSetting, setAmountDisplayed, settingsPromises, sortAccountsBy, sortData, unCollapsedSetting, w; - w = $scope.widget; - $scope.orgDeferred = $q.defer(); - $scope.timePeriodDeferred = $q.defer(); - $scope.widthDeferred = $q.defer(); - $scope.chartDeferred = $q.defer(); - $scope.paramSelectorDeferred = $q.defer(); - $scope.tagFilterDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.timePeriodDeferred.promise, $scope.widthDeferred.promise, $scope.chartDeferred.promise, $scope.paramSelectorDeferred.promise, $scope.tagFilterDeferred.promise]; - $scope.ascending = true; - $scope.sortedColumn = 'account'; - $scope.filterTagsEnabled = ImpacTheming.get().widgetSettings.tagging.enabled; - setAmountDisplayed = function() { - return $scope.amountDisplayed = angular.copy(_.find($scope.amountDisplayedOptions, function(o) { - return w.metadata && o.value === w.metadata.amount_displayed; - }) || $scope.amountDisplayedOptions[1]); - }; - $translate(['impac.widget.accounts_profit_and_loss.last_period', 'impac.widget.accounts_profit_and_loss.total_for_period']).then(function(translation) { - $scope.amountDisplayedOptions = [ - { - label: translation['impac.widget.accounts_profit_and_loss.last_period'], - value: 'last' - }, { - label: translation['impac.widget.accounts_profit_and_loss.total_for_period'], - value: 'total' - } - ]; - return setAmountDisplayed(); - }); - periodName = (h = $scope.widget.metadata.hist_parameters) && h.period ? h.period.toLowerCase() : 'monthly'; - $translate('impac.widget.settings.time_period.period.' + periodName).then(function(translation) { - return $scope.period_translation = _.capitalize(translation.toLowerCase()); - }); - $scope.isReportFiltered = function() { - return (w.metadata != null) && (w.metadata.filter_query != null) && Object.keys(w.metadata.filter_query).length > 0; - }; - w.initContext = function() { - var dates, firstDate, foundElem, histParams, i, lastDate, len, ref, sElemId; - if ($scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.summary) && !_.isEmpty(w.content.dates)) { - $scope.dates = w.content.dates; - $scope.unCollapsed = w.metadata.unCollapsed || []; - if (w.metadata && (histParams = w.metadata.hist_parameters)) { - dates = ImpacUtilities.selectedTimeRange(histParams); - firstDate = $filter('momentDate')(dates.from, getPeriod()); - lastDate = $filter('momentDate')(dates.to, getPeriod()); - $scope.amountDisplayedOptions[1].label = firstDate + " to " + lastDate; - $scope.amountDisplayedOptions[0].label = lastDate; - } - setAmountDisplayed(); - if (!_.isEmpty(w.metadata.selectedElements)) { - $scope.selectedElements = []; - ref = w.metadata.selectedElements; - for (i = 0, len = ref.length; i < len; i++) { - sElemId = ref[i]; - foundElem = _.find(w.content.summary, function(statement) { - return statement.name === sElemId; - }); - foundElem || (foundElem = fetchElement(w.content.summary, sElemId)); - if (foundElem) { - $scope.selectedElements.push(foundElem); - } - } - } - if (!_.any($scope.selectedElements)) { - w.width = 6; - } - return sortData(); - } - }; - $scope.getElementChartColor = function(index) { - return ChartFormatterSvc.getColor(index); - }; - getPeriod = function() { - if ((w.metadata != null) && (w.metadata.hist_parameters != null) && (w.metadata.hist_parameters.period != null)) { - return w.metadata.hist_parameters.period; - } else { - return 'MONTHLY'; - } - }; - getLastAmount = function(element) { - if (element.totals != null) { - return _.last(element.totals); - } - }; - getTotalAmount = function(element) { - if (element.totals != null) { - return _.sum(element.totals); - } - }; - $scope.getAmount = function(element) { - switch ($scope.amountDisplayed.value) { - case 'total': - return getTotalAmount(element); - default: - return getLastAmount(element); - } - }; - $scope.getClassColor = function(aTotal) { - if (parseInt(aTotal) > 0) { - return 'positive'; - } else if (parseInt(aTotal) < 0) { - return 'negative'; - } else { - return null; - } - }; - $scope.getName = function(element) { - if ((element != null) && (element.name != null)) { - return element.name.replace(/_/g, " "); - } - }; - $scope.sort = function(col) { - if ($scope.sortedColumn === col) { - $scope.ascending = !$scope.ascending; - } else { - $scope.ascending = true; - $scope.sortedColumn = col; - } - return sortData(); - }; - $scope.toggleSelectedElement = function(element, statementName) { - var selectedElement; - if (statementName == null) { - statementName = null; - } - if ($scope.isSelected(element, statementName)) { - $scope.selectedElements = _.reject($scope.selectedElements, function(sElem) { - return matchElementToSelectedElement(element, statementName, sElem); + $scope.getElementChartColor = function(index) { + return ChartFormatterSvc.getColor(index); + }; + $scope.sort = function(col) { + if ($scope.sortedColumn === col) { + $scope.ascending = !$scope.ascending; + } else { + $scope.ascending = true; + $scope.sortedColumn = col; + } + return sortData(); + }; + $scope.toggleSelectedElement = function(element, statementName) { + var selectedElement; + if (statementName == null) { + statementName = null; + } + if ($scope.isSelected(element, statementName)) { + $scope.selectedElements = _.reject($scope.selectedElements, function(sElem) { + return matchElementToSelectedElement(element, statementName, sElem); }); w.format(); if (w.isExpanded() && $scope.selectedElements.length === 0) { @@ -11683,6 +11920,9 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
0; + }; $scope.getSelectLineColor = function(element, statementName) { var sElem; if (statementName == null) { @@ -11695,9 +11935,6 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
0; - }; matchElementToSelectedElement = function(element, elementCategory, sElem) { if (elementCategory == null) { elementCategory = null; @@ -11708,11 +11945,11 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
getElem(b) ? 1 : getElem(a) < getElem(b) ? -1 : 0; if (!$scope.ascending) { @@ -11749,13 +11986,13 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
= 0); @@ -11787,167 +12024,111 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
-1) { + angular.merge(options, { + currency: 'hide' + }); + } chartData = ChartFormatterSvc.lineChart(inputData, options); return $scope.drawTrigger.notify(chartData); } }; - unCollapsedSetting = {}; - unCollapsedSetting.initialized = false; - unCollapsedSetting.initialize = function() { - return unCollapsedSetting.initialized = true; - }; - unCollapsedSetting.toMetadata = function() { - return { - unCollapsed: $scope.unCollapsed - }; - }; - w.settings.push(unCollapsedSetting); - selectedElementsSetting = {}; - selectedElementsSetting.initialized = false; - selectedElementsSetting.initialize = function() { - return selectedElementsSetting.initialized = true; - }; - selectedElementsSetting.toMetadata = function() { - var selectedElementsMetadata; - selectedElementsMetadata = _.map($scope.selectedElements, function(element) { - return getIdentifier(element); - }); - return { - selectedElements: selectedElementsMetadata - }; - }; - w.settings.push(selectedElementsSetting); - return $scope.widgetDeferred.resolve(settingsPromises); - }]); - - module.directive('widgetAccountsProfitAndLoss', function() { - return { - restrict: 'A', - controller: 'WidgetAccountsProfitAndLossCtrl' - }; - }); - -}).call(this); - -(function() { - var module; - - module = angular.module('impac.components.widgets.accounts-ratios', []); - - module.controller('WidgetAccountsRatiosCtrl', ["$scope", "$q", "$filter", "$translate", "ChartFormatterSvc", "ImpacTheming", function($scope, $q, $filter, $translate, ChartFormatterSvc, ImpacTheming) { - var getPrefix, settingsPromises, w; - w = $scope.widget; - $scope.orgDeferred = $q.defer(); - $scope.chartDeferred = $q.defer(); - $scope.timePeriodDeferred = $q.defer(); - $scope.histModeDeferred = $q.defer(); - $scope.numeratorOffsetsDeferred = $q.defer(); - $scope.denominatorOffsetsDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.chartDeferred.promise, $scope.timePeriodDeferred.promise, $scope.histModeDeferred.promise, $scope.numeratorOffsetsDeferred.promise, $scope.denominatorOffsetsDeferred.promise]; - $scope.totalRatio = 0; - $scope.totalNumerator = 0; - $scope.totalDenominator = 0; - $scope.calculatedNumerator = 0; - $scope.calculatedDenominator = 0; - $scope.simulationMode = false; - $scope.intervalsCount = 0; - $scope.isPnl = false; - $scope.periodInfoContext = {}; - getPrefix = function(behaviour) { - var label, labels, needPrefix, prefix, todayPrefixes; - labels = ImpacTheming.get().widgetSettings.histModeChoser.currentLabels; - todayPrefixes = ImpacTheming.get().widgetSettings.histModeChoser.todayPrefixes; - needPrefix = _.last(w.content.layout.dates) === moment().format('YYYY-MM-DD'); - label = labels[behaviour]; - prefix = todayPrefixes[behaviour]; - return $translate([label, prefix]).then(function(translations) { - if (needPrefix) { - return translations[prefix] + " " + translations[label]; - } else { - return translations[label]; - } - }); - }; - w.initContext = function() { - var behaviour; - $scope.isDataFound = !_.isEmpty(w.content); - if ($scope.isDataFound) { - $scope.intervalsCount = _.size(w.content.layout.dates); - $scope.endDate = _.last(w.content.layout.dates); - behaviour = w.content.layout.accounting_behaviour; - $scope.periodInfoContext.histParams = w.metadata.hist_parameters; - $scope.periodInfoContext.accountingBehaviour = behaviour; - getPrefix(behaviour).then(function(label) { - return $scope.periodInfoContext.injectBefore = label; - }); - if (behaviour === 'pnl') { - $scope.totalRatio = w.content.calculation.ratio.average; - $scope.totalNumerator = _.sum(w.content.calculation.numerator.totals); - $scope.totalDenominator = _.sum(w.content.calculation.denominator.totals); - $scope.calculatedNumerator = _.sum(w.content.calculation.numerator.values); - $scope.calculatedDenominator = _.sum(w.content.calculation.denominator.values); - return $scope.isPnl = true; - } else { - $scope.totalRatio = _.last(w.content.calculation.ratio.totals); - $scope.totalNumerator = _.last(w.content.calculation.numerator.totals); - $scope.totalDenominator = _.last(w.content.calculation.denominator.totals); - $scope.calculatedNumerator = _.last(w.content.calculation.numerator.values); - return $scope.calculatedDenominator = _.last(w.content.calculation.denominator.values); - } + buildFxTotals = function() { + var grossSaleFxTotals, groupedSales, i, len, netSaleFxTotals, ref, results, sale; + ref = w.content.sales_comparison; + results = []; + for (i = 0, len = ref.length; i < len; i++) { + groupedSales = ref[i]; + results.push((function() { + var j, len1, ref1, results1; + ref1 = groupedSales.sales; + results1 = []; + for (j = 0, len1 = ref1.length; j < len1; j++) { + sale = ref1[j]; + sale.formattedFxTotals = {}; + netSaleFxTotals = []; + grossSaleFxTotals = []; + if (!_.isEmpty(sale.fx_totals)) { + _.mapKeys(sale.fx_totals, function(total, currency) { + var grossAmount, k, l, len2, len3, netAmount, ref2, ref3, results2; + ref2 = total['net_value_sold']; + for (k = 0, len2 = ref2.length; k < len2; k++) { + grossAmount = ref2[k]; + if (!(grossAmount === 0 || currency === w.metadata.currency)) { + netSaleFxTotals.push({ + currency: currency, + amount: grossAmount, + rate: total.rate + }); + } + } + ref3 = total['gross_value_sold']; + results2 = []; + for (l = 0, len3 = ref3.length; l < len3; l++) { + netAmount = ref3[l]; + if (!(netAmount === 0 || currency === w.metadata.currency)) { + results2.push(grossSaleFxTotals.push({ + currency: currency, + amount: netAmount, + rate: total.rate + })); + } else { + results2.push(void 0); + } + } + return results2; + }); + } + if (!_.isEmpty(netSaleFxTotals)) { + sale.formattedFxTotals['net_value_sold'] = netSaleFxTotals; + } + if (!_.isEmpty(grossSaleFxTotals)) { + results1.push(sale.formattedFxTotals['gross_value_sold'] = grossSaleFxTotals); + } else { + results1.push(void 0); + } + } + return results1; + })()); } + return results; }; - $scope.toggleSimulationMode = function(init) { - if (init == null) { - init = false; - } - if (init) { - $scope.initSettings(); - } - return $scope.simulationMode = !$scope.simulationMode; + unCollapsedSetting = {}; + unCollapsedSetting.initialized = false; + unCollapsedSetting.initialize = function() { + return unCollapsedSetting.initialized = true; }; - $scope.saveSimulation = function() { - $scope.updateSettings(); - return $scope.toggleSimulationMode(); + unCollapsedSetting.toMetadata = function() { + return { + unCollapsed: $scope.unCollapsed + }; }; - $scope.drawTrigger = $q.defer(); - w.format = function() { - var chartData, data, dates, inputData, options, period; - if ($scope.isDataFound) { - data = angular.copy(w.content); - period = null; - if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { - period = w.metadata.hist_parameters.period; - } - dates = _.map(data.layout.dates, function(date) { - return $filter('momentDate')(date, period); - }); - inputData = { - labels: dates, - datasets: [ - { - title: data.layout.ratio, - values: data.calculation.ratio.totals - } - ] - }; - options = { - currency: 'hide', - showXLabels: false - }; - chartData = ChartFormatterSvc.combinedBarChart(inputData, options, false); - return $scope.drawTrigger.notify(chartData); - } + w.settings.push(unCollapsedSetting); + selectedElementsSetting = {}; + selectedElementsSetting.initialized = false; + selectedElementsSetting.initialize = function() { + return selectedElementsSetting.initialized = true; + }; + selectedElementsSetting.toMetadata = function() { + var selectedElementsMetadata; + selectedElementsMetadata = _.map($scope.selectedElements, function(sElem) { + return getIdentifier(sElem); + }); + return { + selectedElements: selectedElementsMetadata + }; }; + w.settings.push(selectedElementsSetting); return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetAccountsRatios', function() { + module.directive('widgetSalesComparison', function() { return { restrict: 'A', - controller: 'WidgetAccountsRatiosCtrl' + controller: 'WidgetSalesComparisonCtrl' }; }); @@ -11956,192 +12137,196 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
= 0); + return $scope.statusOptions.push({ + label: status, + selected: isSelected + }); + }); } }; - $scope.getSingleCompanyName = function() { - var org, orgUid; - if (w.content && w.content.organizations) { - orgUid = w.content.organizations[0]; - org = _.find($scope.parentDashboard.data_sources, function(o) { - return o.uid === orgUid; - }); - return org.label; + w.processError = function(error) { + if (error.code === 404) { + return $scope.isDataFound = false; } }; - $scope.getEmployeeEarnings = function(anEmployee) { - if (anEmployee.salary != null) { - return $filter('mnoCurrency')(anEmployee.salary.amount, w.content.total.currency); - } else { - return '-'; + $scope.drawTrigger = $q.defer(); + w.format = function() { + var chartData, pieData, pieOptions; + if ($scope.isDataFound) { + pieData = _.compact(_.map($scope.statusOptions, function(statusOption) { + var value; + value = w.content.status_average_durations[statusOption.label]; + if (statusOption.selected && angular.isDefined(value)) { + return { + label: ($filter('titleize')(statusOption.label)) + ": " + value + " " + $scope.unit, + value: value + }; + } + })); + pieOptions = { + percentageInnerCutout: 50, + tooltipFontSize: 12, + currency: w.content.unit + }; + chartData = ChartFormatterSvc.pieChart(pieData, pieOptions); + return $scope.drawTrigger.notify(chartData); } }; return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetHrEmployeesList', function() { + module.directive('widgetSalesCycle', function() { return { restrict: 'A', - controller: 'WidgetHrEmployeesListCtrl' + controller: 'WidgetSalesCycleCtrl' }; }); @@ -12150,65 +12335,81 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
= 0); + }); + options = { + scaleBeginAtZero: all_values_are_positive, + showXLabels: true, + datasetFill: true, + pointDot: false + }; + chartData = ChartFormatterSvc.lineChart(inputData, options); + return $scope.drawTrigger.notify(chartData); } - return angular.copy(e); }; - employee = $scope.getEmployee(); - name = employee && employee.leaves[0].name; - if (name) { - $scope.vacationLeaves_translation = name; - } else { - $translate('impac.widget.hr_leaves_balance.vacation_leaves').then(function(translation) { - return $scope.vacationLeaves_translation = translation; - }); - } - name = employee && employee.leaves[1].name; - if (name) { - $scope.sickLeaves_translation = name; - } else { - $translate('impac.widget.hr_leaves_balance.sick_leaves').then(function(translation) { - return $scope.sickLeaves_translation = translation; - }); - } return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetHrLeavesBalance', function() { + module.directive('widgetSalesForecast', function() { return { restrict: 'A', - controller: 'WidgetHrLeavesBalanceCtrl' + controller: 'WidgetSalesForecastCtrl' }; }); @@ -12217,412 +12418,325 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
threshold) { + return codeName; + } else { + return fullName; + } + }; + $scope.drawTrigger = $q.defer(); + w.format = function() { + var all_values_are_positive, chartData, data, dates, inputData, options, period; + if ($scope.isDataFound && $scope.product && (data = $scope.getSelectedProduct())) { + period = null; + if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { + period = w.metadata.hist_parameters.period; + } + dates = _.map(w.content.dates, function(date) { + return $filter('momentDate')(date, period); + }); + inputData = { + title: data.name, + labels: dates, + values: data.totals + }; + all_values_are_positive = true; + angular.forEach(data.totals, function(value) { + return all_values_are_positive && (all_values_are_positive = value >= 0); + }); + options = { + scaleBeginAtZero: all_values_are_positive, + showXLabels: false + }; + if ($scope.filter.value.indexOf('quantity') > -1) { + angular.merge(options, { + currency: 'hide' + }); + } + chartData = ChartFormatterSvc.lineChart([inputData], options); + return $scope.drawTrigger.notify(chartData); } }; return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetHrLeavesSchedule', function() { + module.directive('widgetSalesGrowth', function() { return { restrict: 'A', - controller: 'WidgetHrLeavesScheduleCtrl' + controller: 'WidgetSalesGrowthCtrl' }; }); - module.directive('widgetComponentCalendar', ["$tranlate", function($tranlate) { - return { - scope: { - events: '=ngModel' - }, - restrict: 'A', - link: function(scope, element) { - var calendarOptions, getEvents; - scope.eventSources = []; - calendarOptions = { - header: { - left: $tranlate.instant('impac.common.action.calendar.left'), - center: $tranlate.instant('impac.common.action.calendar.center'), - right: $tranlate.instant('impac.common.action.calendar.right') - }, - contentHeight: 204 - }; - getEvents = function() { - return scope.events; - }; - return scope.$watch(getEvents, function(events) { - if (events.length > 0) { - element.fullCalendar('destroy'); - angular.extend(calendarOptions, { - events: scope.events - }); - return element.fullCalendar(calendarOptions); - } - }, true); - } - }; - }]); - }).call(this); (function() { - var module; + var module, + indexOf = [].indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; }; - module = angular.module('impac.components.widgets.hr-payroll-summary', []); + module = angular.module('impac.components.widgets.sales-leads-funnel', []); - module.controller('WidgetHrPayrollSummaryCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "ImpacWidgetsSvc", "$translate", function($scope, $q, ChartFormatterSvc, $filter, ImpacWidgetsSvc, $translate) { - var fetchElement, getIdentifier, h, matchElementToSelectedElement, periodName, selectedElementsSetting, settingsPromises, sortData, sortEmployeesBy, unCollapsedSetting, w; + module.controller('WidgetSalesLeadsFunnelCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "$sce", "ImpacWidgetsSvc", "ImpacDashboardsSvc", "$translate", function($scope, $q, ChartFormatterSvc, $filter, $sce, ImpacWidgetsSvc, ImpacDashboardsSvc, $translate) { + var hasOneLead, selectedStatusSetting, setLeadDescriptionTooltips, settingsPromises, w; w = $scope.widget; $scope.orgDeferred = $q.defer(); $scope.timePeriodDeferred = $q.defer(); + $scope.paramsPickerDeferred = $q.defer(); $scope.widthDeferred = $q.defer(); - $scope.histModeDeferred = $q.defer(); - $scope.chartDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.timePeriodDeferred.promise, $scope.widthDeferred.promise, $scope.histModeDeferred.promise, $scope.chartDeferred.promise]; - $scope.ascending = true; - $scope.sortedColumn = 'employee'; - periodName = (h = $scope.widget.metadata.hist_parameters) && h.period ? h.period.toLowerCase() : 'monthly'; - $scope.periodTranslation = $translate.instant("impac.widget.settings.time_period.period." + periodName); + settingsPromises = [$scope.orgDeferred.promise, $scope.timePeriodDeferred.promise, $scope.paramsPickerDeferred.promise, $scope.widthDeferred.promise]; + hasOneLead = function(leadsPerStatus) { + var reducedHash, total, totalsArray; + reducedHash = _.mapValues(leadsPerStatus, function(statusHash) { + return statusHash.total; + }); + totalsArray = _.compact(_.values(reducedHash)); + total = _.reduce(totalsArray, function(total, n) { + if (total == null) { + total = 0; + } + return total + n; + }); + return (total != null) && total > 0; + }; w.initContext = function() { - var foundElem, i, len, ref, sElemId; - if ($scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.summary) && !_.isEmpty(w.content.dates)) { - $scope.unCollapsed = w.metadata.unCollapsed || []; - if (!_.isEmpty(w.metadata.selectedElements)) { - $scope.selectedElements = []; - ref = w.metadata.selectedElements; - for (i = 0, len = ref.length; i < len; i++) { - sElemId = ref[i]; - foundElem = _.find(w.content.summary, function(statement) { - return statement.name === sElemId; - }); - foundElem || (foundElem = fetchElement(w.content.summary, sElemId)); - if (foundElem) { - $scope.selectedElements.push(foundElem); - } - } - } - if (!(($scope.selectedElements != null) && $scope.selectedElements.length > 0)) { - w.width = 6; - } - return sortData(); - } - }; - $scope.getElementChartColor = function(index) { - return ChartFormatterSvc.getColor(index); - }; - $scope.getLastValue = function(element) { - return (element.totals && element.totals[element.totals.length - 1]) || 0; - }; - $scope.getTotalSum = function(element) { - if (element.totals != null) { - return _.reduce(element.totals, function(memo, num) { - return memo + num; - }, 0); - } - }; - $scope.getName = function(element) { - if ((element != null) && (element.name != null)) { - if (element.name === "total_leaves") { - return $translate.instant('impac.widget.hr_payroll_summary.total_leaves'); - } - if (element.name === "total_super") { - return $translate.instant('impac.widget.hr_payroll_summary.total_superannuation'); - } - if (element.name === "total_reimbursement") { - return $translate.instant('impac.widget.hr_payroll_summary.total_reimbursements'); - } - if (element.name === "total_tax") { - return $translate.instant('impac.widget.hr_payroll_summary.total_taxes'); - } - if (element.name === "total_timeoff") { - return $translate.instant('impac.widget.hr_payroll_summary.total_time_off'); - } - return element.name.replace(/_/g, " "); - } - }; - $scope.getTrackedField = function() { - var allFieldsEquals, field; - if (!_.isEmpty($scope.selectedElements) && ($scope.selectedElements[0].id != null)) { - field = $scope.selectedElements[0].id.split('-')[0]; - allFieldsEquals = true; - angular.forEach($scope.selectedElements, function(element) { - return allFieldsEquals && (allFieldsEquals = element.id && field === element.id.split('-')[0]); + var dhb, status_selection; + dhb = ImpacDashboardsSvc.getCurrentDashboard(); + status_selection = w.metadata.status_selection || dhb.metadata.status_selection || { + values: [] + }; + if ($scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.leads_per_status) && hasOneLead(w.content.leads_per_status)) { + _.remove(status_selection.values, function(status) { + return indexOf.call(_.keys(w.content.leads_per_status), status) < 0; }); - if (allFieldsEquals) { - return $scope.getName({ - name: field + $scope.hasReach = true; + $scope.statusOptions = []; + return angular.forEach(w.content.leads_per_status, function(value, status) { + var isSelected; + isSelected = _.isEmpty(status_selection.values) || (indexOf.call(status_selection.values, status) >= 0); + return $scope.statusOptions.push({ + label: status, + selected: isSelected }); - } else { - return null; - } + }); } }; - $scope.formatDate = function(date) { - if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { - return $filter('momentDate')(date, w.metadata.hist_parameters.period); - } else { - return $filter('momentDate')(date, 'default'); + w.processError = function(error) { + if (error.code === 404) { + return $scope.isDataFound = false; } }; - $scope.sort = function(col) { - if ($scope.sortedColumn === col) { - $scope.ascending = !$scope.ascending; - } else { - $scope.ascending = true; - $scope.sortedColumn = col; - } - return sortData(); + $scope.getImpacColor = function(index) { + return ChartFormatterSvc.getColor(index); }; - $scope.toggleSelectedElement = function(element, statementName) { - var selectedElement; - if (statementName == null) { - statementName = null; + $scope.toggleSelectStatus = function(aStatus) { + if ($scope.selectedStatus && $scope.selectedStatus === aStatus) { + $scope.selectedStatus = null; + } else { + $scope.selectedStatus = aStatus; + $scope.setLeadTooltipsIsLocked = false; } - if ($scope.isSelected(element, statementName)) { - $scope.selectedElements = _.reject($scope.selectedElements, function(sElem) { - return matchElementToSelectedElement(element, statementName, sElem); - }); - w.format(); - if (w.isExpanded() && $scope.selectedElements.length === 0) { - return w.toggleExpanded(); - } else { - return ImpacWidgetsSvc.updateWidgetSettings(w, false); - } + if (!w.isExpanded() && $scope.selectedStatus) { + return w.toggleExpanded(); } else { - selectedElement = angular.copy(element); - selectedElement.category = statementName; - $scope.selectedElements || ($scope.selectedElements = []); - $scope.selectedElements.push(selectedElement); - w.format(); - if (!w.isExpanded()) { - return w.toggleExpanded(); - } else { - return ImpacWidgetsSvc.updateWidgetSettings(w, false); - } + return ImpacWidgetsSvc.updateWidgetSettings(w, false, true); } }; - $scope.isSelected = function(element, statementName) { - if (statementName == null) { - statementName = null; - } - return (element != null) && _.any($scope.selectedElements, function(sElem) { - return matchElementToSelectedElement(element, statementName, sElem); - }); + $scope.isSelected = function(aStatus) { + return $scope.selectedStatus && aStatus === $scope.selectedStatus; }; - $scope.toggleCollapsed = function(element) { - if ((element != null) && (element.name != null)) { - if (_.find($scope.unCollapsed, (function(name) { - return element.name === name; - }))) { - $scope.unCollapsed = _.reject($scope.unCollapsed, function(name) { - return name === element.name; - }); - } else { - $scope.unCollapsed.push(element.name); + $scope.getSelectedLeads = function() { + var leads; + if ($scope.isDataFound && $scope.selectedStatus) { + leads = w.content.leads_per_status[$scope.selectedStatus].leads; + if (!$scope.setLeadTooltipsIsLocked) { + setLeadDescriptionTooltips(leads); } - return ImpacWidgetsSvc.updateWidgetSettings(w, false); + return leads; } }; - $scope.isCollapsed = function(element) { - if ((element != null) && (element.name != null)) { - if (_.find($scope.unCollapsed, (function(name) { - return element.name === name; - }))) { - return false; - } else { - return true; + $scope.leadDescriptionTooltips = {}; + setLeadDescriptionTooltips = function(leads) { + $scope.leadDescriptionTooltips = {}; + $scope.setLeadTooltipsIsLocked = true; + return _.each(leads, function(aLead, index) { + var nameLineArray, tooltip; + tooltip = []; + nameLineArray = [""]; + if (aLead.first_name) { + nameLineArray.push($filter('titleize')(aLead.first_name)); } - } - }; - $scope.hasElements = function() { - return ($scope.selectedElements != null) && $scope.selectedElements.length > 0; - }; - $scope.getSelectLineColor = function(element, statementName) { - var sElem; - if (statementName == null) { - statementName = null; - } - sElem = _.find($scope.selectedElements, function(sElem) { - return matchElementToSelectedElement(element, statementName, sElem); - }); - if ($scope.hasElements()) { - return ChartFormatterSvc.getColor(_.indexOf($scope.selectedElements, sElem)); - } - }; - matchElementToSelectedElement = function(element, elementCategory, sElem) { - if (elementCategory == null) { - elementCategory = null; - } - return getIdentifier(element, elementCategory) === getIdentifier(sElem); - }; - fetchElement = function(statements, sElemId) { - var element, i, len, statement; - for (i = 0, len = statements.length; i < len; i++) { - statement = statements[i]; - if (statement.employees == null) { - continue; + if (aLead.last_name) { + nameLineArray.push($filter('titleize')(aLead.last_name)); } - element = _.find(statement.employees, function(e) { - return getIdentifier(e, statement.name) === sElemId; - }); - if (element != null) { - element = angular.merge(angular.copy(element), { - category: statement.name + nameLineArray.push(""); + tooltip.push(nameLineArray.join(' ')); + tooltip.push("Status: " + ($filter('titleize')(aLead.lead_status))); + if (aLead.organization) { + tooltip.push("Organization: " + ($filter('titleize')(aLead.organization))); + } + if (aLead.opportunities) { + tooltip.push("Opportunities:"); + _.each(aLead.opportunities, function(opp) { + var oppLineArray; + oppLineArray = []; + if (opp.code) { + oppLineArray.push("#" + opp.code); + } + if (opp.name) { + oppLineArray.push("" + opp.name); + } + if (opp.amount) { + oppLineArray.push($filter('mnoCurrency')(opp.amount.total_amount, "USD", false)); + } + if (opp.probability) { + oppLineArray.push(opp.probability + "%"); + } + if (opp.sales_stage) { + oppLineArray.push("" + opp.sales_stage); + } + return tooltip.push(oppLineArray.join(' - ')); }); - return element; } - } + return $scope.leadDescriptionTooltips[index] = $sce.trustAsHtml(tooltip.join("
")); + }); }; - getIdentifier = function(element, category) { - var id; - if (category == null) { - category = null; - } - id = element.id || element.name; - category || (category = element.category); - if (!category) { - return id; + selectedStatusSetting = {}; + selectedStatusSetting.initialized = false; + selectedStatusSetting.initialize = function() { + if (!_.isEmpty(w.content) && angular.isDefined(w.content.leads_per_status[w.metadata.selected_status])) { + $scope.selectedStatus = w.metadata.selected_status; } - return category + "-" + id; + return selectedStatusSetting.initialized = true; }; - sortEmployeesBy = function(getElem) { - return angular.forEach(w.content.summary, function(sElem) { - if (sElem.employees) { - return sElem.employees.sort(function(a, b) { - var res; - res = getElem(a) > getElem(b) ? 1 : getElem(a) < getElem(b) ? -1 : 0; - if (!$scope.ascending) { - res *= -1; - } - return res; - }); - } - }); - }; - sortData = function() { - if ($scope.sortedColumn === 'employee') { - return sortEmployeesBy(function(el) { - return el.name; - }); - } else if ($scope.sortedColumn === 'total') { - return sortEmployeesBy(function(el) { - return $scope.getLastValue(el); - }); - } + selectedStatusSetting.toMetadata = function() { + return { + selected_status: $scope.selectedStatus + }; }; - $scope.drawTrigger = $q.defer(); + w.settings.push(selectedStatusSetting); w.format = function() { - var all_values_are_positive, chartData, inputData, labels, options, pieData, pieOptions; - if ($scope.isDataFound && $scope.hasElements()) { - if (w.isHistoryMode) { - all_values_are_positive = true; - inputData = []; - labels = _.map(w.content.dates, function(date) { - if (w.metadata.hist_parameters && w.metadata.hist_parameters.period === "YEARLY") { - return $filter('momentDate')(date, 'YEARLY'); - } else if (w.metadata.hist_parameters && w.metadata.hist_parameters.period === "QUARTERLY") { - return $filter('momentDate')(date, 'QUARTERLY'); - } else if (w.metadata.hist_parameters && w.metadata.hist_parameters.period === "MONTHLY") { - return $filter('momentDate')(date, 'MONTHLY'); - } else if (w.metadata.hist_parameters && w.metadata.hist_parameters.period === "WEEKLY") { - return $filter('momentDate')(date, 'WEEKLY'); - } else if (w.metadata.hist_parameters && w.metadata.hist_parameters.period === "DAILY") { - return $filter('momentDate')(date, 'DAILY'); + var max; + if ($scope.isDataFound) { + max = 0; + angular.forEach($scope.statusOptions, function(statusOption) { + var value; + value = w.content.leads_per_status[statusOption.label].total; + if (statusOption.selected && angular.isDefined(value) && value > max) { + return max = value; + } + }); + if (max > 0) { + return $scope.funnel = _.compact(_.map($scope.statusOptions, function(statusOption, index) { + var coloredWidth, statusWidth, value; + value = w.content.leads_per_status[statusOption.label].total; + coloredWidth = (100 * (value / max) - 10).toFixed(); + if (coloredWidth < 8) { + statusWidth = 92; } else { - return $filter('momentDate')(date, 'default'); + statusWidth = 100 - coloredWidth; } - }); - angular.forEach($scope.selectedElements, function(sElem) { - var data; - data = angular.copy(sElem); - inputData.push({ - title: data.name, - labels: labels, - values: data.totals - }); - return angular.forEach(data.totals, function(value) { - return all_values_are_positive && (all_values_are_positive = value >= 0); - }); - }); - options = { - scaleBeginAtZero: all_values_are_positive, - showXLabels: true, - datasetFill: $scope.selectedElements.length === 1, - pointDot: $scope.selectedElements.length === 1, - currency: 'hide' - }; - chartData = ChartFormatterSvc.lineChart(inputData, options); - } else { - pieData = _.map($scope.selectedElements, function(elem) { - return { - label: $filter('titleize')($scope.getName({ - name: elem.name - })), - value: $scope.getLastValue(elem) - }; - }); - pieOptions = { - showTooltips: true, - percentageInnerCutout: 50, - tooltipFontSize: 12, - currency: 'hide' - }; - chartData = ChartFormatterSvc.pieChart(pieData, pieOptions); + if (statusOption.selected && angular.isDefined(value)) { + return { + status: statusOption.label, + number: value, + coloredWidth: { + width: coloredWidth + "%" + }, + statusWidth: { + width: statusWidth + "%" + } + }; + } + })); } - return $scope.drawTrigger.notify(chartData); } }; - unCollapsedSetting = {}; - unCollapsedSetting.initialized = false; - unCollapsedSetting.initialize = function() { - return unCollapsedSetting.initialized = true; - }; - unCollapsedSetting.toMetadata = function() { - return { - unCollapsed: $scope.unCollapsed - }; - }; - w.settings.push(unCollapsedSetting); - selectedElementsSetting = {}; - selectedElementsSetting.initialized = false; - selectedElementsSetting.initialize = function() { - return selectedElementsSetting.initialized = true; - }; - selectedElementsSetting.toMetadata = function() { - var selectedElementsMetadata; - selectedElementsMetadata = _.map($scope.selectedElements, function(element) { - return getIdentifier(element); - }); - return { - selectedElements: selectedElementsMetadata - }; - }; - w.settings.push(selectedElementsSetting); return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetHrPayrollSummary', function() { + module.directive('widgetSalesLeadsFunnel', function() { return { restrict: 'A', - controller: 'WidgetHrPayrollSummaryCtrl' + controller: 'WidgetSalesLeadsFunnelCtrl' }; }); @@ -12631,75 +12745,76 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
"]; + if (aLead.first_name) { + nameLineArray.push($filter('titleize')(aLead.first_name)); } - return "(current " + period + ")"; - } - }; - $scope.drawTrigger = $q.defer(); - w.format = function() { - var all_values_are_positive, chartData, dates, inputData, options, period; - if ($scope.isDataFound) { - period = null; - if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { - period = w.metadata.hist_parameters.period; + if (aLead.last_name) { + nameLineArray.push($filter('titleize')(aLead.last_name)); } - dates = _.map(w.content.dates, function(date) { - return $filter('momentDate')(date, period); - }); - inputData = { - title: $translate.instant('impac.widget.hr_payroll_taxes.payroll_taxes'), - labels: dates, - values: w.content.total_tax - }; - all_values_are_positive = true; - angular.forEach(w.content.total_tax, function(value) { - return all_values_are_positive && (all_values_are_positive = value >= 0); - }); - options = { - scaleBeginAtZero: all_values_are_positive, - showXLabels: false - }; - chartData = ChartFormatterSvc.lineChart([inputData], options); - return $scope.drawTrigger.notify(chartData); - } + nameLineArray.push(""); + tooltip.push(nameLineArray.join(' ')); + tooltip.push("Status: " + ($filter('titleize')(aLead.lead_status))); + if (aLead.organization) { + tooltip.push("Organization: " + ($filter('titleize')(aLead.organization))); + } + if (aLead.opportunities) { + tooltip.push("Opportunities:"); + _.each(aLead.opportunities, function(opp) { + var oppLineArray; + oppLineArray = []; + if (opp.code) { + oppLineArray.push("#" + opp.code); + } + if (opp.name) { + oppLineArray.push("" + opp.name); + } + if (opp.amount) { + oppLineArray.push($filter('mnoCurrency')(opp.amount.total_amount, "USD", false)); + } + if (opp.probability) { + oppLineArray.push(opp.probability + "%"); + } + if (opp.sales_stage) { + oppLineArray.push("" + opp.sales_stage); + } + return tooltip.push(oppLineArray.join(' - ')); + }); + } + return $scope.leadDescriptionTooltips[index] = $sce.trustAsHtml(tooltip.join("
")); + }); }; return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetHrPayrollTaxes', function() { + module.directive('widgetSalesLeadsList', function() { return { restrict: 'A', - controller: 'WidgetHrPayrollTaxesCtrl' + controller: 'WidgetSalesLeadsListCtrl' }; }); @@ -12708,197 +12823,48 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
" + $translate.instant('impac.widget.sales_list.to') + " "; w.initContext = function() { - $scope.isDataFound = !_.isEmpty(w.content) && (w.content.summary != null) && !_.isEmpty(w.content.summary.data); - if ($scope.isDataFound) { - $scope.periodOptions = [ + if ($scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.summary)) { + buildFxTotals(); + $scope.ratesDate = moment.now(); + $scope.filterOptions = [ { - label: _.capitalize($translate.instant("impac.widget.settings.time_period.period.yearly").toLowerCase()), - value: "yearly" + label: $translate.instant('impac.widget.sales_list.value_sold_taxes'), + value: 'gross_value_sold' }, { - label: _.capitalize($translate.instant("impac.widget.settings.time_period.period.monthly").toLowerCase()), - value: "monthly" + label: $translate.instant('impac.widget.sales_list.value_sold_no_taxes'), + value: 'net_value_sold' }, { - label: _.capitalize($translate.instant("impac.widget.settings.time_period.period.weekly").toLowerCase()), - value: "weekly" + label: $translate.instant('impac.widget.sales_list.quantity_sold'), + value: 'quantity_sold' }, { - label: _.capitalize($translate.instant("impac.widget.settings.time_period.period.daily").toLowerCase()), - value: "daily" - } - ]; - $scope.filterOptions = [ - { - label: $translate.instant("impac.common.label.gender"), - value: "gender" + label: $translate.instant('impac.widget.sales_list.value_purchased_taxes'), + value: 'gross_value_purchased' }, { - label: $translate.instant("impac.common.label.age_range"), - value: "age_range" + label: $translate.instant('impac.widget.sales_list.value_purchased_no_taxes'), + value: 'net_value_purchased' }, { - label: $translate.instant("impac.common.label.job_title"), - value: "job_title" + label: $translate.instant('impac.widget.sales_list.quantity_purchased'), + value: 'quantity_purchased' } ]; - $scope.period = angular.copy(_.find($scope.periodOptions, function(o) { - return o.value === w.content.total.period.toLowerCase(); - }) || $scope.periodOptions[0]); - return $scope.filter = angular.copy(_.find($scope.filterOptions, function(o) { - return o.value === w.content.summary.filter; + $scope.filter = angular.copy(_.find($scope.filterOptions, function(o) { + return o.value === w.metadata.filter; }) || $scope.filterOptions[0]); - } - }; - $scope.getColorByIndex = function(index) { - return ChartFormatterSvc.getColor(index); - }; - $scope.drawTrigger = $q.defer(); - w.format = function() { - var barData, barOptions, chartData, lineData, lineOptions; - if ($scope.isDataFound) { - barData = { - labels: _.map(w.content.summary.data, function(elem) { - return elem.label; - }), - values: _.map(w.content.summary.data, function(elem) { - return elem.value; - }) - }; - if ($scope.filter.value === 'gender') { - barOptions = { - showTooltips: false - }; - chartData = ChartFormatterSvc.barChart(barData, barOptions); - } else if ($scope.filter.value === 'job_title') { - barOptions = { - showTooltips: false, - showXLabels: false, - barDatasetSpacing: 15 - }; - chartData = ChartFormatterSvc.barChart(barData, barOptions); - } else if ($scope.filter.value === 'age_range') { - if (_.last(barData.labels) === "unknown") { - barData.labels.pop(); - barData.values.pop(); - } - lineData = [ - { - title: "Average salary", - labels: barData.labels, - values: barData.values - } - ]; - lineOptions = { - scaleBeginAtZero: true, - showXLabels: false - }; - chartData = ChartFormatterSvc.lineChart(lineData, lineOptions); - } else { - return { - error: { - message: "wrong filter", - code: 400 - } - }; - } - return $scope.drawTrigger.notify(chartData); - } - }; - return $scope.widgetDeferred.resolve(settingsPromises); - }]); - - module.directive('widgetHrSalariesSummary', function() { - return { - restrict: 'A', - controller: 'WidgetHrSalariesSummaryCtrl' - }; - }); - -}).call(this); - -(function() { - var module; - - module = angular.module('impac.components.widgets.hr-superannuation-accruals', []); - - module.controller('WidgetHrSuperannuationAccrualsCtrl', ["$scope", "$q", function($scope, $q) { - var settingsPromises, w; - w = $scope.widget; - $scope.orgDeferred = $q.defer(); - $scope.paramSelectorDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.paramSelectorDeferred.promise]; - w.initContext = function() { - if ($scope.isDataFound = !_.isEmpty(w.content) && !_.isEmpty(w.content.employees)) { - $scope.employeesOptions = _.map(w.content.employees, function(e) { - return { - value: e.uid, - label: e.lastname + " " + e.firstname - }; - }); - return $scope.selectedEmployee = { - value: $scope.getEmployee().uid, - label: ($scope.getEmployee().lastname) + " " + ($scope.getEmployee().firstname) - }; - } - }; - $scope.getEmployee = function() { - var e; - if (!$scope.isDataFound) { - return false; - } - e = w.content.employees[0]; - if (w.metadata && w.metadata.employee_id) { - e = _.find(w.content.employees, function(e) { - return e.uid === w.metadata.employee_id; - }) || w.content.employees[0]; - } - return angular.copy(e); - }; - return $scope.widgetDeferred.resolve(settingsPromises); - }]); - - module.directive('widgetHrSuperannuationAccruals', function() { - return { - restrict: 'A', - controller: 'WidgetHrSuperannuationAccrualsCtrl' - }; - }); - -}).call(this); - -(function() { - var module; - - module = angular.module('impac.components.widgets.hr-timesheets', []); - - module.controller('WidgetHrTimesheetsCtrl', ["$scope", "$q", "ChartFormatterSvc", "ImpacWidgetsSvc", function($scope, $q, ChartFormatterSvc, ImpacWidgetsSvc) { - var settingsPromises, unCollapsedSetting, w; - w = $scope.widget; - $scope.orgDeferred = $q.defer(); - $scope.timePeriodDeferred = $q.defer(); - $scope.paramSelectorDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.timePeriodDeferred.promise, $scope.paramSelectorDeferred.promise]; - w.initContext = function() { - if ($scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.employees) && !_.isEmpty(w.content.dates)) { - $scope.employeesOptions = _.map(w.content.employees, function(e) { - return { - value: e.id, - label: e.lastname + " " + e.firstname - }; - }); - $scope.selectedEmployee = { - value: $scope.getEmployee().id, - label: ($scope.getEmployee().lastname) + " " + ($scope.getEmployee().firstname) - }; - return $scope.unCollapsed = w.metadata.unCollapsed || []; + $scope.unCollapsed = w.metadata.unCollapsed || []; + return sortData(); } }; $scope.toggleCollapsed = function(categoryName) { @@ -12926,33 +12892,76 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
getElem(b) ? 1 : getElem(a) < getElem(b) ? -1 : 0; + if (!$scope.ascending) { + res *= -1; + } + return res; + }); + } + }); }; - $scope.getEmployeeTimeWorked = function() { - var employee; - if (employee = $scope.getEmployee()) { - return _.find(w.content.employees, function(e) { - return e.id === employee.id; - }).total_time_worked; + sortData = function() { + if ($scope.sortedColumn === 'account') { + return sortAccountsBy(function(el) { + return el.name; + }); + } else if ($scope.sortedColumn === 'total') { + return sortAccountsBy(function(el) { + return el.total; + }); } }; - $scope.getEmployeeTimeOff = function() { - var employee; - if (employee = $scope.getEmployee()) { - return _.find(w.content.employees, function(e) { - return e.id === employee.id; - }).total_time_off; + $scope.sort = function(col) { + if ($scope.sortedColumn === col) { + $scope.ascending = !$scope.ascending; + } else { + $scope.ascending = true; + $scope.sortedColumn = col; } + return sortData(); + }; + buildFxTotals = function() { + var groupedSales, i, len, ref, results, sale, saleFxTotals; + ref = w.content.summary; + results = []; + for (i = 0, len = ref.length; i < len; i++) { + groupedSales = ref[i]; + results.push((function() { + var j, len1, ref1, results1; + ref1 = groupedSales.products; + results1 = []; + for (j = 0, len1 = ref1.length; j < len1; j++) { + sale = ref1[j]; + saleFxTotals = []; + if (!_.isEmpty(sale.fx_totals)) { + _.mapKeys(sale.fx_totals, function(total, currency) { + var amount; + amount = total['amount']; + if (!(amount === 0 || currency === w.metadata.currency)) { + return saleFxTotals.push({ + currency: currency, + amount: amount, + rate: total.rate + }); + } + }); + } + if (!_.isEmpty(saleFxTotals)) { + results1.push(sale.formattedFxTotals = saleFxTotals); + } else { + results1.push(void 0); + } + } + return results1; + })()); + } + return results; }; unCollapsedSetting = {}; unCollapsedSetting.initialized = false; @@ -12968,10 +12977,10 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
= 0); + }); + options = { + scaleBeginAtZero: all_values_are_positive, + showXLabels: false + }; + chartData = ChartFormatterSvc.lineChart([inputData], options); return $scope.drawTrigger.notify(chartData); } }; return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetHrWorkforceSummary', function() { + module.directive('widgetSalesMargin', function() { return { restrict: 'A', - controller: 'WidgetHrWorkforceSummaryCtrl' + controller: 'WidgetSalesMarginCtrl' }; }); @@ -13107,351 +13085,238 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
0)) { - w.width = 6; - } - return sortData(); - } - }; - $scope.getElementChartColor = function(index) { - if (index != null) { - return ChartFormatterSvc.getColor(index); - } - }; - $scope.getLastValue = function(element) { - if ((element != null) && (element.totals != null)) { - return _.last(element.totals); - } - }; - $scope.getTotalSum = function(element) { - if ((element != null) && (element.totals != null)) { - return _.reduce(element.totals, function(memo, num) { - return memo + num; - }, 0); - } + return $scope.isDataFound = (w.content != null) && (w.content.sales != null) && w.content.sales.length > 0 && (w.content.sales[0].total != null); }; - $scope.getName = function(element) { - if ((element != null) && (element.name != null)) { - return element.name.replace(/_/g, " "); + $scope.getCurrency = function() { + if ($scope.isDataFound) { + return w.content.currency; } }; - $scope.getPeriod = function() { - var period, period_param; - if ($scope.isDataFound && w.metadata && w.metadata.hist_parameters) { - period_param = w.metadata.hist_parameters.period || "MONTHLY"; - period = "day"; - if (period_param !== "DAILY") { - period = period_param.substr(0, period_param.length - 2).toLowerCase(); + $scope.getValue = function(valueType) { + if ((w.content != null) && w.content[valueType]) { + switch ($scope.displayType.value) { + case 'total': + return $filter('mnoCurrency')(w.content[valueType][0].total, $scope.getCurrency(), false); + case 'average': + return $filter('mnoCurrency')(w.content[valueType][0].avg, $scope.getCurrency(), false); + case 'trans_count': + return w.content[valueType][0].trans_count; } - return "current " + period; } else { - return "current month"; + return 0; } }; - $scope.getOldestInvoice = function(element) { - var idx; - idx = _.findIndex(element.totals, function(invoice) { - return invoice !== 0; - }); - return w.content.dates[idx] || null; - }; - $scope.sort = function(col) { - if ($scope.sortedColumn === col) { - $scope.ascending = !$scope.ascending; + $scope.sign = function(type) { + if ($scope.displayType.value === 'average') { + return { + minus: '~', + equal: '=>' + }[type]; + } else if ($scope.displayType.value === 'trans_count') { + return { + minus: '+', + equal: '=' + }[type]; } else { - $scope.ascending = true; - $scope.sortedColumn = col; + return { + minus: '-', + equal: '=' + }[type]; } - return sortData(); }; - $scope.toggleSelectedElement = function(element, statementName) { - if (statementName == null) { - statementName = null; + return $scope.widgetDeferred.resolve(settingsPromises); + }]); + + module.directive('widgetSalesNetSales', function() { + return { + restrict: 'A', + controller: 'WidgetSalesNetSalesCtrl' + }; + }); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets.sales-new-vs-existing-customers', []); + + module.controller('WidgetSalesNewVsExistingCustomersCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "$translate", function($scope, $q, ChartFormatterSvc, $filter, $translate) { + var daysTmpl, hoursTmpl, settingsPromises, w; + w = $scope.widget; + $scope.orgDeferred = $q.defer(); + $scope.timeRangeParamSelectorDeferred = $q.defer(); + $scope.displayTypeParamSelectorDeferred = $q.defer(); + $scope.chartDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise, $scope.timeRangeParamSelectorDeferred.promise, $scope.displayTypeParamSelectorDeferred.promise, $scope.chartDeferred.promise]; + $scope.displayOptions = [ + { + label: $translate.instant('impac.widget.sales_new_vs_existing.customers'), + value: 'customers_count' + }, { + label: $translate.instant('impac.widget.sales_new_vs_existing.total_sales'), + value: 'total_sales' + }, { + label: $translate.instant('impac.widget.sales_new_vs_existing.transactions'), + value: 'transactions_count' } - if ($scope.isSelected(element, statementName)) { - $scope.selectedElements = _.reject($scope.selectedElements, function(sElem) { - return matchElementToSelectedElement(element, statementName, sElem); - }); - w.format(); - if (w.isExpanded() && $scope.selectedElements.length === 0) { - return w.toggleExpanded(); - } else { - return ImpacWidgetsSvc.updateWidgetSettings(w, false); - } - } else { - $scope.selectedElements || ($scope.selectedElements = []); - if (statementName) { - element.category = statementName; - } - $scope.selectedElements.push(element); - w.format(); - if (!w.isExpanded()) { - return w.toggleExpanded(); - } else { - return ImpacWidgetsSvc.updateWidgetSettings(w, false); - } + ]; + $scope.displayType = angular.copy(_.find($scope.displayOptions, function(o) { + return w.metadata && (o.value === w.metadata.display_type); + }) || $scope.displayOptions[0]); + hoursTmpl = $translate.instant('impac.widget.sales_new_vs_existing.tmpl.last_hours'); + daysTmpl = $translate.instant('impac.widget.sales_new_vs_existing.tmpl.last_days'); + $scope.timeRangeOptions = [ + { + label: hoursTmpl.replace(':hours:', 24), + value: '-1d' + }, { + label: daysTmpl.replace(':days:', 5), + value: '-5d' + }, { + label: daysTmpl.replace(':days:', 7), + value: '-7d' + }, { + label: daysTmpl.replace(':days:', 30), + value: '-30d' + }, { + label: daysTmpl.replace(':days:', 45), + value: '-45d' + }, { + label: daysTmpl.replace(':days:', 60), + value: '-60d' + }, { + label: daysTmpl.replace(':days:', 90), + value: '-90d' } + ]; + $scope.timeRange = angular.copy(_.find($scope.timeRangeOptions, function(o) { + return w.metadata && (o.value === w.metadata.time_range); + }) || $scope.timeRangeOptions[6]); + w.initContext = function() { + return $scope.isDataFound = (w.content != null) && (w.content.summary != null) && (w.content.summary.customers_count != null) && (w.content.summary.customers_count.total != null) && w.content.summary.customers_count.total > 0; }; - $scope.isSelected = function(element, statementName) { - if (statementName == null) { - statementName = null; - } - return (element != null) && _.any($scope.selectedElements, function(sElem) { - return matchElementToSelectedElement(element, statementName, sElem); - }); + $scope.displayTypeOnClick = function() { + $scope.updateSettings(false); + return w.format(); }; - $scope.toggleCollapsed = function(element) { - if ((element != null) && (element.name != null)) { - if (_.find($scope.unCollapsed, (function(name) { - return element.name === name; - }))) { - $scope.unCollapsed = _.reject($scope.unCollapsed, function(name) { - return name === element.name; - }); - } else { - $scope.unCollapsed.push(element.name); + $scope.getValue = function(key) { + var result, returnType; + if ($scope.isDataFound) { + returnType = $scope.displayType.value; + result = w.content.summary[returnType][key]; + switch (returnType) { + case 'total_sales': + return $filter('mnoCurrency')(result, w.metadata.currency); + default: + return result; } - return ImpacWidgetsSvc.updateWidgetSettings(w, false); } }; - $scope.isCollapsed = function(element) { - if ((element != null) && (element.name != null)) { - if (_.find($scope.unCollapsed, (function(name) { - return element.name === name; - }))) { - return false; - } else { - return true; + $scope.shouldDisplayCurrency = function() { + return $scope.isDataFound && $scope.displayType.value.indexOf('count') < 0; + }; + $scope.calculatePercentage = function(sliceType) { + var values; + values = { + "new": Math.abs(w.content.summary[$scope.displayType.value]["new"]), + existing: Math.abs(w.content.summary[$scope.displayType.value].existing) + }; + values.totals = values["new"] + values.existing; + return Math.round(values[sliceType] / values.totals * 100); + }; + $scope.drawTrigger = $q.defer(); + w.format = function() { + var chartData, pieData, pieOptions; + if ($scope.isDataFound) { + pieData = [ + { + label: "EXISTING " + ($scope.calculatePercentage('existing')) + "%", + value: w.content.summary[$scope.displayType.value].existing + }, { + label: "NEW " + ($scope.calculatePercentage('new')) + "%", + value: w.content.summary[$scope.displayType.value]["new"] + } + ]; + pieOptions = { + percentageInnerCutout: 50, + tooltipFontSize: 12 + }; + if (!$scope.shouldDisplayCurrency()) { + angular.merge(pieOptions, { + currency: 'hide' + }); } + chartData = ChartFormatterSvc.pieChart(pieData, pieOptions, true); + return $scope.drawTrigger.notify(chartData); } }; - $scope.getSelectLineColor = function(element, statementName) { - var sElem; - if (statementName == null) { - statementName = null; - } - sElem = _.find($scope.selectedElements, function(sElem) { - return matchElementToSelectedElement(element, statementName, sElem); - }); - if ($scope.hasElements()) { - return ChartFormatterSvc.getColor(_.indexOf($scope.selectedElements, sElem)); - } - }; - $scope.hasElements = function() { - return ($scope.selectedElements != null) && $scope.selectedElements.length > 0; - }; - matchElementToSelectedElement = function(element, elementCategory, sElem) { - if (elementCategory == null) { - elementCategory = null; - } - return getIdentifier(element, elementCategory) === getIdentifier(sElem); - }; - fetchElement = function(statements, sElemId) { - var element, elements, i, len, statement; - for (i = 0, len = statements.length; i < len; i++) { - statement = statements[i]; - elements = statement.suppliers || statement.customers; - if (_.isEmpty(elements)) { - continue; - } - element = _.find(elements, function(elem) { - return getIdentifier(elem, statement.name) === sElemId; - }); - if (element != null) { - element = angular.merge(angular.copy(element), { - category: statement.name - }); - return element; - } - } - }; - getIdentifier = function(element, category) { - var id; - if (category == null) { - category = null; - } - id = element.id || element.name; - category || (category = element.category); - if (!category) { - return id; - } - return category + "-" + id; - }; - sortBy = function(data, getElem) { - return data.sort(function(a, b) { - var res; - res = getElem(a) > getElem(b) ? 1 : getElem(a) < getElem(b) ? -1 : 0; - if (!$scope.ascending) { - res *= -1; - } - return res; - }); - }; - sortByInvoiceCallback = function(el) { - var date; - date = $scope.getOldestInvoice(el); - if (date && _.isString(date)) { - date = date.match(/[^_\W]+\s?/g).join(''); - } - return new Date(date); - }; - sortData = function() { - if ($scope.sortedColumn === 'customer') { - sortBy(w.content.payables.suppliers, function(el) { - return el.name; - }); - return sortBy(w.content.receivables.customers, function(el) { - return el.name; - }); - } else if ($scope.sortedColumn === 'total') { - sortBy(w.content.payables.suppliers, function(el) { - return $scope.getTotalSum(el); - }); - return sortBy(w.content.receivables.customers, function(el) { - return $scope.getTotalSum(el); - }); - } else if ($scope.sortedColumn === 'invoice') { - sortBy(w.content.payables.suppliers, sortByInvoiceCallback); - return sortBy(w.content.receivables.customers, sortByInvoiceCallback); - } - }; - buildFxTotals = function() { - var contact, contactFxTotals, fxTotal, i, j, len, len1, ref, ref1, results; - ref = _.union(w.content.payables.suppliers, w.content.receivables.customers); - results = []; - for (i = 0, len = ref.length; i < len; i++) { - contact = ref[i]; - contactFxTotals = []; - ref1 = contact.fx_totals; - for (j = 0, len1 = ref1.length; j < len1; j++) { - fxTotal = ref1[j]; - if (!_.isEmpty(fxTotal)) { - _.mapKeys(fxTotal, function(total, currency) { - if (currency !== w.metadata.currency) { - return contactFxTotals.push({ - currency: currency, - amount: total.amount, - rate: total.rate - }); - } - }); - } - } - if (!_.isEmpty(contactFxTotals)) { - results.push(contact.formattedFxTotals = contactFxTotals); - } else { - results.push(void 0); - } - } - return results; - }; - $scope.drawTrigger = $q.defer(); - w.format = function() { - var all_values_are_positive, chartData, dates, inputData, options, period; - if ($scope.isDataFound && ($scope.selectedElements != null) && $scope.selectedElements.length > 0) { - all_values_are_positive = true; - inputData = []; - period = null; - if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { - period = w.metadata.hist_parameters.period; - } - dates = _.map(w.content.dates, function(date, index) { - return $filter('momentDate')(date, period); - }); - angular.forEach($scope.selectedElements, function(sElem) { - var data; - data = angular.copy(sElem); - inputData.push({ - title: data.name, - labels: dates, - values: data.totals - }); - return angular.forEach(data.totals, function(value) { - return all_values_are_positive && (all_values_are_positive = value >= 0); - }); - }); - options = { - scaleBeginAtZero: all_values_are_positive, - showXLabels: true, - datasetFill: $scope.selectedElements.length === 1, - pointDot: $scope.selectedElements.length === 1 - }; - chartData = ChartFormatterSvc.lineChart(inputData, options); - return $scope.drawTrigger.notify(chartData); - } - }; - unCollapsedSetting = {}; - unCollapsedSetting.initialized = false; - unCollapsedSetting.initialize = function() { - return unCollapsedSetting.initialized = true; - }; - unCollapsedSetting.toMetadata = function() { - return { - unCollapsed: $scope.unCollapsed - }; - }; - w.settings.push(unCollapsedSetting); - selectedElementsSetting = {}; - selectedElementsSetting.initialized = false; - selectedElementsSetting.initialize = function() { - return selectedElementsSetting.initialized = true; - }; - selectedElementsSetting.toMetadata = function() { - var selectedElementsMetadata; - selectedElementsMetadata = _.map($scope.selectedElements, function(element) { - return getIdentifier(element); - }); - return { - selectedElements: selectedElementsMetadata - }; - }; - w.settings.push(selectedElementsSetting); return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetInvoicesAgedPayablesReceivables', function() { + module.directive('widgetSalesNewVsExistingCustomers', function() { return { restrict: 'A', - controller: 'WidgetInvoicesAgedPayablesReceivablesCtrl' + controller: 'WidgetSalesNewVsExistingCustomersCtrl' }; }); @@ -13460,572 +13325,591 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
" + entity.name + ""]; - count = 1; - _.each(entity.invoices, function(i) { - var amountDetail, formattedInvoiced, formattedPaid, invCurrency, txn; - txn = i.transaction_no !== "" ? " (" + i.transaction_no + ")" : ""; - invCurrency = Object.keys(i.fx_totals)[0]; - formattedInvoiced = $filter('mnoCurrency')(i.fx_totals[invCurrency].invoiced, invCurrency, true); - if (i.tooltip_status === "partially paid") { - formattedPaid = $filter('mnoCurrency')(i.fx_totals[invCurrency].paid, invCurrency, true); - amountDetail = " (" + formattedPaid + " on " + formattedInvoiced + ")"; - } else { - amountDetail = " (" + formattedInvoiced + ")"; - } - tooltip.push("#" + count + txn + " - " + i.tooltip_status + amountDetail); - return count++; - }); - return $scope.invoiceTooltips[entity.id] = $sce.trustAsHtml(tooltip.join("
")); - }); - }; - buildFxTotals = function() { - var contact, contactFxTotals, j, len, ref, results; - ref = w.content.entities; - results = []; - for (j = 0, len = ref.length; j < len; j++) { - contact = ref[j]; - contactFxTotals = []; - _.mapKeys(contact.fx_totals, function(total, currency) { - if (currency !== w.metadata.currency) { - return contactFxTotals.push({ - currency: currency, - amount: total.invoiced, - rate: total.rate - }); - } - }); - if (!_.isEmpty(contactFxTotals)) { - results.push(contact.formattedFxTotals = contactFxTotals); - } else { - results.push(void 0); + $scope.formatNumberOfLeads = function(carac) { + var color, formattedNominal, formattedVariation, n_hash, nominal, variation; + formattedNominal = 0; + formattedVariation = "- %"; + if (!$scope.isDataFound) { + return { + nominal: formattedNominal, + variation: formattedVariation, + color: '' + }; + } + n_hash = angular.copy(w.content.number_of_leads); + nominal = 0; + color = ''; + if (carac === "new" && n_hash.total && n_hash.total.length === 2) { + nominal = n_hash.total[1] - n_hash.total[0]; + variation = getVariation(n_hash.total); + if (variation > 0) { + color = 'green'; + } else if (variation < 0) { + color = 'red'; + } + } else if (carac === "converted" && n_hash.converted && n_hash.converted.length === 2) { + nominal = n_hash.converted[1]; + variation = getVariation(n_hash.converted); + if (variation > 0) { + color = 'green'; + } else if (variation < 0) { + color = 'red'; + } + } else if (carac === "lost" && n_hash.lost && n_hash.lost.length === 2) { + nominal = n_hash.lost[1]; + variation = getVariation(n_hash.lost); + if (variation < 0) { + color = 'green'; + } else if (variation > 0) { + color = 'red'; } + } else { + return { + nominal: formattedNominal, + variation: formattedVariation, + color: color + }; } - return results; - }; - return $scope.widgetDeferred.resolve(settingsPromises); - }]); - - module.directive('widgetInvoicesList', function() { - return { - restrict: 'A', - controller: 'WidgetInvoicesListCtrl' - }; - }); - -}).call(this); - -(function() { - var module; - - module = angular.module('impac.components.widgets.invoices-summary', []); - - module.controller('WidgetInvoicesSummaryCtrl', ["$scope", "$q", "ChartFormatterSvc", function($scope, $q, ChartFormatterSvc) { - var settingsPromises, w; - w = $scope.widget; - $scope.orgDeferred = $q.defer(); - $scope.chartFiltersDeferred = $q.defer(); - $scope.chartDeferred = $q.defer(); - $scope.datesPickerDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.chartFiltersDeferred.promise, $scope.chartDeferred.promise, $scope.datesPickerDeferred.promise]; - $scope.defaultFrom = (new Date().getFullYear() - 10) + "-01-01"; - w.initContext = function() { - return $scope.isDataFound = !_.isEmpty(w.content) && !_.isEmpty(w.content.summary); + if (nominal > 0) { + formattedNominal = "+" + nominal; + } else if (nominal < 0) { + formattedNominal = nominal; + } + if (variation && variation > 0) { + formattedVariation = "+" + (variation.toFixed(0)) + "%"; + } else if (variation && variation < 0) { + formattedVariation = (variation.toFixed(0)) + "%"; + } + return { + nominal: formattedNominal, + variation: formattedVariation, + color: color + }; }; - $scope.drawTrigger = $q.defer(); - w.format = function() { - var chartData, pieData, pieOptions; - if ($scope.isDataFound) { - pieData = _.map(w.content.summary, function(entity) { - return { - label: entity.name, - value: entity.total - }; - }); - pieOptions = { - percentageInnerCutout: 50, - tooltipFontSize: 12 - }; - chartData = ChartFormatterSvc.pieChart(pieData, pieOptions); - return $scope.drawTrigger.notify(chartData); + getVariation = function(v_array) { + var variation; + if (v_array[0] !== 0) { + return variation = 100 * ((v_array[1] / v_array[0]) - 1); + } else { + return variation = "- "; } }; return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetInvoicesSummary', function() { + module.directive('widgetSalesNumberOfLeads', function() { return { restrict: 'A', - controller: 'WidgetInvoicesSummaryCtrl' + controller: 'WidgetSalesNumberOfLeadsCtrl' }; }); }).call(this); (function() { - var module; + var module, + indexOf = [].indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; }; - module = angular.module('impac.components.widgets.sales-aged', []); + module = angular.module('impac.components.widgets.sales-opportunities-funnel', []); - module.controller('WidgetSalesAgedCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "$translate", function($scope, $q, ChartFormatterSvc, $filter, $translate) { - var settingsPromises, w; + module.controller('WidgetSalesOpportunitiesFunnelCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "ImpacWidgetsSvc", "ImpacDashboardsSvc", function($scope, $q, ChartFormatterSvc, $filter, ImpacWidgetsSvc, ImpacDashboardsSvc) { + var getFilteredTotal, getOrderedAssigneeIds, hasOneOpportunity, selectedStatusSetting, settingsPromises, sortData, sortOppsBy, w; w = $scope.widget; + $scope.selectedOpportunities = []; + $scope.collapsed = []; $scope.orgDeferred = $q.defer(); - $scope.timePeriodDeferred = $q.defer(); - $scope.paramSelectorDeferred = $q.defer(); - $scope.chartDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.timePeriodDeferred.promise, $scope.paramSelectorDeferred.promise, $scope.chartDeferred.promise]; - w.initContext = function() { - $scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.aged_sales) && !_.isEmpty(w.content.dates); - if ($scope.isDataFound) { - $scope.filterOptions = [ - { - label: $translate.instant("impac.widget.sales_aged.value_sold_taxes"), - value: 'gross_value_sold' - }, { - label: $translate.instant("impac.widget.sales_aged.value_sold_no_taxes"), - value: 'net_value_sold' - }, { - label: $translate.instant("impac.widget.sales_aged.quantity_sold"), - value: 'quantity_sold' - } - ]; - return $scope.filter = angular.copy(_.find($scope.filterOptions, function(o) { - return w.metadata && w.metadata.filter === o.value; - }) || $scope.filterOptions[0]); - } - }; - $scope.getTotal = function(anIndex) { - if ($scope.isDataFound && anIndex >= 0 && anIndex < w.content.aged_sales[$scope.filter.value].length) { - return w.content.aged_sales[$scope.filter.value][anIndex]; - } + $scope.paramsPickerDeferred1 = $q.defer(); + $scope.paramsPickerDeferred2 = $q.defer(); + $scope.widthDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise, $scope.paramsPickerDeferred1.promise, $scope.paramsPickerDeferred2.promise, $scope.widthDeferred.promise]; + $scope.ascending = true; + $scope.sortedColumn = 'group'; + hasOneOpportunity = function(oppsPerSalesStage) { + var reducedHash, total, totalsArray; + reducedHash = _.mapValues(oppsPerSalesStage, function(statusHash) { + return statusHash.total; + }); + totalsArray = _.compact(_.values(reducedHash)); + total = _.reduce(totalsArray, function(total, n) { + if (total == null) { + total = 0; + } + return total + n; + }); + return (total != null) && total > 0; }; - $scope.getLastDate = function() { - if ($scope.isDataFound) { - return _.last(w.content.dates); - } + getFilteredTotal = function(opps, assignees) { + return _.reduce(opps, function(total, opp) { + var ref; + if (total == null) { + total = 0; + } + if (ref = opp.assignee_id, indexOf.call(assignees, ref) >= 0) { + return total + 1; + } else { + return total; + } + }, 0); }; - $scope.getClassColor = function(prev, value) { - if (value < prev) { - return 'negative'; - } else if (value > prev) { - return 'positive'; - } else { - return null; - } + getOrderedAssigneeIds = function(assigneesOptions) { + return _.map(_.filter(assigneesOptions, function(assigneeOption) { + return assigneeOption.selected; + }), 'value'); }; - $scope.drawTrigger = $q.defer(); - w.format = function() { - var all_values_are_positive, chartData, inputData, options, period, values; - if ($scope.isDataFound) { - all_values_are_positive = true; - inputData = []; - values = w.content.aged_sales[$scope.filter.value]; - period = null; - if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { - period = w.metadata.hist_parameters.period; - } - $scope.formattedDates = _.map(w.content.dates, function(date) { - return $filter('momentDate')(date, period); - }); - inputData.push({ - title: $scope.filter.label, - labels: $scope.formattedDates, - values: values + w.initContext = function() { + var assignees_selection, dhb, sales_stage_selection; + dhb = ImpacDashboardsSvc.getCurrentDashboard(); + sales_stage_selection = w.metadata.sales_stage_selection || dhb.metadata.sales_stage_selection || { + values: [] + }; + assignees_selection = w.metadata.assignees_selection || dhb.metadata.assignees_selection || { + values: [] + }; + if ($scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.opps_per_sales_stage) && hasOneOpportunity(w.content.opps_per_sales_stage)) { + _.remove(sales_stage_selection.values, function(status) { + return indexOf.call(_.keys(w.content.opps_per_sales_stage), status) < 0; }); - angular.forEach(values, function(value) { - return all_values_are_positive && (all_values_are_positive = value >= 0); + $scope.hasReach = true; + $scope.statusOptions = []; + angular.forEach(w.content.opps_per_sales_stage, function(value, status) { + var isSelected; + isSelected = _.isEmpty(sales_stage_selection.values) || (indexOf.call(sales_stage_selection.values, status) >= 0); + return $scope.statusOptions.push({ + label: status, + selected: isSelected + }); }); - options = { - scaleBeginAtZero: all_values_are_positive, - showXLabels: true, - datasetFill: true, - pointDot: true - }; - if ($scope.filter.value.indexOf('quantity') > -1) { - angular.merge(options, { - currency: 'hide' + if ($scope.statusOptions[0] && !_.any($scope.statusOptions, 'selected') && !_.isEmpty(w.content.opps_per_sales_stage)) { + $scope.statusOptions[0].selected = true; + } + $scope.assigneesOptions = []; + angular.forEach(w.content.assignees, function(obj, index) { + var isSelected, ref; + isSelected = _.isEmpty(assignees_selection.values) || (ref = obj.id, indexOf.call(assignees_selection.values, ref) >= 0); + return $scope.assigneesOptions.push({ + label: obj.name, + selected: isSelected, + value: obj.id }); + }); + if ($scope.assigneesOptions[0] && !_.any($scope.assigneesOptions, 'selected') && !_.isEmpty(w.content.assignees)) { + return $scope.assigneesOptions[0].selected = true; } - chartData = ChartFormatterSvc.lineChart(inputData, options); - return $scope.drawTrigger.notify(chartData); } }; - return $scope.widgetDeferred.resolve(settingsPromises); - }]); - - module.directive('widgetSalesAged', function() { - return { - restrict: 'A', - controller: 'WidgetSalesAgedCtrl' - }; - }); - -}).call(this); - -(function() { - var module; - - module = angular.module('impac.components.widgets.sales-break-even', []); - - module.controller('WidgetSalesBreakEvenCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", function($scope, $q, ChartFormatterSvc, $filter) { - var settingsPromises, thresholdSetting, w; - w = $scope.widget; - $scope.orgDeferred = $q.defer(); - $scope.timePeriodDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.timePeriodDeferred.promise]; - w.initContext = function() { - $scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.sales); - return $scope.threshold = w.metadata.threshold; - }; w.processError = function(error) { if (error.code === 404) { return $scope.isDataFound = false; } }; - $scope.getProjectedDate = function() { - var date; - if ($scope.isDataFound && w.content.break_even) { - if (("" + w.content.break_even.projected_date).match('After')) { - date = angular.copy(w.content.break_even.projected_date).replace('After ', ''); - return "> " + ($filter('date')(date, 'd-MM-yy')); + $scope.getImpacColor = function(index) { + return ChartFormatterSvc.getColor(index); + }; + $scope.toggleSelectStatus = function(aStatus) { + if ($scope.selectedStatus && $scope.selectedStatus === aStatus) { + $scope.selectedStatus = null; + } else { + $scope.selectedStatus = aStatus; + } + $scope.updateRightView(); + if (!w.isExpanded() && $scope.selectedStatus) { + return w.toggleExpanded(); + } else { + return ImpacWidgetsSvc.updateWidgetSettings(w, false, true); + } + }; + $scope.isSelected = function(aStatus) { + return $scope.selectedStatus && aStatus === $scope.selectedStatus; + }; + $scope.toggleCollapsed = function(element) { + if ((element != null) && (element.assigneeName != null)) { + if (_.find($scope.collapsed, (function(name) { + return element.assigneeName === name; + }))) { + return $scope.collapsed = _.reject($scope.collapsed, function(name) { + return name === element.assigneeName; + }); } else { - return w.content.break_even.projected_date; + return $scope.collapsed.push(element.assigneeName); } } }; - $scope.getOpportunitiesToClose = function() { - var opps; - if ($scope.isDataFound && w.content.break_even) { - if (("" + w.content.break_even.opportunities_to_close).match('>')) { - opps = angular.copy(w.content.break_even.opportunities_to_close).replace('>', ''); - return "> " + opps; + $scope.isCollapsed = function(element) { + if ((element != null) && (element.assigneeName != null)) { + if (_.find($scope.collapsed, (function(name) { + return element.assigneeName === name; + }))) { + return true; } else { - return w.content.break_even.opportunities_to_close; + return false; } } }; - $scope.isTargetMet = function() { - if ($scope.isDataFound && w.content.break_even) { - return w.content.break_even.variance < 0; + $scope.getSelectedOpportunities = function() { + var assignees, filteredOpps, oppGroups, sortedOppGroups; + if ($scope.isDataFound && $scope.selectedStatus && w.content.opps_per_sales_stage[$scope.selectedStatus]) { + assignees = getOrderedAssigneeIds($scope.assigneesOptions); + filteredOpps = _.filter(w.content.opps_per_sales_stage[$scope.selectedStatus].opps, function(opportunity) { + var ref; + return ref = opportunity.assignee_id, indexOf.call(assignees, ref) >= 0; + }); + oppGroups = _.groupBy(filteredOpps, 'assignee_id'); + sortedOppGroups = []; + angular.forEach($scope.assigneesOptions, function(assigneeOption) { + var assigneeId; + assigneeId = assigneeOption.value; + if (oppGroups[assigneeId]) { + return sortedOppGroups.push({ + assigneeName: assigneeOption.label, + opps: oppGroups[assigneeId] + }); + } + }); + return sortedOppGroups; + } else { + return []; } }; - $scope.getVariance = function() { - if ($scope.isDataFound && w.content.break_even) { - return Math.abs(w.content.break_even.variance); + $scope.getOppDetails = function(anOpp) { + var oppDetails; + oppDetails = []; + if (anOpp.amount) { + oppDetails.push($filter('mnoCurrency')(anOpp.amount.amount, anOpp.amount.currency || 'AUD')); + } + if (anOpp.probability) { + oppDetails.push("prob. " + anOpp.probability + "%"); } + return oppDetails.join(' / '); }; - thresholdSetting = {}; - thresholdSetting.initialized = false; - thresholdSetting.initialize = function() { - return thresholdSetting.initialized = true; + $scope.getTotal = function(oppsGroup) { + var currency, total; + if (!(oppsGroup.length > 0)) { + return ""; + } + total = _.sum(oppsGroup, function(o) { + var amount, proba; + amount = o.amount.amount || 0.0; + proba = o.probability || 0.0; + return amount * (proba / 100); + }); + currency = oppsGroup[0].amount.currency || 'AUD'; + return $filter('mnoCurrency')(total, currency); }; - thresholdSetting.toMetadata = function() { + sortOppsBy = function(getElem) { + return angular.forEach($scope.selectedOpportunities, function(sElem) { + if (sElem.opps) { + return sElem.opps.sort(function(a, b) { + var res; + res = getElem(a) > getElem(b) ? 1 : getElem(a) < getElem(b) ? -1 : 0; + if (!$scope.ascending) { + res *= -1; + } + return res; + }); + } + }); + }; + sortData = function() { + if ($scope.sortedColumn === 'group') { + return sortOppsBy(function(el) { + return el.name; + }); + } else if ($scope.sortedColumn === 'total') { + return sortOppsBy(function(el) { + return el.amount.amount; + }); + } + }; + $scope.sort = function(col) { + if ($scope.sortedColumn === col) { + $scope.ascending = !$scope.ascending; + } else { + $scope.ascending = true; + $scope.sortedColumn = col; + } + return sortData(); + }; + $scope.updateRightView = function() { + $scope.selectedOpportunities = $scope.getSelectedOpportunities(); + $scope.collapsed = []; + return sortData(); + }; + selectedStatusSetting = {}; + selectedStatusSetting.initialized = false; + selectedStatusSetting.initialize = function() { + if (!_.isEmpty(w.content) && angular.isDefined(w.content.opps_per_sales_stage[w.metadata.selected_status])) { + $scope.selectedStatus = w.metadata.selected_status; + } + selectedStatusSetting.initialized = true; + return $scope.updateRightView(); + }; + selectedStatusSetting.toMetadata = function() { return { - threshold: $scope.threshold + selected_status: $scope.selectedStatus }; }; - w.settings.push(thresholdSetting); - return $scope.widgetDeferred.resolve(settingsPromises); - }]); - - module.directive('widgetSalesBreakEven', function() { - return { - restrict: 'A', - controller: 'WidgetSalesBreakEvenCtrl' - }; - }); - -}).call(this); - -(function() { - var module; - - module = angular.module('impac.components.widgets.sales-comparison', []); - - module.controller('WidgetSalesComparisonCtrl', ["$scope", "$q", "$filter", "ChartFormatterSvc", "ImpacWidgetsSvc", "$translate", function($scope, $q, $filter, ChartFormatterSvc, ImpacWidgetsSvc, $translate) { - var buildFxTotals, fetchElement, getIdentifier, matchElementToSelectedElement, selectedElementsSetting, settingsPromises, sortAccountsBy, sortData, unCollapsedSetting, w; - w = $scope.widget; - $scope.orgDeferred = $q.defer(); + w.settings.push(selectedStatusSetting); + w.format = function() { + var assignees, max; + if ($scope.isDataFound) { + max = 0; + assignees = getOrderedAssigneeIds($scope.assigneesOptions); + angular.forEach($scope.statusOptions, function(statusOption) { + var value; + value = getFilteredTotal(w.content.opps_per_sales_stage[statusOption.label].opps, assignees); + if (statusOption.selected && angular.isDefined(value) && value > max) { + return max = value; + } + }); + if (max > 0) { + return $scope.funnel = _.compact(_.map($scope.statusOptions, function(statusOption, index) { + var coloredWidth, statusWidth, value; + value = getFilteredTotal(w.content.opps_per_sales_stage[statusOption.label].opps, assignees); + coloredWidth = (100 * (value / max) - 10).toFixed(); + if (coloredWidth < 8) { + statusWidth = 92; + } else { + statusWidth = 100 - coloredWidth; + } + if (statusOption.selected && angular.isDefined(value) && value > 0) { + return { + status: statusOption.label, + number: value, + coloredWidth: { + width: coloredWidth + "%" + }, + statusWidth: { + width: statusWidth + "%" + } + }; + } + })); + } else { + return $scope.isDataFound = false; + } + } + }; + return $scope.widgetDeferred.resolve(settingsPromises); + }]); + + module.directive('widgetSalesOpportunitiesFunnel', function() { + return { + restrict: 'A', + controller: 'WidgetSalesOpportunitiesFunnelCtrl' + }; + }); + +}).call(this); + +(function() { + var module, + indexOf = [].indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; }; + + module = angular.module('impac.components.widgets.sales-performance', []); + + module.controller('WidgetSalesPerformanceCtrl', ["$scope", "$q", "$filter", "ChartFormatterSvc", "ImpacWidgetsSvc", function($scope, $q, $filter, ChartFormatterSvc, ImpacWidgetsSvc) { + var formatDate, getIdentifier, matchElementToSelectedElement, selectedElementsSetting, settingsPromises, w; + w = $scope.widget; + $scope.orgDeferred = $q.defer(); + $scope.paramsWinsPickerDeferred = $q.defer(); + $scope.paramsLostsPickerDeferred = $q.defer(); $scope.timePeriodDeferred = $q.defer(); $scope.widthDeferred = $q.defer(); - $scope.paramSelectorDeferred1 = $q.defer(); - $scope.paramSelectorDeferred2 = $q.defer(); $scope.chartDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.timePeriodDeferred.promise, $scope.widthDeferred.promise, $scope.paramSelectorDeferred1, $scope.paramSelectorDeferred2, $scope.chartDeferred.promise]; - $scope.ascending = true; - $scope.sortedColumn = 'sales'; + settingsPromises = [$scope.orgDeferred.promise, $scope.paramsWinsPickerDeferred, $scope.paramsLostsPickerDeferred, $scope.timePeriodDeferred, $scope.widthDeferred.promise, $scope.chartDeferred.promise]; w.initContext = function() { var foundElem, i, len, ref, sElemId; - $scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.sales_comparison) && !_.isEmpty(w.content.dates); + $scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.assignees); if ($scope.isDataFound) { - $scope.unCollapsed = w.metadata.unCollapsed || []; - $scope.filterOptions = [ - { - label: $translate.instant('impac.widget.sales_comparison.value_sold_taxes'), - value: 'gross_value_sold' - }, { - label: $translate.instant('impac.widget.sales_comparison.value_sold_no_taxes'), - value: 'net_value_sold' - }, { - label: $translate.instant('impac.widget.sales_comparison.quantity_sold'), - value: 'quantity_sold' - } - ]; - $scope.filter = angular.copy(_.find($scope.filterOptions, function(o) { - return w.metadata && w.metadata.filter === o.value; - }) || $scope.filterOptions[0]); - $scope.criteriaOptions = [ - { - label: $translate.instant('impac.widget.sales_comparison.criteria_options.products'), - value: 'default' - }, { - label: $translate.instant('impac.widget.sales_comparison.criteria_options.locations'), - value: 'location' - }, { - label: $translate.instant('impac.widget.sales_comparison.criteria_options.industries'), - value: 'industry' - }, { - label: $translate.instant('impac.widget.sales_comparison.criteria_options.customers'), - value: 'customer' - } - ]; - $scope.criteria = angular.copy(_.find($scope.criteriaOptions, function(o) { - return w.metadata && w.metadata.criteria === o.value; - }) || $scope.criteriaOptions[0]); - buildFxTotals(); - $scope.ratesDate = moment.now(); if (!_.isEmpty(w.metadata.selectedElements)) { $scope.selectedElements = []; ref = w.metadata.selectedElements; for (i = 0, len = ref.length; i < len; i++) { sElemId = ref[i]; - foundElem = _.find(w.content.sales_comparison, function(statement) { - return statement.name === sElemId; + foundElem = _.find(w.content.assignees, function(assignee) { + return getIdentifier(assignee) === sElemId; }); - foundElem || (foundElem = fetchElement(w.content.sales_comparison, sElemId)); if (foundElem) { $scope.selectedElements.push(foundElem); } } } - return sortData(); + $scope.hasReach = true; + $scope.closedWonOptions = _.compact(_.map(w.content.sales_stages.won, function(stage) { + return { + label: stage, + selected: true + }; + })); + angular.forEach(w.content.sales_stages.all, function(stage) { + if (!(indexOf.call(w.content.sales_stages.won, stage) >= 0)) { + return $scope.closedWonOptions.push({ + label: stage, + selected: false + }); + } + }); + $scope.closedLostOptions = _.compact(_.map(w.content.sales_stages.lost, function(stage) { + return { + label: stage, + selected: true + }; + })); + return angular.forEach(w.content.sales_stages.all, function(stage) { + if (!(indexOf.call(w.content.sales_stages.lost, stage) >= 0)) { + return $scope.closedLostOptions.push({ + label: stage, + selected: false + }); + } + }); } }; - $scope.getLastDate = function() { - if ($scope.isDataFound) { - return _.last(w.content.dates); + w.processError = function(error) { + if (error.code === 404) { + return $scope.isDataFound = false; } }; - $scope.getTotalForPeriod = function(element) { - if ((element.totals != null) && $scope.filter) { - return _.reduce(element.totals[$scope.filter.value], function(memo, total) { - return memo + total; - }, 0); + $scope.getChartTitle = function(el) { + if ($scope.selectedElements) { + return $scope.selectedElements.map(function(el) { + return el.name; + }).join(', '); + } + }; + $scope.getTotalWon = function(el) { + if ($scope.selectedElements) { + return $scope.selectedElements.reduce((function(t, e) { + return t + e.total_won; + }), 0); + } else { + return 0; + } + }; + formatDate = function(date) { + var period; + period = (w.metadata != null) && (w.metadata.hist_parameters != null) ? w.metadata.hist_parameters.period : null; + return $filter('momentDate')(date, period); + }; + $scope.getCloseDate = function(anOpp) { + var theDate; + if ((anOpp != null) && (anOpp.sales_stage_changes != null) && anOpp.sales_stage_changes.length > 0) { + theDate = anOpp.sales_stage_changes[anOpp.sales_stage_changes.length - 1].updated_at; + if (theDate.split(' ').length > 0) { + theDate = theDate.split(' ')[0]; + return formatDate(theDate); + } + } + }; + $scope.getForecastCloseDate = function(anOpp) { + var theDate; + if ((anOpp != null) && anOpp.expected_close_date) { + theDate = anOpp.expected_close_date; + if (theDate.split(' ').length > 0) { + theDate = theDate.split(' ')[0]; + return formatDate(theDate); + } } }; $scope.getElementChartColor = function(index) { return ChartFormatterSvc.getColor(index); }; - $scope.sort = function(col) { - if ($scope.sortedColumn === col) { - $scope.ascending = !$scope.ascending; - } else { - $scope.ascending = true; - $scope.sortedColumn = col; - } - return sortData(); + $scope.no_sales_stages_selected = function() { + return w.content && w.content.sales_stages && w.content.sales_stages.won.length === 0 && w.content.sales_stages.lost.length === 0; }; - $scope.toggleSelectedElement = function(element, statementName) { + $scope.toggleSelectedElement = function(element) { var selectedElement; - if (statementName == null) { - statementName = null; - } - if ($scope.isSelected(element, statementName)) { + if ($scope.isSelected(element)) { $scope.selectedElements = _.reject($scope.selectedElements, function(sElem) { - return matchElementToSelectedElement(element, statementName, sElem); + return matchElementToSelectedElement(element, sElem); }); w.format(); if (w.isExpanded() && $scope.selectedElements.length === 0) { return w.toggleExpanded(); } else { - return ImpacWidgetsSvc.updateWidgetSettings(w, false); + return ImpacWidgetsSvc.updateWidgetSettings(w, false, true); } } else { selectedElement = angular.copy(element); - selectedElement.category = statementName; $scope.selectedElements || ($scope.selectedElements = []); $scope.selectedElements.push(selectedElement); w.format(); if (!w.isExpanded()) { return w.toggleExpanded(); } else { - return ImpacWidgetsSvc.updateWidgetSettings(w, false); + return ImpacWidgetsSvc.updateWidgetSettings(w, false, true); } } }; - $scope.isSelected = function(element, statementName) { - if (statementName == null) { - statementName = null; - } + $scope.isSelected = function(element) { return (element != null) && _.any($scope.selectedElements, function(sElem) { - return matchElementToSelectedElement(element, statementName, sElem); + return matchElementToSelectedElement(element, sElem); }); }; - $scope.toggleCollapsed = function(element) { - if ((element != null) && (element.name != null)) { - if (_.find($scope.unCollapsed, (function(name) { - return element.name === name; - }))) { - $scope.unCollapsed = _.reject($scope.unCollapsed, function(name) { - return name === element.name; - }); - } else { - $scope.unCollapsed.push(element.name); - } - return ImpacWidgetsSvc.updateWidgetSettings(w, false); - } - }; - $scope.isCollapsed = function(element) { - if ((element != null) && (element.name != null)) { - if (_.find($scope.unCollapsed, (function(name) { - return element.name === name; - }))) { - return false; - } else { - return true; - } - } - }; $scope.hasElements = function() { return ($scope.selectedElements != null) && $scope.selectedElements.length > 0; }; - $scope.getSelectLineColor = function(element, statementName) { + $scope.getSelectLineColor = function(element) { var sElem; - if (statementName == null) { - statementName = null; - } sElem = _.find($scope.selectedElements, function(sElem) { - return matchElementToSelectedElement(element, statementName, sElem); + return matchElementToSelectedElement(element, sElem); }); if ($scope.hasElements()) { return ChartFormatterSvc.getColor(_.indexOf($scope.selectedElements, sElem)); } }; - matchElementToSelectedElement = function(element, elementCategory, sElem) { - if (elementCategory == null) { - elementCategory = null; - } - return getIdentifier(element, elementCategory) === getIdentifier(sElem); - }; - fetchElement = function(statements, sElemId) { - var element, i, len, statement; - for (i = 0, len = statements.length; i < len; i++) { - statement = statements[i]; - if (statement.sales == null) { - continue; - } - element = _.find(statement.sales, function(sale) { - return getIdentifier(sale, statement.name) === sElemId; - }); - if (element != null) { - element = angular.merge(angular.copy(element), { - category: statement.name - }); - return element; - } - } - }; - getIdentifier = function(element, category) { - var id; - if (category == null) { - category = null; - } - id = element.id || element.name; - category || (category = element.category); - if (!category) { - return id; - } - return category + "-" + id; - }; - sortAccountsBy = function(getElem) { - return angular.forEach(w.content.sales_comparison, function(sElem) { - if (sElem.sales) { - return sElem.sales.sort(function(a, b) { - var res; - res = getElem(a) > getElem(b) ? 1 : getElem(a) < getElem(b) ? -1 : 0; - if (!$scope.ascending) { - res *= -1; - } - return res; - }); - } - }); + matchElementToSelectedElement = function(element, sElem) { + return getIdentifier(element) === getIdentifier(sElem); }; - sortData = function() { - if ($scope.sortedColumn === 'sales') { - return sortAccountsBy(function(el) { - return el.name; - }); - } else if ($scope.sortedColumn === 'total') { - return sortAccountsBy(function(el) { - return $scope.getTotalForPeriod(el); - }); - } + getIdentifier = function(element) { + return element.id || element.name; }; $scope.drawTrigger = $q.defer(); w.format = function() { var all_values_are_positive, chartData, inputData, options; if ($scope.isDataFound && ($scope.selectedElements != null) && $scope.selectedElements.length > 0) { - all_values_are_positive = true; inputData = []; + all_values_are_positive = true; angular.forEach($scope.selectedElements, function(sElem) { var data, dates, period; data = angular.copy(sElem); @@ -14039,7 +13923,7 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
= 0); @@ -14048,91 +13932,16 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
-1) { - angular.merge(options, { - currency: 'hide' - }); - } chartData = ChartFormatterSvc.lineChart(inputData, options); return $scope.drawTrigger.notify(chartData); } }; - buildFxTotals = function() { - var grossSaleFxTotals, groupedSales, i, len, netSaleFxTotals, ref, results, sale; - ref = w.content.sales_comparison; - results = []; - for (i = 0, len = ref.length; i < len; i++) { - groupedSales = ref[i]; - results.push((function() { - var j, len1, ref1, results1; - ref1 = groupedSales.sales; - results1 = []; - for (j = 0, len1 = ref1.length; j < len1; j++) { - sale = ref1[j]; - sale.formattedFxTotals = {}; - netSaleFxTotals = []; - grossSaleFxTotals = []; - if (!_.isEmpty(sale.fx_totals)) { - _.mapKeys(sale.fx_totals, function(total, currency) { - var grossAmount, k, l, len2, len3, netAmount, ref2, ref3, results2; - ref2 = total['net_value_sold']; - for (k = 0, len2 = ref2.length; k < len2; k++) { - grossAmount = ref2[k]; - if (!(grossAmount === 0 || currency === w.metadata.currency)) { - netSaleFxTotals.push({ - currency: currency, - amount: grossAmount, - rate: total.rate - }); - } - } - ref3 = total['gross_value_sold']; - results2 = []; - for (l = 0, len3 = ref3.length; l < len3; l++) { - netAmount = ref3[l]; - if (!(netAmount === 0 || currency === w.metadata.currency)) { - results2.push(grossSaleFxTotals.push({ - currency: currency, - amount: netAmount, - rate: total.rate - })); - } else { - results2.push(void 0); - } - } - return results2; - }); - } - if (!_.isEmpty(netSaleFxTotals)) { - sale.formattedFxTotals['net_value_sold'] = netSaleFxTotals; - } - if (!_.isEmpty(grossSaleFxTotals)) { - results1.push(sale.formattedFxTotals['gross_value_sold'] = grossSaleFxTotals); - } else { - results1.push(void 0); - } - } - return results1; - })()); - } - return results; - }; - unCollapsedSetting = {}; - unCollapsedSetting.initialized = false; - unCollapsedSetting.initialize = function() { - return unCollapsedSetting.initialized = true; - }; - unCollapsedSetting.toMetadata = function() { - return { - unCollapsed: $scope.unCollapsed - }; + selectedElementsSetting = { + initialized: false }; - w.settings.push(unCollapsedSetting); - selectedElementsSetting = {}; - selectedElementsSetting.initialized = false; selectedElementsSetting.initialize = function() { return selectedElementsSetting.initialized = true; }; @@ -14149,10 +13958,10 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
50) { + return $scope.analysisTranslate = $translate.instant('impac.widget.sales_turnover.analysis.least'); + } else if (w.content.ranges[3].percentage + w.content.ranges[4].percentage > 50) { + return $scope.analysisTranslate = $translate.instant('impac.widget.sales_turnover.analysis.most'); + } else { + return $scope.analysisTranslate = $translate.instant('impac.widget.sales_turnover.analysis.balanced'); + } } }; - $scope.formatAddress = function(anAddress) { - if (angular.isDefined(anAddress)) { - return anAddress.replace(/, /g, ',\n'); - } + $scope.getColorByIndex = function(index) { + return ChartFormatterSvc.getColor(index); }; - $scope.getFromDate = function() { - if ($scope.isDataFound) { - return w.content.from; + $scope.getRangeLabel = function(aLabel, ISOmode) { + var prices; + if (ISOmode == null) { + ISOmode = false; } + prices = aLabel.split('-'); + return _.map(prices, function(price) { + return $filter('mnoCurrency')(price, w.content.currency, ISOmode); + }).join(' - '); }; - $scope.getToDate = function() { + $scope.getMaxRange = function() { + var max, maxRange; if ($scope.isDataFound) { - return w.content.to; + max = 0; + maxRange = w.content.ranges[0]; + angular.forEach(w.content.ranges, function(range) { + if (range.percentage > max) { + maxRange = angular.copy(range); + } + return max = Math.max(max, range.percentage); + }); + return maxRange; } }; - setSelectedCustomer = function() { - var customer; - if (!$scope.isDataFound) { - return false; - } - if (w.metadata && w.metadata.customer_uid) { - customer = _.find(w.content.customers, function(c) { - return c.uid === w.metadata.customer_uid; - }); - } - customer || (customer = w.content.customers[0]); - $scope.selectedCustomer = angular.copy(customer); - setSelectedCustomerId(); - return buildFxTotals(); - }; - setSelectedCustomerId = function() { - var cust; - if (!(cust = $scope.selectedCustomer)) { - return false; - } - return $scope.selectedCustomerId = { - value: cust.uid, - label: cust.name - }; - }; - buildFxTotals = function() { - var cust, dueFxTotals, invoicedFxTotals, paidFxTotals; - if (!(cust = $scope.selectedCustomer)) { - return false; - } - invoicedFxTotals = []; - dueFxTotals = []; - paidFxTotals = []; - if (_.some(cust.fx_totals, function(total, currency) { - return currency !== w.metadata.currency; - })) { - _.mapKeys(cust.fx_totals, function(total, currency) { - var baseTotal; - baseTotal = { - rate: total.rate, - currency: currency - }; - if (total.invoiced !== 0) { - invoicedFxTotals.push(angular.merge({ - amount: total.invoiced - }, baseTotal)); - } - if (total.paid !== 0) { - paidFxTotals.push(angular.merge({ - amount: total.paid - }, baseTotal)); - } - if (total.due !== 0) { - return dueFxTotals.push(angular.merge({ - amount: total.due - }, baseTotal)); - } - }); - if (!_.isEmpty(invoicedFxTotals)) { - cust.invoicedFxTotals = invoicedFxTotals; - } - if (!_.isEmpty(paidFxTotals)) { - cust.paidFxTotals = paidFxTotals; - } - if (!_.isEmpty(dueFxTotals)) { - return cust.dueFxTotals = dueFxTotals; - } + $scope.drawTrigger = $q.defer(); + w.format = function() { + var barData, barOptions, chartData; + if ($scope.isDataFound) { + barData = { + labels: _.map(w.content.ranges, function(elem) { + return $scope.getRangeLabel(elem.label, true); + }), + values: _.map(w.content.ranges, function(elem) { + return elem.value; + }) + }; + barOptions = { + showTooltips: false, + showXLabels: false, + barDatasetSpacing: 15 + }; + chartData = ChartFormatterSvc.barChart(barData, barOptions); + return $scope.drawTrigger.notify(chartData); } }; return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetSalesCustomerDetails', function() { + module.directive('widgetSalesSegmentedTurnover', function() { return { restrict: 'A', - controller: 'WidgetSalesCustomerDetailsCtrl' + controller: 'WidgetSalesSegmentedTurnoverCtrl' }; }); }).call(this); (function() { - var module, - indexOf = [].indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; }; + var module; - module = angular.module('impac.components.widgets.sales-cycle', []); + module = angular.module('impac.components.widgets.sales-summary', []); - module.controller('WidgetSalesCycleCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "ImpacWidgetsSvc", "ImpacDashboardsSvc", function($scope, $q, ChartFormatterSvc, $filter, ImpacWidgetsSvc, ImpacDashboardsSvc) { + module.controller('WidgetSalesSummaryCtrl', ["$scope", "$q", "ChartFormatterSvc", "$translate", function($scope, $q, ChartFormatterSvc, $translate) { var settingsPromises, w; w = $scope.widget; $scope.orgDeferred = $q.defer(); - $scope.paramsPickerDeferred = $q.defer(); - $scope.timePeriodDeferred = $q.defer(); + $scope.chartFiltersDeferred = $q.defer(); + $scope.paramSelectorDeferred = $q.defer(); + $scope.datesPickerDeferred = $q.defer(); $scope.chartDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.paramsPickerDeferred.promise, $scope.timePeriodDeferred.promise, $scope.chartDeferred.promise]; + settingsPromises = [$scope.orgDeferred.promise, $scope.chartFiltersDeferred.promise, $scope.paramSelectorDeferred.promise, $scope.datesPickerDeferred.promise, $scope.chartDeferred.promise]; + $scope.datesPickerTemplate = "" + $translate.instant('impac.widget.sales_summary.to') + " "; w.initContext = function() { - var dhb, status_selection; - dhb = ImpacDashboardsSvc.getCurrentDashboard(); - status_selection = w.metadata.status_selection || dhb.metadata.status_selection || { - values: [] - }; - if ($scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.status_average_durations)) { - _.remove(status_selection.values, function(status) { - return indexOf.call(_.keys(w.content.status_average_durations), status) < 0; - }); - $scope.hasReach = true; - $scope.statusOptions = []; - return angular.forEach(w.content.status_average_durations, function(value, status) { - var isSelected; - isSelected = _.isEmpty(status_selection.values) || (indexOf.call(status_selection.values, status) >= 0); - return $scope.statusOptions.push({ - label: status, - selected: isSelected - }); - }); - } - }; - w.processError = function(error) { - if (error.code === 404) { - return $scope.isDataFound = false; + $scope.isDataFound = !_.isEmpty(w.content) && !_.isEmpty(w.content.summary) && (_.sum(_.map(w.content.summary, function(s) { + return s.total; + })) > 0); + if ($scope.isDataFound) { + $scope.filterOptions = [ + { + label: $translate.instant('impac.widget.sales_summary.value_sold_taxes'), + value: 'gross_value_sold' + }, { + label: $translate.instant('impac.widget.sales_summary.value_sold_no_taxes'), + value: 'net_value_sold' + }, { + label: $translate.instant('impac.widget.sales_summary.quantity_sold'), + value: 'quantity_sold' + }, { + label: $translate.instant('impac.widget.sales_summary.value_purchased_taxes'), + value: 'gross_value_purchased' + }, { + label: $translate.instant('impac.widget.sales_summary.value_purchased_no_taxes'), + value: 'net_value_purchased' + }, { + label: $translate.instant('impac.widget.sales_summary.quantity_purchased'), + value: 'quantity_purchased' + } + ]; + if (w.metadata.criteria === "customer") { + $scope.filterOptions = [$scope.filterOptions[0], $scope.filterOptions[1], $scope.filterOptions[2]]; + } + return $scope.filter = angular.copy(_.find($scope.filterOptions, function(o) { + return o.value === w.metadata.filter; + }) || $scope.filterOptions[0]); } }; $scope.drawTrigger = $q.defer(); w.format = function() { var chartData, pieData, pieOptions; if ($scope.isDataFound) { - pieData = _.compact(_.map($scope.statusOptions, function(statusOption) { - var value; - value = w.content.status_average_durations[statusOption.label]; - if (statusOption.selected && angular.isDefined(value)) { - return { - label: ($filter('titleize')(statusOption.label)) + ": " + value + " " + $scope.unit, - value: value - }; + pieData = _.map(w.content.summary, function(entity) { + var label; + if (entity.company) { + label = (entity.code || entity.name || entity.location || entity.industry || entity.customer) + " (" + entity.company + ")"; + } else { + label = entity.code || entity.name || entity.location || entity.industry || entity.customer; } - })); + return { + label: label, + value: entity.total + }; + }); pieOptions = { percentageInnerCutout: 50, - tooltipFontSize: 12, - currency: w.content.unit + tooltipFontSize: 12 }; + if ($scope.filter.value.indexOf('quantity') > -1) { + angular.merge(pieOptions, { + currency: 'hide' + }); + } chartData = ChartFormatterSvc.pieChart(pieData, pieOptions); return $scope.drawTrigger.notify(chartData); } @@ -14347,10 +14145,10 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
0) { + return entity.total_invoiced / entity.invoices.length; + } else { + return 0; + } + } + }, { + label: 'last', + showCurrency: true, + getValue: function(entity) { + var total; + total = entity.invoices.length; + if (total > 0) { + return entity.invoices[entity.invoices.length - 1].invoiced; + } else { + return 0; + } + } + } + ]; + $scope.getHeaderField = function() { + return _.find(fields, function(f) { + return f.label === $scope.headerSelected.minified; + }); + }; + $scope.getRemainingFields = function() { + return _.reject(fields, function(f) { + return f.label === $scope.headerSelected.minified; + }); + }; + $scope.getEntities = function() { + if (!$scope.isDataFound) { + return []; + } + return $filter('orderBy')(w.content.entities, (function(entity) { + return $scope.getHeaderField().getValue(entity); + }), true); + }; + buildFxTotals = function() { + var contact, contactFxTotals, j, len, ref, results; + ref = w.content.entities; + results = []; + for (j = 0, len = ref.length; j < len; j++) { + contact = ref[j]; + contactFxTotals = []; + _.mapKeys(contact.fx_totals, function(total, currency) { + if (currency !== w.metadata.currency) { + return contactFxTotals.push({ + currency: currency, + amount: total.invoiced, + rate: total.rate + }); } - ]; - angular.forEach(w.content.totals, function(value) { - return all_values_are_positive && (all_values_are_positive = value >= 0); }); - options = { - scaleBeginAtZero: all_values_are_positive, - showXLabels: true, - datasetFill: true, - pointDot: false - }; - chartData = ChartFormatterSvc.lineChart(inputData, options); - return $scope.drawTrigger.notify(chartData); + if (!_.isEmpty(contactFxTotals)) { + results.push(contact.formattedFxTotals = contactFxTotals); + } else { + results.push(void 0); + } } + return results; }; return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetSalesForecast', function() { + module.directive('widgetSalesTopCustomers', function() { return { restrict: 'A', - controller: 'WidgetSalesForecastCtrl' + controller: 'WidgetSalesTopCustomersCtrl', + link: function(scope) { + scope.transactionsCollapsed = false; + return scope.toggleTransactions = function() { + return scope.transactionsCollapsed = !scope.transactionsCollapsed; + }; + } }; }); @@ -14442,325 +14330,192 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
threshold) { - return codeName; - } else { - return fullName; + if (anOpp.sales_stage) { + oppDetails.push(anOpp.sales_stage); } + return oppDetails.join(' / '); }; - $scope.drawTrigger = $q.defer(); - w.format = function() { - var all_values_are_positive, chartData, data, dates, inputData, options, period; - if ($scope.isDataFound && $scope.product && (data = $scope.getSelectedProduct())) { - period = null; - if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { - period = w.metadata.hist_parameters.period; - } - dates = _.map(w.content.dates, function(date) { - return $filter('momentDate')(date, period); - }); - inputData = { - title: data.name, - labels: dates, - values: data.totals - }; - all_values_are_positive = true; - angular.forEach(data.totals, function(value) { - return all_values_are_positive && (all_values_are_positive = value >= 0); - }); - options = { - scaleBeginAtZero: all_values_are_positive, - showXLabels: false - }; - if ($scope.filter.value.indexOf('quantity') > -1) { - angular.merge(options, { - currency: 'hide' - }); - } - chartData = ChartFormatterSvc.lineChart([inputData], options); - return $scope.drawTrigger.notify(chartData); + $scope.getOppClass = function(index) { + switch (index) { + case 0: + return 'first'; + case 1: + return 'second'; + case 2: + return 'second'; + default: + return ''; } }; return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetSalesGrowth', function() { + module.directive('widgetSalesTopOpportunities', function() { return { restrict: 'A', - controller: 'WidgetSalesGrowthCtrl' + controller: 'WidgetSalesTopOpportunitiesCtrl' }; }); }).call(this); (function() { - var module, - indexOf = [].indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; }; + var module; - module = angular.module('impac.components.widgets.sales-leads-funnel', []); + module = angular.module('impac.components.widgets-layouts.table', []); - module.controller('WidgetSalesLeadsFunnelCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "$sce", "ImpacWidgetsSvc", "ImpacDashboardsSvc", "$translate", function($scope, $q, ChartFormatterSvc, $filter, $sce, ImpacWidgetsSvc, ImpacDashboardsSvc, $translate) { - var hasOneLead, selectedStatusSetting, setLeadDescriptionTooltips, settingsPromises, w; + module.controller('WidgetTableCtrl', ["$scope", "$q", "$filter", "ImpacWidgetsSvc", function($scope, $q, $filter, ImpacWidgetsSvc) { + var settingsPromises, sortData, sortSingleRows, unCollapsedSetting, w; w = $scope.widget; $scope.orgDeferred = $q.defer(); $scope.timePeriodDeferred = $q.defer(); - $scope.paramsPickerDeferred = $q.defer(); - $scope.widthDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.timePeriodDeferred.promise, $scope.paramsPickerDeferred.promise, $scope.widthDeferred.promise]; - hasOneLead = function(leadsPerStatus) { - var reducedHash, total, totalsArray; - reducedHash = _.mapValues(leadsPerStatus, function(statusHash) { - return statusHash.total; - }); - totalsArray = _.compact(_.values(reducedHash)); - total = _.reduce(totalsArray, function(total, n) { - if (total == null) { - total = 0; - } - return total + n; - }); - return (total != null) && total > 0; + settingsPromises = [$scope.orgDeferred.promise, $scope.timePeriodDeferred.promise]; + $scope.timePeriodInfoParams = { + accountingBehaviour: 'pnl', + histParams: {} }; w.initContext = function() { - var dhb, status_selection; - dhb = ImpacDashboardsSvc.getCurrentDashboard(); - status_selection = w.metadata.status_selection || dhb.metadata.status_selection || { - values: [] - }; - if ($scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.leads_per_status) && hasOneLead(w.content.leads_per_status)) { - _.remove(status_selection.values, function(status) { - return indexOf.call(_.keys(w.content.leads_per_status), status) < 0; - }); - $scope.hasReach = true; - $scope.statusOptions = []; - return angular.forEach(w.content.leads_per_status, function(value, status) { - var isSelected; - isSelected = _.isEmpty(status_selection.values) || (indexOf.call(status_selection.values, status) >= 0); - return $scope.statusOptions.push({ - label: status, - selected: isSelected - }); - }); + $scope.table = _.get(w, 'content.table', {}); + if (_.isEmpty($scope.table.rows)) { + return; } - }; - w.processError = function(error) { - if (error.code === 404) { - return $scope.isDataFound = false; + $scope.currency = _.get(w, 'metadata.currency'); + $scope.timePeriodInfoParams.histParams = _.get(w, 'metadata.hist_parameters', {}); + $scope.unCollapsed = _.get(w, 'metadata.unCollapsed') || []; + $scope.ascending = true; + $scope.sortedColumn = $scope.table.headers.cells[0]; + $scope.colSize = $scope.table.headers.cells.length; + $scope.colWidth = (100 / $scope.colSize) + "%"; + }; + $scope.cellValue = function(v) { + var num; + num = parseFloat(v); + if (_.isNumber(num) && !_.isNaN(num)) { + return $filter('mnoCurrency')(v, $scope.currency); + } else { + return v; } }; - $scope.getImpacColor = function(index) { - return ChartFormatterSvc.getColor(index); - }; - $scope.toggleSelectStatus = function(aStatus) { - if ($scope.selectedStatus && $scope.selectedStatus === aStatus) { - $scope.selectedStatus = null; + $scope.toggleCollapsed = function(table, $event) { + var id; + $event.stopPropagation(); + id = table.headers.id; + if (id == null) { + return; + } + if (_.find($scope.unCollapsed, (function(name) { + return id === name; + }))) { + $scope.unCollapsed = _.reject($scope.unCollapsed, function(name) { + return name === id; + }); } else { - $scope.selectedStatus = aStatus; - $scope.setLeadTooltipsIsLocked = false; + $scope.unCollapsed.push(id); } - if (!w.isExpanded() && $scope.selectedStatus) { - return w.toggleExpanded(); + return ImpacWidgetsSvc.updateWidgetSettings(w, false); + }; + $scope.isCollapsed = function(table) { + var id; + id = table.headers.id; + if (id == null) { + return; + } + if (_.find($scope.unCollapsed, (function(name) { + return id === name; + }))) { + return false; } else { - return ImpacWidgetsSvc.updateWidgetSettings(w, false, true); + return true; } }; - $scope.isSelected = function(aStatus) { - return $scope.selectedStatus && aStatus === $scope.selectedStatus; + $scope.sort = function(col, $index) { + if ($scope.sortedColumn === col) { + $scope.ascending = !$scope.ascending; + } else { + $scope.ascending = true; + $scope.sortedColumn = col; + } + return sortData($scope.table.rows, $index); }; - $scope.getSelectedLeads = function() { - var leads; - if ($scope.isDataFound && $scope.selectedStatus) { - leads = w.content.leads_per_status[$scope.selectedStatus].leads; - if (!$scope.setLeadTooltipsIsLocked) { - setLeadDescriptionTooltips(leads); + sortData = function(rows, colIndex) { + var i, len, ref, table; + if (rows.single) { + rows.single = sortSingleRows(rows.single, colIndex); + } + if (rows.grouped) { + ref = rows.grouped; + for (i = 0, len = ref.length; i < len; i++) { + table = ref[i]; + sortData(table.rows, colIndex); } - return leads; } }; - $scope.leadDescriptionTooltips = {}; - setLeadDescriptionTooltips = function(leads) { - $scope.leadDescriptionTooltips = {}; - $scope.setLeadTooltipsIsLocked = true; - return _.each(leads, function(aLead, index) { - var nameLineArray, tooltip; - tooltip = []; - nameLineArray = [""]; - if (aLead.first_name) { - nameLineArray.push($filter('titleize')(aLead.first_name)); - } - if (aLead.last_name) { - nameLineArray.push($filter('titleize')(aLead.last_name)); - } - nameLineArray.push(""); - tooltip.push(nameLineArray.join(' ')); - tooltip.push("Status: " + ($filter('titleize')(aLead.lead_status))); - if (aLead.organization) { - tooltip.push("Organization: " + ($filter('titleize')(aLead.organization))); - } - if (aLead.opportunities) { - tooltip.push("Opportunities:"); - _.each(aLead.opportunities, function(opp) { - var oppLineArray; - oppLineArray = []; - if (opp.code) { - oppLineArray.push("#" + opp.code); - } - if (opp.name) { - oppLineArray.push("" + opp.name); - } - if (opp.amount) { - oppLineArray.push($filter('mnoCurrency')(opp.amount.total_amount, "USD", false)); - } - if (opp.probability) { - oppLineArray.push(opp.probability + "%"); - } - if (opp.sales_stage) { - oppLineArray.push("" + opp.sales_stage); - } - return tooltip.push(oppLineArray.join(' - ')); - }); - } - return $scope.leadDescriptionTooltips[index] = $sce.trustAsHtml(tooltip.join("
")); - }); + sortSingleRows = function(rows, colIndex) { + return _.sortByOrder(rows, (function(r) { + return r.cells[colIndex]; + }), [$scope.ascending]); }; - selectedStatusSetting = {}; - selectedStatusSetting.initialized = false; - selectedStatusSetting.initialize = function() { - if (!_.isEmpty(w.content) && angular.isDefined(w.content.leads_per_status[w.metadata.selected_status])) { - $scope.selectedStatus = w.metadata.selected_status; - } - return selectedStatusSetting.initialized = true; + unCollapsedSetting = {}; + unCollapsedSetting.initialized = false; + unCollapsedSetting.initialize = function() { + return unCollapsedSetting.initialized = true; }; - selectedStatusSetting.toMetadata = function() { + unCollapsedSetting.toMetadata = function() { return { - selected_status: $scope.selectedStatus + unCollapsed: $scope.unCollapsed }; }; - w.settings.push(selectedStatusSetting); - w.format = function() { - var max; - if ($scope.isDataFound) { - max = 0; - angular.forEach($scope.statusOptions, function(statusOption) { - var value; - value = w.content.leads_per_status[statusOption.label].total; - if (statusOption.selected && angular.isDefined(value) && value > max) { - return max = value; - } - }); - if (max > 0) { - return $scope.funnel = _.compact(_.map($scope.statusOptions, function(statusOption, index) { - var coloredWidth, statusWidth, value; - value = w.content.leads_per_status[statusOption.label].total; - coloredWidth = (100 * (value / max) - 10).toFixed(); - if (coloredWidth < 8) { - statusWidth = 92; - } else { - statusWidth = 100 - coloredWidth; - } - if (statusOption.selected && angular.isDefined(value)) { - return { - status: statusOption.label, - number: value, - coloredWidth: { - width: coloredWidth + "%" - }, - statusWidth: { - width: statusWidth + "%" - } - }; - } - })); - } - } - }; + w.settings.push(unCollapsedSetting); return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetSalesLeadsFunnel', function() { + module.directive('widgetTable', function() { return { restrict: 'A', - controller: 'WidgetSalesLeadsFunnelCtrl' + controller: 'WidgetTableCtrl' + }; + }); + + module.directive('indentTableRow', function() { + return { + restrict: 'A', + link: function(_$scope, $element) { + var ancestorTables, nestLevel; + if ($element.is(':first-child')) { + ancestorTables = $element.closest('table').parentsUntil('#table-layout', 'table'); + nestLevel = ancestorTables.get().length; + if ($element.is('td')) { + nestLevel++; + } + $element.css({ + 'padding-left': (nestLevel * 20) + "px" + }); + } + } }; }); @@ -14769,1410 +14524,2825 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
"]; - if (aLead.first_name) { - nameLineArray.push($filter('titleize')(aLead.first_name)); - } - if (aLead.last_name) { - nameLineArray.push($filter('titleize')(aLead.last_name)); - } - nameLineArray.push(""); - tooltip.push(nameLineArray.join(' ')); - tooltip.push("Status: " + ($filter('titleize')(aLead.lead_status))); - if (aLead.organization) { - tooltip.push("Organization: " + ($filter('titleize')(aLead.organization))); - } - if (aLead.opportunities) { - tooltip.push("Opportunities:"); - _.each(aLead.opportunities, function(opp) { - var oppLineArray; - oppLineArray = []; - if (opp.code) { - oppLineArray.push("#" + opp.code); - } - if (opp.name) { - oppLineArray.push("" + opp.name); - } - if (opp.amount) { - oppLineArray.push($filter('mnoCurrency')(opp.amount.total_amount, "USD", false)); - } - if (opp.probability) { - oppLineArray.push(opp.probability + "%"); - } - if (opp.sales_stage) { - oppLineArray.push("" + opp.sales_stage); - } - return tooltip.push(oppLineArray.join(' - ')); - }); - } - return $scope.leadDescriptionTooltips[index] = $sce.trustAsHtml(tooltip.join("
")); - }); + formatAmount = function(anAccount) { + var balance; + balance = anAccount.current_balance || anAccount.balance || 0.0; + return $filter('mnoCurrency')(balance, anAccount.currency); }; - return $scope.widgetDeferred.resolve(settingsPromises); + $scope.formatLabel = function(anAccount) { + if (anAccount.company != null) { + return anAccount.company + " - " + anAccount.name + " (" + (formatAmount(anAccount)) + ")"; + } else { + return anAccount.name + " (" + (formatAmount(anAccount)) + ")"; + } + }; + w.settings.push(setting); + return $scope.deferred.resolve($scope.parentWidget); }]); - module.directive('widgetSalesLeadsList', function() { + module.directive('settingAccount', ["$templateCache", "$translate", function($templateCache, $translate) { return { restrict: 'A', - controller: 'WidgetSalesLeadsListCtrl' + scope: { + parentWidget: '=', + deferred: '=', + label: '@', + showLabel: '=?', + onAccountSelected: '&' + }, + link: function(scope, element) { + if (!scope.label) { + return scope.label = $translate.instant('impac.widget.settings.account.label'); + } + }, + template: $templateCache.get('widgets-settings/account.tmpl.html'), + controller: 'SettingAccountCtrl' }; - }); + }]); }).call(this); (function() { var module; - module = angular.module('impac.components.widgets.sales-list', []); + module = angular.module('impac.components.widgets-settings.accounting-behaviour', []); - module.controller('WidgetSalesListCtrl', ["$scope", "$q", "ChartFormatterSvc", "ImpacWidgetsSvc", "$translate", function($scope, $q, ChartFormatterSvc, ImpacWidgetsSvc, $translate) { - var buildFxTotals, settingsPromises, sortAccountsBy, sortData, unCollapsedSetting, w; - w = $scope.widget; - $scope.orgDeferred = $q.defer(); - $scope.paramSelectorDeferred = $q.defer(); - $scope.datesPickerDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.paramSelectorDeferred.promise, $scope.datesPickerDeferred.promise]; - $scope.ascending = true; - $scope.sortedColumn = 'account'; - $scope.datesPickerTemplate = "" + $translate.instant('impac.widget.sales_list.from') + " " + $translate.instant('impac.widget.sales_list.to') + " "; - w.initContext = function() { - if ($scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.summary)) { - buildFxTotals(); - $scope.ratesDate = moment.now(); - $scope.filterOptions = [ - { - label: $translate.instant('impac.widget.sales_list.value_sold_taxes'), - value: 'gross_value_sold' - }, { - label: $translate.instant('impac.widget.sales_list.value_sold_no_taxes'), - value: 'net_value_sold' - }, { - label: $translate.instant('impac.widget.sales_list.quantity_sold'), - value: 'quantity_sold' - }, { - label: $translate.instant('impac.widget.sales_list.value_purchased_taxes'), - value: 'gross_value_purchased' - }, { - label: $translate.instant('impac.widget.sales_list.value_purchased_no_taxes'), - value: 'net_value_purchased' - }, { - label: $translate.instant('impac.widget.sales_list.quantity_purchased'), - value: 'quantity_purchased' - } - ]; - $scope.filter = angular.copy(_.find($scope.filterOptions, function(o) { - return o.value === w.metadata.filter; - }) || $scope.filterOptions[0]); - $scope.unCollapsed = w.metadata.unCollapsed || []; - return sortData(); - } - }; - $scope.toggleCollapsed = function(categoryName) { - if (categoryName != null) { - if (_.find($scope.unCollapsed, (function(name) { - return categoryName === name; - }))) { - $scope.unCollapsed = _.reject($scope.unCollapsed, function(name) { - return name === categoryName; + module.directive('settingAccountingBehaviour', ["$templateCache", "$timeout", function($templateCache, $timeout) { + return { + restrict: 'A', + scope: { + parentWidget: '=', + deferred: '=', + defaultBehaviour: '=?' + }, + template: $templateCache.get('widgets-settings/accounting-behaviour.tmpl.html'), + link: function(scope) { + var setting, w; + w = scope.parentWidget; + setting = {}; + setting.key = "accounting-behaviour"; + setting.initialize = function() { + return $timeout(function() { + if ((scope.defaultBehaviour != null) && scope.defaultBehaviour === 'pnl') { + return scope.selectedBehaviour = 'pnl'; + } else { + return scope.selectedBehaviour = 'bls'; + } }); - } else { - $scope.unCollapsed.push(categoryName); - } - return ImpacWidgetsSvc.updateWidgetSettings(w, false); + }; + setting.toMetadata = function() { + return { + accounting_behaviour: scope.selectedBehaviour + }; + }; + w.settings.push(setting); + return scope.deferred.resolve(setting); } }; - $scope.isCollapsed = function(categoryName) { - if (categoryName != null) { - if (_.find($scope.unCollapsed, (function(name) { - return categoryName === name; - }))) { - return false; - } else { - return true; - } + }]); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets-settings.accounts-list', []); + + module.controller('SettingAccountsListCtrl', ["$scope", "$timeout", "ImpacWidgetsSvc", function($scope, $timeout, ImpacWidgetsSvc) { + var restoreSavedAccounts, setting, w; + w = $scope.parentWidget; + w.moveAccountToAnotherList = function(account, src, dst, triggerUpdate) { + if (triggerUpdate == null) { + triggerUpdate = true; } - }; - sortAccountsBy = function(getElem) { - return angular.forEach(w.content.summary, function(sElem) { - if (sElem.products) { - return sElem.products.sort(function(a, b) { - var res; - res = getElem(a) > getElem(b) ? 1 : getElem(a) < getElem(b) ? -1 : 0; - if (!$scope.ascending) { - res *= -1; - } - return res; - }); - } + if (_.isEmpty(src) || _.isEmpty(account)) { + return; + } + dst || (dst = []); + _.remove(src, function(acc) { + return account.uid === acc.uid; }); + dst.push(account); + if (triggerUpdate) { + ImpacWidgetsSvc.updateWidgetSettings(w, false); + } + return null; }; - sortData = function() { - if ($scope.sortedColumn === 'account') { - return sortAccountsBy(function(el) { - return el.name; - }); - } else if ($scope.sortedColumn === 'total') { - return sortAccountsBy(function(el) { - return el.total; + setting = {}; + setting.key = "accounts-list"; + setting.initialize = function() { + setting.isInitialized = false; + w.remainingAccounts = []; + w.selectedAccounts = []; + if ((w.content != null) && !_.isEmpty(w.content.complete_list)) { + w.remainingAccounts = angular.copy(w.content.complete_list); + return $timeout(function() { + restoreSavedAccounts(); + return setting.isInitialized = true; }); } }; - $scope.sort = function(col) { - if ($scope.sortedColumn === col) { - $scope.ascending = !$scope.ascending; - } else { - $scope.ascending = true; - $scope.sortedColumn = col; + setting.toMetadata = function() { + if (setting.isInitialized) { + return { + accounts_list: _.map(w.selectedAccounts, (function(acc) { + return acc.uid; + })) + }; } - return sortData(); }; - buildFxTotals = function() { - var groupedSales, i, len, ref, results, sale, saleFxTotals; - ref = w.content.summary; + restoreSavedAccounts = function() { + var acc, accUid, accountsList, i, len, results; + if (_.isEmpty(w.metadata.accounts_list) && _.isEmpty($scope.accountsList)) { + return; + } + accountsList = _.isEmpty($scope.accountsList) ? w.metadata.accounts_list : $scope.accountsList; results = []; - for (i = 0, len = ref.length; i < len; i++) { - groupedSales = ref[i]; - results.push((function() { - var j, len1, ref1, results1; - ref1 = groupedSales.products; - results1 = []; - for (j = 0, len1 = ref1.length; j < len1; j++) { - sale = ref1[j]; - saleFxTotals = []; - if (!_.isEmpty(sale.fx_totals)) { - _.mapKeys(sale.fx_totals, function(total, currency) { - var amount; - amount = total['amount']; - if (!(amount === 0 || currency === w.metadata.currency)) { - return saleFxTotals.push({ - currency: currency, - amount: amount, - rate: total.rate - }); - } - }); - } - if (!_.isEmpty(saleFxTotals)) { - results1.push(sale.formattedFxTotals = saleFxTotals); - } else { - results1.push(void 0); - } - } - return results1; - })()); + for (i = 0, len = accountsList.length; i < len; i++) { + accUid = accountsList[i]; + acc = _.find(w.content.complete_list, function(acc) { + return acc.uid === accUid; + }); + results.push(w.moveAccountToAnotherList(acc, w.remainingAccounts, w.selectedAccounts, false)); } return results; }; - unCollapsedSetting = {}; - unCollapsedSetting.initialized = false; - unCollapsedSetting.initialize = function() { - return unCollapsedSetting.initialized = true; - }; - unCollapsedSetting.toMetadata = function() { - return { - unCollapsed: $scope.unCollapsed - }; - }; - w.settings.push(unCollapsedSetting); - return $scope.widgetDeferred.resolve(settingsPromises); + w.settings.push(setting); + return $scope.deferred.resolve($scope.parentWidget); }]); - module.directive('widgetSalesList', function() { + module.directive('settingAccountsList', function() { return { restrict: 'A', - controller: 'WidgetSalesListCtrl' + scope: { + parentWidget: '=', + deferred: '=', + accountsList: '=?' + }, + controller: 'SettingAccountsListCtrl' }; }); }).call(this); + +/* + * Attach KPIs onto widget with a form for picking target mode and value. View widget's + * attached KPIs, manage set targets, alerts and delete. + * **NOTE: this component is not in use, and requires fixes/improvements to be used.** + */ + (function() { var module; - module = angular.module('impac.components.widgets.sales-margin', []); + module = angular.module('impac.components.widgets-settings.attach-kpis', []); - module.controller('WidgetSalesMarginCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "$translate", function($scope, $q, ChartFormatterSvc, $filter, $translate) { - var settingsPromises, w; - w = $scope.widget; - $scope.orgDeferred = $q.defer(); - $scope.timePeriodDeferred = $q.defer(); - $scope.histModeDeferred = $q.defer(); - $scope.paramSelectorDeferred = $q.defer(); - $scope.chartDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.timePeriodDeferred.promise, $scope.histModeDeferred.promise, $scope.paramSelectorDeferred.promise, $scope.chartDeferred.promise]; - w.initContext = function() { - $scope.isDataFound = (w.content != null) && (w.content.margins != null) && (w.content.dates != null); - if ($scope.isDataFound) { - $scope.filterOptions = [ + module.directive('settingAttachKpis', ["$templateCache", "ImpacWidgetsSvc", "ImpacKpisSvc", "$translate", function($templateCache, ImpacWidgetsSvc, ImpacKpisSvc, $translate) { + return { + restrict: 'A', + scope: { + parentWidget: '=', + attachedKpis: '=?', + widgetEngine: '=', + widgetId: '=', + extraParams: '=?', + deferred: '=', + showExtraParam: '=?' + }, + template: $templateCache.get('widgets-settings/attach-kpis.tmpl.html'), + controller: ["$scope", function($scope) { + var loadKpisData, settings, w; + w = $scope.parentWidget; + settings = {}; + settings.initialize = function() { + return loadKpisData(); + }; + settings.toMetadata = function() {}; + w.settings.push(settings); + $scope.formatKpiName = function(endpoint) { + return ImpacKpisSvc.formatKpiName(endpoint); + }; + $scope.hasValidTarget = function() { + return ImpacKpisSvc.validateKpiTarget($scope.kpi); + }; + $scope.attachKpi = function() { + var param, paramValues, params, ref, target0; + params = {}; + if (!$scope.hasValidTarget()) { + return; + } + target0 = {}; + target0[$scope.kpi.limit.mode] = $scope.kpi.limit.value; + params.targets = {}; + params.targets[$scope.kpi.watchables[0]] = [target0]; + params.widget_id = $scope.widgetId; + ref = $scope.extraParams; + for (param in ref) { + paramValues = ref[param]; + params.extra_params || (params.extra_params = {}); + params.extra_params[param] = paramValues.uid; + } + console.log('attachKpis: ', $scope.kpi.endpoint, $scope.elementWatched, params); + return ImpacKpisSvc.create('impac', $scope.kpi.endpoint, $scope.elementWatched, params).then(function(kpi) { + console.log('attached KPI: ', kpi); + return $scope.attachedKpis.push(kpi); + }); + }; + $scope.deleteKpi = function(kpi) { + return ImpacKpisSvc["delete"](kpi, { + widget_id: $scope.widgetId + }).then(function() { + return _.remove($scope.attachedKpis, function(k) { + return k.id === kpi.id; + }); + }); + }; + $scope.formatAttachedKpiTitle = function(kpi) { + if (!(kpi.data && kpi.targets && $scope.elementWatched)) { + return ''; + } + return ImpacKpisSvc.formatKpiTarget(kpi.targets[$scope.elementWatched][0], kpi.data[$scope.elementWatched].unit, $scope.possibleTargets); + }; + $scope.attachedKpis || ($scope.attachedKpis = []); + $scope.possibleTargets = [ { - label: $translate.instant('impac.widget.sales_margin.including_taxes'), - value: 'gross_margin' + label: $translate.instant('impac.widget.settings.attach_kpis.over'), + mode: 'min' }, { - label: $translate.instant('impac.widget.sales_margin.excluding_taxes'), - value: 'net_margin' + label: $translate.instant('impac.widget.settings.attach_kpis.below'), + mode: 'max' } ]; - if ((w.metadata != null) && w.metadata.filter === "net_margin") { - return $scope.filter = angular.copy($scope.filterOptions[1]); - } else { - return $scope.filter = angular.copy($scope.filterOptions[0]); - } + $scope.kpi = { + limit: { + mode: $scope.possibleTargets[0].mode + } + }; + ImpacKpisSvc.getAttachableKpis($scope.widgetEngine).then(function(kpiTemplates) { + $scope.availableKpis = angular.copy(kpiTemplates); + angular.extend($scope.kpi, $scope.availableKpis[0]); + $scope.selectedParam = _.keys($scope.extraParams)[0]; + return $scope.elementWatched = ($scope.kpi.watchables != null) && $scope.kpi.watchables[0]; + }); + loadKpisData = function() {}; + loadKpisData(); + return $scope.deferred.resolve($scope.parentWidget); + }] + }; + }]); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets-settings.bolt-account', []); + + module.controller('SettingBoltAccountCtrl', ["$scope", "$filter", function($scope, $filter) { + var formatAmount, setOptions, setSelected, setting, w; + w = $scope.parentWidget; + setting = {}; + setting.key = "bolt-account"; + setting.isInitialized = false; + setting.initialize = function() { + if (w.content.settings.selectors.length !== 0) { + w.accountList = setOptions(); + } + w.selectedAccount = setSelected(); + if ((w.content != null) && (w.accountList != null) && (w.metadata != null) && (w.metadata.account_uid != null)) { + w.selectedAccount = setSelected(w.metadata.account_uid); + return setting.isInitialized = true; } }; - $scope.getTotalMargin = function() { - if ($scope.isDataFound) { - if ((w.metadata != null) && w.metadata.filter === "net_margin") { - return _.reduce(w.content.margins.net, function(memo, margin) { - return memo + margin; - }, 0); - } else { - return _.reduce(w.content.margins.gross, function(memo, margin) { - return memo + margin; - }, 0); - } + setting.toMetadata = function() { + if (w.selectedAccount != null) { + return { + account_uid: w.selectedAccount.account_id + }; } }; - $scope.getCurrency = function() { - if ($scope.isDataFound) { - return w.content.currency || "USD"; + setOptions = function(name) { + if (name == null) { + name = 'account'; } + return _.find(w.content.settings.selectors, function(selector) { + return selector.name === name; + }).options; }; - $scope.drawTrigger = $q.defer(); - w.format = function() { - var all_values_are_positive, chartData, dates, inputData, options, period, values; - if ($scope.isDataFound) { - if ((w.metadata != null) && w.metadata.filter === "net_margin") { - values = w.content.margins.net; - } else { - values = w.content.margins.gross; - } - period = null; - if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { - period = w.metadata.hist_parameters.period; - } - dates = _.map(w.content.dates, function(date) { - return $filter('momentDate')(date, period); - }); - inputData = { - title: $translate.instant('impac.widget.sales_margin.gross_margin'), - labels: dates, - values: values - }; - all_values_are_positive = true; - angular.forEach(values, function(value) { - return all_values_are_positive && (all_values_are_positive = value >= 0); - }); - options = { - scaleBeginAtZero: all_values_are_positive, - showXLabels: false - }; - chartData = ChartFormatterSvc.lineChart([inputData], options); - return $scope.drawTrigger.notify(chartData); + setSelected = function(selected) { + if (selected == null) { + selected = 'total_uid'; + } + return _.find(w.accountList, function(acc) { + return acc.account_id === selected; + }); + }; + formatAmount = function(anAccount) { + var balance; + balance = null; + return $filter('mnoCurrency')(balance, anAccount.currency); + }; + $scope.formatLabel = function(anAccount) { + if (anAccount.currency != null) { + return anAccount.name + " (" + anAccount.currency + ")"; + } else { + return "" + anAccount.name; } }; - return $scope.widgetDeferred.resolve(settingsPromises); + w.settings.push(setting); + return $scope.deferred.resolve($scope.parentWidget); }]); - module.directive('widgetSalesMargin', function() { + module.directive('settingBoltAccount', ["$templateCache", "$translate", function($templateCache, $translate) { return { restrict: 'A', - controller: 'WidgetSalesMarginCtrl' - }; - }); - -}).call(this); - -(function() { - var module; - - module = angular.module('impac.components.widgets.sales-net-sales', []); - - module.controller('WidgetSalesNetSalesCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "$translate", function($scope, $q, ChartFormatterSvc, $filter, $translate) { - var settingsPromises, w; - w = $scope.widget; - $scope.orgDeferred = $q.defer(); - $scope.paramSelector1Deferred = $q.defer(); - $scope.paramSelector2Deferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.paramSelector1Deferred.promise, $scope.paramSelector2Deferred.promise]; - $translate(['impac.widget.sales_net_sales.total_amount', 'impac.widget.sales_net_sales.average_amount', 'impac.widget.sales_net_sales.volume']).then(function(translations) { - $scope.displayOptions = [ - { - label: translations['impac.widget.sales_net_sales.total_amount'], - value: 'total' - }, { - label: translations['impac.widget.sales_net_sales.average_amount'], - value: 'average' - }, { - label: translations['impac.widget.sales_net_sales.volume'], - value: 'trans_count' + scope: { + parentWidget: '=', + deferred: '=', + label: '@', + showLabel: '=?', + onAccountSelected: '&' + }, + link: function(scope, element) { + if (!scope.label) { + return scope.label = $translate.instant('impac.widget.settings.bolt-account.label'); } - ]; - return $scope.displayType = angular.copy(_.find($scope.displayOptions, function(o) { - return w.metadata && o.value === w.metadata.display_type; - }) || $scope.displayOptions[0]); - }); - $translate(['impac.widget.sales_net_sales.tmpl.last_hours', 'impac.widget.sales_net_sales.tmpl.last_days']).then(function(translations) { - var daysTmpl, hoursTmpl; - hoursTmpl = translations['impac.widget.sales_net_sales.tmpl.last_hours']; - daysTmpl = translations['impac.widget.sales_net_sales.tmpl.last_days']; - $scope.timeRangeOptions = [ - { - label: hoursTmpl.replace(':hours:', 24), - value: '-1d' - }, { - label: daysTmpl.replace(':days:', 5), - value: '-5d' - }, { - label: daysTmpl.replace(':days:', 7), - value: '-7d' - }, { - label: daysTmpl.replace(':days:', 30), - value: '-30d' - }, { - label: daysTmpl.replace(':days:', 45), - value: '-45d' - }, { - label: daysTmpl.replace(':days:', 60), - value: '-60d' - }, { - label: daysTmpl.replace(':days:', 90), - value: '-90d' + }, + template: $templateCache.get('widgets-settings/bolt-account.tmpl.html'), + controller: 'SettingBoltAccountCtrl' + }; + }]); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets-settings.dates-picker', []); + + module.directive('settingDatesPicker', ["$templateCache", "$filter", "ImpacWidgetsSvc", "$timeout", "$compile", function($templateCache, $filter, ImpacWidgetsSvc, $timeout, $compile) { + return { + restrict: 'A', + scope: { + parentWidget: '=?', + deferred: '=', + fromDate: '=from', + toDate: '=to', + keepToday: '=', + onUse: '&?', + onChangeCb: '&?onChange', + minDate: '=?', + updateOnPick: '=?', + template: '=?', + period: '=?' + }, + template: $templateCache.get('widgets-settings/dates-picker.tmpl.html'), + link: function(scope, element) { + var applyHtml, buildDates, fromDateHtml, isToToday, setting, templatesContainer, toDateHtml, w; + w = scope.parentWidget; + setting = {}; + setting.key = "dates-picker"; + scope.setting = setting; + scope.calendarFrom = { + opened: false, + value: new Date(new Date().getFullYear(), 0, 1), + toggle: function() { + scope.calendarFrom.opened = !scope.calendarFrom.opened; + return scope.calendarTo.opened = false; + } + }; + scope.calendarTo = { + opened: false, + value: new Date(), + toggle: function() { + scope.calendarFrom.opened = false; + return scope.calendarTo.opened = !scope.calendarTo.opened; + } + }; + scope.template || (scope.template = "
\n
\n impac.widget.settings.dates_picker.from \n
\n
\n impac.widget.settings.dates_picker.to \n
\n
"); + fromDateHtml = "
\n \n
"; + toDateHtml = "
\n \n
"; + applyHtml = ""; + scope.template = scope.template.replace(/>/, " ng-click='onUse()'>"); + scope.template = scope.template.replace(/]*)>/g, "" + (fromDateHtml.replace('ATTRS', '$1'))); + scope.template = scope.template.replace(/]*)>/g, "" + (toDateHtml.replace('ATTRS', '$1'))); + scope.template = scope.template.replace(/]*)>/g, "" + (applyHtml.replace('ATTRS', '$1'))); + templatesContainer = element.find('#template-container'); + templatesContainer.html(scope.template).show(); + $compile(templatesContainer.contents())(scope); + setting.initialize = function() { + return $timeout(function() { + var d, m, parsedFrom, parsedTo, y; + scope.changed = false; + if (Date.parse(scope.fromDate)) { + parsedFrom = scope.fromDate.split('-'); + y = parsedFrom[0]; + m = parsedFrom[1] - 1; + d = parsedFrom[2]; + scope.calendarFrom.value = new Date(y, m, d); + } else { + scope.calendarFrom.value = new Date(new Date().getFullYear(), 0, 1); + } + if (Date.parse(scope.toDate) && !scope.keepToday) { + parsedTo = scope.toDate.split('-'); + y = parsedTo[0]; + m = parsedTo[1] - 1; + d = parsedTo[2]; + return scope.calendarTo.value = new Date(y, m, d); + } else { + return scope.calendarTo.value = new Date(); + } + }); + }; + isToToday = function() { + return (scope.calendarTo.value.getFullYear() === new Date().getFullYear()) && (scope.calendarTo.value.getMonth() === new Date().getMonth()) && (scope.calendarTo.value.getDate() === new Date().getDate()); + }; + setting.toMetadata = function() { + return { + hist_parameters: { + from: $filter('date')(scope.calendarFrom.value, 'yyyy-MM-dd'), + to: $filter('date')(scope.calendarTo.value, 'yyyy-MM-dd'), + period: scope.period || "RANGE", + keep_today: isToToday() + } + }; + }; + scope.onChange = function() { + scope.showApplyButton(); + if (!_.isUndefined(scope.onChangeCb)) { + return scope.onChangeCb()(buildDates()); + } + }; + buildDates = function() { + return { + from: $filter('date')(scope.calendarFrom.value, 'yyyy-MM-dd'), + to: $filter('date')(scope.calendarTo.value, 'yyyy-MM-dd'), + keepToday: isToToday() + }; + }; + scope.showApplyButton = function() { + if (scope.updateOnPick) { + return scope.applyChanges(); + } else { + return scope.changed = true; + } + }; + scope.applyChanges = function() { + ImpacWidgetsSvc.updateWidgetSettings(w, true); + return scope.changed = false; + }; + scope.showTitle = function() { + return element.hasClass('part'); + }; + if (w) { + w.settings.push(setting); } - ]; - return $scope.timeRange = angular.copy(_.find($scope.timeRangeOptions, function(o) { - return w.metadata && o.value === w.metadata.time_range; - }) || $scope.timeRangeOptions[6]); - }); - w.initContext = function() { - return $scope.isDataFound = (w.content != null) && (w.content.sales != null) && w.content.sales.length > 0 && (w.content.sales[0].total != null); + return scope.deferred.resolve(setting); + } }; - $scope.getCurrency = function() { - if ($scope.isDataFound) { - return w.content.currency; + }]); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets-settings.chart-filters', []); + + module.controller('SettingChartFiltersCtrl', ["$scope", function($scope) { + var setting, w; + w = $scope.parentWidget; + setting = {}; + setting.key = "chart-filters"; + setting.isInitialized = false; + setting.initialize = function() { + if ((w.content != null) && (w.content.chart_filter != null) && ($scope.filterCriteria = w.content.chart_filter.criteria)) { + $scope.maxEntities = w.content.chart_filter.max; + $scope.entityType = w.content.chart_filter.entity_type; + $scope.filterLabel = w.content.chart_filter.filter_label.replace(/_/g, " "); + if ($scope.filterCriteria === "number") { + $scope.filterValuePercentage = 80; + $scope.filterValueNumber = w.content.chart_filter.value; + } else { + $scope.filterValuePercentage = w.content.chart_filter.value; + $scope.filterValueNumber = Math.round($scope.maxEntities / 2); + } + return setting.isInitialized = true; } }; - $scope.getValue = function(valueType) { - if ((w.content != null) && w.content[valueType]) { - switch ($scope.displayType.value) { - case 'total': - return $filter('mnoCurrency')(w.content[valueType][0].total, $scope.getCurrency(), false); - case 'average': - return $filter('mnoCurrency')(w.content[valueType][0].avg, $scope.getCurrency(), false); - case 'trans_count': - return w.content[valueType][0].trans_count; + setting.toMetadata = function() { + var filterValue; + if ((w.content != null) && (w.content.chart_filter != null)) { + if ($scope.filterCriteria === "percentage") { + filterValue = $scope.filterValuePercentage; + } else { + filterValue = $scope.filterValueNumber; } + return { + chart_filter: { + criteria: $scope.filterCriteria, + value: filterValue + } + }; } else { - return 0; + return {}; } }; - $scope.sign = function(type) { - if ($scope.displayType.value === 'average') { - return { - minus: '~', - equal: '=>' - }[type]; - } else if ($scope.displayType.value === 'trans_count') { + w.settings.push(setting); + return $scope.deferred.resolve($scope.parentWidget); + }]); + + module.directive('settingChartFilters', ["$templateCache", function($templateCache) { + return { + restrict: 'A', + scope: { + parentWidget: '=', + deferred: '=' + }, + template: $templateCache.get('widgets-settings/chart-filters.tmpl.html'), + controller: 'SettingChartFiltersCtrl' + }; + }]); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets-settings.forecast-payroll', []); + + module.controller('SettingForecastPayrollCtrl', ["$scope", "ImpacDashboardsSvc", function($scope, ImpacDashboardsSvc) { + var setting, w; + w = $scope.parentWidget; + $scope.selectedForecastPayroll = false; + $scope.toggleForecastPayroll = function() { + return $scope.selectedForecastPayroll = !$scope.selectedForecastPayroll; + }; + $scope.isToggleForecastPayroll = function() { + return $scope.selectedForecastPayroll; + }; + setting = {}; + setting.key = "forecast_payroll"; + setting.isInitialized = false; + setting.initialize = function() { + return ImpacDashboardsSvc.load().then(function(config) { + var currentDashboard; + currentDashboard = config.currentDashboard; + if (!((w.metadata != null) && (w.metadata.forecast_payroll != null))) { + return; + } + $scope.selectedForecastPayroll = w.metadata.forecast_payroll; + return setting.isInitialized = true; + }); + }; + setting.toMetadata = function() { + return { + forecast_payroll: $scope.selectedForecastPayroll + }; + }; + w.settings.push(setting); + return $scope.deferred.resolve($scope.parentWidget); + }]); + + module.directive('settingForecastPayroll', ["$templateCache", function($templateCache) { + return { + restrict: 'A', + scope: { + parentWidget: '=', + mode: '@?', + deferred: '=', + onSelect: '&?' + }, + template: $templateCache.get('widgets-settings/forecast-payroll.tmpl.html'), + controller: 'SettingForecastPayrollCtrl' + }; + }]); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets-settings.formula', []); + + module.controller('SettingFormulaCtrl', ["$scope", "$filter", "$timeout", "$translate", function($scope, $filter, $timeout, $translate) { + var AUTHORIZED_REGEXP, evaluateFormula, formatFormula, getFormula, interpolateInFormula, isRatio, prepareFormula, setting, translateEvaluatedFormula, w; + w = $scope.parentWidget; + w.formula = ''; + AUTHORIZED_REGEXP = new RegExp("^(\\{|\\d|\\}|\\/|\\+|-|\\*|\\(|\\)|\\s|\\.)*$"); + setting = {}; + setting.key = "formula"; + setting.isInitialized = false; + setting.initialize = function() { + if ((w.metadata != null) && (w.metadata.formula != null)) { + w.formula = w.metadata.formula; + return $timeout(function() { + prepareFormula(); + return setting.isInitialized = true; + }); + } else { + return w.formula = ''; + } + }; + setting.toMetadata = function() { + prepareFormula(); + if (w.isFormulaCorrect) { return { - minus: '+', - equal: '=' - }[type]; + formula: w.formula + }; } else { return { - minus: '-', - equal: '=' - }[type]; + formula: '' + }; + } + }; + getFormula = function() { + return w.formula; + }; + w.formatAmount = function(anAccount) { + return $filter('mnoCurrency')(anAccount.current_balance, anAccount.currency); + }; + $scope.$watch(getFormula, function(e) { + return prepareFormula(); + }); + prepareFormula = function() { + var evaluatedFormula, interpolatedFormula; + interpolatedFormula = interpolateInFormula(w.formula, w.selectedAccounts, 'current_balance'); + if ((evaluatedFormula = evaluateFormula(interpolatedFormula))) { + w.evaluatedFormula = formatFormula(evaluatedFormula, w.formula, w.selectedAccounts); + w.legend = interpolateInFormula(w.formula, w.selectedAccounts, 'name'); + w.isFormulaCorrect = true; + } else { + w.evaluatedFormula = 'invalid expression'; + w.legend = '...'; + w.isFormulaCorrect = false; + } + return w.evaluatedFormulaTranslate = translateEvaluatedFormula(w.evaluatedFormula); + }; + w.evaluatedFormula_History = function(index) { + var account, i, interpolation, j, len, pattern, ref; + interpolation = w.formula; + ref = w.selectedAccounts; + for (i = j = 0, len = ref.length; j < len; i = ++j) { + account = ref[i]; + pattern = new RegExp("\\{" + (i + 1) + "\\}", 'g'); + interpolation = interpolation.replace(pattern, " " + account['balances'][index] + " "); + } + return evaluateFormula(interpolation); + }; + translateEvaluatedFormula = function(formula) { + switch (formula) { + case 'invalid expression': + return $translate.instant('impac.widget.formula.invalid_expression'); + case 'Infinity': + return $translate.instant('impac.widget.formula.infinity'); + case '-Infinity': + return $translate.instant('impac.widget.formula.minus_infinity'); + default: + return formula; + } + }; + interpolateInFormula = function(sourceFormula, selectedAccounts, accountMember) { + var account, i, interpolation, j, len, pattern; + interpolation = sourceFormula; + if (_.isEmpty(selectedAccounts)) { + return interpolation; + } + for (i = j = 0, len = selectedAccounts.length; j < len; i = ++j) { + account = selectedAccounts[i]; + pattern = new RegExp("\\{" + (i + 1) + "\\}", 'g'); + interpolation = interpolation.replace(pattern, " " + account[accountMember] + " "); + } + return interpolation; + }; + evaluateFormula = function(interpolatedFormula) { + var e, evaluation; + if (!interpolatedFormula.match(AUTHORIZED_REGEXP)) { + return false; + } + try { + evaluation = eval(interpolatedFormula).toFixed(2); + if (isFinite(evaluation)) { + return evaluation; + } else { + return false; + } + } catch (error) { + e = error; + return false; + } + }; + isRatio = function(sourceFormula) { + return sourceFormula.match(/\//g); + }; + formatFormula = function(evaluation, sourceFormula, selectedAccounts) { + var currency, firstAccount; + if (isRatio(sourceFormula) || _.isEmpty(selectedAccounts)) { + return evaluation; + } + firstAccount = selectedAccounts[0]; + if (!(currency = firstAccount.currency)) { + return evaluation; + } + return $filter('mnoCurrency')(evaluation, currency); + }; + w.settings.push(setting); + return $scope.deferred.resolve($scope.parentWidget); + }]); + + module.directive('settingFormula', function() { + return { + restrict: 'A', + scope: { + parentWidget: '=', + deferred: '=' + }, + controller: 'SettingFormulaCtrl' + }; + }); + +}).call(this); + +(function() { + var module, + indexOf = [].indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; }; + + module = angular.module('impac.components.widgets-settings.hist-mode', []); + + module.controller('SettingHistModeCtrl', ["$scope", "$translate", "$timeout", "ImpacWidgetsSvc", "ImpacTheming", "ImpacUtilities", function($scope, $translate, $timeout, ImpacWidgetsSvc, ImpacTheming, ImpacUtilities) { + var buildCurrentLabel, setting, w; + w = $scope.parentWidget; + w.isHistoryMode = w.metadata && w.metadata.hist_parameters && w.metadata.hist_parameters.mode === 'history'; + $scope.forwardParams = { + accountingBehaviour: function() { + return $scope.accountingBehaviour; + } + }; + $scope.toggleHistMode = function(mode) { + var ref; + if ((w.isHistoryMode && mode === 'history') || (!w.isHistoryMode && mode === 'current')) { + return; + } + w.isHistoryMode = !w.isHistoryMode; + ImpacWidgetsSvc.updateWidgetSettings(w, false); + return ref = $scope.onToggle(), indexOf.call(angular.isDefined($scope.onToggle), ref) >= 0; + }; + buildCurrentLabel = function() { + var label, labels, needPrefix, prefix; + labels = ImpacTheming.get().widgetSettings.histModeChoser.currentLabels; + if (($scope.accountingBehaviour != null) && labels[$scope.accountingBehaviour]) { + needPrefix = !$scope.endDate || ($scope.endDate === moment().format('YYYY-MM-DD')); + label = labels[$scope.accountingBehaviour]; + prefix = labels[$scope.accountingBehaviour] + '.prefix'; + return $translate([prefix, label]).then(function(translations) { + return $scope.currentLabel = needPrefix ? translations[prefix] + " " + translations[label] : translations[label]; + }); + } else { + return $translate(labels["default"]).then(function(label) { + return $scope.currentLabel = label; + }); + } + }; + setting = {}; + setting.key = "hist-mode"; + setting.isInitialized = false; + setting.initialize = function() { + return $timeout(function() { + var mode; + if ((w.metadata != null) && (w.metadata.hist_parameters != null) && (mode = w.metadata.hist_parameters.mode)) { + w.isHistoryMode = mode === 'history' ? true : false; + } + buildCurrentLabel(); + $scope.forwardParams.histParams = w.metadata && w.metadata.hist_parameters; + setting.isInitialized = true; + return $scope; + }); + }; + setting.toMetadata = function() { + var mode; + mode = w.isHistoryMode ? 'history' : 'current'; + return { + hist_parameters: { + mode: mode + } + }; + }; + w.settings.push(setting); + return $scope.deferred.resolve($scope.parentWidget); + }]); + + module.directive('settingHistMode', ["$templateCache", function($templateCache) { + return { + restrict: 'A', + scope: { + parentWidget: '=', + deferred: '=', + onToggle: '&', + accountingBehaviour: '@?', + endDate: '=?' + }, + template: $templateCache.get('widgets-settings/hist-mode.tmpl.html'), + controller: 'SettingHistModeCtrl' + }; + }]); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets-settings.limit-entries', []); + + module.controller('SettingLimitEntriesCtrl', ["$scope", function($scope) { + var setting; + setting = {}; + setting.key = 'limit-entries'; + setting.initialize = function() { + return true; + }; + setting.toMetadata = function() { + return { + limit_entries: $scope.selected + }; + }; + $scope.parentWidget.settings.push(setting); + return $scope.deferred.resolve(setting); + }]); + + module.directive('settingLimitEntries', ["$templateCache", "ImpacWidgetsSvc", function($templateCache, ImpacWidgetsSvc) { + return { + restrict: 'A', + scope: { + parentWidget: '=', + deferred: '=', + selected: '=', + max: '=?', + options: '=?', + entriesLabel: '=?' + }, + link: function(scope, elements, attrs) { + if (!((scope.options != null) && scope.options.length > 0)) { + scope.options = [5, 15, 50]; + } + scope.selectOption = function(anOption) { + scope.selected = anOption; + return ImpacWidgetsSvc.updateWidgetSettings(scope.parentWidget, false); + }; + return scope.isOptionValid = function(anOption) { + return (scope.max == null) || anOption < scope.max; + }; + }, + controller: 'SettingLimitEntriesCtrl', + template: $templateCache.get('widgets-settings/limit-entries.tmpl.html') + }; + }]); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets-settings.offsets', []); + + module.directive('settingOffsets', ["$templateCache", "ImpacUtilities", function($templateCache, ImpacUtilities) { + return { + restrict: 'A', + scope: { + parentWidget: '=', + deferred: '=', + offsetsKey: '@', + initialOffsets: '=', + currency: '=', + intervalsCount: '=', + period: '=', + showIntervalsMult: '=', + textPlaceholder: '@?' + }, + template: $templateCache.get('widgets-settings/offsets.tmpl.html'), + link: function(scope) { + var authorized_regex, computedFormula, placeholder, setting, w; + w = scope.parentWidget; + authorized_regex = new RegExp("^(\\{|\\d|\\}|\\/|\\+|-|\\*|\\(|\\)|\\s|\\.)*$"); + setting = { + key: "offsets-" + scope.offsetsKey + }; + setting.initialize = function() { + var i, len, offsetValue, ref; + scope.offsets = []; + ref = scope.initialOffsets || []; + for (i = 0, len = ref.length; i < len; i++) { + offsetValue = ref[i]; + scope.offsets.push(offsetValue); + } + scope.offsetFormula = ""; + scope.periodWord = ImpacUtilities.getPeriodWord(scope.period); + return scope.placeholder = placeholder(scope.period || 'MONTHLY'); + }; + setting.toMetadata = function() { + var metadata; + metadata = { + offset: {} + }; + metadata.offset[scope.offsetsKey] = scope.offsets; + return metadata; + }; + scope.addOffset = function() { + var result; + result = computedFormula(); + if (result) { + scope.offsets.push(result); + } + return scope.offsetFormula = ""; + }; + scope.removeOffset = function(offsetIndex) { + return scope.offsets.splice(offsetIndex, 1); + }; + scope.addOffsetOnEnter = function(event) { + if (event.keyCode === 13) { + return scope.addOffset(); + } + }; + placeholder = function(inputPeriod) { + var period; + if (scope.textPlaceholder != null) { + return scope.textPlaceholder; + } + period = inputPeriod.charAt(0).toUpperCase() + inputPeriod.slice(1).toLowerCase(); + return period + " adjustment"; + }; + computedFormula = function() { + if (scope.offsetFormula.match(authorized_regex)) { + return eval(scope.offsetFormula); + } + }; + if (w) { + w.settings.push(setting); + } + return scope.deferred.resolve(setting); + } + }; + }]); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets-settings.organizations', []); + + module.controller('SettingOrganizationsCtrl', ["$scope", "$log", "ImpacDashboardsSvc", "ImpacMainSvc", "ImpacWidgetsSvc", function($scope, $log, ImpacDashboardsSvc, ImpacMainSvc, ImpacWidgetsSvc) { + var resetSelectedOrgs, setting, w; + w = $scope.parentWidget; + w.selectedOrganizations = {}; + $scope.mode || ($scope.mode = 'multiple'); + $scope.multiOrgMode = function() { + return $scope.mode === 'multiple'; + }; + $scope.singleOrgMode = function() { + return $scope.mode === 'single'; + }; + resetSelectedOrgs = function() { + return w.selectedOrganizations = _.mapValues(w.selectedOrganizations, function() { + return false; + }); + }; + $scope.isOrganizationSelected = function(orgUid) { + return !!w.selectedOrganizations[orgUid]; + }; + $scope.toggleSelectOrganization = function(orgUid) { + if ($scope.multiOrgMode()) { + w.selectedOrganizations[orgUid] = !w.selectedOrganizations[orgUid]; + if (angular.isDefined($scope.onSelect)) { + return $scope.onSelect({ + orgs: w.selectedOrganizations + }); + } + } else if ($scope.singleOrgMode()) { + resetSelectedOrgs(); + return w.selectedOrganizations[orgUid] = true; + } + }; + setting = {}; + setting.key = "organizations"; + setting.isInitialized = false; + setting.initialize = function() { + return ImpacDashboardsSvc.load().then(function(config) { + var currentDashboard, currentOrganization, forceReload, i, len, org, ref, widgetOrgIds; + currentDashboard = config.currentDashboard; + $scope.dashboardOrganizations = _.sortBy(currentDashboard.data_sources, function(org) { + return org.label.toLowerCase(); + }); + if (!((w.metadata != null) && (w.metadata.organization_ids != null))) { + return; + } + widgetOrgIds = w.metadata.organization_ids; + if ($scope.singleOrgMode()) { + resetSelectedOrgs(); + if (widgetOrgIds.length > 1) { + currentOrganization = ImpacMainSvc.config.currentOrganization; + w.selectedOrganizations[currentOrganization.uid] = true; + forceReload = true; + } else { + w.selectedOrganizations[widgetOrgIds[0]] = true; + } + } else if ($scope.multiOrgMode()) { + ref = $scope.dashboardOrganizations; + for (i = 0, len = ref.length; i < len; i++) { + org = ref[i]; + w.selectedOrganizations[org.uid] = _.contains(widgetOrgIds, org.uid); + } + } + setting.isInitialized = true; + if (forceReload) { + return ImpacWidgetsSvc.updateWidgetSettings(w, true); + } + }); + }; + setting.toMetadata = function() { + var newOrganizations; + newOrganizations = _.compact(_.map(w.selectedOrganizations, function(checked, uid) { + if (checked) { + return uid; + } + })); + if (_.isEmpty(newOrganizations)) { + newOrganizations = [_.first($scope.dashboardOrganizations).uid]; + } + return { + organization_ids: newOrganizations + }; + }; + w.settings.push(setting); + return $scope.deferred.resolve($scope.parentWidget); + }]); + + module.directive('settingOrganizations', ["$templateCache", function($templateCache) { + return { + restrict: 'A', + scope: { + parentWidget: '=', + mode: '@?', + deferred: '=', + onSelect: '&?' + }, + template: $templateCache.get('widgets-settings/organizations.tmpl.html'), + controller: 'SettingOrganizationsCtrl' + }; + }]); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets-settings.param-selector', []); + + module.controller('SettingParamSelectorCtrl', ["$scope", "ImpacWidgetsSvc", function($scope, ImpacWidgetsSvc) { + var setting, w; + $scope.showOptions = false; + $scope.toggleShowOptions = function() { + return $scope.showOptions = !$scope.showOptions; + }; + $scope.onInit = function() { + $scope.selectedOption = {}; + return angular.extend($scope.selectedOption, $scope.selected); + }; + $scope.selectOption = function(anOption) { + if (anOption.value !== $scope.selected.value) { + angular.extend($scope.selected, anOption); + ImpacWidgetsSvc.updateWidgetSettings($scope.parentWidget, !$scope.noReload); + if (angular.isDefined($scope.onSelect)) { + $scope.onSelect(); + } + } + return $scope.toggleShowOptions(); + }; + $scope.getTruncateValue = function() { + return parseInt($scope.truncateNo) || 20; + }; + w = $scope.parentWidget; + setting = {}; + setting.key = "param-selector"; + setting.isInitialized = false; + setting.initialize = function() { + if (w.content != null) { + return setting.isInitialized = true; + } + }; + setting.toMetadata = function() { + var param; + param = {}; + if (!_.isEmpty($scope.selected)) { + param[$scope.param] = $scope.selected.value; + } + return param; + }; + w.settings.push(setting); + return $scope.deferred.resolve($scope.parentWidget); + }]); + + module.directive('settingParamSelector', ["$templateCache", function($templateCache) { + return { + restrict: 'A', + scope: { + parentWidget: '=', + deferred: '=', + param: '@', + options: '=', + selected: '=', + truncateNo: '@', + onSelect: '&' + }, + link: function(scope, elements, attrs) { + scope.noReload = typeof attrs.noReload !== 'undefined'; + return scope.truncateNo = attrs.truncateNo || 20; + }, + template: function(elements, attrs) { + return $templateCache.get(attrs.classic ? 'widgets-settings/param-selector-classic.tmpl.html' : 'widgets-settings/param-selector.tmpl.html'); + }, + controller: 'SettingParamSelectorCtrl' + }; + }]); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets-settings.params-checkboxes', []); + + module.controller('SettingParamsCheckboxesCtrl', ["$scope", function($scope) { + var setting, w; + w = $scope.parentWidget; + setting = {}; + setting.key = "params-checkboxes"; + setting.initialize = function() {}; + setting.toMetadata = function() { + var param; + param = {}; + param[$scope.param] = _.map($scope.options, function(opt) { + return { + id: opt.id, + value: opt.value + }; + }); + return param; + }; + w.settings.push(setting); + return $scope.deferred.resolve($scope.parentWidget); + }]); + + module.directive('settingParamsCheckboxes', ["$templateCache", function($templateCache) { + return { + restrict: 'A', + scope: { + parentWidget: '=', + deferred: '=', + param: '@', + options: '=' + }, + template: $templateCache.get('widgets-settings/params-checkboxes.tmpl.html'), + controller: 'SettingParamsCheckboxesCtrl' + }; + }]); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets-settings.params-picker', []); + + module.controller('SettingParamsPickerCtrl', ["$scope", function($scope) { + var setting, w; + w = $scope.parentWidget; + setting = {}; + setting.key = "params-picker"; + setting.isInitialized = false; + setting.initialize = function() { + $scope.sortableOptions = { + 'ui-floating': true, + tolerance: 'pointer' + }; + $scope.applyToDashboard = w.metadata[$scope.param] && w.metadata[$scope.param].reach === 'dashboard'; + $scope.toggleReach = function() { + return setting.reach = $scope.applyToDashboard ? 'dashboard' : 'widget'; + }; + $scope.toggleReach(); + if (_.isEmpty($scope.options)) { + return setting.isInitialized = true; + } + }; + setting.toMetadata = function() { + var param; + param = {}; + param[$scope.param] = { + values: _.compact(_.map($scope.options, function(statusOption) { + if (statusOption.selected) { + return statusOption.value || statusOption.label; + } + })), + reach: setting.reach + }; + return param; + }; + w.settings.push(setting); + return $scope.deferred.resolve($scope.parentWidget); + }]); + + module.directive('settingParamsPicker', ["$templateCache", "$translate", function($templateCache, $translate) { + return { + restrict: 'A', + scope: { + parentWidget: '=', + deferred: '=', + param: '@', + options: '=', + hasReach: '=', + description: '@' + }, + link: function(scope, elements, attrs) { + var paramText; + paramText = $translate.instant('impac.widget.settings.params-picker.' + scope.param); + scope.formattedParam = _.includes(paramText, 'impac.widget.settings.params-picker') ? scope.param.replace(/_/g, ' ') : paramText; + if (scope.description == null) { + return scope.description = $translate.instant('impac.widget.settings.params-picker.description'); + } + }, + template: $templateCache.get('widgets-settings/params-picker.tmpl.html'), + controller: 'SettingParamsPickerCtrl' + }; + }]); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets-settings.payroll', []); + + module.controller('SettingPayrollCtrl', ["$scope", "ImpacDashboardsSvc", function($scope, ImpacDashboardsSvc) { + var setting, w; + w = $scope.parentWidget; + $scope.togglePayroll = function() { + $scope.selectedPayroll.enabled = !$scope.selectedPayroll.enabled; + if (!$scope.selectedPayroll.enabled) { + return $scope.selectedPayroll.time_logged = false; + } + }; + $scope.toggleTimeSheetModifier = function() { + if ($scope.selectedPayroll.enabled) { + return $scope.selectedPayroll.time_logged = !$scope.selectedPayroll.time_logged; + } + }; + $scope.isTogglePayroll = function() { + if ($scope.selectedPayroll != null) { + return $scope.selectedPayroll.enabled; + } + }; + $scope.isToggleTimeSheetModifier = function() { + if ($scope.selectedPayroll != null) { + return $scope.selectedPayroll.time_logged; + } + }; + setting = {}; + setting.key = "payroll"; + setting.isInitialized = false; + setting.initialize = function() { + return ImpacDashboardsSvc.load().then(function(config) { + var currentDashboard, payroll; + currentDashboard = config.currentDashboard; + $scope.selectedPayroll = { + enabled: false, + time_logged: false + }; + payroll = _.get(w, 'metadata.payroll'); + if (_.isPlainObject(payroll)) { + $scope.selectedPayroll = w.metadata.payroll; + } + return setting.isInitialized = true; + }); + }; + setting.toMetadata = function() { + return { + payroll: $scope.selectedPayroll + }; + }; + w.settings.push(setting); + return $scope.deferred.resolve($scope.parentWidget); + }]); + + module.directive('settingPayroll', ["$templateCache", function($templateCache) { + return { + restrict: 'A', + scope: { + parentWidget: '=', + mode: '@?', + deferred: '=', + onSelect: '&?' + }, + template: $templateCache.get('widgets-settings/payroll.tmpl.html'), + controller: 'SettingPayrollCtrl' + }; + }]); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets-settings.source-selector', []); + + module.directive('settingSourceSelector', ["$templateCache", "$timeout", "ImpacMainSvc", "ImpacUtilities", "ImpacTheming", function($templateCache, $timeout, ImpacMainSvc, ImpacUtilities, ImpacTheming) { + return { + restrict: 'A', + scope: { + parentWidget: '=', + deferred: '=' + }, + template: $templateCache.get('widgets-settings/source-selector.tmpl.html'), + link: function(scope) { + var resetSelectedApps, retrieveAppInstances, setting, updateAppInstances, w; + w = scope.parentWidget; + scope.mode || (scope.mode = 'single'); + scope.singleOrgMode = function() { + return scope.mode === 'single'; + }; + scope.multiOrgMode = function() { + return scope.mode === 'multiple'; + }; + scope.selectedApps = {}; + setting = {}; + setting.key = "source-selector"; + setting.initialize = function() { + return $timeout(function() { + retrieveAppInstances(); + return true; + }); + }; + setting.toMetadata = function() { + var appInstanceId; + appInstanceId = _.compact(_.map(scope.selectedApps, function(checked, uid) { + if (uid === 'prm-records-only') { + return null; + } + if (checked) { + return uid; + } + })); + return { + app_instance_id: appInstanceId + }; + }; + resetSelectedApps = function() { + return scope.selectedApps = _.mapValues(scope.selectedApps, function() { + return false; + }); + }; + updateAppInstances = function(appInstances, primary) { + var valuesPresent; + valuesPresent = _.find(appInstances, function(hash) { + return hash.value === 'prm-records-only'; + }); + if (valuesPresent) { + return appInstances; + } else { + return appInstances.push(primary); + } + }; + retrieveAppInstances = function() { + var appInstances, primary; + appInstances = _.find(w.configOptions.selectors, function(selector) { + return selector.name === 'app_instances'; + }).options; + primary = { + 'value': 'prm-records-only', + 'label': 'Primary Only' + }; + if (appInstances) { + updateAppInstances(appInstances, primary); + } else { + appInstances = [primary]; + } + return scope.organizationApps = appInstances; + }; + scope.isApplicationSelected = function(app_uid) { + return !!scope.selectedApps[app_uid]; + }; + scope.toggleSelectApplication = function(app_uid) { + resetSelectedApps(); + return scope.selectedApps[app_uid] = true; + }; + w.settings.push(setting); + return scope.deferred.resolve(setting); + } + }; + }]); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets-settings.tag-filter', ['ngTagsInput']); + + module.directive('settingTagFilter', ["$templateCache", "$timeout", function($templateCache, $timeout) { + return { + restrict: 'A', + scope: { + parentWidget: '=', + deferred: '=' + }, + template: $templateCache.get('widgets-settings/tag-filter.tmpl.html'), + link: function(scope) { + var asciiParseTag, filterToSettingTags, initiateAutoComplete, loadRules, setting, w; + w = scope.parentWidget; + setting = {}; + setting.key = "tag-filter"; + scope.settingsTags = []; + setting.initialize = function() { + return $timeout(function() { + loadRules(); + initiateAutoComplete(); + return true; + }); + }; + setting.toMetadata = function() { + var filterQuery, filterQueryRules; + filterQueryRules = []; + filterQuery = { + condition: 'OR', + rules: filterQueryRules + }; + angular.forEach(scope.settingsTags, function(settingsTag) { + var filterQueryCondition; + filterQueryCondition = { + condition: 'AND', + rules: [] + }; + angular.forEach(settingsTag.tags, function(filterItem) { + var ruleTag; + ruleTag = asciiParseTag(filterItem, true); + return filterQueryCondition.rules.push(ruleTag); + }); + if (settingsTag.tags.length !== 0) { + return filterQueryRules.push(filterQueryCondition); + } + }); + if (filterQuery.rules.length === 0) { + filterQuery = {}; + } + return { + filter_query: filterQuery + }; + }; + filterToSettingTags = function(filterQuery) { + var settingsTags; + if (_.isEmpty(filterQuery)) { + return; + } + settingsTags = []; + angular.forEach(filterQuery.rules, function(filterQueryRule) { + var settingRule; + settingRule = { + operator: 'OR', + tags: [] + }; + angular.forEach(filterQueryRule.rules, function(rule) { + var ruletag, tagtext; + rule = asciiParseTag(rule); + tagtext = _.compact([rule.name, rule.value]).join(":"); + ruletag = { + value: rule.value, + text: tagtext + }; + if (rule.name != null) { + ruletag.name = rule.name; + } + return settingRule.tags.push(ruletag); + }); + return settingsTags.push(settingRule); + }); + return settingsTags; + }; + loadRules = function() { + if (_.isEmpty(w.metadata.filter_query)) { + return; + } + return scope.settingsTags = filterToSettingTags(w.metadata.filter_query); + }; + initiateAutoComplete = function() { + var autotags, org, tag_hash, tags; + tags = w.content.available_tags || []; + autotags = []; + for (org in tags) { + tag_hash = tags[org]; + angular.forEach(tag_hash.tag_references, function(tag_ref) { + tag_ref = asciiParseTag(tag_ref); + return angular.forEach(tag_ref.tag_reference_values, function(tag) { + var ruletag, tagtext; + tag = asciiParseTag(tag); + tagtext = _.compact([tag_ref.name, tag.value]).join(":"); + ruletag = { + text: tagtext, + value: tag.value + }; + if (tag_ref.name != null) { + ruletag.name = tag_ref.name; + } + return autotags.push(ruletag); + }); + }); + } + return scope.loadTagList = function(query) { + return _.filter(autotags, function(e) { + return e.text.toLowerCase().indexOf(query.toLowerCase()) > -1; + }); + }; + }; + asciiParseTag = function(rule, encode) { + var meth; + if (encode == null) { + encode = false; + } + meth = encode ? encodeURIComponent : decodeURIComponent; + return _.inject(rule, function(res, v, k) { + if (_.isString(v)) { + return (res[k] = meth(v)) && res; + } else { + return (res[k] = v) && res; + } + }, {}); + }; + scope.addRule = function() { + return scope.settingsTags.push({ + 'operator': 'OR', + 'tags': [] + }); + }; + scope.delRule = function(index) { + return scope.settingsTags.splice(index, 1); + }; + w.settings.push(setting); + return scope.deferred.resolve(setting); + } + }; + }]); + +}).call(this); + +(function() { + var module; + + module = angular.module('impac.components.widgets-settings.time-period', []); + + module.directive('settingTimePeriod', ["$templateCache", "$q", "$log", "$timeout", "$filter", "ImpacTheming", "$translate", function($templateCache, $q, $log, $timeout, $filter, ImpacTheming, $translate) { + return { + restrict: 'A', + scope: { + parentWidget: '=', + deferred: '=', + histParams: '=?', + hideChartInterval: '=?', + applyChangesCallback: '&?' + }, + template: $templateCache.get('widgets-settings/time-period.tmpl.html'), + link: function(scope) { + var getPeriod, getSetting, getUsedSettingKey, initPeriod, initUsedSetting, settingsPromises, updateFromDate, updateTimeRangePeriod, w; + w = scope.parentWidget; + scope.timePeriodSetting = { + key: "time-period", + settings: [], + isEditMode: true + }; + scope.timeSliderDeferred = $q.defer(); + scope.datesPickerDeferred = $q.defer(); + scope.timePresetsDeferred = $q.defer(); + settingsPromises = [scope.timeSliderDeferred.promise, scope.datesPickerDeferred.promise, scope.timePresetsDeferred.promise]; + scope.resetPreset = $q.defer(); + $translate(["impac.widget.settings.time_period.period.daily", "impac.widget.settings.time_period.period.weekly", "impac.widget.settings.time_period.period.monthly", "impac.widget.settings.time_period.period.quarterly", "impac.widget.settings.time_period.period.yearly", "impac.widget.settings.time_period.period.days", "impac.widget.settings.time_period.period.weeks", "impac.widget.settings.time_period.period.months", "impac.widget.settings.time_period.period.quarters", "impac.widget.settings.time_period.period.years"]).then(function(translations) { + return scope.periods = [ + { + label: translations["impac.widget.settings.time_period.period.daily"], + plural: "days", + value: "DAILY" + }, { + label: translations["impac.widget.settings.time_period.period.weekly"], + plural: "weeks", + value: "WEEKLY" + }, { + label: translations["impac.widget.settings.time_period.period.monthly"], + plural: "months", + value: "MONTHLY" + }, { + label: translations["impac.widget.settings.time_period.period.quarterly"], + plural: "quarters", + value: "QUARTERLY" + }, { + label: translations["impac.widget.settings.time_period.period.yearly"], + plural: "years", + value: "YEARLY" + } + ]; + }); + scope.maxNumberOfPeriods = 20; + if ((ImpacTheming.get().widgetSettings != null) && (ImpacTheming.get().widgetSettings.timePeriod != null) && !_.isEmpty(ImpacTheming.get().widgetSettings.timePeriod.presets)) { + scope.presets = angular.copy(ImpacTheming.get().widgetSettings.timePeriod.presets); + } + scope.applyPreset = function(histParams) { + initPeriod(histParams); + return initUsedSetting(histParams); + }; + scope.timePeriodSetting.initialize = function() { + return $timeout(function() { + initPeriod(); + getSetting('time-presets').initialize(); + return scope.showApplyButton = angular.isDefined(scope.applyChangesCallback); + }); + }; + scope.timePeriodSetting.toMetadata = function() { + var histParams, metadata, sourceSetting; + sourceSetting = getSetting(getUsedSettingKey()); + if (sourceSetting != null) { + histParams = sourceSetting.toMetadata().hist_parameters; + } + histParams.period = getPeriod(); + if ((scope.histParams != null) && (scope.histParams.mode != null)) { + histParams.mode = scope.histParams.mode; + } + metadata = { + hist_parameters: histParams + }; + return metadata; + }; + scope.titleize = function(word) { + if (word !== "FYEARLY") { + return "" + (word.slice(0, 1).toUpperCase()) + (word.slice(1).toLowerCase()); + } else { + return "Yearly (financial)"; + } + }; + getPeriod = function() { + if (scope.timePeriodSetting.period != null) { + return scope.timePeriodSetting.period; + } else { + return initPeriod(); + } + }; + scope.isTimeSliderUsed = function() { + return getUsedSettingKey() === 'time-slider'; + }; + scope.isDatesPickerUsed = function() { + return getUsedSettingKey() === 'dates-picker'; + }; + getUsedSettingKey = function() { + if (scope.usedSetting != null) { + return scope.usedSetting; + } else { + return initUsedSetting(); + } + }; + getSetting = function(key) { + return _.find(scope.timePeriodSetting.settings, function(set) { + return set.key === key; + }); + }; + initPeriod = function(histParams) { + if (histParams == null) { + histParams = null; + } + if (histParams == null) { + histParams = scope.histParams; + } + if ((histParams != null) && (histParams.period != null) && _.find(scope.periods, function(period) { + return period.value === histParams.period; + })) { + scope.timePeriodSetting.period = angular.copy(histParams.period); + } else { + scope.timePeriodSetting.period = "MONTHLY"; + } + return scope.timePeriodSetting.period; + }; + initUsedSetting = function(histParams) { + var minDate, newLetter, pattern, tr; + if (histParams == null) { + histParams = null; + } + if (histParams == null) { + histParams = scope.histParams; + } + if ((histParams != null) && (histParams.from != null)) { + scope.usedSetting = 'dates-picker'; + scope.toDate = histParams.to; + minDate = scope.getMinDate(scope.toDate); + if (moment(histParams.from, "YYYY-MM-DD").isBefore(minDate)) { + scope.fromDate = minDate; + } else { + scope.fromDate = histParams.from; + } + scope.keepToday = histParams.keep_today; + getSetting('dates-picker').initialize(); + } else { + scope.usedSetting = 'time-slider'; + if ((histParams != null) && (histParams.time_range != null)) { + tr = histParams.time_range; + pattern = /([a-z])/; + newLetter = pattern.exec(tr)[1]; + scope.timePeriodSetting.period = angular.copy(_.find(scope.periods, function(p) { + return p.value.slice(0, 1).toLowerCase() === newLetter; + }).value); + scope.timePeriodSetting.timeRange = tr; + } + getSetting('time-slider').initialize(); + } + return scope.usedSetting; + }; + scope.updateSettings = function() { + if (scope.usedSetting === 'time-slider') { + scope.resetPreset.notify('choose-period'); + } else if (scope.usedSetting === 'dates-picker') { + scope.resetPreset.notify('choose-dates'); + } + updateTimeRangePeriod(); + return updateFromDate(); + }; + updateTimeRangePeriod = function() { + var periodLetter, set, tr; + if (scope.isTimeSliderUsed()) { + set = getSetting('time-slider'); + tr = set.toMetadata().hist_parameters.time_range; + periodLetter = getPeriod().slice(0, 1).toLowerCase(); + scope.timePeriodSetting.timeRange = tr.replace(/[a-z]/, periodLetter); + set.initialize(); + } + return scope.timePeriodSetting.timeRange; + }; + updateFromDate = function() { + var fromDate, minDate, set, toDate; + if (scope.isDatesPickerUsed()) { + set = getSetting('dates-picker'); + fromDate = set.toMetadata().hist_parameters.from; + toDate = set.toMetadata().hist_parameters.to; + minDate = scope.getMinDate(); + if (moment(fromDate, "YYYY-MM-DD").isBefore(minDate)) { + scope.toDate = toDate; + scope.fromDate = minDate; + set.initialize(); + } + } + return scope.fromDate; + }; + scope.useTimeSlider = function() { + scope.usedSetting = 'time-slider'; + return scope.updateSettings(); + }; + scope.useDatesPicker = function() { + scope.usedSetting = 'dates-picker'; + return scope.updateSettings(); + }; + scope.getMinDate = function(toDate) { + var currentPeriod, periodWord, sourceSetting, to; + if (toDate == null) { + toDate = void 0; + } + to = moment(); + if (toDate != null) { + to = moment(toDate, "YYYY-MM-DD"); + } else if ((scope.usedSetting != null) && scope.isDatesPickerUsed()) { + sourceSetting = getSetting('dates-picker'); + to = moment(sourceSetting.toMetadata().hist_parameters.to, "YYYY-MM-DD"); + } + currentPeriod = getPeriod(); + periodWord = _.find(scope.periods, function(period) { + return currentPeriod === period.value; + }).plural; + return to.subtract(scope.maxNumberOfPeriods, periodWord); + }; + scope.formattedMinDate = function(toDate) { + if (toDate == null) { + toDate = void 0; + } + return $filter('momentDate')(scope.getMinDate(toDate), 'time-period'); + }; + w.settings.push(scope.timePeriodSetting); + return $q.all(settingsPromises).then(function() { + return scope.deferred.resolve(scope.timePeriodSetting); + }); } }; - return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetSalesNetSales', function() { - return { - restrict: 'A', - controller: 'WidgetSalesNetSalesCtrl' - }; - }); - }).call(this); (function() { var module; - module = angular.module('impac.components.widgets.sales-new-vs-existing-customers', []); + module = angular.module('impac.components.widgets-settings.time-presets', []); - module.controller('WidgetSalesNewVsExistingCustomersCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "$translate", function($scope, $q, ChartFormatterSvc, $filter, $translate) { - var daysTmpl, hoursTmpl, settingsPromises, w; - w = $scope.widget; - $scope.orgDeferred = $q.defer(); - $scope.timeRangeParamSelectorDeferred = $q.defer(); - $scope.displayTypeParamSelectorDeferred = $q.defer(); - $scope.chartDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.timeRangeParamSelectorDeferred.promise, $scope.displayTypeParamSelectorDeferred.promise, $scope.chartDeferred.promise]; - $scope.displayOptions = [ - { - label: $translate.instant('impac.widget.sales_new_vs_existing.customers'), - value: 'customers_count' - }, { - label: $translate.instant('impac.widget.sales_new_vs_existing.total_sales'), - value: 'total_sales' - }, { - label: $translate.instant('impac.widget.sales_new_vs_existing.transactions'), - value: 'transactions_count' - } - ]; - $scope.displayType = angular.copy(_.find($scope.displayOptions, function(o) { - return w.metadata && (o.value === w.metadata.display_type); - }) || $scope.displayOptions[0]); - hoursTmpl = $translate.instant('impac.widget.sales_new_vs_existing.tmpl.last_hours'); - daysTmpl = $translate.instant('impac.widget.sales_new_vs_existing.tmpl.last_days'); - $scope.timeRangeOptions = [ - { - label: hoursTmpl.replace(':hours:', 24), - value: '-1d' - }, { - label: daysTmpl.replace(':days:', 5), - value: '-5d' - }, { - label: daysTmpl.replace(':days:', 7), - value: '-7d' - }, { - label: daysTmpl.replace(':days:', 30), - value: '-30d' - }, { - label: daysTmpl.replace(':days:', 45), - value: '-45d' - }, { - label: daysTmpl.replace(':days:', 60), - value: '-60d' - }, { - label: daysTmpl.replace(':days:', 90), - value: '-90d' - } - ]; - $scope.timeRange = angular.copy(_.find($scope.timeRangeOptions, function(o) { - return w.metadata && (o.value === w.metadata.time_range); - }) || $scope.timeRangeOptions[6]); - w.initContext = function() { - return $scope.isDataFound = (w.content != null) && (w.content.summary != null) && (w.content.summary.customers_count != null) && (w.content.summary.customers_count.total != null) && w.content.summary.customers_count.total > 0; - }; - $scope.displayTypeOnClick = function() { - $scope.updateSettings(false); - return w.format(); - }; - $scope.getValue = function(key) { - var result, returnType; - if ($scope.isDataFound) { - returnType = $scope.displayType.value; - result = w.content.summary[returnType][key]; - switch (returnType) { - case 'total_sales': - return $filter('mnoCurrency')(result, w.metadata.currency); - default: - return result; + module.directive('settingTimePresets', ["$templateCache", "ImpacMainSvc", "$timeout", "ImpacUtilities", "ImpacTheming", "$translate", function($templateCache, ImpacMainSvc, $timeout, ImpacUtilities, ImpacTheming, $translate) { + return { + restrict: 'A', + scope: { + parentWidget: '=', + deferred: '=', + presets: '=?', + onSelect: '&?', + onChooseDates: '&?', + onChoosePeriod: '&?', + histParams: '=?', + resetPromise: '=?' + }, + template: $templateCache.get('widgets-settings/time-presets.tmpl.html'), + link: function(scope) { + var fyEndMonth, initPreset, showSlider, w; + w = scope.parentWidget; + scope.setting = {}; + scope.setting.key = "time-presets"; + scope.financialYearEndMonth = 6; + fyEndMonth = scope.financialYearEndMonth; + ImpacMainSvc.load().then(function() { + return fyEndMonth = ImpacMainSvc.getFinancialYearEndMonth(); + })["finally"](function() { + var fyStartDate, prevFyEndDate, prevFyStartDate, toDate; + fyStartDate = ImpacUtilities.financialYearDates(fyEndMonth).start; + prevFyStartDate = moment(ImpacUtilities.financialYearDates(fyEndMonth).start, 'YYYY-MM-DD').subtract(1, 'year').format('YYYY-MM-DD'); + prevFyEndDate = moment(ImpacUtilities.financialYearDates(fyEndMonth).end, 'YYYY-MM-DD').subtract(1, 'year').format('YYYY-MM-DD'); + toDate = moment().format('YYYY-MM-DD'); + return $translate(['impac.common.period.preset_in_words.calendar_year_to_date', 'impac.common.period.preset_in_words.financial_year_to_date', 'impac.common.period.preset_in_words.previous_financial_year', 'impac.common.period.preset_in_words.last_6_months', 'impac.common.period.preset_in_words.last_4_quarters', 'impac.common.period.preset_in_words.last_4_weeks', 'impac.common.period.preset_in_words.choose_period', 'impac.common.period.preset_in_words.choose_dates']).then(function(translations) { + scope.presets || (scope.presets = [ + { + label: translations['impac.common.period.preset_in_words.calendar_year_to_date'], + value: { + from: moment().startOf('year').format('YYYY-MM-DD'), + to: toDate, + period: 'MONTHLY' + } + }, { + label: translations['impac.common.period.preset_in_words.financial_year_to_date'], + value: { + from: fyStartDate, + to: toDate, + period: 'MONTHLY' + } + }, { + label: translations['impac.common.period.preset_in_words.previous_financial_year'], + value: { + from: prevFyStartDate, + to: prevFyEndDate, + period: 'MONTHLY' + } + }, { + label: translations['impac.common.period.preset_in_words.last_6_months'], + value: { + time_range: '-6m', + to: toDate + } + }, { + label: translations['impac.common.period.preset_in_words.last_4_quarters'], + value: { + time_range: '-4q', + to: toDate + } + }, { + label: translations['impac.common.period.preset_in_words.last_4_weeks'], + value: { + time_range: '-4w', + to: toDate + } + } + ]); + if (angular.isDefined(scope.onChooseDates) && showSlider()) { + scope.presets.unshift({ + label: translations['impac.common.period.preset_in_words.choose_period'], + value: 'choose-period' + }); + } + if (angular.isDefined(scope.onChooseDates)) { + return scope.presets.unshift({ + label: translations['impac.common.period.preset_in_words.choose_dates'], + value: 'choose-dates' + }); + } + }); + }); + if (scope.resetPromise != null) { + scope.resetPromise.then(null, null, function(key) { + return scope.selectedPreset = _.find(scope.presets, function(p) { + return p.value === key; + }); + }); } - } - }; - $scope.shouldDisplayCurrency = function() { - return $scope.isDataFound && $scope.displayType.value.indexOf('count') < 0; - }; - $scope.calculatePercentage = function(sliceType) { - var values; - values = { - "new": Math.abs(w.content.summary[$scope.displayType.value]["new"]), - existing: Math.abs(w.content.summary[$scope.displayType.value].existing) - }; - values.totals = values["new"] + values.existing; - return Math.round(values[sliceType] / values.totals * 100); - }; - $scope.drawTrigger = $q.defer(); - w.format = function() { - var chartData, pieData, pieOptions; - if ($scope.isDataFound) { - pieData = [ - { - label: "EXISTING " + ($scope.calculatePercentage('existing')) + "%", - value: w.content.summary[$scope.displayType.value].existing - }, { - label: "NEW " + ($scope.calculatePercentage('new')) + "%", - value: w.content.summary[$scope.displayType.value]["new"] + showSlider = function() { + return (ImpacTheming.get().widgetSettings != null) && (ImpacTheming.get().widgetSettings.timePeriod != null) && ImpacTheming.get().widgetSettings.timePeriod.showSlider; + }; + initPreset = function() { + if (scope.histParams != null) { + scope.selectedPreset = _.find(scope.presets, function(p) { + return _.every(p.value, function(v, k) { + return scope.histParams[k] === (angular.isFunction(v) ? v(fyEndMonth) : v); + }); + }); + if ((scope.selectedPreset == null) && (scope.histParams.time_range != null) && showSlider()) { + scope.selectedPreset = scope.presets[1]; + } + } + if (scope.selectedPreset == null) { + return scope.selectedPreset = scope.presets[0]; + } + }; + scope.presetSelected = function() { + if ((scope.selectedPreset != null) && (scope.selectedPreset.value === "choose-dates")) { + return scope.onChooseDates(); + } else if ((scope.selectedPreset != null) && (scope.selectedPreset.value === "choose-period")) { + return scope.onChoosePeriod(); + } else { + return scope.onSelect({ + histParams: scope.setting.toMetadata().hist_parameters + }); + } + }; + scope.setting.initialize = function() { + initPreset(); + scope.presetSelected(); + return true; + }; + scope.setting.toMetadata = function() { + var result; + result = {}; + if (!_.isEmpty(scope.selectedPreset.value)) { + _.forEach(scope.selectedPreset.value, function(value, key) { + if (angular.isFunction(value)) { + return result[key] = value(fyEndMonth); + } else { + return result[key] = value; + } + }); } - ]; - pieOptions = { - percentageInnerCutout: 50, - tooltipFontSize: 12 + return { + hist_parameters: result + }; }; - if (!$scope.shouldDisplayCurrency()) { - angular.merge(pieOptions, { - currency: 'hide' - }); - } - chartData = ChartFormatterSvc.pieChart(pieData, pieOptions, true); - return $scope.drawTrigger.notify(chartData); + w.settings.push(scope.setting); + return scope.deferred.resolve(scope.setting); } }; - return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetSalesNewVsExistingCustomers', function() { - return { - restrict: 'A', - controller: 'WidgetSalesNewVsExistingCustomersCtrl' - }; - }); - }).call(this); (function() { var module; - module = angular.module('impac.components.widgets.sales-number-of-leads', []); + module = angular.module('impac.components.widgets-settings.time-slider', []); - module.controller('WidgetSalesNumberOfLeadsCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "$translate", function($scope, $q, ChartFormatterSvc, $filter, $translate) { - var getVariation, settingsPromises, w; - w = $scope.widget; - $scope.orgDeferred = $q.defer(); - $scope.paramSelectorDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.paramSelectorDeferred.promise]; - w.initContext = function() { - if ($scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.number_of_leads)) { - return $translate(['impac.widget.settings.time_period.period.year', 'impac.widget.settings.time_period.period.quarter', 'impac.widget.settings.time_period.period.month', 'impac.widget.settings.time_period.period.week', 'impac.widget.settings.time_period.period.day']).then(function(translations) { - $scope.periodOptions = [ - { - label: translations['impac.widget.settings.time_period.period.year'], - value: 'YEARLY' - }, { - label: translations['impac.widget.settings.time_period.period.quarter'], - value: 'QUARTERLY' - }, { - label: translations['impac.widget.settings.time_period.period.month'], - value: 'monthly' - }, { - label: translations['impac.widget.settings.time_period.period.week'], - value: 'WEEKLY' - }, { - label: translations['impac.widget.settings.time_period.period.day'], - value: 'DAILY' + module.directive('settingTimeSlider', ["$templateCache", "$timeout", "ImpacMainSvc", "ImpacUtilities", "ImpacTheming", function($templateCache, $timeout, ImpacMainSvc, ImpacUtilities, ImpacTheming) { + return { + restrict: 'A', + scope: { + parentWidget: '=', + deferred: '=', + timeRange: '=?', + onUse: '&?' + }, + template: $templateCache.get('widgets-settings/time-slider.tmpl.html'), + link: function(scope) { + var PERIODS, getNumberOfPeriods, getPeriod, getPeriodWord, getTimeRange, initFinancialYearEndMonth, initNumberOfPeriods, initPeriod, setting, w; + w = scope.parentWidget; + setting = {}; + setting.key = "time-slider"; + PERIODS = ['d', 'w', 'm', 'q', 'y', 'f']; + setting.initialize = function() { + return $timeout(function() { + initNumberOfPeriods(); + initPeriod(); + initFinancialYearEndMonth(); + return true; + }); + }; + setting.toMetadata = function() { + var histParams; + histParams = { + to: scope.toDate().format('YYYY-MM-DD'), + time_range: getTimeRange() + }; + if (getPeriod() === 'f') { + histParams.from = scope.fromDate().format('YYYY-MM-DD'); + } + return { + hist_parameters: histParams + }; + }; + initNumberOfPeriods = function() { + var n, nPattern, tr; + tr = scope.timeRange; + scope.numberOfPeriods = moment().month(); + if (tr == null) { + return scope.numberOfPeriods; + } + nPattern = /^-?([0-9]{1,2})[a-z]?$/; + n = nPattern.exec(tr); + if ((n != null) && n[1] && parseInt(n[1])) { + scope.numberOfPeriods = parseInt(n[1]); + } + return scope.numberOfPeriods; + }; + initPeriod = function() { + var p, pPattern, period, tr; + tr = scope.timeRange; + scope.period = "m"; + if (tr == null) { + return "m"; + } + pPattern = /^-?[0-9]{0,2}([a-z])$/; + p = pPattern.exec(tr); + period = _.find(PERIODS, function(authPeriod) { + return (p != null) && (p[1] === authPeriod); + }); + if (period != null) { + scope.period = period; + } + return scope.period; + }; + initFinancialYearEndMonth = function() { + scope.financialYearEndMonth = 6; + return ImpacMainSvc.load().then(function(config) { + if ((config != null) && (config.currentOrganization != null) && parseInt(config.currentOrganization.financial_year_end_month)) { + return scope.financialYearEndMonth = parseInt(config.currentOrganization.financial_year_end_month); } - ]; - return $scope.period = angular.copy(_.find($scope.periodOptions, function(o) { - return o.value === w.metadata.period; - }) || $scope.periodOptions[3]); - }); - } - }; - w.processError = function(error) { - if (error.code === 404) { - return $scope.isDataFound = false; - } - }; - $scope.formatNumberOfLeads = function(carac) { - var color, formattedNominal, formattedVariation, n_hash, nominal, variation; - formattedNominal = 0; - formattedVariation = "- %"; - if (!$scope.isDataFound) { - return { - nominal: formattedNominal, - variation: formattedVariation, - color: '' + }); }; - } - n_hash = angular.copy(w.content.number_of_leads); - nominal = 0; - color = ''; - if (carac === "new" && n_hash.total && n_hash.total.length === 2) { - nominal = n_hash.total[1] - n_hash.total[0]; - variation = getVariation(n_hash.total); - if (variation > 0) { - color = 'green'; - } else if (variation < 0) { - color = 'red'; - } - } else if (carac === "converted" && n_hash.converted && n_hash.converted.length === 2) { - nominal = n_hash.converted[1]; - variation = getVariation(n_hash.converted); - if (variation > 0) { - color = 'green'; - } else if (variation < 0) { - color = 'red'; - } - } else if (carac === "lost" && n_hash.lost && n_hash.lost.length === 2) { - nominal = n_hash.lost[1]; - variation = getVariation(n_hash.lost); - if (variation < 0) { - color = 'green'; - } else if (variation > 0) { - color = 'red'; - } - } else { - return { - nominal: formattedNominal, - variation: formattedVariation, - color: color + getPeriod = function() { + if (scope.period != null) { + return scope.period; + } else { + return initPeriod(); + } }; - } - if (nominal > 0) { - formattedNominal = "+" + nominal; - } else if (nominal < 0) { - formattedNominal = nominal; - } - if (variation && variation > 0) { - formattedVariation = "+" + (variation.toFixed(0)) + "%"; - } else if (variation && variation < 0) { - formattedVariation = (variation.toFixed(0)) + "%"; - } - return { - nominal: formattedNominal, - variation: formattedVariation, - color: color - }; - }; - getVariation = function(v_array) { - var variation; - if (v_array[0] !== 0) { - return variation = 100 * ((v_array[1] / v_array[0]) - 1); - } else { - return variation = "- "; + getPeriodWord = function() { + return ImpacUtilities.getPeriodWord(getPeriod()); + }; + getNumberOfPeriods = function() { + if (scope.numberOfPeriods != null) { + return scope.numberOfPeriods; + } else { + return initNumberOfPeriods(); + } + }; + getTimeRange = function() { + var n, p; + n = getNumberOfPeriods(); + p = getPeriod(); + return "-" + n + p; + }; + scope.formatPeriod = function() { + return ImpacUtilities.formatPeriod(getNumberOfPeriods(), getPeriod()); + }; + scope.fromDate = function() { + var financialYearStartYear, n, word; + n = getNumberOfPeriods(); + word = getPeriodWord(); + if (word.slice(0, 1) === "f") { + financialYearStartYear = moment().year() - 1; + if (moment().month() >= 6) { + financialYearStartYear = moment().year(); + } + financialYearStartYear = financialYearStartYear - n; + return moment(financialYearStartYear + "-" + (scope.financialYearEndMonth + 1) + "-01", "YYYY-M-DD"); + } else if (word.slice(0, 1) === "w") { + return moment().subtract(n, word).startOf('isoweek'); + } else { + return moment().subtract(n, word).startOf(word); + } + }; + scope.toDate = function() { + return moment(); + }; + w.settings.push(setting); + return scope.deferred.resolve(setting); } }; - return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetSalesNumberOfLeads', function() { - return { - restrict: 'A', - controller: 'WidgetSalesNumberOfLeadsCtrl' - }; - }); - }).call(this); (function() { - var module, - indexOf = [].indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; }; + var module; - module = angular.module('impac.components.widgets.sales-opportunities-funnel', []); + module = angular.module('impac.components.widgets-settings.width', []); - module.controller('WidgetSalesOpportunitiesFunnelCtrl', ["$scope", "$q", "ChartFormatterSvc", "$filter", "ImpacWidgetsSvc", "ImpacDashboardsSvc", function($scope, $q, ChartFormatterSvc, $filter, ImpacWidgetsSvc, ImpacDashboardsSvc) { - var getFilteredTotal, getOrderedAssigneeIds, hasOneOpportunity, selectedStatusSetting, settingsPromises, sortData, sortOppsBy, w; - w = $scope.widget; - $scope.selectedOpportunities = []; - $scope.collapsed = []; - $scope.orgDeferred = $q.defer(); - $scope.paramsPickerDeferred1 = $q.defer(); - $scope.paramsPickerDeferred2 = $q.defer(); - $scope.widthDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.paramsPickerDeferred1.promise, $scope.paramsPickerDeferred2.promise, $scope.widthDeferred.promise]; - $scope.ascending = true; - $scope.sortedColumn = 'group'; - hasOneOpportunity = function(oppsPerSalesStage) { - var reducedHash, total, totalsArray; - reducedHash = _.mapValues(oppsPerSalesStage, function(statusHash) { - return statusHash.total; - }); - totalsArray = _.compact(_.values(reducedHash)); - total = _.reduce(totalsArray, function(total, n) { - if (total == null) { - total = 0; - } - return total + n; - }); - return (total != null) && total > 0; - }; - getFilteredTotal = function(opps, assignees) { - return _.reduce(opps, function(total, opp) { - var ref; - if (total == null) { - total = 0; - } - if (ref = opp.assignee_id, indexOf.call(assignees, ref) >= 0) { - return total + 1; - } else { - return total; - } - }, 0); - }; - getOrderedAssigneeIds = function(assigneesOptions) { - return _.map(_.filter(assigneesOptions, function(assigneeOption) { - return assigneeOption.selected; - }), 'value'); - }; - w.initContext = function() { - var assignees_selection, dhb, sales_stage_selection; - dhb = ImpacDashboardsSvc.getCurrentDashboard(); - sales_stage_selection = w.metadata.sales_stage_selection || dhb.metadata.sales_stage_selection || { - values: [] - }; - assignees_selection = w.metadata.assignees_selection || dhb.metadata.assignees_selection || { - values: [] - }; - if ($scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.opps_per_sales_stage) && hasOneOpportunity(w.content.opps_per_sales_stage)) { - _.remove(sales_stage_selection.values, function(status) { - return indexOf.call(_.keys(w.content.opps_per_sales_stage), status) < 0; - }); - $scope.hasReach = true; - $scope.statusOptions = []; - angular.forEach(w.content.opps_per_sales_stage, function(value, status) { - var isSelected; - isSelected = _.isEmpty(sales_stage_selection.values) || (indexOf.call(sales_stage_selection.values, status) >= 0); - return $scope.statusOptions.push({ - label: status, - selected: isSelected - }); - }); - if ($scope.statusOptions[0] && !_.any($scope.statusOptions, 'selected') && !_.isEmpty(w.content.opps_per_sales_stage)) { - $scope.statusOptions[0].selected = true; - } - $scope.assigneesOptions = []; - angular.forEach(w.content.assignees, function(obj, index) { - var isSelected, ref; - isSelected = _.isEmpty(assignees_selection.values) || (ref = obj.id, indexOf.call(assignees_selection.values, ref) >= 0); - return $scope.assigneesOptions.push({ - label: obj.name, - selected: isSelected, - value: obj.id - }); - }); - if ($scope.assigneesOptions[0] && !_.any($scope.assigneesOptions, 'selected') && !_.isEmpty(w.content.assignees)) { - return $scope.assigneesOptions[0].selected = true; - } - } - }; - w.processError = function(error) { - if (error.code === 404) { - return $scope.isDataFound = false; - } - }; - $scope.getImpacColor = function(index) { - return ChartFormatterSvc.getColor(index); - }; - $scope.toggleSelectStatus = function(aStatus) { - if ($scope.selectedStatus && $scope.selectedStatus === aStatus) { - $scope.selectedStatus = null; - } else { - $scope.selectedStatus = aStatus; - } - $scope.updateRightView(); - if (!w.isExpanded() && $scope.selectedStatus) { - return w.toggleExpanded(); - } else { - return ImpacWidgetsSvc.updateWidgetSettings(w, false, true); - } - }; - $scope.isSelected = function(aStatus) { - return $scope.selectedStatus && aStatus === $scope.selectedStatus; - }; - $scope.toggleCollapsed = function(element) { - if ((element != null) && (element.assigneeName != null)) { - if (_.find($scope.collapsed, (function(name) { - return element.assigneeName === name; - }))) { - return $scope.collapsed = _.reject($scope.collapsed, function(name) { - return name === element.assigneeName; - }); - } else { - return $scope.collapsed.push(element.assigneeName); - } - } - }; - $scope.isCollapsed = function(element) { - if ((element != null) && (element.assigneeName != null)) { - if (_.find($scope.collapsed, (function(name) { - return element.assigneeName === name; - }))) { - return true; - } else { - return false; - } - } - }; - $scope.getSelectedOpportunities = function() { - var assignees, filteredOpps, oppGroups, sortedOppGroups; - if ($scope.isDataFound && $scope.selectedStatus && w.content.opps_per_sales_stage[$scope.selectedStatus]) { - assignees = getOrderedAssigneeIds($scope.assigneesOptions); - filteredOpps = _.filter(w.content.opps_per_sales_stage[$scope.selectedStatus].opps, function(opportunity) { - var ref; - return ref = opportunity.assignee_id, indexOf.call(assignees, ref) >= 0; - }); - oppGroups = _.groupBy(filteredOpps, 'assignee_id'); - sortedOppGroups = []; - angular.forEach($scope.assigneesOptions, function(assigneeOption) { - var assigneeId; - assigneeId = assigneeOption.value; - if (oppGroups[assigneeId]) { - return sortedOppGroups.push({ - assigneeName: assigneeOption.label, - opps: oppGroups[assigneeId] - }); - } - }); - return sortedOppGroups; - } else { - return []; - } - }; - $scope.getOppDetails = function(anOpp) { - var oppDetails; - oppDetails = []; - if (anOpp.amount) { - oppDetails.push($filter('mnoCurrency')(anOpp.amount.amount, anOpp.amount.currency || 'AUD')); - } - if (anOpp.probability) { - oppDetails.push("prob. " + anOpp.probability + "%"); + module.controller('SettingWidthCtrl', ["$scope", "$element", "$timeout", "$log", "ImpacWidgetsSvc", "ImpacDashboardsSvc", function($scope, $element, $timeout, $log, ImpacWidgetsSvc, ImpacDashboardsSvc) { + var elem, hideOnResize, i, len, ref, setting, w; + w = $scope.parentWidget; + setting = {}; + setting.key = "width"; + setting.isInitialized = false; + ref = $element.parents(); + for (i = 0, len = ref.length; i < len; i++) { + elem = ref[i]; + if (angular.element(elem).hasClass('content')) { + $scope.contentElements = angular.element(elem).children(); + break; } - return oppDetails.join(' / '); - }; - $scope.getTotal = function(oppsGroup) { - var currency, total; - if (!(oppsGroup.length > 0)) { - return ""; + } + hideOnResize = function(elements) { + var j, len1; + if (!(elements && elements.length > 0)) { + return; } - total = _.sum(oppsGroup, function(o) { - var amount, proba; - amount = o.amount.amount || 0.0; - proba = o.probability || 0.0; - return amount * (proba / 100); - }); - currency = oppsGroup[0].amount.currency || 'AUD'; - return $filter('mnoCurrency')(total, currency); - }; - sortOppsBy = function(getElem) { - return angular.forEach($scope.selectedOpportunities, function(sElem) { - if (sElem.opps) { - return sElem.opps.sort(function(a, b) { - var res; - res = getElem(a) > getElem(b) ? 1 : getElem(a) < getElem(b) ? -1 : 0; - if (!$scope.ascending) { - res *= -1; - } - return res; - }); - } - }); - }; - sortData = function() { - if ($scope.sortedColumn === 'group') { - return sortOppsBy(function(el) { - return el.name; - }); - } else if ($scope.sortedColumn === 'total') { - return sortOppsBy(function(el) { - return el.amount.amount; - }); + for (j = 0, len1 = elements.length; j < len1; j++) { + elem = elements[j]; + angular.element(elem).animate({ + opacity: 0 + }, 0); } + return $timeout(function() { + var k, len2, results; + results = []; + for (k = 0, len2 = elements.length; k < len2; k++) { + elem = elements[k]; + results.push(angular.element(elem).animate({ + opacity: 1 + }, 200)); + } + return results; + }, 300); }; - $scope.sort = function(col) { - if ($scope.sortedColumn === col) { - $scope.ascending = !$scope.ascending; + w.toggleExpanded = function(save) { + if (save == null) { + save = true; + } + $scope.expanded = !$scope.expanded; + if (save) { + ImpacWidgetsSvc.updateWidgetSettings(w, false, true); + } + hideOnResize($scope.contentElements); + if ($scope.expanded) { + return w.width = parseInt($scope.max); } else { - $scope.ascending = true; - $scope.sortedColumn = col; + return w.width = parseInt($scope.min); } - return sortData(); }; - $scope.updateRightView = function() { - $scope.selectedOpportunities = $scope.getSelectedOpportunities(); - $scope.collapsed = []; - return sortData(); + w.isExpanded = function() { + return $scope.expanded; }; - selectedStatusSetting = {}; - selectedStatusSetting.initialized = false; - selectedStatusSetting.initialize = function() { - if (!_.isEmpty(w.content) && angular.isDefined(w.content.opps_per_sales_stage[w.metadata.selected_status])) { - $scope.selectedStatus = w.metadata.selected_status; + setting.initialize = function() { + if (w.width != null) { + $scope.expanded = w.width === parseInt($scope.max); + return setting.isInitialized = true; } - selectedStatusSetting.initialized = true; - return $scope.updateRightView(); }; - selectedStatusSetting.toMetadata = function() { + setting.toMetadata = function() { + var newWidth; + if ($scope.expanded) { + newWidth = $scope.max; + } else { + newWidth = $scope.min; + } return { - selected_status: $scope.selectedStatus + width: parseInt(newWidth) }; }; - w.settings.push(selectedStatusSetting); - w.format = function() { - var assignees, max; - if ($scope.isDataFound) { - max = 0; - assignees = getOrderedAssigneeIds($scope.assigneesOptions); - angular.forEach($scope.statusOptions, function(statusOption) { - var value; - value = getFilteredTotal(w.content.opps_per_sales_stage[statusOption.label].opps, assignees); - if (statusOption.selected && angular.isDefined(value) && value > max) { - return max = value; - } - }); - if (max > 0) { - return $scope.funnel = _.compact(_.map($scope.statusOptions, function(statusOption, index) { - var coloredWidth, statusWidth, value; - value = getFilteredTotal(w.content.opps_per_sales_stage[statusOption.label].opps, assignees); - coloredWidth = (100 * (value / max) - 10).toFixed(); - if (coloredWidth < 8) { - statusWidth = 92; - } else { - statusWidth = 100 - coloredWidth; - } - if (statusOption.selected && angular.isDefined(value) && value > 0) { - return { - status: statusOption.label, - number: value, - coloredWidth: { - width: coloredWidth + "%" - }, - statusWidth: { - width: statusWidth + "%" - } - }; - } - })); - } else { - return $scope.isDataFound = false; - } + ImpacDashboardsSvc.pdfModeEnabled().then(null, null, function() { + $scope.pdfMode = true; + $scope.initiallyExpanded = !!$scope.expanded; + if (!$scope.initiallyExpanded) { + return w.toggleExpanded(false); } - }; - return $scope.widgetDeferred.resolve(settingsPromises); + }); + ImpacDashboardsSvc.pdfModeCanceled().then(null, null, function() { + $scope.pdfMode = false; + if (!$scope.initiallyExpanded) { + return w.toggleExpanded(false); + } + }); + w.settings.push(setting); + return $scope.deferred.resolve($scope.parentWidget); }]); - module.directive('widgetSalesOpportunitiesFunnel', function() { + module.directive('settingWidth', ["$templateCache", function($templateCache) { return { restrict: 'A', - controller: 'WidgetSalesOpportunitiesFunnelCtrl' + scope: { + parentWidget: '=', + deferred: '=', + min: '@', + max: '@' + }, + template: $templateCache.get('widgets-settings/width.tmpl.html'), + controller: 'SettingWidthCtrl' }; - }); + }]); }).call(this); (function() { - var module, - indexOf = [].indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; }; + var module; - module = angular.module('impac.components.widgets.sales-performance', []); + module = angular.module('impac.components.widgets-layouts.accounts-cash-projection', []); - module.controller('WidgetSalesPerformanceCtrl', ["$scope", "$q", "$filter", "ChartFormatterSvc", "ImpacWidgetsSvc", function($scope, $q, $filter, ChartFormatterSvc, ImpacWidgetsSvc) { - var formatDate, getIdentifier, matchElementToSelectedElement, selectedElementsSetting, settingsPromises, w; + module.controller('WidgetAccountsCashProjectionCtrl', ["$scope", "$q", "$filter", "$timeout", "ImpacKpisSvc", "ImpacWidgetsSvc", "ImpacAssets", "HighchartsFactory", "BoltResources", "ImpacMainSvc", function($scope, $q, $filter, $timeout, ImpacKpisSvc, ImpacWidgetsSvc, ImpacAssets, HighchartsFactory, BoltResources, ImpacMainSvc) { + var createUser, dateFilter, extractEntityName, extractTrend, fetchUser, imgSrc, imgTemplate, legendFormatter, loadContacts, loadTrendsGroups, onClickBar, onClickLegend, onZoom, settingsPromises, todayUTC, updateLocked, w, zoomMetadata; w = $scope.widget; + todayUTC = moment().startOf('day').add(moment().utcOffset(), 'minutes'); + updateLocked = false; + zoomMetadata = {}; + w.metadata.ranges = ['-60d', '-30d']; + dateFilter = function(timestamp) { + var pickedDate; + pickedDate = moment.utc(timestamp); + if (pickedDate <= todayUTC) { + return "lte " + (pickedDate.format('YYYY-MM-DD')); + } else { + return pickedDate.format('YYYY-MM-DD'); + } + }; + imgSrc = function(name) { + return ImpacAssets.get(_.camelCase(name + 'LegendIcon')); + }; + imgTemplate = function(src, name) { + return "
" + name; + }; + extractEntityName = function(id, entities, type) { + var entity; + entity = _.find(entities, function(c) { + return c.id === id && (c.type = type); + }); + return entity.attributes.name; + }; + extractTrend = function(id, entities) { + var account_name, trend; + trend = _.find(entities, function(c) { + return c.id === id && c.type === 'trends'; + }); + if (trend.relationships && trend.relationships.account && trend.relationships.account.data) { + account_name = extractEntityName(trend.relationships.account.data.id, entities, 'accounts'); + } + return angular.merge(trend.attributes, { + id: id, + account_name: account_name || null + }); + }; + $scope.chartId = function() { + return "cashProjectionChart-" + w.id; + }; $scope.orgDeferred = $q.defer(); - $scope.paramsWinsPickerDeferred = $q.defer(); - $scope.paramsLostsPickerDeferred = $q.defer(); - $scope.timePeriodDeferred = $q.defer(); - $scope.widthDeferred = $q.defer(); - $scope.chartDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.paramsWinsPickerDeferred, $scope.paramsLostsPickerDeferred, $scope.timePeriodDeferred, $scope.widthDeferred.promise, $scope.chartDeferred.promise]; - w.initContext = function() { - var foundElem, i, len, ref, sElemId; - $scope.isDataFound = angular.isDefined(w.content) && !_.isEmpty(w.content.assignees); - if ($scope.isDataFound) { - if (!_.isEmpty(w.metadata.selectedElements)) { - $scope.selectedElements = []; - ref = w.metadata.selectedElements; - for (i = 0, len = ref.length; i < len; i++) { - sElemId = ref[i]; - foundElem = _.find(w.content.assignees, function(assignee) { - return getIdentifier(assignee) === sElemId; + $scope.sourceDeferred = $q.defer(); + settingsPromises = [$scope.orgDeferred.promise, $scope.sourceDeferred.promise]; + $scope.trxList = { + display: false, + updated: false, + transactions: [] + }; + $scope.sourceSelector = { + display: false + }; + $scope.contacts = []; + $scope.accounts = []; + $scope.trxList.show = function() { + return $scope.trxList.display = true; + }; + $scope.trxList.hide = function() { + $scope.trxList.display = false; + if ($scope.trxList.updated) { + return ImpacWidgetsSvc.show(w).then(function() { + return $scope.trxList.updated = false; + }); + } + }; + $scope.trxList.fetch = function(currentPage) { + var params; + if (currentPage == null) { + currentPage = 1; + } + params = angular.merge($scope.trxList.params, { + metadata: _.pick(w.metadata, 'organization_ids'), + page: { + number: currentPage + }, + sort: '-expected_payment_date', + currency: w.metadata.currency + }); + return BoltResources.index(w.metadata.bolt_path, $scope.trxList.resources, params).then(function(response) { + var contact, contactName, i, len, ref, trx; + _.remove($scope.trxList.transactions, function() { + return true; + }); + ref = response.data.data; + for (i = 0, len = ref.length; i < len; i++) { + trx = ref[i]; + contactName = ''; + if (trx.relationships && trx.relationships.contact && trx.relationships.contact.data) { + contact = _.find(response.data.included, function(includedContact) { + return includedContact.id === trx.relationships.contact.data.id; }); - if (foundElem) { - $scope.selectedElements.push(foundElem); + if (contact != null) { + contact.name = contactName = contact.attributes.name; } } + $scope.trxList.transactions.push(angular.merge(trx.attributes, { + id: trx.id, + contact: contact, + contact_name: contactName + })); } - $scope.hasReach = true; - $scope.closedWonOptions = _.compact(_.map(w.content.sales_stages.won, function(stage) { - return { - label: stage, - selected: true - }; - })); - angular.forEach(w.content.sales_stages.all, function(stage) { - if (!(indexOf.call(w.content.sales_stages.won, stage) >= 0)) { - return $scope.closedWonOptions.push({ - label: stage, - selected: false - }); - } - }); - $scope.closedLostOptions = _.compact(_.map(w.content.sales_stages.lost, function(stage) { - return { - label: stage, - selected: true - }; - })); - return angular.forEach(w.content.sales_stages.all, function(stage) { - if (!(indexOf.call(w.content.sales_stages.lost, stage) >= 0)) { - return $scope.closedLostOptions.push({ - label: stage, - selected: false - }); - } - }); - } + return $scope.trxList.totalRecords = response.data.meta.record_count; + })["finally"](function() { + return $scope.trxList.show(); + }); + }; + $scope.trxList.updateParams = function(resources, filter) { + $scope.trxList.resources = resources; + return $scope.trxList.params = { + include: 'contact', + fields: { + contacts: 'name' + }, + filter: filter + }; }; - w.processError = function(error) { - if (error.code === 404) { - return $scope.isDataFound = false; + $scope.trxList.showAll = function(resources) { + var appUid, filter; + if (resources == null) { + resources = 'invoices'; } + if ($scope.widget.metadata.app_instance_id) { + appUid = $scope.widget.metadata.app_instance_id[0]; + } + filter = { + status: ['AUTHORISED', 'APPROVED', 'SUBMITTED', 'FORECAST'], + reconciliation_status: 'UNRECONCILED', + 'app_instance.id': appUid + }; + $scope.trxList.updateParams(resources, filter); + return $scope.trxList.fetch(); }; - $scope.getChartTitle = function(el) { - if ($scope.selectedElements) { - return $scope.selectedElements.map(function(el) { - return el.name; - }).join(', '); + $scope.trxList.changeQuery = function(query) { + $scope.trxList.params.filter.query_data = query; + return $scope.trxList.fetch(); + }; + $scope.trxList.updateExpectedDate = function(trxId, date) { + return BoltResources.update(w.metadata.bolt_path, $scope.trxList.resources, trxId, { + expected_payment_date: moment(date).format('YYYY-MM-DD') + }).then(function() { + return $scope.trxList.updated = true; + }); + }; + $scope.trxList.changeResourcesType = function(resourcesType) { + if (resourcesType === $scope.trxList.resources) { + return; } + $scope.trxList.resources = resourcesType; + return $scope.trxList.fetch(); }; - $scope.getTotalWon = function(el) { - if ($scope.selectedElements) { - return $scope.selectedElements.reduce((function(t, e) { - return t + e.total_won; - }), 0); - } else { - return 0; + $scope.trxList.deleteTransaction = function(resourcesType, trxId) { + return BoltResources.destroy(w.metadata.bolt_path, resourcesType, trxId).then(function() { + return $scope.trxList.updated = true; + }); + }; + $scope.trxList.updateSchedulableTransactions = function(resourcesType, trx) { + return $scope.trxList.updated = true; + }; + $scope.trxList.deleteChildrenTransactions = function(resourcesType, trxId) { + return BoltResources.update(w.metadata.bolt_path, resourcesType, trxId, { + recurring: false + }).then(function() { + return $scope.trxList.updated = true; + }); + }; + $scope.trendList = { + display: false, + updated: false, + trends: [], + params: { + include: 'trends,trends.account' } }; - formatDate = function(date) { - var period; - period = (w.metadata != null) && (w.metadata.hist_parameters != null) ? w.metadata.hist_parameters.period : null; - return $filter('momentDate')(date, period); + $scope.trendList.show = function() { + return $scope.trendList.display = true; }; - $scope.getCloseDate = function(anOpp) { - var theDate; - if ((anOpp != null) && (anOpp.sales_stage_changes != null) && anOpp.sales_stage_changes.length > 0) { - theDate = anOpp.sales_stage_changes[anOpp.sales_stage_changes.length - 1].updated_at; - if (theDate.split(' ').length > 0) { - theDate = theDate.split(' ')[0]; - return formatDate(theDate); - } + $scope.trendList.hide = function() { + $scope.trendList.display = false; + if ($scope.trendList.updated) { + return ImpacWidgetsSvc.show(w).then(function() { + return $scope.trendList.updated = false; + }); } }; - $scope.getForecastCloseDate = function(anOpp) { - var theDate; - if ((anOpp != null) && anOpp.expected_close_date) { - theDate = anOpp.expected_close_date; - if (theDate.split(' ').length > 0) { - theDate = theDate.split(' ')[0]; - return formatDate(theDate); + $scope.trendList.fetch = function(currentPage) { + var params; + if (currentPage == null) { + currentPage = 1; + } + params = angular.merge($scope.trendList.params, { + metadata: _.pick(w.metadata, 'organization_ids'), + page: { + number: currentPage + } + }); + return BoltResources.index(w.metadata.bolt_path, 'trends_groups', params).then(function(response) { + var group, i, j, len, len1, ref, ref1, trend, trends; + _.remove($scope.trendList.trends, function() { + return true; + }); + ref = response.data.data; + for (i = 0, len = ref.length; i < len; i++) { + group = ref[i]; + trends = []; + if (group.relationships && group.relationships.trends && group.relationships.trends.data) { + ref1 = group.relationships.trends.data; + for (j = 0, len1 = ref1.length; j < len1; j++) { + trend = ref1[j]; + trends.push(extractTrend(trend.id, response.data.included)); + } + } + $scope.trendList.trends.push(angular.merge(group.attributes, { + id: group.id, + trends: trends + })); } + return $scope.trendList.totalRecords = response.data.meta.record_count; + })["finally"](function() { + return $scope.trendList.show(); + }); + }; + $scope.trendList.showAll = function() { + return $scope.trendList.fetch(); + }; + $scope.trendList.updateTrend = function(trend) { + return BoltResources.update(w.metadata.bolt_path, 'trends', trend.id, _.omit(trend, 'id', 'account_name')).then(function() { + return $scope.trendList.updated = true; + }); + }; + $scope.trendList["delete"] = function(entityId, resource) { + return BoltResources.destroy(w.metadata.bolt_path, resource, entityId).then(function() { + return $scope.trendList.updated = true; + }); + }; + $scope.accountsAverageBalances = function(widget) { + return _.find(widget.configOptions.selectors, function(selector) { + return selector.name === 'accounts_average_balance'; + }).options; + }; + $scope.chartDeferred = $q.defer(); + $scope.chartPromise = $scope.chartDeferred.promise; + $scope.addForecastPopup = { + resourcesType: 'invoices', + display: false, + hide: function() { + return this.display = false; + }, + show: function() { + return this.display = true; } }; - $scope.getElementChartColor = function(index) { - return ChartFormatterSvc.getColor(index); + $scope.addForecastPopup.createTransaction = function(trx, resourcesType) { + return BoltResources.create(w.metadata.bolt_path, resourcesType, { + title: trx.title, + transaction_number: "FOR-" + (Math.ceil(Math.random() * 10000)), + amount: trx.amount, + balance: trx.amount, + transaction_date: moment().format('YYYY-MM-DD'), + due_date: moment(trx.datePicker.date).format('YYYY-MM-DD'), + status: 'FORECAST', + recurring: trx.recurring, + recurring_pattern: trx.recurring_pattern, + recurring_end_date: trx.recurring_end_date ? moment(trx.recurring_end_date).format('YYYY-MM-DD') : null, + reconciliation_status: 'UNRECONCILED', + currency: w.metadata.currency + }, { + company: { + data: { + type: 'companies', + id: $scope.firstCompanyId + } + }, + contact: { + data: { + type: 'contacts', + id: trx.contact.id + } + } + }).then(function() { + return ImpacWidgetsSvc.show(w); + }); }; - $scope.no_sales_stages_selected = function() { - return w.content && w.content.sales_stages && w.content.sales_stages.won.length === 0 && w.content.sales_stages.lost.length === 0; + $scope.dupTrxList = { + display: false, + updated: false, + transactions: [] }; - $scope.toggleSelectedElement = function(element) { - var selectedElement; - if ($scope.isSelected(element)) { - $scope.selectedElements = _.reject($scope.selectedElements, function(sElem) { - return matchElementToSelectedElement(element, sElem); + $scope.dupTrxList.show = function() { + return $scope.dupTrxList.display = true; + }; + $scope.dupTrxList.hide = function() { + $scope.dupTrxList.display = false; + if ($scope.dupTrxList.updated) { + return ImpacWidgetsSvc.show(w).then(function() { + return $scope.dupTrxList.updated = false; }); - w.format(); - if (w.isExpanded() && $scope.selectedElements.length === 0) { - return w.toggleExpanded(); - } else { - return ImpacWidgetsSvc.updateWidgetSettings(w, false, true); + } + }; + $scope.dupTrxList.fetch = function(currentPage) { + var params; + if (currentPage == null) { + currentPage = 1; + } + params = angular.merge($scope.dupTrxList.params, { + metadata: _.pick(w.metadata, 'organization_ids'), + page: { + number: currentPage } - } else { - selectedElement = angular.copy(element); - $scope.selectedElements || ($scope.selectedElements = []); - $scope.selectedElements.push(selectedElement); - w.format(); - if (!w.isExpanded()) { - return w.toggleExpanded(); - } else { - return ImpacWidgetsSvc.updateWidgetSettings(w, false, true); + }); + return BoltResources.index(w.metadata.bolt_path, $scope.dupTrxList.resources, params).then(function(response) { + var i, len, ref, trx; + _.remove($scope.dupTrxList.transactions, function() { + return true; + }); + ref = response.data.data; + for (i = 0, len = ref.length; i < len; i++) { + trx = ref[i]; + $scope.dupTrxList.transactions.push(angular.merge(trx.attributes, { + id: trx.id + })); } + return $scope.dupTrxList.totalRecords = response.data.meta.record_count; + })["finally"](function() { + return $scope.dupTrxList.show(); + }); + }; + $scope.dupTrxList.updateParams = function(resources, filter) { + $scope.dupTrxList.resources = resources; + return $scope.dupTrxList.params = { + filter: filter + }; + }; + $scope.dupTrxList.showAll = function(resources) { + var filter; + if (resources == null) { + resources = 'invoices'; } + filter = { + status: ['FORECAST'], + reconciliation_status: 'RECONCILING' + }; + if (w.metadata.app_instance_id) { + filter['app_instance.id'] = w.metadata.app_instance_id[0]; + } + $scope.dupTrxList.updateParams(resources, filter); + return $scope.dupTrxList.fetch(); }; - $scope.isSelected = function(element) { - return (element != null) && _.any($scope.selectedElements, function(sElem) { - return matchElementToSelectedElement(element, sElem); + $scope.dupTrxList.updateDuplicateTransaction = function(dupTrxId, action) { + _.remove($scope.dupTrxList.transactions, function(dupTrx) { + return dupTrx.id === dupTrxId; + }); + return BoltResources.patch(w.metadata.bolt_path, $scope.dupTrxList.resources, dupTrxId, action).then(function() { + return $scope.dupTrxList.updated = true; }); }; - $scope.hasElements = function() { - return ($scope.selectedElements != null) && $scope.selectedElements.length > 0; - }; - $scope.getSelectLineColor = function(element) { - var sElem; - sElem = _.find($scope.selectedElements, function(sElem) { - return matchElementToSelectedElement(element, sElem); - }); - if ($scope.hasElements()) { - return ChartFormatterSvc.getColor(_.indexOf($scope.selectedElements, sElem)); + $scope.dupTrxList.changeResourcesType = function(resourcesType) { + if (resourcesType === $scope.dupTrxList.resources) { + return; } + $scope.dupTrxList.resources = resourcesType; + return $scope.dupTrxList.fetch(); }; - matchElementToSelectedElement = function(element, sElem) { - return getIdentifier(element) === getIdentifier(sElem); - }; - getIdentifier = function(element) { - return element.id || element.name; + $scope.addTrendPopup = { + display: false, + show: function() { + return this.display = true; + }, + hide: function() { + return this.display = false; + } }; - $scope.drawTrigger = $q.defer(); - w.format = function() { - var all_values_are_positive, chartData, inputData, options; - if ($scope.isDataFound && ($scope.selectedElements != null) && $scope.selectedElements.length > 0) { - inputData = []; - all_values_are_positive = true; - angular.forEach($scope.selectedElements, function(sElem) { - var data, dates, period; - data = angular.copy(sElem); - period = null; - if ((w.metadata != null) && (w.metadata.hist_parameters != null)) { - period = w.metadata.hist_parameters.period; + $scope.addTrendPopup.createTrend = function(trend) { + var relations; + relations = { + user: { + data: { + type: 'users', + id: $scope.userId + } + }, + trends_group: { + data: { + type: 'trends_groups', + id: trend.trends_group_id + } + } + }; + if (trend.account_id) { + relations['account'] = { + data: { + type: 'accounts', + id: trend.account_id } - dates = _.map(w.content.dates, function(date) { - return $filter('momentDate')(date, period); - }); - inputData.push({ - title: data.name, - labels: dates, - values: data.totals - }); - return angular.forEach(data.totals, function(value) { - return all_values_are_positive && (all_values_are_positive = value >= 0); - }); - }); - options = { - scaleBeginAtZero: all_values_are_positive, - showXLabels: true, - datasetFill: $scope.selectedElements.length === 1, - pointDot: $scope.selectedElements.length === 1 }; - chartData = ChartFormatterSvc.lineChart(inputData, options); - return $scope.drawTrigger.notify(chartData); } + return BoltResources.create(w.metadata.bolt_path, 'trends', { + name: trend.name, + rate: trend.rate, + period: trend.period, + start_date: trend.startDate, + last_apply_date: trend.untilDate, + description: trend.description, + account_class: trend.account_class + }, relations).then(function() { + return ImpacWidgetsSvc.show(w); + }); }; - selectedElementsSetting = { - initialized: false + onClickBar = function(event) { + var filter, resources, series; + series = this; + resources = (function() { + switch (series.userOptions.stack) { + case 'Payables': + return 'bills'; + case 'Receivables': + return 'invoices'; + } + })(); + if (resources == null) { + return; + } + filter = { + expected_payment_date: dateFilter(event.point.x), + status: ['AUTHORISED', 'APPROVED', 'SUBMITTED', 'FORECAST'], + reconciliation_status: 'UNRECONCILED' + }; + $scope.trxList.updateParams(resources, filter); + return $scope.trxList.fetch(); }; - selectedElementsSetting.initialize = function() { - return selectedElementsSetting.initialized = true; + legendFormatter = function() { + var img, name; + name = this.name; + img = imgSrc(name); + if (!img) { + return name; + } + if (name !== 'Projected cash') { + return imgTemplate(img, name); + } + return imgTemplate(img, name) + '
' + imgTemplate(imgSrc('cashFlow'), 'Cash flow'); }; - selectedElementsSetting.toMetadata = function() { - var selectedElementsMetadata; - selectedElementsMetadata = _.map($scope.selectedElements, function(sElem) { - return getIdentifier(sElem); + onZoom = function(event) { + zoomMetadata = angular.merge(w.metadata, { + xAxis: { + max: event.max, + min: event.min + } }); - return { - selectedElements: selectedElementsMetadata - }; - }; - w.settings.push(selectedElementsSetting); - return $scope.widgetDeferred.resolve(settingsPromises); - }]); - - module.directive('widgetSalesPerformance', function() { - return { - restrict: 'A', - controller: 'WidgetSalesPerformanceCtrl' + if (!updateLocked) { + updateLocked = true; + return $timeout(function() { + return ImpacWidgetsSvc.update(w, { + metadata: zoomMetadata + }, false)["finally"](function() { + return updateLocked = false; + }); + }, 1000); + } }; - }); - -}).call(this); - -(function() { - var module; - - module = angular.module('impac.components.widgets.sales-segmented-turnover', []); - - module.controller('WidgetSalesSegmentedTurnoverCtrl', ["$scope", "$q", "$filter", "ChartFormatterSvc", "$translate", function($scope, $q, $filter, ChartFormatterSvc, $translate) { - var settingsPromises, w; - w = $scope.widget; - $scope.orgDeferred = $q.defer(); - $scope.timePeriodDeferred = $q.defer(); - $scope.widthDeferred = $q.defer(); - $scope.paramSelectorDeferred = $q.defer(); - $scope.chartDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.timePeriodDeferred.promise, $scope.widthDeferred.promise, $scope.paramSelectorDeferred.promise, $scope.chartDeferred.promise]; - w.initContext = function() { - if ($scope.isDataFound = !_.isEmpty(w.content) && !_.isEmpty(w.content.dates) && !_.isEmpty(w.content.ranges)) { - $scope.filterOptions = [ - { - label: $translate.instant('impac.widget.sales_turnover.gross_revenue'), - value: 'gross' - }, { - label: $translate.instant('impac.widget.sales_turnover.net_revenue'), - value: 'net' - } - ]; - $scope.filter = angular.copy(_.find($scope.filterOptions, function(o) { - return o.value === w.content.filter; - }) || $scope.filterOptions[0]); - if (w.content.ranges[0].percentage + w.content.ranges[1].percentage > 50) { - return $scope.analysisTranslate = $translate.instant('impac.widget.sales_turnover.analysis.least'); - } else if (w.content.ranges[3].percentage + w.content.ranges[4].percentage > 50) { - return $scope.analysisTranslate = $translate.instant('impac.widget.sales_turnover.analysis.most'); + onClickLegend = function() { + var i, len, ref, results, s, series; + series = this; + ref = $scope.chart.hc.series; + results = []; + for (i = 0, len = ref.length; i < len; i++) { + s = ref[i]; + if (s.userOptions.linkedTo !== series.name) { + continue; + } + if (series.visible) { + results.push(s.hide()); } else { - return $scope.analysisTranslate = $translate.instant('impac.widget.sales_turnover.analysis.balanced'); + results.push(s.show()); } } + return results; }; - $scope.getColorByIndex = function(index) { - return ChartFormatterSvc.getColor(index); - }; - $scope.getRangeLabel = function(aLabel, ISOmode) { - var prices; - if (ISOmode == null) { - ISOmode = false; - } - prices = aLabel.split('-'); - return _.map(prices, function(price) { - return $filter('mnoCurrency')(price, w.content.currency, ISOmode); - }).join(' - '); + loadContacts = function() { + return BoltResources.index(w.metadata.bolt_path, 'contacts', { + metadata: _.pick(w.metadata, 'organization_ids') + }).then(function(response) { + return $scope.contacts = response.data.data; + }); }; - $scope.getMaxRange = function() { - var max, maxRange; - if ($scope.isDataFound) { - max = 0; - maxRange = w.content.ranges[0]; - angular.forEach(w.content.ranges, function(range) { - if (range.percentage > max) { - maxRange = angular.copy(range); - } - return max = Math.max(max, range.percentage); - }); - return maxRange; - } + loadTrendsGroups = function() { + return BoltResources.index(w.metadata.bolt_path, 'trends_groups', { + metadata: _.pick(w.metadata, 'organization_ids'), + fields: { + trends_groups: 'name' + } + }).then(function(response) { + return $scope.trendsGroups = response.data.data; + }); }; - $scope.drawTrigger = $q.defer(); - w.format = function() { - var barData, barOptions, chartData; - if ($scope.isDataFound) { - barData = { - labels: _.map(w.content.ranges, function(elem) { - return $scope.getRangeLabel(elem.label, true); - }), - values: _.map(w.content.ranges, function(elem) { - return elem.value; - }) - }; - barOptions = { - showTooltips: false, - showXLabels: false, - barDatasetSpacing: 15 - }; - chartData = ChartFormatterSvc.barChart(barData, barOptions); - return $scope.drawTrigger.notify(chartData); + createUser = function() { + if ($scope.firstCompanyId) { + return BoltResources.create(w.metadata.bolt_path, 'users', { + first_name: ImpacMainSvc.config.userData.name, + last_name: ImpacMainSvc.config.userData.surname, + email: ImpacMainSvc.config.userData.email + }, { + companies: { + data: [ + { + type: 'companies', + id: $scope.firstCompanyId + } + ] + } + }).then(function(response) { + return $scope.userId = response.data.data.id; + }); } }; - return $scope.widgetDeferred.resolve(settingsPromises); - }]); - - module.directive('widgetSalesSegmentedTurnover', function() { - return { - restrict: 'A', - controller: 'WidgetSalesSegmentedTurnoverCtrl' + fetchUser = function() { + return BoltResources.index(w.metadata.bolt_path, 'users', { + filter: { + email: ImpacMainSvc.config.userData.email + }, + metadata: _.pick(w.metadata, 'organization_ids') + }).then(function(response) { + if (response.data.meta.record_count > 0) { + return $scope.userId = response.data.data[0].id; + } else { + return createUser(); + } + }); }; - }); - -}).call(this); - -(function() { - var module; - - module = angular.module('impac.components.widgets.sales-summary', []); - - module.controller('WidgetSalesSummaryCtrl', ["$scope", "$q", "ChartFormatterSvc", "$translate", function($scope, $q, ChartFormatterSvc, $translate) { - var settingsPromises, w; - w = $scope.widget; - $scope.orgDeferred = $q.defer(); - $scope.chartFiltersDeferred = $q.defer(); - $scope.paramSelectorDeferred = $q.defer(); - $scope.datesPickerDeferred = $q.defer(); - $scope.chartDeferred = $q.defer(); - settingsPromises = [$scope.orgDeferred.promise, $scope.chartFiltersDeferred.promise, $scope.paramSelectorDeferred.promise, $scope.datesPickerDeferred.promise, $scope.chartDeferred.promise]; - $scope.datesPickerTemplate = "" + $translate.instant('impac.widget.sales_summary.to') + " "; w.initContext = function() { - $scope.isDataFound = !_.isEmpty(w.content) && !_.isEmpty(w.content.summary) && (_.sum(_.map(w.content.summary, function(s) { - return s.total; - })) > 0); - if ($scope.isDataFound) { - $scope.filterOptions = [ - { - label: $translate.instant('impac.widget.sales_summary.value_sold_taxes'), - value: 'gross_value_sold' - }, { - label: $translate.instant('impac.widget.sales_summary.value_sold_no_taxes'), - value: 'net_value_sold' - }, { - label: $translate.instant('impac.widget.sales_summary.quantity_sold'), - value: 'quantity_sold' - }, { - label: $translate.instant('impac.widget.sales_summary.value_purchased_taxes'), - value: 'gross_value_purchased' - }, { - label: $translate.instant('impac.widget.sales_summary.value_purchased_no_taxes'), - value: 'net_value_purchased' - }, { - label: $translate.instant('impac.widget.sales_summary.quantity_purchased'), - value: 'quantity_purchased' - } - ]; - if (w.metadata.criteria === "customer") { - $scope.filterOptions = [$scope.filterOptions[0], $scope.filterOptions[1], $scope.filterOptions[2]]; + var cashFlowSerie; + cashFlowSerie = _.find(w.content.chart.series, function(serie) { + return serie.name === "Cash flow"; + }); + cashFlowSerie.data = []; + cashFlowSerie.type = 'area'; + cashFlowSerie.showInLegend = false; + return BoltResources.index(w.metadata.bolt_path, 'companies', { + metadata: _.pick(w.metadata, 'organization_ids') + }).then(function(response) { + if (_.isEmpty(response.data.data)) { + w.demoData = true; + } else { + w.demoData = false; + $scope.firstCompanyId = response.data.data[0].id; + fetchUser(); } - return $scope.filter = angular.copy(_.find($scope.filterOptions, function(o) { - return o.value === w.metadata.filter; - }) || $scope.filterOptions[0]); - } + loadContacts(); + return loadTrendsGroups(); + }); }; - $scope.drawTrigger = $q.defer(); w.format = function() { - var chartData, pieData, pieOptions; - if ($scope.isDataFound) { - pieData = _.map(w.content.summary, function(entity) { - var label; - if (entity.company) { - label = (entity.code || entity.name || entity.location || entity.industry || entity.customer) + " (" + entity.company + ")"; - } else { - label = entity.code || entity.name || entity.location || entity.industry || entity.customer; - } - return { - label: label, - value: entity.total - }; - }); - pieOptions = { - percentageInnerCutout: 50, - tooltipFontSize: 12 - }; - if ($scope.filter.value.indexOf('quantity') > -1) { - angular.merge(pieOptions, { - currency: 'hide' - }); - } - chartData = ChartFormatterSvc.pieChart(pieData, pieOptions); - return $scope.drawTrigger.notify(chartData); - } + var _highChartOptions; + _highChartOptions = { + chartType: 'line', + currency: w.metadata.currency, + showToday: true + }; + $scope.chart = new HighchartsFactory($scope.chartId(), w.content.chart.series, _highChartOptions); + $scope.chart.addCustomLegend(legendFormatter); + $scope.chart.addSeriesEvent('click', onClickBar); + $scope.chart.addSeriesEvent('legendItemClick', onClickLegend); + $scope.chart.addXAxisOptions({ + defaults: w.metadata.xAxis, + callback: onZoom + }); + $scope.chart.render(); + return $scope.chartDeferred.notify($scope.chart); }; return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetSalesSummary', function() { + module.directive('widgetAccountsCashProjection', function() { return { restrict: 'A', - controller: 'WidgetSalesSummaryCtrl' + controller: 'WidgetAccountsCashProjectionCtrl' }; }); @@ -16181,171 +17351,145 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
0) { - return entity.total_invoiced / entity.invoices.length; - } else { - return 0; - } - } - }, { - label: 'last', - showCurrency: true, - getValue: function(entity) { - var total; - total = entity.invoices.length; - if (total > 0) { - return entity.invoices[entity.invoices.length - 1].invoiced; - } else { - return 0; - } - } + $scope.legendItemOnClick = function(account) { + var serie, visibility; + serie = ($scope.chart != null) && ($scope.chart.hc != null) && getSerieByAccount($scope.chart.hc.series, account); + if (!serie) { + return; } - ]; - $scope.getHeaderField = function() { - return _.find(fields, function(f) { - return f.label === $scope.headerSelected.minified; - }); + visibility = serie.visible ? false : true; + return serie.setVisible(visibility); }; - $scope.getRemainingFields = function() { - return _.reject(fields, function(f) { - return f.label === $scope.headerSelected.minified; - }); + $scope.getLegendItemCheckBox = function(account) { + var serie; + serie = ($scope.chart != null) && ($scope.chart.hc != null) && getSerieByAccount($scope.chart.hc.series, account); + if (!serie) { + return 'fa-check-square-o'; + } + if (serie.visible) { + return 'fa-check-square-o'; + } else { + return 'fa-square-o'; + } }; - $scope.getEntities = function() { - if (!$scope.isDataFound) { - return []; + $scope.getLegendItemIcon = function(account) { + var serie; + serie = ($scope.chart != null) && ($scope.chart.hc != null) && getSerieByAccount($scope.chart.hc.series, account); + if (serie.type === 'area') { + return ImpacAssets.get('areaLegendIcon'); + } else { + return ImpacAssets.get('plotLineLegendIcon'); } - return $filter('orderBy')(w.content.entities, (function(entity) { - return $scope.getHeaderField().getValue(entity); - }), true); }; - buildFxTotals = function() { - var contact, contactFxTotals, j, len, ref, results; - ref = w.content.entities; + $scope.getLegendItemColor = function(account) { + var serie; + serie = ($scope.chart != null) && ($scope.chart.hc != null) && getSerieByAccount($scope.chart.hc.series, account); + if (!serie) { + return '#000'; + } + return serie.color; + }; + getSerieByAccount = function(series, account) { + return _.find(series, function(serie) { + return (serie.id || serie.options && serie.options.id) === account.id; + }); + }; + setSeriesColors = function(series, chartColors) { + var bias, groupedSeries, i, palette, results, serie; + groupedSeries = _.groupBy(series, function(serie) { + return serie.bias; + }); results = []; - for (j = 0, len = ref.length; j < len; j++) { - contact = ref[j]; - contactFxTotals = []; - _.mapKeys(contact.fx_totals, function(total, currency) { - if (currency !== w.metadata.currency) { - return contactFxTotals.push({ - currency: currency, - amount: total.invoiced, - rate: total.rate - }); - } - }); - if (!_.isEmpty(contactFxTotals)) { - results.push(contact.formattedFxTotals = contactFxTotals); - } else { - results.push(void 0); + for (bias in groupedSeries) { + series = groupedSeries[bias]; + if (!chartColors[bias]) { + continue; } + palette = ImpacTheming.color.generateShadesPalette(chartColors[bias], series.length); + results.push((function() { + var j, len, results1; + results1 = []; + for (i = j = 0, len = series.length; j < len; i = ++j) { + serie = series[i]; + results1.push(serie.color = palette[i]); + } + return results1; + })()); } return results; }; + $scope.chartId = function() { + return "cashBalanceChart-" + w.id; + }; + updateLocked = false; + zoomMetadata = {}; + onZoom = function(event) { + zoomMetadata = angular.merge(w.metadata, { + xAxis: { + max: event.max, + min: event.min + } + }); + if (!updateLocked) { + updateLocked = true; + return $timeout(function() { + return ImpacWidgetsSvc.update(w, { + metadata: zoomMetadata + }, false)["finally"](function() { + return updateLocked = false; + }); + }, 1000); + } + }; + w.format = function() { + return $timeout(function() { + var _highChartOptions; + _highChartOptions = { + chartType: 'line', + currency: w.metadata.currency, + period: getPeriod(), + showToday: true, + showLegend: false + }; + $scope.chart = new HighchartsFactory($scope.chartId(), w.content.chart.series, _highChartOptions); + $scope.chart.addXAxisOptions({ + defaults: w.metadata.xAxis, + callback: onZoom + }); + $scope.chart.removeLegend(); + return $scope.chart.render(); + }); + }; return $scope.widgetDeferred.resolve(settingsPromises); }]); - module.directive('widgetSalesTopCustomers', function() { + module.directive('widgetAccountsCashBalance', function() { return { restrict: 'A', - controller: 'WidgetSalesTopCustomersCtrl', - link: function(scope) { - scope.transactionsCollapsed = false; - return scope.toggleTransactions = function() { - return scope.transactionsCollapsed = !scope.transactionsCollapsed; - }; - } + controller: 'WidgetAccountsCashBalanceCtrl' }; }); @@ -16354,54 +17498,116 @@ $templateCache.put("widgets/sales-top-opportunities.tmpl.html","
.title span { + margin-left: 3px; + } +} - form .row.kpi-description { - padding: 10px 2px; - span { - display: block; - font-weight: bold; - font-size: 13px; - } - } +.analytics .widget-item .content.accounts-balance { + h3 { + .left-thin(30px); + text-align: center; + } - form.attach-kpi-form { - input.attach-target { - background-color: white; - height: inherit; + .price { + .center-bold(0px); + } +} + +.analytics .widget-item .content.accounts-balance-sheet { + .tall-widget(); + .widget-lines-container { + .scrollable(scroll); + max-height: 490px; + @media (max-width: @screen-xs-max) { + .row.widget-line { + &:not(:last-child) { border-bottom: dashed 1px @impac-widget-borders-color; } } } + .row.widget-line.header > [class*='col-'] { position: static; } - .error-messages { - color: @brand-danger; - width: 120px; + &.no-scroll { + overflow: visible; } } - .attached-kpis { - padding: 5px; + .no-data-block { + .center-thin(); + margin: 15px 0px; } +} - .list-group-item.attached-kpi { - padding: 5px 10px; +.analytics .widget-item .content.accounts-cash-balance { + .tall-widget(); - .attached-kpi-name { - overflow: hidden; - width: 75%; - display: inline-block; - white-space: nowrap; - text-overflow: ellipsis; - margin-top: 3px; - font-size: 13px; - font-weight: bold; - } + .data-container { + height: ~"calc(@{impac-big-widget-size} - 50px)"; + width: 100%; + } - .actions { - padding-top: 2px; - .alerts-config { - display: inline-block; - text-align: left; - padding-left: 4px; - height: 20px; - border-radius: 40px; - width: 21px; - color: @mblue; - background-color: white; - border: solid 1px @mblue; + .left-panel { + width: 180px; + display: inline-block; + overflow: auto; + max-height: 100%; + } - &:hover { cursor: pointer; } - } - .edit-attached-kpi { - display: inline-block; - i { - border-radius: 10px; - width: 21px; - color: @mblue; - background-color: white; - height: 20px; - padding: 3px 5px 5px 5px; - border: solid 1px @mblue; - &:hover { cursor: pointer; } + #cash-balance-legend { + .header { + .group-item { + display: flex; + align-items: center; + min-height: 45px; + margin: 3px; + font-size: 13px; + padding: 3px; + cursor: pointer; + user-select: none; + &:hover { + background-color: @impac-widget-menus-hover-background-color; } - } - .remove-attached-kpi { - display: inline-block; i { - border-radius: 10px; - width: 21px; - color: @brand-danger; - background-color: white; - height: 20px; - padding: 3px 5px 5px 5px; - border: solid 1px @brand-danger; - &:hover { cursor: pointer; } + font-size: 19px; + padding: 4px; + margin-top: 1px } + span { color: @impac-widget-text-color; } } } } -} -.analytics .widget-item .content .settings.select-account { - padding: 0px 5px; -} -.analytics .widget-item .content .settings.chart-filters { - .row { - margin: 0px; + .legend-item-icon { + width: 16px; + height: 16px; } - input[type="radio"] { - margin: 0; - margin-right: 3px; - padding: 0; - width: 13px; - height: 13px; - vertical-align: middle; - position: relative; - top: -1px; - outline: none; + + .right-panel { + width: ~"calc(100% - 180px)"; + float: right; + + // Highchart container + .cash-balance-chart { + height: ~"calc(@{impac-big-widget-size} - 50px)"; + } } - input[type="range"] { - height: auto; - width: 100%; + + .dates-picker { + display: inline-block; + float: right; + font-size: 12px; } } -.analytics .settings.dates-picker { - h5 { display: none; } +.analytics .widget-item .content.accounts-cash-projection { + .tall-widget(); - button.btn.btn-sm { - line-height: 1; - &.date-button { margin: 0px 5px; } - &.btn-danger { display: none; } - &.btn-info { border-radius: 3px; } + .cash-projection-chart { + height: ~"calc(@{impac-big-widget-size} - 50px)"; } - .tooltip-inner { text-transform: none; } - - .dropdown-menu > li > div > table { outline: none; } -} - -.analytics .settings.forecast-payroll { - .widget-lines-container { - .widget-line { - padding: 5px 10px 5px 18px; - .alternate-bg(#f3f4f4); - .fa { - float: right; - font-size: 20px; - cursor: pointer; - &.fa-toggle-on { - color: @impac-widget-link-color; - } - &.fa-toggle-off { - color: @impac-widget-text-color-medium; - } - } + .highcharts-legend-item { + rect.highcharts-point { + display: none; } - } -} - -.analytics .widget-item .content .settings.hist-mode-choser { - max-height: 70px; - - [common-time-period-info] { - padding-bottom: 8px; - } - .options { - width: 150px; - margin: auto; - padding-bottom: 8px; - border-bottom: solid 1px #e6e6e6; - .font(@impac-widget-hist-text-size,500,@impac-widget-hist-text-color); - a { - .font(@impac-widget-hist-text-size,500,@impac-widget-hist-text-color); - text-transform: @impac-widget-hist-text-transform; - &.active { - color: @impac-widget-link-color; + span { + width: 110px; + text-align: center; + img { + text-align: center; + width: 55px; + height: 25px; } } } - .arrow-container { - width: 28px; - height: 28px; - position: relative; - top: -14px; - margin: auto; - &.right { - left: 46px; - } - &.left { - left: -30px; - } - .arrow-border { - border-top: 14px solid #e6e6e6; - border-left: 14px solid transparent; - border-right: 14px solid transparent; - width: 0px; - height: 0px; - } - .arrow { - border-top: 14px solid @impac-widget-background-color; - border-left: 14px solid transparent; - border-right: 14px solid transparent; - position: relative; - top: 12px; - width: 0px; - height: 0px; - } - } -} - -.analytics .settings.limit-entries { - color: @impac-widget-limit-entries-color; - text-transform: uppercase; - text-align: center; - border-bottom: dashed 1px #E6E6E6; - padding-bottom: 8px; - a.option { - &.badge { - color: white; - background-color: @impac-widget-limit-entries-color; - } + .dates-picker { + display: inline-block; + float: right; + font-size: 12px; } + transactions-list { + font-size: 12px; + } } -.analytics .settings.offsets { - .offset-value { - font-style: italic; - font-size: 13px; +.analytics .widget-item .content.accounts-cash-summary { + .drill-down-widget(); + .right-panel .widget-lines-container { + max-height: 215px; } - .offset-value .fa-trash-o { - &:hover { - color: @brand-danger; - cursor: pointer; - } - margin-left: 10px; + .row.lines-group.cash { + border-top: solid 1px; + border-bottom: double; } - - input { width: 75%; } - button { width: 30px; } } -.analytics .settings.organizations { +.analytics .widget-item .content.accounts-class-comparison { + .param-selector { + text-align: center; + } .widget-lines-container { - .widget-line { - padding: 5px 10px 5px 18px; - .alternate-bg(#f3f4f4); - .fa { - float: right; - font-size: 20px; - cursor: pointer; - &.fa-toggle-on, &.fa-check-circle { - color: @impac-widget-link-color; - } - &.fa-toggle-off, &.fa-circle-thin { - color: @impac-widget-text-color-medium; - } - } - } + max-height: 94px; + color: #626d6d; } } -.analytics .widget-item .content .settings.param-selector { - display: inline-block; - - &.classic { - width: 100%; +.analytics .widget-item .content.accounts-comparison { + .tall-widget(); - select { - width: 100%; - height: 25px; - border: 1px solid #ccc; - text-transform: uppercase; - margin: 0px 0px 5px 0px; - } + .chart-container { + @media print { max-width: 80% !important; } } - a { - font-weight: normal; - color: @impac-widget-param-selector-color; - white-space: nowrap; - } - .options-container { + .add-account { position: absolute; - background-color: white; - text-align: left; - min-width: 150px; - max-height: 200px; - z-index: 999; - overflow-y: auto; - overflow-x: hidden; - .box-shadow(rgb(0, 0, 0) 0px 3px 15px -3px); - - .param-selector-label { - padding: 3px 5px; - .font(inherit,500,black); - cursor: text; - overflow: hidden; - white-space: nowrap; - text-overflow: ellipsis; - line-height: 1.9; - } - .param-selector-label:hover { + right: 40px; + bottom: 30px; + width: 160px; + select { + font-size: 13px; + background-color: @impac-widget-link-color; + color: @impac-widget-background-color; + outline: none; + border: none; cursor: pointer; - background-color: @impac-widget-param-selector-color; - color: white; - } - - &::-webkit-scrollbar { - width: 8px; - background-color: darken(@lightgray,5%); - } - - &::-webkit-scrollbar-thumb { - background-color: @impac-widget-param-selector-color; + &[disabled] { + cursor: not-allowed; + background-color: lighten(@impac-widget-link-color,10%); + &:hover { + background-color: lighten(@impac-widget-link-color,10%); + } + } &:hover { - background-color: lighten(@impac-widget-param-selector-color,5%); + background-color: darken(@impac-widget-link-color,10%); + } + option { + background-color: @impac-widget-background-color; + color: lighten(@impac-widget-text-color,40%); + &[disabled] { + color: @impac-widget-background-color; + } } } } -} - -.analytics .settings.params-checkboxes { - padding: 2px 0px; - input { + button.close { + font-size: 15px; + } + .legend { + text-align: left; + max-height: 103px; + } + .row { margin: 0; - height: inherit; } - span { - margin-left: 5px; + .widget-lines-container { + font-size: 11px; + max-height: @impac-widget-accounts-comparison-lines-container-max-height; + margin-bottom: 65px; + overflow: auto; } - label { - display: flex; - justify-content: center; - line-height: 14px; + + .settings.params-checkboxes { + margin-left: 13px; + } + + .comparable-error h5 { + margin-left: 13px; + color: @impac-negative; } } -.analytics .widget-item .content .settings.params-picker { - padding: 0px 10px; - .parameter { - margin: 0px 3px 3px 0px; - padding: 3px 5px; - background-color: @impac-widget-params-picker-bg; - color: white; - border: solid 1px @impac-widget-params-picker-bg; - border-radius: 4px; - cursor: move; +.analytics .widget-item .content.accounts-custom-calculation { + h3 { + margin-top: 85px; + text-align: center; font-weight: bold; - white-space: nowrap; - float: left; - input[type="checkbox"] { - margin: 0px -3px 0px 3px; - vertical-align: middle; - height: inherit; - outline: none; - cursor: pointer; - } - .badge { - margin-right: 3px; - font-size: 10px; - background-color: darken(@impac-widget-background-color, 5%); - color: @impac-widget-params-picker-bg; - padding: 2px 6px; - } - - &.unchecked { - background-color: inherit; - font-weight: normal; - color: inherit; - border-color: @impac-widget-params-picker-unchecked-bg; - .badge { - background-color: @impac-widget-params-picker-unchecked-bg; - color: white; - } - } } + .legend { max-height: 125px; } } -.analytics .settings.tag-filter { - padding: 0px 5px; - - .btn.btn-default { - height: 32px; - width: 30px; - } - - .tag-lines-container { - padding: 0px 10px; - - .tag-line { - display: flex; - align-items: center; - justify-content: flex-end; - - .tags-col { position: static; } - tags-input { - .tags { - display: flex; - border-radius: 4px; - border: solid 1px #ccc; - .tag-item { - background: #79a2bb; - border-radius: 4px; - color: white; - } - } - } +.analytics.modal-custom-calculation { + margin: 0px; + padding: 0px; +} - .host { position: static; } - } +.analytics.modal-custom-calculation .modal-body { + .edit { + .edit-panel-style(); + padding: 5px; + overflow: visible; } } -.analytics .settings.time-period { - padding: 0px 5px; - - select { - height: 22px; - width: 100%; +.analytics .widget-item .content.accounts-detailed-classifications { + .tall-widget(); + .widget-lines-container { + .scrollable(scroll); + max-height: 540px; } - - & > .row { - margin: 0px -5px 7px -5px; - & > div { - padding: 0px 5px; - position: static; - } - .sub-setting { padding: 5px; } + .account-class-title { + margin-bottom: 8px; + margin-left: 11px; } -} -.analytics .widget-item .content .settings.width { - float: right; - font-size: 14px; - i { - color: silver; - cursor: pointer; - &.reduce { - margin-right: -10px; - } - &.expand { - margin-right: -3px; - } - } -} -.analytics .widget-item .content.accounts-accounting-values { - // Nothing particular yet for this template... -} -.analytics .widget-item .content.accounts-assets-liability-summary { - .param-selector { - text-align: center; + .time-period-info { + text-align: right; } - .legend { - text-align: left; - max-height: 90px; - .title { - text-align: center; - border-bottom: dashed 1px @impac-widget-borders-color; - } + .widget-line.header.sorting { + border-bottom: 1px solid #ccc; } } -.analytics .widget-item .content.accounts-assets-summary { + + +.analytics .widget-item .content.accounts-expense-weight { .legend { text-align: left; max-height: 115px; .title { text-align: center; - border-bottom: dashed 1px @impac-widget-borders-color; } } } -.analytics .widget-item .content.accounts-assets-vs-liabilities { - .legend > .title span { - margin-left: 3px; +.analytics .widget-item .content.accounts-expenses-revenue { + .legend { + font-weight: bold; } -} -.analytics .widget-item .content.accounts-balance { - h3 { - .left-thin(30px); + .settings.params-checkboxes { + font-size: 12px; + margin-left: 0px; text-align: center; } - - .price { - .center-bold(0px); - } } -.analytics .widget-item .content.accounts-balance-sheet { +.analytics .widget-item .content.accounts-invoices-list { + // component specific styles + // ------------------------- .tall-widget(); - .widget-lines-container { - .scrollable(scroll); - max-height: 490px; - @media (max-width: @screen-xs-max) { - .row.widget-line { - &:not(:last-child) { border-bottom: dashed 1px @impac-widget-borders-color; } - } - } - .row.widget-line.header > [class*='col-'] { position: static; } - &.no-scroll { - overflow: visible; - } + transactions-list { + font-size: 12px; } - .no-data-block { - .center-thin(); - margin: 15px 0px; - } } -.analytics .widget-item .content.accounts-cash-balance { - .tall-widget(); - - .data-container { - height: ~"calc(@{impac-big-widget-size} - 50px)"; - width: 100%; +.analytics .widget-item .content.accounts-live-balance { + h3 { + .center-bold(0px); + font-size: 18px; + text-align: center; + text-shadow: 1px; } - .left-panel { - width: 180px; - display: inline-block; - overflow: auto; - max-height: 100%; + .statement-title { + font-size: 13px; + font-weight: 400; } - #cash-balance-legend { - .header { - .group-item { - display: flex; - align-items: center; - min-height: 45px; - margin: 3px; - font-size: 13px; - padding: 3px; - cursor: pointer; - user-select: none; - &:hover { - background-color: @impac-widget-menus-hover-background-color; - } - i { - font-size: 19px; - padding: 4px; - margin-top: 1px - } - span { color: @impac-widget-text-color; } - } - } + .balance-title { + font-size: 12px; } - .legend-item-icon { - width: 16px; - height: 16px; + .currency-centered { + .center-small() } - .right-panel { - width: ~"calc(100% - 180px)"; - float: right; - - // Highchart container - .cash-balance-chart { - height: ~"calc(@{impac-big-widget-size} - 50px)"; - } + .headers { + text-align: center; } - .dates-picker { - display: inline-block; - float: right; - font-size: 12px; + .spacer { + min-height: 30px; } -} -.analytics .widget-item .content.accounts-cash-projection { - .tall-widget(); + .price { + .center-bold(0px); + } - .cash-projection-chart { - height: ~"calc(@{impac-big-widget-size} - 50px)"; + .come-back-later { + text-align: center; + font-size: 11px; + opacity: 0.8; } - .highcharts-legend-item { - rect.highcharts-point { - display: none; - } - - span { - width: 110px; - text-align: center; - img { - text-align: center; - width: 55px; - height: 25px; - } - } - } - - .dates-picker { - display: inline-block; - float: right; - font-size: 12px; - } - - transactions-list { - font-size: 12px; - } -} - -.analytics .widget-item .content.accounts-cash-summary { - .drill-down-widget(); - .right-panel .widget-lines-container { - max-height: 215px; - } - - .row.lines-group.cash { - border-top: solid 1px; - border-bottom: double; - } -} - -.analytics .widget-item .content.accounts-class-comparison { - .param-selector { - text-align: center; - } - .widget-lines-container { - max-height: 94px; - color: #626d6d; - } -} - -.analytics .widget-item .content.accounts-comparison { - .tall-widget(); - - .chart-container { - @media print { max-width: 80% !important; } - } - - .add-account { - position: absolute; - right: 40px; - bottom: 30px; - width: 160px; - select { - font-size: 13px; - background-color: @impac-widget-link-color; - color: @impac-widget-background-color; - outline: none; - border: none; - cursor: pointer; - &[disabled] { - cursor: not-allowed; - background-color: lighten(@impac-widget-link-color,10%); - &:hover { - background-color: lighten(@impac-widget-link-color,10%); - } - } - &:hover { - background-color: darken(@impac-widget-link-color,10%); - } - option { - background-color: @impac-widget-background-color; - color: lighten(@impac-widget-text-color,40%); - &[disabled] { - color: @impac-widget-background-color; - } - } - } - } - button.close { - font-size: 15px; - } - .legend { - text-align: left; - max-height: 103px; - } - .row { - margin: 0; - } - .widget-lines-container { - font-size: 11px; - max-height: @impac-widget-accounts-comparison-lines-container-max-height; - margin-bottom: 65px; - overflow: auto; - } - - .settings.params-checkboxes { - margin-left: 13px; - } - - .comparable-error h5 { - margin-left: 13px; - color: @impac-negative; - } -} - -.analytics .widget-item .content.accounts-custom-calculation { - h3 { - margin-top: 85px; - text-align: center; - font-weight: bold; - } - .legend { max-height: 125px; } -} - -.analytics.modal-custom-calculation { - margin: 0px; - padding: 0px; -} - -.analytics.modal-custom-calculation .modal-body { - .edit { - .edit-panel-style(); - padding: 5px; - overflow: visible; - } -} - -.analytics .widget-item .content.accounts-detailed-classifications { - .tall-widget(); - .widget-lines-container { - .scrollable(scroll); - max-height: 540px; - } - - .account-class-title { - margin-bottom: 8px; - margin-left: 11px; - } - - .time-period-info { - text-align: right; - } - - .widget-line.header.sorting { - border-bottom: 1px solid #ccc; - } -} - - - -.analytics .widget-item .content.accounts-expense-weight { - .legend { - text-align: left; - max-height: 115px; - - .title { - text-align: center; - } - } -} - -.analytics .widget-item .content.accounts-expenses-revenue { - .legend { - font-weight: bold; - } - - .settings.params-checkboxes { - font-size: 12px; - margin-left: 0px; - text-align: center; - } -} - -.analytics .widget-item .content.accounts-invoices-list { - // component specific styles - // ------------------------- - .tall-widget(); - - transactions-list { - font-size: 12px; - } - -} - -.analytics .widget-item .content.accounts-live-balance { - h3 { - .center-bold(0px); - font-size: 18px; - text-align: center; - text-shadow: 1px; - } - - .statement-title { - font-size: 13px; - font-weight: 400; - } - - .balance-title { - font-size: 12px; - } - - .currency-centered { - .center-small() - } - - .headers { - text-align: center; - } - - .spacer { - min-height: 30px; - } - - .price { - .center-bold(0px); - } - - .negative2 { - font-size: 14px; - } -} + .negative2 { + font-size: 14px; + } +} .analytics .widget-item .content.accounts-payable-receivable { h3 { @@ -4659,4 +4203,466 @@ chart-threshold { } } } +} +.analytics .widget-item .content .settings.select-account { + padding: 0px 5px; +} +.analytics .settings.accounting-behaviour { + + .btn.btn-primary { + background-color: lighten(@impac-widget-link-color, 10%); + border: solid 1px @impac-widget-link-color; + &.focus, &.active { background-color: @impac-widget-link-color; } + } + +} + +.analytics .settings.attach-kpis { + .attach-kpi { + padding: 8px 5px; + + form .row { + padding-bottom: 5px; + } + + .attach-kpi-form { + background-color: white; + border: 1px solid #ddd; + padding: 5px; + } + + form .row.kpi-description { + padding: 10px 2px; + span { + display: block; + font-weight: bold; + font-size: 13px; + } + } + + form.attach-kpi-form { + input.attach-target { + background-color: white; + height: inherit; + } + } + + .error-messages { + color: @brand-danger; + width: 120px; + } + } + + .attached-kpis { + padding: 5px; + } + + .list-group-item.attached-kpi { + padding: 5px 10px; + + .attached-kpi-name { + overflow: hidden; + width: 75%; + display: inline-block; + white-space: nowrap; + text-overflow: ellipsis; + margin-top: 3px; + font-size: 13px; + font-weight: bold; + } + + .actions { + padding-top: 2px; + .alerts-config { + display: inline-block; + text-align: left; + padding-left: 4px; + height: 20px; + border-radius: 40px; + width: 21px; + color: @mblue; + background-color: white; + border: solid 1px @mblue; + + &:hover { cursor: pointer; } + } + .edit-attached-kpi { + display: inline-block; + i { + border-radius: 10px; + width: 21px; + color: @mblue; + background-color: white; + height: 20px; + padding: 3px 5px 5px 5px; + border: solid 1px @mblue; + &:hover { cursor: pointer; } + } + } + .remove-attached-kpi { + display: inline-block; + i { + border-radius: 10px; + width: 21px; + color: @brand-danger; + background-color: white; + height: 20px; + padding: 3px 5px 5px 5px; + border: solid 1px @brand-danger; + &:hover { cursor: pointer; } + } + } + } + } +} + +.analytics .widget-item .content .settings.select-account { + padding: 0px 5px; +} +.analytics .widget-item .content .settings.chart-filters { + .row { + margin: 0px; + } + input[type="radio"] { + margin: 0; + margin-right: 3px; + padding: 0; + width: 13px; + height: 13px; + vertical-align: middle; + position: relative; + top: -1px; + outline: none; + } + input[type="range"] { + height: auto; + width: 100%; + } +} + +.analytics .settings.dates-picker { + h5 { display: none; } + + button.btn.btn-sm { + line-height: 1; + &.date-button { margin: 0px 5px; } + &.btn-danger { display: none; } + &.btn-info { border-radius: 3px; } + } + + .tooltip-inner { text-transform: none; } + + .dropdown-menu > li > div > table { outline: none; } +} + +.analytics .settings.forecast-payroll { + .widget-lines-container { + .widget-line { + padding: 5px 10px 5px 18px; + .alternate-bg(#f3f4f4); + .fa { + float: right; + font-size: 20px; + cursor: pointer; + &.fa-toggle-on { + color: @impac-widget-link-color; + } + &.fa-toggle-off { + color: @impac-widget-text-color-medium; + } + } + } + } +} + +.analytics .widget-item .content .settings.hist-mode-choser { + max-height: 70px; + + [common-time-period-info] { + padding-bottom: 8px; + } + + .options { + width: 150px; + margin: auto; + padding-bottom: 8px; + border-bottom: solid 1px #e6e6e6; + .font(@impac-widget-hist-text-size,500,@impac-widget-hist-text-color); + a { + .font(@impac-widget-hist-text-size,500,@impac-widget-hist-text-color); + text-transform: @impac-widget-hist-text-transform; + &.active { + color: @impac-widget-link-color; + } + } + } + .arrow-container { + width: 28px; + height: 28px; + position: relative; + top: -14px; + margin: auto; + &.right { + left: 46px; + } + &.left { + left: -30px; + } + .arrow-border { + border-top: 14px solid #e6e6e6; + border-left: 14px solid transparent; + border-right: 14px solid transparent; + width: 0px; + height: 0px; + } + .arrow { + border-top: 14px solid @impac-widget-background-color; + border-left: 14px solid transparent; + border-right: 14px solid transparent; + position: relative; + top: 12px; + width: 0px; + height: 0px; + } + } +} + +.analytics .settings.limit-entries { + color: @impac-widget-limit-entries-color; + text-transform: uppercase; + text-align: center; + border-bottom: dashed 1px #E6E6E6; + padding-bottom: 8px; + + a.option { + &.badge { + color: white; + background-color: @impac-widget-limit-entries-color; + } + } + +} + +.analytics .settings.offsets { + .offset-value { + font-style: italic; + font-size: 13px; + } + + .offset-value .fa-trash-o { + &:hover { + color: @brand-danger; + cursor: pointer; + } + margin-left: 10px; + } + + input { width: 75%; } + button { width: 30px; } +} + +.analytics .settings.organizations { + .widget-lines-container { + .widget-line { + padding: 5px 10px 5px 18px; + .alternate-bg(#f3f4f4); + .fa { + float: right; + font-size: 20px; + cursor: pointer; + &.fa-toggle-on, &.fa-check-circle { + color: @impac-widget-link-color; + } + &.fa-toggle-off, &.fa-circle-thin { + color: @impac-widget-text-color-medium; + } + } + } + } +} + +.analytics .widget-item .content .settings.param-selector { + display: inline-block; + + &.classic { + width: 100%; + + select { + width: 100%; + height: 25px; + border: 1px solid #ccc; + text-transform: uppercase; + margin: 0px 0px 5px 0px; + } + } + + a { + font-weight: normal; + color: @impac-widget-param-selector-color; + white-space: nowrap; + } + .options-container { + position: absolute; + background-color: white; + text-align: left; + min-width: 150px; + max-height: 200px; + z-index: 999; + overflow-y: auto; + overflow-x: hidden; + .box-shadow(rgb(0, 0, 0) 0px 3px 15px -3px); + + .param-selector-label { + padding: 3px 5px; + .font(inherit,500,black); + cursor: text; + overflow: hidden; + white-space: nowrap; + text-overflow: ellipsis; + line-height: 1.9; + } + .param-selector-label:hover { + cursor: pointer; + background-color: @impac-widget-param-selector-color; + color: white; + } + + &::-webkit-scrollbar { + width: 8px; + background-color: darken(@lightgray,5%); + } + + &::-webkit-scrollbar-thumb { + background-color: @impac-widget-param-selector-color; + &:hover { + background-color: lighten(@impac-widget-param-selector-color,5%); + } + } + } +} + +.analytics .settings.params-checkboxes { + padding: 2px 0px; + input { + margin: 0; + height: inherit; + } + span { + margin-left: 5px; + } + label { + display: flex; + justify-content: center; + line-height: 14px; + } +} + +.analytics .widget-item .content .settings.params-picker { + padding: 0px 10px; + .parameter { + margin: 0px 3px 3px 0px; + padding: 3px 5px; + background-color: @impac-widget-params-picker-bg; + color: white; + border: solid 1px @impac-widget-params-picker-bg; + border-radius: 4px; + cursor: move; + font-weight: bold; + white-space: nowrap; + float: left; + input[type="checkbox"] { + margin: 0px -3px 0px 3px; + vertical-align: middle; + height: inherit; + outline: none; + cursor: pointer; + } + .badge { + margin-right: 3px; + font-size: 10px; + background-color: darken(@impac-widget-background-color, 5%); + color: @impac-widget-params-picker-bg; + padding: 2px 6px; + } + + &.unchecked { + background-color: inherit; + font-weight: normal; + color: inherit; + border-color: @impac-widget-params-picker-unchecked-bg; + .badge { + background-color: @impac-widget-params-picker-unchecked-bg; + color: white; + } + } + } +} +.analytics .settings.tag-filter { + padding: 0px 5px; + + .btn.btn-default { + height: 32px; + width: 30px; + } + + .tag-lines-container { + padding: 0px 10px; + + .tag-line { + display: flex; + align-items: center; + justify-content: flex-end; + + .tags-col { position: static; } + + tags-input { + .tags { + display: flex; + border-radius: 4px; + border: solid 1px #ccc; + .tag-item { + background: #79a2bb; + border-radius: 4px; + color: white; + } + } + } + + .host { position: static; } + } + } +} + +.analytics .settings.time-period { + padding: 0px 5px; + + select { + height: 22px; + width: 100%; + } + + & > .row { + margin: 0px -5px 7px -5px; + & > div { + padding: 0px 5px; + position: static; + } + + .sub-setting { padding: 5px; } + } +} + +.analytics .widget-item .content .settings.width { + float: right; + font-size: 14px; + i { + color: silver; + cursor: pointer; + &.reduce { + margin-right: -10px; + } + &.expand { + margin-right: -3px; + } + } } \ No newline at end of file diff --git a/dist/impac-angular.min.css b/dist/impac-angular.min.css index 15c30303..f7b0ad6f 100644 --- a/dist/impac-angular.min.css +++ b/dist/impac-angular.min.css @@ -2,4 +2,4 @@ * Bootstrap v3.3.7 (http://getbootstrap.com) * Copyright 2011-2016 Twitter, Inc. * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) - *//*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */.label,sub,sup{vertical-align:baseline}hr,img{border:0}body,figure{margin:0}.btn-group>.btn-group,.btn-toolbar .btn,.btn-toolbar .btn-group,.btn-toolbar .input-group,.col-xs-1,.col-xs-10,.col-xs-11,.col-xs-12,.col-xs-2,.col-xs-3,.col-xs-4,.col-xs-5,.col-xs-6,.col-xs-7,.col-xs-8,.col-xs-9,.dropdown-menu{float:left}.btn,.kpi-alerts-settings .modal-body ul>li.list-group-item{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.navbar-fixed-bottom .navbar-collapse,.navbar-fixed-top .navbar-collapse,.pre-scrollable{max-height:340px}.analytics .impac-kpi .kpi .top-line,.analytics kpis-bar>.kpis .actions .im-form-inline,.widget-item .top-line{-webkit-box-orient:horizontal;-webkit-box-direction:normal}.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea,.analytics kpis-bar>.kpis .actions .im-form-group textarea{resize:none}html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary{display:block}audio,canvas,progress,video{display:inline-block;vertical-align:baseline}audio:not([controls]){display:none;height:0}[hidden],template{display:none}a{background-color:transparent;color:#00e5f0;text-decoration:none}a:active,a:hover{outline:0}b,optgroup,strong{font-weight:700}dfn{font-style:italic}h1{margin:.67em 0}mark{background:#ff0;color:#000}.img-thumbnail,body{background-color:#fff}.btn,.btn-danger.active,.btn-danger:active,.btn-default.active,.btn-default:active,.btn-info.active,.btn-info:active,.btn-primary.active,.btn-primary:active,.btn-warning.active,.btn-warning:active,.btn.active,.btn:active,.dropdown-menu>.disabled>a:focus,.dropdown-menu>.disabled>a:hover,.form-control,.navbar-toggle,.open>.dropdown-toggle.btn-danger,.open>.dropdown-toggle.btn-default,.open>.dropdown-toggle.btn-info,.open>.dropdown-toggle.btn-primary,.open>.dropdown-toggle.btn-warning{background-image:none}sub,sup{font-size:75%;line-height:0;position:relative}sup{top:-.5em}sub{bottom:-.25em}img{vertical-align:middle}svg:not(:root){overflow:hidden}hr{box-sizing:content-box;height:0}pre,textarea{overflow:auto}code,kbd,pre,samp{font-size:1em}button,input,optgroup,select,textarea{color:inherit;font:inherit;margin:0}.glyphicon,address{font-style:normal}button{overflow:visible}button,select{text-transform:none}button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer}button[disabled],html input[disabled]{cursor:default}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{height:auto}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}td,th{padding:0}@font-face{font-family:'Glyphicons Halflings';src:url(../fonts/glyphicons-halflings-regular.eot);src:url(../fonts/glyphicons-halflings-regular.eot?#iefix) format('embedded-opentype'),url(../fonts/glyphicons-halflings-regular.woff2) format('woff2'),url(../fonts/glyphicons-halflings-regular.woff) format('woff'),url(../fonts/glyphicons-halflings-regular.ttf) format('truetype'),url(../fonts/glyphicons-halflings-regular.svg#glyphicons_halflingsregular) format('svg')}.glyphicon{position:relative;top:1px;display:inline-block;font-family:'Glyphicons Halflings';font-weight:400;line-height:1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.glyphicon-asterisk:before{content:"\002a"}.glyphicon-plus:before{content:"\002b"}.glyphicon-eur:before,.glyphicon-euro:before{content:"\20ac"}.glyphicon-minus:before{content:"\2212"}.glyphicon-cloud:before{content:"\2601"}.glyphicon-envelope:before{content:"\2709"}.glyphicon-pencil:before{content:"\270f"}.glyphicon-glass:before{content:"\e001"}.glyphicon-music:before{content:"\e002"}.glyphicon-search:before{content:"\e003"}.glyphicon-heart:before{content:"\e005"}.glyphicon-star:before{content:"\e006"}.glyphicon-star-empty:before{content:"\e007"}.glyphicon-user:before{content:"\e008"}.glyphicon-film:before{content:"\e009"}.glyphicon-th-large:before{content:"\e010"}.glyphicon-th:before{content:"\e011"}.glyphicon-th-list:before{content:"\e012"}.glyphicon-ok:before{content:"\e013"}.glyphicon-remove:before{content:"\e014"}.glyphicon-zoom-in:before{content:"\e015"}.glyphicon-zoom-out:before{content:"\e016"}.glyphicon-off:before{content:"\e017"}.glyphicon-signal:before{content:"\e018"}.glyphicon-cog:before{content:"\e019"}.glyphicon-trash:before{content:"\e020"}.glyphicon-home:before{content:"\e021"}.glyphicon-file:before{content:"\e022"}.glyphicon-time:before{content:"\e023"}.glyphicon-road:before{content:"\e024"}.glyphicon-download-alt:before{content:"\e025"}.glyphicon-download:before{content:"\e026"}.glyphicon-upload:before{content:"\e027"}.glyphicon-inbox:before{content:"\e028"}.glyphicon-play-circle:before{content:"\e029"}.glyphicon-repeat:before{content:"\e030"}.glyphicon-refresh:before{content:"\e031"}.glyphicon-list-alt:before{content:"\e032"}.glyphicon-lock:before{content:"\e033"}.glyphicon-flag:before{content:"\e034"}.glyphicon-headphones:before{content:"\e035"}.glyphicon-volume-off:before{content:"\e036"}.glyphicon-volume-down:before{content:"\e037"}.glyphicon-volume-up:before{content:"\e038"}.glyphicon-qrcode:before{content:"\e039"}.glyphicon-barcode:before{content:"\e040"}.glyphicon-tag:before{content:"\e041"}.glyphicon-tags:before{content:"\e042"}.glyphicon-book:before{content:"\e043"}.glyphicon-bookmark:before{content:"\e044"}.glyphicon-print:before{content:"\e045"}.glyphicon-camera:before{content:"\e046"}.glyphicon-font:before{content:"\e047"}.glyphicon-bold:before{content:"\e048"}.glyphicon-italic:before{content:"\e049"}.glyphicon-text-height:before{content:"\e050"}.glyphicon-text-width:before{content:"\e051"}.glyphicon-align-left:before{content:"\e052"}.glyphicon-align-center:before{content:"\e053"}.glyphicon-align-right:before{content:"\e054"}.glyphicon-align-justify:before{content:"\e055"}.glyphicon-list:before{content:"\e056"}.glyphicon-indent-left:before{content:"\e057"}.glyphicon-indent-right:before{content:"\e058"}.glyphicon-facetime-video:before{content:"\e059"}.glyphicon-picture:before{content:"\e060"}.glyphicon-map-marker:before{content:"\e062"}.glyphicon-adjust:before{content:"\e063"}.glyphicon-tint:before{content:"\e064"}.glyphicon-edit:before{content:"\e065"}.glyphicon-share:before{content:"\e066"}.glyphicon-check:before{content:"\e067"}.glyphicon-move:before{content:"\e068"}.glyphicon-step-backward:before{content:"\e069"}.glyphicon-fast-backward:before{content:"\e070"}.glyphicon-backward:before{content:"\e071"}.glyphicon-play:before{content:"\e072"}.glyphicon-pause:before{content:"\e073"}.glyphicon-stop:before{content:"\e074"}.glyphicon-forward:before{content:"\e075"}.glyphicon-fast-forward:before{content:"\e076"}.glyphicon-step-forward:before{content:"\e077"}.glyphicon-eject:before{content:"\e078"}.glyphicon-chevron-left:before{content:"\e079"}.glyphicon-chevron-right:before{content:"\e080"}.glyphicon-plus-sign:before{content:"\e081"}.glyphicon-minus-sign:before{content:"\e082"}.glyphicon-remove-sign:before{content:"\e083"}.glyphicon-ok-sign:before{content:"\e084"}.glyphicon-question-sign:before{content:"\e085"}.glyphicon-info-sign:before{content:"\e086"}.glyphicon-screenshot:before{content:"\e087"}.glyphicon-remove-circle:before{content:"\e088"}.glyphicon-ok-circle:before{content:"\e089"}.glyphicon-ban-circle:before{content:"\e090"}.glyphicon-arrow-left:before{content:"\e091"}.glyphicon-arrow-right:before{content:"\e092"}.glyphicon-arrow-up:before{content:"\e093"}.glyphicon-arrow-down:before{content:"\e094"}.glyphicon-share-alt:before{content:"\e095"}.glyphicon-resize-full:before{content:"\e096"}.glyphicon-resize-small:before{content:"\e097"}.glyphicon-exclamation-sign:before{content:"\e101"}.glyphicon-gift:before{content:"\e102"}.glyphicon-leaf:before{content:"\e103"}.glyphicon-fire:before{content:"\e104"}.glyphicon-eye-open:before{content:"\e105"}.glyphicon-eye-close:before{content:"\e106"}.glyphicon-warning-sign:before{content:"\e107"}.glyphicon-plane:before{content:"\e108"}.glyphicon-calendar:before{content:"\e109"}.glyphicon-random:before{content:"\e110"}.glyphicon-comment:before{content:"\e111"}.glyphicon-magnet:before{content:"\e112"}.glyphicon-chevron-up:before{content:"\e113"}.glyphicon-chevron-down:before{content:"\e114"}.glyphicon-retweet:before{content:"\e115"}.glyphicon-shopping-cart:before{content:"\e116"}.glyphicon-folder-close:before{content:"\e117"}.glyphicon-folder-open:before{content:"\e118"}.glyphicon-resize-vertical:before{content:"\e119"}.glyphicon-resize-horizontal:before{content:"\e120"}.glyphicon-hdd:before{content:"\e121"}.glyphicon-bullhorn:before{content:"\e122"}.glyphicon-bell:before{content:"\e123"}.glyphicon-certificate:before{content:"\e124"}.glyphicon-thumbs-up:before{content:"\e125"}.glyphicon-thumbs-down:before{content:"\e126"}.glyphicon-hand-right:before{content:"\e127"}.glyphicon-hand-left:before{content:"\e128"}.glyphicon-hand-up:before{content:"\e129"}.glyphicon-hand-down:before{content:"\e130"}.glyphicon-circle-arrow-right:before{content:"\e131"}.glyphicon-circle-arrow-left:before{content:"\e132"}.glyphicon-circle-arrow-up:before{content:"\e133"}.glyphicon-circle-arrow-down:before{content:"\e134"}.glyphicon-globe:before{content:"\e135"}.glyphicon-wrench:before{content:"\e136"}.glyphicon-tasks:before{content:"\e137"}.glyphicon-filter:before{content:"\e138"}.glyphicon-briefcase:before{content:"\e139"}.glyphicon-fullscreen:before{content:"\e140"}.glyphicon-dashboard:before{content:"\e141"}.glyphicon-paperclip:before{content:"\e142"}.glyphicon-heart-empty:before{content:"\e143"}.glyphicon-link:before{content:"\e144"}.glyphicon-phone:before{content:"\e145"}.glyphicon-pushpin:before{content:"\e146"}.glyphicon-usd:before{content:"\e148"}.glyphicon-gbp:before{content:"\e149"}.glyphicon-sort:before{content:"\e150"}.glyphicon-sort-by-alphabet:before{content:"\e151"}.glyphicon-sort-by-alphabet-alt:before{content:"\e152"}.glyphicon-sort-by-order:before{content:"\e153"}.glyphicon-sort-by-order-alt:before{content:"\e154"}.glyphicon-sort-by-attributes:before{content:"\e155"}.glyphicon-sort-by-attributes-alt:before{content:"\e156"}.glyphicon-unchecked:before{content:"\e157"}.glyphicon-expand:before{content:"\e158"}.glyphicon-collapse-down:before{content:"\e159"}.glyphicon-collapse-up:before{content:"\e160"}.glyphicon-log-in:before{content:"\e161"}.glyphicon-flash:before{content:"\e162"}.glyphicon-log-out:before{content:"\e163"}.glyphicon-new-window:before{content:"\e164"}.glyphicon-record:before{content:"\e165"}.glyphicon-save:before{content:"\e166"}.glyphicon-open:before{content:"\e167"}.glyphicon-saved:before{content:"\e168"}.glyphicon-import:before{content:"\e169"}.glyphicon-export:before{content:"\e170"}.glyphicon-send:before{content:"\e171"}.glyphicon-floppy-disk:before{content:"\e172"}.glyphicon-floppy-saved:before{content:"\e173"}.glyphicon-floppy-remove:before{content:"\e174"}.glyphicon-floppy-save:before{content:"\e175"}.glyphicon-floppy-open:before{content:"\e176"}.glyphicon-credit-card:before{content:"\e177"}.glyphicon-transfer:before{content:"\e178"}.glyphicon-cutlery:before{content:"\e179"}.glyphicon-header:before{content:"\e180"}.glyphicon-compressed:before{content:"\e181"}.glyphicon-earphone:before{content:"\e182"}.glyphicon-phone-alt:before{content:"\e183"}.glyphicon-tower:before{content:"\e184"}.glyphicon-stats:before{content:"\e185"}.glyphicon-sd-video:before{content:"\e186"}.glyphicon-hd-video:before{content:"\e187"}.glyphicon-subtitles:before{content:"\e188"}.glyphicon-sound-stereo:before{content:"\e189"}.glyphicon-sound-dolby:before{content:"\e190"}.glyphicon-sound-5-1:before{content:"\e191"}.glyphicon-sound-6-1:before{content:"\e192"}.glyphicon-sound-7-1:before{content:"\e193"}.glyphicon-copyright-mark:before{content:"\e194"}.glyphicon-registration-mark:before{content:"\e195"}.glyphicon-cloud-download:before{content:"\e197"}.glyphicon-cloud-upload:before{content:"\e198"}.glyphicon-tree-conifer:before{content:"\e199"}.glyphicon-tree-deciduous:before{content:"\e200"}.glyphicon-cd:before{content:"\e201"}.glyphicon-save-file:before{content:"\e202"}.glyphicon-open-file:before{content:"\e203"}.glyphicon-level-up:before{content:"\e204"}.glyphicon-copy:before{content:"\e205"}.glyphicon-paste:before{content:"\e206"}.glyphicon-alert:before{content:"\e209"}.glyphicon-equalizer:before{content:"\e210"}.glyphicon-king:before{content:"\e211"}.glyphicon-queen:before{content:"\e212"}.glyphicon-pawn:before{content:"\e213"}.glyphicon-bishop:before{content:"\e214"}.glyphicon-knight:before{content:"\e215"}.glyphicon-baby-formula:before{content:"\e216"}.glyphicon-tent:before{content:"\26fa"}.glyphicon-blackboard:before{content:"\e218"}.glyphicon-bed:before{content:"\e219"}.glyphicon-apple:before{content:"\f8ff"}.glyphicon-erase:before{content:"\e221"}.glyphicon-hourglass:before{content:"\231b"}.glyphicon-lamp:before{content:"\e223"}.glyphicon-duplicate:before{content:"\e224"}.glyphicon-piggy-bank:before{content:"\e225"}.glyphicon-scissors:before{content:"\e226"}.glyphicon-bitcoin:before,.glyphicon-btc:before,.glyphicon-xbt:before{content:"\e227"}.glyphicon-jpy:before,.glyphicon-yen:before{content:"\00a5"}.glyphicon-rub:before,.glyphicon-ruble:before{content:"\20bd"}.glyphicon-scale:before{content:"\e230"}.glyphicon-ice-lolly:before{content:"\e231"}.glyphicon-ice-lolly-tasted:before{content:"\e232"}.glyphicon-education:before{content:"\e233"}.glyphicon-option-horizontal:before{content:"\e234"}.glyphicon-option-vertical:before{content:"\e235"}.glyphicon-menu-hamburger:before{content:"\e236"}.glyphicon-modal-window:before{content:"\e237"}.glyphicon-oil:before{content:"\e238"}.glyphicon-grain:before{content:"\e239"}.glyphicon-sunglasses:before{content:"\e240"}.glyphicon-text-size:before{content:"\e241"}.glyphicon-text-color:before{content:"\e242"}.glyphicon-text-background:before{content:"\e243"}.glyphicon-object-align-top:before{content:"\e244"}.glyphicon-object-align-bottom:before{content:"\e245"}.glyphicon-object-align-horizontal:before{content:"\e246"}.glyphicon-object-align-left:before{content:"\e247"}.glyphicon-object-align-vertical:before{content:"\e248"}.glyphicon-object-align-right:before{content:"\e249"}.glyphicon-triangle-right:before{content:"\e250"}.glyphicon-triangle-left:before{content:"\e251"}.glyphicon-triangle-bottom:before{content:"\e252"}.glyphicon-triangle-top:before{content:"\e253"}.glyphicon-console:before{content:"\e254"}.glyphicon-superscript:before{content:"\e255"}.glyphicon-subscript:before{content:"\e256"}.glyphicon-menu-left:before{content:"\e257"}.glyphicon-menu-right:before{content:"\e258"}.glyphicon-menu-down:before{content:"\e259"}.glyphicon-menu-up:before{content:"\e260"}*,:after,:before{box-sizing:border-box}html{font-size:10px;-webkit-tap-highlight-color:rgba(0,0,0,0)}body{font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:14px;line-height:1.42857143;color:#333}button,input,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit}a:focus,a:hover{color:#009ca3;text-decoration:underline}a:focus{outline:-webkit-focus-ring-color auto 5px;outline-offset:-2px}.carousel-inner>.item>a>img,.carousel-inner>.item>img,.img-responsive,.thumbnail a>img,.thumbnail>img{display:block;max-width:100%;height:auto}.img-rounded{border-radius:6px}.img-thumbnail{padding:4px;line-height:1.42857143;border:1px solid #ddd;border-radius:4px;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out;display:inline-block;max-width:100%;height:auto}.img-circle{border-radius:50%}hr{margin-top:20px;margin-bottom:20px;border-top:1px solid #eee}.sr-only{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);border:0}.sr-only-focusable:active,.sr-only-focusable:focus{position:static;width:auto;height:auto;margin:0;overflow:visible;clip:auto}[role=button]{cursor:pointer}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{font-family:inherit;font-weight:500;line-height:1.1;color:inherit}.h1 .small,.h1 small,.h2 .small,.h2 small,.h3 .small,.h3 small,.h4 .small,.h4 small,.h5 .small,.h5 small,.h6 .small,.h6 small,h1 .small,h1 small,h2 .small,h2 small,h3 .small,h3 small,h4 .small,h4 small,h5 .small,h5 small,h6 .small,h6 small{font-weight:400;line-height:1;color:#777}.h1,.h2,.h3,h1,h2,h3{margin-top:20px;margin-bottom:10px}.h1 .small,.h1 small,.h2 .small,.h2 small,.h3 .small,.h3 small,h1 .small,h1 small,h2 .small,h2 small,h3 .small,h3 small{font-size:65%}.h4,.h5,.h6,h4,h5,h6{margin-top:10px;margin-bottom:10px}.h4 .small,.h4 small,.h5 .small,.h5 small,.h6 .small,.h6 small,h4 .small,h4 small,h5 .small,h5 small,h6 .small,h6 small{font-size:75%}.h1,h1{font-size:36px}.h2,h2{font-size:30px}.h3,h3{font-size:24px}.h4,h4{font-size:18px}.h5,h5{font-size:14px}.h6,h6{font-size:12px}p{margin:0 0 10px}.lead{margin-bottom:20px;font-size:16px;font-weight:300;line-height:1.4}dt,kbd kbd,label{font-weight:700}address,blockquote .small,blockquote footer,blockquote small,dd,dt,pre{line-height:1.42857143}@media (min-width:768px){.lead{font-size:21px}}.small,small{font-size:85%}.mark,mark{background-color:#fcf8e3;padding:.2em}.list-inline,.list-unstyled{padding-left:0;list-style:none}.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}.text-justify{text-align:justify}.text-nowrap{white-space:nowrap}.text-lowercase{text-transform:lowercase}.text-uppercase{text-transform:uppercase}.text-capitalize{text-transform:capitalize}.text-muted{color:#777}.text-primary{color:#00e5f0}a.text-primary:focus,a.text-primary:hover{color:#00b4bd}.text-success{color:#3c763d}a.text-success:focus,a.text-success:hover{color:#2b542c}.text-info{color:#31708f}a.text-info:focus,a.text-info:hover{color:#245269}.text-warning{color:#8a6d3b}a.text-warning:focus,a.text-warning:hover{color:#66512c}.text-danger{color:#a94442}a.text-danger:focus,a.text-danger:hover{color:#843534}.bg-primary{color:#fff;background-color:#00e5f0}a.bg-primary:focus,a.bg-primary:hover{background-color:#00b4bd}.bg-success{background-color:#dff0d8}a.bg-success:focus,a.bg-success:hover{background-color:#c1e2b3}.bg-info{background-color:#d9edf7}a.bg-info:focus,a.bg-info:hover{background-color:#afd9ee}.bg-warning{background-color:#fcf8e3}a.bg-warning:focus,a.bg-warning:hover{background-color:#f7ecb5}.bg-danger{background-color:#f2dede}a.bg-danger:focus,a.bg-danger:hover{background-color:#e4b9b9}pre code,table{background-color:transparent}.page-header{padding-bottom:9px;margin:40px 0 20px;border-bottom:1px solid #eee}dl,ol,ul{margin-top:0}address,dl{margin-bottom:20px}ol,ul{margin-bottom:10px}ol ol,ol ul,ul ol,ul ul{margin-bottom:0}.list-inline{margin-left:-5px}.list-inline>li{display:inline-block;padding-left:5px;padding-right:5px}dd{margin-left:0}@media (min-width:768px){.dl-horizontal dt{float:left;width:160px;clear:left;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dl-horizontal dd{margin-left:180px}.container{width:750px}}abbr[data-original-title],abbr[title]{cursor:help;border-bottom:1px dotted #777}.initialism{font-size:90%;text-transform:uppercase}blockquote{padding:10px 20px;margin:0 0 20px;font-size:17.5px;border-left:5px solid #eee}blockquote ol:last-child,blockquote p:last-child,blockquote ul:last-child{margin-bottom:0}blockquote .small,blockquote footer,blockquote small{display:block;font-size:80%;color:#777}legend,pre{display:block;color:#333}blockquote .small:before,blockquote footer:before,blockquote small:before{content:'\2014 \00A0'}.blockquote-reverse,blockquote.pull-right{padding-right:15px;padding-left:0;border-right:5px solid #eee;border-left:0;text-align:right}code,kbd{padding:2px 4px;font-size:90%}caption,th{text-align:left}.blockquote-reverse .small:before,.blockquote-reverse footer:before,.blockquote-reverse small:before,blockquote.pull-right .small:before,blockquote.pull-right footer:before,blockquote.pull-right small:before{content:''}.blockquote-reverse .small:after,.blockquote-reverse footer:after,.blockquote-reverse small:after,blockquote.pull-right .small:after,blockquote.pull-right footer:after,blockquote.pull-right small:after{content:'\00A0 \2014'}code,kbd,pre,samp{font-family:Menlo,Monaco,Consolas,"Courier New",monospace}code{color:#c7254e;background-color:#f9f2f4;border-radius:4px}kbd{color:#fff;background-color:#333;border-radius:3px;box-shadow:inset 0 -1px 0 rgba(0,0,0,.25)}kbd kbd{padding:0;font-size:100%;box-shadow:none}pre{padding:9.5px;margin:0 0 10px;font-size:13px;word-break:break-all;word-wrap:break-word;background-color:#f5f5f5;border:1px solid #ccc;border-radius:4px}.container,.container-fluid{margin-right:auto;margin-left:auto}pre code{padding:0;font-size:inherit;color:inherit;white-space:pre-wrap;border-radius:0}.container,.container-fluid{padding-left:15px;padding-right:15px}.pre-scrollable{overflow-y:scroll}@media (min-width:992px){.container{width:970px}}@media (min-width:1200px){.container{width:1170px}}.row{margin-left:-15px;margin-right:-15px}.col-lg-1,.col-lg-10,.col-lg-11,.col-lg-12,.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-md-1,.col-md-10,.col-md-11,.col-md-12,.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-sm-1,.col-sm-10,.col-sm-11,.col-sm-12,.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-xs-1,.col-xs-10,.col-xs-11,.col-xs-12,.col-xs-2,.col-xs-3,.col-xs-4,.col-xs-5,.col-xs-6,.col-xs-7,.col-xs-8,.col-xs-9{position:relative;min-height:1px;padding-left:15px;padding-right:15px}.col-xs-12{width:100%}.col-xs-11{width:91.66666667%}.col-xs-10{width:83.33333333%}.col-xs-9{width:75%}.col-xs-8{width:66.66666667%}.col-xs-7{width:58.33333333%}.col-xs-6{width:50%}.col-xs-5{width:41.66666667%}.col-xs-4{width:33.33333333%}.col-xs-3{width:25%}.col-xs-2{width:16.66666667%}.col-xs-1{width:8.33333333%}.col-xs-pull-12{right:100%}.col-xs-pull-11{right:91.66666667%}.col-xs-pull-10{right:83.33333333%}.col-xs-pull-9{right:75%}.col-xs-pull-8{right:66.66666667%}.col-xs-pull-7{right:58.33333333%}.col-xs-pull-6{right:50%}.col-xs-pull-5{right:41.66666667%}.col-xs-pull-4{right:33.33333333%}.col-xs-pull-3{right:25%}.col-xs-pull-2{right:16.66666667%}.col-xs-pull-1{right:8.33333333%}.col-xs-pull-0{right:auto}.col-xs-push-12{left:100%}.col-xs-push-11{left:91.66666667%}.col-xs-push-10{left:83.33333333%}.col-xs-push-9{left:75%}.col-xs-push-8{left:66.66666667%}.col-xs-push-7{left:58.33333333%}.col-xs-push-6{left:50%}.col-xs-push-5{left:41.66666667%}.col-xs-push-4{left:33.33333333%}.col-xs-push-3{left:25%}.col-xs-push-2{left:16.66666667%}.col-xs-push-1{left:8.33333333%}.col-xs-push-0{left:auto}.col-xs-offset-12{margin-left:100%}.col-xs-offset-11{margin-left:91.66666667%}.col-xs-offset-10{margin-left:83.33333333%}.col-xs-offset-9{margin-left:75%}.col-xs-offset-8{margin-left:66.66666667%}.col-xs-offset-7{margin-left:58.33333333%}.col-xs-offset-6{margin-left:50%}.col-xs-offset-5{margin-left:41.66666667%}.col-xs-offset-4{margin-left:33.33333333%}.col-xs-offset-3{margin-left:25%}.col-xs-offset-2{margin-left:16.66666667%}.col-xs-offset-1{margin-left:8.33333333%}.col-xs-offset-0{margin-left:0}@media (min-width:768px){.col-sm-1,.col-sm-10,.col-sm-11,.col-sm-12,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9{float:left}.col-sm-12{width:100%}.col-sm-11{width:91.66666667%}.col-sm-10{width:83.33333333%}.col-sm-9{width:75%}.col-sm-8{width:66.66666667%}.col-sm-7{width:58.33333333%}.col-sm-6{width:50%}.col-sm-5{width:41.66666667%}.col-sm-4{width:33.33333333%}.col-sm-3{width:25%}.col-sm-2{width:16.66666667%}.col-sm-1{width:8.33333333%}.col-sm-pull-12{right:100%}.col-sm-pull-11{right:91.66666667%}.col-sm-pull-10{right:83.33333333%}.col-sm-pull-9{right:75%}.col-sm-pull-8{right:66.66666667%}.col-sm-pull-7{right:58.33333333%}.col-sm-pull-6{right:50%}.col-sm-pull-5{right:41.66666667%}.col-sm-pull-4{right:33.33333333%}.col-sm-pull-3{right:25%}.col-sm-pull-2{right:16.66666667%}.col-sm-pull-1{right:8.33333333%}.col-sm-pull-0{right:auto}.col-sm-push-12{left:100%}.col-sm-push-11{left:91.66666667%}.col-sm-push-10{left:83.33333333%}.col-sm-push-9{left:75%}.col-sm-push-8{left:66.66666667%}.col-sm-push-7{left:58.33333333%}.col-sm-push-6{left:50%}.col-sm-push-5{left:41.66666667%}.col-sm-push-4{left:33.33333333%}.col-sm-push-3{left:25%}.col-sm-push-2{left:16.66666667%}.col-sm-push-1{left:8.33333333%}.col-sm-push-0{left:auto}.col-sm-offset-12{margin-left:100%}.col-sm-offset-11{margin-left:91.66666667%}.col-sm-offset-10{margin-left:83.33333333%}.col-sm-offset-9{margin-left:75%}.col-sm-offset-8{margin-left:66.66666667%}.col-sm-offset-7{margin-left:58.33333333%}.col-sm-offset-6{margin-left:50%}.col-sm-offset-5{margin-left:41.66666667%}.col-sm-offset-4{margin-left:33.33333333%}.col-sm-offset-3{margin-left:25%}.col-sm-offset-2{margin-left:16.66666667%}.col-sm-offset-1{margin-left:8.33333333%}.col-sm-offset-0{margin-left:0}}@media (min-width:992px){.col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9{float:left}.col-md-12{width:100%}.col-md-11{width:91.66666667%}.col-md-10{width:83.33333333%}.col-md-9{width:75%}.col-md-8{width:66.66666667%}.col-md-7{width:58.33333333%}.col-md-6{width:50%}.col-md-5{width:41.66666667%}.col-md-4{width:33.33333333%}.col-md-3{width:25%}.col-md-2{width:16.66666667%}.col-md-1{width:8.33333333%}.col-md-pull-12{right:100%}.col-md-pull-11{right:91.66666667%}.col-md-pull-10{right:83.33333333%}.col-md-pull-9{right:75%}.col-md-pull-8{right:66.66666667%}.col-md-pull-7{right:58.33333333%}.col-md-pull-6{right:50%}.col-md-pull-5{right:41.66666667%}.col-md-pull-4{right:33.33333333%}.col-md-pull-3{right:25%}.col-md-pull-2{right:16.66666667%}.col-md-pull-1{right:8.33333333%}.col-md-pull-0{right:auto}.col-md-push-12{left:100%}.col-md-push-11{left:91.66666667%}.col-md-push-10{left:83.33333333%}.col-md-push-9{left:75%}.col-md-push-8{left:66.66666667%}.col-md-push-7{left:58.33333333%}.col-md-push-6{left:50%}.col-md-push-5{left:41.66666667%}.col-md-push-4{left:33.33333333%}.col-md-push-3{left:25%}.col-md-push-2{left:16.66666667%}.col-md-push-1{left:8.33333333%}.col-md-push-0{left:auto}.col-md-offset-12{margin-left:100%}.col-md-offset-11{margin-left:91.66666667%}.col-md-offset-10{margin-left:83.33333333%}.col-md-offset-9{margin-left:75%}.col-md-offset-8{margin-left:66.66666667%}.col-md-offset-7{margin-left:58.33333333%}.col-md-offset-6{margin-left:50%}.col-md-offset-5{margin-left:41.66666667%}.col-md-offset-4{margin-left:33.33333333%}.col-md-offset-3{margin-left:25%}.col-md-offset-2{margin-left:16.66666667%}.col-md-offset-1{margin-left:8.33333333%}.col-md-offset-0{margin-left:0}}@media (min-width:1200px){.col-lg-1,.col-lg-10,.col-lg-11,.col-lg-12,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9{float:left}.col-lg-12{width:100%}.col-lg-11{width:91.66666667%}.col-lg-10{width:83.33333333%}.col-lg-9{width:75%}.col-lg-8{width:66.66666667%}.col-lg-7{width:58.33333333%}.col-lg-6{width:50%}.col-lg-5{width:41.66666667%}.col-lg-4{width:33.33333333%}.col-lg-3{width:25%}.col-lg-2{width:16.66666667%}.col-lg-1{width:8.33333333%}.col-lg-pull-12{right:100%}.col-lg-pull-11{right:91.66666667%}.col-lg-pull-10{right:83.33333333%}.col-lg-pull-9{right:75%}.col-lg-pull-8{right:66.66666667%}.col-lg-pull-7{right:58.33333333%}.col-lg-pull-6{right:50%}.col-lg-pull-5{right:41.66666667%}.col-lg-pull-4{right:33.33333333%}.col-lg-pull-3{right:25%}.col-lg-pull-2{right:16.66666667%}.col-lg-pull-1{right:8.33333333%}.col-lg-pull-0{right:auto}.col-lg-push-12{left:100%}.col-lg-push-11{left:91.66666667%}.col-lg-push-10{left:83.33333333%}.col-lg-push-9{left:75%}.col-lg-push-8{left:66.66666667%}.col-lg-push-7{left:58.33333333%}.col-lg-push-6{left:50%}.col-lg-push-5{left:41.66666667%}.col-lg-push-4{left:33.33333333%}.col-lg-push-3{left:25%}.col-lg-push-2{left:16.66666667%}.col-lg-push-1{left:8.33333333%}.col-lg-push-0{left:auto}.col-lg-offset-12{margin-left:100%}.col-lg-offset-11{margin-left:91.66666667%}.col-lg-offset-10{margin-left:83.33333333%}.col-lg-offset-9{margin-left:75%}.col-lg-offset-8{margin-left:66.66666667%}.col-lg-offset-7{margin-left:58.33333333%}.col-lg-offset-6{margin-left:50%}.col-lg-offset-5{margin-left:41.66666667%}.col-lg-offset-4{margin-left:33.33333333%}.col-lg-offset-3{margin-left:25%}.col-lg-offset-2{margin-left:16.66666667%}.col-lg-offset-1{margin-left:8.33333333%}.col-lg-offset-0{margin-left:0}}table{border-collapse:collapse;border-spacing:0}caption{padding-top:8px;padding-bottom:8px;color:#777}.table{width:100%;max-width:100%;margin-bottom:20px}.table>tbody>tr>td,.table>tbody>tr>th,.table>tfoot>tr>td,.table>tfoot>tr>th,.table>thead>tr>td,.table>thead>tr>th{padding:8px;line-height:1.42857143;vertical-align:top;border-top:1px solid #ddd}.table>thead>tr>th{vertical-align:bottom;border-bottom:2px solid #ddd}.table>caption+thead>tr:first-child>td,.table>caption+thead>tr:first-child>th,.table>colgroup+thead>tr:first-child>td,.table>colgroup+thead>tr:first-child>th,.table>thead:first-child>tr:first-child>td,.table>thead:first-child>tr:first-child>th{border-top:0}.table>tbody+tbody{border-top:2px solid #ddd}.table .table{background-color:#fff}.table-condensed>tbody>tr>td,.table-condensed>tbody>tr>th,.table-condensed>tfoot>tr>td,.table-condensed>tfoot>tr>th,.table-condensed>thead>tr>td,.table-condensed>thead>tr>th{padding:5px}.table-bordered,.table-bordered>tbody>tr>td,.table-bordered>tbody>tr>th,.table-bordered>tfoot>tr>td,.table-bordered>tfoot>tr>th,.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border:1px solid #ddd}.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border-bottom-width:2px}.table-striped>tbody>tr:nth-of-type(odd){background-color:#f9f9f9}.table-hover>tbody>tr:hover,.table>tbody>tr.active>td,.table>tbody>tr.active>th,.table>tbody>tr>td.active,.table>tbody>tr>th.active,.table>tfoot>tr.active>td,.table>tfoot>tr.active>th,.table>tfoot>tr>td.active,.table>tfoot>tr>th.active,.table>thead>tr.active>td,.table>thead>tr.active>th,.table>thead>tr>td.active,.table>thead>tr>th.active{background-color:#f5f5f5}table col[class*=col-]{position:static;float:none;display:table-column}table td[class*=col-],table th[class*=col-]{position:static;float:none;display:table-cell}.table-hover>tbody>tr.active:hover>td,.table-hover>tbody>tr.active:hover>th,.table-hover>tbody>tr:hover>.active,.table-hover>tbody>tr>td.active:hover,.table-hover>tbody>tr>th.active:hover{background-color:#e8e8e8}.table>tbody>tr.success>td,.table>tbody>tr.success>th,.table>tbody>tr>td.success,.table>tbody>tr>th.success,.table>tfoot>tr.success>td,.table>tfoot>tr.success>th,.table>tfoot>tr>td.success,.table>tfoot>tr>th.success,.table>thead>tr.success>td,.table>thead>tr.success>th,.table>thead>tr>td.success,.table>thead>tr>th.success{background-color:#dff0d8}.table-hover>tbody>tr.success:hover>td,.table-hover>tbody>tr.success:hover>th,.table-hover>tbody>tr:hover>.success,.table-hover>tbody>tr>td.success:hover,.table-hover>tbody>tr>th.success:hover{background-color:#d0e9c6}.table>tbody>tr.info>td,.table>tbody>tr.info>th,.table>tbody>tr>td.info,.table>tbody>tr>th.info,.table>tfoot>tr.info>td,.table>tfoot>tr.info>th,.table>tfoot>tr>td.info,.table>tfoot>tr>th.info,.table>thead>tr.info>td,.table>thead>tr.info>th,.table>thead>tr>td.info,.table>thead>tr>th.info{background-color:#d9edf7}.table-hover>tbody>tr.info:hover>td,.table-hover>tbody>tr.info:hover>th,.table-hover>tbody>tr:hover>.info,.table-hover>tbody>tr>td.info:hover,.table-hover>tbody>tr>th.info:hover{background-color:#c4e3f3}.table>tbody>tr.warning>td,.table>tbody>tr.warning>th,.table>tbody>tr>td.warning,.table>tbody>tr>th.warning,.table>tfoot>tr.warning>td,.table>tfoot>tr.warning>th,.table>tfoot>tr>td.warning,.table>tfoot>tr>th.warning,.table>thead>tr.warning>td,.table>thead>tr.warning>th,.table>thead>tr>td.warning,.table>thead>tr>th.warning{background-color:#fcf8e3}.table-hover>tbody>tr.warning:hover>td,.table-hover>tbody>tr.warning:hover>th,.table-hover>tbody>tr:hover>.warning,.table-hover>tbody>tr>td.warning:hover,.table-hover>tbody>tr>th.warning:hover{background-color:#faf2cc}.table>tbody>tr.danger>td,.table>tbody>tr.danger>th,.table>tbody>tr>td.danger,.table>tbody>tr>th.danger,.table>tfoot>tr.danger>td,.table>tfoot>tr.danger>th,.table>tfoot>tr>td.danger,.table>tfoot>tr>th.danger,.table>thead>tr.danger>td,.table>thead>tr.danger>th,.table>thead>tr>td.danger,.table>thead>tr>th.danger{background-color:#f2dede}.table-hover>tbody>tr.danger:hover>td,.table-hover>tbody>tr.danger:hover>th,.table-hover>tbody>tr:hover>.danger,.table-hover>tbody>tr>td.danger:hover,.table-hover>tbody>tr>th.danger:hover{background-color:#ebcccc}.table-responsive{overflow-x:auto;min-height:.01%}@media screen and (max-width:767px){.table-responsive{width:100%;margin-bottom:15px;overflow-y:hidden;-ms-overflow-style:-ms-autohiding-scrollbar;border:1px solid #ddd}.table-responsive>.table{margin-bottom:0}.table-responsive>.table>tbody>tr>td,.table-responsive>.table>tbody>tr>th,.table-responsive>.table>tfoot>tr>td,.table-responsive>.table>tfoot>tr>th,.table-responsive>.table>thead>tr>td,.table-responsive>.table>thead>tr>th{white-space:nowrap}.table-responsive>.table-bordered{border:0}.table-responsive>.table-bordered>tbody>tr>td:first-child,.table-responsive>.table-bordered>tbody>tr>th:first-child,.table-responsive>.table-bordered>tfoot>tr>td:first-child,.table-responsive>.table-bordered>tfoot>tr>th:first-child,.table-responsive>.table-bordered>thead>tr>td:first-child,.table-responsive>.table-bordered>thead>tr>th:first-child{border-left:0}.table-responsive>.table-bordered>tbody>tr>td:last-child,.table-responsive>.table-bordered>tbody>tr>th:last-child,.table-responsive>.table-bordered>tfoot>tr>td:last-child,.table-responsive>.table-bordered>tfoot>tr>th:last-child,.table-responsive>.table-bordered>thead>tr>td:last-child,.table-responsive>.table-bordered>thead>tr>th:last-child{border-right:0}.table-responsive>.table-bordered>tbody>tr:last-child>td,.table-responsive>.table-bordered>tbody>tr:last-child>th,.table-responsive>.table-bordered>tfoot>tr:last-child>td,.table-responsive>.table-bordered>tfoot>tr:last-child>th{border-bottom:0}}fieldset,legend{padding:0;border:0}fieldset{margin:0;min-width:0}legend{width:100%;margin-bottom:20px;font-size:21px;line-height:inherit;border-bottom:1px solid #e5e5e5}label{display:inline-block;max-width:100%;margin-bottom:5px}input[type=search]{box-sizing:border-box;-webkit-appearance:none}input[type=checkbox],input[type=radio]{margin:4px 0 0;margin-top:1px\9;line-height:normal}.form-control,output{font-size:14px;line-height:1.42857143;color:#555;display:block}input[type=file]{display:block}input[type=range]{display:block;width:100%}select[multiple],select[size]{height:auto}input[type=file]:focus,input[type=checkbox]:focus,input[type=radio]:focus{outline:-webkit-focus-ring-color auto 5px;outline-offset:-2px}output{padding-top:7px}.form-control{width:100%;height:34px;padding:6px 12px;background-color:#fff;border:1px solid #ccc;border-radius:4px;box-shadow:inset 0 1px 1px rgba(0,0,0,.075);-webkit-transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s;transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s}.form-control:focus{border-color:#66afe9;outline:0;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 8px rgba(102,175,233,.6)}.form-control::-moz-placeholder{color:#999;opacity:1}.form-control:-ms-input-placeholder{color:#999}.form-control::-webkit-input-placeholder{color:#999}.has-success .checkbox,.has-success .checkbox-inline,.has-success .control-label,.has-success .form-control-feedback,.has-success .help-block,.has-success .radio,.has-success .radio-inline,.has-success.checkbox label,.has-success.checkbox-inline label,.has-success.radio label,.has-success.radio-inline label{color:#3c763d}.form-control::-ms-expand{border:0;background-color:transparent}.form-control[disabled],.form-control[readonly],fieldset[disabled] .form-control{background-color:#eee;opacity:1}.form-control[disabled],fieldset[disabled] .form-control{cursor:not-allowed}textarea.form-control{height:auto}@media screen and (-webkit-min-device-pixel-ratio:0){input[type=date].form-control,input[type=time].form-control,input[type=datetime-local].form-control,input[type=month].form-control{line-height:34px}.input-group-sm input[type=date],.input-group-sm input[type=time],.input-group-sm input[type=datetime-local],.input-group-sm input[type=month],input[type=date].input-sm,input[type=time].input-sm,input[type=datetime-local].input-sm,input[type=month].input-sm{line-height:30px}.input-group-lg input[type=date],.input-group-lg input[type=time],.input-group-lg input[type=datetime-local],.input-group-lg input[type=month],input[type=date].input-lg,input[type=time].input-lg,input[type=datetime-local].input-lg,input[type=month].input-lg{line-height:46px}}.form-group{margin-bottom:15px}.checkbox,.radio{position:relative;display:block;margin-top:10px;margin-bottom:10px}.checkbox label,.radio label{min-height:20px;padding-left:20px;margin-bottom:0;font-weight:400;cursor:pointer}.checkbox input[type=checkbox],.checkbox-inline input[type=checkbox],.radio input[type=radio],.radio-inline input[type=radio]{position:absolute;margin-left:-20px;margin-top:4px\9}.checkbox+.checkbox,.radio+.radio{margin-top:-5px}.checkbox-inline,.radio-inline{position:relative;display:inline-block;padding-left:20px;margin-bottom:0;vertical-align:middle;font-weight:400;cursor:pointer}.checkbox-inline+.checkbox-inline,.radio-inline+.radio-inline{margin-top:0;margin-left:10px}.checkbox-inline.disabled,.checkbox.disabled label,.radio-inline.disabled,.radio.disabled label,fieldset[disabled] .checkbox label,fieldset[disabled] .checkbox-inline,fieldset[disabled] .radio label,fieldset[disabled] .radio-inline,fieldset[disabled] input[type=checkbox],fieldset[disabled] input[type=radio],input[type=checkbox].disabled,input[type=checkbox][disabled],input[type=radio].disabled,input[type=radio][disabled]{cursor:not-allowed}.form-control-static{padding-top:7px;padding-bottom:7px;margin-bottom:0;min-height:34px}.form-control-static.input-lg,.form-control-static.input-sm{padding-left:0;padding-right:0}.form-group-sm .form-control,.input-sm{padding:5px 10px;border-radius:3px;font-size:12px}.input-sm{height:30px;line-height:1.5}select.input-sm{height:30px;line-height:30px}select[multiple].input-sm,textarea.input-sm{height:auto}.form-group-sm .form-control{height:30px;line-height:1.5}.form-group-lg .form-control,.input-lg{border-radius:6px;padding:10px 16px;font-size:18px}.form-group-sm select.form-control{height:30px;line-height:30px}.form-group-sm select[multiple].form-control,.form-group-sm textarea.form-control{height:auto}.form-group-sm .form-control-static{height:30px;min-height:32px;padding:6px 10px;font-size:12px;line-height:1.5}.input-lg{height:46px;line-height:1.3333333}select.input-lg{height:46px;line-height:46px}select[multiple].input-lg,textarea.input-lg{height:auto}.form-group-lg .form-control{height:46px;line-height:1.3333333}.form-group-lg select.form-control{height:46px;line-height:46px}.form-group-lg select[multiple].form-control,.form-group-lg textarea.form-control{height:auto}.form-group-lg .form-control-static{height:46px;min-height:38px;padding:11px 16px;font-size:18px;line-height:1.3333333}.has-feedback{position:relative}.has-feedback .form-control{padding-right:42.5px}.form-control-feedback{position:absolute;top:0;right:0;z-index:2;display:block;width:34px;height:34px;line-height:34px;text-align:center;pointer-events:none}.collapsing,.dropdown,.dropup{position:relative}.form-group-lg .form-control+.form-control-feedback,.input-group-lg+.form-control-feedback,.input-lg+.form-control-feedback{width:46px;height:46px;line-height:46px}.form-group-sm .form-control+.form-control-feedback,.input-group-sm+.form-control-feedback,.input-sm+.form-control-feedback{width:30px;height:30px;line-height:30px}.has-success .form-control{box-shadow:inset 0 1px 1px rgba(0,0,0,.075)}.has-success .form-control:focus{box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #67b168}.has-success .input-group-addon{color:#3c763d;border-color:#3c763d;background-color:#dff0d8}.has-warning .checkbox,.has-warning .checkbox-inline,.has-warning .control-label,.has-warning .form-control-feedback,.has-warning .help-block,.has-warning .radio,.has-warning .radio-inline,.has-warning.checkbox label,.has-warning.checkbox-inline label,.has-warning.radio label,.has-warning.radio-inline label{color:#8a6d3b}.has-warning .form-control{border-color:#8a6d3b;box-shadow:inset 0 1px 1px rgba(0,0,0,.075)}.has-warning .form-control:focus{border-color:#66512c;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #c0a16b}.has-warning .input-group-addon{color:#8a6d3b;border-color:#8a6d3b;background-color:#fcf8e3}.has-error .checkbox,.has-error .checkbox-inline,.has-error .control-label,.has-error .form-control-feedback,.has-error .help-block,.has-error .radio,.has-error .radio-inline,.has-error.checkbox label,.has-error.checkbox-inline label,.has-error.radio label,.has-error.radio-inline label{color:#a94442}.has-error .form-control{box-shadow:inset 0 1px 1px rgba(0,0,0,.075)}.has-error .form-control:focus{box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #ce8483}.has-error .input-group-addon{color:#a94442;border-color:#a94442;background-color:#f2dede}.has-feedback label~.form-control-feedback{top:25px}.has-feedback label.sr-only~.form-control-feedback{top:0}.help-block{display:block;margin-top:5px;margin-bottom:10px;color:#737373}@media (min-width:768px){.form-inline .form-control-static,.form-inline .form-group{display:inline-block}.form-inline .control-label,.form-inline .form-group{margin-bottom:0;vertical-align:middle}.form-inline .form-control{display:inline-block;width:auto;vertical-align:middle}.form-inline .input-group{display:inline-table;vertical-align:middle}.form-inline .input-group .form-control,.form-inline .input-group .input-group-addon,.form-inline .input-group .input-group-btn{width:auto}.form-inline .input-group>.form-control{width:100%}.form-inline .checkbox,.form-inline .radio{display:inline-block;margin-top:0;margin-bottom:0;vertical-align:middle}.form-inline .checkbox label,.form-inline .radio label{padding-left:0}.form-inline .checkbox input[type=checkbox],.form-inline .radio input[type=radio]{position:relative;margin-left:0}.form-inline .has-feedback .form-control-feedback{top:0}.form-horizontal .control-label{text-align:right;margin-bottom:0;padding-top:7px}}.form-horizontal .checkbox,.form-horizontal .checkbox-inline,.form-horizontal .radio,.form-horizontal .radio-inline{margin-top:0;margin-bottom:0;padding-top:7px}.form-horizontal .checkbox,.form-horizontal .radio{min-height:27px}.form-horizontal .form-group{margin-left:-15px;margin-right:-15px}.form-horizontal .has-feedback .form-control-feedback{right:15px}@media (min-width:768px){.form-horizontal .form-group-lg .control-label{padding-top:11px;font-size:18px}.form-horizontal .form-group-sm .control-label{padding-top:6px;font-size:12px}}.btn{display:inline-block;margin-bottom:0;font-weight:400;text-align:center;vertical-align:middle;-ms-touch-action:manipulation;touch-action:manipulation;cursor:pointer;border:1px solid transparent;white-space:nowrap;padding:6px 12px;font-size:14px;line-height:1.42857143;border-radius:4px;user-select:none}.btn.active.focus,.btn.active:focus,.btn.focus,.btn:active.focus,.btn:active:focus,.btn:focus{outline:-webkit-focus-ring-color auto 5px;outline-offset:-2px}.btn.focus,.btn:focus,.btn:hover{color:#333;text-decoration:none}.btn.active,.btn:active{outline:0;box-shadow:inset 0 3px 5px rgba(0,0,0,.125)}.btn.disabled,.btn[disabled],fieldset[disabled] .btn{cursor:not-allowed;opacity:.65;filter:alpha(opacity=65);box-shadow:none}a.btn.disabled,fieldset[disabled] a.btn{pointer-events:none}.btn-default{color:#333;background-color:#fff;border-color:#ccc}.btn-default.focus,.btn-default:focus{color:#333;background-color:#e6e6e6;border-color:#8c8c8c}.btn-default.active,.btn-default:active,.btn-default:hover,.open>.dropdown-toggle.btn-default{color:#333;background-color:#e6e6e6;border-color:#adadad}.btn-default.active.focus,.btn-default.active:focus,.btn-default.active:hover,.btn-default:active.focus,.btn-default:active:focus,.btn-default:active:hover,.open>.dropdown-toggle.btn-default.focus,.open>.dropdown-toggle.btn-default:focus,.open>.dropdown-toggle.btn-default:hover{color:#333;background-color:#d4d4d4;border-color:#8c8c8c}.btn-default.disabled.focus,.btn-default.disabled:focus,.btn-default.disabled:hover,.btn-default[disabled].focus,.btn-default[disabled]:focus,.btn-default[disabled]:hover,fieldset[disabled] .btn-default.focus,fieldset[disabled] .btn-default:focus,fieldset[disabled] .btn-default:hover{background-color:#fff;border-color:#ccc}.btn-default .badge{color:#fff;background-color:#333}.btn-primary{color:#fff;background-color:#00e5f0;border-color:#00cdd7}.btn-primary.focus,.btn-primary:focus{color:#fff;background-color:#00b4bd;border-color:#005357}.btn-primary.active,.btn-primary:active,.btn-primary:hover,.open>.dropdown-toggle.btn-primary{color:#fff;background-color:#00b4bd;border-color:#009299}.btn-primary.active.focus,.btn-primary.active:focus,.btn-primary.active:hover,.btn-primary:active.focus,.btn-primary:active:focus,.btn-primary:active:hover,.open>.dropdown-toggle.btn-primary.focus,.open>.dropdown-toggle.btn-primary:focus,.open>.dropdown-toggle.btn-primary:hover{color:#fff;background-color:#009299;border-color:#005357}.btn-primary.disabled.focus,.btn-primary.disabled:focus,.btn-primary.disabled:hover,.btn-primary[disabled].focus,.btn-primary[disabled]:focus,.btn-primary[disabled]:hover,fieldset[disabled] .btn-primary.focus,fieldset[disabled] .btn-primary:focus,fieldset[disabled] .btn-primary:hover{background-color:#00e5f0;border-color:#00cdd7}.btn-primary .badge{color:#00e5f0;background-color:#fff}.btn-success{color:#fff;background-color:#00e5f0;border-color:#00cdd7}.btn-success.focus,.btn-success:focus{color:#fff;background-color:#00b4bd;border-color:#005357}.btn-success.active,.btn-success:active,.btn-success:hover,.open>.dropdown-toggle.btn-success{color:#fff;background-color:#00b4bd;border-color:#009299}.btn-success.active.focus,.btn-success.active:focus,.btn-success.active:hover,.btn-success:active.focus,.btn-success:active:focus,.btn-success:active:hover,.open>.dropdown-toggle.btn-success.focus,.open>.dropdown-toggle.btn-success:focus,.open>.dropdown-toggle.btn-success:hover{color:#fff;background-color:#009299;border-color:#005357}.btn-success.active,.btn-success:active,.open>.dropdown-toggle.btn-success{background-image:none}.btn-success.disabled.focus,.btn-success.disabled:focus,.btn-success.disabled:hover,.btn-success[disabled].focus,.btn-success[disabled]:focus,.btn-success[disabled]:hover,fieldset[disabled] .btn-success.focus,fieldset[disabled] .btn-success:focus,fieldset[disabled] .btn-success:hover{background-color:#00e5f0;border-color:#00cdd7}.btn-success .badge{color:#00e5f0;background-color:#fff}.btn-info{color:#fff;background-color:#00e5f0;border-color:#00cdd7}.btn-info.focus,.btn-info:focus{color:#fff;background-color:#00b4bd;border-color:#005357}.btn-info.active,.btn-info:active,.btn-info:hover,.open>.dropdown-toggle.btn-info{color:#fff;background-color:#00b4bd;border-color:#009299}.btn-info.active.focus,.btn-info.active:focus,.btn-info.active:hover,.btn-info:active.focus,.btn-info:active:focus,.btn-info:active:hover,.open>.dropdown-toggle.btn-info.focus,.open>.dropdown-toggle.btn-info:focus,.open>.dropdown-toggle.btn-info:hover{color:#fff;background-color:#009299;border-color:#005357}.btn-info.disabled.focus,.btn-info.disabled:focus,.btn-info.disabled:hover,.btn-info[disabled].focus,.btn-info[disabled]:focus,.btn-info[disabled]:hover,fieldset[disabled] .btn-info.focus,fieldset[disabled] .btn-info:focus,fieldset[disabled] .btn-info:hover{background-color:#00e5f0;border-color:#00cdd7}.btn-info .badge{color:#00e5f0;background-color:#fff}.btn-warning{color:#fff;background-color:#977bf0;border-color:#8564ed}.btn-warning.focus,.btn-warning:focus{color:#fff;background-color:#734deb;border-color:#3d15bd}.btn-warning.active,.btn-warning:active,.btn-warning:hover,.open>.dropdown-toggle.btn-warning{color:#fff;background-color:#734deb;border-color:#5a2de7}.btn-warning.active.focus,.btn-warning.active:focus,.btn-warning.active:hover,.btn-warning:active.focus,.btn-warning:active:focus,.btn-warning:active:hover,.open>.dropdown-toggle.btn-warning.focus,.open>.dropdown-toggle.btn-warning:focus,.open>.dropdown-toggle.btn-warning:hover{color:#fff;background-color:#5a2de7;border-color:#3d15bd}.btn-warning.disabled.focus,.btn-warning.disabled:focus,.btn-warning.disabled:hover,.btn-warning[disabled].focus,.btn-warning[disabled]:focus,.btn-warning[disabled]:hover,fieldset[disabled] .btn-warning.focus,fieldset[disabled] .btn-warning:focus,fieldset[disabled] .btn-warning:hover{background-color:#977bf0;border-color:#8564ed}.btn-warning .badge{color:#977bf0;background-color:#fff}.btn-danger{color:#fff;background-color:#e01f74;border-color:#ca1c68}.btn-danger.focus,.btn-danger:focus{color:#fff;background-color:#b3195d;border-color:#5a0c2e}.btn-danger.active,.btn-danger:active,.btn-danger:hover,.open>.dropdown-toggle.btn-danger{color:#fff;background-color:#b3195d;border-color:#94144d}.btn-danger.active.focus,.btn-danger.active:focus,.btn-danger.active:hover,.btn-danger:active.focus,.btn-danger:active:focus,.btn-danger:active:hover,.open>.dropdown-toggle.btn-danger.focus,.open>.dropdown-toggle.btn-danger:focus,.open>.dropdown-toggle.btn-danger:hover{color:#fff;background-color:#94144d;border-color:#5a0c2e}.btn-danger.disabled.focus,.btn-danger.disabled:focus,.btn-danger.disabled:hover,.btn-danger[disabled].focus,.btn-danger[disabled]:focus,.btn-danger[disabled]:hover,fieldset[disabled] .btn-danger.focus,fieldset[disabled] .btn-danger:focus,fieldset[disabled] .btn-danger:hover{background-color:#e01f74;border-color:#ca1c68}.btn-danger .badge{color:#e01f74;background-color:#fff}.btn-link{color:#00e5f0;font-weight:400;border-radius:0}.btn-link,.btn-link.active,.btn-link:active,.btn-link[disabled],fieldset[disabled] .btn-link{background-color:transparent;box-shadow:none}.btn-link,.btn-link:active,.btn-link:focus,.btn-link:hover{border-color:transparent}.btn-link:focus,.btn-link:hover{color:#009ca3;text-decoration:underline;background-color:transparent}.btn-link[disabled]:focus,.btn-link[disabled]:hover,fieldset[disabled] .btn-link:focus,fieldset[disabled] .btn-link:hover{color:#777;text-decoration:none}.btn-group-lg>.btn,.btn-lg{padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}.btn-group-sm>.btn,.btn-sm{padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}.btn-group-xs>.btn,.btn-xs{padding:1px 5px;font-size:12px;line-height:1.5;border-radius:3px}.btn-block{display:block;width:100%}.btn-block+.btn-block{margin-top:5px}input[type=button].btn-block,input[type=reset].btn-block,input[type=submit].btn-block{width:100%}.fade{opacity:0;-webkit-transition:opacity .15s linear;transition:opacity .15s linear}.fade.in{opacity:1}.collapse{display:none}.collapse.in{display:block}tr.collapse.in{display:table-row}tbody.collapse.in{display:table-row-group}.collapsing{height:0;overflow:hidden;-webkit-transition-property:height,visibility;transition-property:height,visibility;-webkit-transition-duration:.35s;transition-duration:.35s;-webkit-transition-timing-function:ease;transition-timing-function:ease}.caret{display:inline-block;width:0;height:0;margin-left:2px;vertical-align:middle;border-top:4px dashed;border-top:4px solid\9;border-right:4px solid transparent;border-left:4px solid transparent}.dropdown-toggle:focus{outline:0}.dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;display:none;min-width:160px;padding:5px 0;margin:2px 0 0;list-style:none;font-size:14px;text-align:left;background-color:#fff;border:1px solid #ccc;border:1px solid rgba(0,0,0,.15);border-radius:4px;box-shadow:0 6px 12px rgba(0,0,0,.175);background-clip:padding-box}.dropdown-menu-right,.dropdown-menu.pull-right{left:auto;right:0}.dropdown-header,.dropdown-menu>li>a{display:block;padding:3px 20px;line-height:1.42857143;white-space:nowrap}.dropdown-menu .divider{height:1px;margin:9px 0;overflow:hidden;background-color:#e5e5e5}.dropdown-menu>li>a{clear:both;font-weight:400;color:#333}.dropdown-menu>li>a:focus,.dropdown-menu>li>a:hover{text-decoration:none;color:#262626;background-color:#f5f5f5}.dropdown-menu>.active>a,.dropdown-menu>.active>a:focus,.dropdown-menu>.active>a:hover{color:#fff;text-decoration:none;outline:0;background-color:#00e5f0}.dropdown-menu>.disabled>a,.dropdown-menu>.disabled>a:focus,.dropdown-menu>.disabled>a:hover{color:#777}.dropdown-menu>.disabled>a:focus,.dropdown-menu>.disabled>a:hover{text-decoration:none;background-color:transparent;filter:progid:DXImageTransform.Microsoft.gradient(enabled=false);cursor:not-allowed}.open>.dropdown-menu{display:block}.open>a{outline:0}.dropdown-menu-left{left:0;right:auto}.dropdown-header{font-size:12px;color:#777}.dropdown-backdrop{position:fixed;left:0;right:0;bottom:0;top:0;z-index:990}.nav-justified>.dropdown .dropdown-menu,.nav-tabs.nav-justified>.dropdown .dropdown-menu{top:auto;left:auto}.pull-right>.dropdown-menu{right:0;left:auto}.dropup .caret,.navbar-fixed-bottom .dropdown .caret{border-top:0;border-bottom:4px dashed;border-bottom:4px solid\9;content:""}.dropup .dropdown-menu,.navbar-fixed-bottom .dropdown .dropdown-menu{top:auto;bottom:100%;margin-bottom:2px}@media (min-width:768px){.navbar-right .dropdown-menu{left:auto;right:0}.navbar-right .dropdown-menu-left{left:0;right:auto}}.btn-group,.btn-group-vertical{position:relative;display:inline-block;vertical-align:middle}.btn-group-vertical>.btn,.btn-group>.btn{position:relative;float:left}.btn-group-vertical>.btn.active,.btn-group-vertical>.btn:active,.btn-group-vertical>.btn:focus,.btn-group-vertical>.btn:hover,.btn-group>.btn.active,.btn-group>.btn:active,.btn-group>.btn:focus,.btn-group>.btn:hover{z-index:2}.btn-group .btn+.btn,.btn-group .btn+.btn-group,.btn-group .btn-group+.btn,.btn-group .btn-group+.btn-group{margin-left:-1px}.btn-toolbar{margin-left:-5px}.btn-toolbar>.btn,.btn-toolbar>.btn-group,.btn-toolbar>.input-group{margin-left:5px}.btn .caret,.btn-group>.btn:first-child{margin-left:0}.btn-group>.btn:not(:first-child):not(:last-child):not(.dropdown-toggle){border-radius:0}.btn-group>.btn:first-child:not(:last-child):not(.dropdown-toggle){border-bottom-right-radius:0;border-top-right-radius:0}.btn-group>.btn:last-child:not(:first-child),.btn-group>.dropdown-toggle:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0}.btn-group>.btn-group:not(:first-child):not(:last-child)>.btn{border-radius:0}.btn-group>.btn-group:first-child:not(:last-child)>.btn:last-child,.btn-group>.btn-group:first-child:not(:last-child)>.dropdown-toggle{border-bottom-right-radius:0;border-top-right-radius:0}.btn-group>.btn-group:last-child:not(:first-child)>.btn:first-child{border-bottom-left-radius:0;border-top-left-radius:0}.btn-group .dropdown-toggle:active,.btn-group.open .dropdown-toggle{outline:0}.btn-group>.btn+.dropdown-toggle{padding-left:8px;padding-right:8px}.btn-group>.btn-lg+.dropdown-toggle{padding-left:12px;padding-right:12px}.btn-group.open .dropdown-toggle{box-shadow:inset 0 3px 5px rgba(0,0,0,.125)}.btn-group.open .dropdown-toggle.btn-link{box-shadow:none}.btn-lg .caret{border-width:5px 5px 0}.dropup .btn-lg .caret{border-width:0 5px 5px}.btn-group-vertical>.btn,.btn-group-vertical>.btn-group,.btn-group-vertical>.btn-group>.btn{display:block;float:none;width:100%;max-width:100%}.btn-group-vertical>.btn-group>.btn{float:none}.btn-group-vertical>.btn+.btn,.btn-group-vertical>.btn+.btn-group,.btn-group-vertical>.btn-group+.btn,.btn-group-vertical>.btn-group+.btn-group{margin-top:-1px;margin-left:0}.btn-group-vertical>.btn:not(:first-child):not(:last-child){border-radius:0}.btn-group-vertical>.btn:first-child:not(:last-child){border-radius:4px 4px 0 0}.btn-group-vertical>.btn:last-child:not(:first-child){border-radius:0 0 4px 4px}.btn-group-vertical>.btn-group:not(:first-child):not(:last-child)>.btn{border-radius:0}.btn-group-vertical>.btn-group:first-child:not(:last-child)>.btn:last-child,.btn-group-vertical>.btn-group:first-child:not(:last-child)>.dropdown-toggle{border-bottom-right-radius:0;border-bottom-left-radius:0}.btn-group-vertical>.btn-group:last-child:not(:first-child)>.btn:first-child{border-top-right-radius:0;border-top-left-radius:0}.btn-group-justified{display:table;width:100%;table-layout:fixed;border-collapse:separate}.btn-group-justified>.btn,.btn-group-justified>.btn-group{float:none;display:table-cell;width:1%}.btn-group-justified>.btn-group .btn{width:100%}.btn-group-justified>.btn-group .dropdown-menu{left:auto}[data-toggle=buttons]>.btn input[type=checkbox],[data-toggle=buttons]>.btn input[type=radio],[data-toggle=buttons]>.btn-group>.btn input[type=checkbox],[data-toggle=buttons]>.btn-group>.btn input[type=radio]{position:absolute;clip:rect(0,0,0,0);pointer-events:none}.input-group{position:relative;display:table;border-collapse:separate}.input-group[class*=col-]{float:none;padding-left:0;padding-right:0}.input-group .form-control{position:relative;z-index:2;float:left;width:100%;margin-bottom:0}.input-group .form-control:focus{z-index:3}.input-group-lg>.form-control,.input-group-lg>.input-group-addon,.input-group-lg>.input-group-btn>.btn{height:46px;padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}select.input-group-lg>.form-control,select.input-group-lg>.input-group-addon,select.input-group-lg>.input-group-btn>.btn{height:46px;line-height:46px}select[multiple].input-group-lg>.form-control,select[multiple].input-group-lg>.input-group-addon,select[multiple].input-group-lg>.input-group-btn>.btn,textarea.input-group-lg>.form-control,textarea.input-group-lg>.input-group-addon,textarea.input-group-lg>.input-group-btn>.btn{height:auto}.input-group-sm>.form-control,.input-group-sm>.input-group-addon,.input-group-sm>.input-group-btn>.btn{height:30px;padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}select.input-group-sm>.form-control,select.input-group-sm>.input-group-addon,select.input-group-sm>.input-group-btn>.btn{height:30px;line-height:30px}select[multiple].input-group-sm>.form-control,select[multiple].input-group-sm>.input-group-addon,select[multiple].input-group-sm>.input-group-btn>.btn,textarea.input-group-sm>.form-control,textarea.input-group-sm>.input-group-addon,textarea.input-group-sm>.input-group-btn>.btn{height:auto}.input-group .form-control,.input-group-addon,.input-group-btn{display:table-cell}.nav>li,.nav>li>a{display:block;position:relative}.input-group .form-control:not(:first-child):not(:last-child),.input-group-addon:not(:first-child):not(:last-child),.input-group-btn:not(:first-child):not(:last-child){border-radius:0}.input-group-addon,.input-group-btn{width:1%;white-space:nowrap;vertical-align:middle}.input-group-addon{padding:6px 12px;font-size:14px;font-weight:400;line-height:1;color:#555;text-align:center;background-color:#eee;border:1px solid #ccc;border-radius:4px}.input-group-addon.input-sm{padding:5px 10px;font-size:12px;border-radius:3px}.input-group-addon.input-lg{padding:10px 16px;font-size:18px;border-radius:6px}.input-group-addon input[type=checkbox],.input-group-addon input[type=radio]{margin-top:0}.input-group .form-control:first-child,.input-group-addon:first-child,.input-group-btn:first-child>.btn,.input-group-btn:first-child>.btn-group>.btn,.input-group-btn:first-child>.dropdown-toggle,.input-group-btn:last-child>.btn-group:not(:last-child)>.btn,.input-group-btn:last-child>.btn:not(:last-child):not(.dropdown-toggle){border-bottom-right-radius:0;border-top-right-radius:0}.input-group-addon:first-child{border-right:0}.input-group .form-control:last-child,.input-group-addon:last-child,.input-group-btn:first-child>.btn-group:not(:first-child)>.btn,.input-group-btn:first-child>.btn:not(:first-child),.input-group-btn:last-child>.btn,.input-group-btn:last-child>.btn-group>.btn,.input-group-btn:last-child>.dropdown-toggle{border-bottom-left-radius:0;border-top-left-radius:0}.input-group-addon:last-child{border-left:0}.input-group-btn{position:relative;font-size:0;white-space:nowrap}.input-group-btn>.btn{position:relative}.input-group-btn>.btn+.btn{margin-left:-1px}.input-group-btn>.btn:active,.input-group-btn>.btn:focus,.input-group-btn>.btn:hover{z-index:2}.input-group-btn:first-child>.btn,.input-group-btn:first-child>.btn-group{margin-right:-1px}.input-group-btn:last-child>.btn,.input-group-btn:last-child>.btn-group{z-index:2;margin-left:-1px}.nav{margin-bottom:0;padding-left:0;list-style:none}.nav>li>a{padding:10px 15px}.nav>li>a:focus,.nav>li>a:hover{text-decoration:none;background-color:#eee}.nav>li.disabled>a{color:#777}.nav>li.disabled>a:focus,.nav>li.disabled>a:hover{color:#777;text-decoration:none;background-color:transparent;cursor:not-allowed}.nav .open>a,.nav .open>a:focus,.nav .open>a:hover{background-color:#eee;border-color:#00e5f0}.nav .nav-divider{height:1px;margin:9px 0;overflow:hidden;background-color:#e5e5e5}.nav>li>a>img{max-width:none}.nav-tabs{border-bottom:1px solid #ddd}.nav-tabs>li{float:left;margin-bottom:-1px}.nav-tabs>li>a{margin-right:2px;line-height:1.42857143;border:1px solid transparent;border-radius:4px 4px 0 0}.nav-tabs>li>a:hover{border-color:#eee #eee #ddd}.nav-tabs>li.active>a,.nav-tabs>li.active>a:focus,.nav-tabs>li.active>a:hover{color:#555;background-color:#fff;border:1px solid #ddd;border-bottom-color:transparent;cursor:default}.nav-tabs.nav-justified{width:100%;border-bottom:0}.nav-tabs.nav-justified>li{float:none}.nav-tabs.nav-justified>li>a{text-align:center;margin-bottom:5px;margin-right:0;border-radius:4px}.nav-tabs.nav-justified>.active>a,.nav-tabs.nav-justified>.active>a:focus,.nav-tabs.nav-justified>.active>a:hover{border:1px solid #ddd}@media (min-width:768px){.nav-tabs.nav-justified>li{display:table-cell;width:1%}.nav-tabs.nav-justified>li>a{margin-bottom:0;border-bottom:1px solid #ddd;border-radius:4px 4px 0 0}.nav-tabs.nav-justified>.active>a,.nav-tabs.nav-justified>.active>a:focus,.nav-tabs.nav-justified>.active>a:hover{border-bottom-color:#fff}}.nav-pills>li{float:left}.nav-justified>li,.nav-stacked>li{float:none}.nav-pills>li>a{border-radius:4px}.nav-pills>li+li{margin-left:2px}.nav-pills>li.active>a,.nav-pills>li.active>a:focus,.nav-pills>li.active>a:hover{color:#fff;background-color:#00e5f0}.nav-stacked>li+li{margin-top:2px;margin-left:0}.nav-justified{width:100%}.nav-justified>li>a{text-align:center;margin-bottom:5px}.nav-tabs-justified{border-bottom:0}.nav-tabs-justified>li>a{margin-right:0;border-radius:4px}.nav-tabs-justified>.active>a,.nav-tabs-justified>.active>a:focus,.nav-tabs-justified>.active>a:hover{border:1px solid #ddd}@media (min-width:768px){.nav-justified>li{display:table-cell;width:1%}.nav-justified>li>a{margin-bottom:0}.nav-tabs-justified>li>a{border-bottom:1px solid #ddd;border-radius:4px 4px 0 0}.nav-tabs-justified>.active>a,.nav-tabs-justified>.active>a:focus,.nav-tabs-justified>.active>a:hover{border-bottom-color:#fff}}.tab-content>.tab-pane{display:none}.tab-content>.active{display:block}.nav-tabs .dropdown-menu{margin-top:-1px;border-top-right-radius:0;border-top-left-radius:0}.navbar{position:relative;min-height:50px;margin-bottom:20px;border:1px solid transparent}.navbar-collapse{overflow-x:visible;padding-right:15px;padding-left:15px;border-top:1px solid transparent;box-shadow:inset 0 1px 0 rgba(255,255,255,.1);-webkit-overflow-scrolling:touch}.navbar-collapse.in{overflow-y:auto}@media (min-width:768px){.navbar{border-radius:4px}.navbar-header{float:left}.navbar-collapse{width:auto;border-top:0;box-shadow:none}.navbar-collapse.collapse{display:block!important;height:auto!important;padding-bottom:0;overflow:visible!important}.navbar-collapse.in{overflow-y:visible}.navbar-fixed-bottom .navbar-collapse,.navbar-fixed-top .navbar-collapse,.navbar-static-top .navbar-collapse{padding-left:0;padding-right:0}}.analytics pre,.carousel-inner,.embed-responsive,.media,.media-body,.modal,.modal-open,.progress{overflow:hidden}@media (max-device-width:480px) and (orientation:landscape){.navbar-fixed-bottom .navbar-collapse,.navbar-fixed-top .navbar-collapse{max-height:200px}}.container-fluid>.navbar-collapse,.container-fluid>.navbar-header,.container>.navbar-collapse,.container>.navbar-header{margin-right:-15px;margin-left:-15px}.navbar-static-top{z-index:1000;border-width:0 0 1px}.navbar-fixed-bottom,.navbar-fixed-top{position:fixed;right:0;left:0;z-index:1030}.navbar-fixed-top{top:0;border-width:0 0 1px}.navbar-fixed-bottom{bottom:0;margin-bottom:0;border-width:1px 0 0}.navbar-brand{float:left;padding:15px;font-size:18px;line-height:20px;height:50px}.navbar-brand:focus,.navbar-brand:hover{text-decoration:none}.navbar-brand>img{display:block}@media (min-width:768px){.container-fluid>.navbar-collapse,.container-fluid>.navbar-header,.container>.navbar-collapse,.container>.navbar-header{margin-right:0;margin-left:0}.navbar-fixed-bottom,.navbar-fixed-top,.navbar-static-top{border-radius:0}.navbar>.container .navbar-brand,.navbar>.container-fluid .navbar-brand{margin-left:-15px}}.navbar-toggle{position:relative;float:right;margin-right:15px;padding:9px 10px;margin-top:8px;margin-bottom:8px;background-color:transparent;border:1px solid transparent;border-radius:4px}.navbar-toggle:focus{outline:0}.navbar-toggle .icon-bar{display:block;width:22px;height:2px;border-radius:1px}.navbar-toggle .icon-bar+.icon-bar{margin-top:4px}.navbar-nav{margin:7.5px -15px}.navbar-nav>li>a{padding-top:10px;padding-bottom:10px;line-height:20px}@media (max-width:767px){.navbar-nav .open .dropdown-menu{position:static;float:none;width:auto;margin-top:0;background-color:transparent;border:0;box-shadow:none}.navbar-nav .open .dropdown-menu .dropdown-header,.navbar-nav .open .dropdown-menu>li>a{padding:5px 15px 5px 25px}.navbar-nav .open .dropdown-menu>li>a{line-height:20px}.navbar-nav .open .dropdown-menu>li>a:focus,.navbar-nav .open .dropdown-menu>li>a:hover{background-image:none}}.progress-bar-striped,.progress-striped .progress-bar,.progress-striped .progress-bar-success{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}@media (min-width:768px){.navbar-toggle{display:none}.navbar-nav{float:left;margin:0}.navbar-nav>li{float:left}.navbar-nav>li>a{padding-top:15px;padding-bottom:15px}}.navbar-form{padding:10px 15px;border-top:1px solid transparent;border-bottom:1px solid transparent;box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 1px 0 rgba(255,255,255,.1);margin:8px -15px}@media (min-width:768px){.navbar-form .form-control-static,.navbar-form .form-group{display:inline-block}.navbar-form .control-label,.navbar-form .form-group{margin-bottom:0;vertical-align:middle}.navbar-form .form-control{display:inline-block;width:auto;vertical-align:middle}.navbar-form .input-group{display:inline-table;vertical-align:middle}.navbar-form .input-group .form-control,.navbar-form .input-group .input-group-addon,.navbar-form .input-group .input-group-btn{width:auto}.navbar-form .input-group>.form-control{width:100%}.navbar-form .checkbox,.navbar-form .radio{display:inline-block;margin-top:0;margin-bottom:0;vertical-align:middle}.navbar-form .checkbox label,.navbar-form .radio label{padding-left:0}.navbar-form .checkbox input[type=checkbox],.navbar-form .radio input[type=radio]{position:relative;margin-left:0}.navbar-form .has-feedback .form-control-feedback{top:0}.navbar-form{width:auto;border:0;margin-left:0;margin-right:0;padding-top:0;padding-bottom:0;box-shadow:none}}.breadcrumb>li,.pagination{display:inline-block}.btn .badge,.btn .label{top:-1px;position:relative}@media (max-width:767px){.navbar-form .form-group{margin-bottom:5px}.navbar-form .form-group:last-child{margin-bottom:0}}.navbar-nav>li>.dropdown-menu{margin-top:0;border-top-right-radius:0;border-top-left-radius:0}.navbar-fixed-bottom .navbar-nav>li>.dropdown-menu{margin-bottom:0;border-radius:4px 4px 0 0}.navbar-btn{margin-top:8px;margin-bottom:8px}.navbar-btn.btn-sm{margin-top:10px;margin-bottom:10px}.navbar-btn.btn-xs{margin-top:14px;margin-bottom:14px}.navbar-text{margin-top:15px;margin-bottom:15px}@media (min-width:768px){.navbar-text{float:left;margin-left:15px;margin-right:15px}.navbar-left{float:left!important}.navbar-right{float:right!important;margin-right:-15px}.navbar-right~.navbar-right{margin-right:0}}.navbar-default{background-color:#f8f8f8;border-color:#e7e7e7}.navbar-default .navbar-brand{color:#777}.navbar-default .navbar-brand:focus,.navbar-default .navbar-brand:hover{color:#5e5e5e;background-color:transparent}.navbar-default .navbar-nav>li>a,.navbar-default .navbar-text{color:#777}.navbar-default .navbar-nav>li>a:focus,.navbar-default .navbar-nav>li>a:hover{color:#333;background-color:transparent}.navbar-default .navbar-nav>.active>a,.navbar-default .navbar-nav>.active>a:focus,.navbar-default .navbar-nav>.active>a:hover{color:#555;background-color:#e7e7e7}.navbar-default .navbar-nav>.disabled>a,.navbar-default .navbar-nav>.disabled>a:focus,.navbar-default .navbar-nav>.disabled>a:hover{color:#ccc;background-color:transparent}.navbar-default .navbar-toggle{border-color:#ddd}.navbar-default .navbar-toggle:focus,.navbar-default .navbar-toggle:hover{background-color:#ddd}.navbar-default .navbar-toggle .icon-bar{background-color:#888}.navbar-default .navbar-collapse,.navbar-default .navbar-form{border-color:#e7e7e7}.navbar-default .navbar-nav>.open>a,.navbar-default .navbar-nav>.open>a:focus,.navbar-default .navbar-nav>.open>a:hover{background-color:#e7e7e7;color:#555}@media (max-width:767px){.navbar-default .navbar-nav .open .dropdown-menu>li>a{color:#777}.navbar-default .navbar-nav .open .dropdown-menu>li>a:focus,.navbar-default .navbar-nav .open .dropdown-menu>li>a:hover{color:#333;background-color:transparent}.navbar-default .navbar-nav .open .dropdown-menu>.active>a,.navbar-default .navbar-nav .open .dropdown-menu>.active>a:focus,.navbar-default .navbar-nav .open .dropdown-menu>.active>a:hover{color:#555;background-color:#e7e7e7}.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a,.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a:focus,.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a:hover{color:#ccc;background-color:transparent}}.navbar-default .navbar-link{color:#777}.navbar-default .navbar-link:hover{color:#333}.navbar-default .btn-link{color:#777}.navbar-default .btn-link:focus,.navbar-default .btn-link:hover{color:#333}.navbar-default .btn-link[disabled]:focus,.navbar-default .btn-link[disabled]:hover,fieldset[disabled] .navbar-default .btn-link:focus,fieldset[disabled] .navbar-default .btn-link:hover{color:#ccc}.navbar-inverse{background-color:#222;border-color:#080808}.navbar-inverse .navbar-brand{color:#9d9d9d}.navbar-inverse .navbar-brand:focus,.navbar-inverse .navbar-brand:hover{color:#fff;background-color:transparent}.navbar-inverse .navbar-nav>li>a,.navbar-inverse .navbar-text{color:#9d9d9d}.navbar-inverse .navbar-nav>li>a:focus,.navbar-inverse .navbar-nav>li>a:hover{color:#fff;background-color:transparent}.navbar-inverse .navbar-nav>.active>a,.navbar-inverse .navbar-nav>.active>a:focus,.navbar-inverse .navbar-nav>.active>a:hover{color:#fff;background-color:#080808}.navbar-inverse .navbar-nav>.disabled>a,.navbar-inverse .navbar-nav>.disabled>a:focus,.navbar-inverse .navbar-nav>.disabled>a:hover{color:#444;background-color:transparent}.navbar-inverse .navbar-toggle{border-color:#333}.navbar-inverse .navbar-toggle:focus,.navbar-inverse .navbar-toggle:hover{background-color:#333}.navbar-inverse .navbar-toggle .icon-bar{background-color:#fff}.navbar-inverse .navbar-collapse,.navbar-inverse .navbar-form{border-color:#101010}.navbar-inverse .navbar-nav>.open>a,.navbar-inverse .navbar-nav>.open>a:focus,.navbar-inverse .navbar-nav>.open>a:hover{background-color:#080808;color:#fff}@media (max-width:767px){.navbar-inverse .navbar-nav .open .dropdown-menu>.dropdown-header{border-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu .divider{background-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu>li>a{color:#9d9d9d}.navbar-inverse .navbar-nav .open .dropdown-menu>li>a:focus,.navbar-inverse .navbar-nav .open .dropdown-menu>li>a:hover{color:#fff;background-color:transparent}.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a,.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a:focus,.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a:hover{color:#fff;background-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a,.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a:focus,.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a:hover{color:#444;background-color:transparent}}.navbar-inverse .navbar-link{color:#9d9d9d}.navbar-inverse .navbar-link:hover{color:#fff}.navbar-inverse .btn-link{color:#9d9d9d}.navbar-inverse .btn-link:focus,.navbar-inverse .btn-link:hover{color:#fff}.navbar-inverse .btn-link[disabled]:focus,.navbar-inverse .btn-link[disabled]:hover,fieldset[disabled] .navbar-inverse .btn-link:focus,fieldset[disabled] .navbar-inverse .btn-link:hover{color:#444}.breadcrumb{padding:8px 15px;margin-bottom:20px;list-style:none;background-color:#f5f5f5;border-radius:4px}.breadcrumb>li+li:before{content:"/\00a0";padding:0 5px;color:#ccc}.breadcrumb>.active{color:#777}.pagination{padding-left:0;margin:20px 0;border-radius:4px}.pager li,.pagination>li{display:inline}.pagination>li>a,.pagination>li>span{position:relative;float:left;padding:6px 12px;line-height:1.42857143;text-decoration:none;color:#00e5f0;background-color:#fff;border:1px solid #ddd;margin-left:-1px}.pagination>li:first-child>a,.pagination>li:first-child>span{margin-left:0;border-bottom-left-radius:4px;border-top-left-radius:4px}.pagination>li:last-child>a,.pagination>li:last-child>span{border-bottom-right-radius:4px;border-top-right-radius:4px}.pagination>li>a:focus,.pagination>li>a:hover,.pagination>li>span:focus,.pagination>li>span:hover{z-index:2;color:#009ca3;background-color:#eee;border-color:#ddd}.pagination>.active>a,.pagination>.active>a:focus,.pagination>.active>a:hover,.pagination>.active>span,.pagination>.active>span:focus,.pagination>.active>span:hover{z-index:3;color:#fff;background-color:#00e5f0;border-color:#00e5f0;cursor:default}.pagination>.disabled>a,.pagination>.disabled>a:focus,.pagination>.disabled>a:hover,.pagination>.disabled>span,.pagination>.disabled>span:focus,.pagination>.disabled>span:hover{color:#777;background-color:#fff;border-color:#ddd;cursor:not-allowed}.pagination-lg>li>a,.pagination-lg>li>span{padding:10px 16px;font-size:18px;line-height:1.3333333}.pagination-lg>li:first-child>a,.pagination-lg>li:first-child>span{border-bottom-left-radius:6px;border-top-left-radius:6px}.pagination-lg>li:last-child>a,.pagination-lg>li:last-child>span{border-bottom-right-radius:6px;border-top-right-radius:6px}.pagination-sm>li>a,.pagination-sm>li>span{padding:5px 10px;font-size:12px;line-height:1.5}.badge,.label{font-weight:700;line-height:1;white-space:nowrap;text-align:center}.pagination-sm>li:first-child>a,.pagination-sm>li:first-child>span{border-bottom-left-radius:3px;border-top-left-radius:3px}.pagination-sm>li:last-child>a,.pagination-sm>li:last-child>span{border-bottom-right-radius:3px;border-top-right-radius:3px}.pager{padding-left:0;margin:20px 0;list-style:none;text-align:center}.pager li>a,.pager li>span{display:inline-block;padding:5px 14px;background-color:#fff;border:1px solid #ddd;border-radius:15px}.pager li>a:focus,.pager li>a:hover{text-decoration:none;background-color:#eee}.pager .next>a,.pager .next>span{float:right}.pager .previous>a,.pager .previous>span{float:left}.pager .disabled>a,.pager .disabled>a:focus,.pager .disabled>a:hover,.pager .disabled>span{color:#777;background-color:#fff;cursor:not-allowed}a.badge:focus,a.badge:hover,a.label:focus,a.label:hover{color:#fff;cursor:pointer;text-decoration:none}.label{display:inline;padding:.2em .6em .3em;font-size:75%;color:#fff;border-radius:.25em}.label:empty{display:none}.label-default{background-color:#777}.label-default[href]:focus,.label-default[href]:hover{background-color:#5e5e5e}.label-primary{background-color:#00e5f0}.label-primary[href]:focus,.label-primary[href]:hover{background-color:#00b4bd}.label-success{background-color:#00e5f0}.label-success[href]:focus,.label-success[href]:hover{background-color:#00b4bd}.label-info{background-color:#00e5f0}.label-info[href]:focus,.label-info[href]:hover{background-color:#00b4bd}.label-warning{background-color:#977bf0}.label-warning[href]:focus,.label-warning[href]:hover{background-color:#734deb}.label-danger{background-color:#e01f74}.label-danger[href]:focus,.label-danger[href]:hover{background-color:#b3195d}.badge{display:inline-block;min-width:10px;padding:3px 7px;font-size:12px;color:#fff;vertical-align:middle;background-color:#777;border-radius:10px}.badge:empty{display:none}.media-object,.thumbnail{display:block}.btn-group-xs>.btn .badge,.btn-xs .badge{top:0;padding:1px 5px}.list-group-item.active>.badge,.nav-pills>.active>a>.badge{color:#00e5f0;background-color:#fff}.jumbotron,.jumbotron .h1,.jumbotron h1{color:inherit}.list-group-item>.badge{float:right}.list-group-item>.badge+.badge{margin-right:5px}.nav-pills>li>a>.badge{margin-left:3px}.jumbotron{padding-top:30px;padding-bottom:30px;margin-bottom:30px;background-color:#eee}.jumbotron p{margin-bottom:15px;font-size:21px;font-weight:200}.alert,.thumbnail{margin-bottom:20px}.alert .alert-link,.close{font-weight:700}.jumbotron>hr{border-top-color:#d5d5d5}.container .jumbotron,.container-fluid .jumbotron{border-radius:6px;padding-left:15px;padding-right:15px}.jumbotron .container{max-width:100%}@media screen and (min-width:768px){.jumbotron{padding-top:48px;padding-bottom:48px}.container .jumbotron,.container-fluid .jumbotron{padding-left:60px;padding-right:60px}.jumbotron .h1,.jumbotron h1{font-size:63px}}.thumbnail{padding:4px;line-height:1.42857143;background-color:#fff;border:1px solid #ddd;border-radius:4px;-webkit-transition:border .2s ease-in-out;transition:border .2s ease-in-out}.thumbnail a>img,.thumbnail>img{margin-left:auto;margin-right:auto}a.thumbnail.active,a.thumbnail:focus,a.thumbnail:hover{border-color:#00e5f0}.thumbnail .caption{padding:9px;color:#333}.alert{padding:15px;border:1px solid transparent;border-radius:4px}.alert h4{margin-top:0;color:inherit}.alert>p,.alert>ul{margin-bottom:0}.alert>p+p{margin-top:5px}.alert-dismissable,.alert-dismissible{padding-right:35px}.alert-dismissable .close,.alert-dismissible .close{position:relative;top:-2px;right:-21px;color:inherit}.modal,.modal-backdrop{top:0;right:0;bottom:0;left:0}.alert-success{background-color:#dff0d8;border-color:#d6e9c6;color:#3c763d}.alert-success hr{border-top-color:#c9e2b3}.alert-success .alert-link{color:#2b542c}.alert-info{background-color:#d9edf7;border-color:#bce8f1;color:#31708f}.alert-info hr{border-top-color:#a6e1ec}.alert-info .alert-link{color:#245269}.alert-warning{background-color:#fcf8e3;border-color:#faebcc;color:#8a6d3b}.alert-warning hr{border-top-color:#f7e1b5}.alert-warning .alert-link{color:#66512c}.alert-danger{background-color:#f2dede;border-color:#ebccd1;color:#a94442}.alert-danger hr{border-top-color:#e4b9c0}.alert-danger .alert-link{color:#843534}@-webkit-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}.progress{height:20px;margin-bottom:20px;background-color:#f5f5f5;border-radius:4px;box-shadow:inset 0 1px 2px rgba(0,0,0,.1)}.progress-bar,.progress-bar-info,.progress-bar-success{background-color:#00e5f0}.progress-bar{float:left;width:0%;height:100%;font-size:12px;line-height:20px;color:#fff;text-align:center;box-shadow:inset 0 -1px 0 rgba(0,0,0,.15);-webkit-transition:width .6s ease;transition:width .6s ease}.progress-bar-striped,.progress-striped .progress-bar{background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-size:40px 40px}.progress-bar.active,.progress.active .progress-bar{-webkit-animation:progress-bar-stripes 2s linear infinite;animation:progress-bar-stripes 2s linear infinite}.progress-striped .progress-bar-success{background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-striped .progress-bar-info,.progress-striped .progress-bar-warning{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-striped .progress-bar-info{background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-bar-warning{background-color:#977bf0}.progress-striped .progress-bar-warning{background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-bar-danger{background-color:#e01f74}.progress-striped .progress-bar-danger{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.media{margin-top:15px}.media:first-child{margin-top:0}.media,.media-body{zoom:1}.media-body{width:10000px}.media-object.img-thumbnail{max-width:none}.media-right,.media>.pull-right{padding-left:10px}.media-left,.media>.pull-left{padding-right:10px}.media-body,.media-left,.media-right{display:table-cell;vertical-align:top}.media-middle{vertical-align:middle}.media-bottom{vertical-align:bottom}.media-heading{margin-top:0;margin-bottom:5px}.media-list{padding-left:0;list-style:none}.list-group{margin-bottom:20px;padding-left:0}.list-group-item{position:relative;display:block;padding:10px 15px;margin-bottom:-1px;background-color:#fff;border:1px solid #ddd}.list-group-item:first-child{border-top-right-radius:4px;border-top-left-radius:4px}.list-group-item:last-child{margin-bottom:0;border-bottom-right-radius:4px;border-bottom-left-radius:4px}a.list-group-item,button.list-group-item{color:#555}a.list-group-item .list-group-item-heading,button.list-group-item .list-group-item-heading{color:#333}a.list-group-item:focus,a.list-group-item:hover,button.list-group-item:focus,button.list-group-item:hover{text-decoration:none;color:#555;background-color:#f5f5f5}button.list-group-item{width:100%;text-align:left}.list-group-item.disabled,.list-group-item.disabled:focus,.list-group-item.disabled:hover{background-color:#eee;color:#777;cursor:not-allowed}.list-group-item.disabled .list-group-item-heading,.list-group-item.disabled:focus .list-group-item-heading,.list-group-item.disabled:hover .list-group-item-heading{color:inherit}.list-group-item.disabled .list-group-item-text,.list-group-item.disabled:focus .list-group-item-text,.list-group-item.disabled:hover .list-group-item-text{color:#777}.list-group-item.active,.list-group-item.active:focus,.list-group-item.active:hover{z-index:2;color:#fff;background-color:#00e5f0;border-color:#00e5f0}.list-group-item.active .list-group-item-heading,.list-group-item.active .list-group-item-heading>.small,.list-group-item.active .list-group-item-heading>small,.list-group-item.active:focus .list-group-item-heading,.list-group-item.active:focus .list-group-item-heading>.small,.list-group-item.active:focus .list-group-item-heading>small,.list-group-item.active:hover .list-group-item-heading,.list-group-item.active:hover .list-group-item-heading>.small,.list-group-item.active:hover .list-group-item-heading>small{color:inherit}.list-group-item.active .list-group-item-text,.list-group-item.active:focus .list-group-item-text,.list-group-item.active:hover .list-group-item-text{color:#bdfcff}.list-group-item-success{color:#3c763d;background-color:#dff0d8}a.list-group-item-success,button.list-group-item-success{color:#3c763d}a.list-group-item-success .list-group-item-heading,button.list-group-item-success .list-group-item-heading{color:inherit}a.list-group-item-success:focus,a.list-group-item-success:hover,button.list-group-item-success:focus,button.list-group-item-success:hover{color:#3c763d;background-color:#d0e9c6}a.list-group-item-success.active,a.list-group-item-success.active:focus,a.list-group-item-success.active:hover,button.list-group-item-success.active,button.list-group-item-success.active:focus,button.list-group-item-success.active:hover{color:#fff;background-color:#3c763d;border-color:#3c763d}.list-group-item-info{color:#31708f;background-color:#d9edf7}a.list-group-item-info,button.list-group-item-info{color:#31708f}a.list-group-item-info .list-group-item-heading,button.list-group-item-info .list-group-item-heading{color:inherit}a.list-group-item-info:focus,a.list-group-item-info:hover,button.list-group-item-info:focus,button.list-group-item-info:hover{color:#31708f;background-color:#c4e3f3}a.list-group-item-info.active,a.list-group-item-info.active:focus,a.list-group-item-info.active:hover,button.list-group-item-info.active,button.list-group-item-info.active:focus,button.list-group-item-info.active:hover{color:#fff;background-color:#31708f;border-color:#31708f}.list-group-item-warning{color:#8a6d3b;background-color:#fcf8e3}a.list-group-item-warning,button.list-group-item-warning{color:#8a6d3b}a.list-group-item-warning .list-group-item-heading,button.list-group-item-warning .list-group-item-heading{color:inherit}a.list-group-item-warning:focus,a.list-group-item-warning:hover,button.list-group-item-warning:focus,button.list-group-item-warning:hover{color:#8a6d3b;background-color:#faf2cc}a.list-group-item-warning.active,a.list-group-item-warning.active:focus,a.list-group-item-warning.active:hover,button.list-group-item-warning.active,button.list-group-item-warning.active:focus,button.list-group-item-warning.active:hover{color:#fff;background-color:#8a6d3b;border-color:#8a6d3b}.list-group-item-danger{color:#a94442;background-color:#f2dede}a.list-group-item-danger,button.list-group-item-danger{color:#a94442}a.list-group-item-danger .list-group-item-heading,button.list-group-item-danger .list-group-item-heading{color:inherit}a.list-group-item-danger:focus,a.list-group-item-danger:hover,button.list-group-item-danger:focus,button.list-group-item-danger:hover{color:#a94442;background-color:#ebcccc}a.list-group-item-danger.active,a.list-group-item-danger.active:focus,a.list-group-item-danger.active:hover,button.list-group-item-danger.active,button.list-group-item-danger.active:focus,button.list-group-item-danger.active:hover{color:#fff;background-color:#a94442;border-color:#a94442}.panel-heading>.dropdown .dropdown-toggle,.panel-title,.panel-title>.small,.panel-title>.small>a,.panel-title>a,.panel-title>small,.panel-title>small>a{color:inherit}.list-group-item-heading{margin-top:0;margin-bottom:5px}.list-group-item-text{margin-bottom:0;line-height:1.3}.panel{margin-bottom:20px;background-color:#fff;border:1px solid transparent;border-radius:4px;box-shadow:0 1px 1px rgba(0,0,0,.05)}.panel-title,.panel>.list-group,.panel>.panel-collapse>.list-group,.panel>.panel-collapse>.table,.panel>.table,.panel>.table-responsive>.table{margin-bottom:0}.panel-body{padding:15px}.panel-heading{padding:10px 15px;border-bottom:1px solid transparent;border-top-right-radius:3px;border-top-left-radius:3px}.panel-title{margin-top:0;font-size:16px}.panel-footer{padding:10px 15px;background-color:#f5f5f5;border-top:1px solid #ddd;border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.list-group .list-group-item,.panel>.panel-collapse>.list-group .list-group-item{border-width:1px 0;border-radius:0}.panel-group .panel-heading,.panel>.table-bordered>tbody>tr:first-child>td,.panel>.table-bordered>tbody>tr:first-child>th,.panel>.table-bordered>thead>tr:first-child>td,.panel>.table-bordered>thead>tr:first-child>th,.panel>.table-responsive>.table-bordered>tbody>tr:first-child>td,.panel>.table-responsive>.table-bordered>tbody>tr:first-child>th,.panel>.table-responsive>.table-bordered>thead>tr:first-child>td,.panel>.table-responsive>.table-bordered>thead>tr:first-child>th{border-bottom:0}.panel>.list-group:first-child .list-group-item:first-child,.panel>.panel-collapse>.list-group:first-child .list-group-item:first-child{border-top:0;border-top-right-radius:3px;border-top-left-radius:3px}.panel>.list-group:last-child .list-group-item:last-child,.panel>.panel-collapse>.list-group:last-child .list-group-item:last-child{border-bottom:0;border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.panel-heading+.panel-collapse>.list-group .list-group-item:first-child{border-top-right-radius:0;border-top-left-radius:0}.panel>.table-responsive:first-child>.table:first-child,.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child,.panel>.table:first-child,.panel>.table:first-child>tbody:first-child>tr:first-child,.panel>.table:first-child>thead:first-child>tr:first-child{border-top-right-radius:3px;border-top-left-radius:3px}.list-group+.panel-footer,.panel-heading+.list-group .list-group-item:first-child{border-top-width:0}.panel>.panel-collapse>.table caption,.panel>.table caption,.panel>.table-responsive>.table caption{padding-left:15px;padding-right:15px}.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child td:first-child,.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child th:first-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child td:first-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child th:first-child,.panel>.table:first-child>tbody:first-child>tr:first-child td:first-child,.panel>.table:first-child>tbody:first-child>tr:first-child th:first-child,.panel>.table:first-child>thead:first-child>tr:first-child td:first-child,.panel>.table:first-child>thead:first-child>tr:first-child th:first-child{border-top-left-radius:3px}.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child td:last-child,.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child th:last-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child td:last-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child th:last-child,.panel>.table:first-child>tbody:first-child>tr:first-child td:last-child,.panel>.table:first-child>tbody:first-child>tr:first-child th:last-child,.panel>.table:first-child>thead:first-child>tr:first-child td:last-child,.panel>.table:first-child>thead:first-child>tr:first-child th:last-child{border-top-right-radius:3px}.panel>.table-responsive:last-child>.table:last-child,.panel>.table:last-child{border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child,.panel>.table:last-child>tbody:last-child>tr:last-child,.panel>.table:last-child>tfoot:last-child>tr:last-child{border-bottom-left-radius:3px;border-bottom-right-radius:3px}.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child td:first-child,.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child th:first-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child td:first-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child th:first-child,.panel>.table:last-child>tbody:last-child>tr:last-child td:first-child,.panel>.table:last-child>tbody:last-child>tr:last-child th:first-child,.panel>.table:last-child>tfoot:last-child>tr:last-child td:first-child,.panel>.table:last-child>tfoot:last-child>tr:last-child th:first-child{border-bottom-left-radius:3px}.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child td:last-child,.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child th:last-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child td:last-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child th:last-child,.panel>.table:last-child>tbody:last-child>tr:last-child td:last-child,.panel>.table:last-child>tbody:last-child>tr:last-child th:last-child,.panel>.table:last-child>tfoot:last-child>tr:last-child td:last-child,.panel>.table:last-child>tfoot:last-child>tr:last-child th:last-child{border-bottom-right-radius:3px}.panel>.panel-body+.table,.panel>.panel-body+.table-responsive,.panel>.table+.panel-body,.panel>.table-responsive+.panel-body{border-top:1px solid #ddd}.panel>.table>tbody:first-child>tr:first-child td,.panel>.table>tbody:first-child>tr:first-child th{border-top:0}.panel>.table-bordered,.panel>.table-responsive>.table-bordered{border:0}.panel>.table-bordered>tbody>tr>td:first-child,.panel>.table-bordered>tbody>tr>th:first-child,.panel>.table-bordered>tfoot>tr>td:first-child,.panel>.table-bordered>tfoot>tr>th:first-child,.panel>.table-bordered>thead>tr>td:first-child,.panel>.table-bordered>thead>tr>th:first-child,.panel>.table-responsive>.table-bordered>tbody>tr>td:first-child,.panel>.table-responsive>.table-bordered>tbody>tr>th:first-child,.panel>.table-responsive>.table-bordered>tfoot>tr>td:first-child,.panel>.table-responsive>.table-bordered>tfoot>tr>th:first-child,.panel>.table-responsive>.table-bordered>thead>tr>td:first-child,.panel>.table-responsive>.table-bordered>thead>tr>th:first-child{border-left:0}.panel>.table-bordered>tbody>tr>td:last-child,.panel>.table-bordered>tbody>tr>th:last-child,.panel>.table-bordered>tfoot>tr>td:last-child,.panel>.table-bordered>tfoot>tr>th:last-child,.panel>.table-bordered>thead>tr>td:last-child,.panel>.table-bordered>thead>tr>th:last-child,.panel>.table-responsive>.table-bordered>tbody>tr>td:last-child,.panel>.table-responsive>.table-bordered>tbody>tr>th:last-child,.panel>.table-responsive>.table-bordered>tfoot>tr>td:last-child,.panel>.table-responsive>.table-bordered>tfoot>tr>th:last-child,.panel>.table-responsive>.table-bordered>thead>tr>td:last-child,.panel>.table-responsive>.table-bordered>thead>tr>th:last-child{border-right:0}.panel>.table-bordered>tbody>tr:last-child>td,.panel>.table-bordered>tbody>tr:last-child>th,.panel>.table-bordered>tfoot>tr:last-child>td,.panel>.table-bordered>tfoot>tr:last-child>th,.panel>.table-responsive>.table-bordered>tbody>tr:last-child>td,.panel>.table-responsive>.table-bordered>tbody>tr:last-child>th,.panel>.table-responsive>.table-bordered>tfoot>tr:last-child>td,.panel>.table-responsive>.table-bordered>tfoot>tr:last-child>th{border-bottom:0}.panel>.table-responsive{border:0;margin-bottom:0}.panel-group{margin-bottom:20px}.panel-group .panel{margin-bottom:0;border-radius:4px}.panel-group .panel+.panel{margin-top:5px}.panel-group .panel-heading+.panel-collapse>.list-group,.panel-group .panel-heading+.panel-collapse>.panel-body{border-top:1px solid #ddd}.panel-group .panel-footer{border-top:0}.panel-group .panel-footer+.panel-collapse .panel-body{border-bottom:1px solid #ddd}.panel-default{border-color:#ddd}.panel-default>.panel-heading{color:#333;background-color:#f5f5f5;border-color:#ddd}.panel-default>.panel-heading+.panel-collapse>.panel-body{border-top-color:#ddd}.panel-default>.panel-heading .badge{color:#f5f5f5;background-color:#333}.panel-default>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#ddd}.panel-primary{border-color:#00e5f0}.panel-primary>.panel-heading{color:#fff;background-color:#00e5f0;border-color:#00e5f0}.panel-primary>.panel-heading+.panel-collapse>.panel-body{border-top-color:#00e5f0}.panel-primary>.panel-heading .badge{color:#00e5f0;background-color:#fff}.panel-primary>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#00e5f0}.panel-success{border-color:#d6e9c6}.panel-success>.panel-heading{color:#3c763d;background-color:#dff0d8;border-color:#d6e9c6}.panel-success>.panel-heading+.panel-collapse>.panel-body{border-top-color:#d6e9c6}.panel-success>.panel-heading .badge{color:#dff0d8;background-color:#3c763d}.panel-success>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#d6e9c6}.panel-info{border-color:#bce8f1}.panel-info>.panel-heading{color:#31708f;background-color:#d9edf7;border-color:#bce8f1}.panel-info>.panel-heading+.panel-collapse>.panel-body{border-top-color:#bce8f1}.panel-info>.panel-heading .badge{color:#d9edf7;background-color:#31708f}.panel-info>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#bce8f1}.panel-warning{border-color:#faebcc}.panel-warning>.panel-heading{color:#8a6d3b;background-color:#fcf8e3;border-color:#faebcc}.panel-warning>.panel-heading+.panel-collapse>.panel-body{border-top-color:#faebcc}.panel-warning>.panel-heading .badge{color:#fcf8e3;background-color:#8a6d3b}.panel-warning>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#faebcc}.panel-danger{border-color:#ebccd1}.panel-danger>.panel-heading{color:#a94442;background-color:#f2dede;border-color:#ebccd1}.panel-danger>.panel-heading+.panel-collapse>.panel-body{border-top-color:#ebccd1}.panel-danger>.panel-heading .badge{color:#f2dede;background-color:#a94442}.panel-danger>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#ebccd1}.embed-responsive{position:relative;display:block;height:0;padding:0}.embed-responsive .embed-responsive-item,.embed-responsive embed,.embed-responsive iframe,.embed-responsive object,.embed-responsive video{position:absolute;top:0;left:0;bottom:0;height:100%;width:100%;border:0}.embed-responsive-16by9{padding-bottom:56.25%}.embed-responsive-4by3{padding-bottom:75%}.well{min-height:20px;padding:19px;margin-bottom:20px;background-color:#f5f5f5;border:1px solid #e3e3e3;border-radius:4px;box-shadow:inset 0 1px 1px rgba(0,0,0,.05)}.well blockquote{border-color:#ddd;border-color:rgba(0,0,0,.15)}.well-lg{padding:24px;border-radius:6px}.well-sm{padding:9px;border-radius:3px}.close{float:right;font-size:21px;line-height:1;color:#000;text-shadow:0 1px 0 #fff;opacity:.2;filter:alpha(opacity=20)}.popover,.tooltip{font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-style:normal;letter-spacing:normal;line-break:auto;line-height:1.42857143;text-shadow:none;text-transform:none;white-space:normal;word-break:normal;word-spacing:normal;word-wrap:normal;text-decoration:none}.close:focus,.close:hover{color:#000;text-decoration:none;cursor:pointer;opacity:.5;filter:alpha(opacity=50)}button.close{padding:0;cursor:pointer;background:0 0;border:0;-webkit-appearance:none}.modal-content,.popover{background-clip:padding-box}.modal{display:none;position:fixed;z-index:1050;-webkit-overflow-scrolling:touch;outline:0}.modal.fade .modal-dialog{-webkit-transform:translate(0,-25%);transform:translate(0,-25%);-webkit-transition:-webkit-transform .3s ease-out;transition:-webkit-transform .3s ease-out;transition:transform .3s ease-out;transition:transform .3s ease-out,-webkit-transform .3s ease-out}.modal.in .modal-dialog{-webkit-transform:translate(0,0);transform:translate(0,0)}.modal-open .modal{overflow-x:hidden;overflow-y:auto}.modal-dialog{position:relative;width:auto;margin:10px}.modal-content{position:relative;background-color:#fff;border:1px solid #999;border:1px solid rgba(0,0,0,.2);border-radius:6px;box-shadow:0 3px 9px rgba(0,0,0,.5);outline:0}.modal-backdrop{position:fixed;z-index:1040;background-color:#000}.modal-backdrop.fade{opacity:0;filter:alpha(opacity=0)}.modal-backdrop.in{opacity:.5;filter:alpha(opacity=50)}.modal-header{padding:15px;border-bottom:1px solid #e5e5e5}.modal-header .close{margin-top:-2px}.modal-title{margin:0;line-height:1.42857143}.modal-body{position:relative;padding:15px}.modal-footer{padding:15px;text-align:right;border-top:1px solid #e5e5e5}.modal-footer .btn+.btn{margin-left:5px;margin-bottom:0}.modal-footer .btn-group .btn+.btn{margin-left:-1px}.modal-footer .btn-block+.btn-block{margin-left:0}.modal-scrollbar-measure{position:absolute;top:-9999px;width:50px;height:50px;overflow:scroll}@media (min-width:768px){.modal-dialog{width:600px;margin:30px auto}.modal-content{box-shadow:0 5px 15px rgba(0,0,0,.5)}.modal-sm{width:300px}}@media (min-width:992px){.modal-lg{width:900px}}.tooltip{position:absolute;z-index:1070;display:block;font-weight:400;text-align:left;text-align:start;font-size:12px;opacity:0;filter:alpha(opacity=0)}.tooltip.in{opacity:.9;filter:alpha(opacity=90)}.tooltip.top{margin-top:-3px;padding:5px 0}.tooltip.right{margin-left:3px;padding:0 5px}.tooltip.bottom{margin-top:3px;padding:5px 0}.tooltip.left{margin-left:-3px;padding:0 5px}.tooltip-inner{max-width:200px;padding:3px 8px;color:#fff;text-align:center;background-color:#000;border-radius:4px}.tooltip-arrow{position:absolute;width:0;height:0;border-color:transparent;border-style:solid}.tooltip.top .tooltip-arrow,.tooltip.top-left .tooltip-arrow,.tooltip.top-right .tooltip-arrow{bottom:0;border-width:5px 5px 0;border-top-color:#000}.tooltip.top .tooltip-arrow{left:50%;margin-left:-5px}.tooltip.top-left .tooltip-arrow{right:5px;margin-bottom:-5px}.tooltip.top-right .tooltip-arrow{left:5px;margin-bottom:-5px}.tooltip.right .tooltip-arrow{top:50%;left:0;margin-top:-5px;border-width:5px 5px 5px 0;border-right-color:#000}.tooltip.left .tooltip-arrow{top:50%;right:0;margin-top:-5px;border-width:5px 0 5px 5px;border-left-color:#000}.tooltip.bottom .tooltip-arrow,.tooltip.bottom-left .tooltip-arrow,.tooltip.bottom-right .tooltip-arrow{border-width:0 5px 5px;border-bottom-color:#000;top:0}.tooltip.bottom .tooltip-arrow{left:50%;margin-left:-5px}.tooltip.bottom-left .tooltip-arrow{right:5px;margin-top:-5px}.tooltip.bottom-right .tooltip-arrow{left:5px;margin-top:-5px}.popover{position:absolute;top:0;left:0;z-index:1060;display:none;max-width:276px;padding:1px;font-weight:400;text-align:left;text-align:start;font-size:14px;background-color:#fff;border:1px solid #ccc;border:1px solid rgba(0,0,0,.2);border-radius:6px;box-shadow:0 5px 10px rgba(0,0,0,.2)}.carousel-caption,.carousel-control{color:#fff;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,.6)}.popover.top{margin-top:-10px}.popover.right{margin-left:10px}.popover.bottom{margin-top:10px}.popover.left{margin-left:-10px}.popover-title{margin:0;padding:8px 14px;font-size:14px;background-color:#f7f7f7;border-bottom:1px solid #ebebeb;border-radius:5px 5px 0 0}.popover-content{padding:9px 14px}.popover>.arrow,.popover>.arrow:after{position:absolute;display:block;width:0;height:0;border-color:transparent;border-style:solid}.carousel,.carousel-inner{position:relative}.popover>.arrow{border-width:11px}.popover>.arrow:after{border-width:10px;content:""}.popover.top>.arrow{left:50%;margin-left:-11px;border-bottom-width:0;border-top-color:#999;border-top-color:rgba(0,0,0,.25);bottom:-11px}.popover.top>.arrow:after{content:" ";bottom:1px;margin-left:-10px;border-bottom-width:0;border-top-color:#fff}.popover.left>.arrow:after,.popover.right>.arrow:after{content:" ";bottom:-10px}.popover.right>.arrow{top:50%;left:-11px;margin-top:-11px;border-left-width:0;border-right-color:#999;border-right-color:rgba(0,0,0,.25)}.popover.right>.arrow:after{left:1px;border-left-width:0;border-right-color:#fff}.popover.bottom>.arrow{left:50%;margin-left:-11px;border-top-width:0;border-bottom-color:#999;border-bottom-color:rgba(0,0,0,.25);top:-11px}.popover.bottom>.arrow:after{content:" ";top:1px;margin-left:-10px;border-top-width:0;border-bottom-color:#fff}.popover.left>.arrow{top:50%;right:-11px;margin-top:-11px;border-right-width:0;border-left-color:#999;border-left-color:rgba(0,0,0,.25)}.popover.left>.arrow:after{right:1px;border-right-width:0;border-left-color:#fff}.carousel-inner{width:100%}.carousel-inner>.item{display:none;position:relative;-webkit-transition:.6s ease-in-out left;transition:.6s ease-in-out left}.carousel-inner>.item>a>img,.carousel-inner>.item>img{line-height:1}@media all and (transform-3d),(-webkit-transform-3d){.carousel-inner>.item{-webkit-transition:-webkit-transform .6s ease-in-out;transition:-webkit-transform .6s ease-in-out;transition:transform .6s ease-in-out;transition:transform .6s ease-in-out,-webkit-transform .6s ease-in-out;-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-perspective:1000px;perspective:1000px}.carousel-inner>.item.active.right,.carousel-inner>.item.next{-webkit-transform:translate3d(100%,0,0);transform:translate3d(100%,0,0);left:0}.carousel-inner>.item.active.left,.carousel-inner>.item.prev{-webkit-transform:translate3d(-100%,0,0);transform:translate3d(-100%,0,0);left:0}.carousel-inner>.item.active,.carousel-inner>.item.next.left,.carousel-inner>.item.prev.right{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0);left:0}}.carousel-inner>.active,.carousel-inner>.next,.carousel-inner>.prev{display:block}.carousel-inner>.active{left:0}.carousel-inner>.next,.carousel-inner>.prev{position:absolute;top:0;width:100%}.carousel-inner>.next{left:100%}.carousel-inner>.prev{left:-100%}.carousel-inner>.next.left,.carousel-inner>.prev.right{left:0}.carousel-inner>.active.left{left:-100%}.carousel-inner>.active.right{left:100%}.carousel-control{position:absolute;top:0;left:0;bottom:0;width:15%;opacity:.5;filter:alpha(opacity=50);font-size:20px;background-color:rgba(0,0,0,0)}.carousel-control.left{background-image:-webkit-linear-gradient(left,rgba(0,0,0,.5) 0,rgba(0,0,0,.0001) 100%);background-image:linear-gradient(to right,rgba(0,0,0,.5) 0,rgba(0,0,0,.0001) 100%);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#80000000', endColorstr='#00000000', GradientType=1)}.carousel-control.right{left:auto;right:0;background-image:-webkit-linear-gradient(left,rgba(0,0,0,.0001) 0,rgba(0,0,0,.5) 100%);background-image:linear-gradient(to right,rgba(0,0,0,.0001) 0,rgba(0,0,0,.5) 100%);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000', endColorstr='#80000000', GradientType=1)}.carousel-control:focus,.carousel-control:hover{outline:0;color:#fff;text-decoration:none;opacity:.9;filter:alpha(opacity=90)}.carousel-control .glyphicon-chevron-left,.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next,.carousel-control .icon-prev{position:absolute;top:50%;margin-top:-10px;z-index:5;display:inline-block}.carousel-control .glyphicon-chevron-left,.carousel-control .icon-prev{left:50%;margin-left:-10px}.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next{right:50%;margin-right:-10px}.carousel-control .icon-next,.carousel-control .icon-prev{width:20px;height:20px;line-height:1;font-family:serif}.carousel-control .icon-prev:before{content:'\2039'}.carousel-control .icon-next:before{content:'\203a'}.carousel-indicators{position:absolute;bottom:10px;left:50%;z-index:15;width:60%;margin-left:-30%;padding-left:0;list-style:none;text-align:center}.carousel-indicators li{display:inline-block;width:10px;height:10px;margin:1px;text-indent:-999px;border:1px solid #fff;border-radius:10px;cursor:pointer;background-color:#000\9;background-color:rgba(0,0,0,0)}.carousel-indicators .active{margin:0;width:12px;height:12px;background-color:#fff}.carousel-caption{position:absolute;left:15%;right:15%;bottom:20px;z-index:10;padding-top:20px;padding-bottom:20px}.carousel-caption .btn,.text-hide{text-shadow:none}@media screen and (min-width:768px){.carousel-control .glyphicon-chevron-left,.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next,.carousel-control .icon-prev{width:30px;height:30px;margin-top:-10px;font-size:30px}.carousel-control .glyphicon-chevron-left,.carousel-control .icon-prev{margin-left:-10px}.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next{margin-right:-10px}.carousel-caption{left:20%;right:20%;padding-bottom:30px}.carousel-indicators{bottom:20px}}.btn-group-vertical>.btn-group:after,.btn-group-vertical>.btn-group:before,.btn-toolbar:after,.btn-toolbar:before,.clearfix:after,.clearfix:before,.container-fluid:after,.container-fluid:before,.container:after,.container:before,.dl-horizontal dd:after,.dl-horizontal dd:before,.form-horizontal .form-group:after,.form-horizontal .form-group:before,.modal-footer:after,.modal-footer:before,.modal-header:after,.modal-header:before,.nav:after,.nav:before,.navbar-collapse:after,.navbar-collapse:before,.navbar-header:after,.navbar-header:before,.navbar:after,.navbar:before,.pager:after,.pager:before,.panel-body:after,.panel-body:before,.row:after,.row:before{content:" ";display:table}.btn-group-vertical>.btn-group:after,.btn-toolbar:after,.clearfix:after,.container-fluid:after,.container:after,.dl-horizontal dd:after,.form-horizontal .form-group:after,.modal-footer:after,.modal-header:after,.nav:after,.navbar-collapse:after,.navbar-header:after,.navbar:after,.pager:after,.panel-body:after,.row:after{clear:both}.center-block{display:block;margin-left:auto;margin-right:auto}.pull-right{float:right!important}.pull-left{float:left!important}.hide{display:none!important}.show{display:block!important}.hidden,.visible-lg,.visible-lg-block,.visible-lg-inline,.visible-lg-inline-block,.visible-md,.visible-md-block,.visible-md-inline,.visible-md-inline-block,.visible-sm,.visible-sm-block,.visible-sm-inline,.visible-sm-inline-block,.visible-xs,.visible-xs-block,.visible-xs-inline,.visible-xs-inline-block{display:none!important}.invisible{visibility:hidden}.text-hide{font:0/0 a;color:transparent;background-color:transparent;border:0}.analytics h2,.analytics h3{font-size:14px;color:#5B6667}.affix{position:fixed}@-ms-viewport{width:device-width}@media (max-width:767px){.visible-xs{display:block!important}table.visible-xs{display:table!important}tr.visible-xs{display:table-row!important}td.visible-xs,th.visible-xs{display:table-cell!important}.visible-xs-block{display:block!important}.visible-xs-inline{display:inline!important}.visible-xs-inline-block{display:inline-block!important}}@media (min-width:768px) and (max-width:991px){.visible-sm{display:block!important}table.visible-sm{display:table!important}tr.visible-sm{display:table-row!important}td.visible-sm,th.visible-sm{display:table-cell!important}.visible-sm-block{display:block!important}.visible-sm-inline{display:inline!important}.visible-sm-inline-block{display:inline-block!important}}@media (min-width:992px) and (max-width:1199px){.visible-md{display:block!important}table.visible-md{display:table!important}tr.visible-md{display:table-row!important}td.visible-md,th.visible-md{display:table-cell!important}.visible-md-block{display:block!important}.visible-md-inline{display:inline!important}.visible-md-inline-block{display:inline-block!important}}@media (min-width:1200px){.visible-lg{display:block!important}table.visible-lg{display:table!important}tr.visible-lg{display:table-row!important}td.visible-lg,th.visible-lg{display:table-cell!important}.visible-lg-block{display:block!important}.visible-lg-inline{display:inline!important}.visible-lg-inline-block{display:inline-block!important}.hidden-lg{display:none!important}}@media (max-width:767px){.hidden-xs{display:none!important}}@media (min-width:768px) and (max-width:991px){.hidden-sm{display:none!important}}@media (min-width:992px) and (max-width:1199px){.hidden-md{display:none!important}}.visible-print{display:none!important}@media print{.visible-print{display:block!important}table.visible-print{display:table!important}tr.visible-print{display:table-row!important}td.visible-print,th.visible-print{display:table-cell!important}}.visible-print-block{display:none!important}@media print{.visible-print-block{display:block!important}}.visible-print-inline{display:none!important}@media print{.visible-print-inline{display:inline!important}}.visible-print-inline-block{display:none!important}@media print{.visible-print-inline-block{display:inline-block!important}.hidden-print{display:none!important}}.top-buffer-1{margin-top:15px}.top-buffer-2{margin-top:30px}.top-buffer-3{margin-top:45px}.top-buffer-4{margin-top:60px}.top-buffer-5{margin-top:75px}.top-buffer-6{margin-top:90px}.top-buffer-7{margin-top:105px}.top-buffer-8{margin-top:120px}.top-buffer-9{margin-top:135px}.top-buffer-10{margin-top:150px}body{height:101%!important}.analytics h2{margin-top:2px}.analytics h3{margin:0;font-weight:300;text-align:left}.analytics h4{color:#5B6667;font-size:16px}.analytics .green,.analytics .positive{color:green!important}.analytics .negative,.analytics .red{color:#ed1e79!important}.analytics .positive2{color:#3fc4ff!important}.analytics .negative2{color:#1de9b6!important}.analytics a{font-weight:700;color:#977bf0;cursor:pointer}.analytics .input-group{width:100%}.analytics select{margin-top:5px;background-color:#fff;height:32px}.analytics pre{font-size:12px;padding:0;margin:1px 0 8px;border:none;white-space:pre-wrap;word-wrap:break-word}.analytics .widget-item .content ::-webkit-scrollbar,.analytics kpis-bar .kpi ::-webkit-scrollbar{width:6px;background-color:transparent}.analytics .widget-item .content ::-webkit-scrollbar-thumb,.analytics kpis-bar .kpi ::-webkit-scrollbar-thumb{background-color:#6896b2;border-radius:10px}.analytics .widget-item .content ::-webkit-scrollbar-thumb:hover,.analytics kpis-bar .kpi ::-webkit-scrollbar-thumb:hover{background-color:#79a2bb}.analytics .nopadding{padding:0}.analytics .nomargin{margin:0}.analytics .btn.btn-shaded{background-color:#17262d;border:1px solid #0e181c;color:#626d6d;font-weight:400}.analytics .btn.btn-shaded:hover{color:#6e7a7a;background-color:#20343e}.analytics .price{font-weight:900;font-size:22px;color:#5B6667;text-align:center;margin-top:30px}.analytics .currency{font-weight:300;font-size:16px;text-align:center;color:#9ba6a7}.analytics .legend{font-weight:300;font-size:12px;text-align:center;overflow-y:auto;overflow-x:hidden;color:#c4caca}.analytics .loader{height:100%;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}.analytics .loader i{color:#67BBE9}.analytics .loader p{margin-top:10px}.analytics .right-panel{border-left:solid 1px #e6e6e6}.analytics .selector{text-transform:uppercase;font-size:12px;color:#626d6d;text-align:center}.analytics .tile{background-color:#f7f7f7;box-shadow:0 7px 10px -7px #17262d;height:45px;margin-bottom:10px;white-space:nowrap;cursor:pointer}.analytics .tile:hover{background-color:#e2f2ff}.analytics .tile .colored-area{background-color:#3FC4FF;height:100%;float:right;color:#fff;text-align:right;padding:5px 10px;min-width:8%}.analytics .tile .colored-area.selected{background-color:#977bf0}.analytics .tile .main-text{color:#5B6667;padding:20px 0 0 5px;height:100%;font-style:italic;font-weight:700}.analytics .widget-lines-container{overflow-y:auto;overflow-x:hidden;max-height:200px;text-align:left;font-size:12px;padding:0 15px}.analytics .widget-lines-container .row.widget-line{padding:5px;color:#626d6d}.analytics .widget-lines-container .row.widget-line.header{font-weight:500;font-size:12px;color:#9ba6a7;text-transform:uppercase}@media (max-width:767px){.analytics .widget-lines-container .row.widget-line{margin:inherit;margin-left:-3px;margin-right:-3px;padding:2px}.analytics .widget-lines-container .row.widget-line>[class*=col-]{padding-left:3px;padding-right:3px}}.analytics .widget-lines-container .row.widget-line i.fa{min-width:12px;min-height:12px}.analytics .widget-lines-container .row .dashed{border-bottom:dashed 1px #dfe2e2;padding-bottom:3px;margin-bottom:3px}.analytics .widget-lines-container .row.lines-group{border-top:solid 1px #e6edee}.vertical-scroll{overflow-y:scroll}.horizontal-scroll{overflow-x:scroll}.tooltip.impac-widgets-tooltip .tooltip-inner.ng-binding{text-align:left;background-color:#232528;max-width:100%;white-space:nowrap}.tooltip.impac-widgets-tooltip .tooltip-inner.ng-binding strong{color:#dae173}.sortable-title{cursor:pointer}.sortable-title div{display:inline-block}div[ng-messages]{color:red}.has-error .form-control,.has-error .form-control:focus{border-color:#e01f74}.has-success .form-control,.has-success .form-control:focus{border-color:#00e5f0}.row.no-gutters{margin-right:0;margin-left:0}[class*=" col-"].no-gutters,[class^=col-].no-gutters{padding-right:0;padding-left:0}@media print{body{background-color:#fff!important}.analytics{padding-top:0!important}.analytics #module__dashboard-selector .title-container{margin-top:20px}.analytics .widget-item{page-break-inside:avoid}.analytics .widget-item .content .chart-container{max-width:270px;margin:auto}.analytics .widget-item .content .chart-container canvas{width:100%!important;height:100%!important}.analytics .widget-item .right-panel{page-break-inside:avoid;border-left:0}.analytics .widget-item .right-panel .chart-container{max-width:inherit;max-height:inherit}.analytics .widget-item .right-panel .chart-container canvas{width:80%!important;height:80%!important}*{-webkit-transition:none!important;transition:none!important}}.kpi-alerts-settings .modal-header{font-size:20px}.kpi-alerts-settings .modal-body{line-height:2}.kpi-alerts-settings .modal-body ul{margin-top:10px}.kpi-alerts-settings .modal-body ul>li.list-group-item{list-style:none;padding:6px 15px;color:#9ba6a7;user-select:none}.kpi-alerts-settings .modal-body ul>li.list-group-item .alert-toggle:hover{cursor:pointer}.kpi-alerts-settings .modal-body ul>li.list-group-item.active{color:#358fdc;font-weight:700;background-color:transparent;border-color:#c4caca}.kpi-alerts-settings .modal-body .fa.fa-toggle-off,.kpi-alerts-settings .modal-body .fa.fa-toggle-on{font-size:17px;margin-right:8px}.kpi-alerts-settings .modal-body ul.recipients-list{height:75px;overflow:hidden;overflow-y:scroll;border:1px solid #c4caca}.kpi-alerts-settings .modal-body ul.recipients-list li{border:none}.kpi-alerts-settings .modal-body input.recipient-search{color:#000;width:100%}.kpi-alerts-settings .modal-body ul.available{margin-top:0}.analytics{padding-top:50px;margin-left:100px}@media screen and (max-width:992px){.analytics{padding-top:150px}}.analytics.pdf-mode{padding-top:20px}.analytics.show-dhb{-webkit-transition:opacity 1s;transition:opacity 1s;opacity:1}.analytics.hide-dhb{opacity:0}.analytics #dashboard-heading img{float:left;margin-right:15px;max-width:200px;max-height:150px}.analytics #dashboard-heading img.pdf-mode:hover{cursor:pointer}.analytics #dashboard-heading .caption{font-size:14px;margin:5px 0}.analytics #sub-menu{margin-top:15px}.analytics #sub-menu h3{font-size:26px;font-weight:400;margin-bottom:10px;color:#233845}.analytics #sub-menu .fa.fa-times{margin:6px;color:#3d6178;cursor:pointer;float:right}.analytics #widget-selector{background-color:#233845;color:#fff;padding:0 45px 10px;margin:10px -45px;border-radius:3px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none}@media (max-width:767px){.analytics #widget-selector{padding:0 15px 10px;margin:0}}.analytics #widget-selector .title{padding:15px 0;border-bottom:solid 1px #2d4859;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.analytics #widget-selector .title p.instruction{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;margin:0}@media screen and (max-width:768px){.analytics #widget-selector .title p.instruction{width:50%;font-size:13px}}.analytics #widget-selector .title .widget-added.badge{margin-right:10px;opacity:0}.analytics #widget-selector .title .fa.close-selector{float:right;cursor:pointer;font-size:20px;padding:6px}.analytics #widget-selector .title .fa.close-selector:hover{color:#999}.analytics #widget-selector .top-container{margin:15px 0;background-color:transparent;border-radius:3px}.analytics #widget-selector .section-header{padding:10px 20px;font-weight:700;min-height:40px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.analytics #widget-selector .section-lines{overflow-x:hidden;overflow-y:auto;height:200px;margin-right:-10px;margin-left:0}.analytics #widget-selector .section-lines p{padding:5px;margin:0;cursor:pointer}.analytics #widget-selector .section-lines p.selected,.analytics #widget-selector .section-lines p:hover{color:#fff}.analytics #widget-selector .section-lines::-webkit-scrollbar{width:6px;background-color:transparent}.analytics #widget-selector .section-lines::-webkit-scrollbar-thumb{background-color:#28404f;border-radius:10px}.analytics #widget-selector .section-lines::-webkit-scrollbar-thumb:hover{background-color:#2d4859}.analytics #widget-selector .categories-section{background-color:#192831;padding-bottom:15px}.analytics #widget-selector .categories-section>.section-lines>[class*=col-]:first-child{padding:3px 12px}.analytics #widget-selector .categories-section>.section-lines .line-item:hover{background-color:#1e303b}.analytics #widget-selector .categories-section>.section-lines .line-item.selected{background-color:#977bf0;font-weight:700;box-shadow:-2px 2px 10px -4px #000}.analytics #widget-selector .categories-section .arrow-icon{position:absolute;top:33px;right:-11px;z-index:1}.analytics #widget-selector .categories-section .arrow-icon .square{width:50px;height:30px;position:absolute;top:10px;right:17px;background-color:#977bf0}.analytics #widget-selector .categories-section .arrow-icon i.fa.fa-caret-right{font-size:52px;color:#977bf0;float:right;position:absolute;top:-1.5px;right:0}.analytics #widget-selector .widgets-section{background-color:#1e303b;padding-bottom:15px}.analytics #widget-selector .widgets-section>.section-header{text-transform:uppercase;font-size:12px;color:#977bf0}.analytics #widget-selector .widgets-section>.section-lines{padding:3px 0}.analytics #widget-selector .widgets-section>.section-lines .fa.fa-plus-circle{float:right;margin-top:3px}.analytics #widget-selector .widgets-section>.section-lines>.line-items-grid{width:100%;display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;height:0%}.analytics #widget-selector .widgets-section>.section-lines>.line-items-grid>.grid-item{padding:0 13px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;-ms-flex:0 31.33%;flex:0 31.33%;margin:0 1%;-webkit-box-align:center;-ms-flex-align:center;align-items:center;border-bottom:solid 1px #233845;min-height:0}@media screen and (max-width:992px){.analytics #widget-selector .widgets-section>.section-lines>.line-items-grid>.grid-item{-webkit-box-flex:0;-ms-flex:0 100%;flex:0 100%}}.analytics #widget-selector .widgets-section>.section-lines>.line-items-grid>.grid-item:hover{background-color:#192831;font-weight:400}.analytics #widget-selector .widgets-section>.section-lines>.line-items-grid>.grid-item p.line-item{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1}.analytics #widget-selector .bottom{height:20px}.analytics #widget-selector .bottom>.suggestion{float:right;opacity:.7}.analytics #widget-selector .bottom>.suggestion a{cursor:pointer}.analytics #widget-selector .bottom>.suggestion a:hover{color:#00e5f0}.analytics #widget-selector .bottom>.suggestion:hover{opacity:1}.analytics #dashboard-settings-panel{position:relative;margin-top:5px}.analytics #dashboard-settings-panel>div{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:end;-ms-flex-pack:end;justify-content:flex-end}.analytics #dashboard-settings-panel>div>*{margin:0 3px}.analytics #dashboard-settings-panel select{margin:0;height:34px;padding-top:1px}.analytics #no-widgets-container{position:relative;min-height:150px}.analytics #no-widgets-container img.bg{left:0;top:0;min-width:100%;min-height:100%}.analytics #no-widgets-container .impac-info-message{position:absolute;top:0;width:100%}.analytics #no-widgets-container .impac-info-message .info-text{font-size:25px;font-weight:300;padding:20px;min-height:115px;color:#fff;border-radius:10px;background-color:rgba(23,38,45,.7)}.analytics #widgets-section #widgets-container{min-height:700px}.analytics #widgets-section .placeHolderBox{margin:12px;height:267px;width:300px;float:left;border:2px dashed #abc4c6;background:0 0}.analytics.load-failed p{font-size:22px}.analytics.load-failed .second-msg p{color:#e01f74;font-size:14px}.tooltip.impac-widget-selector-tooltip .tooltip-inner.ng-binding{font-size:14px}.impac-widget-suggestion .modal-body input,.impac-widget-suggestion .modal-body textarea{width:100%;color:#000}.impac-widget-suggestion .modal-body textarea{height:150px}.impac-widget-suggestion .modal-body .thanks-message{color:#dae173}.modal-footer .loader{color:#fff}.analytics .dashboard-create .btn-create{background-color:#977bf0}.modal.impac-dashboard-create h1{font-size:24px}.modal.impac-dashboard-create .fa.fa-times{float:right;color:#ccc;cursor:pointer}.modal.impac-dashboard-create .control-label{text-align:left}.modal.impac-dashboard-create .modal-footer .loader{color:#fff}#module__dashboard-selector a{font-weight:400}#module__dashboard-selector>div:first-child{border-bottom:1px solid #abc4c6}#module__dashboard-selector .buttons-bar-row{margin-top:54px}#module__dashboard-selector .buttons-bar-row.pdf-mode{margin-top:0}#module__dashboard-selector .buttons-bar{padding:0;position:relative}#module__dashboard-selector .buttons-bar .btn{float:right;margin:3px;border-radius:4px}#module__dashboard-selector .buttons-bar .title-container h1{margin:0;color:#000;cursor:auto}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-title{color:#977bf0;display:inline;cursor:pointer}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-title:hover{color:#734deb}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-title i.fa.fa-pencil{margin-left:20px;font-size:14px}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-title i.fa.fa-pencil:hover{color:#dae173}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select{margin:5px 0 10px 30px;height:auto;border-left:1px solid #977bf0;border-bottom:1px solid #977bf0;width:300px;background-color:#e6edee;cursor:pointer}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option{color:#17262d;white-space:nowrap}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option:hover{background-color:#fff}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option.dashboard-create{height:33px}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option.dashboard-create .btn{float:none;width:100%;text-align:left;margin:0;border-radius:0}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option i.fa.fa-pencil{float:right;padding-top:7px;text-align:center;width:15%;height:30px}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option i.fa.fa-pencil:hover{color:#734deb}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option span.name{width:85%;height:30px;display:inline-block;padding:5px 10px}#module__dashboard-selector .buttons-bar .dropdown-container .change-name{position:absolute;top:30px;left:20px;width:60%;background-color:#17262d;color:#fff;padding:10px;border-radius:4px;text-align:center;box-shadow:0 0 25px 4px #000;z-index:50;border:1px solid #fff}#module__dashboard-selector .buttons-bar .dropdown-container .change-name .form-control{height:25px;margin-bottom:10px}#module__dashboard-selector .buttons-bar .dropdown-container .data-source-label{color:#17262d;padding-left:3px;margin:0}#module__dashboard-selector .buttons-bar .loader-container{padding-left:10px}#module__dashboard-selector .buttons-bar .loader-container .loading-spinner{color:#67BBE9;font-size:40px}#module__dashboard-selector .nav-tabs{border-bottom:0}#module__dashboard-selector .nav.nav-pills li:last-child>a,#module__dashboard-selector .nav.nav-tabs li:last-child>a{padding-right:15px}#module__dashboard-selector .nav.nav-pills li:last-child>a tab-heading a,#module__dashboard-selector .nav.nav-tabs li:last-child>a tab-heading a{position:static}#module__dashboard-selector .nav.nav-tabs li>a{padding:10px 8px 10px 15px;margin:0 2px 0 0;background-color:transparent;border:1px solid #abc4c6;color:#000}#module__dashboard-selector .nav.nav-tabs li.active>a{background-color:#fff;color:#977bf0}#module__dashboard-selector .nav.nav-tabs li:last-child.active>a{background-color:transparent}#module__dashboard-selector .nav.nav-pills li>a{min-width:0;padding-right:8px}#module__dashboard-selector .nav.nav-pills li:last-child tab-heading a{margin-left:2px}#module__dashboard-selector .nav.nav-pills li:last-child.active>a{background-color:#f4f4f4}#module__dashboard-selector tab-heading a.close-link{border-bottom:0 solid;margin-left:12px;position:relative;top:-9px;right:1px;color:#000}dashboard-templates-selector .templates-header{display:-webkit-box;display:-ms-flexbox;display:flex}dashboard-templates-selector .templates-header .templates-toggle{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;-webkit-box-pack:end;-ms-flex-pack:end;justify-content:flex-end;font-size:20px}dashboard-templates-selector .templates-header .templates-toggle i.fa{cursor:pointer}dashboard-templates-selector .templates-header .templates-toggle i.fa.fa-toggle-on{color:#977bf0}dashboard-templates-selector .templates{border:1px solid #ccc;box-shadow:inset 0 0 1px 0 #ccc;height:130px;overflow:auto;border-radius:2px}dashboard-templates-selector .templates .template{padding:5px 10px;color:#5B6667;border-bottom:1px solid #ececec}.analytics .impac-kpi .kpi.add:hover .kpi-icon,.analytics .impac-kpi .kpi.add:hover .kpi-text{color:#000}dashboard-templates-selector .templates .template:hover{cursor:pointer;background-color:rgba(96,232,119,.62)}dashboard-templates-selector .templates .template.selected{background-color:rgba(29,197,57,.62)}.analytics .impac-kpi .kpi{position:relative;max-width:220px;min-height:95px;max-height:95px;background-color:#fff;margin:10px 0;border-bottom:1px solid #fff;-webkit-transition:all .2s ease-in;transition:all .2s ease-in}@media screen and (max-width:768px){.analytics .impac-kpi .kpi{margin-left:auto;margin-right:auto}}.analytics .impac-kpi .kpi.add:hover,.analytics .impac-kpi .kpi.triggered{border-bottom:4px solid #e01f74}.analytics .impac-kpi .kpi.add .kpi-text .emphasis{visibility:hidden}.analytics .impac-kpi .kpi.add:hover{cursor:pointer}.analytics .impac-kpi .kpi.add:hover .top-line{background-color:#000}.analytics .impac-kpi .kpi.add:hover .kpi-text .emphasis{visibility:visible}.analytics .impac-kpi .kpi.add:hover .kpi-icon .fa-plus:before{content:"\f00c"}.analytics .impac-kpi .kpi.editing{min-height:185px}.analytics .impac-kpi .kpi:hover{cursor:default}.analytics .impac-kpi .kpi.static .kpi-value{display:block;font-size:14px;font-weight:700}.analytics .impac-kpi .kpi .top-line{width:100%;position:relative;cursor:move;padding:9px 9px 0 12px;border-bottom:none;min-height:7px;box-shadow:none;display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-direction:row;flex-direction:row;margin-bottom:5px;background-color:grey;-webkit-transition:background .2s ease-in;transition:background .2s ease-in}.analytics .impac-kpi .kpi .top-line.triggered{background-color:#000}.analytics .impac-kpi .kpi .kpi-content{max-height:90px}.analytics .impac-kpi .kpi .kpi-content.editing{min-height:180px;overflow-y:auto;overflow-x:hidden}.analytics .impac-kpi .kpi .kpi-show{white-space:normal;padding:10px}.analytics .impac-kpi .kpi .kpi-show .caption,.analytics .impac-kpi .kpi .kpi-show .emphasis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media screen and (max-width:380px){.analytics .impac-kpi .kpi .kpi-show{padding:10px 3px}}.analytics .impac-kpi .kpi .kpi-show .emphasis .real-value{color:#676767}.analytics .impac-kpi .kpi .kpi-show .kpi-text{padding:7px 0;color:grey;-webkit-transition:color .2s ease-in;transition:color .2s ease-in}.analytics .impac-kpi .kpi .kpi-show .kpi-text>span{display:block}.analytics .impac-kpi .kpi .kpi-show .kpi-text.triggered{color:#000}.analytics .impac-kpi .kpi .kpi-show .kpi-text .caption{font-size:11px;padding-bottom:2px}@media screen and (max-width:465px){.analytics .impac-kpi .kpi .kpi-show .kpi-text .caption{font-size:10px}.analytics .impac-kpi .kpi .kpi-show .kpi-text .emphasis{font-size:11px}}.analytics .impac-kpi .kpi .kpi-show .kpi-icon{font-size:16px;padding:10px 0;color:grey;-webkit-transition:color .2s ease-in;transition:color .2s ease-in}.analytics .impac-kpi .kpi .kpi-show .kpi-icon.triggered{color:#000}@media screen and (max-width:465px){.analytics .impac-kpi .kpi .kpi-show .kpi-icon{font-size:12px;padding:16px 0}}.analytics .impac-kpi .kpi .kpi-edit a{color:#fff}.analytics .impac-kpi .kpi .kpi-edit .kpi-name{text-align:center;margin-bottom:5px}.analytics .impac-kpi .kpi .kpi-edit .kpi-name h6{margin:0 0 5px}.analytics .impac-kpi .kpi .kpi-edit .real-value{text-transform:uppercase;font-size:10px;text-align:center}.analytics .impac-kpi .kpi .kpi-edit .alert-caption{text-align:center;font-size:11px;background:#f99;border-radius:3px;width:100%;margin:0 auto 5px;box-shadow:none;padding:2px;color:#fff}.analytics .impac-kpi .kpi .kpi-edit .kpi-target-unit,.analytics .impac-kpi .kpi .kpi-edit .kpi-target-watchable{text-transform:uppercase;font-weight:500;font-size:11px}.analytics .impac-kpi .kpi .kpi-edit .kpi-target-watchable{margin-bottom:20px;color:#8d8d8d}.analytics .impac-kpi .kpi .kpi-edit .kpi-target-unit{position:absolute;top:6px;right:0;color:#9a9a9a}.analytics .impac-kpi .kpi .kpi-edit .param-name{font-size:85%}.analytics .impac-kpi .kpi .kpi-edit .btn.btn-xs{margin-top:4px}.analytics .impac-kpi .kpi .kpi-edit .add-on,.analytics .impac-kpi .kpi .kpi-edit .alert,.analytics .impac-kpi .kpi .kpi-edit .badge,.analytics .impac-kpi .kpi .kpi-edit .btn,.analytics .impac-kpi .kpi .kpi-edit .dropdown-menu,.analytics .impac-kpi .kpi .kpi-edit .img-polaroid,.analytics .impac-kpi .kpi .kpi-edit .label,.analytics .impac-kpi .kpi .kpi-edit .modal,.analytics .impac-kpi .kpi .kpi-edit .nav>.active>a,.analytics .impac-kpi .kpi .kpi-edit .navbar-inner,.analytics .impac-kpi .kpi .kpi-edit .popover,.analytics .impac-kpi .kpi .kpi-edit .progress,.analytics .impac-kpi .kpi .kpi-edit .table-bordered,.analytics .impac-kpi .kpi .kpi-edit .tooltip,.analytics .impac-kpi .kpi .kpi-edit .tooltip-inner,.analytics .impac-kpi .kpi .kpi-edit .well,.analytics .impac-kpi .kpi .kpi-edit input,.analytics .impac-kpi .kpi .kpi-edit pre,.analytics .impac-kpi .kpi .kpi-edit select,.analytics .impac-kpi .kpi .kpi-edit textarea,.analytics .impac-kpi .kpi .kpi-no-data .add-on,.analytics .impac-kpi .kpi .kpi-no-data .alert,.analytics .impac-kpi .kpi .kpi-no-data .badge,.analytics .impac-kpi .kpi .kpi-no-data .btn,.analytics .impac-kpi .kpi .kpi-no-data .dropdown-menu,.analytics .impac-kpi .kpi .kpi-no-data .img-polaroid,.analytics .impac-kpi .kpi .kpi-no-data .label,.analytics .impac-kpi .kpi .kpi-no-data .modal,.analytics .impac-kpi .kpi .kpi-no-data .nav>.active>a,.analytics .impac-kpi .kpi .kpi-no-data .navbar-inner,.analytics .impac-kpi .kpi .kpi-no-data .popover,.analytics .impac-kpi .kpi .kpi-no-data .progress,.analytics .impac-kpi .kpi .kpi-no-data .table-bordered,.analytics .impac-kpi .kpi .kpi-no-data .tooltip,.analytics .impac-kpi .kpi .kpi-no-data .tooltip-inner,.analytics .impac-kpi .kpi .kpi-no-data .well,.analytics .impac-kpi .kpi .kpi-no-data input,.analytics .impac-kpi .kpi .kpi-no-data pre,.analytics .impac-kpi .kpi .kpi-no-data select,.analytics .impac-kpi .kpi .kpi-no-data textarea{box-shadow:none!important;border-radius:0!important;border-collapse:collapse!important;background-image:none!important}.analytics .impac-kpi .kpi .kpi-edit body,.analytics .impac-kpi .kpi .kpi-edit body::after,.analytics .impac-kpi .kpi .kpi-edit body::before,.analytics .impac-kpi .kpi .kpi-edit input,.analytics .impac-kpi .kpi .kpi-edit input::after,.analytics .impac-kpi .kpi .kpi-edit input::before,.analytics .impac-kpi .kpi .kpi-edit select,.analytics .impac-kpi .kpi .kpi-edit select::after,.analytics .impac-kpi .kpi .kpi-edit select::before,.analytics .impac-kpi .kpi .kpi-edit textarea,.analytics .impac-kpi .kpi .kpi-edit textarea::after,.analytics .impac-kpi .kpi .kpi-edit textarea::before,.analytics .impac-kpi .kpi .kpi-no-data body,.analytics .impac-kpi .kpi .kpi-no-data body::after,.analytics .impac-kpi .kpi .kpi-no-data body::before,.analytics .impac-kpi .kpi .kpi-no-data input,.analytics .impac-kpi .kpi .kpi-no-data input::after,.analytics .impac-kpi .kpi .kpi-no-data input::before,.analytics .impac-kpi .kpi .kpi-no-data select,.analytics .impac-kpi .kpi .kpi-no-data select::after,.analytics .impac-kpi .kpi .kpi-no-data select::before,.analytics .impac-kpi .kpi .kpi-no-data textarea,.analytics .impac-kpi .kpi .kpi-no-data textarea::after,.analytics .impac-kpi .kpi .kpi-no-data textarea::before{box-sizing:border-box}.analytics .impac-kpi .kpi .kpi-edit input[type=number]::-webkit-inner-spin-button,.analytics .impac-kpi .kpi .kpi-edit input[type=number]::-webkit-outer-spin-button,.analytics .impac-kpi .kpi .kpi-no-data input[type=number]::-webkit-inner-spin-button,.analytics .impac-kpi .kpi .kpi-no-data input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.analytics .impac-kpi .kpi .kpi-edit a:hover,.analytics .impac-kpi .kpi .kpi-no-data a:hover{text-decoration:none}.analytics .impac-kpi .kpi .kpi-edit fieldset,.analytics .impac-kpi .kpi .kpi-no-data fieldset{margin:0 0 1.75rem;padding:0;border:none}.analytics .impac-kpi .kpi .kpi-edit .im-form-group,.analytics .impac-kpi .kpi .kpi-edit .im-form-radio,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group,.analytics .impac-kpi .kpi .kpi-no-data .im-form-radio{position:relative;margin-top:1.3125rem;margin-bottom:1.3125rem}.analytics .impac-kpi .kpi .kpi-edit .im-form-inline,.analytics .impac-kpi .kpi .kpi-no-data .im-form-inline{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row;box-sizing:border-box}.analytics .impac-kpi .kpi .kpi-edit .im-form-inline>.im-form-group,.analytics .impac-kpi .kpi .kpi-no-data .im-form-inline>.im-form-group{display:block;-webkit-box-flex:1;-ms-flex:1;flex:1;position:relative;vertical-align:middle;margin-left:.175rem;margin-right:.175rem}.analytics .impac-kpi .kpi .kpi-edit .im-form-inline>.btn,.analytics .impac-kpi .kpi .kpi-no-data .im-form-inline>.btn{display:inline-block;margin-bottom:0}.analytics .impac-kpi .kpi .kpi-edit .im-form-group input,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input{height:2.375rem}.analytics .impac-kpi .kpi .kpi-edit .im-form-group select,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select{width:100%;font-size:1.25rem;height:2rem;padding:.15625rem .15625rem .078125rem;background:0 0;border:none;line-height:1.6;box-shadow:none}.analytics .impac-kpi .kpi .kpi-edit .im-form-group .im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group .im-control-label{position:absolute;top:.3125rem;pointer-events:none;padding-left:.15625rem;z-index:1;color:#b3b3b3;font-size:1.25rem;font-weight:400;-webkit-transition:all .28s ease;transition:all .28s ease}.analytics .impac-kpi .kpi .kpi-edit .im-form-group .im-bar,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group .im-bar{position:relative;border-bottom:.078125rem solid #999;display:block}.analytics .impac-kpi .kpi .kpi-edit .im-form-group .im-bar::before,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group .im-bar::before{content:'';height:.15625rem;width:0;left:50%;bottom:-.078125rem;position:absolute;background:#358fdc;-webkit-transition:left .28s ease,width .28s ease;transition:left .28s ease,width .28s ease;z-index:2}.analytics .impac-kpi .kpi .kpi-edit .im-form-group input,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea{display:block;background:0 0;padding:.15625rem .15625rem .078125rem;font-size:1.25rem;border-width:0;border-color:transparent;line-height:1.9;width:100%;color:transparent;-webkit-transition:all .28s ease;transition:all .28s ease;box-shadow:none}.analytics .impac-kpi .kpi .kpi-edit .im-form-group input[type=file],.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input[type=file]{line-height:1}.analytics .impac-kpi .kpi .kpi-edit .im-form-group input[type=file]~.im-bar,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input[type=file]~.im-bar{display:none}.analytics .impac-kpi .kpi .kpi-edit .im-form-group input.form-file,.analytics .impac-kpi .kpi .kpi-edit .im-form-group input.has-value,.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:focus,.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:valid,.analytics .impac-kpi .kpi .kpi-edit .im-form-group select,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea.form-file,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea.has-value,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:focus,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:valid,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input.form-file,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input.has-value,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:focus,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:valid,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea.form-file,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea.has-value,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:focus,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:valid{color:#333}.analytics .impac-kpi .kpi .kpi-edit .im-form-group input.form-file~.im-control-label,.analytics .impac-kpi .kpi .kpi-edit .im-form-group input.has-value~.im-control-label,.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:focus~.im-control-label,.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:valid~.im-control-label,.analytics .impac-kpi .kpi .kpi-edit .im-form-group select~.im-control-label,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea.form-file~.im-control-label,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea.has-value~.im-control-label,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:focus~.im-control-label,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:valid~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input.form-file~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input.has-value~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:focus~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:valid~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea.form-file~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea.has-value~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:focus~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:valid~.im-control-label{font-size:1rem;color:grey;top:-1.25rem;left:0}.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:focus,.analytics .impac-kpi .kpi .kpi-edit .im-form-group select:focus,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:focus,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:focus,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select:focus,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:focus{outline:0}.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:focus~.im-control-label,.analytics .impac-kpi .kpi .kpi-edit .im-form-group select:focus~.im-control-label,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:focus~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:focus~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select:focus~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:focus~.im-control-label{color:#358fdc}.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:focus~.im-bar::before,.analytics .impac-kpi .kpi .kpi-edit .im-form-group select:focus~.im-bar::before,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:focus~.im-bar::before,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:focus~.im-bar::before,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select:focus~.im-bar::before,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:focus~.im-bar::before{width:100%;left:0}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox label,.analytics .impac-kpi .kpi .kpi-edit .im-form-radio label,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-radio label{position:relative;cursor:pointer;padding-left:2.5rem;text-align:left;color:#333;display:block}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input,.analytics .impac-kpi .kpi .kpi-edit .im-form-radio input,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input,.analytics .impac-kpi .kpi .kpi-no-data .im-form-radio input{width:auto;opacity:.00000001;position:absolute;left:0}.analytics .impac-kpi .kpi .kpi-edit .im-radio,.analytics .impac-kpi .kpi .kpi-no-data .im-radio{margin-bottom:1.25rem}.analytics .impac-kpi .kpi .kpi-edit .im-radio .im-helper,.analytics .impac-kpi .kpi .kpi-no-data .im-radio .im-helper{position:absolute;top:-.3125rem;left:-.3125rem;cursor:pointer;display:block;font-size:1.25rem;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;color:#999}.analytics .impac-kpi .kpi .kpi-edit .im-radio .im-helper::after,.analytics .impac-kpi .kpi .kpi-edit .im-radio .im-helper::before,.analytics .impac-kpi .kpi .kpi-no-data .im-radio .im-helper::after,.analytics .impac-kpi .kpi .kpi-no-data .im-radio .im-helper::before{content:'';position:absolute;left:0;top:0;margin:.3125rem;width:1.25rem;height:1.25rem;-webkit-transition:-webkit-transform .28s ease;transition:-webkit-transform .28s ease;transition:transform .28s ease;transition:transform .28s ease,-webkit-transform .28s ease;border-radius:50%;border:.15625rem solid currentColor}.analytics .impac-kpi .kpi .kpi-edit .im-radio .im-helper::after,.analytics .impac-kpi .kpi .kpi-no-data .im-radio .im-helper::after{-webkit-transform:scale(0);transform:scale(0);background-color:#358fdc;border-color:#358fdc}.analytics .impac-kpi .kpi .kpi-edit .im-radio label:hover .im-helper,.analytics .impac-kpi .kpi .kpi-no-data .im-radio label:hover .im-helper{color:#358fdc}.analytics .impac-kpi .kpi .kpi-edit .im-radio input:checked~.im-helper::after,.analytics .impac-kpi .kpi .kpi-no-data .im-radio input:checked~.im-helper::after{-webkit-transform:scale(.5);transform:scale(.5)}.analytics .impac-kpi .kpi .kpi-edit .im-radio input:checked~.im-helper::before,.analytics .impac-kpi .kpi .kpi-no-data .im-radio input:checked~.im-helper::before{color:#358fdc}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox{margin-top:1.75rem;margin-bottom:1.25rem}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox .im-helper,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox .im-helper{color:#999;position:absolute;top:0;left:0;width:1.25rem;height:1.25rem;z-index:0;border:.15625rem solid currentColor;border-radius:.078125rem;-webkit-transition:border-color .28s ease;transition:border-color .28s ease}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox .im-helper::after,.analytics .impac-kpi .kpi .kpi-edit .im-checkbox .im-helper::before,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox .im-helper::after,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox .im-helper::before{position:absolute;height:0;width:.25rem;background-color:#358fdc;display:block;-webkit-transform-origin:left top;transform-origin:left top;border-radius:.3125rem;content:'';-webkit-transition:opacity .28s ease,height 0s linear .28s;transition:opacity .28s ease,height 0s linear .28s;opacity:0}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox .im-helper::before,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox .im-helper::before{top:.8125rem;left:.475rem;-webkit-transform:rotate(-135deg);transform:rotate(-135deg);box-shadow:0 0 0 .078125rem #fff}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox .im-helper::after,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox .im-helper::after{top:.375rem;left:0;-webkit-transform:rotate(-45deg);transform:rotate(-45deg)}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox label:hover .im-helper,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox label:hover .im-helper{color:#358fdc}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input:checked~.im-helper,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input:checked~.im-helper{color:#358fdc}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input:checked~.im-helper::after,.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input:checked~.im-helper::before,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input:checked~.im-helper::after,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input:checked~.im-helper::before{opacity:1;-webkit-transition:height .28s ease;transition:height .28s ease}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input:checked~.im-helper::after,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input:checked~.im-helper::after{height:.625rem}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input:checked~.im-helper::before,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input:checked~.im-helper::before{height:1.5rem;-webkit-transition-delay:.28s;transition-delay:.28s}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox+.im-checkbox,.analytics .impac-kpi .kpi .kpi-edit .im-radio+.im-radio,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox+.im-checkbox,.analytics .impac-kpi .kpi .kpi-no-data .im-radio+.im-radio{margin-top:1.25rem}.analytics .impac-kpi .kpi .kpi-edit .im-messages,.analytics .impac-kpi .kpi .kpi-no-data .im-messages{font-size:1.04166667rem;color:#e01f74;overflow:hidden;-webkit-transition:all .28s cubic-bezier(.55,0,.55,.2);transition:all .28s cubic-bezier(.55,0,.55,.2);opacity:0;margin-top:0;padding-top:5px}.analytics .impac-kpi .kpi .kpi-edit .has-error .legend.legend,.analytics .impac-kpi .kpi .kpi-edit .has-error.im-form-group .im-control-label.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .has-error .legend.legend,.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-form-group .im-control-label.im-control-label{color:#e01f74}.analytics .impac-kpi .kpi .kpi-edit .has-error.im-checkbox .im-helper,.analytics .impac-kpi .kpi .kpi-edit .has-error.im-checkbox .im-messages,.analytics .impac-kpi .kpi .kpi-edit .has-error.im-form-group .im-helper,.analytics .impac-kpi .kpi .kpi-edit .has-error.im-form-group .im-messages,.analytics .impac-kpi .kpi .kpi-edit .has-error.im-form-radio .im-helper,.analytics .impac-kpi .kpi .kpi-edit .has-error.im-form-radio .im-messages,.analytics .impac-kpi .kpi .kpi-edit .has-error.im-radio .im-helper,.analytics .impac-kpi .kpi .kpi-edit .has-error.im-radio .im-messages,.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-checkbox .im-helper,.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-checkbox .im-messages,.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-form-group .im-helper,.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-form-group .im-messages,.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-form-radio .im-helper,.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-form-radio .im-messages,.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-radio .im-helper,.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-radio .im-messages{color:#e01f74;opacity:1}.analytics .impac-kpi .kpi .kpi-edit .has-error .im-bar::before,.analytics .impac-kpi .kpi .kpi-no-data .has-error .im-bar::before{background:#e01f74;left:0;width:100%}.analytics .impac-kpi .kpi .kpi-edit .im-button,.analytics .impac-kpi .kpi .kpi-no-data .im-button{position:relative;background:#60a7e4;border:0;font-size:1.375rem;color:#333;margin:.7rem 0;padding:.4375rem 1.75rem;border-radius:3px;cursor:pointer;overflow:hidden;box-shadow:0 2px 2px 0 rgba(0,0,0,.14),0 3px 1px -2px rgba(0,0,0,.2),0 1px 5px 0 rgba(0,0,0,.12)}.analytics .impac-kpi .kpi .kpi-edit .im-button span,.analytics .impac-kpi .kpi .kpi-no-data .im-button span{color:#fff;position:relative;z-index:1}.analytics .impac-kpi .kpi .kpi-edit .im-button:hover,.analytics .impac-kpi .kpi .kpi-no-data .im-button:hover{-webkit-transition:background .1s ease-in;transition:background .1s ease-in;background:#2583d3}.analytics .impac-kpi .kpi .kpi-edit .im-button:active,.analytics .impac-kpi .kpi .kpi-no-data .im-button:active{box-shadow:inset 0 2px 2px 0 rgba(0,0,0,.14)}.analytics .impac-kpi .kpi .kpi-edit .im-button a:focus,.analytics .impac-kpi .kpi .kpi-edit .im-button:focus,.analytics .impac-kpi .kpi .kpi-no-data .im-button a:focus,.analytics .impac-kpi .kpi .kpi-no-data .im-button:focus{outline:0;text-decoration:none}.analytics .impac-kpi .kpi .kpi-edit button.im-fab,.analytics .impac-kpi .kpi .kpi-no-data button.im-fab{position:relative;height:46px;width:46px;-webkit-box-flex:0;-ms-flex:0 0 56px;flex:0 0 56px;display:inline-block;padding:0;margin:4px;border:0;border-radius:100%;overflow:hidden;font-size:20px;box-shadow:0 4px 5px 0 rgba(0,0,0,.14),0 1px 10px 0 rgba(0,0,0,.12),0 2px 4px -1px rgba(0,0,0,.2);color:#fff}.analytics .impac-kpi .kpi .kpi-edit button.im-fab:focus,.analytics .impac-kpi .kpi .kpi-no-data button.im-fab:focus{outline:0}.analytics .impac-kpi .kpi .kpi-edit button.im-fab:active,.analytics .impac-kpi .kpi .kpi-no-data button.im-fab:active{box-shadow:inset 0 2px 2px 0 rgba(0,0,0,.14)}.analytics .impac-kpi .kpi .kpi-edit button.im-fab.im-primary,.analytics .impac-kpi .kpi .kpi-no-data button.im-fab.im-primary{background:#358fdc}.analytics .impac-kpi .kpi .kpi-edit button.im-fab.im-primary:hover,.analytics .impac-kpi .kpi .kpi-no-data button.im-fab.im-primary:hover{-webkit-transition:background .1s ease-in;transition:background .1s ease-in;background:#2583d3}.analytics .impac-kpi .kpi .kpi-edit button.im-fab.im-warn,.analytics .impac-kpi .kpi .kpi-no-data button.im-fab.im-warn{background:#e01f74}.analytics .impac-kpi .kpi .kpi-edit button.im-fab.im-warn:hover,.analytics .impac-kpi .kpi .kpi-no-data button.im-fab.im-warn:hover{-webkit-transition:background .1s ease-in;transition:background .1s ease-in;background:#ca1c68}.analytics .impac-kpi .kpi button.kpi-alerts.im-fab.im-primary{position:absolute;top:-12px;right:15px;width:22px;height:22px;font-size:13px;background:#4c4749}.analytics .impac-kpi .kpi button.kpi-alerts.im-fab.im-primary:hover{backgroud:#358fdc}.analytics .impac-kpi .kpi button.kpi-remove.im-fab.im-warn{position:absolute;top:-12px;right:-11px;width:22px;height:22px;font-size:13px;background:#4c4749}.analytics .impac-kpi .kpi button.kpi-remove.im-fab.im-warn:hover{background:#ca1c68}.analytics .impac-kpi .kpi .kpi-data-loader{width:100%;min-height:95px}.analytics kpis-bar>.key-stats .kpi{min-height:80px}.analytics kpis-bar>.kpis{position:relative}.analytics kpis-bar>.kpis .actions{margin-bottom:12px}@media screen and (max-width:675px){.analytics kpis-bar>.kpis .actions{position:relative}}.analytics kpis-bar>.kpis .actions .add-on,.analytics kpis-bar>.kpis .actions .alert,.analytics kpis-bar>.kpis .actions .badge,.analytics kpis-bar>.kpis .actions .btn,.analytics kpis-bar>.kpis .actions .dropdown-menu,.analytics kpis-bar>.kpis .actions .img-polaroid,.analytics kpis-bar>.kpis .actions .label,.analytics kpis-bar>.kpis .actions .modal,.analytics kpis-bar>.kpis .actions .nav>.active>a,.analytics kpis-bar>.kpis .actions .navbar-inner,.analytics kpis-bar>.kpis .actions .popover,.analytics kpis-bar>.kpis .actions .progress,.analytics kpis-bar>.kpis .actions .table-bordered,.analytics kpis-bar>.kpis .actions .tooltip,.analytics kpis-bar>.kpis .actions .tooltip-inner,.analytics kpis-bar>.kpis .actions .well,.analytics kpis-bar>.kpis .actions input,.analytics kpis-bar>.kpis .actions pre,.analytics kpis-bar>.kpis .actions select,.analytics kpis-bar>.kpis .actions textarea{box-shadow:none!important;border-radius:0!important;border-collapse:collapse!important;background-image:none!important}.analytics kpis-bar>.kpis .actions body,.analytics kpis-bar>.kpis .actions body::after,.analytics kpis-bar>.kpis .actions body::before,.analytics kpis-bar>.kpis .actions input,.analytics kpis-bar>.kpis .actions input::after,.analytics kpis-bar>.kpis .actions input::before,.analytics kpis-bar>.kpis .actions select,.analytics kpis-bar>.kpis .actions select::after,.analytics kpis-bar>.kpis .actions select::before,.analytics kpis-bar>.kpis .actions textarea,.analytics kpis-bar>.kpis .actions textarea::after,.analytics kpis-bar>.kpis .actions textarea::before{box-sizing:border-box}.analytics kpis-bar>.kpis .actions input[type=number]::-webkit-inner-spin-button,.analytics kpis-bar>.kpis .actions input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.analytics kpis-bar>.kpis .actions a:hover{text-decoration:none}.analytics kpis-bar>.kpis .actions fieldset{margin:0 0 1.75rem;padding:0;border:none}.analytics kpis-bar>.kpis .actions .im-form-group,.analytics kpis-bar>.kpis .actions .im-form-radio{position:relative;margin-top:1.3125rem;margin-bottom:1.3125rem}.analytics kpis-bar>.kpis .actions .im-form-inline{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-direction:row;flex-direction:row;box-sizing:border-box}.analytics kpis-bar>.kpis .actions .im-form-inline>.im-form-group{display:block;-webkit-box-flex:1;-ms-flex:1;flex:1;position:relative;vertical-align:middle;margin-left:.175rem;margin-right:.175rem}.analytics kpis-bar>.kpis .actions .im-form-inline>.btn{display:inline-block;margin-bottom:0}.analytics kpis-bar>.kpis .actions .im-form-group input{height:2.375rem}.analytics kpis-bar>.kpis .actions .im-form-group select{width:100%;font-size:1.25rem;height:2rem;padding:.15625rem .15625rem .078125rem;background:0 0;border:none;line-height:1.6;box-shadow:none}.analytics kpis-bar>.kpis .actions .im-form-group .im-control-label{position:absolute;top:.3125rem;pointer-events:none;padding-left:.15625rem;z-index:1;color:#b3b3b3;font-size:1.25rem;font-weight:400;-webkit-transition:all .28s ease;transition:all .28s ease}.analytics kpis-bar>.kpis .actions .im-form-group .im-bar{position:relative;border-bottom:.078125rem solid #999;display:block}.analytics kpis-bar>.kpis .actions .im-form-group .im-bar::before{content:'';height:.15625rem;width:0;left:50%;bottom:-.078125rem;position:absolute;background:#358fdc;-webkit-transition:left .28s ease,width .28s ease;transition:left .28s ease,width .28s ease;z-index:2}.analytics kpis-bar>.kpis .actions .im-form-group input,.analytics kpis-bar>.kpis .actions .im-form-group textarea{display:block;background:0 0;padding:.15625rem .15625rem .078125rem;font-size:1.25rem;border-width:0;border-color:transparent;line-height:1.9;width:100%;color:transparent;-webkit-transition:all .28s ease;transition:all .28s ease;box-shadow:none}.analytics .settings.dates-picker button.btn.btn-sm,.analytics kpis-bar>.kpis .actions .im-form-group input[type=file]{line-height:1}.analytics kpis-bar>.kpis .actions .im-form-group input[type=file]~.im-bar{display:none}.analytics kpis-bar>.kpis .actions .im-form-group input.form-file,.analytics kpis-bar>.kpis .actions .im-form-group input.has-value,.analytics kpis-bar>.kpis .actions .im-form-group input:focus,.analytics kpis-bar>.kpis .actions .im-form-group input:valid,.analytics kpis-bar>.kpis .actions .im-form-group select,.analytics kpis-bar>.kpis .actions .im-form-group textarea.form-file,.analytics kpis-bar>.kpis .actions .im-form-group textarea.has-value,.analytics kpis-bar>.kpis .actions .im-form-group textarea:focus,.analytics kpis-bar>.kpis .actions .im-form-group textarea:valid{color:#333}.analytics kpis-bar>.kpis .actions .im-form-group input.form-file~.im-control-label,.analytics kpis-bar>.kpis .actions .im-form-group input.has-value~.im-control-label,.analytics kpis-bar>.kpis .actions .im-form-group input:focus~.im-control-label,.analytics kpis-bar>.kpis .actions .im-form-group input:valid~.im-control-label,.analytics kpis-bar>.kpis .actions .im-form-group select~.im-control-label,.analytics kpis-bar>.kpis .actions .im-form-group textarea.form-file~.im-control-label,.analytics kpis-bar>.kpis .actions .im-form-group textarea.has-value~.im-control-label,.analytics kpis-bar>.kpis .actions .im-form-group textarea:focus~.im-control-label,.analytics kpis-bar>.kpis .actions .im-form-group textarea:valid~.im-control-label{font-size:1rem;color:grey;top:-1.25rem;left:0}.analytics kpis-bar>.kpis .actions .im-form-group input:focus,.analytics kpis-bar>.kpis .actions .im-form-group select:focus,.analytics kpis-bar>.kpis .actions .im-form-group textarea:focus{outline:0}.analytics kpis-bar>.kpis .actions .im-form-group input:focus~.im-control-label,.analytics kpis-bar>.kpis .actions .im-form-group select:focus~.im-control-label,.analytics kpis-bar>.kpis .actions .im-form-group textarea:focus~.im-control-label{color:#358fdc}.analytics kpis-bar>.kpis .actions .im-form-group input:focus~.im-bar::before,.analytics kpis-bar>.kpis .actions .im-form-group select:focus~.im-bar::before,.analytics kpis-bar>.kpis .actions .im-form-group textarea:focus~.im-bar::before{width:100%;left:0}.analytics kpis-bar>.kpis .actions .im-checkbox label,.analytics kpis-bar>.kpis .actions .im-form-radio label{position:relative;cursor:pointer;padding-left:2.5rem;text-align:left;color:#333;display:block}.analytics kpis-bar>.kpis .actions .im-checkbox input,.analytics kpis-bar>.kpis .actions .im-form-radio input{width:auto;opacity:.00000001;position:absolute;left:0}.analytics kpis-bar>.kpis .actions .im-radio{margin-bottom:1.25rem}.analytics kpis-bar>.kpis .actions .im-radio .im-helper{position:absolute;top:-.3125rem;left:-.3125rem;cursor:pointer;display:block;font-size:1.25rem;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;color:#999}.analytics kpis-bar>.kpis .actions .im-radio .im-helper::after,.analytics kpis-bar>.kpis .actions .im-radio .im-helper::before{content:'';position:absolute;left:0;top:0;margin:.3125rem;width:1.25rem;height:1.25rem;-webkit-transition:-webkit-transform .28s ease;transition:-webkit-transform .28s ease;transition:transform .28s ease;transition:transform .28s ease,-webkit-transform .28s ease;border-radius:50%;border:.15625rem solid currentColor}.analytics kpis-bar>.kpis .actions .im-radio .im-helper::after{-webkit-transform:scale(0);transform:scale(0);background-color:#358fdc;border-color:#358fdc}.analytics kpis-bar>.kpis .actions .im-radio label:hover .im-helper{color:#358fdc}.analytics kpis-bar>.kpis .actions .im-radio input:checked~.im-helper::after{-webkit-transform:scale(.5);transform:scale(.5)}.analytics kpis-bar>.kpis .actions .im-radio input:checked~.im-helper::before{color:#358fdc}.analytics kpis-bar>.kpis .actions .im-checkbox{margin-top:1.75rem;margin-bottom:1.25rem}.analytics kpis-bar>.kpis .actions .im-checkbox .im-helper{color:#999;position:absolute;top:0;left:0;width:1.25rem;height:1.25rem;z-index:0;border:.15625rem solid currentColor;border-radius:.078125rem;-webkit-transition:border-color .28s ease;transition:border-color .28s ease}.analytics kpis-bar>.kpis .actions .im-checkbox .im-helper::after,.analytics kpis-bar>.kpis .actions .im-checkbox .im-helper::before{position:absolute;height:0;width:.25rem;background-color:#358fdc;display:block;-webkit-transform-origin:left top;transform-origin:left top;border-radius:.3125rem;content:'';-webkit-transition:opacity .28s ease,height 0s linear .28s;transition:opacity .28s ease,height 0s linear .28s;opacity:0}.analytics kpis-bar>.kpis .actions .im-checkbox .im-helper::before{top:.8125rem;left:.475rem;-webkit-transform:rotate(-135deg);transform:rotate(-135deg);box-shadow:0 0 0 .078125rem #fff}.analytics kpis-bar>.kpis .actions .im-checkbox .im-helper::after{top:.375rem;left:0;-webkit-transform:rotate(-45deg);transform:rotate(-45deg)}.analytics kpis-bar>.kpis .actions .im-checkbox label:hover .im-helper{color:#358fdc}.analytics kpis-bar>.kpis .actions .im-checkbox input:checked~.im-helper{color:#358fdc}.analytics kpis-bar>.kpis .actions .im-checkbox input:checked~.im-helper::after,.analytics kpis-bar>.kpis .actions .im-checkbox input:checked~.im-helper::before{opacity:1;-webkit-transition:height .28s ease;transition:height .28s ease}.analytics kpis-bar>.kpis .actions .im-checkbox input:checked~.im-helper::after{height:.625rem}.analytics kpis-bar>.kpis .actions .im-checkbox input:checked~.im-helper::before{height:1.5rem;-webkit-transition-delay:.28s;transition-delay:.28s}.analytics kpis-bar>.kpis .actions .im-checkbox+.im-checkbox,.analytics kpis-bar>.kpis .actions .im-radio+.im-radio{margin-top:1.25rem}.analytics kpis-bar>.kpis .actions .im-messages{font-size:1.04166667rem;color:#e01f74;overflow:hidden;-webkit-transition:all .28s cubic-bezier(.55,0,.55,.2);transition:all .28s cubic-bezier(.55,0,.55,.2);opacity:0;margin-top:0;padding-top:5px}.analytics kpis-bar>.kpis .actions .has-error .legend.legend,.analytics kpis-bar>.kpis .actions .has-error.im-form-group .im-control-label.im-control-label{color:#e01f74}.analytics kpis-bar>.kpis .actions .has-error.im-checkbox .im-helper,.analytics kpis-bar>.kpis .actions .has-error.im-checkbox .im-messages,.analytics kpis-bar>.kpis .actions .has-error.im-form-group .im-helper,.analytics kpis-bar>.kpis .actions .has-error.im-form-group .im-messages,.analytics kpis-bar>.kpis .actions .has-error.im-form-radio .im-helper,.analytics kpis-bar>.kpis .actions .has-error.im-form-radio .im-messages,.analytics kpis-bar>.kpis .actions .has-error.im-radio .im-helper,.analytics kpis-bar>.kpis .actions .has-error.im-radio .im-messages{color:#e01f74;opacity:1}.analytics kpis-bar>.kpis .actions .has-error .im-bar::before{background:#e01f74;left:0;width:100%}.analytics kpis-bar>.kpis .actions .im-button{position:relative;background:#60a7e4;border:0;font-size:1.375rem;color:#333;margin:.7rem 0;padding:.4375rem 1.75rem;border-radius:3px;cursor:pointer;overflow:hidden;box-shadow:0 2px 2px 0 rgba(0,0,0,.14),0 3px 1px -2px rgba(0,0,0,.2),0 1px 5px 0 rgba(0,0,0,.12)}.analytics kpis-bar>.kpis .actions .im-button span{color:#fff;position:relative;z-index:1}.analytics kpis-bar>.kpis .actions .im-button:hover{-webkit-transition:background .1s ease-in;transition:background .1s ease-in;background:#2583d3}.analytics kpis-bar>.kpis .actions .im-button:active{box-shadow:inset 0 2px 2px 0 rgba(0,0,0,.14)}.analytics kpis-bar>.kpis .actions .im-button a:focus,.analytics kpis-bar>.kpis .actions .im-button:focus{outline:0;text-decoration:none}.analytics kpis-bar>.kpis .actions button.im-fab{position:relative;height:46px;width:46px;-webkit-box-flex:0;-ms-flex:0 0 56px;flex:0 0 56px;display:inline-block;padding:0;margin:4px;border:0;border-radius:100%;overflow:hidden;font-size:20px;box-shadow:0 4px 5px 0 rgba(0,0,0,.14),0 1px 10px 0 rgba(0,0,0,.12),0 2px 4px -1px rgba(0,0,0,.2);color:#fff}.analytics kpis-bar>.kpis .actions button.im-fab:focus{outline:0}.analytics kpis-bar>.kpis .actions button.im-fab:active{box-shadow:inset 0 2px 2px 0 rgba(0,0,0,.14)}.analytics kpis-bar>.kpis .actions button.im-fab.im-primary{background:#358fdc}.analytics kpis-bar>.kpis .actions button.im-fab.im-primary:hover{-webkit-transition:background .1s ease-in;transition:background .1s ease-in;background:#2583d3}.analytics kpis-bar>.kpis .actions button.im-fab.im-warn{background:#e01f74}.analytics kpis-bar>.kpis .actions button.im-fab.im-warn:hover{-webkit-transition:background .1s ease-in;transition:background .1s ease-in;background:#ca1c68}.analytics kpis-bar>.kpis .actions a{color:#fff}.analytics kpis-bar>.kpis .actions button.im-fab.add-kpis,.analytics kpis-bar>.kpis .actions button.im-fab.edit-kpis,.analytics kpis-bar>.kpis .actions button.im-fab.toggle-show-content{position:absolute;width:40px;height:40px;font-size:18px;-webkit-transition:all .28s ease-in;transition:all .28s ease-in}.analytics kpis-bar>.kpis .actions button.im-fab.add-kpis.im-primary,.analytics kpis-bar>.kpis .actions button.im-fab.edit-kpis.im-primary,.analytics kpis-bar>.kpis .actions button.im-fab.toggle-show-content.im-primary{background:#4c4749}.analytics kpis-bar>.kpis .actions button.im-fab.add-kpis.im-primary.disabled,.analytics kpis-bar>.kpis .actions button.im-fab.edit-kpis.im-primary.disabled,.analytics kpis-bar>.kpis .actions button.im-fab.toggle-show-content.im-primary.disabled{background:#b2b5c1;cursor:not-allowed}.analytics kpis-bar>.kpis .actions button.im-fab.add-kpis.im-primary.disabled a,.analytics kpis-bar>.kpis .actions button.im-fab.edit-kpis.im-primary.disabled a,.analytics kpis-bar>.kpis .actions button.im-fab.toggle-show-content.im-primary.disabled a{cursor:not-allowed}.analytics kpis-bar>.kpis .actions button.im-fab.add-kpis.im-primary:hover:not(.disabled),.analytics kpis-bar>.kpis .actions button.im-fab.edit-kpis.im-primary:hover:not(.disabled),.analytics kpis-bar>.kpis .actions button.im-fab.toggle-show-content.im-primary:hover:not(.disabled){background:#000}.analytics kpis-bar>.kpis .actions button.im-fab.toggle-show-content{top:-15px;right:-15px;z-index:10}@media screen and (max-width:675px){.analytics kpis-bar>.kpis .actions button.im-fab.toggle-show-content{top:-30px;right:-14px;bottom:0}}.analytics kpis-bar>.kpis .actions button.im-fab.add-kpis{top:30px;right:-15px;z-index:10}@media screen and (max-width:675px){.analytics kpis-bar>.kpis .actions button.im-fab.add-kpis{top:-30px;right:33px;bottom:0}}.analytics kpis-bar>.kpis .actions button.im-fab.edit-kpis{top:75px;right:-15px;z-index:10}.analytics kpis-bar>.kpis .actions button.im-fab.edit-kpis.editing{background:#358fdc}.analytics kpis-bar>.kpis .actions button.im-fab.edit-kpis.editing:hover:not(.disabled){background:#76b3e7}@media screen and (max-width:675px){.analytics kpis-bar>.kpis .actions button.im-fab.edit-kpis{top:-30px;right:79px;bottom:0}.analytics kpis-bar>.kpis .content{margin-top:25px}}.analytics kpis-bar>.kpis .content-buttons{position:absolute;top:0;right:0}.analytics kpis-bar>.kpis .content{padding:15px;background-color:#fff;box-shadow:0 1px 8px -4px}@media screen and (min-width:725px){.analytics kpis-bar>.kpis .content{padding:0 60px}}.analytics kpis-bar>.kpis .content .impac-kpi{padding-left:5px;padding-right:5px}@media screen and (min-width:1200px){.analytics kpis-bar>.kpis .content .impac-kpi{padding-left:20px;padding-right:20px}}.analytics kpis-bar>.kpis .content .impac-kpi .kpi.add .kpi-show .caption{white-space:inherit}.analytics kpis-bar>.kpis .content .title .text-center{line-height:3;font-variant:small-caps;font-size:larger}.analytics kpis-bar>.kpis .content .title .badge{position:absolute;top:8px;left:-10px;background-color:#d1e55c;color:#4f5959;box-shadow:0 1px 3px -1px}.widget-item .content,.widget-item .top-line{position:relative;background-color:#fff;box-shadow:0 1px 8px -4px}.analytics kpis-bar>.kpis .content .title .no-kpi-templates{color:#afadb5;font-weight:500}.analytics kpis-bar>.kpis .content .add-bar{border-bottom:dashed 1px}.analytics kpis-bar>.kpis .content .kpi-loader{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;min-height:115px}.analytics kpis-bar>.kpis .content .dates-picker-container{width:40%;margin:0 auto}.analytics kpis-bar>.kpis .content .dates-picker-container .sdp-from-label,.analytics kpis-bar>.kpis .content .dates-picker-container .sdp-to-label{text-transform:uppercase;font-weight:400}.analytics kpis-bar{display:block}.analytics kpis-bar>.key-stats{background-color:#fff;padding:5px 0}.analytics.pdf-mode kpis-bar>.kpis .actions{display:none}.widget-item{-webkit-transition:width .3s;transition:width .3s;padding:12px}.widget-item.pdf-mode{width:100%;padding:12px 0}.widget-item .top-line{cursor:move;padding:9px 9px 0 12px;border-radius:5px 5px 0 0;border:1px solid #c8d7d9;border-bottom:none;min-height:41px;display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-direction:row;flex-direction:row;z-index:4}.widget-item .content{padding:9px;border-radius:0 0 5px 5px;border:1px solid #c8d7d9;border-top:none;vertical-align:top;min-height:250px}@media (min-width:992px){.widget-item .content{height:250px}.widget-item .content .chart-container{max-width:270px;max-height:125px;margin:auto}}.widget-item .content .edit{max-height:230px;overflow-y:auto;overflow-x:hidden;color:#5B6667;padding:2px;font-size:12px}.widget-item .content .edit .bottom-buttons .btn{border-radius:2px;margin-right:5px;padding:3px 13px;text-transform:uppercase;font-size:12px}.widget-item .content .edit .bottom-buttons .btn.btn-default{background-color:#c2c4c4;border:1px solid #a8abab;color:#fff}.widget-item .content .edit .bottom-buttons .btn.btn-default:hover{border:1px solid #8e9292;background-color:#a8abab}.widget-item .content .edit h4{margin:0 0 8px;text-align:left;font-weight:400;font-size:12px;color:#c4caca}.widget-item .content .edit .part{margin-bottom:8px;padding:10px 0;background-color:#fcfcfc;border:1px solid #dfe2e2}.widget-item .content .edit .part h5{display:block;margin:0 0 10px;padding:0 15px;text-transform:uppercase;font-weight:400;font-size:12px;color:#c4caca}.widget-item .content .edit .part label{font-weight:400}.widget-item .content .edit .part select.form-control{margin:0;border:1px solid #acb0b1;outline:0;-webkit-box-shadow:none;font-size:13px;color:#72728b}.widget-item .content.accessible{height:auto!important;min-height:250px!important;max-height:auto!important}.widget-item .content .content-template-wrapper{height:100%;overflow:auto;overflow-x:hidden}.widget-item.pdf-mode .content{height:100%!important;min-height:250px!important;max-height:none!important}.widget-item.pdf-mode .content .collapse{display:inherit}.widget-item.pdf-mode .content .fa-plus-square-o:before{content:"\f147"}.widget-item.pdf-mode .content .legend{max-height:none!important}.widget-item.pdf-mode .content .chart-container{max-height:none}.widget-item.pdf-mode .content .widget-lines-container{max-height:none!important}.widget-item.pdf-mode .content .data-not-found .message{position:inherit;width:100%}.widget-item.pdf-mode .include-to-pdf.title{position:absolute;width:calc(100% - 2*12px);z-index:3;padding-right:1px}.widget-item.pdf-mode .include-to-pdf.title h6{padding:10px;background-color:#FFC928;text-align:center;margin:0}.widget-item.pdf-mode .include-to-pdf.tick i{position:absolute;top:35%;left:46%;font-size:100px;opacity:.5;z-index:2;color:#000}.widget-item.pdf-mode .include-to-pdf .widget-hover{position:absolute;width:100%;height:100%;padding:9px;top:0;right:0;-webkit-transition:all ease .5s;transition:all ease .5s;z-index:1}.widget-item.pdf-mode .include-to-pdf .widget-hover:hover{opacity:.5;background:#CCCFD0}.widget-item .widget-lines-container .widget-line>[class*=col-]{overflow-wrap:break-word}.analytics .kpi .data-not-found,.analytics .widget-item .content .data-not-found{text-align:center;font-size:13px;color:#5B6667}.analytics .kpi .data-not-found .overlay,.analytics .widget-item .content .data-not-found .overlay{background-color:#fff;position:absolute;height:calc(100% - 4px);width:calc(100% - 4px);top:2px;left:2px;opacity:.6;z-index:3}.analytics .kpi .data-not-found .message,.analytics .widget-item .content .data-not-found .message{position:absolute;top:125px;left:50%;padding-bottom:10px;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);width:85%;background-color:#f4f8f9;border-radius:4px;box-shadow:0 0 25px 0;z-index:4}.analytics .kpi .data-not-found .message .title,.analytics .widget-item .content .data-not-found .message .title{padding:2px;background-color:#192831;color:#fff;margin:-1px -1px 10px;text-transform:uppercase}.analytics .kpi .data-not-found .message p,.analytics .widget-item .content .data-not-found .message p{margin-left:5px;margin-right:5px}.analytics .kpi .data-not-found .message .btn,.analytics .widget-item .content .data-not-found .message .btn{margin-top:5px}.analytics .kpi .data-not-found .example,.analytics .widget-item .content .data-not-found .example{position:absolute;bottom:0;left:0;width:100%;color:#fff;background-color:#192831;padding:3px;z-index:6}.analytics .kpi .data-not-found .example a,.analytics .widget-item .content .data-not-found .example a{font-weight:400;color:#dae173}.analytics .kpi .data-not-found .message{width:90%;padding-bottom:0;border:1px solid silver;box-shadow:none}.analytics .kpi .data-not-found .message p{margin:5px}.analytics .kpi .data-not-found .btn,.analytics .kpi .data-not-found .example,.analytics .kpi .data-not-found .overlay,.analytics .kpi .data-not-found .title{display:none}#duplicate-transactions-list .top{height:40px}#duplicate-transactions-list .top a.back-link{font-weight:400}#duplicate-transactions-list .top .pagination{margin:0}#duplicate-transactions-list .table-striped tr.origin:nth-of-type(odd){background-color:#f9f9f9}#duplicate-transactions-list .table-container{max-height:calc(565px - 60px);overflow:auto}#duplicate-transactions-list .table-container div[uib-datepicker-popup-wrap]{display:inline-block}#duplicate-transactions-list .table-container button.btn.reset-date,#duplicate-transactions-list .table-container input.btn.btn-xs{margin-top:-2px}#duplicate-transactions-list .table-container .fa.fa-times{color:#e01f74;cursor:pointer}#duplicate-transactions-list .table-container tr.total{font-weight:700}#duplicate-transactions-list .table-container tr.total.invoices{background-color:#00e600}#duplicate-transactions-list .table-container tr.total.bills{background-color:#f57cb1}#transactions-add{text-align:center;font-size:13px;color:#5B6667}#transactions-add .overlay{background-color:#fff;position:absolute;height:calc(100% - 4px);width:calc(100% - 4px);top:2px;left:2px;opacity:.6;z-index:5}#transactions-add .message{z-index:6;position:absolute;min-height:160px;padding-bottom:10px;background-color:#f4f8f9;border-radius:4px;box-shadow:0 0 25px 0;top:30px;left:35%;width:30%}#transactions-add .message .title{padding:2px;background-color:#192831;color:#fff;margin:-1px -1px 10px;text-transform:uppercase}#transactions-add .message .form{padding:0 10px}#transactions-add .message .form .schedulable-section>label,#transactions-add .message .form>label{padding-top:10px;font-weight:400;margin-bottom:3px}#transactions-add .message .form input.form-control,#transactions-add .message .form select.form-control{width:90%;border-radius:2px;height:28px;font-size:13px}#transactions-add .message .form .btn-group{display:block;min-height:22px}#transactions-add .message .form .btn-group select{border-radius:2px;height:28px;margin-top:0}#transactions-add .message .form .repeat-btn select,#transactions-add .message .form .schedulable-section .btn-group select{height:22px}#transactions-add .message .form .disable{color:#888;font-style:italic}#transactions-add .message .form .never-disable{color:#000;font-style:normal}#transactions-add .message .form .repeat-btn{margin-top:30px}#transactions-add .message .form .repeat-btn input[type=checkbox]{vertical-align:text-bottom;margin:0}#transactions-add .message .form .repeat-btn .btn{float:none;border-color:#888}#transactions-add .message .form .schedulable-section{padding:5px;border:1px solid silver;margin-top:0;background-color:#fff}#transactions-add .message .form .schedulable-section .badge{font-weight:400;background-color:#888}#transactions-add .message .form .schedulable-section .interval-field{width:40px}#transactions-add .message .form .schedulable-section .btn-group{margin-left:10px}#transactions-add .message .form .schedulable-section .btn-group .btn{float:none;border-color:#888}#transactions-add .message .bottom{margin-top:20px}#transactions-list .top{height:40px;position:relative}#transactions-list .top .back{position:absolute}#transactions-list .top .resource-type{position:absolute;left:calc(50% - 98px)}@media (max-width:767px){#transactions-list .top .resource-type{left:unset;right:0}}#transactions-list .top .btn-group{display:-webkit-box;display:-ms-flexbox;display:flex}#transactions-list .bottom{height:40px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}#transactions-list .bottom .pagination{margin:0}#transactions-list .table-container{max-height:calc(565px - 100px);overflow:auto;width:100%}#transactions-list .table-container div[uib-datepicker-popup-wrap]{display:inline-block}#transactions-list .table-container button.btn.reset-date,#transactions-list .table-container input.btn.btn-xs{margin-top:-2px}#transactions-list .table-container .actions{cursor:pointer}#transactions-list .table-container .actions .fa.fa-times{color:#e01f74}#transactions-list .table-container tr.total{font-weight:700}#transactions-list .table-container tr.total.invoices{background-color:#c1d1b1}#transactions-list .table-container tr.total.bills{background-color:#e2aeb9}#transactions-list .table-container td>.expected-payment-date{display:-webkit-box;display:-ms-flexbox;display:flex}#transactions-list .table-container td>.expected-payment-date .reset-date{margin-left:3px}#trends-list .top{height:40px}#trends-list .top a.back-link{font-weight:400}#trends-list .top .pagination{margin:0}#trends-list .table-container{max-height:calc(565px - 60px);overflow:auto}#trends-list .table-container div[uib-datepicker-popup-wrap]{display:inline-block}#trends-list .table-container button.btn.reset-date,#trends-list .table-container input.btn.btn-xs{margin-top:-2px}#trends-add{text-align:center;font-size:13px;color:#5B6667}#trends-add .overlay{background-color:#fff;position:absolute;height:calc(100% - 4px);width:calc(100% - 4px);top:2px;left:2px;opacity:.6;z-index:5}#trends-add .message{z-index:6;position:absolute;min-height:160px;padding-bottom:10px;background-color:#f4f8f9;border-radius:4px;box-shadow:0 0 25px 0;top:30px;left:35%;width:30%}#trends-add .message .title{padding:2px;background-color:#192831;color:#fff;margin:-1px -1px 10px;text-transform:uppercase}#trends-add .message .form{padding:0 10px}#trends-add .message .form>label{padding-top:10px;font-weight:400;margin-bottom:3px}#trends-add .message .form input.form-control{width:90%;border-radius:2px;height:28px;font-size:13px}#trends-add .message .form .btn-group{display:block;min-height:22px;margin-top:10px}#trends-add .message .form .btn-group>.btn{float:none}#trends-add .message .form .btn-group input[type=radio]{margin:4px 0 10px}#trends-add .message .bottom{margin-top:20px}.analytics .dashboard-settings.currency{text-align:right}.analytics .dashboard-settings.currency select{margin-top:4px}.analytics .dashboard-settings.sync-apps .show-status{margin-right:5px;color:#9ba6a7}.analytics .dashboard-settings.sync-apps .show-status:hover{cursor:pointer;text-decoration:underline}.analytics .dashboard-settings.sync-apps .show-status .fa.fa-info{margin-right:2px}.analytics .dashboard-settings.sync-apps .status-btn{display:inline-block;cursor:pointer;padding:5px 7px 5px 0}.analytics .dashboard-settings.sync-apps .status-btn i{font-size:16px}.analytics .dashboard-settings.sync-apps .status-btn i.fa-exclamation-triangle{color:#ff7300}.analytics .dashboard-settings.sync-apps .status-btn i.fa-check{color:#d1e55c}.analytics .dashboard-settings.sync-apps .popover{max-width:550px}.analytics .dashboard-settings.sync-apps .popover .connector{padding:4px 13px}.analytics .dashboard-settings.sync-apps .popover .connector.add-seperator{border-bottom:1px solid #ccc}.analytics .dashboard-settings.sync-apps .popover .popover-content{padding:0}.analytics .dashboard-settings.sync-apps .popover .popover-footer{border-top:1px solid #ccc;padding:4px 13px}.analytics .dashboard-settings.sync-apps .popover .popover-footer p{font-weight:700;margin:0}.analytics .dashboard-settings.sync-apps .popover .popover-footer.remove-seperator{border:0}.analytics .dashboard-settings.sync-apps .badge{float:right;margin-left:8px}.analytics .dashboard-settings.sync-apps .success .badge{background-color:#d1e55c}.analytics .dashboard-settings.sync-apps .pending .badge,.analytics .dashboard-settings.sync-apps .running .badge{background-color:#ff7300}.analytics .dashboard-settings.sync-apps .disconnected .badge,.analytics .dashboard-settings.sync-apps .error .badge,.analytics .dashboard-settings.sync-apps .failed .badge,.analytics .dashboard-settings.sync-apps .unknown .badge{background-color:#ed1e79}#sync-apps-modal .modal-header{text-align:center;border:0;box-shadow:0 2px 3px 0 #ccc}#sync-apps-modal .modal-list{max-height:280px;overflow-y:auto}#sync-apps-modal .modal-list-item{border-bottom:1px solid #ccc;padding:10px}#sync-apps-modal .modal-list-item .badge{float:right}#sync-apps-modal .modal-list-item.success .badge{background-color:#d1e55c}#sync-apps-modal .modal-list-item.pending .badge,#sync-apps-modal .modal-list-item.running .badge{background-color:#ff7300}#sync-apps-modal .modal-list-item.disconnected .badge,#sync-apps-modal .modal-list-item.error .badge,#sync-apps-modal .modal-list-item.failed .badge,#sync-apps-modal .modal-list-item.unknown .badge{background-color:#ed1e79}#sync-apps-modal .modal-list-item .message{padding:3px;border-radius:2px;margin-left:31px;margin-top:9px}#sync-apps-modal .modal-list-item .message p{margin:0}#sync-apps-modal .modal-list-item.success .message{background-color:rgba(0,255,55,.08)}#sync-apps-modal .modal-list-item.pending .message,#sync-apps-modal .modal-list-item.running .message{background-color:rgba(255,118,0,.08)}#sync-apps-modal .modal-list-item.disconnected .message,#sync-apps-modal .modal-list-item.error .message,#sync-apps-modal .modal-list-item.failed .message,#sync-apps-modal .modal-list-item.unknown .message{background-color:rgba(255,0,0,.08)}#sync-apps-modal .modal-list-item.with-message{cursor:pointer}#sync-apps-modal .modal-list-item.with-message:hover{background-color:#ccc}#sync-apps-modal .modal-footer{border:0}#sync-apps-modal .fa{padding:0 10px}#sync-apps-modal .fa.error{color:red}#sync-apps-modal .fa.warn{color:#ff7300}#sync-apps-modal .fa.success{color:#47ff00}chart-threshold .attach-panel{padding:5px 0;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:baseline;-ms-flex-align:baseline;align-items:baseline;background-color:rgba(20,132,228,.16)}chart-threshold .attach-panel>div{padding-right:5px}chart-threshold .attach-panel>div.target{text-align:center}@media (max-width:1199px){chart-threshold .attach-panel{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-align:center;-ms-flex-align:center;align-items:center}chart-threshold .attach-panel>div{padding:5px}}chart-threshold .attach-panel .text{text-transform:uppercase;font-weight:700;color:#5B6667;font-size:13px}chart-threshold .attach-panel input{border-radius:3px;border:1px #fff;padding:3px}chart-threshold .attach-panel input[name=amount]{max-width:70px}chart-threshold .attach-panel .currency{font-weight:700;color:#000}chart-threshold .attach-panel .actions{display:inline-block;padding:0 2px}chart-threshold .attach-panel .actions button{padding:3px 6px;display:inline-block}chart-threshold .attach-panel .actions button.loading{padding:3px 20px}.analytics widgets-common-confirm-modal{text-align:center;font-size:13px;color:#5B6667}.analytics widgets-common-confirm-modal .overlay{background-color:#fff;position:absolute;height:calc(100% - 4px);width:calc(100% - 4px);top:2px;left:2px;opacity:.6;z-index:5}.analytics widgets-common-confirm-modal .message{z-index:6;position:absolute;min-height:160px;padding-bottom:10px;top:45px;left:7%;width:86%;background-color:#f4f8f9;border-radius:4px;box-shadow:0 0 25px 0;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between}.analytics .widget-item .content.accounts-balance-sheet,.analytics .widget-item .content.accounts-cash-balance{min-height:565px}.analytics widgets-common-confirm-modal .message .title{padding:2px;background-color:#192831;color:#fff;margin:-1px -1px 10px;text-transform:uppercase}.analytics widgets-common-confirm-modal .message p{padding:0 10px}.analytics widgets-common-confirm-modal .message button.btn{margin-top:20px}.analytics widgets-common-confirm-modal .message .loader i.fa.fa-spinner{font-size:26px}.currency-conversions img{width:15px;cursor:pointer}.currency-conversions.popover .popover-title{background-color:#000;color:#fff}.analytics .widget-item .editable-title{width:100%;-webkit-box-flex:1;-ms-flex:1;flex:1;overflow:hidden;height:22px}.analytics .widget-item .editable-title .title{text-transform:uppercase;font-weight:600;font-size:12px;color:#4f5959;cursor:text;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;line-height:1.9}.analytics .widget-item .editable-title .editable-wrap{position:relative;height:20px;min-width:100%;white-space:nowrap}.analytics .widget-item .editable-title .editable-wrap .editable-controls{min-width:100%}.analytics .widget-item .editable-title .editable-wrap .editable-controls .editable-input{height:20px;font-size:12px;text-transform:uppercase;width:calc(100% - 65px);padding:0 3px}.analytics .widget-item .editable-title .editable-wrap .editable-controls .editable-buttons{background-color:#fff}.analytics .widget-item .editable-title .editable-wrap .editable-controls .editable-buttons button{margin:0 0 0 5px;height:20px;padding:0 5px}.analytics .widget-item .info-panel{position:absolute;top:15px;left:15px;width:calc(100% - 30px);max-height:calc(100% - 30px);height:100%;background-color:#fff;border:1px dotted #B7CDCE;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;font-family:"Lato Semibold",Lato;z-index:4}.analytics .widget-item .info-panel:hover{opacity:1}.analytics .widget-item .info-panel .i-header{background-color:#FFC928;color:#1E303B;padding:8px;text-transform:uppercase;font-family:"Lato Medium",Lato;font-size:12px}.analytics .widget-item .info-panel .i-header .fa{font-size:18px}.analytics .widget-item .info-panel .i-header .fa-info-circle{float:left}.analytics .widget-item .info-panel .i-header .fa-times-circle{cursor:pointer;float:right}.analytics .widget-item .info-panel .i-content{overflow-y:auto;overflow-x:hidden;padding:5px;text-align:justify;-webkit-box-flex:1;-ms-flex:1;flex:1}.analytics .widget-item .info-panel .i-content .row{margin-bottom:6px;padding-bottom:6px;border-bottom:solid 1px #abc4c6}.analytics .widget-item .info-panel .i-content .row:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.analytics .widget-item .info-panel .i-content .row .key{text-align:right;font-variant:small-caps}@media (max-width:991px){.analytics .widget-item .info-panel .i-content .row .key{text-align:center}}.analytics .widget-item .info-panel .i-content .row .value{text-align:justify}.analytics .time-period-info{font-size:11px;color:#ABC4C6;text-transform:uppercase}.analytics .widget-item .top-line .top-buttons{text-align:right;margin-top:-1px;white-space:nowrap;padding-left:10px}.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-export,.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-info,.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-refresh{font-size:17px;margin-top:1px}.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button{background:0 0;border:none;color:#c4caca;padding:0;outline:0;width:17px}.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button:active,.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button:focus{box-shadow:none}.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-info:hover{color:#FFC928}.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-export:hover,.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-refresh:hover{color:#358fdc}.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-edit{font-size:13px}.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-edit.edit-mode,.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-edit:hover{color:#cfd849}.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-close{font-size:13px}.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-close:hover{color:#ed1e79}.analytics .settings.accounting-behaviour .btn.btn-primary{background-color:#bba9f5;border:1px solid #977bf0}.analytics .settings.accounting-behaviour .btn.btn-primary.active,.analytics .settings.accounting-behaviour .btn.btn-primary.focus{background-color:#977bf0}.analytics .settings.attach-kpis .attach-kpi{padding:8px 5px}.analytics .settings.attach-kpis .attach-kpi form .row{padding-bottom:5px}.analytics .settings.attach-kpis .attach-kpi .attach-kpi-form{background-color:#fff;border:1px solid #ddd;padding:5px}.analytics .settings.attach-kpis .attach-kpi form .row.kpi-description{padding:10px 2px}.analytics .settings.attach-kpis .attach-kpi form .row.kpi-description span{display:block;font-weight:700;font-size:13px}.analytics .settings.attach-kpis .attach-kpi form.attach-kpi-form input.attach-target{background-color:#fff;height:inherit}.analytics .settings.attach-kpis .attach-kpi .error-messages{color:#e01f74;width:120px}.analytics .settings.attach-kpis .attached-kpis{padding:5px}.analytics .settings.attach-kpis .list-group-item.attached-kpi{padding:5px 10px}.analytics .settings.attach-kpis .list-group-item.attached-kpi .attached-kpi-name{overflow:hidden;width:75%;display:inline-block;white-space:nowrap;text-overflow:ellipsis;margin-top:3px;font-size:13px;font-weight:700}.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions{padding-top:2px}.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .alerts-config{display:inline-block;text-align:left;padding-left:4px;height:20px;border-radius:40px;width:21px;color:#358fdc;background-color:#fff;border:1px solid #358fdc}.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .alerts-config:hover{cursor:pointer}.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .edit-attached-kpi{display:inline-block}.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .edit-attached-kpi i{border-radius:10px;width:21px;color:#358fdc;background-color:#fff;height:20px;padding:3px 5px 5px;border:1px solid #358fdc}.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .edit-attached-kpi i:hover{cursor:pointer}.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .remove-attached-kpi{display:inline-block}.analytics .settings.dates-picker button.btn.btn-sm.btn-danger,.analytics .settings.dates-picker h5{display:none}.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .remove-attached-kpi i{border-radius:10px;width:21px;color:#e01f74;background-color:#fff;height:20px;padding:3px 5px 5px;border:1px solid #e01f74}.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .remove-attached-kpi i:hover{cursor:pointer}.analytics .widget-item .content .settings.select-account{padding:0 5px}.analytics .widget-item .content .settings.chart-filters .row{margin:0}.analytics .widget-item .content .settings.chart-filters input[type=radio]{margin:0 3px 0 0;padding:0;width:13px;height:13px;vertical-align:middle;position:relative;top:-1px;outline:0}.analytics .widget-item .content .settings.chart-filters input[type=range]{height:auto;width:100%}.analytics .settings.dates-picker button.btn.btn-sm.date-button{margin:0 5px}.analytics .settings.dates-picker button.btn.btn-sm.btn-info{border-radius:3px}.analytics .settings.dates-picker .tooltip-inner{text-transform:none}.analytics .settings.dates-picker .dropdown-menu>li>div>table{outline:0}.analytics .settings.forecast-payroll .widget-lines-container .widget-line{padding:5px 10px 5px 18px}.analytics .settings.forecast-payroll .widget-lines-container .widget-line:nth-child(even){background-color:#f3f4f4}.analytics .settings.forecast-payroll .widget-lines-container .widget-line:nth-child(odd){background-color:#fff}.analytics .settings.forecast-payroll .widget-lines-container .widget-line .fa{float:right;font-size:20px;cursor:pointer}.analytics .settings.forecast-payroll .widget-lines-container .widget-line .fa.fa-toggle-on{color:#977bf0}.analytics .settings.forecast-payroll .widget-lines-container .widget-line .fa.fa-toggle-off{color:#9ba6a7}.analytics .widget-item .content .settings.hist-mode-choser{max-height:70px}.analytics .widget-item .content .settings.hist-mode-choser [common-time-period-info]{padding-bottom:8px}.analytics .widget-item .content .settings.hist-mode-choser .options{width:150px;margin:auto;padding-bottom:8px;border-bottom:solid 1px #e6e6e6;font-weight:500;font-size:12px;color:#c4caca}.analytics .widget-item .content .settings.hist-mode-choser .options a{font-weight:500;font-size:12px;color:#c4caca;text-transform:uppercase}.analytics .widget-item .content .settings.hist-mode-choser .options a.active{color:#977bf0}.analytics .widget-item .content .settings.hist-mode-choser .arrow-container{width:28px;height:28px;position:relative;top:-14px;margin:auto}.analytics .widget-item .content .settings.hist-mode-choser .arrow-container.right{left:46px}.analytics .widget-item .content .settings.hist-mode-choser .arrow-container.left{left:-30px}.analytics .widget-item .content .settings.hist-mode-choser .arrow-container .arrow-border{border-top:14px solid #e6e6e6;border-left:14px solid transparent;border-right:14px solid transparent;width:0;height:0}.analytics .widget-item .content .settings.hist-mode-choser .arrow-container .arrow{border-top:14px solid #fff;border-left:14px solid transparent;border-right:14px solid transparent;position:relative;top:12px;width:0;height:0}.analytics .settings.limit-entries{color:#1E303B;text-transform:uppercase;text-align:center;border-bottom:dashed 1px #E6E6E6;padding-bottom:8px}.analytics .settings.limit-entries a.option.badge{color:#fff;background-color:#1E303B}.analytics .settings.offsets .offset-value{font-style:italic;font-size:13px}.analytics .settings.offsets .offset-value .fa-trash-o{margin-left:10px}.analytics .settings.offsets .offset-value .fa-trash-o:hover{color:#e01f74;cursor:pointer}.analytics .settings.offsets input{width:75%}.analytics .settings.offsets button{width:30px}.analytics .settings.organizations .widget-lines-container .widget-line{padding:5px 10px 5px 18px}.analytics .settings.organizations .widget-lines-container .widget-line:nth-child(even){background-color:#f3f4f4}.analytics .settings.organizations .widget-lines-container .widget-line:nth-child(odd){background-color:#fff}.analytics .settings.organizations .widget-lines-container .widget-line .fa{float:right;font-size:20px;cursor:pointer}.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-check-circle,.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-toggle-on{color:#977bf0}.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-circle-thin,.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-toggle-off{color:#9ba6a7}.analytics .widget-item .content .settings.param-selector{display:inline-block}.analytics .widget-item .content .settings.param-selector.classic{width:100%}.analytics .widget-item .content .settings.param-selector.classic select{width:100%;height:25px;border:1px solid #ccc;text-transform:uppercase;margin:0 0 5px}.analytics .widget-item .content .settings.param-selector a{font-weight:400;color:#977bf0;white-space:nowrap}.analytics .widget-item .content .settings.param-selector .options-container{position:absolute;background-color:#fff;text-align:left;min-width:150px;max-height:200px;z-index:999;overflow-y:auto;overflow-x:hidden;box-shadow:#000 0 3px 15px -3px}.analytics .settings.tag-filter .tag-lines-container .tag-line .host,.analytics .settings.tag-filter .tag-lines-container .tag-line .tags-col,.analytics .widget-item .content.accounts-balance-sheet .widget-lines-container .row.widget-line.header>[class*=col-]{position:static}.analytics .widget-item .content .settings.param-selector .options-container .param-selector-label{padding:3px 5px;font-weight:500;font-size:inherit;color:#000;cursor:text;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;line-height:1.9}.analytics .widget-item .content .settings.param-selector .options-container .param-selector-label:hover{cursor:pointer;background-color:#977bf0;color:#fff}.analytics .widget-item .content .settings.param-selector .options-container::-webkit-scrollbar{width:8px;background-color:#d7e2e4}.analytics .widget-item .content .settings.param-selector .options-container::-webkit-scrollbar-thumb{background-color:#977bf0}.analytics .widget-item .content .settings.param-selector .options-container::-webkit-scrollbar-thumb:hover{background-color:#a992f3}.analytics .settings.params-checkboxes{padding:2px 0}.analytics .settings.params-checkboxes input{margin:0;height:inherit}.analytics .settings.params-checkboxes span{margin-left:5px}.analytics .settings.params-checkboxes label{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;line-height:14px}.analytics .widget-item .content .settings.params-picker{padding:0 10px}.analytics .widget-item .content .settings.params-picker .parameter{margin:0 3px 3px 0;padding:3px 5px;background-color:#1E303B;color:#fff;border:1px solid #1E303B;border-radius:4px;cursor:move;font-weight:700;white-space:nowrap;float:left}.analytics .widget-item .content .settings.params-picker .parameter input[type=checkbox]{margin:0 -3px 0 3px;vertical-align:middle;height:inherit;outline:0;cursor:pointer}.analytics .widget-item .content .settings.params-picker .parameter .badge{margin-right:3px;font-size:10px;background-color:#f2f2f2;color:#1E303B;padding:2px 6px}.analytics .widget-item .content .settings.params-picker .parameter.unchecked{background-color:inherit;font-weight:400;color:inherit;border-color:#c2c4c4}.analytics .widget-item .content .settings.params-picker .parameter.unchecked .badge{background-color:#c2c4c4;color:#fff}.analytics .settings.tag-filter{padding:0 5px}.analytics .settings.tag-filter .btn.btn-default{height:32px;width:30px}.analytics .settings.tag-filter .tag-lines-container{padding:0 10px}.analytics .settings.tag-filter .tag-lines-container .tag-line{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:end;-ms-flex-pack:end;justify-content:flex-end}.analytics .settings.tag-filter .tag-lines-container .tag-line tags-input .tags{display:-webkit-box;display:-ms-flexbox;display:flex;border-radius:4px;border:1px solid #ccc}.analytics .settings.tag-filter .tag-lines-container .tag-line tags-input .tags .tag-item{background:#79a2bb;border-radius:4px;color:#fff}.analytics .settings.time-period{padding:0 5px}.analytics .settings.time-period select{height:22px;width:100%}.analytics .settings.time-period>.row{margin:0 -5px 7px}.analytics .settings.time-period>.row>div{padding:0 5px;position:static}.analytics .settings.time-period>.row .sub-setting{padding:5px}.analytics .widget-item .content .settings.width{float:right;font-size:14px}.analytics .widget-item .content .settings.width i{color:silver;cursor:pointer}.analytics .widget-item .content .settings.width i.reduce{margin-right:-10px}.analytics .widget-item .content .settings.width i.expand{margin-right:-3px}.analytics .widget-item .content.accounts-assets-liability-summary .param-selector{text-align:center}.analytics .widget-item .content.accounts-assets-liability-summary .legend{text-align:left;max-height:90px}.analytics .widget-item .content.accounts-assets-liability-summary .legend .title{text-align:center;border-bottom:dashed 1px #dfe2e2}.analytics .widget-item .content.accounts-assets-summary .legend{text-align:left;max-height:115px}.analytics .widget-item .content.accounts-assets-summary .legend .title{text-align:center;border-bottom:dashed 1px #dfe2e2}.analytics .widget-item .content.accounts-assets-vs-liabilities .legend>.title span{margin-left:3px}.analytics .widget-item .content.accounts-balance h3{font-weight:300;font-size:14px;color:#5B6667;margin-top:30px;text-align:center}.analytics .widget-item .content.accounts-balance .price{font-weight:900;font-size:22px;color:#5B6667;text-align:center;margin-top:0}@media (min-width:992px){.analytics .widget-item .content.accounts-balance-sheet{height:565px}.analytics .widget-item .content.accounts-balance-sheet .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.accounts-balance-sheet .edit{max-height:545px}.analytics .widget-item .content.accounts-balance-sheet .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.accounts-balance-sheet .widget-lines-container{overflow-y:scroll;overflow-x:hidden;max-height:490px}@media (max-width:767px){.analytics .widget-item .content.accounts-balance-sheet .widget-lines-container .row.widget-line:not(:last-child){border-bottom:dashed 1px #dfe2e2}}.analytics .widget-item .content.accounts-balance-sheet .widget-lines-container.no-scroll{overflow:visible}.analytics .widget-item .content.accounts-balance-sheet .no-data-block{font-weight:300;font-size:16px;color:#5B6667;text-align:center;margin:15px 0}@media (min-width:992px){.analytics .widget-item .content.accounts-cash-balance{height:565px}.analytics .widget-item .content.accounts-cash-balance .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.accounts-cash-balance .edit{max-height:545px}.analytics .widget-item .content.accounts-cash-balance .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.accounts-cash-balance .data-container{height:calc(565px - 50px);width:100%}.analytics .widget-item .content.accounts-cash-balance .left-panel{width:180px;display:inline-block;overflow:auto;max-height:100%}.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;min-height:45px;margin:3px;font-size:13px;padding:3px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.analytics .widget-item .content.accounts-cash-projection,.analytics .widget-item .content.accounts-cash-summary,.analytics .widget-item .content.accounts-comparison,.analytics .widget-item .content.accounts-detailed-classifications,.analytics .widget-item .content.accounts-invoices-list{min-height:565px}.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item:hover{background-color:#ececec}.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item i{font-size:19px;padding:4px;margin-top:1px}.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item span{color:#5B6667}.analytics .widget-item .content.accounts-cash-balance .legend-item-icon{width:16px;height:16px}.analytics .widget-item .content.accounts-cash-balance .right-panel{width:calc(100% - 180px);float:right}.analytics .widget-item .content.accounts-cash-balance .right-panel .cash-balance-chart{height:calc(565px - 50px)}.analytics .widget-item .content.accounts-cash-balance .dates-picker{display:inline-block;float:right;font-size:12px}@media (min-width:992px){.analytics .widget-item .content.accounts-cash-projection{height:565px}.analytics .widget-item .content.accounts-cash-projection .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.accounts-cash-projection .edit{max-height:545px}.analytics .widget-item .content.accounts-cash-projection .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.accounts-cash-projection .cash-projection-chart{height:calc(565px - 50px)}.analytics .widget-item .content.accounts-cash-projection .highcharts-legend-item rect.highcharts-point{display:none}.analytics .widget-item .content.accounts-cash-projection .highcharts-legend-item span{width:110px;text-align:center}.analytics .widget-item .content.accounts-cash-projection .highcharts-legend-item span img{text-align:center;width:55px;height:25px}.analytics .widget-item .content.accounts-cash-projection .dates-picker{display:inline-block;float:right;font-size:12px}.analytics .widget-item .content.accounts-cash-projection transactions-list{font-size:12px}@media (min-width:992px){.analytics .widget-item .content.accounts-cash-summary{height:565px}.analytics .widget-item .content.accounts-cash-summary .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.accounts-cash-summary .edit{max-height:545px}.analytics .widget-item .content.accounts-cash-summary .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.accounts-cash-summary .widget-lines-container{max-height:540px}.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line{cursor:pointer;border:1px solid #fff}.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line .selection-tag{display:block;right:0;margin-top:-6px;width:10px;height:29px;position:absolute}.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line:hover{background-color:#e6e0fb}.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line.no-select{cursor:auto}.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line.no-select:hover{color:#626d6d}.analytics .widget-item .content.accounts-cash-summary .right-panel .widget-lines-container{overflow-y:auto;overflow-x:hidden;max-height:215px}.analytics .widget-item .content.accounts-cash-summary .no-element{font-weight:300;font-size:16px;color:#5B6667;text-align:center}.analytics .widget-item .content.accounts-cash-summary .row.lines-group.cash{border-top:solid 1px;border-bottom:double}.analytics .widget-item .content.accounts-class-comparison .param-selector{text-align:center}.analytics .widget-item .content.accounts-class-comparison .widget-lines-container{max-height:94px;color:#626d6d}@media (min-width:992px){.analytics .widget-item .content.accounts-comparison{height:565px}.analytics .widget-item .content.accounts-comparison .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.accounts-comparison .edit{max-height:545px}.analytics .widget-item .content.accounts-comparison .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}@media print{.analytics .widget-item .content.accounts-comparison .chart-container{max-width:80%!important}}.analytics .widget-item .content.accounts-comparison .add-account{position:absolute;right:40px;bottom:30px;width:160px}.analytics .widget-item .content.accounts-comparison .add-account select{font-size:13px;background-color:#977bf0;color:#fff;outline:0;border:none;cursor:pointer}.analytics .widget-item .content.accounts-comparison .add-account select[disabled]{cursor:not-allowed;background-color:#bba9f5}.analytics .widget-item .content.accounts-comparison .add-account select[disabled]:hover{background-color:#bba9f5}.analytics .widget-item .content.accounts-comparison .add-account select:hover{background-color:#734deb}.analytics .widget-item .content.accounts-comparison .add-account select option{background-color:#fff;color:#c4caca}.analytics .widget-item .content.accounts-comparison .add-account select option[disabled]{color:#fff}.analytics .widget-item .content.accounts-comparison button.close{font-size:15px}.analytics .widget-item .content.accounts-comparison .legend{text-align:left;max-height:103px}.analytics .widget-item .content.accounts-comparison .row{margin:0}.analytics .widget-item .content.accounts-comparison .widget-lines-container{font-size:11px;max-height:220px;margin-bottom:65px;overflow:auto}.analytics .widget-item .content.accounts-comparison .settings.params-checkboxes{margin-left:13px}.analytics .widget-item .content.accounts-comparison .comparable-error h5{margin-left:13px;color:#ed1e79}.analytics .widget-item .content.accounts-custom-calculation h3{margin-top:85px;text-align:center;font-weight:700}.analytics .widget-item .content.accounts-custom-calculation .legend{max-height:125px}.analytics.modal-custom-calculation{margin:0;padding:0}.analytics.modal-custom-calculation .modal-body .edit{overflow-y:auto;overflow-x:hidden;color:#5B6667;font-size:12px;padding:5px;overflow:visible}.analytics.modal-custom-calculation .modal-body .edit .bottom-buttons .btn{border-radius:2px;margin-right:5px;padding:3px 13px;text-transform:uppercase;font-size:12px}.analytics.modal-custom-calculation .modal-body .edit .bottom-buttons .btn.btn-default{background-color:#c2c4c4;border:1px solid #a8abab;color:#fff}.analytics.modal-custom-calculation .modal-body .edit .bottom-buttons .btn.btn-default:hover{border:1px solid #8e9292;background-color:#a8abab}.analytics.modal-custom-calculation .modal-body .edit h4{margin:0 0 8px;text-align:left;font-weight:400;font-size:12px;color:#c4caca}.analytics.modal-custom-calculation .modal-body .edit .part{margin-bottom:8px;padding:10px 0;background-color:#fcfcfc;border:1px solid #dfe2e2}.analytics.modal-custom-calculation .modal-body .edit .part h5{display:block;margin:0 0 10px;padding:0 15px;text-transform:uppercase;font-weight:400;font-size:12px;color:#c4caca}.analytics.modal-custom-calculation .modal-body .edit .part label{font-weight:400}.analytics.modal-custom-calculation .modal-body .edit .part select.form-control{margin:0;border:1px solid #acb0b1;outline:0;-webkit-box-shadow:none;font-size:13px;color:#72728b}@media (min-width:992px){.analytics .widget-item .content.accounts-detailed-classifications{height:565px}.analytics .widget-item .content.accounts-detailed-classifications .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.accounts-detailed-classifications .edit{max-height:545px}.analytics .widget-item .content.accounts-detailed-classifications .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.accounts-detailed-classifications .widget-lines-container{overflow-y:scroll;overflow-x:hidden;max-height:540px}.analytics .widget-item .content.accounts-invoices-list .edit .widget-lines-container,.analytics .widget-item .content.accounts-profit-and-loss .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.accounts-detailed-classifications .account-class-title{margin-bottom:8px;margin-left:11px}.analytics .widget-item .content.accounts-detailed-classifications .time-period-info{text-align:right}.analytics .widget-item .content.accounts-detailed-classifications .widget-line.header.sorting{border-bottom:1px solid #ccc}.analytics .widget-item .content.accounts-expense-weight .legend{text-align:left;max-height:115px}.analytics .widget-item .content.accounts-expense-weight .legend .title{text-align:center}.analytics .widget-item .content.accounts-expenses-revenue .legend{font-weight:700}.analytics .widget-item .content.accounts-expenses-revenue .settings.params-checkboxes{font-size:12px;margin-left:0;text-align:center}@media (min-width:992px){.analytics .widget-item .content.accounts-invoices-list{height:565px}.analytics .widget-item .content.accounts-invoices-list .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.accounts-invoices-list .edit{max-height:545px}.analytics .widget-item .content.accounts-invoices-list transactions-list{font-size:12px}.analytics .widget-item .content.accounts-live-balance h3{font-weight:900;color:#5B6667;margin-top:0;font-size:18px;text-align:center;text-shadow:1px}.analytics .widget-item .content.accounts-live-balance .statement-title{font-size:13px;font-weight:400}.analytics .widget-item .content.accounts-live-balance .balance-title{font-size:12px}.analytics .widget-item .content.accounts-live-balance .currency-centered{font-weight:300;font-size:12px;color:#5B6667;text-align:center}.analytics .widget-item .content.accounts-live-balance .headers{text-align:center}.analytics .widget-item .content.accounts-live-balance .spacer{min-height:30px}.analytics .widget-item .content.accounts-profit-and-loss,.analytics .widget-item .content.hr-payroll-summary,.analytics .widget-item .content.invoices-aged-payables-receivables,.analytics .widget-item .content.sales-aged,.analytics .widget-item .content.sales-comparison,.analytics .widget-item .content.sales-forecast,.analytics .widget-item .content.sales-leads-funnel,.analytics .widget-item .content.sales-opportunities-funnel,.analytics .widget-item .content.sales-performance{min-height:565px}.analytics .widget-item .content.accounts-live-balance .price{font-weight:900;font-size:22px;color:#5B6667;text-align:center;margin-top:0}.analytics .widget-item .content.accounts-live-balance .negative2{font-size:14px}.analytics .widget-item .content.accounts-payable-receivable h3{text-align:center}.analytics .widget-item .content.accounts-payable-receivable .legend{font-weight:700}.analytics .widget-item .content.accounts-payable-receivable .payable{margin-top:15px}.analytics .widget-item .content.accounts-payable-receivable .price{font-weight:900;font-size:22px;color:#5B6667;text-align:center;margin-top:0}@media (min-width:992px){.analytics .widget-item .content.accounts-profit-and-loss{height:565px}.analytics .widget-item .content.accounts-profit-and-loss .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.accounts-profit-and-loss .edit{max-height:545px}.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container{max-height:540px}.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line{cursor:pointer;border:1px solid #fff}.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line .selection-tag{display:block;right:0;margin-top:-6px;width:10px;height:29px;position:absolute}.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line:hover{background-color:#e6e0fb}.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line.no-select{cursor:auto}.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line.no-select:hover{color:#626d6d}.analytics .widget-item .content.accounts-profit-and-loss .right-panel .widget-lines-container{overflow-y:auto;overflow-x:hidden;max-height:215px}.analytics .widget-item .content.accounts-profit-and-loss .no-element{font-weight:300;font-size:16px;color:#5B6667;text-align:center}.analytics .widget-item .content.accounts-profit-and-loss .row.lines-group.profit{border-top:solid 1px;border-bottom:double}.analytics .widget-item .content.accounts-profit-and-loss .row.widget-line.header>[class*=col-]{position:static}.analytics .widget-item .content.accounts-ratios .left-panel{max-height:230px;overflow-y:auto}.analytics .widget-item .content.accounts-ratios .left-panel .separator{border-bottom:solid 1px #5B6667;width:75%}.analytics .widget-item .content.accounts-ratios .left-panel .member{padding-top:20px;padding-bottom:20px}.analytics .widget-item .content.accounts-ratios .left-panel .member .price{margin-top:0;font-size:18px}.analytics .widget-item .content.accounts-ratios .left-panel button{outline:0}.analytics .widget-item .content.accounts-ratios .left-panel.simulation .member{padding-top:5px}.analytics .widget-item .content.accounts-ratios .left-panel.simulation .member .legend{display:none}.analytics .widget-item .content.accounts-ratios .left-panel.simulation .member .price{text-align:right}.analytics .widget-item .content.accounts-ratios .left-panel.simulation .separator{width:100%}.analytics .widget-item .content.hr-employee-details{font-size:12px}.analytics .widget-item .content.hr-employee-details .details-container{padding:0;max-height:none;overflow-y:auto;overflow-x:hidden}.analytics .widget-item .content.hr-employee-details .right-panel .legend{margin-bottom:5px}.analytics .widget-item .content.hr-employee-details .title{text-align:center;margin-bottom:10px;font-size:14px}.analytics .widget-item .content.hr-employees-list .legend{margin-bottom:9px}.analytics .widget-item .content.hr-employees-list .widget-lines-container{text-align:center}.analytics .widget-item .content.hr-employees-list .widget-lines-container .widget-line:nth-child(even){background-color:#f0f0f0}.analytics .widget-item .content.hr-employees-list .widget-lines-container .widget-line:nth-child(odd){background-color:#fff}.analytics .widget-item .content.hr-employees-list .edit .widget-lines-container{text-align:left}.analytics .widget-item .content.hr-leaves-balance .employee-name{text-align:center}.analytics .widget-item .content.hr-leaves-balance .balance{font-weight:900;font-size:22px;color:#5B6667;text-align:center;margin-top:0}.analytics .widget-item .content.hr-leaves-balance h3{margin-top:33px;text-align:center}.analytics .widget-item .content.hr-leaves-schedule .fc-button{height:22px;font-size:12px;color:#977bf0;background:#fff;outline:0}.analytics .widget-item .content.hr-leaves-schedule .fc-button:hover{color:#fff;background:#977bf0}.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line:hover,.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line:hover{background-color:#e6e0fb}.analytics .widget-item .content.hr-leaves-schedule .fc-toolbar{margin-bottom:5px}.analytics .widget-item .content.hr-leaves-schedule .fc-day-grid,.analytics .widget-item .content.hr-leaves-schedule .fc-widget-header{font-size:12px;color:#5B6667}@media (min-width:992px){.analytics .widget-item .content.hr-employee-details .details-container{max-height:200px}.analytics .widget-item .content.hr-employee-details .right-panel .details-container{max-height:220px}.analytics .widget-item .content.hr-payroll-summary{height:565px}.analytics .widget-item .content.hr-payroll-summary .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.hr-salaries-summary h3.right,.analytics .widget-item .content.hr-workforce-summary h3.right{margin-bottom:10px;text-align:center}.analytics .widget-item .content.hr-payroll-summary .edit{max-height:545px}.analytics .widget-item .content.hr-payroll-summary .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.hr-payroll-summary .widget-lines-container{max-height:540px}.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line{cursor:pointer;border:1px solid #fff}.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line .selection-tag{display:block;right:0;margin-top:-6px;width:10px;height:29px;position:absolute}.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line.no-select{cursor:auto}.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line.no-select:hover{color:#626d6d}.analytics .widget-item .content.hr-payroll-summary .right-panel .widget-lines-container{overflow-y:auto;overflow-x:hidden;max-height:145px}.analytics .widget-item .content.hr-payroll-summary .no-element{font-weight:300;font-size:16px;color:#5B6667;text-align:center}.analytics .widget-item .content.hr-salaries-summary h3.left{text-align:center}.analytics .widget-item .content.hr-salaries-summary h3.reduced-left{text-align:center}@media (min-width:992px){.analytics .widget-item .content.hr-salaries-summary h3.left{margin-top:69px}.analytics .widget-item .content.hr-salaries-summary h3.reduced-left{margin-top:10px}}.analytics .widget-item .content.hr-salaries-summary .price{margin-top:0}.analytics .widget-item .content.hr-salaries-summary .widget-lines-container{max-height:75px}.analytics .widget-item .content.hr-salaries-summary .widget-lines-container .widget-line{font-size:11px}.analytics .widget-item .content.hr-superannuation-accruals h3{margin-top:63px;text-align:center}.analytics .widget-item .content.hr-superannuation-accruals .legend{margin-top:23px}.analytics .widget-item .content.hr-superannuation-accruals .currency{font-size:14px}.analytics .widget-item .content.hr-superannuation-accruals .price{font-weight:900;font-size:22px;color:#5B6667;text-align:center;margin-top:0}.analytics .widget-item .content.hr-timesheets .currency{font-size:14px}.analytics .widget-item .content.hr-timesheets .widget-lines-container{max-height:210px}.analytics .widget-item .content.hr-workforce-summary h3.left{text-align:center}.analytics .widget-item .content.hr-workforce-summary h3.reduced-left{text-align:center}@media (min-width:992px){.analytics .widget-item .content.hr-workforce-summary h3.left{margin-top:69px}.analytics .widget-item .content.hr-workforce-summary h3.reduced-left{margin-top:10px}}.analytics .widget-item .content.hr-workforce-summary .price{margin-top:0}.analytics .widget-item .content.hr-workforce-summary .widget-lines-container{max-height:75px}.analytics .widget-item .content.hr-workforce-summary .widget-lines-container .widget-line{font-size:11px}@media (min-width:480px) and (max-width:991px){.analytics .widget-item .content.hr-salaries-summary .right-panel .chart-container,.analytics .widget-item .content.hr-workforce-summary .right-panel .chart-container{max-width:320px}}@media (min-width:992px){.analytics .widget-item .content.invoices-aged-payables-receivables{height:565px}.analytics .widget-item .content.invoices-aged-payables-receivables .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.invoices-aged-payables-receivables .edit{max-height:545px}.analytics .widget-item .content.invoices-aged-payables-receivables .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container{max-height:540px}.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line{cursor:pointer;border:1px solid #fff}.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line .selection-tag{display:block;right:0;margin-top:-6px;width:10px;height:29px;position:absolute}.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line.no-select{cursor:auto}.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line.no-select:hover{color:#626d6d}.analytics .widget-item .content.invoices-aged-payables-receivables .right-panel .widget-lines-container{overflow-y:auto;overflow-x:hidden;max-height:215px}.analytics .widget-item .content.sales-aged .edit .widget-lines-container,.analytics .widget-item .content.sales-comparison .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.invoices-aged-payables-receivables .no-element{font-weight:300;font-size:16px;color:#5B6667;text-align:center}.analytics .widget-item .content.invoices-aged-payables-receivables .row.astericks-info{margin-top:15px}.analytics .widget-item .content.invoices-aged-payables-receivables .currency-conversions{float:right;margin-left:3px}.analytics .widget-item .content.invoices-list .widget-lines-container{max-height:230px}.analytics .widget-item .content.invoices-list .widget-lines-container .widget-line:nth-child(even){background-color:#f0f0f0}.analytics .widget-item .content.invoices-list .widget-lines-container .widget-line:nth-child(odd){background-color:#fff}.analytics .widget-item .content.invoices-list .widget-lines-container .widget-line.header{background-color:#fff}.analytics .widget-item .content.invoices-list .currency-conversions{float:right;margin-right:3px;margin-top:-2px}.analytics .widget-item .content.invoices-list .fa.fa-info-circle{float:right;font-size:15px}.analytics .widget-item .content.invoices-list .right-column{padding-left:0;padding-right:0}.analytics .widget-item .content.invoices-summary .chart-container{max-width:410px}.analytics .widget-item .content.invoices-summary .legend{max-height:28px}@media (min-width:992px){.analytics .widget-item .content.sales-aged{height:565px}.analytics .widget-item .content.sales-aged .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.sales-aged .edit{max-height:545px}.analytics .widget-item .content.sales-aged .widget-lines-container{max-height:238px}.analytics .widget-item .content.sales-break-even .price{font-weight:900;font-size:22px;color:#5B6667;text-align:center;margin-top:0}.analytics .widget-item .content.sales-break-even .block{margin:5px;padding:0 10px 5px;text-align:left;box-shadow:0 7px 10px -7px #17262d;font-size:12px}.analytics .widget-item .content.sales-break-even .block form.editable-wrap .editable-controls input{margin-top:5px;width:100px}.analytics .widget-item .content.sales-break-even .block.to-date{background-color:#f0f0f0;color:#5B6667}.analytics .widget-item .content.sales-break-even .block.to-breakeven{margin-top:10px;background-color:#192831;color:#1de9b6}.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line:hover,.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main:hover{background-color:#e6e0fb}.analytics .widget-item .content.sales-break-even .block.to-breakeven .title{border-bottom:solid 1px #2a4453}.analytics .widget-item .content.sales-break-even .block.to-breakeven .define-text{font-weight:300;font-size:16px;text-align:center;padding-top:5px;color:#1de9b6}.analytics .widget-item .content.sales-break-even .block.to-breakeven .price{color:#1de9b6}.analytics .widget-item .content.sales-break-even .block .title{font-size:13px;text-align:center;font-variant:small-caps;border-bottom:solid 1px #e6edee;font-weight:300}@media (min-width:992px){.analytics .widget-item .content.sales-comparison{height:565px}.analytics .widget-item .content.sales-comparison .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.sales-comparison .edit{max-height:545px}.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line{cursor:pointer;border:1px solid #fff}.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line .selection-tag{display:block;right:0;margin-top:-6px;width:10px;height:29px;position:absolute}.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line.no-select{cursor:auto}.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line.no-select:hover{color:#626d6d}.analytics .widget-item .content.sales-comparison .no-element{font-weight:300;font-size:16px;color:#5B6667;text-align:center}.analytics .widget-item .content.sales-comparison .widget-lines-container{max-height:530px}.analytics .widget-item .content.sales-comparison .right-panel .widget-lines-container{overflow-y:auto;overflow-x:hidden;max-height:250px}.analytics .widget-item .content.sales-comparison .currency-conversions img{margin-top:-2px}.analytics .widget-item .content.sales-customer-details{font-size:12px}.analytics .widget-item .content.sales-customer-details .loader{font-size:14px}.analytics .widget-item .content.sales-customer-details .details-container{padding:0;overflow-y:auto;overflow-x:hidden}.analytics .widget-item .content.sales-forecast .edit .widget-lines-container,.analytics .widget-item .content.sales-leads-funnel .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}@media (min-width:992px){.analytics .widget-item .content.sales-customer-details .details-container{max-height:194px}.analytics .widget-item .content.sales-customer-details .right-panel .details-container{max-height:230px}}.analytics .widget-item .content.sales-customer-details .right-panel .legend{margin-bottom:5px}.analytics .widget-item .content.sales-customer-details .row.title{text-align:center;margin-bottom:10px;font-size:14px}.analytics .widget-item .content.sales-customer-details .currency-conversions{float:left;margin-right:3px}.analytics .widget-item .content.sales-cycle .chart-container{max-width:410px}.analytics .widget-item .content.sales-cycle .legend{max-height:28px}@media (min-width:992px){.analytics .widget-item .content.sales-forecast{height:565px}.analytics .widget-item .content.sales-forecast .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.sales-forecast .edit{max-height:545px}.analytics .widget-item .content.sales-forecast .widget-lines-container{max-height:275px}.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main{cursor:pointer;border:1px solid #fff}.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main .selection-tag{display:block;right:0;margin-top:-6px;width:10px;height:29px;position:absolute}.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main.no-select{cursor:auto}.analytics .widget-item .content.sales-leads-funnel .right-panel .widget-lines-container .widget-line,.analytics .widget-item .content.sales-opportunities-funnel .right-panel .widget-lines-container .widget-line{cursor:default}.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main.no-select:hover{color:#626d6d}.analytics .widget-item .content.sales-growth .price{font-weight:900;font-size:22px;color:#5B6667;text-align:center;margin-top:0}.analytics .widget-item .content.sales-growth .legend{max-height:49px;font-size:14px;text-overflow:ellipsis;white-space:nowrap}@media (min-width:992px){.analytics .widget-item .content.sales-leads-funnel{height:565px}.analytics .widget-item .content.sales-leads-funnel .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.sales-leads-funnel .edit{max-height:545px}.analytics .widget-item .content.sales-leads-funnel .funnel-container{width:95%;margin:15px auto auto;padding-right:10px;max-height:505px;overflow:auto}.analytics .widget-item .content.sales-leads-funnel .right-panel .widget-lines-container{max-height:545px;margin-right:10px}.analytics .widget-item .content.sales-leads-list .widget-lines-container{max-height:230px;overflow-y:scroll;overflow-x:hidden}.analytics .widget-item .content.sales-leads-list .widget-lines-container .widget-line:nth-child(even){background-color:#f0f0f0}.analytics .widget-item .content.sales-leads-list .widget-lines-container .widget-line:nth-child(odd){background-color:#fff}.analytics .widget-item .content.sales-leads-list .widget-lines-container .widget-line.header{background-color:#fff}.analytics .widget-item .content.sales-list .widget-lines-container .widget-line:nth-child(even){background-color:#f0f0f0}.analytics .widget-item .content.sales-list .widget-lines-container .widget-line:nth-child(odd){background-color:#fff}.analytics .widget-item .content.sales-list .widget-lines-container .widget-line.header{background-color:#fff}.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header:hover,.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line:hover{background-color:#e6e0fb}.analytics .widget-item .content.sales-list .widget-lines-container{overflow-y:scroll;overflow-x:hidden;max-height:170px}.analytics .widget-item .content.sales-list .widget-lines-container.no-scroll{overflow:visible}.analytics .widget-item .content.sales-list .selector{margin-bottom:4px}.analytics .widget-item .content.sales-list .currency-conversions img{margin-top:-2px}.analytics .widget-item .content.sales-net-sales .operator,.analytics .widget-item .content.sales-net-sales .value-container{line-height:85px}.analytics .widget-item .content.sales-net-sales .value-container .title{line-height:20px;font-size:1.2em;padding:10px 0}.analytics .widget-item .content.sales-net-sales .value-container .value-box{font-size:1.3em;border-radius:10px;border-top:solid 1px #C4CACA;border-bottom:solid 1px #C4CACA;white-space:nowrap}.analytics .widget-item .content.sales-net-sales .operator{padding-top:38px;font-size:1.3em}@media (min-width:992px){.analytics .widget-item .content.sales-net-sales .values{margin-top:25px}}.analytics .widget-item .content.sales-new-vs-existing-customers .selector .selector-wrap{display:inline-block;margin:0 5px}.analytics .widget-item .content.sales-new-vs-existing-customers .chart-container{margin-top:15px}.analytics .widget-item .content.sales-new-vs-existing-customers .legend{margin-top:5px;font-weight:700;max-height:77px!important}.analytics .widget-item .content.sales-new-vs-existing-customers .legend .row{margin:0 -5px}.analytics .widget-item .content.sales-new-vs-existing-customers .legend .row>div{padding:0 5px}.analytics .widget-item .content.sales-new-vs-existing-customers .legend .total{color:#5B6667;font-size:14px}.analytics .widget-item .content.sales-number-of-leads .stats{margin-top:35px;font-size:18px}.analytics .widget-item .content.sales-number-of-leads .stats .stat{margin:15px 0 10px;border-bottom:solid 1px #e6edee}.analytics .widget-item .content.sales-number-of-leads .stats .stat span.title{font-weight:700}.analytics .widget-item .content.sales-number-of-leads .stats .stat span.nominal{float:right;text-align:right;font-weight:300}.analytics .widget-item .content.sales-number-of-leads .stats .stat span.variation{float:right;width:50px;text-align:right;font-style:italic;font-size:14px;font-weight:300;margin-top:2px}@media (min-width:992px){.analytics .widget-item .content.sales-opportunities-funnel{height:565px}.analytics .widget-item .content.sales-opportunities-funnel .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.sales-opportunities-funnel .edit{max-height:545px}.analytics .widget-item .content.sales-opportunities-funnel .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.sales-opportunities-funnel .funnel-container{width:95%;margin:15px auto auto;padding-right:10px;max-height:505px;overflow:auto}.analytics .widget-item .content.sales-opportunities-funnel .right-panel .widget-lines-container{max-height:545px;margin-right:10px}@media (min-width:992px){.analytics .widget-item .content.sales-performance{height:565px}.analytics .widget-item .content.sales-performance .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header .selection-tag,.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line .selection-tag{display:block;right:0;margin-top:-6px;width:10px;height:29px;position:absolute}.analytics .widget-item .content.sales-performance .edit{max-height:545px}.analytics .widget-item .content.sales-performance .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.sales-performance .widget-lines-container{max-height:540px}.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line{cursor:pointer;border:1px solid #fff}.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line.no-select{cursor:auto}.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line.no-select:hover{color:#626d6d}.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container{overflow-y:auto;overflow-x:hidden;max-height:215px}.analytics .widget-item .content.sales-performance .no-element{font-weight:300;font-size:16px;color:#5B6667;text-align:center}.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header{cursor:pointer;border:1px solid #fff}.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header.no-select{cursor:auto}.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header.no-select:hover{color:#626d6d}.analytics .widget-item .content.sales-segmented-turnover h3.right{margin-top:55px;text-align:center}.analytics .widget-item .content.sales-segmented-turnover .selector{margin-bottom:10px}.analytics .widget-item .content.sales-segmented-turnover .analysis{font-weight:900;font-size:22px;color:#5B6667;text-align:center;margin-top:0}.analytics .widget-item .content.sales-segmented-turnover .widget-lines-container{max-height:75px}.analytics .widget-item .content.sales-segmented-turnover .widget-lines-container .widget-line{font-size:11px}.analytics .widget-item .content.sales-segmented-turnover .right-panel h3{margin:15px 10px 5px;text-align:center}.analytics .widget-item .content.sales-segmented-turnover .right-panel .fa.fa-info-circle{float:left}.analytics .widget-item .content.sales-summary .chart-container{max-width:410px}.analytics .widget-item .content.sales-summary .legend{max-height:28px}.analytics .widget-item .content.sales-summary .selector{margin-bottom:5px}.analytics .widget-item .content.sales-top-customers .selector{border-bottom:dashed 1px #E6E6E6;padding-bottom:3px}.analytics .widget-item .content.sales-top-customers .selector a{font-weight:400}.analytics .widget-item .content.sales-top-customers .selector .param-selector{display:inline-block}.analytics .widget-item .content.sales-top-customers .widget-lines-container{max-height:235px}.analytics .widget-item .content.sales-top-customers .widget-lines-container .widget-line.sub-line{background-color:#f0f0f0}.analytics .widget-item .content.sales-top-customers .widget-lines-container .row>[class*=col-]{position:static}.analytics .widget-item .content.sales-top-customers .currency-conversions img{margin-top:-2px}.analytics .widget-item .content.sales-top-opportunities .opps-container{max-height:195px;margin-top:10px;padding-right:10px;overflow-y:auto;overflow-x:hidden}.analytics .widget-item .content.sales-top-opportunities .opps-container .tile{height:40px;font-size:13px;font-weight:300}.analytics .widget-item .content.sales-top-opportunities .opps-container .tile .colored-area{width:10%;text-align:center;font-size:20px}.analytics .widget-item .content.sales-top-opportunities .opps-container .tile .main-text{color:#5B6667;padding:3px 0 0 10px}.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.first{height:55px;font-size:15px;font-weight:700}.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.first .colored-area{font-size:26px;padding-top:10px;background-color:#ff6e41}.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.first .main-text{padding-top:8px}.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.second{height:55px;font-size:15px;font-weight:500}.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.second .colored-area{font-size:26px;padding-top:10px;background-color:#1de9b6}.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.second .main-text{padding-top:8px} \ No newline at end of file + *//*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */.label,sub,sup{vertical-align:baseline}hr,img{border:0}body,figure{margin:0}.analytics pre,pre{word-wrap:break-word}.btn-group>.btn-group,.btn-toolbar .btn,.btn-toolbar .btn-group,.btn-toolbar .input-group,.col-xs-1,.col-xs-10,.col-xs-11,.col-xs-12,.col-xs-2,.col-xs-3,.col-xs-4,.col-xs-5,.col-xs-6,.col-xs-7,.col-xs-8,.col-xs-9,.dropdown-menu{float:left}.btn,.kpi-alerts-settings .modal-body ul>li.list-group-item{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.navbar-fixed-bottom .navbar-collapse,.navbar-fixed-top .navbar-collapse,.pre-scrollable{max-height:340px}.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea,.analytics kpis-bar>.kpis .actions .im-form-group textarea{resize:none}html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary{display:block}audio,canvas,progress,video{display:inline-block;vertical-align:baseline}audio:not([controls]){display:none;height:0}[hidden],template{display:none}a{background-color:transparent;color:#00e5f0;text-decoration:none}a:active,a:hover{outline:0}b,optgroup,strong{font-weight:700}dfn{font-style:italic}h1{margin:.67em 0}mark{background:#ff0;color:#000}.img-thumbnail,body{background-color:#fff}.btn,.btn-danger.active,.btn-danger:active,.btn-default.active,.btn-default:active,.btn-info.active,.btn-info:active,.btn-primary.active,.btn-primary:active,.btn-warning.active,.btn-warning:active,.btn.active,.btn:active,.dropdown-menu>.disabled>a:focus,.dropdown-menu>.disabled>a:hover,.form-control,.navbar-toggle,.open>.dropdown-toggle.btn-danger,.open>.dropdown-toggle.btn-default,.open>.dropdown-toggle.btn-info,.open>.dropdown-toggle.btn-primary,.open>.dropdown-toggle.btn-warning{background-image:none}sub,sup{font-size:75%;line-height:0;position:relative}sup{top:-.5em}sub{bottom:-.25em}img{vertical-align:middle}svg:not(:root){overflow:hidden}hr{box-sizing:content-box;height:0}pre,textarea{overflow:auto}code,kbd,pre,samp{font-size:1em}button,input,optgroup,select,textarea{color:inherit;font:inherit;margin:0}.glyphicon,address{font-style:normal}button{overflow:visible}button,select{text-transform:none}button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer}button[disabled],html input[disabled]{cursor:default}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{height:auto}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}td,th{padding:0}@font-face{font-family:'Glyphicons Halflings';src:url(../fonts/glyphicons-halflings-regular.eot);src:url(../fonts/glyphicons-halflings-regular.eot?#iefix) format('embedded-opentype'),url(../fonts/glyphicons-halflings-regular.woff2) format('woff2'),url(../fonts/glyphicons-halflings-regular.woff) format('woff'),url(../fonts/glyphicons-halflings-regular.ttf) format('truetype'),url(../fonts/glyphicons-halflings-regular.svg#glyphicons_halflingsregular) format('svg')}.glyphicon{position:relative;top:1px;display:inline-block;font-family:'Glyphicons Halflings';font-weight:400;line-height:1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.glyphicon-asterisk:before{content:"\002a"}.glyphicon-plus:before{content:"\002b"}.glyphicon-eur:before,.glyphicon-euro:before{content:"\20ac"}.glyphicon-minus:before{content:"\2212"}.glyphicon-cloud:before{content:"\2601"}.glyphicon-envelope:before{content:"\2709"}.glyphicon-pencil:before{content:"\270f"}.glyphicon-glass:before{content:"\e001"}.glyphicon-music:before{content:"\e002"}.glyphicon-search:before{content:"\e003"}.glyphicon-heart:before{content:"\e005"}.glyphicon-star:before{content:"\e006"}.glyphicon-star-empty:before{content:"\e007"}.glyphicon-user:before{content:"\e008"}.glyphicon-film:before{content:"\e009"}.glyphicon-th-large:before{content:"\e010"}.glyphicon-th:before{content:"\e011"}.glyphicon-th-list:before{content:"\e012"}.glyphicon-ok:before{content:"\e013"}.glyphicon-remove:before{content:"\e014"}.glyphicon-zoom-in:before{content:"\e015"}.glyphicon-zoom-out:before{content:"\e016"}.glyphicon-off:before{content:"\e017"}.glyphicon-signal:before{content:"\e018"}.glyphicon-cog:before{content:"\e019"}.glyphicon-trash:before{content:"\e020"}.glyphicon-home:before{content:"\e021"}.glyphicon-file:before{content:"\e022"}.glyphicon-time:before{content:"\e023"}.glyphicon-road:before{content:"\e024"}.glyphicon-download-alt:before{content:"\e025"}.glyphicon-download:before{content:"\e026"}.glyphicon-upload:before{content:"\e027"}.glyphicon-inbox:before{content:"\e028"}.glyphicon-play-circle:before{content:"\e029"}.glyphicon-repeat:before{content:"\e030"}.glyphicon-refresh:before{content:"\e031"}.glyphicon-list-alt:before{content:"\e032"}.glyphicon-lock:before{content:"\e033"}.glyphicon-flag:before{content:"\e034"}.glyphicon-headphones:before{content:"\e035"}.glyphicon-volume-off:before{content:"\e036"}.glyphicon-volume-down:before{content:"\e037"}.glyphicon-volume-up:before{content:"\e038"}.glyphicon-qrcode:before{content:"\e039"}.glyphicon-barcode:before{content:"\e040"}.glyphicon-tag:before{content:"\e041"}.glyphicon-tags:before{content:"\e042"}.glyphicon-book:before{content:"\e043"}.glyphicon-bookmark:before{content:"\e044"}.glyphicon-print:before{content:"\e045"}.glyphicon-camera:before{content:"\e046"}.glyphicon-font:before{content:"\e047"}.glyphicon-bold:before{content:"\e048"}.glyphicon-italic:before{content:"\e049"}.glyphicon-text-height:before{content:"\e050"}.glyphicon-text-width:before{content:"\e051"}.glyphicon-align-left:before{content:"\e052"}.glyphicon-align-center:before{content:"\e053"}.glyphicon-align-right:before{content:"\e054"}.glyphicon-align-justify:before{content:"\e055"}.glyphicon-list:before{content:"\e056"}.glyphicon-indent-left:before{content:"\e057"}.glyphicon-indent-right:before{content:"\e058"}.glyphicon-facetime-video:before{content:"\e059"}.glyphicon-picture:before{content:"\e060"}.glyphicon-map-marker:before{content:"\e062"}.glyphicon-adjust:before{content:"\e063"}.glyphicon-tint:before{content:"\e064"}.glyphicon-edit:before{content:"\e065"}.glyphicon-share:before{content:"\e066"}.glyphicon-check:before{content:"\e067"}.glyphicon-move:before{content:"\e068"}.glyphicon-step-backward:before{content:"\e069"}.glyphicon-fast-backward:before{content:"\e070"}.glyphicon-backward:before{content:"\e071"}.glyphicon-play:before{content:"\e072"}.glyphicon-pause:before{content:"\e073"}.glyphicon-stop:before{content:"\e074"}.glyphicon-forward:before{content:"\e075"}.glyphicon-fast-forward:before{content:"\e076"}.glyphicon-step-forward:before{content:"\e077"}.glyphicon-eject:before{content:"\e078"}.glyphicon-chevron-left:before{content:"\e079"}.glyphicon-chevron-right:before{content:"\e080"}.glyphicon-plus-sign:before{content:"\e081"}.glyphicon-minus-sign:before{content:"\e082"}.glyphicon-remove-sign:before{content:"\e083"}.glyphicon-ok-sign:before{content:"\e084"}.glyphicon-question-sign:before{content:"\e085"}.glyphicon-info-sign:before{content:"\e086"}.glyphicon-screenshot:before{content:"\e087"}.glyphicon-remove-circle:before{content:"\e088"}.glyphicon-ok-circle:before{content:"\e089"}.glyphicon-ban-circle:before{content:"\e090"}.glyphicon-arrow-left:before{content:"\e091"}.glyphicon-arrow-right:before{content:"\e092"}.glyphicon-arrow-up:before{content:"\e093"}.glyphicon-arrow-down:before{content:"\e094"}.glyphicon-share-alt:before{content:"\e095"}.glyphicon-resize-full:before{content:"\e096"}.glyphicon-resize-small:before{content:"\e097"}.glyphicon-exclamation-sign:before{content:"\e101"}.glyphicon-gift:before{content:"\e102"}.glyphicon-leaf:before{content:"\e103"}.glyphicon-fire:before{content:"\e104"}.glyphicon-eye-open:before{content:"\e105"}.glyphicon-eye-close:before{content:"\e106"}.glyphicon-warning-sign:before{content:"\e107"}.glyphicon-plane:before{content:"\e108"}.glyphicon-calendar:before{content:"\e109"}.glyphicon-random:before{content:"\e110"}.glyphicon-comment:before{content:"\e111"}.glyphicon-magnet:before{content:"\e112"}.glyphicon-chevron-up:before{content:"\e113"}.glyphicon-chevron-down:before{content:"\e114"}.glyphicon-retweet:before{content:"\e115"}.glyphicon-shopping-cart:before{content:"\e116"}.glyphicon-folder-close:before{content:"\e117"}.glyphicon-folder-open:before{content:"\e118"}.glyphicon-resize-vertical:before{content:"\e119"}.glyphicon-resize-horizontal:before{content:"\e120"}.glyphicon-hdd:before{content:"\e121"}.glyphicon-bullhorn:before{content:"\e122"}.glyphicon-bell:before{content:"\e123"}.glyphicon-certificate:before{content:"\e124"}.glyphicon-thumbs-up:before{content:"\e125"}.glyphicon-thumbs-down:before{content:"\e126"}.glyphicon-hand-right:before{content:"\e127"}.glyphicon-hand-left:before{content:"\e128"}.glyphicon-hand-up:before{content:"\e129"}.glyphicon-hand-down:before{content:"\e130"}.glyphicon-circle-arrow-right:before{content:"\e131"}.glyphicon-circle-arrow-left:before{content:"\e132"}.glyphicon-circle-arrow-up:before{content:"\e133"}.glyphicon-circle-arrow-down:before{content:"\e134"}.glyphicon-globe:before{content:"\e135"}.glyphicon-wrench:before{content:"\e136"}.glyphicon-tasks:before{content:"\e137"}.glyphicon-filter:before{content:"\e138"}.glyphicon-briefcase:before{content:"\e139"}.glyphicon-fullscreen:before{content:"\e140"}.glyphicon-dashboard:before{content:"\e141"}.glyphicon-paperclip:before{content:"\e142"}.glyphicon-heart-empty:before{content:"\e143"}.glyphicon-link:before{content:"\e144"}.glyphicon-phone:before{content:"\e145"}.glyphicon-pushpin:before{content:"\e146"}.glyphicon-usd:before{content:"\e148"}.glyphicon-gbp:before{content:"\e149"}.glyphicon-sort:before{content:"\e150"}.glyphicon-sort-by-alphabet:before{content:"\e151"}.glyphicon-sort-by-alphabet-alt:before{content:"\e152"}.glyphicon-sort-by-order:before{content:"\e153"}.glyphicon-sort-by-order-alt:before{content:"\e154"}.glyphicon-sort-by-attributes:before{content:"\e155"}.glyphicon-sort-by-attributes-alt:before{content:"\e156"}.glyphicon-unchecked:before{content:"\e157"}.glyphicon-expand:before{content:"\e158"}.glyphicon-collapse-down:before{content:"\e159"}.glyphicon-collapse-up:before{content:"\e160"}.glyphicon-log-in:before{content:"\e161"}.glyphicon-flash:before{content:"\e162"}.glyphicon-log-out:before{content:"\e163"}.glyphicon-new-window:before{content:"\e164"}.glyphicon-record:before{content:"\e165"}.glyphicon-save:before{content:"\e166"}.glyphicon-open:before{content:"\e167"}.glyphicon-saved:before{content:"\e168"}.glyphicon-import:before{content:"\e169"}.glyphicon-export:before{content:"\e170"}.glyphicon-send:before{content:"\e171"}.glyphicon-floppy-disk:before{content:"\e172"}.glyphicon-floppy-saved:before{content:"\e173"}.glyphicon-floppy-remove:before{content:"\e174"}.glyphicon-floppy-save:before{content:"\e175"}.glyphicon-floppy-open:before{content:"\e176"}.glyphicon-credit-card:before{content:"\e177"}.glyphicon-transfer:before{content:"\e178"}.glyphicon-cutlery:before{content:"\e179"}.glyphicon-header:before{content:"\e180"}.glyphicon-compressed:before{content:"\e181"}.glyphicon-earphone:before{content:"\e182"}.glyphicon-phone-alt:before{content:"\e183"}.glyphicon-tower:before{content:"\e184"}.glyphicon-stats:before{content:"\e185"}.glyphicon-sd-video:before{content:"\e186"}.glyphicon-hd-video:before{content:"\e187"}.glyphicon-subtitles:before{content:"\e188"}.glyphicon-sound-stereo:before{content:"\e189"}.glyphicon-sound-dolby:before{content:"\e190"}.glyphicon-sound-5-1:before{content:"\e191"}.glyphicon-sound-6-1:before{content:"\e192"}.glyphicon-sound-7-1:before{content:"\e193"}.glyphicon-copyright-mark:before{content:"\e194"}.glyphicon-registration-mark:before{content:"\e195"}.glyphicon-cloud-download:before{content:"\e197"}.glyphicon-cloud-upload:before{content:"\e198"}.glyphicon-tree-conifer:before{content:"\e199"}.glyphicon-tree-deciduous:before{content:"\e200"}.glyphicon-cd:before{content:"\e201"}.glyphicon-save-file:before{content:"\e202"}.glyphicon-open-file:before{content:"\e203"}.glyphicon-level-up:before{content:"\e204"}.glyphicon-copy:before{content:"\e205"}.glyphicon-paste:before{content:"\e206"}.glyphicon-alert:before{content:"\e209"}.glyphicon-equalizer:before{content:"\e210"}.glyphicon-king:before{content:"\e211"}.glyphicon-queen:before{content:"\e212"}.glyphicon-pawn:before{content:"\e213"}.glyphicon-bishop:before{content:"\e214"}.glyphicon-knight:before{content:"\e215"}.glyphicon-baby-formula:before{content:"\e216"}.glyphicon-tent:before{content:"\26fa"}.glyphicon-blackboard:before{content:"\e218"}.glyphicon-bed:before{content:"\e219"}.glyphicon-apple:before{content:"\f8ff"}.glyphicon-erase:before{content:"\e221"}.glyphicon-hourglass:before{content:"\231b"}.glyphicon-lamp:before{content:"\e223"}.glyphicon-duplicate:before{content:"\e224"}.glyphicon-piggy-bank:before{content:"\e225"}.glyphicon-scissors:before{content:"\e226"}.glyphicon-bitcoin:before,.glyphicon-btc:before,.glyphicon-xbt:before{content:"\e227"}.glyphicon-jpy:before,.glyphicon-yen:before{content:"\00a5"}.glyphicon-rub:before,.glyphicon-ruble:before{content:"\20bd"}.glyphicon-scale:before{content:"\e230"}.glyphicon-ice-lolly:before{content:"\e231"}.glyphicon-ice-lolly-tasted:before{content:"\e232"}.glyphicon-education:before{content:"\e233"}.glyphicon-option-horizontal:before{content:"\e234"}.glyphicon-option-vertical:before{content:"\e235"}.glyphicon-menu-hamburger:before{content:"\e236"}.glyphicon-modal-window:before{content:"\e237"}.glyphicon-oil:before{content:"\e238"}.glyphicon-grain:before{content:"\e239"}.glyphicon-sunglasses:before{content:"\e240"}.glyphicon-text-size:before{content:"\e241"}.glyphicon-text-color:before{content:"\e242"}.glyphicon-text-background:before{content:"\e243"}.glyphicon-object-align-top:before{content:"\e244"}.glyphicon-object-align-bottom:before{content:"\e245"}.glyphicon-object-align-horizontal:before{content:"\e246"}.glyphicon-object-align-left:before{content:"\e247"}.glyphicon-object-align-vertical:before{content:"\e248"}.glyphicon-object-align-right:before{content:"\e249"}.glyphicon-triangle-right:before{content:"\e250"}.glyphicon-triangle-left:before{content:"\e251"}.glyphicon-triangle-bottom:before{content:"\e252"}.glyphicon-triangle-top:before{content:"\e253"}.glyphicon-console:before{content:"\e254"}.glyphicon-superscript:before{content:"\e255"}.glyphicon-subscript:before{content:"\e256"}.glyphicon-menu-left:before{content:"\e257"}.glyphicon-menu-right:before{content:"\e258"}.glyphicon-menu-down:before{content:"\e259"}.glyphicon-menu-up:before{content:"\e260"}*,:after,:before{box-sizing:border-box}html{font-size:10px;-webkit-tap-highlight-color:rgba(0,0,0,0)}body{font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:14px;line-height:1.42857143;color:#333}button,input,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit}a:focus,a:hover{color:#009ca3;text-decoration:underline}a:focus{outline:-webkit-focus-ring-color auto 5px;outline-offset:-2px}.carousel-inner>.item>a>img,.carousel-inner>.item>img,.img-responsive,.thumbnail a>img,.thumbnail>img{display:block;max-width:100%;height:auto}.img-rounded{border-radius:6px}.img-thumbnail{padding:4px;line-height:1.42857143;border:1px solid #ddd;border-radius:4px;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out;display:inline-block;max-width:100%;height:auto}.img-circle{border-radius:50%}hr{margin-top:20px;margin-bottom:20px;border-top:1px solid #eee}.sr-only{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);border:0}.sr-only-focusable:active,.sr-only-focusable:focus{position:static;width:auto;height:auto;margin:0;overflow:visible;clip:auto}[role=button]{cursor:pointer}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{font-family:inherit;font-weight:500;line-height:1.1;color:inherit}.h1 .small,.h1 small,.h2 .small,.h2 small,.h3 .small,.h3 small,.h4 .small,.h4 small,.h5 .small,.h5 small,.h6 .small,.h6 small,h1 .small,h1 small,h2 .small,h2 small,h3 .small,h3 small,h4 .small,h4 small,h5 .small,h5 small,h6 .small,h6 small{font-weight:400;line-height:1;color:#777}.h1,.h2,.h3,h1,h2,h3{margin-top:20px;margin-bottom:10px}.h1 .small,.h1 small,.h2 .small,.h2 small,.h3 .small,.h3 small,h1 .small,h1 small,h2 .small,h2 small,h3 .small,h3 small{font-size:65%}.h4,.h5,.h6,h4,h5,h6{margin-top:10px;margin-bottom:10px}.h4 .small,.h4 small,.h5 .small,.h5 small,.h6 .small,.h6 small,h4 .small,h4 small,h5 .small,h5 small,h6 .small,h6 small{font-size:75%}.h1,h1{font-size:36px}.h2,h2{font-size:30px}.h3,h3{font-size:24px}.h4,h4{font-size:18px}.h5,h5{font-size:14px}.h6,h6{font-size:12px}p{margin:0 0 10px}.lead{margin-bottom:20px;font-size:16px;font-weight:300;line-height:1.4}dt,kbd kbd,label{font-weight:700}address,blockquote .small,blockquote footer,blockquote small,dd,dt,pre{line-height:1.42857143}@media (min-width:768px){.lead{font-size:21px}}.small,small{font-size:85%}.mark,mark{background-color:#fcf8e3;padding:.2em}.list-inline,.list-unstyled{padding-left:0;list-style:none}.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}.text-justify{text-align:justify}.text-nowrap{white-space:nowrap}.text-lowercase{text-transform:lowercase}.text-uppercase{text-transform:uppercase}.text-capitalize{text-transform:capitalize}.text-muted{color:#777}.text-primary{color:#00e5f0}a.text-primary:focus,a.text-primary:hover{color:#00b4bd}.text-success{color:#3c763d}a.text-success:focus,a.text-success:hover{color:#2b542c}.text-info{color:#31708f}a.text-info:focus,a.text-info:hover{color:#245269}.text-warning{color:#8a6d3b}a.text-warning:focus,a.text-warning:hover{color:#66512c}.text-danger{color:#a94442}a.text-danger:focus,a.text-danger:hover{color:#843534}.bg-primary{color:#fff;background-color:#00e5f0}a.bg-primary:focus,a.bg-primary:hover{background-color:#00b4bd}.bg-success{background-color:#dff0d8}a.bg-success:focus,a.bg-success:hover{background-color:#c1e2b3}.bg-info{background-color:#d9edf7}a.bg-info:focus,a.bg-info:hover{background-color:#afd9ee}.bg-warning{background-color:#fcf8e3}a.bg-warning:focus,a.bg-warning:hover{background-color:#f7ecb5}.bg-danger{background-color:#f2dede}a.bg-danger:focus,a.bg-danger:hover{background-color:#e4b9b9}pre code,table{background-color:transparent}.page-header{padding-bottom:9px;margin:40px 0 20px;border-bottom:1px solid #eee}dl,ol,ul{margin-top:0}address,dl{margin-bottom:20px}ol,ul{margin-bottom:10px}ol ol,ol ul,ul ol,ul ul{margin-bottom:0}.list-inline{margin-left:-5px}.list-inline>li{display:inline-block;padding-left:5px;padding-right:5px}dd{margin-left:0}@media (min-width:768px){.dl-horizontal dt{float:left;width:160px;clear:left;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dl-horizontal dd{margin-left:180px}.container{width:750px}}abbr[data-original-title],abbr[title]{cursor:help;border-bottom:1px dotted #777}.initialism{font-size:90%;text-transform:uppercase}blockquote{padding:10px 20px;margin:0 0 20px;font-size:17.5px;border-left:5px solid #eee}blockquote ol:last-child,blockquote p:last-child,blockquote ul:last-child{margin-bottom:0}blockquote .small,blockquote footer,blockquote small{display:block;font-size:80%;color:#777}legend,pre{display:block;color:#333}blockquote .small:before,blockquote footer:before,blockquote small:before{content:'\2014 \00A0'}.blockquote-reverse,blockquote.pull-right{padding-right:15px;padding-left:0;border-right:5px solid #eee;border-left:0;text-align:right}code,kbd{padding:2px 4px;font-size:90%}caption,th{text-align:left}.blockquote-reverse .small:before,.blockquote-reverse footer:before,.blockquote-reverse small:before,blockquote.pull-right .small:before,blockquote.pull-right footer:before,blockquote.pull-right small:before{content:''}.blockquote-reverse .small:after,.blockquote-reverse footer:after,.blockquote-reverse small:after,blockquote.pull-right .small:after,blockquote.pull-right footer:after,blockquote.pull-right small:after{content:'\00A0 \2014'}code,kbd,pre,samp{font-family:Menlo,Monaco,Consolas,"Courier New",monospace}code{color:#c7254e;background-color:#f9f2f4;border-radius:4px}kbd{color:#fff;background-color:#333;border-radius:3px;box-shadow:inset 0 -1px 0 rgba(0,0,0,.25)}kbd kbd{padding:0;font-size:100%;box-shadow:none}pre{padding:9.5px;margin:0 0 10px;font-size:13px;word-break:break-all;background-color:#f5f5f5;border:1px solid #ccc;border-radius:4px}.container,.container-fluid{margin-right:auto;margin-left:auto}pre code{padding:0;font-size:inherit;color:inherit;white-space:pre-wrap;border-radius:0}.container,.container-fluid{padding-left:15px;padding-right:15px}.pre-scrollable{overflow-y:scroll}@media (min-width:992px){.container{width:970px}}@media (min-width:1200px){.container{width:1170px}}.row{margin-left:-15px;margin-right:-15px}.col-lg-1,.col-lg-10,.col-lg-11,.col-lg-12,.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-md-1,.col-md-10,.col-md-11,.col-md-12,.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-sm-1,.col-sm-10,.col-sm-11,.col-sm-12,.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-xs-1,.col-xs-10,.col-xs-11,.col-xs-12,.col-xs-2,.col-xs-3,.col-xs-4,.col-xs-5,.col-xs-6,.col-xs-7,.col-xs-8,.col-xs-9{position:relative;min-height:1px;padding-left:15px;padding-right:15px}.col-xs-12{width:100%}.col-xs-11{width:91.66666667%}.col-xs-10{width:83.33333333%}.col-xs-9{width:75%}.col-xs-8{width:66.66666667%}.col-xs-7{width:58.33333333%}.col-xs-6{width:50%}.col-xs-5{width:41.66666667%}.col-xs-4{width:33.33333333%}.col-xs-3{width:25%}.col-xs-2{width:16.66666667%}.col-xs-1{width:8.33333333%}.col-xs-pull-12{right:100%}.col-xs-pull-11{right:91.66666667%}.col-xs-pull-10{right:83.33333333%}.col-xs-pull-9{right:75%}.col-xs-pull-8{right:66.66666667%}.col-xs-pull-7{right:58.33333333%}.col-xs-pull-6{right:50%}.col-xs-pull-5{right:41.66666667%}.col-xs-pull-4{right:33.33333333%}.col-xs-pull-3{right:25%}.col-xs-pull-2{right:16.66666667%}.col-xs-pull-1{right:8.33333333%}.col-xs-pull-0{right:auto}.col-xs-push-12{left:100%}.col-xs-push-11{left:91.66666667%}.col-xs-push-10{left:83.33333333%}.col-xs-push-9{left:75%}.col-xs-push-8{left:66.66666667%}.col-xs-push-7{left:58.33333333%}.col-xs-push-6{left:50%}.col-xs-push-5{left:41.66666667%}.col-xs-push-4{left:33.33333333%}.col-xs-push-3{left:25%}.col-xs-push-2{left:16.66666667%}.col-xs-push-1{left:8.33333333%}.col-xs-push-0{left:auto}.col-xs-offset-12{margin-left:100%}.col-xs-offset-11{margin-left:91.66666667%}.col-xs-offset-10{margin-left:83.33333333%}.col-xs-offset-9{margin-left:75%}.col-xs-offset-8{margin-left:66.66666667%}.col-xs-offset-7{margin-left:58.33333333%}.col-xs-offset-6{margin-left:50%}.col-xs-offset-5{margin-left:41.66666667%}.col-xs-offset-4{margin-left:33.33333333%}.col-xs-offset-3{margin-left:25%}.col-xs-offset-2{margin-left:16.66666667%}.col-xs-offset-1{margin-left:8.33333333%}.col-xs-offset-0{margin-left:0}@media (min-width:768px){.col-sm-1,.col-sm-10,.col-sm-11,.col-sm-12,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9{float:left}.col-sm-12{width:100%}.col-sm-11{width:91.66666667%}.col-sm-10{width:83.33333333%}.col-sm-9{width:75%}.col-sm-8{width:66.66666667%}.col-sm-7{width:58.33333333%}.col-sm-6{width:50%}.col-sm-5{width:41.66666667%}.col-sm-4{width:33.33333333%}.col-sm-3{width:25%}.col-sm-2{width:16.66666667%}.col-sm-1{width:8.33333333%}.col-sm-pull-12{right:100%}.col-sm-pull-11{right:91.66666667%}.col-sm-pull-10{right:83.33333333%}.col-sm-pull-9{right:75%}.col-sm-pull-8{right:66.66666667%}.col-sm-pull-7{right:58.33333333%}.col-sm-pull-6{right:50%}.col-sm-pull-5{right:41.66666667%}.col-sm-pull-4{right:33.33333333%}.col-sm-pull-3{right:25%}.col-sm-pull-2{right:16.66666667%}.col-sm-pull-1{right:8.33333333%}.col-sm-pull-0{right:auto}.col-sm-push-12{left:100%}.col-sm-push-11{left:91.66666667%}.col-sm-push-10{left:83.33333333%}.col-sm-push-9{left:75%}.col-sm-push-8{left:66.66666667%}.col-sm-push-7{left:58.33333333%}.col-sm-push-6{left:50%}.col-sm-push-5{left:41.66666667%}.col-sm-push-4{left:33.33333333%}.col-sm-push-3{left:25%}.col-sm-push-2{left:16.66666667%}.col-sm-push-1{left:8.33333333%}.col-sm-push-0{left:auto}.col-sm-offset-12{margin-left:100%}.col-sm-offset-11{margin-left:91.66666667%}.col-sm-offset-10{margin-left:83.33333333%}.col-sm-offset-9{margin-left:75%}.col-sm-offset-8{margin-left:66.66666667%}.col-sm-offset-7{margin-left:58.33333333%}.col-sm-offset-6{margin-left:50%}.col-sm-offset-5{margin-left:41.66666667%}.col-sm-offset-4{margin-left:33.33333333%}.col-sm-offset-3{margin-left:25%}.col-sm-offset-2{margin-left:16.66666667%}.col-sm-offset-1{margin-left:8.33333333%}.col-sm-offset-0{margin-left:0}}@media (min-width:992px){.col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9{float:left}.col-md-12{width:100%}.col-md-11{width:91.66666667%}.col-md-10{width:83.33333333%}.col-md-9{width:75%}.col-md-8{width:66.66666667%}.col-md-7{width:58.33333333%}.col-md-6{width:50%}.col-md-5{width:41.66666667%}.col-md-4{width:33.33333333%}.col-md-3{width:25%}.col-md-2{width:16.66666667%}.col-md-1{width:8.33333333%}.col-md-pull-12{right:100%}.col-md-pull-11{right:91.66666667%}.col-md-pull-10{right:83.33333333%}.col-md-pull-9{right:75%}.col-md-pull-8{right:66.66666667%}.col-md-pull-7{right:58.33333333%}.col-md-pull-6{right:50%}.col-md-pull-5{right:41.66666667%}.col-md-pull-4{right:33.33333333%}.col-md-pull-3{right:25%}.col-md-pull-2{right:16.66666667%}.col-md-pull-1{right:8.33333333%}.col-md-pull-0{right:auto}.col-md-push-12{left:100%}.col-md-push-11{left:91.66666667%}.col-md-push-10{left:83.33333333%}.col-md-push-9{left:75%}.col-md-push-8{left:66.66666667%}.col-md-push-7{left:58.33333333%}.col-md-push-6{left:50%}.col-md-push-5{left:41.66666667%}.col-md-push-4{left:33.33333333%}.col-md-push-3{left:25%}.col-md-push-2{left:16.66666667%}.col-md-push-1{left:8.33333333%}.col-md-push-0{left:auto}.col-md-offset-12{margin-left:100%}.col-md-offset-11{margin-left:91.66666667%}.col-md-offset-10{margin-left:83.33333333%}.col-md-offset-9{margin-left:75%}.col-md-offset-8{margin-left:66.66666667%}.col-md-offset-7{margin-left:58.33333333%}.col-md-offset-6{margin-left:50%}.col-md-offset-5{margin-left:41.66666667%}.col-md-offset-4{margin-left:33.33333333%}.col-md-offset-3{margin-left:25%}.col-md-offset-2{margin-left:16.66666667%}.col-md-offset-1{margin-left:8.33333333%}.col-md-offset-0{margin-left:0}}@media (min-width:1200px){.col-lg-1,.col-lg-10,.col-lg-11,.col-lg-12,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9{float:left}.col-lg-12{width:100%}.col-lg-11{width:91.66666667%}.col-lg-10{width:83.33333333%}.col-lg-9{width:75%}.col-lg-8{width:66.66666667%}.col-lg-7{width:58.33333333%}.col-lg-6{width:50%}.col-lg-5{width:41.66666667%}.col-lg-4{width:33.33333333%}.col-lg-3{width:25%}.col-lg-2{width:16.66666667%}.col-lg-1{width:8.33333333%}.col-lg-pull-12{right:100%}.col-lg-pull-11{right:91.66666667%}.col-lg-pull-10{right:83.33333333%}.col-lg-pull-9{right:75%}.col-lg-pull-8{right:66.66666667%}.col-lg-pull-7{right:58.33333333%}.col-lg-pull-6{right:50%}.col-lg-pull-5{right:41.66666667%}.col-lg-pull-4{right:33.33333333%}.col-lg-pull-3{right:25%}.col-lg-pull-2{right:16.66666667%}.col-lg-pull-1{right:8.33333333%}.col-lg-pull-0{right:auto}.col-lg-push-12{left:100%}.col-lg-push-11{left:91.66666667%}.col-lg-push-10{left:83.33333333%}.col-lg-push-9{left:75%}.col-lg-push-8{left:66.66666667%}.col-lg-push-7{left:58.33333333%}.col-lg-push-6{left:50%}.col-lg-push-5{left:41.66666667%}.col-lg-push-4{left:33.33333333%}.col-lg-push-3{left:25%}.col-lg-push-2{left:16.66666667%}.col-lg-push-1{left:8.33333333%}.col-lg-push-0{left:auto}.col-lg-offset-12{margin-left:100%}.col-lg-offset-11{margin-left:91.66666667%}.col-lg-offset-10{margin-left:83.33333333%}.col-lg-offset-9{margin-left:75%}.col-lg-offset-8{margin-left:66.66666667%}.col-lg-offset-7{margin-left:58.33333333%}.col-lg-offset-6{margin-left:50%}.col-lg-offset-5{margin-left:41.66666667%}.col-lg-offset-4{margin-left:33.33333333%}.col-lg-offset-3{margin-left:25%}.col-lg-offset-2{margin-left:16.66666667%}.col-lg-offset-1{margin-left:8.33333333%}.col-lg-offset-0{margin-left:0}}table{border-collapse:collapse;border-spacing:0}caption{padding-top:8px;padding-bottom:8px;color:#777}.table{width:100%;max-width:100%;margin-bottom:20px}.table>tbody>tr>td,.table>tbody>tr>th,.table>tfoot>tr>td,.table>tfoot>tr>th,.table>thead>tr>td,.table>thead>tr>th{padding:8px;line-height:1.42857143;vertical-align:top;border-top:1px solid #ddd}.table>thead>tr>th{vertical-align:bottom;border-bottom:2px solid #ddd}.table>caption+thead>tr:first-child>td,.table>caption+thead>tr:first-child>th,.table>colgroup+thead>tr:first-child>td,.table>colgroup+thead>tr:first-child>th,.table>thead:first-child>tr:first-child>td,.table>thead:first-child>tr:first-child>th{border-top:0}.table>tbody+tbody{border-top:2px solid #ddd}.table .table{background-color:#fff}.table-condensed>tbody>tr>td,.table-condensed>tbody>tr>th,.table-condensed>tfoot>tr>td,.table-condensed>tfoot>tr>th,.table-condensed>thead>tr>td,.table-condensed>thead>tr>th{padding:5px}.table-bordered,.table-bordered>tbody>tr>td,.table-bordered>tbody>tr>th,.table-bordered>tfoot>tr>td,.table-bordered>tfoot>tr>th,.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border:1px solid #ddd}.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border-bottom-width:2px}.table-striped>tbody>tr:nth-of-type(odd){background-color:#f9f9f9}.table-hover>tbody>tr:hover,.table>tbody>tr.active>td,.table>tbody>tr.active>th,.table>tbody>tr>td.active,.table>tbody>tr>th.active,.table>tfoot>tr.active>td,.table>tfoot>tr.active>th,.table>tfoot>tr>td.active,.table>tfoot>tr>th.active,.table>thead>tr.active>td,.table>thead>tr.active>th,.table>thead>tr>td.active,.table>thead>tr>th.active{background-color:#f5f5f5}table col[class*=col-]{position:static;float:none;display:table-column}table td[class*=col-],table th[class*=col-]{position:static;float:none;display:table-cell}.table-hover>tbody>tr.active:hover>td,.table-hover>tbody>tr.active:hover>th,.table-hover>tbody>tr:hover>.active,.table-hover>tbody>tr>td.active:hover,.table-hover>tbody>tr>th.active:hover{background-color:#e8e8e8}.table>tbody>tr.success>td,.table>tbody>tr.success>th,.table>tbody>tr>td.success,.table>tbody>tr>th.success,.table>tfoot>tr.success>td,.table>tfoot>tr.success>th,.table>tfoot>tr>td.success,.table>tfoot>tr>th.success,.table>thead>tr.success>td,.table>thead>tr.success>th,.table>thead>tr>td.success,.table>thead>tr>th.success{background-color:#dff0d8}.table-hover>tbody>tr.success:hover>td,.table-hover>tbody>tr.success:hover>th,.table-hover>tbody>tr:hover>.success,.table-hover>tbody>tr>td.success:hover,.table-hover>tbody>tr>th.success:hover{background-color:#d0e9c6}.table>tbody>tr.info>td,.table>tbody>tr.info>th,.table>tbody>tr>td.info,.table>tbody>tr>th.info,.table>tfoot>tr.info>td,.table>tfoot>tr.info>th,.table>tfoot>tr>td.info,.table>tfoot>tr>th.info,.table>thead>tr.info>td,.table>thead>tr.info>th,.table>thead>tr>td.info,.table>thead>tr>th.info{background-color:#d9edf7}.table-hover>tbody>tr.info:hover>td,.table-hover>tbody>tr.info:hover>th,.table-hover>tbody>tr:hover>.info,.table-hover>tbody>tr>td.info:hover,.table-hover>tbody>tr>th.info:hover{background-color:#c4e3f3}.table>tbody>tr.warning>td,.table>tbody>tr.warning>th,.table>tbody>tr>td.warning,.table>tbody>tr>th.warning,.table>tfoot>tr.warning>td,.table>tfoot>tr.warning>th,.table>tfoot>tr>td.warning,.table>tfoot>tr>th.warning,.table>thead>tr.warning>td,.table>thead>tr.warning>th,.table>thead>tr>td.warning,.table>thead>tr>th.warning{background-color:#fcf8e3}.table-hover>tbody>tr.warning:hover>td,.table-hover>tbody>tr.warning:hover>th,.table-hover>tbody>tr:hover>.warning,.table-hover>tbody>tr>td.warning:hover,.table-hover>tbody>tr>th.warning:hover{background-color:#faf2cc}.table>tbody>tr.danger>td,.table>tbody>tr.danger>th,.table>tbody>tr>td.danger,.table>tbody>tr>th.danger,.table>tfoot>tr.danger>td,.table>tfoot>tr.danger>th,.table>tfoot>tr>td.danger,.table>tfoot>tr>th.danger,.table>thead>tr.danger>td,.table>thead>tr.danger>th,.table>thead>tr>td.danger,.table>thead>tr>th.danger{background-color:#f2dede}.table-hover>tbody>tr.danger:hover>td,.table-hover>tbody>tr.danger:hover>th,.table-hover>tbody>tr:hover>.danger,.table-hover>tbody>tr>td.danger:hover,.table-hover>tbody>tr>th.danger:hover{background-color:#ebcccc}.table-responsive{overflow-x:auto;min-height:.01%}@media screen and (max-width:767px){.table-responsive{width:100%;margin-bottom:15px;overflow-y:hidden;-ms-overflow-style:-ms-autohiding-scrollbar;border:1px solid #ddd}.table-responsive>.table{margin-bottom:0}.table-responsive>.table>tbody>tr>td,.table-responsive>.table>tbody>tr>th,.table-responsive>.table>tfoot>tr>td,.table-responsive>.table>tfoot>tr>th,.table-responsive>.table>thead>tr>td,.table-responsive>.table>thead>tr>th{white-space:nowrap}.table-responsive>.table-bordered{border:0}.table-responsive>.table-bordered>tbody>tr>td:first-child,.table-responsive>.table-bordered>tbody>tr>th:first-child,.table-responsive>.table-bordered>tfoot>tr>td:first-child,.table-responsive>.table-bordered>tfoot>tr>th:first-child,.table-responsive>.table-bordered>thead>tr>td:first-child,.table-responsive>.table-bordered>thead>tr>th:first-child{border-left:0}.table-responsive>.table-bordered>tbody>tr>td:last-child,.table-responsive>.table-bordered>tbody>tr>th:last-child,.table-responsive>.table-bordered>tfoot>tr>td:last-child,.table-responsive>.table-bordered>tfoot>tr>th:last-child,.table-responsive>.table-bordered>thead>tr>td:last-child,.table-responsive>.table-bordered>thead>tr>th:last-child{border-right:0}.table-responsive>.table-bordered>tbody>tr:last-child>td,.table-responsive>.table-bordered>tbody>tr:last-child>th,.table-responsive>.table-bordered>tfoot>tr:last-child>td,.table-responsive>.table-bordered>tfoot>tr:last-child>th{border-bottom:0}}fieldset,legend{padding:0;border:0}fieldset{margin:0;min-width:0}legend{width:100%;margin-bottom:20px;font-size:21px;line-height:inherit;border-bottom:1px solid #e5e5e5}label{display:inline-block;max-width:100%;margin-bottom:5px}input[type=search]{box-sizing:border-box;-webkit-appearance:none}input[type=checkbox],input[type=radio]{margin:4px 0 0;margin-top:1px\9;line-height:normal}.form-control,output{font-size:14px;line-height:1.42857143;color:#555;display:block}input[type=file]{display:block}input[type=range]{display:block;width:100%}select[multiple],select[size]{height:auto}input[type=file]:focus,input[type=checkbox]:focus,input[type=radio]:focus{outline:-webkit-focus-ring-color auto 5px;outline-offset:-2px}output{padding-top:7px}.form-control{width:100%;height:34px;padding:6px 12px;background-color:#fff;border:1px solid #ccc;border-radius:4px;box-shadow:inset 0 1px 1px rgba(0,0,0,.075);-webkit-transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s;transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s}.form-control:focus{border-color:#66afe9;outline:0;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 8px rgba(102,175,233,.6)}.form-control::-moz-placeholder{color:#999;opacity:1}.form-control:-ms-input-placeholder{color:#999}.form-control::-webkit-input-placeholder{color:#999}.has-success .checkbox,.has-success .checkbox-inline,.has-success .control-label,.has-success .form-control-feedback,.has-success .help-block,.has-success .radio,.has-success .radio-inline,.has-success.checkbox label,.has-success.checkbox-inline label,.has-success.radio label,.has-success.radio-inline label{color:#3c763d}.form-control::-ms-expand{border:0;background-color:transparent}.form-control[disabled],.form-control[readonly],fieldset[disabled] .form-control{background-color:#eee;opacity:1}.form-control[disabled],fieldset[disabled] .form-control{cursor:not-allowed}textarea.form-control{height:auto}@media screen and (-webkit-min-device-pixel-ratio:0){input[type=date].form-control,input[type=time].form-control,input[type=datetime-local].form-control,input[type=month].form-control{line-height:34px}.input-group-sm input[type=date],.input-group-sm input[type=time],.input-group-sm input[type=datetime-local],.input-group-sm input[type=month],input[type=date].input-sm,input[type=time].input-sm,input[type=datetime-local].input-sm,input[type=month].input-sm{line-height:30px}.input-group-lg input[type=date],.input-group-lg input[type=time],.input-group-lg input[type=datetime-local],.input-group-lg input[type=month],input[type=date].input-lg,input[type=time].input-lg,input[type=datetime-local].input-lg,input[type=month].input-lg{line-height:46px}}.form-group{margin-bottom:15px}.checkbox,.radio{position:relative;display:block;margin-top:10px;margin-bottom:10px}.checkbox label,.radio label{min-height:20px;padding-left:20px;margin-bottom:0;font-weight:400;cursor:pointer}.checkbox input[type=checkbox],.checkbox-inline input[type=checkbox],.radio input[type=radio],.radio-inline input[type=radio]{position:absolute;margin-left:-20px;margin-top:4px\9}.checkbox+.checkbox,.radio+.radio{margin-top:-5px}.checkbox-inline,.radio-inline{position:relative;display:inline-block;padding-left:20px;margin-bottom:0;vertical-align:middle;font-weight:400;cursor:pointer}.checkbox-inline+.checkbox-inline,.radio-inline+.radio-inline{margin-top:0;margin-left:10px}.checkbox-inline.disabled,.checkbox.disabled label,.radio-inline.disabled,.radio.disabled label,fieldset[disabled] .checkbox label,fieldset[disabled] .checkbox-inline,fieldset[disabled] .radio label,fieldset[disabled] .radio-inline,fieldset[disabled] input[type=checkbox],fieldset[disabled] input[type=radio],input[type=checkbox].disabled,input[type=checkbox][disabled],input[type=radio].disabled,input[type=radio][disabled]{cursor:not-allowed}.form-control-static{padding-top:7px;padding-bottom:7px;margin-bottom:0;min-height:34px}.form-control-static.input-lg,.form-control-static.input-sm{padding-left:0;padding-right:0}.form-group-sm .form-control,.input-sm{padding:5px 10px;border-radius:3px;font-size:12px}.input-sm{height:30px;line-height:1.5}select.input-sm{height:30px;line-height:30px}select[multiple].input-sm,textarea.input-sm{height:auto}.form-group-sm .form-control{height:30px;line-height:1.5}.form-group-lg .form-control,.input-lg{border-radius:6px;padding:10px 16px;font-size:18px}.form-group-sm select.form-control{height:30px;line-height:30px}.form-group-sm select[multiple].form-control,.form-group-sm textarea.form-control{height:auto}.form-group-sm .form-control-static{height:30px;min-height:32px;padding:6px 10px;font-size:12px;line-height:1.5}.input-lg{height:46px;line-height:1.3333333}select.input-lg{height:46px;line-height:46px}select[multiple].input-lg,textarea.input-lg{height:auto}.form-group-lg .form-control{height:46px;line-height:1.3333333}.form-group-lg select.form-control{height:46px;line-height:46px}.form-group-lg select[multiple].form-control,.form-group-lg textarea.form-control{height:auto}.form-group-lg .form-control-static{height:46px;min-height:38px;padding:11px 16px;font-size:18px;line-height:1.3333333}.has-feedback{position:relative}.has-feedback .form-control{padding-right:42.5px}.form-control-feedback{position:absolute;top:0;right:0;z-index:2;display:block;width:34px;height:34px;line-height:34px;text-align:center;pointer-events:none}.collapsing,.dropdown,.dropup{position:relative}.form-group-lg .form-control+.form-control-feedback,.input-group-lg+.form-control-feedback,.input-lg+.form-control-feedback{width:46px;height:46px;line-height:46px}.form-group-sm .form-control+.form-control-feedback,.input-group-sm+.form-control-feedback,.input-sm+.form-control-feedback{width:30px;height:30px;line-height:30px}.has-success .form-control{box-shadow:inset 0 1px 1px rgba(0,0,0,.075)}.has-success .form-control:focus{box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #67b168}.has-success .input-group-addon{color:#3c763d;border-color:#3c763d;background-color:#dff0d8}.has-warning .checkbox,.has-warning .checkbox-inline,.has-warning .control-label,.has-warning .form-control-feedback,.has-warning .help-block,.has-warning .radio,.has-warning .radio-inline,.has-warning.checkbox label,.has-warning.checkbox-inline label,.has-warning.radio label,.has-warning.radio-inline label{color:#8a6d3b}.has-warning .form-control{border-color:#8a6d3b;box-shadow:inset 0 1px 1px rgba(0,0,0,.075)}.has-warning .form-control:focus{border-color:#66512c;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #c0a16b}.has-warning .input-group-addon{color:#8a6d3b;border-color:#8a6d3b;background-color:#fcf8e3}.has-error .checkbox,.has-error .checkbox-inline,.has-error .control-label,.has-error .form-control-feedback,.has-error .help-block,.has-error .radio,.has-error .radio-inline,.has-error.checkbox label,.has-error.checkbox-inline label,.has-error.radio label,.has-error.radio-inline label{color:#a94442}.has-error .form-control{box-shadow:inset 0 1px 1px rgba(0,0,0,.075)}.has-error .form-control:focus{box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #ce8483}.has-error .input-group-addon{color:#a94442;border-color:#a94442;background-color:#f2dede}.has-feedback label~.form-control-feedback{top:25px}.has-feedback label.sr-only~.form-control-feedback{top:0}.help-block{display:block;margin-top:5px;margin-bottom:10px;color:#737373}@media (min-width:768px){.form-inline .form-control-static,.form-inline .form-group{display:inline-block}.form-inline .control-label,.form-inline .form-group{margin-bottom:0;vertical-align:middle}.form-inline .form-control{display:inline-block;width:auto;vertical-align:middle}.form-inline .input-group{display:inline-table;vertical-align:middle}.form-inline .input-group .form-control,.form-inline .input-group .input-group-addon,.form-inline .input-group .input-group-btn{width:auto}.form-inline .input-group>.form-control{width:100%}.form-inline .checkbox,.form-inline .radio{display:inline-block;margin-top:0;margin-bottom:0;vertical-align:middle}.form-inline .checkbox label,.form-inline .radio label{padding-left:0}.form-inline .checkbox input[type=checkbox],.form-inline .radio input[type=radio]{position:relative;margin-left:0}.form-inline .has-feedback .form-control-feedback{top:0}.form-horizontal .control-label{text-align:right;margin-bottom:0;padding-top:7px}}.form-horizontal .checkbox,.form-horizontal .checkbox-inline,.form-horizontal .radio,.form-horizontal .radio-inline{margin-top:0;margin-bottom:0;padding-top:7px}.form-horizontal .checkbox,.form-horizontal .radio{min-height:27px}.form-horizontal .form-group{margin-left:-15px;margin-right:-15px}.form-horizontal .has-feedback .form-control-feedback{right:15px}@media (min-width:768px){.form-horizontal .form-group-lg .control-label{padding-top:11px;font-size:18px}.form-horizontal .form-group-sm .control-label{padding-top:6px;font-size:12px}}.btn{display:inline-block;margin-bottom:0;font-weight:400;text-align:center;vertical-align:middle;-ms-touch-action:manipulation;touch-action:manipulation;cursor:pointer;border:1px solid transparent;white-space:nowrap;padding:6px 12px;font-size:14px;line-height:1.42857143;border-radius:4px;user-select:none}.btn.active.focus,.btn.active:focus,.btn.focus,.btn:active.focus,.btn:active:focus,.btn:focus{outline:-webkit-focus-ring-color auto 5px;outline-offset:-2px}.btn.focus,.btn:focus,.btn:hover{color:#333;text-decoration:none}.btn.active,.btn:active{outline:0;box-shadow:inset 0 3px 5px rgba(0,0,0,.125)}.btn.disabled,.btn[disabled],fieldset[disabled] .btn{cursor:not-allowed;opacity:.65;filter:alpha(opacity=65);box-shadow:none}a.btn.disabled,fieldset[disabled] a.btn{pointer-events:none}.btn-default{color:#333;background-color:#fff;border-color:#ccc}.btn-default.focus,.btn-default:focus{color:#333;background-color:#e6e6e6;border-color:#8c8c8c}.btn-default.active,.btn-default:active,.btn-default:hover,.open>.dropdown-toggle.btn-default{color:#333;background-color:#e6e6e6;border-color:#adadad}.btn-default.active.focus,.btn-default.active:focus,.btn-default.active:hover,.btn-default:active.focus,.btn-default:active:focus,.btn-default:active:hover,.open>.dropdown-toggle.btn-default.focus,.open>.dropdown-toggle.btn-default:focus,.open>.dropdown-toggle.btn-default:hover{color:#333;background-color:#d4d4d4;border-color:#8c8c8c}.btn-default.disabled.focus,.btn-default.disabled:focus,.btn-default.disabled:hover,.btn-default[disabled].focus,.btn-default[disabled]:focus,.btn-default[disabled]:hover,fieldset[disabled] .btn-default.focus,fieldset[disabled] .btn-default:focus,fieldset[disabled] .btn-default:hover{background-color:#fff;border-color:#ccc}.btn-default .badge{color:#fff;background-color:#333}.btn-primary{color:#fff;background-color:#00e5f0;border-color:#00cdd7}.btn-primary.focus,.btn-primary:focus{color:#fff;background-color:#00b4bd;border-color:#005357}.btn-primary.active,.btn-primary:active,.btn-primary:hover,.open>.dropdown-toggle.btn-primary{color:#fff;background-color:#00b4bd;border-color:#009299}.btn-primary.active.focus,.btn-primary.active:focus,.btn-primary.active:hover,.btn-primary:active.focus,.btn-primary:active:focus,.btn-primary:active:hover,.open>.dropdown-toggle.btn-primary.focus,.open>.dropdown-toggle.btn-primary:focus,.open>.dropdown-toggle.btn-primary:hover{color:#fff;background-color:#009299;border-color:#005357}.btn-primary.disabled.focus,.btn-primary.disabled:focus,.btn-primary.disabled:hover,.btn-primary[disabled].focus,.btn-primary[disabled]:focus,.btn-primary[disabled]:hover,fieldset[disabled] .btn-primary.focus,fieldset[disabled] .btn-primary:focus,fieldset[disabled] .btn-primary:hover{background-color:#00e5f0;border-color:#00cdd7}.btn-primary .badge{color:#00e5f0;background-color:#fff}.btn-success{color:#fff;background-color:#00e5f0;border-color:#00cdd7}.btn-success.focus,.btn-success:focus{color:#fff;background-color:#00b4bd;border-color:#005357}.btn-success.active,.btn-success:active,.btn-success:hover,.open>.dropdown-toggle.btn-success{color:#fff;background-color:#00b4bd;border-color:#009299}.btn-success.active.focus,.btn-success.active:focus,.btn-success.active:hover,.btn-success:active.focus,.btn-success:active:focus,.btn-success:active:hover,.open>.dropdown-toggle.btn-success.focus,.open>.dropdown-toggle.btn-success:focus,.open>.dropdown-toggle.btn-success:hover{color:#fff;background-color:#009299;border-color:#005357}.btn-success.active,.btn-success:active,.open>.dropdown-toggle.btn-success{background-image:none}.btn-success.disabled.focus,.btn-success.disabled:focus,.btn-success.disabled:hover,.btn-success[disabled].focus,.btn-success[disabled]:focus,.btn-success[disabled]:hover,fieldset[disabled] .btn-success.focus,fieldset[disabled] .btn-success:focus,fieldset[disabled] .btn-success:hover{background-color:#00e5f0;border-color:#00cdd7}.btn-success .badge{color:#00e5f0;background-color:#fff}.btn-info{color:#fff;background-color:#00e5f0;border-color:#00cdd7}.btn-info.focus,.btn-info:focus{color:#fff;background-color:#00b4bd;border-color:#005357}.btn-info.active,.btn-info:active,.btn-info:hover,.open>.dropdown-toggle.btn-info{color:#fff;background-color:#00b4bd;border-color:#009299}.btn-info.active.focus,.btn-info.active:focus,.btn-info.active:hover,.btn-info:active.focus,.btn-info:active:focus,.btn-info:active:hover,.open>.dropdown-toggle.btn-info.focus,.open>.dropdown-toggle.btn-info:focus,.open>.dropdown-toggle.btn-info:hover{color:#fff;background-color:#009299;border-color:#005357}.btn-info.disabled.focus,.btn-info.disabled:focus,.btn-info.disabled:hover,.btn-info[disabled].focus,.btn-info[disabled]:focus,.btn-info[disabled]:hover,fieldset[disabled] .btn-info.focus,fieldset[disabled] .btn-info:focus,fieldset[disabled] .btn-info:hover{background-color:#00e5f0;border-color:#00cdd7}.btn-info .badge{color:#00e5f0;background-color:#fff}.btn-warning{color:#fff;background-color:#977bf0;border-color:#8564ed}.btn-warning.focus,.btn-warning:focus{color:#fff;background-color:#734deb;border-color:#3d15bd}.btn-warning.active,.btn-warning:active,.btn-warning:hover,.open>.dropdown-toggle.btn-warning{color:#fff;background-color:#734deb;border-color:#5a2de7}.btn-warning.active.focus,.btn-warning.active:focus,.btn-warning.active:hover,.btn-warning:active.focus,.btn-warning:active:focus,.btn-warning:active:hover,.open>.dropdown-toggle.btn-warning.focus,.open>.dropdown-toggle.btn-warning:focus,.open>.dropdown-toggle.btn-warning:hover{color:#fff;background-color:#5a2de7;border-color:#3d15bd}.btn-warning.disabled.focus,.btn-warning.disabled:focus,.btn-warning.disabled:hover,.btn-warning[disabled].focus,.btn-warning[disabled]:focus,.btn-warning[disabled]:hover,fieldset[disabled] .btn-warning.focus,fieldset[disabled] .btn-warning:focus,fieldset[disabled] .btn-warning:hover{background-color:#977bf0;border-color:#8564ed}.btn-warning .badge{color:#977bf0;background-color:#fff}.btn-danger{color:#fff;background-color:#e01f74;border-color:#ca1c68}.btn-danger.focus,.btn-danger:focus{color:#fff;background-color:#b3195d;border-color:#5a0c2e}.btn-danger.active,.btn-danger:active,.btn-danger:hover,.open>.dropdown-toggle.btn-danger{color:#fff;background-color:#b3195d;border-color:#94144d}.btn-danger.active.focus,.btn-danger.active:focus,.btn-danger.active:hover,.btn-danger:active.focus,.btn-danger:active:focus,.btn-danger:active:hover,.open>.dropdown-toggle.btn-danger.focus,.open>.dropdown-toggle.btn-danger:focus,.open>.dropdown-toggle.btn-danger:hover{color:#fff;background-color:#94144d;border-color:#5a0c2e}.btn-danger.disabled.focus,.btn-danger.disabled:focus,.btn-danger.disabled:hover,.btn-danger[disabled].focus,.btn-danger[disabled]:focus,.btn-danger[disabled]:hover,fieldset[disabled] .btn-danger.focus,fieldset[disabled] .btn-danger:focus,fieldset[disabled] .btn-danger:hover{background-color:#e01f74;border-color:#ca1c68}.btn-danger .badge{color:#e01f74;background-color:#fff}.btn-link{color:#00e5f0;font-weight:400;border-radius:0}.btn-link,.btn-link.active,.btn-link:active,.btn-link[disabled],fieldset[disabled] .btn-link{background-color:transparent;box-shadow:none}.btn-link,.btn-link:active,.btn-link:focus,.btn-link:hover{border-color:transparent}.btn-link:focus,.btn-link:hover{color:#009ca3;text-decoration:underline;background-color:transparent}.btn-link[disabled]:focus,.btn-link[disabled]:hover,fieldset[disabled] .btn-link:focus,fieldset[disabled] .btn-link:hover{color:#777;text-decoration:none}.btn-group-lg>.btn,.btn-lg{padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}.btn-group-sm>.btn,.btn-sm{padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}.btn-group-xs>.btn,.btn-xs{padding:1px 5px;font-size:12px;line-height:1.5;border-radius:3px}.btn-block{display:block;width:100%}.btn-block+.btn-block{margin-top:5px}input[type=button].btn-block,input[type=reset].btn-block,input[type=submit].btn-block{width:100%}.fade{opacity:0;-webkit-transition:opacity .15s linear;transition:opacity .15s linear}.fade.in{opacity:1}.collapse{display:none}.collapse.in{display:block}tr.collapse.in{display:table-row}tbody.collapse.in{display:table-row-group}.collapsing{height:0;overflow:hidden;-webkit-transition-property:height,visibility;transition-property:height,visibility;-webkit-transition-duration:.35s;transition-duration:.35s;-webkit-transition-timing-function:ease;transition-timing-function:ease}.caret{display:inline-block;width:0;height:0;margin-left:2px;vertical-align:middle;border-top:4px dashed;border-top:4px solid\9;border-right:4px solid transparent;border-left:4px solid transparent}.dropdown-toggle:focus{outline:0}.dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;display:none;min-width:160px;padding:5px 0;margin:2px 0 0;list-style:none;font-size:14px;text-align:left;background-color:#fff;border:1px solid #ccc;border:1px solid rgba(0,0,0,.15);border-radius:4px;box-shadow:0 6px 12px rgba(0,0,0,.175);background-clip:padding-box}.dropdown-menu-right,.dropdown-menu.pull-right{left:auto;right:0}.dropdown-header,.dropdown-menu>li>a{display:block;padding:3px 20px;line-height:1.42857143;white-space:nowrap}.dropdown-menu .divider{height:1px;margin:9px 0;overflow:hidden;background-color:#e5e5e5}.dropdown-menu>li>a{clear:both;font-weight:400;color:#333}.dropdown-menu>li>a:focus,.dropdown-menu>li>a:hover{text-decoration:none;color:#262626;background-color:#f5f5f5}.dropdown-menu>.active>a,.dropdown-menu>.active>a:focus,.dropdown-menu>.active>a:hover{color:#fff;text-decoration:none;outline:0;background-color:#00e5f0}.dropdown-menu>.disabled>a,.dropdown-menu>.disabled>a:focus,.dropdown-menu>.disabled>a:hover{color:#777}.dropdown-menu>.disabled>a:focus,.dropdown-menu>.disabled>a:hover{text-decoration:none;background-color:transparent;filter:progid:DXImageTransform.Microsoft.gradient(enabled=false);cursor:not-allowed}.open>.dropdown-menu{display:block}.open>a{outline:0}.dropdown-menu-left{left:0;right:auto}.dropdown-header{font-size:12px;color:#777}.dropdown-backdrop{position:fixed;left:0;right:0;bottom:0;top:0;z-index:990}.nav-justified>.dropdown .dropdown-menu,.nav-tabs.nav-justified>.dropdown .dropdown-menu{top:auto;left:auto}.pull-right>.dropdown-menu{right:0;left:auto}.dropup .caret,.navbar-fixed-bottom .dropdown .caret{border-top:0;border-bottom:4px dashed;border-bottom:4px solid\9;content:""}.dropup .dropdown-menu,.navbar-fixed-bottom .dropdown .dropdown-menu{top:auto;bottom:100%;margin-bottom:2px}@media (min-width:768px){.navbar-right .dropdown-menu{left:auto;right:0}.navbar-right .dropdown-menu-left{left:0;right:auto}}.btn-group,.btn-group-vertical{position:relative;display:inline-block;vertical-align:middle}.btn-group-vertical>.btn,.btn-group>.btn{position:relative;float:left}.btn-group-vertical>.btn.active,.btn-group-vertical>.btn:active,.btn-group-vertical>.btn:focus,.btn-group-vertical>.btn:hover,.btn-group>.btn.active,.btn-group>.btn:active,.btn-group>.btn:focus,.btn-group>.btn:hover{z-index:2}.btn-group .btn+.btn,.btn-group .btn+.btn-group,.btn-group .btn-group+.btn,.btn-group .btn-group+.btn-group{margin-left:-1px}.btn-toolbar{margin-left:-5px}.btn-toolbar>.btn,.btn-toolbar>.btn-group,.btn-toolbar>.input-group{margin-left:5px}.btn .caret,.btn-group>.btn:first-child{margin-left:0}.btn-group>.btn:not(:first-child):not(:last-child):not(.dropdown-toggle){border-radius:0}.btn-group>.btn:first-child:not(:last-child):not(.dropdown-toggle){border-bottom-right-radius:0;border-top-right-radius:0}.btn-group>.btn:last-child:not(:first-child),.btn-group>.dropdown-toggle:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0}.btn-group>.btn-group:not(:first-child):not(:last-child)>.btn{border-radius:0}.btn-group>.btn-group:first-child:not(:last-child)>.btn:last-child,.btn-group>.btn-group:first-child:not(:last-child)>.dropdown-toggle{border-bottom-right-radius:0;border-top-right-radius:0}.btn-group>.btn-group:last-child:not(:first-child)>.btn:first-child{border-bottom-left-radius:0;border-top-left-radius:0}.btn-group .dropdown-toggle:active,.btn-group.open .dropdown-toggle{outline:0}.btn-group>.btn+.dropdown-toggle{padding-left:8px;padding-right:8px}.btn-group>.btn-lg+.dropdown-toggle{padding-left:12px;padding-right:12px}.btn-group.open .dropdown-toggle{box-shadow:inset 0 3px 5px rgba(0,0,0,.125)}.btn-group.open .dropdown-toggle.btn-link{box-shadow:none}.btn-lg .caret{border-width:5px 5px 0}.dropup .btn-lg .caret{border-width:0 5px 5px}.btn-group-vertical>.btn,.btn-group-vertical>.btn-group,.btn-group-vertical>.btn-group>.btn{display:block;float:none;width:100%;max-width:100%}.btn-group-vertical>.btn-group>.btn{float:none}.btn-group-vertical>.btn+.btn,.btn-group-vertical>.btn+.btn-group,.btn-group-vertical>.btn-group+.btn,.btn-group-vertical>.btn-group+.btn-group{margin-top:-1px;margin-left:0}.btn-group-vertical>.btn:not(:first-child):not(:last-child){border-radius:0}.btn-group-vertical>.btn:first-child:not(:last-child){border-radius:4px 4px 0 0}.btn-group-vertical>.btn:last-child:not(:first-child){border-radius:0 0 4px 4px}.btn-group-vertical>.btn-group:not(:first-child):not(:last-child)>.btn{border-radius:0}.btn-group-vertical>.btn-group:first-child:not(:last-child)>.btn:last-child,.btn-group-vertical>.btn-group:first-child:not(:last-child)>.dropdown-toggle{border-bottom-right-radius:0;border-bottom-left-radius:0}.btn-group-vertical>.btn-group:last-child:not(:first-child)>.btn:first-child{border-top-right-radius:0;border-top-left-radius:0}.btn-group-justified{display:table;width:100%;table-layout:fixed;border-collapse:separate}.btn-group-justified>.btn,.btn-group-justified>.btn-group{float:none;display:table-cell;width:1%}.btn-group-justified>.btn-group .btn{width:100%}.btn-group-justified>.btn-group .dropdown-menu{left:auto}[data-toggle=buttons]>.btn input[type=checkbox],[data-toggle=buttons]>.btn input[type=radio],[data-toggle=buttons]>.btn-group>.btn input[type=checkbox],[data-toggle=buttons]>.btn-group>.btn input[type=radio]{position:absolute;clip:rect(0,0,0,0);pointer-events:none}.input-group{position:relative;display:table;border-collapse:separate}.input-group[class*=col-]{float:none;padding-left:0;padding-right:0}.input-group .form-control{position:relative;z-index:2;float:left;width:100%;margin-bottom:0}.input-group .form-control:focus{z-index:3}.input-group-lg>.form-control,.input-group-lg>.input-group-addon,.input-group-lg>.input-group-btn>.btn{height:46px;padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}select.input-group-lg>.form-control,select.input-group-lg>.input-group-addon,select.input-group-lg>.input-group-btn>.btn{height:46px;line-height:46px}select[multiple].input-group-lg>.form-control,select[multiple].input-group-lg>.input-group-addon,select[multiple].input-group-lg>.input-group-btn>.btn,textarea.input-group-lg>.form-control,textarea.input-group-lg>.input-group-addon,textarea.input-group-lg>.input-group-btn>.btn{height:auto}.input-group-sm>.form-control,.input-group-sm>.input-group-addon,.input-group-sm>.input-group-btn>.btn{height:30px;padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}select.input-group-sm>.form-control,select.input-group-sm>.input-group-addon,select.input-group-sm>.input-group-btn>.btn{height:30px;line-height:30px}select[multiple].input-group-sm>.form-control,select[multiple].input-group-sm>.input-group-addon,select[multiple].input-group-sm>.input-group-btn>.btn,textarea.input-group-sm>.form-control,textarea.input-group-sm>.input-group-addon,textarea.input-group-sm>.input-group-btn>.btn{height:auto}.input-group .form-control,.input-group-addon,.input-group-btn{display:table-cell}.nav>li,.nav>li>a{display:block;position:relative}.input-group .form-control:not(:first-child):not(:last-child),.input-group-addon:not(:first-child):not(:last-child),.input-group-btn:not(:first-child):not(:last-child){border-radius:0}.input-group-addon,.input-group-btn{width:1%;white-space:nowrap;vertical-align:middle}.input-group-addon{padding:6px 12px;font-size:14px;font-weight:400;line-height:1;color:#555;text-align:center;background-color:#eee;border:1px solid #ccc;border-radius:4px}.input-group-addon.input-sm{padding:5px 10px;font-size:12px;border-radius:3px}.input-group-addon.input-lg{padding:10px 16px;font-size:18px;border-radius:6px}.input-group-addon input[type=checkbox],.input-group-addon input[type=radio]{margin-top:0}.input-group .form-control:first-child,.input-group-addon:first-child,.input-group-btn:first-child>.btn,.input-group-btn:first-child>.btn-group>.btn,.input-group-btn:first-child>.dropdown-toggle,.input-group-btn:last-child>.btn-group:not(:last-child)>.btn,.input-group-btn:last-child>.btn:not(:last-child):not(.dropdown-toggle){border-bottom-right-radius:0;border-top-right-radius:0}.input-group-addon:first-child{border-right:0}.input-group .form-control:last-child,.input-group-addon:last-child,.input-group-btn:first-child>.btn-group:not(:first-child)>.btn,.input-group-btn:first-child>.btn:not(:first-child),.input-group-btn:last-child>.btn,.input-group-btn:last-child>.btn-group>.btn,.input-group-btn:last-child>.dropdown-toggle{border-bottom-left-radius:0;border-top-left-radius:0}.input-group-addon:last-child{border-left:0}.input-group-btn{position:relative;font-size:0;white-space:nowrap}.input-group-btn>.btn{position:relative}.input-group-btn>.btn+.btn{margin-left:-1px}.input-group-btn>.btn:active,.input-group-btn>.btn:focus,.input-group-btn>.btn:hover{z-index:2}.input-group-btn:first-child>.btn,.input-group-btn:first-child>.btn-group{margin-right:-1px}.input-group-btn:last-child>.btn,.input-group-btn:last-child>.btn-group{z-index:2;margin-left:-1px}.nav{margin-bottom:0;padding-left:0;list-style:none}.nav>li>a{padding:10px 15px}.nav>li>a:focus,.nav>li>a:hover{text-decoration:none;background-color:#eee}.nav>li.disabled>a{color:#777}.nav>li.disabled>a:focus,.nav>li.disabled>a:hover{color:#777;text-decoration:none;background-color:transparent;cursor:not-allowed}.nav .open>a,.nav .open>a:focus,.nav .open>a:hover{background-color:#eee;border-color:#00e5f0}.nav .nav-divider{height:1px;margin:9px 0;overflow:hidden;background-color:#e5e5e5}.nav>li>a>img{max-width:none}.nav-tabs{border-bottom:1px solid #ddd}.nav-tabs>li{float:left;margin-bottom:-1px}.nav-tabs>li>a{margin-right:2px;line-height:1.42857143;border:1px solid transparent;border-radius:4px 4px 0 0}.nav-tabs>li>a:hover{border-color:#eee #eee #ddd}.nav-tabs>li.active>a,.nav-tabs>li.active>a:focus,.nav-tabs>li.active>a:hover{color:#555;background-color:#fff;border:1px solid #ddd;border-bottom-color:transparent;cursor:default}.nav-tabs.nav-justified{width:100%;border-bottom:0}.nav-tabs.nav-justified>li{float:none}.nav-tabs.nav-justified>li>a{text-align:center;margin-bottom:5px;margin-right:0;border-radius:4px}.nav-tabs.nav-justified>.active>a,.nav-tabs.nav-justified>.active>a:focus,.nav-tabs.nav-justified>.active>a:hover{border:1px solid #ddd}@media (min-width:768px){.nav-tabs.nav-justified>li{display:table-cell;width:1%}.nav-tabs.nav-justified>li>a{margin-bottom:0;border-bottom:1px solid #ddd;border-radius:4px 4px 0 0}.nav-tabs.nav-justified>.active>a,.nav-tabs.nav-justified>.active>a:focus,.nav-tabs.nav-justified>.active>a:hover{border-bottom-color:#fff}}.nav-pills>li{float:left}.nav-justified>li,.nav-stacked>li{float:none}.nav-pills>li>a{border-radius:4px}.nav-pills>li+li{margin-left:2px}.nav-pills>li.active>a,.nav-pills>li.active>a:focus,.nav-pills>li.active>a:hover{color:#fff;background-color:#00e5f0}.nav-stacked>li+li{margin-top:2px;margin-left:0}.nav-justified{width:100%}.nav-justified>li>a{text-align:center;margin-bottom:5px}.nav-tabs-justified{border-bottom:0}.nav-tabs-justified>li>a{margin-right:0;border-radius:4px}.nav-tabs-justified>.active>a,.nav-tabs-justified>.active>a:focus,.nav-tabs-justified>.active>a:hover{border:1px solid #ddd}@media (min-width:768px){.nav-justified>li{display:table-cell;width:1%}.nav-justified>li>a{margin-bottom:0}.nav-tabs-justified>li>a{border-bottom:1px solid #ddd;border-radius:4px 4px 0 0}.nav-tabs-justified>.active>a,.nav-tabs-justified>.active>a:focus,.nav-tabs-justified>.active>a:hover{border-bottom-color:#fff}}.tab-content>.tab-pane{display:none}.tab-content>.active{display:block}.nav-tabs .dropdown-menu{margin-top:-1px;border-top-right-radius:0;border-top-left-radius:0}.navbar{position:relative;min-height:50px;margin-bottom:20px;border:1px solid transparent}.navbar-collapse{overflow-x:visible;padding-right:15px;padding-left:15px;border-top:1px solid transparent;box-shadow:inset 0 1px 0 rgba(255,255,255,.1);-webkit-overflow-scrolling:touch}.navbar-collapse.in{overflow-y:auto}@media (min-width:768px){.navbar{border-radius:4px}.navbar-header{float:left}.navbar-collapse{width:auto;border-top:0;box-shadow:none}.navbar-collapse.collapse{display:block!important;height:auto!important;padding-bottom:0;overflow:visible!important}.navbar-collapse.in{overflow-y:visible}.navbar-fixed-bottom .navbar-collapse,.navbar-fixed-top .navbar-collapse,.navbar-static-top .navbar-collapse{padding-left:0;padding-right:0}}.analytics pre,.carousel-inner,.embed-responsive,.media,.media-body,.modal,.modal-open,.progress{overflow:hidden}@media (max-device-width:480px) and (orientation:landscape){.navbar-fixed-bottom .navbar-collapse,.navbar-fixed-top .navbar-collapse{max-height:200px}}.container-fluid>.navbar-collapse,.container-fluid>.navbar-header,.container>.navbar-collapse,.container>.navbar-header{margin-right:-15px;margin-left:-15px}.navbar-static-top{z-index:1000;border-width:0 0 1px}.navbar-fixed-bottom,.navbar-fixed-top{position:fixed;right:0;left:0;z-index:1030}.navbar-fixed-top{top:0;border-width:0 0 1px}.navbar-fixed-bottom{bottom:0;margin-bottom:0;border-width:1px 0 0}.navbar-brand{float:left;padding:15px;font-size:18px;line-height:20px;height:50px}.navbar-brand:focus,.navbar-brand:hover{text-decoration:none}.navbar-brand>img{display:block}@media (min-width:768px){.container-fluid>.navbar-collapse,.container-fluid>.navbar-header,.container>.navbar-collapse,.container>.navbar-header{margin-right:0;margin-left:0}.navbar-fixed-bottom,.navbar-fixed-top,.navbar-static-top{border-radius:0}.navbar>.container .navbar-brand,.navbar>.container-fluid .navbar-brand{margin-left:-15px}}.navbar-toggle{position:relative;float:right;margin-right:15px;padding:9px 10px;margin-top:8px;margin-bottom:8px;background-color:transparent;border:1px solid transparent;border-radius:4px}.navbar-toggle:focus{outline:0}.navbar-toggle .icon-bar{display:block;width:22px;height:2px;border-radius:1px}.navbar-toggle .icon-bar+.icon-bar{margin-top:4px}.navbar-nav{margin:7.5px -15px}.navbar-nav>li>a{padding-top:10px;padding-bottom:10px;line-height:20px}@media (max-width:767px){.navbar-nav .open .dropdown-menu{position:static;float:none;width:auto;margin-top:0;background-color:transparent;border:0;box-shadow:none}.navbar-nav .open .dropdown-menu .dropdown-header,.navbar-nav .open .dropdown-menu>li>a{padding:5px 15px 5px 25px}.navbar-nav .open .dropdown-menu>li>a{line-height:20px}.navbar-nav .open .dropdown-menu>li>a:focus,.navbar-nav .open .dropdown-menu>li>a:hover{background-image:none}}.progress-bar-striped,.progress-striped .progress-bar,.progress-striped .progress-bar-success{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}@media (min-width:768px){.navbar-toggle{display:none}.navbar-nav{float:left;margin:0}.navbar-nav>li{float:left}.navbar-nav>li>a{padding-top:15px;padding-bottom:15px}}.navbar-form{padding:10px 15px;border-top:1px solid transparent;border-bottom:1px solid transparent;box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 1px 0 rgba(255,255,255,.1);margin:8px -15px}@media (min-width:768px){.navbar-form .form-control-static,.navbar-form .form-group{display:inline-block}.navbar-form .control-label,.navbar-form .form-group{margin-bottom:0;vertical-align:middle}.navbar-form .form-control{display:inline-block;width:auto;vertical-align:middle}.navbar-form .input-group{display:inline-table;vertical-align:middle}.navbar-form .input-group .form-control,.navbar-form .input-group .input-group-addon,.navbar-form .input-group .input-group-btn{width:auto}.navbar-form .input-group>.form-control{width:100%}.navbar-form .checkbox,.navbar-form .radio{display:inline-block;margin-top:0;margin-bottom:0;vertical-align:middle}.navbar-form .checkbox label,.navbar-form .radio label{padding-left:0}.navbar-form .checkbox input[type=checkbox],.navbar-form .radio input[type=radio]{position:relative;margin-left:0}.navbar-form .has-feedback .form-control-feedback{top:0}.navbar-form{width:auto;border:0;margin-left:0;margin-right:0;padding-top:0;padding-bottom:0;box-shadow:none}}.breadcrumb>li,.pagination{display:inline-block}.btn .badge,.btn .label{top:-1px;position:relative}@media (max-width:767px){.navbar-form .form-group{margin-bottom:5px}.navbar-form .form-group:last-child{margin-bottom:0}}.navbar-nav>li>.dropdown-menu{margin-top:0;border-top-right-radius:0;border-top-left-radius:0}.navbar-fixed-bottom .navbar-nav>li>.dropdown-menu{margin-bottom:0;border-radius:4px 4px 0 0}.navbar-btn{margin-top:8px;margin-bottom:8px}.navbar-btn.btn-sm{margin-top:10px;margin-bottom:10px}.navbar-btn.btn-xs{margin-top:14px;margin-bottom:14px}.navbar-text{margin-top:15px;margin-bottom:15px}@media (min-width:768px){.navbar-text{float:left;margin-left:15px;margin-right:15px}.navbar-left{float:left!important}.navbar-right{float:right!important;margin-right:-15px}.navbar-right~.navbar-right{margin-right:0}}.navbar-default{background-color:#f8f8f8;border-color:#e7e7e7}.navbar-default .navbar-brand{color:#777}.navbar-default .navbar-brand:focus,.navbar-default .navbar-brand:hover{color:#5e5e5e;background-color:transparent}.navbar-default .navbar-nav>li>a,.navbar-default .navbar-text{color:#777}.navbar-default .navbar-nav>li>a:focus,.navbar-default .navbar-nav>li>a:hover{color:#333;background-color:transparent}.navbar-default .navbar-nav>.active>a,.navbar-default .navbar-nav>.active>a:focus,.navbar-default .navbar-nav>.active>a:hover{color:#555;background-color:#e7e7e7}.navbar-default .navbar-nav>.disabled>a,.navbar-default .navbar-nav>.disabled>a:focus,.navbar-default .navbar-nav>.disabled>a:hover{color:#ccc;background-color:transparent}.navbar-default .navbar-toggle{border-color:#ddd}.navbar-default .navbar-toggle:focus,.navbar-default .navbar-toggle:hover{background-color:#ddd}.navbar-default .navbar-toggle .icon-bar{background-color:#888}.navbar-default .navbar-collapse,.navbar-default .navbar-form{border-color:#e7e7e7}.navbar-default .navbar-nav>.open>a,.navbar-default .navbar-nav>.open>a:focus,.navbar-default .navbar-nav>.open>a:hover{background-color:#e7e7e7;color:#555}@media (max-width:767px){.navbar-default .navbar-nav .open .dropdown-menu>li>a{color:#777}.navbar-default .navbar-nav .open .dropdown-menu>li>a:focus,.navbar-default .navbar-nav .open .dropdown-menu>li>a:hover{color:#333;background-color:transparent}.navbar-default .navbar-nav .open .dropdown-menu>.active>a,.navbar-default .navbar-nav .open .dropdown-menu>.active>a:focus,.navbar-default .navbar-nav .open .dropdown-menu>.active>a:hover{color:#555;background-color:#e7e7e7}.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a,.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a:focus,.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a:hover{color:#ccc;background-color:transparent}}.navbar-default .navbar-link{color:#777}.navbar-default .navbar-link:hover{color:#333}.navbar-default .btn-link{color:#777}.navbar-default .btn-link:focus,.navbar-default .btn-link:hover{color:#333}.navbar-default .btn-link[disabled]:focus,.navbar-default .btn-link[disabled]:hover,fieldset[disabled] .navbar-default .btn-link:focus,fieldset[disabled] .navbar-default .btn-link:hover{color:#ccc}.navbar-inverse{background-color:#222;border-color:#080808}.navbar-inverse .navbar-brand{color:#9d9d9d}.navbar-inverse .navbar-brand:focus,.navbar-inverse .navbar-brand:hover{color:#fff;background-color:transparent}.navbar-inverse .navbar-nav>li>a,.navbar-inverse .navbar-text{color:#9d9d9d}.navbar-inverse .navbar-nav>li>a:focus,.navbar-inverse .navbar-nav>li>a:hover{color:#fff;background-color:transparent}.navbar-inverse .navbar-nav>.active>a,.navbar-inverse .navbar-nav>.active>a:focus,.navbar-inverse .navbar-nav>.active>a:hover{color:#fff;background-color:#080808}.navbar-inverse .navbar-nav>.disabled>a,.navbar-inverse .navbar-nav>.disabled>a:focus,.navbar-inverse .navbar-nav>.disabled>a:hover{color:#444;background-color:transparent}.navbar-inverse .navbar-toggle{border-color:#333}.navbar-inverse .navbar-toggle:focus,.navbar-inverse .navbar-toggle:hover{background-color:#333}.navbar-inverse .navbar-toggle .icon-bar{background-color:#fff}.navbar-inverse .navbar-collapse,.navbar-inverse .navbar-form{border-color:#101010}.navbar-inverse .navbar-nav>.open>a,.navbar-inverse .navbar-nav>.open>a:focus,.navbar-inverse .navbar-nav>.open>a:hover{background-color:#080808;color:#fff}@media (max-width:767px){.navbar-inverse .navbar-nav .open .dropdown-menu>.dropdown-header{border-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu .divider{background-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu>li>a{color:#9d9d9d}.navbar-inverse .navbar-nav .open .dropdown-menu>li>a:focus,.navbar-inverse .navbar-nav .open .dropdown-menu>li>a:hover{color:#fff;background-color:transparent}.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a,.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a:focus,.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a:hover{color:#fff;background-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a,.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a:focus,.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a:hover{color:#444;background-color:transparent}}.navbar-inverse .navbar-link{color:#9d9d9d}.navbar-inverse .navbar-link:hover{color:#fff}.navbar-inverse .btn-link{color:#9d9d9d}.navbar-inverse .btn-link:focus,.navbar-inverse .btn-link:hover{color:#fff}.navbar-inverse .btn-link[disabled]:focus,.navbar-inverse .btn-link[disabled]:hover,fieldset[disabled] .navbar-inverse .btn-link:focus,fieldset[disabled] .navbar-inverse .btn-link:hover{color:#444}.breadcrumb{padding:8px 15px;margin-bottom:20px;list-style:none;background-color:#f5f5f5;border-radius:4px}.breadcrumb>li+li:before{content:"/\00a0";padding:0 5px;color:#ccc}.breadcrumb>.active{color:#777}.pagination{padding-left:0;margin:20px 0;border-radius:4px}.pager li,.pagination>li{display:inline}.pagination>li>a,.pagination>li>span{position:relative;float:left;padding:6px 12px;line-height:1.42857143;text-decoration:none;color:#00e5f0;background-color:#fff;border:1px solid #ddd;margin-left:-1px}.pagination>li:first-child>a,.pagination>li:first-child>span{margin-left:0;border-bottom-left-radius:4px;border-top-left-radius:4px}.pagination>li:last-child>a,.pagination>li:last-child>span{border-bottom-right-radius:4px;border-top-right-radius:4px}.pagination>li>a:focus,.pagination>li>a:hover,.pagination>li>span:focus,.pagination>li>span:hover{z-index:2;color:#009ca3;background-color:#eee;border-color:#ddd}.pagination>.active>a,.pagination>.active>a:focus,.pagination>.active>a:hover,.pagination>.active>span,.pagination>.active>span:focus,.pagination>.active>span:hover{z-index:3;color:#fff;background-color:#00e5f0;border-color:#00e5f0;cursor:default}.pagination>.disabled>a,.pagination>.disabled>a:focus,.pagination>.disabled>a:hover,.pagination>.disabled>span,.pagination>.disabled>span:focus,.pagination>.disabled>span:hover{color:#777;background-color:#fff;border-color:#ddd;cursor:not-allowed}.pagination-lg>li>a,.pagination-lg>li>span{padding:10px 16px;font-size:18px;line-height:1.3333333}.pagination-lg>li:first-child>a,.pagination-lg>li:first-child>span{border-bottom-left-radius:6px;border-top-left-radius:6px}.pagination-lg>li:last-child>a,.pagination-lg>li:last-child>span{border-bottom-right-radius:6px;border-top-right-radius:6px}.pagination-sm>li>a,.pagination-sm>li>span{padding:5px 10px;font-size:12px;line-height:1.5}.badge,.label{font-weight:700;line-height:1;white-space:nowrap;text-align:center}.pagination-sm>li:first-child>a,.pagination-sm>li:first-child>span{border-bottom-left-radius:3px;border-top-left-radius:3px}.pagination-sm>li:last-child>a,.pagination-sm>li:last-child>span{border-bottom-right-radius:3px;border-top-right-radius:3px}.pager{padding-left:0;margin:20px 0;list-style:none;text-align:center}.pager li>a,.pager li>span{display:inline-block;padding:5px 14px;background-color:#fff;border:1px solid #ddd;border-radius:15px}.pager li>a:focus,.pager li>a:hover{text-decoration:none;background-color:#eee}.pager .next>a,.pager .next>span{float:right}.pager .previous>a,.pager .previous>span{float:left}.pager .disabled>a,.pager .disabled>a:focus,.pager .disabled>a:hover,.pager .disabled>span{color:#777;background-color:#fff;cursor:not-allowed}a.badge:focus,a.badge:hover,a.label:focus,a.label:hover{color:#fff;cursor:pointer;text-decoration:none}.label{display:inline;padding:.2em .6em .3em;font-size:75%;color:#fff;border-radius:.25em}.label:empty{display:none}.label-default{background-color:#777}.label-default[href]:focus,.label-default[href]:hover{background-color:#5e5e5e}.label-primary{background-color:#00e5f0}.label-primary[href]:focus,.label-primary[href]:hover{background-color:#00b4bd}.label-success{background-color:#00e5f0}.label-success[href]:focus,.label-success[href]:hover{background-color:#00b4bd}.label-info{background-color:#00e5f0}.label-info[href]:focus,.label-info[href]:hover{background-color:#00b4bd}.label-warning{background-color:#977bf0}.label-warning[href]:focus,.label-warning[href]:hover{background-color:#734deb}.label-danger{background-color:#e01f74}.label-danger[href]:focus,.label-danger[href]:hover{background-color:#b3195d}.badge{display:inline-block;min-width:10px;padding:3px 7px;font-size:12px;color:#fff;vertical-align:middle;background-color:#777;border-radius:10px}.badge:empty{display:none}.media-object,.thumbnail{display:block}.btn-group-xs>.btn .badge,.btn-xs .badge{top:0;padding:1px 5px}.list-group-item.active>.badge,.nav-pills>.active>a>.badge{color:#00e5f0;background-color:#fff}.jumbotron,.jumbotron .h1,.jumbotron h1{color:inherit}.list-group-item>.badge{float:right}.list-group-item>.badge+.badge{margin-right:5px}.nav-pills>li>a>.badge{margin-left:3px}.jumbotron{padding-top:30px;padding-bottom:30px;margin-bottom:30px;background-color:#eee}.jumbotron p{margin-bottom:15px;font-size:21px;font-weight:200}.alert,.thumbnail{margin-bottom:20px}.alert .alert-link,.close{font-weight:700}.jumbotron>hr{border-top-color:#d5d5d5}.container .jumbotron,.container-fluid .jumbotron{border-radius:6px;padding-left:15px;padding-right:15px}.jumbotron .container{max-width:100%}@media screen and (min-width:768px){.jumbotron{padding-top:48px;padding-bottom:48px}.container .jumbotron,.container-fluid .jumbotron{padding-left:60px;padding-right:60px}.jumbotron .h1,.jumbotron h1{font-size:63px}}.thumbnail{padding:4px;line-height:1.42857143;background-color:#fff;border:1px solid #ddd;border-radius:4px;-webkit-transition:border .2s ease-in-out;transition:border .2s ease-in-out}.thumbnail a>img,.thumbnail>img{margin-left:auto;margin-right:auto}a.thumbnail.active,a.thumbnail:focus,a.thumbnail:hover{border-color:#00e5f0}.thumbnail .caption{padding:9px;color:#333}.alert{padding:15px;border:1px solid transparent;border-radius:4px}.alert h4{margin-top:0;color:inherit}.alert>p,.alert>ul{margin-bottom:0}.alert>p+p{margin-top:5px}.alert-dismissable,.alert-dismissible{padding-right:35px}.alert-dismissable .close,.alert-dismissible .close{position:relative;top:-2px;right:-21px;color:inherit}.modal,.modal-backdrop{top:0;right:0;bottom:0;left:0}.alert-success{background-color:#dff0d8;border-color:#d6e9c6;color:#3c763d}.alert-success hr{border-top-color:#c9e2b3}.alert-success .alert-link{color:#2b542c}.alert-info{background-color:#d9edf7;border-color:#bce8f1;color:#31708f}.alert-info hr{border-top-color:#a6e1ec}.alert-info .alert-link{color:#245269}.alert-warning{background-color:#fcf8e3;border-color:#faebcc;color:#8a6d3b}.alert-warning hr{border-top-color:#f7e1b5}.alert-warning .alert-link{color:#66512c}.alert-danger{background-color:#f2dede;border-color:#ebccd1;color:#a94442}.alert-danger hr{border-top-color:#e4b9c0}.alert-danger .alert-link{color:#843534}@-webkit-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}.progress{height:20px;margin-bottom:20px;background-color:#f5f5f5;border-radius:4px;box-shadow:inset 0 1px 2px rgba(0,0,0,.1)}.progress-bar,.progress-bar-info,.progress-bar-success{background-color:#00e5f0}.progress-bar{float:left;width:0%;height:100%;font-size:12px;line-height:20px;color:#fff;text-align:center;box-shadow:inset 0 -1px 0 rgba(0,0,0,.15);-webkit-transition:width .6s ease;transition:width .6s ease}.progress-bar-striped,.progress-striped .progress-bar{background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-size:40px 40px}.progress-bar.active,.progress.active .progress-bar{-webkit-animation:progress-bar-stripes 2s linear infinite;animation:progress-bar-stripes 2s linear infinite}.progress-striped .progress-bar-success{background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-striped .progress-bar-info,.progress-striped .progress-bar-warning{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-striped .progress-bar-info{background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-bar-warning{background-color:#977bf0}.progress-striped .progress-bar-warning{background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-bar-danger{background-color:#e01f74}.progress-striped .progress-bar-danger{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.media{margin-top:15px}.media:first-child{margin-top:0}.media,.media-body{zoom:1}.media-body{width:10000px}.media-object.img-thumbnail{max-width:none}.media-right,.media>.pull-right{padding-left:10px}.media-left,.media>.pull-left{padding-right:10px}.media-body,.media-left,.media-right{display:table-cell;vertical-align:top}.media-middle{vertical-align:middle}.media-bottom{vertical-align:bottom}.media-heading{margin-top:0;margin-bottom:5px}.media-list{padding-left:0;list-style:none}.list-group{margin-bottom:20px;padding-left:0}.list-group-item{position:relative;display:block;padding:10px 15px;margin-bottom:-1px;background-color:#fff;border:1px solid #ddd}.list-group-item:first-child{border-top-right-radius:4px;border-top-left-radius:4px}.list-group-item:last-child{margin-bottom:0;border-bottom-right-radius:4px;border-bottom-left-radius:4px}a.list-group-item,button.list-group-item{color:#555}a.list-group-item .list-group-item-heading,button.list-group-item .list-group-item-heading{color:#333}a.list-group-item:focus,a.list-group-item:hover,button.list-group-item:focus,button.list-group-item:hover{text-decoration:none;color:#555;background-color:#f5f5f5}button.list-group-item{width:100%;text-align:left}.list-group-item.disabled,.list-group-item.disabled:focus,.list-group-item.disabled:hover{background-color:#eee;color:#777;cursor:not-allowed}.list-group-item.disabled .list-group-item-heading,.list-group-item.disabled:focus .list-group-item-heading,.list-group-item.disabled:hover .list-group-item-heading{color:inherit}.list-group-item.disabled .list-group-item-text,.list-group-item.disabled:focus .list-group-item-text,.list-group-item.disabled:hover .list-group-item-text{color:#777}.list-group-item.active,.list-group-item.active:focus,.list-group-item.active:hover{z-index:2;color:#fff;background-color:#00e5f0;border-color:#00e5f0}.list-group-item.active .list-group-item-heading,.list-group-item.active .list-group-item-heading>.small,.list-group-item.active .list-group-item-heading>small,.list-group-item.active:focus .list-group-item-heading,.list-group-item.active:focus .list-group-item-heading>.small,.list-group-item.active:focus .list-group-item-heading>small,.list-group-item.active:hover .list-group-item-heading,.list-group-item.active:hover .list-group-item-heading>.small,.list-group-item.active:hover .list-group-item-heading>small{color:inherit}.list-group-item.active .list-group-item-text,.list-group-item.active:focus .list-group-item-text,.list-group-item.active:hover .list-group-item-text{color:#bdfcff}.list-group-item-success{color:#3c763d;background-color:#dff0d8}a.list-group-item-success,button.list-group-item-success{color:#3c763d}a.list-group-item-success .list-group-item-heading,button.list-group-item-success .list-group-item-heading{color:inherit}a.list-group-item-success:focus,a.list-group-item-success:hover,button.list-group-item-success:focus,button.list-group-item-success:hover{color:#3c763d;background-color:#d0e9c6}a.list-group-item-success.active,a.list-group-item-success.active:focus,a.list-group-item-success.active:hover,button.list-group-item-success.active,button.list-group-item-success.active:focus,button.list-group-item-success.active:hover{color:#fff;background-color:#3c763d;border-color:#3c763d}.list-group-item-info{color:#31708f;background-color:#d9edf7}a.list-group-item-info,button.list-group-item-info{color:#31708f}a.list-group-item-info .list-group-item-heading,button.list-group-item-info .list-group-item-heading{color:inherit}a.list-group-item-info:focus,a.list-group-item-info:hover,button.list-group-item-info:focus,button.list-group-item-info:hover{color:#31708f;background-color:#c4e3f3}a.list-group-item-info.active,a.list-group-item-info.active:focus,a.list-group-item-info.active:hover,button.list-group-item-info.active,button.list-group-item-info.active:focus,button.list-group-item-info.active:hover{color:#fff;background-color:#31708f;border-color:#31708f}.list-group-item-warning{color:#8a6d3b;background-color:#fcf8e3}a.list-group-item-warning,button.list-group-item-warning{color:#8a6d3b}a.list-group-item-warning .list-group-item-heading,button.list-group-item-warning .list-group-item-heading{color:inherit}a.list-group-item-warning:focus,a.list-group-item-warning:hover,button.list-group-item-warning:focus,button.list-group-item-warning:hover{color:#8a6d3b;background-color:#faf2cc}a.list-group-item-warning.active,a.list-group-item-warning.active:focus,a.list-group-item-warning.active:hover,button.list-group-item-warning.active,button.list-group-item-warning.active:focus,button.list-group-item-warning.active:hover{color:#fff;background-color:#8a6d3b;border-color:#8a6d3b}.list-group-item-danger{color:#a94442;background-color:#f2dede}a.list-group-item-danger,button.list-group-item-danger{color:#a94442}a.list-group-item-danger .list-group-item-heading,button.list-group-item-danger .list-group-item-heading{color:inherit}a.list-group-item-danger:focus,a.list-group-item-danger:hover,button.list-group-item-danger:focus,button.list-group-item-danger:hover{color:#a94442;background-color:#ebcccc}a.list-group-item-danger.active,a.list-group-item-danger.active:focus,a.list-group-item-danger.active:hover,button.list-group-item-danger.active,button.list-group-item-danger.active:focus,button.list-group-item-danger.active:hover{color:#fff;background-color:#a94442;border-color:#a94442}.panel-heading>.dropdown .dropdown-toggle,.panel-title,.panel-title>.small,.panel-title>.small>a,.panel-title>a,.panel-title>small,.panel-title>small>a{color:inherit}.list-group-item-heading{margin-top:0;margin-bottom:5px}.list-group-item-text{margin-bottom:0;line-height:1.3}.panel{margin-bottom:20px;background-color:#fff;border:1px solid transparent;border-radius:4px;box-shadow:0 1px 1px rgba(0,0,0,.05)}.panel-title,.panel>.list-group,.panel>.panel-collapse>.list-group,.panel>.panel-collapse>.table,.panel>.table,.panel>.table-responsive>.table{margin-bottom:0}.panel-body{padding:15px}.panel-heading{padding:10px 15px;border-bottom:1px solid transparent;border-top-right-radius:3px;border-top-left-radius:3px}.panel-title{margin-top:0;font-size:16px}.panel-footer{padding:10px 15px;background-color:#f5f5f5;border-top:1px solid #ddd;border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.list-group .list-group-item,.panel>.panel-collapse>.list-group .list-group-item{border-width:1px 0;border-radius:0}.panel-group .panel-heading,.panel>.table-bordered>tbody>tr:first-child>td,.panel>.table-bordered>tbody>tr:first-child>th,.panel>.table-bordered>thead>tr:first-child>td,.panel>.table-bordered>thead>tr:first-child>th,.panel>.table-responsive>.table-bordered>tbody>tr:first-child>td,.panel>.table-responsive>.table-bordered>tbody>tr:first-child>th,.panel>.table-responsive>.table-bordered>thead>tr:first-child>td,.panel>.table-responsive>.table-bordered>thead>tr:first-child>th{border-bottom:0}.panel>.list-group:first-child .list-group-item:first-child,.panel>.panel-collapse>.list-group:first-child .list-group-item:first-child{border-top:0;border-top-right-radius:3px;border-top-left-radius:3px}.panel>.list-group:last-child .list-group-item:last-child,.panel>.panel-collapse>.list-group:last-child .list-group-item:last-child{border-bottom:0;border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.panel-heading+.panel-collapse>.list-group .list-group-item:first-child{border-top-right-radius:0;border-top-left-radius:0}.panel>.table-responsive:first-child>.table:first-child,.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child,.panel>.table:first-child,.panel>.table:first-child>tbody:first-child>tr:first-child,.panel>.table:first-child>thead:first-child>tr:first-child{border-top-right-radius:3px;border-top-left-radius:3px}.list-group+.panel-footer,.panel-heading+.list-group .list-group-item:first-child{border-top-width:0}.panel>.panel-collapse>.table caption,.panel>.table caption,.panel>.table-responsive>.table caption{padding-left:15px;padding-right:15px}.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child td:first-child,.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child th:first-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child td:first-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child th:first-child,.panel>.table:first-child>tbody:first-child>tr:first-child td:first-child,.panel>.table:first-child>tbody:first-child>tr:first-child th:first-child,.panel>.table:first-child>thead:first-child>tr:first-child td:first-child,.panel>.table:first-child>thead:first-child>tr:first-child th:first-child{border-top-left-radius:3px}.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child td:last-child,.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child th:last-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child td:last-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child th:last-child,.panel>.table:first-child>tbody:first-child>tr:first-child td:last-child,.panel>.table:first-child>tbody:first-child>tr:first-child th:last-child,.panel>.table:first-child>thead:first-child>tr:first-child td:last-child,.panel>.table:first-child>thead:first-child>tr:first-child th:last-child{border-top-right-radius:3px}.panel>.table-responsive:last-child>.table:last-child,.panel>.table:last-child{border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child,.panel>.table:last-child>tbody:last-child>tr:last-child,.panel>.table:last-child>tfoot:last-child>tr:last-child{border-bottom-left-radius:3px;border-bottom-right-radius:3px}.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child td:first-child,.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child th:first-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child td:first-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child th:first-child,.panel>.table:last-child>tbody:last-child>tr:last-child td:first-child,.panel>.table:last-child>tbody:last-child>tr:last-child th:first-child,.panel>.table:last-child>tfoot:last-child>tr:last-child td:first-child,.panel>.table:last-child>tfoot:last-child>tr:last-child th:first-child{border-bottom-left-radius:3px}.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child td:last-child,.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child th:last-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child td:last-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child th:last-child,.panel>.table:last-child>tbody:last-child>tr:last-child td:last-child,.panel>.table:last-child>tbody:last-child>tr:last-child th:last-child,.panel>.table:last-child>tfoot:last-child>tr:last-child td:last-child,.panel>.table:last-child>tfoot:last-child>tr:last-child th:last-child{border-bottom-right-radius:3px}.panel>.panel-body+.table,.panel>.panel-body+.table-responsive,.panel>.table+.panel-body,.panel>.table-responsive+.panel-body{border-top:1px solid #ddd}.panel>.table>tbody:first-child>tr:first-child td,.panel>.table>tbody:first-child>tr:first-child th{border-top:0}.panel>.table-bordered,.panel>.table-responsive>.table-bordered{border:0}.panel>.table-bordered>tbody>tr>td:first-child,.panel>.table-bordered>tbody>tr>th:first-child,.panel>.table-bordered>tfoot>tr>td:first-child,.panel>.table-bordered>tfoot>tr>th:first-child,.panel>.table-bordered>thead>tr>td:first-child,.panel>.table-bordered>thead>tr>th:first-child,.panel>.table-responsive>.table-bordered>tbody>tr>td:first-child,.panel>.table-responsive>.table-bordered>tbody>tr>th:first-child,.panel>.table-responsive>.table-bordered>tfoot>tr>td:first-child,.panel>.table-responsive>.table-bordered>tfoot>tr>th:first-child,.panel>.table-responsive>.table-bordered>thead>tr>td:first-child,.panel>.table-responsive>.table-bordered>thead>tr>th:first-child{border-left:0}.panel>.table-bordered>tbody>tr>td:last-child,.panel>.table-bordered>tbody>tr>th:last-child,.panel>.table-bordered>tfoot>tr>td:last-child,.panel>.table-bordered>tfoot>tr>th:last-child,.panel>.table-bordered>thead>tr>td:last-child,.panel>.table-bordered>thead>tr>th:last-child,.panel>.table-responsive>.table-bordered>tbody>tr>td:last-child,.panel>.table-responsive>.table-bordered>tbody>tr>th:last-child,.panel>.table-responsive>.table-bordered>tfoot>tr>td:last-child,.panel>.table-responsive>.table-bordered>tfoot>tr>th:last-child,.panel>.table-responsive>.table-bordered>thead>tr>td:last-child,.panel>.table-responsive>.table-bordered>thead>tr>th:last-child{border-right:0}.panel>.table-bordered>tbody>tr:last-child>td,.panel>.table-bordered>tbody>tr:last-child>th,.panel>.table-bordered>tfoot>tr:last-child>td,.panel>.table-bordered>tfoot>tr:last-child>th,.panel>.table-responsive>.table-bordered>tbody>tr:last-child>td,.panel>.table-responsive>.table-bordered>tbody>tr:last-child>th,.panel>.table-responsive>.table-bordered>tfoot>tr:last-child>td,.panel>.table-responsive>.table-bordered>tfoot>tr:last-child>th{border-bottom:0}.panel>.table-responsive{border:0;margin-bottom:0}.panel-group{margin-bottom:20px}.panel-group .panel{margin-bottom:0;border-radius:4px}.panel-group .panel+.panel{margin-top:5px}.panel-group .panel-heading+.panel-collapse>.list-group,.panel-group .panel-heading+.panel-collapse>.panel-body{border-top:1px solid #ddd}.panel-group .panel-footer{border-top:0}.panel-group .panel-footer+.panel-collapse .panel-body{border-bottom:1px solid #ddd}.panel-default{border-color:#ddd}.panel-default>.panel-heading{color:#333;background-color:#f5f5f5;border-color:#ddd}.panel-default>.panel-heading+.panel-collapse>.panel-body{border-top-color:#ddd}.panel-default>.panel-heading .badge{color:#f5f5f5;background-color:#333}.panel-default>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#ddd}.panel-primary{border-color:#00e5f0}.panel-primary>.panel-heading{color:#fff;background-color:#00e5f0;border-color:#00e5f0}.panel-primary>.panel-heading+.panel-collapse>.panel-body{border-top-color:#00e5f0}.panel-primary>.panel-heading .badge{color:#00e5f0;background-color:#fff}.panel-primary>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#00e5f0}.panel-success{border-color:#d6e9c6}.panel-success>.panel-heading{color:#3c763d;background-color:#dff0d8;border-color:#d6e9c6}.panel-success>.panel-heading+.panel-collapse>.panel-body{border-top-color:#d6e9c6}.panel-success>.panel-heading .badge{color:#dff0d8;background-color:#3c763d}.panel-success>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#d6e9c6}.panel-info{border-color:#bce8f1}.panel-info>.panel-heading{color:#31708f;background-color:#d9edf7;border-color:#bce8f1}.panel-info>.panel-heading+.panel-collapse>.panel-body{border-top-color:#bce8f1}.panel-info>.panel-heading .badge{color:#d9edf7;background-color:#31708f}.panel-info>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#bce8f1}.panel-warning{border-color:#faebcc}.panel-warning>.panel-heading{color:#8a6d3b;background-color:#fcf8e3;border-color:#faebcc}.panel-warning>.panel-heading+.panel-collapse>.panel-body{border-top-color:#faebcc}.panel-warning>.panel-heading .badge{color:#fcf8e3;background-color:#8a6d3b}.panel-warning>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#faebcc}.panel-danger{border-color:#ebccd1}.panel-danger>.panel-heading{color:#a94442;background-color:#f2dede;border-color:#ebccd1}.panel-danger>.panel-heading+.panel-collapse>.panel-body{border-top-color:#ebccd1}.panel-danger>.panel-heading .badge{color:#f2dede;background-color:#a94442}.panel-danger>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#ebccd1}.embed-responsive{position:relative;display:block;height:0;padding:0}.embed-responsive .embed-responsive-item,.embed-responsive embed,.embed-responsive iframe,.embed-responsive object,.embed-responsive video{position:absolute;top:0;left:0;bottom:0;height:100%;width:100%;border:0}.embed-responsive-16by9{padding-bottom:56.25%}.embed-responsive-4by3{padding-bottom:75%}.well{min-height:20px;padding:19px;margin-bottom:20px;background-color:#f5f5f5;border:1px solid #e3e3e3;border-radius:4px;box-shadow:inset 0 1px 1px rgba(0,0,0,.05)}.well blockquote{border-color:#ddd;border-color:rgba(0,0,0,.15)}.well-lg{padding:24px;border-radius:6px}.well-sm{padding:9px;border-radius:3px}.close{float:right;font-size:21px;line-height:1;color:#000;text-shadow:0 1px 0 #fff;opacity:.2;filter:alpha(opacity=20)}.popover,.tooltip{font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-style:normal;font-weight:400;letter-spacing:normal;line-break:auto;line-height:1.42857143;text-shadow:none;text-transform:none;white-space:normal;word-break:normal;word-spacing:normal;word-wrap:normal;text-decoration:none}.close:focus,.close:hover{color:#000;text-decoration:none;cursor:pointer;opacity:.5;filter:alpha(opacity=50)}button.close{padding:0;cursor:pointer;background:0 0;border:0;-webkit-appearance:none}.modal-content,.popover{background-clip:padding-box}.modal{display:none;position:fixed;z-index:1050;-webkit-overflow-scrolling:touch;outline:0}.modal.fade .modal-dialog{-webkit-transform:translate(0,-25%);transform:translate(0,-25%);-webkit-transition:-webkit-transform .3s ease-out;transition:-webkit-transform .3s ease-out;transition:transform .3s ease-out;transition:transform .3s ease-out,-webkit-transform .3s ease-out}.modal.in .modal-dialog{-webkit-transform:translate(0,0);transform:translate(0,0)}.modal-open .modal{overflow-x:hidden;overflow-y:auto}.modal-dialog{position:relative;width:auto;margin:10px}.modal-content{position:relative;background-color:#fff;border:1px solid #999;border:1px solid rgba(0,0,0,.2);border-radius:6px;box-shadow:0 3px 9px rgba(0,0,0,.5);outline:0}.modal-backdrop{position:fixed;z-index:1040;background-color:#000}.modal-backdrop.fade{opacity:0;filter:alpha(opacity=0)}.modal-backdrop.in{opacity:.5;filter:alpha(opacity=50)}.modal-header{padding:15px;border-bottom:1px solid #e5e5e5}.modal-header .close{margin-top:-2px}.modal-title{margin:0;line-height:1.42857143}.modal-body{position:relative;padding:15px}.modal-footer{padding:15px;text-align:right;border-top:1px solid #e5e5e5}.modal-footer .btn+.btn{margin-left:5px;margin-bottom:0}.modal-footer .btn-group .btn+.btn{margin-left:-1px}.modal-footer .btn-block+.btn-block{margin-left:0}.modal-scrollbar-measure{position:absolute;top:-9999px;width:50px;height:50px;overflow:scroll}@media (min-width:768px){.modal-dialog{width:600px;margin:30px auto}.modal-content{box-shadow:0 5px 15px rgba(0,0,0,.5)}.modal-sm{width:300px}}@media (min-width:992px){.modal-lg{width:900px}}.tooltip{position:absolute;z-index:1070;display:block;text-align:left;text-align:start;font-size:12px;opacity:0;filter:alpha(opacity=0)}.tooltip.in{opacity:.9;filter:alpha(opacity=90)}.tooltip.top{margin-top:-3px;padding:5px 0}.tooltip.right{margin-left:3px;padding:0 5px}.tooltip.bottom{margin-top:3px;padding:5px 0}.tooltip.left{margin-left:-3px;padding:0 5px}.tooltip-inner{max-width:200px;padding:3px 8px;color:#fff;text-align:center;background-color:#000;border-radius:4px}.tooltip-arrow{position:absolute;width:0;height:0;border-color:transparent;border-style:solid}.tooltip.top .tooltip-arrow,.tooltip.top-left .tooltip-arrow,.tooltip.top-right .tooltip-arrow{bottom:0;border-width:5px 5px 0;border-top-color:#000}.tooltip.top .tooltip-arrow{left:50%;margin-left:-5px}.tooltip.top-left .tooltip-arrow{right:5px;margin-bottom:-5px}.tooltip.top-right .tooltip-arrow{left:5px;margin-bottom:-5px}.tooltip.right .tooltip-arrow{top:50%;left:0;margin-top:-5px;border-width:5px 5px 5px 0;border-right-color:#000}.tooltip.left .tooltip-arrow{top:50%;right:0;margin-top:-5px;border-width:5px 0 5px 5px;border-left-color:#000}.tooltip.bottom .tooltip-arrow,.tooltip.bottom-left .tooltip-arrow,.tooltip.bottom-right .tooltip-arrow{border-width:0 5px 5px;border-bottom-color:#000;top:0}.tooltip.bottom .tooltip-arrow{left:50%;margin-left:-5px}.tooltip.bottom-left .tooltip-arrow{right:5px;margin-top:-5px}.tooltip.bottom-right .tooltip-arrow{left:5px;margin-top:-5px}.popover{position:absolute;top:0;left:0;z-index:1060;display:none;max-width:276px;padding:1px;text-align:left;text-align:start;font-size:14px;background-color:#fff;border:1px solid #ccc;border:1px solid rgba(0,0,0,.2);border-radius:6px;box-shadow:0 5px 10px rgba(0,0,0,.2)}.carousel-caption,.carousel-control{color:#fff;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,.6)}.popover.top{margin-top:-10px}.popover.right{margin-left:10px}.popover.bottom{margin-top:10px}.popover.left{margin-left:-10px}.popover-title{margin:0;padding:8px 14px;font-size:14px;background-color:#f7f7f7;border-bottom:1px solid #ebebeb;border-radius:5px 5px 0 0}.popover-content{padding:9px 14px}.popover>.arrow,.popover>.arrow:after{position:absolute;display:block;width:0;height:0;border-color:transparent;border-style:solid}.carousel,.carousel-inner{position:relative}.popover>.arrow{border-width:11px}.popover>.arrow:after{border-width:10px;content:""}.popover.top>.arrow{left:50%;margin-left:-11px;border-bottom-width:0;border-top-color:#999;border-top-color:rgba(0,0,0,.25);bottom:-11px}.popover.top>.arrow:after{content:" ";bottom:1px;margin-left:-10px;border-bottom-width:0;border-top-color:#fff}.popover.left>.arrow:after,.popover.right>.arrow:after{content:" ";bottom:-10px}.popover.right>.arrow{top:50%;left:-11px;margin-top:-11px;border-left-width:0;border-right-color:#999;border-right-color:rgba(0,0,0,.25)}.popover.right>.arrow:after{left:1px;border-left-width:0;border-right-color:#fff}.popover.bottom>.arrow{left:50%;margin-left:-11px;border-top-width:0;border-bottom-color:#999;border-bottom-color:rgba(0,0,0,.25);top:-11px}.popover.bottom>.arrow:after{content:" ";top:1px;margin-left:-10px;border-top-width:0;border-bottom-color:#fff}.popover.left>.arrow{top:50%;right:-11px;margin-top:-11px;border-right-width:0;border-left-color:#999;border-left-color:rgba(0,0,0,.25)}.popover.left>.arrow:after{right:1px;border-right-width:0;border-left-color:#fff}.carousel-inner{width:100%}.carousel-inner>.item{display:none;position:relative;-webkit-transition:.6s ease-in-out left;transition:.6s ease-in-out left}.carousel-inner>.item>a>img,.carousel-inner>.item>img{line-height:1}@media all and (transform-3d),(-webkit-transform-3d){.carousel-inner>.item{-webkit-transition:-webkit-transform .6s ease-in-out;transition:-webkit-transform .6s ease-in-out;transition:transform .6s ease-in-out;transition:transform .6s ease-in-out,-webkit-transform .6s ease-in-out;-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-perspective:1000px;perspective:1000px}.carousel-inner>.item.active.right,.carousel-inner>.item.next{-webkit-transform:translate3d(100%,0,0);transform:translate3d(100%,0,0);left:0}.carousel-inner>.item.active.left,.carousel-inner>.item.prev{-webkit-transform:translate3d(-100%,0,0);transform:translate3d(-100%,0,0);left:0}.carousel-inner>.item.active,.carousel-inner>.item.next.left,.carousel-inner>.item.prev.right{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0);left:0}}.carousel-inner>.active,.carousel-inner>.next,.carousel-inner>.prev{display:block}.carousel-inner>.active{left:0}.carousel-inner>.next,.carousel-inner>.prev{position:absolute;top:0;width:100%}.carousel-inner>.next{left:100%}.carousel-inner>.prev{left:-100%}.carousel-inner>.next.left,.carousel-inner>.prev.right{left:0}.carousel-inner>.active.left{left:-100%}.carousel-inner>.active.right{left:100%}.carousel-control{position:absolute;top:0;left:0;bottom:0;width:15%;opacity:.5;filter:alpha(opacity=50);font-size:20px;background-color:rgba(0,0,0,0)}.carousel-control.left{background-image:-webkit-linear-gradient(left,rgba(0,0,0,.5) 0,rgba(0,0,0,.0001) 100%);background-image:linear-gradient(to right,rgba(0,0,0,.5) 0,rgba(0,0,0,.0001) 100%);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#80000000', endColorstr='#00000000', GradientType=1)}.carousel-control.right{left:auto;right:0;background-image:-webkit-linear-gradient(left,rgba(0,0,0,.0001) 0,rgba(0,0,0,.5) 100%);background-image:linear-gradient(to right,rgba(0,0,0,.0001) 0,rgba(0,0,0,.5) 100%);background-repeat:repeat-x;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000', endColorstr='#80000000', GradientType=1)}.carousel-control:focus,.carousel-control:hover{outline:0;color:#fff;text-decoration:none;opacity:.9;filter:alpha(opacity=90)}.carousel-control .glyphicon-chevron-left,.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next,.carousel-control .icon-prev{position:absolute;top:50%;margin-top:-10px;z-index:5;display:inline-block}.carousel-control .glyphicon-chevron-left,.carousel-control .icon-prev{left:50%;margin-left:-10px}.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next{right:50%;margin-right:-10px}.carousel-control .icon-next,.carousel-control .icon-prev{width:20px;height:20px;line-height:1;font-family:serif}.carousel-control .icon-prev:before{content:'\2039'}.carousel-control .icon-next:before{content:'\203a'}.carousel-indicators{position:absolute;bottom:10px;left:50%;z-index:15;width:60%;margin-left:-30%;padding-left:0;list-style:none;text-align:center}.carousel-indicators li{display:inline-block;width:10px;height:10px;margin:1px;text-indent:-999px;border:1px solid #fff;border-radius:10px;cursor:pointer;background-color:#000\9;background-color:rgba(0,0,0,0)}.carousel-indicators .active{margin:0;width:12px;height:12px;background-color:#fff}.carousel-caption{position:absolute;left:15%;right:15%;bottom:20px;z-index:10;padding-top:20px;padding-bottom:20px}.carousel-caption .btn,.text-hide{text-shadow:none}@media screen and (min-width:768px){.carousel-control .glyphicon-chevron-left,.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next,.carousel-control .icon-prev{width:30px;height:30px;margin-top:-10px;font-size:30px}.carousel-control .glyphicon-chevron-left,.carousel-control .icon-prev{margin-left:-10px}.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next{margin-right:-10px}.carousel-caption{left:20%;right:20%;padding-bottom:30px}.carousel-indicators{bottom:20px}}.btn-group-vertical>.btn-group:after,.btn-group-vertical>.btn-group:before,.btn-toolbar:after,.btn-toolbar:before,.clearfix:after,.clearfix:before,.container-fluid:after,.container-fluid:before,.container:after,.container:before,.dl-horizontal dd:after,.dl-horizontal dd:before,.form-horizontal .form-group:after,.form-horizontal .form-group:before,.modal-footer:after,.modal-footer:before,.modal-header:after,.modal-header:before,.nav:after,.nav:before,.navbar-collapse:after,.navbar-collapse:before,.navbar-header:after,.navbar-header:before,.navbar:after,.navbar:before,.pager:after,.pager:before,.panel-body:after,.panel-body:before,.row:after,.row:before{content:" ";display:table}.btn-group-vertical>.btn-group:after,.btn-toolbar:after,.clearfix:after,.container-fluid:after,.container:after,.dl-horizontal dd:after,.form-horizontal .form-group:after,.modal-footer:after,.modal-header:after,.nav:after,.navbar-collapse:after,.navbar-header:after,.navbar:after,.pager:after,.panel-body:after,.row:after{clear:both}.center-block{display:block;margin-left:auto;margin-right:auto}.pull-right{float:right!important}.pull-left{float:left!important}.hide{display:none!important}.show{display:block!important}.hidden,.visible-lg,.visible-lg-block,.visible-lg-inline,.visible-lg-inline-block,.visible-md,.visible-md-block,.visible-md-inline,.visible-md-inline-block,.visible-sm,.visible-sm-block,.visible-sm-inline,.visible-sm-inline-block,.visible-xs,.visible-xs-block,.visible-xs-inline,.visible-xs-inline-block{display:none!important}.invisible{visibility:hidden}.text-hide{font:0/0 a;color:transparent;background-color:transparent;border:0}.analytics h2,.analytics h3{font-size:14px;color:#5B6667}.affix{position:fixed}@-ms-viewport{width:device-width}@media (max-width:767px){.visible-xs{display:block!important}table.visible-xs{display:table!important}tr.visible-xs{display:table-row!important}td.visible-xs,th.visible-xs{display:table-cell!important}.visible-xs-block{display:block!important}.visible-xs-inline{display:inline!important}.visible-xs-inline-block{display:inline-block!important}}@media (min-width:768px) and (max-width:991px){.visible-sm{display:block!important}table.visible-sm{display:table!important}tr.visible-sm{display:table-row!important}td.visible-sm,th.visible-sm{display:table-cell!important}.visible-sm-block{display:block!important}.visible-sm-inline{display:inline!important}.visible-sm-inline-block{display:inline-block!important}}@media (min-width:992px) and (max-width:1199px){.visible-md{display:block!important}table.visible-md{display:table!important}tr.visible-md{display:table-row!important}td.visible-md,th.visible-md{display:table-cell!important}.visible-md-block{display:block!important}.visible-md-inline{display:inline!important}.visible-md-inline-block{display:inline-block!important}}@media (min-width:1200px){.visible-lg{display:block!important}table.visible-lg{display:table!important}tr.visible-lg{display:table-row!important}td.visible-lg,th.visible-lg{display:table-cell!important}.visible-lg-block{display:block!important}.visible-lg-inline{display:inline!important}.visible-lg-inline-block{display:inline-block!important}.hidden-lg{display:none!important}}@media (max-width:767px){.hidden-xs{display:none!important}}@media (min-width:768px) and (max-width:991px){.hidden-sm{display:none!important}}@media (min-width:992px) and (max-width:1199px){.hidden-md{display:none!important}}.visible-print{display:none!important}@media print{.visible-print{display:block!important}table.visible-print{display:table!important}tr.visible-print{display:table-row!important}td.visible-print,th.visible-print{display:table-cell!important}}.visible-print-block{display:none!important}@media print{.visible-print-block{display:block!important}}.visible-print-inline{display:none!important}@media print{.visible-print-inline{display:inline!important}}.visible-print-inline-block{display:none!important}@media print{.visible-print-inline-block{display:inline-block!important}.hidden-print{display:none!important}}.top-buffer-1{margin-top:15px}.top-buffer-2{margin-top:30px}.top-buffer-3{margin-top:45px}.top-buffer-4{margin-top:60px}.top-buffer-5{margin-top:75px}.top-buffer-6{margin-top:90px}.top-buffer-7{margin-top:105px}.top-buffer-8{margin-top:120px}.top-buffer-9{margin-top:135px}.top-buffer-10{margin-top:150px}body{height:101%!important}.analytics h2{margin-top:2px}.analytics h3{margin:0;font-weight:300;text-align:left}.analytics h4{color:#5B6667;font-size:16px}.analytics .green,.analytics .positive{color:green!important}.analytics .negative,.analytics .red{color:#ed1e79!important}.analytics .positive2{color:#3fc4ff!important}.analytics .negative2{color:#1de9b6!important}.analytics a{font-weight:700;color:#977bf0;cursor:pointer}.analytics .input-group{width:100%}.analytics select{margin-top:5px;background-color:#fff;height:32px}.analytics pre{font-size:12px;padding:0;margin:1px 0 8px;border:none;white-space:pre-wrap}.analytics .widget-item .content ::-webkit-scrollbar,.analytics kpis-bar .kpi ::-webkit-scrollbar{width:6px;background-color:transparent}.analytics .widget-item .content ::-webkit-scrollbar-thumb,.analytics kpis-bar .kpi ::-webkit-scrollbar-thumb{background-color:#6896b2;border-radius:10px}.analytics .widget-item .content ::-webkit-scrollbar-thumb:hover,.analytics kpis-bar .kpi ::-webkit-scrollbar-thumb:hover{background-color:#79a2bb}.analytics .nopadding{padding:0}.analytics .nomargin{margin:0}.analytics .btn.btn-shaded{background-color:#17262d;border:1px solid #0e181c;color:#626d6d;font-weight:400}.analytics .btn.btn-shaded:hover{color:#6e7a7a;background-color:#20343e}.analytics .price{font-weight:900;font-size:22px;color:#5B6667;text-align:center;margin-top:30px}.analytics .currency{font-weight:300;font-size:16px;text-align:center;color:#9ba6a7}.analytics .legend{font-weight:300;font-size:12px;text-align:center;overflow-y:auto;overflow-x:hidden;color:#c4caca}.analytics .loader{height:100%;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}.analytics .loader i{color:#67BBE9}.analytics .loader p{margin-top:10px}.analytics .right-panel{border-left:solid 1px #e6e6e6}.analytics .selector{text-transform:uppercase;font-size:12px;color:#626d6d;text-align:center}.analytics .tile{background-color:#f7f7f7;box-shadow:0 7px 10px -7px #17262d;height:45px;margin-bottom:10px;white-space:nowrap;cursor:pointer}.analytics .tile:hover{background-color:#e2f2ff}.analytics .tile .colored-area{background-color:#3FC4FF;height:100%;float:right;color:#fff;text-align:right;padding:5px 10px;min-width:8%}.analytics .tile .colored-area.selected{background-color:#977bf0}.analytics .tile .main-text{color:#5B6667;padding:20px 0 0 5px;height:100%;font-style:italic;font-weight:700}.analytics .widget-lines-container{overflow-y:auto;overflow-x:hidden;max-height:200px;text-align:left;font-size:12px;padding:0 15px}.analytics .widget-lines-container .row.widget-line{padding:5px;color:#626d6d}.analytics .widget-lines-container .row.widget-line.header{font-weight:500;font-size:12px;color:#9ba6a7;text-transform:uppercase}@media (max-width:767px){.analytics .widget-lines-container .row.widget-line{margin:inherit;margin-left:-3px;margin-right:-3px;padding:2px}.analytics .widget-lines-container .row.widget-line>[class*=col-]{padding-left:3px;padding-right:3px}}.analytics .widget-lines-container .row.widget-line i.fa{min-width:12px;min-height:12px}.analytics .widget-lines-container .row .dashed{border-bottom:dashed 1px #dfe2e2;padding-bottom:3px;margin-bottom:3px}.analytics .widget-lines-container .row.lines-group{border-top:solid 1px #e6edee}.vertical-scroll{overflow-y:scroll}.horizontal-scroll{overflow-x:scroll}.tooltip.impac-widgets-tooltip .tooltip-inner.ng-binding{text-align:left;background-color:#232528;max-width:100%;white-space:nowrap}.tooltip.impac-widgets-tooltip .tooltip-inner.ng-binding strong{color:#dae173}.sortable-title{cursor:pointer}.sortable-title div{display:inline-block}div[ng-messages]{color:red}.has-error .form-control,.has-error .form-control:focus{border-color:#e01f74}.has-success .form-control,.has-success .form-control:focus{border-color:#00e5f0}.row.no-gutters{margin-right:0;margin-left:0}[class*=" col-"].no-gutters,[class^=col-].no-gutters{padding-right:0;padding-left:0}@media print{body{background-color:#fff!important}.analytics{padding-top:0!important}.analytics #module__dashboard-selector .title-container{margin-top:20px}.analytics .widget-item{page-break-inside:avoid}.analytics .widget-item .content .chart-container{max-width:270px;margin:auto}.analytics .widget-item .content .chart-container canvas{width:100%!important;height:100%!important}.analytics .widget-item .right-panel{page-break-inside:avoid;border-left:0}.analytics .widget-item .right-panel .chart-container{max-width:inherit;max-height:inherit}.analytics .widget-item .right-panel .chart-container canvas{width:80%!important;height:80%!important}*{-webkit-transition:none!important;transition:none!important}}.kpi-alerts-settings .modal-header{font-size:20px}.kpi-alerts-settings .modal-body{line-height:2}.kpi-alerts-settings .modal-body ul{margin-top:10px}.kpi-alerts-settings .modal-body ul>li.list-group-item{list-style:none;padding:6px 15px;color:#9ba6a7;user-select:none}.kpi-alerts-settings .modal-body ul>li.list-group-item .alert-toggle:hover{cursor:pointer}.kpi-alerts-settings .modal-body ul>li.list-group-item.active{color:#358fdc;font-weight:700;background-color:transparent;border-color:#c4caca}.kpi-alerts-settings .modal-body .fa.fa-toggle-off,.kpi-alerts-settings .modal-body .fa.fa-toggle-on{font-size:17px;margin-right:8px}.kpi-alerts-settings .modal-body ul.recipients-list{height:75px;overflow:hidden;overflow-y:scroll;border:1px solid #c4caca}.kpi-alerts-settings .modal-body ul.recipients-list li{border:none}.kpi-alerts-settings .modal-body input.recipient-search{color:#000;width:100%}.kpi-alerts-settings .modal-body ul.available{margin-top:0}.analytics{padding-top:50px;margin-left:100px}@media screen and (max-width:992px){.analytics{padding-top:150px}}.analytics.pdf-mode{padding-top:20px}.analytics.show-dhb{-webkit-transition:opacity 1s;transition:opacity 1s;opacity:1}.analytics.hide-dhb{opacity:0}.analytics #dashboard-heading img{float:left;margin-right:15px;max-width:200px;max-height:150px}.analytics #dashboard-heading img.pdf-mode:hover{cursor:pointer}.analytics #dashboard-heading .caption{font-size:14px;margin:5px 0}.analytics #sub-menu{margin-top:15px}.analytics #sub-menu h3{font-size:26px;font-weight:400;margin-bottom:10px;color:#233845}.analytics #sub-menu .fa.fa-times{margin:6px;color:#3d6178;cursor:pointer;float:right}.analytics #widget-selector{background-color:#233845;color:#fff;padding:0 45px 10px;margin:10px -45px;border-radius:3px;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none}@media (max-width:767px){.analytics #widget-selector{padding:0 15px 10px;margin:0}}.analytics #widget-selector .title{padding:15px 0;border-bottom:solid 1px #2d4859;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.analytics #widget-selector .title p.instruction{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;margin:0}@media screen and (max-width:768px){.analytics #widget-selector .title p.instruction{width:50%;font-size:13px}}.analytics #widget-selector .title .widget-added.badge{margin-right:10px;opacity:0}.analytics #widget-selector .title .fa.close-selector{float:right;cursor:pointer;font-size:20px;padding:6px}.analytics #widget-selector .title .fa.close-selector:hover{color:#999}.analytics #widget-selector .top-container{margin:15px 0;background-color:transparent;border-radius:3px}.analytics #widget-selector .section-header{padding:10px 20px;font-weight:700;min-height:40px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.analytics #widget-selector .section-lines{overflow-x:hidden;overflow-y:auto;height:200px;margin-right:-10px;margin-left:0}.analytics #widget-selector .section-lines p{padding:5px;margin:0;cursor:pointer}.analytics #widget-selector .section-lines p.selected,.analytics #widget-selector .section-lines p:hover{color:#fff}.analytics #widget-selector .section-lines::-webkit-scrollbar{width:6px;background-color:transparent}.analytics #widget-selector .section-lines::-webkit-scrollbar-thumb{background-color:#28404f;border-radius:10px}.analytics #widget-selector .section-lines::-webkit-scrollbar-thumb:hover{background-color:#2d4859}.analytics #widget-selector .categories-section{background-color:#192831;padding-bottom:15px}.analytics #widget-selector .categories-section>.section-lines>[class*=col-]:first-child{padding:3px 12px}.analytics #widget-selector .categories-section>.section-lines .line-item:hover{background-color:#1e303b}.analytics #widget-selector .categories-section>.section-lines .line-item.selected{background-color:#977bf0;font-weight:700;box-shadow:-2px 2px 10px -4px #000}.analytics #widget-selector .categories-section .arrow-icon{position:absolute;top:33px;right:-11px;z-index:1}.analytics #widget-selector .categories-section .arrow-icon .square{width:50px;height:30px;position:absolute;top:10px;right:17px;background-color:#977bf0}.analytics #widget-selector .categories-section .arrow-icon i.fa.fa-caret-right{font-size:52px;color:#977bf0;float:right;position:absolute;top:-1.5px;right:0}.analytics #widget-selector .widgets-section{background-color:#1e303b;padding-bottom:15px}.analytics #widget-selector .widgets-section>.section-header{text-transform:uppercase;font-size:12px;color:#977bf0}.analytics #widget-selector .widgets-section>.section-lines{padding:3px 0}.analytics #widget-selector .widgets-section>.section-lines .fa.fa-plus-circle{float:right;margin-top:3px}.analytics #widget-selector .widgets-section>.section-lines>.line-items-grid{width:100%;display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;height:0%}.analytics #widget-selector .widgets-section>.section-lines>.line-items-grid>.grid-item{padding:0 13px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;-ms-flex:0 31.33%;flex:0 31.33%;margin:0 1%;-webkit-box-align:center;-ms-flex-align:center;align-items:center;border-bottom:solid 1px #233845;min-height:0}@media screen and (max-width:992px){.analytics #widget-selector .widgets-section>.section-lines>.line-items-grid>.grid-item{-webkit-box-flex:0;-ms-flex:0 100%;flex:0 100%}}.analytics #widget-selector .widgets-section>.section-lines>.line-items-grid>.grid-item:hover{background-color:#192831;font-weight:400}.analytics #widget-selector .widgets-section>.section-lines>.line-items-grid>.grid-item p.line-item{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1}.analytics #widget-selector .bottom{height:20px}.analytics #widget-selector .bottom>.suggestion{float:right;opacity:.7}.analytics #widget-selector .bottom>.suggestion a{cursor:pointer}.analytics #widget-selector .bottom>.suggestion a:hover{color:#00e5f0}.analytics #widget-selector .bottom>.suggestion:hover{opacity:1}.analytics #dashboard-settings-panel{position:relative;margin-top:5px}.analytics #dashboard-settings-panel>div{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:end;-ms-flex-pack:end;justify-content:flex-end}.analytics #dashboard-settings-panel>div>*{margin:0 3px}.analytics #dashboard-settings-panel select{margin:0;height:34px;padding-top:1px}.analytics #no-widgets-container{position:relative;min-height:150px}.analytics #no-widgets-container img.bg{left:0;top:0;min-width:100%;min-height:100%}.analytics #no-widgets-container .impac-info-message{position:absolute;top:0;width:100%}.analytics #no-widgets-container .impac-info-message .info-text{font-size:25px;font-weight:300;padding:20px;min-height:115px;color:#fff;border-radius:10px;background-color:rgba(23,38,45,.7)}.analytics #widgets-section #widgets-container{min-height:700px}.analytics #widgets-section .placeHolderBox{margin:12px;height:267px;width:300px;float:left;border:2px dashed #abc4c6;background:0 0}.analytics.load-failed p{font-size:22px}.analytics.load-failed .second-msg p{color:#e01f74;font-size:14px}.tooltip.impac-widget-selector-tooltip .tooltip-inner.ng-binding{font-size:14px}.impac-widget-suggestion .modal-body input,.impac-widget-suggestion .modal-body textarea{width:100%;color:#000}.impac-widget-suggestion .modal-body textarea{height:150px}.impac-widget-suggestion .modal-body .thanks-message{color:#dae173}.modal-footer .loader{color:#fff}.analytics .dashboard-create .btn-create{background-color:#977bf0}.modal.impac-dashboard-create h1{font-size:24px}.modal.impac-dashboard-create .fa.fa-times{float:right;color:#ccc;cursor:pointer}.modal.impac-dashboard-create .control-label{text-align:left}.modal.impac-dashboard-create .modal-footer .loader{color:#fff}#module__dashboard-selector a{font-weight:400}#module__dashboard-selector>div:first-child{border-bottom:1px solid #abc4c6}#module__dashboard-selector .buttons-bar-row{margin-top:54px}#module__dashboard-selector .buttons-bar-row.pdf-mode{margin-top:0}#module__dashboard-selector .buttons-bar{padding:0;position:relative}#module__dashboard-selector .buttons-bar .btn{float:right;margin:3px;border-radius:4px}#module__dashboard-selector .buttons-bar .title-container h1{margin:0;color:#000;cursor:auto}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-title{color:#977bf0;display:inline;cursor:pointer}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-title:hover{color:#734deb}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-title i.fa.fa-pencil{margin-left:20px;font-size:14px}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-title i.fa.fa-pencil:hover{color:#dae173}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select{margin:5px 0 10px 30px;height:auto;border-left:1px solid #977bf0;border-bottom:1px solid #977bf0;width:300px;background-color:#e6edee;cursor:pointer}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option{color:#17262d;white-space:nowrap}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option:hover{background-color:#fff}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option.dashboard-create{height:33px}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option.dashboard-create .btn{float:none;width:100%;text-align:left;margin:0;border-radius:0}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option i.fa.fa-pencil{float:right;padding-top:7px;text-align:center;width:15%;height:30px}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option i.fa.fa-pencil:hover{color:#734deb}#module__dashboard-selector .buttons-bar .dropdown-container .dashboard-select .option span.name{width:85%;height:30px;display:inline-block;padding:5px 10px}#module__dashboard-selector .buttons-bar .dropdown-container .change-name{position:absolute;top:30px;left:20px;width:60%;background-color:#17262d;color:#fff;padding:10px;border-radius:4px;text-align:center;box-shadow:0 0 25px 4px #000;z-index:50;border:1px solid #fff}#module__dashboard-selector .buttons-bar .dropdown-container .change-name .form-control{height:25px;margin-bottom:10px}#module__dashboard-selector .buttons-bar .dropdown-container .data-source-label{color:#17262d;padding-left:3px;margin:0}#module__dashboard-selector .buttons-bar .loader-container{padding-left:10px}#module__dashboard-selector .buttons-bar .loader-container .loading-spinner{color:#67BBE9;font-size:40px}#module__dashboard-selector .nav-tabs{border-bottom:0}#module__dashboard-selector .nav.nav-pills li:last-child>a,#module__dashboard-selector .nav.nav-tabs li:last-child>a{padding-right:15px}#module__dashboard-selector .nav.nav-pills li:last-child>a tab-heading a,#module__dashboard-selector .nav.nav-tabs li:last-child>a tab-heading a{position:static}#module__dashboard-selector .nav.nav-tabs li>a{padding:10px 8px 10px 15px;margin:0 2px 0 0;background-color:transparent;border:1px solid #abc4c6;color:#000}#module__dashboard-selector .nav.nav-tabs li.active>a{background-color:#fff;color:#977bf0}#module__dashboard-selector .nav.nav-tabs li:last-child.active>a{background-color:transparent}#module__dashboard-selector .nav.nav-pills li>a{min-width:0;padding-right:8px}#module__dashboard-selector .nav.nav-pills li:last-child tab-heading a{margin-left:2px}#module__dashboard-selector .nav.nav-pills li:last-child.active>a{background-color:#f4f4f4}#module__dashboard-selector tab-heading a.close-link{border-bottom:0 solid;margin-left:12px;position:relative;top:-9px;right:1px;color:#000}dashboard-templates-selector .templates-header{display:-webkit-box;display:-ms-flexbox;display:flex}dashboard-templates-selector .templates-header .templates-toggle{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;-webkit-box-pack:end;-ms-flex-pack:end;justify-content:flex-end;font-size:20px}dashboard-templates-selector .templates-header .templates-toggle i.fa{cursor:pointer}dashboard-templates-selector .templates-header .templates-toggle i.fa.fa-toggle-on{color:#977bf0}dashboard-templates-selector .templates{border:1px solid #ccc;box-shadow:inset 0 0 1px 0 #ccc;height:130px;overflow:auto;border-radius:2px}dashboard-templates-selector .templates .template{padding:5px 10px;color:#5B6667;border-bottom:1px solid #ececec}.analytics .impac-kpi .kpi.add:hover .kpi-icon,.analytics .impac-kpi .kpi.add:hover .kpi-text{color:#000}dashboard-templates-selector .templates .template:hover{cursor:pointer;background-color:rgba(96,232,119,.62)}dashboard-templates-selector .templates .template.selected{background-color:rgba(29,197,57,.62)}.analytics .impac-kpi .kpi{position:relative;max-width:220px;min-height:95px;max-height:95px;background-color:#fff;margin:10px 0;border-bottom:1px solid #fff;-webkit-transition:all .2s ease-in;transition:all .2s ease-in}@media screen and (max-width:768px){.analytics .impac-kpi .kpi{margin-left:auto;margin-right:auto}}.analytics .impac-kpi .kpi.add:hover,.analytics .impac-kpi .kpi.triggered{border-bottom:4px solid #e01f74}.analytics .impac-kpi .kpi.add .kpi-text .emphasis{visibility:hidden}.analytics .impac-kpi .kpi.add:hover{cursor:pointer}.analytics .impac-kpi .kpi.add:hover .top-line{background-color:#000}.analytics .impac-kpi .kpi.add:hover .kpi-text .emphasis{visibility:visible}.analytics .impac-kpi .kpi.add:hover .kpi-icon .fa-plus:before{content:"\f00c"}.analytics .impac-kpi .kpi.editing{min-height:185px}.analytics .impac-kpi .kpi:hover{cursor:default}.analytics .impac-kpi .kpi.static .kpi-value{display:block;font-size:14px;font-weight:700}.analytics .impac-kpi .kpi .top-line{width:100%;position:relative;cursor:move;padding:9px 9px 0 12px;border-bottom:none;min-height:7px;box-shadow:none;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row;margin-bottom:5px;background-color:grey;-webkit-transition:background .2s ease-in;transition:background .2s ease-in}.analytics .impac-kpi .kpi .top-line.triggered{background-color:#000}.analytics .impac-kpi .kpi .kpi-content{max-height:90px}.analytics .impac-kpi .kpi .kpi-content.editing{min-height:180px;overflow-y:auto;overflow-x:hidden}.analytics .impac-kpi .kpi .kpi-show{white-space:normal;padding:10px}@media screen and (max-width:380px){.analytics .impac-kpi .kpi .kpi-show{padding:10px 3px}}.analytics .impac-kpi .kpi .kpi-show .emphasis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.analytics .impac-kpi .kpi .kpi-show .emphasis .real-value{color:#676767}.analytics .impac-kpi .kpi .kpi-show .caption{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.analytics .impac-kpi .kpi .kpi-show .kpi-text{padding:7px 0;color:grey;-webkit-transition:color .2s ease-in;transition:color .2s ease-in}.analytics .impac-kpi .kpi .kpi-show .kpi-text>span{display:block}.analytics .impac-kpi .kpi .kpi-show .kpi-text.triggered{color:#000}.analytics .impac-kpi .kpi .kpi-show .kpi-text .caption{font-size:11px;padding-bottom:2px}@media screen and (max-width:465px){.analytics .impac-kpi .kpi .kpi-show .kpi-text .caption{font-size:10px}.analytics .impac-kpi .kpi .kpi-show .kpi-text .emphasis{font-size:11px}}.analytics .impac-kpi .kpi .kpi-show .kpi-icon{font-size:16px;padding:10px 0;color:grey;-webkit-transition:color .2s ease-in;transition:color .2s ease-in}.analytics .impac-kpi .kpi .kpi-show .kpi-icon.triggered{color:#000}@media screen and (max-width:465px){.analytics .impac-kpi .kpi .kpi-show .kpi-icon{font-size:12px;padding:16px 0}}.analytics .impac-kpi .kpi .kpi-edit a{color:#fff}.analytics .impac-kpi .kpi .kpi-edit .kpi-name{text-align:center;margin-bottom:5px}.analytics .impac-kpi .kpi .kpi-edit .kpi-name h6{margin:0 0 5px}.analytics .impac-kpi .kpi .kpi-edit .real-value{text-transform:uppercase;font-size:10px;text-align:center}.analytics .impac-kpi .kpi .kpi-edit .alert-caption{text-align:center;font-size:11px;background:#f99;border-radius:3px;width:100%;margin:0 auto 5px;box-shadow:none;padding:2px;color:#fff}.analytics .impac-kpi .kpi .kpi-edit .kpi-target-unit,.analytics .impac-kpi .kpi .kpi-edit .kpi-target-watchable{text-transform:uppercase;font-weight:500;font-size:11px}.analytics .impac-kpi .kpi .kpi-edit .kpi-target-watchable{margin-bottom:20px;color:#8d8d8d}.analytics .impac-kpi .kpi .kpi-edit .kpi-target-unit{position:absolute;top:6px;right:0;color:#9a9a9a}.analytics .impac-kpi .kpi .kpi-edit .param-name{font-size:85%}.analytics .impac-kpi .kpi .kpi-edit .btn.btn-xs{margin-top:4px}.analytics .impac-kpi .kpi .kpi-edit .add-on,.analytics .impac-kpi .kpi .kpi-edit .alert,.analytics .impac-kpi .kpi .kpi-edit .badge,.analytics .impac-kpi .kpi .kpi-edit .btn,.analytics .impac-kpi .kpi .kpi-edit .dropdown-menu,.analytics .impac-kpi .kpi .kpi-edit .img-polaroid,.analytics .impac-kpi .kpi .kpi-edit .label,.analytics .impac-kpi .kpi .kpi-edit .modal,.analytics .impac-kpi .kpi .kpi-edit .nav>.active>a,.analytics .impac-kpi .kpi .kpi-edit .navbar-inner,.analytics .impac-kpi .kpi .kpi-edit .popover,.analytics .impac-kpi .kpi .kpi-edit .progress,.analytics .impac-kpi .kpi .kpi-edit .table-bordered,.analytics .impac-kpi .kpi .kpi-edit .tooltip,.analytics .impac-kpi .kpi .kpi-edit .tooltip-inner,.analytics .impac-kpi .kpi .kpi-edit .well,.analytics .impac-kpi .kpi .kpi-edit input,.analytics .impac-kpi .kpi .kpi-edit pre,.analytics .impac-kpi .kpi .kpi-edit select,.analytics .impac-kpi .kpi .kpi-edit textarea,.analytics .impac-kpi .kpi .kpi-no-data .add-on,.analytics .impac-kpi .kpi .kpi-no-data .alert,.analytics .impac-kpi .kpi .kpi-no-data .badge,.analytics .impac-kpi .kpi .kpi-no-data .btn,.analytics .impac-kpi .kpi .kpi-no-data .dropdown-menu,.analytics .impac-kpi .kpi .kpi-no-data .img-polaroid,.analytics .impac-kpi .kpi .kpi-no-data .label,.analytics .impac-kpi .kpi .kpi-no-data .modal,.analytics .impac-kpi .kpi .kpi-no-data .nav>.active>a,.analytics .impac-kpi .kpi .kpi-no-data .navbar-inner,.analytics .impac-kpi .kpi .kpi-no-data .popover,.analytics .impac-kpi .kpi .kpi-no-data .progress,.analytics .impac-kpi .kpi .kpi-no-data .table-bordered,.analytics .impac-kpi .kpi .kpi-no-data .tooltip,.analytics .impac-kpi .kpi .kpi-no-data .tooltip-inner,.analytics .impac-kpi .kpi .kpi-no-data .well,.analytics .impac-kpi .kpi .kpi-no-data input,.analytics .impac-kpi .kpi .kpi-no-data pre,.analytics .impac-kpi .kpi .kpi-no-data select,.analytics .impac-kpi .kpi .kpi-no-data textarea{box-shadow:none!important;border-radius:0!important;border-collapse:collapse!important;background-image:none!important}.analytics .impac-kpi .kpi .kpi-edit body,.analytics .impac-kpi .kpi .kpi-edit body::after,.analytics .impac-kpi .kpi .kpi-edit body::before,.analytics .impac-kpi .kpi .kpi-edit input,.analytics .impac-kpi .kpi .kpi-edit input::after,.analytics .impac-kpi .kpi .kpi-edit input::before,.analytics .impac-kpi .kpi .kpi-edit select,.analytics .impac-kpi .kpi .kpi-edit select::after,.analytics .impac-kpi .kpi .kpi-edit select::before,.analytics .impac-kpi .kpi .kpi-edit textarea,.analytics .impac-kpi .kpi .kpi-edit textarea::after,.analytics .impac-kpi .kpi .kpi-edit textarea::before,.analytics .impac-kpi .kpi .kpi-no-data body,.analytics .impac-kpi .kpi .kpi-no-data body::after,.analytics .impac-kpi .kpi .kpi-no-data body::before,.analytics .impac-kpi .kpi .kpi-no-data input,.analytics .impac-kpi .kpi .kpi-no-data input::after,.analytics .impac-kpi .kpi .kpi-no-data input::before,.analytics .impac-kpi .kpi .kpi-no-data select,.analytics .impac-kpi .kpi .kpi-no-data select::after,.analytics .impac-kpi .kpi .kpi-no-data select::before,.analytics .impac-kpi .kpi .kpi-no-data textarea,.analytics .impac-kpi .kpi .kpi-no-data textarea::after,.analytics .impac-kpi .kpi .kpi-no-data textarea::before{box-sizing:border-box}.analytics .impac-kpi .kpi .kpi-edit input[type=number]::-webkit-inner-spin-button,.analytics .impac-kpi .kpi .kpi-edit input[type=number]::-webkit-outer-spin-button,.analytics .impac-kpi .kpi .kpi-no-data input[type=number]::-webkit-inner-spin-button,.analytics .impac-kpi .kpi .kpi-no-data input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.analytics .impac-kpi .kpi .kpi-edit a:hover,.analytics .impac-kpi .kpi .kpi-no-data a:hover{text-decoration:none}.analytics .impac-kpi .kpi .kpi-edit fieldset,.analytics .impac-kpi .kpi .kpi-no-data fieldset{margin:0 0 1.75rem;padding:0;border:none}.analytics .impac-kpi .kpi .kpi-edit .im-form-group,.analytics .impac-kpi .kpi .kpi-edit .im-form-radio,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group,.analytics .impac-kpi .kpi .kpi-no-data .im-form-radio{position:relative;margin-top:1.3125rem;margin-bottom:1.3125rem}.analytics .impac-kpi .kpi .kpi-edit .im-form-inline,.analytics .impac-kpi .kpi .kpi-no-data .im-form-inline{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row;box-sizing:border-box}.analytics .impac-kpi .kpi .kpi-edit .im-form-inline>.im-form-group,.analytics .impac-kpi .kpi .kpi-no-data .im-form-inline>.im-form-group{display:block;-webkit-box-flex:1;-ms-flex:1;flex:1;position:relative;vertical-align:middle;margin-left:.175rem;margin-right:.175rem}.analytics .impac-kpi .kpi .kpi-edit .im-form-inline>.btn,.analytics .impac-kpi .kpi .kpi-no-data .im-form-inline>.btn{display:inline-block;margin-bottom:0}.analytics .impac-kpi .kpi .kpi-edit .im-form-group input,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input{height:2.375rem}.analytics .impac-kpi .kpi .kpi-edit .im-form-group select,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select{width:100%;font-size:1.25rem;height:2rem;padding:.15625rem .15625rem .078125rem;background:0 0;border:none;line-height:1.6;box-shadow:none}.analytics .impac-kpi .kpi .kpi-edit .im-form-group .im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group .im-control-label{position:absolute;top:.3125rem;pointer-events:none;padding-left:.15625rem;z-index:1;color:#b3b3b3;font-size:1.25rem;font-weight:400;-webkit-transition:all .28s ease;transition:all .28s ease}.analytics .impac-kpi .kpi .kpi-edit .im-form-group .im-bar,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group .im-bar{position:relative;border-bottom:.078125rem solid #999;display:block}.analytics .impac-kpi .kpi .kpi-edit .im-form-group .im-bar::before,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group .im-bar::before{content:'';height:.15625rem;width:0;left:50%;bottom:-.078125rem;position:absolute;background:#358fdc;-webkit-transition:left .28s ease,width .28s ease;transition:left .28s ease,width .28s ease;z-index:2}.analytics .impac-kpi .kpi .kpi-edit .im-form-group input,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea{display:block;background:0 0;padding:.15625rem .15625rem .078125rem;font-size:1.25rem;border-width:0;border-color:transparent;line-height:1.9;width:100%;color:transparent;-webkit-transition:all .28s ease;transition:all .28s ease;box-shadow:none}.analytics .impac-kpi .kpi .kpi-edit .im-form-group input[type=file],.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input[type=file]{line-height:1}.analytics .impac-kpi .kpi .kpi-edit .im-form-group input[type=file]~.im-bar,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input[type=file]~.im-bar{display:none}.analytics .impac-kpi .kpi .kpi-edit .im-form-group input.form-file,.analytics .impac-kpi .kpi .kpi-edit .im-form-group input.has-value,.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:focus,.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:valid,.analytics .impac-kpi .kpi .kpi-edit .im-form-group select,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea.form-file,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea.has-value,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:focus,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:valid,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input.form-file,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input.has-value,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:focus,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:valid,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea.form-file,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea.has-value,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:focus,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:valid{color:#333}.analytics .impac-kpi .kpi .kpi-edit .im-form-group input.form-file~.im-control-label,.analytics .impac-kpi .kpi .kpi-edit .im-form-group input.has-value~.im-control-label,.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:focus~.im-control-label,.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:valid~.im-control-label,.analytics .impac-kpi .kpi .kpi-edit .im-form-group select~.im-control-label,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea.form-file~.im-control-label,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea.has-value~.im-control-label,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:focus~.im-control-label,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:valid~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input.form-file~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input.has-value~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:focus~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:valid~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea.form-file~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea.has-value~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:focus~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:valid~.im-control-label{font-size:1rem;color:grey;top:-1.25rem;left:0}.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:focus,.analytics .impac-kpi .kpi .kpi-edit .im-form-group select:focus,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:focus,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:focus,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select:focus,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:focus{outline:0}.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:focus~.im-control-label,.analytics .impac-kpi .kpi .kpi-edit .im-form-group select:focus~.im-control-label,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:focus~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:focus~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select:focus~.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:focus~.im-control-label{color:#358fdc}.analytics .impac-kpi .kpi .kpi-edit .im-form-group input:focus~.im-bar::before,.analytics .impac-kpi .kpi .kpi-edit .im-form-group select:focus~.im-bar::before,.analytics .impac-kpi .kpi .kpi-edit .im-form-group textarea:focus~.im-bar::before,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group input:focus~.im-bar::before,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group select:focus~.im-bar::before,.analytics .impac-kpi .kpi .kpi-no-data .im-form-group textarea:focus~.im-bar::before{width:100%;left:0}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox label,.analytics .impac-kpi .kpi .kpi-edit .im-form-radio label,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox label,.analytics .impac-kpi .kpi .kpi-no-data .im-form-radio label{position:relative;cursor:pointer;padding-left:2.5rem;text-align:left;color:#333;display:block}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input,.analytics .impac-kpi .kpi .kpi-edit .im-form-radio input,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input,.analytics .impac-kpi .kpi .kpi-no-data .im-form-radio input{width:auto;opacity:.00000001;position:absolute;left:0}.analytics .impac-kpi .kpi .kpi-edit .im-radio,.analytics .impac-kpi .kpi .kpi-no-data .im-radio{margin-bottom:1.25rem}.analytics .impac-kpi .kpi .kpi-edit .im-radio .im-helper,.analytics .impac-kpi .kpi .kpi-no-data .im-radio .im-helper{position:absolute;top:-.3125rem;left:-.3125rem;cursor:pointer;display:block;font-size:1.25rem;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;color:#999}.analytics .impac-kpi .kpi .kpi-edit .im-radio .im-helper::after,.analytics .impac-kpi .kpi .kpi-edit .im-radio .im-helper::before,.analytics .impac-kpi .kpi .kpi-no-data .im-radio .im-helper::after,.analytics .impac-kpi .kpi .kpi-no-data .im-radio .im-helper::before{content:'';position:absolute;left:0;top:0;margin:.3125rem;width:1.25rem;height:1.25rem;-webkit-transition:-webkit-transform .28s ease;transition:-webkit-transform .28s ease;transition:transform .28s ease;transition:transform .28s ease,-webkit-transform .28s ease;border-radius:50%;border:.15625rem solid currentColor}.analytics .impac-kpi .kpi .kpi-edit .im-radio .im-helper::after,.analytics .impac-kpi .kpi .kpi-no-data .im-radio .im-helper::after{-webkit-transform:scale(0);transform:scale(0);background-color:#358fdc;border-color:#358fdc}.analytics .impac-kpi .kpi .kpi-edit .im-radio label:hover .im-helper,.analytics .impac-kpi .kpi .kpi-no-data .im-radio label:hover .im-helper{color:#358fdc}.analytics .impac-kpi .kpi .kpi-edit .im-radio input:checked~.im-helper::after,.analytics .impac-kpi .kpi .kpi-no-data .im-radio input:checked~.im-helper::after{-webkit-transform:scale(.5);transform:scale(.5)}.analytics .impac-kpi .kpi .kpi-edit .im-radio input:checked~.im-helper::before,.analytics .impac-kpi .kpi .kpi-no-data .im-radio input:checked~.im-helper::before{color:#358fdc}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox{margin-top:1.75rem;margin-bottom:1.25rem}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox .im-helper,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox .im-helper{color:#999;position:absolute;top:0;left:0;width:1.25rem;height:1.25rem;z-index:0;border:.15625rem solid currentColor;border-radius:.078125rem;-webkit-transition:border-color .28s ease;transition:border-color .28s ease}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox .im-helper::after,.analytics .impac-kpi .kpi .kpi-edit .im-checkbox .im-helper::before,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox .im-helper::after,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox .im-helper::before{position:absolute;height:0;width:.25rem;background-color:#358fdc;display:block;-webkit-transform-origin:left top;transform-origin:left top;border-radius:.3125rem;content:'';-webkit-transition:opacity .28s ease,height 0s linear .28s;transition:opacity .28s ease,height 0s linear .28s;opacity:0}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox .im-helper::before,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox .im-helper::before{top:.8125rem;left:.475rem;-webkit-transform:rotate(-135deg);transform:rotate(-135deg);box-shadow:0 0 0 .078125rem #fff}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox .im-helper::after,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox .im-helper::after{top:.375rem;left:0;-webkit-transform:rotate(-45deg);transform:rotate(-45deg)}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox label:hover .im-helper,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox label:hover .im-helper{color:#358fdc}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input:checked~.im-helper,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input:checked~.im-helper{color:#358fdc}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input:checked~.im-helper::after,.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input:checked~.im-helper::before,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input:checked~.im-helper::after,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input:checked~.im-helper::before{opacity:1;-webkit-transition:height .28s ease;transition:height .28s ease}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input:checked~.im-helper::after,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input:checked~.im-helper::after{height:.625rem}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox input:checked~.im-helper::before,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox input:checked~.im-helper::before{height:1.5rem;-webkit-transition-delay:.28s;transition-delay:.28s}.analytics .impac-kpi .kpi .kpi-edit .im-checkbox+.im-checkbox,.analytics .impac-kpi .kpi .kpi-edit .im-radio+.im-radio,.analytics .impac-kpi .kpi .kpi-no-data .im-checkbox+.im-checkbox,.analytics .impac-kpi .kpi .kpi-no-data .im-radio+.im-radio{margin-top:1.25rem}.analytics .impac-kpi .kpi .kpi-edit .im-messages,.analytics .impac-kpi .kpi .kpi-no-data .im-messages{font-size:1.04166667rem;color:#e01f74;overflow:hidden;-webkit-transition:all .28s cubic-bezier(.55,0,.55,.2);transition:all .28s cubic-bezier(.55,0,.55,.2);opacity:0;margin-top:0;padding-top:5px}.analytics .impac-kpi .kpi .kpi-edit .has-error .legend.legend,.analytics .impac-kpi .kpi .kpi-edit .has-error.im-form-group .im-control-label.im-control-label,.analytics .impac-kpi .kpi .kpi-no-data .has-error .legend.legend,.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-form-group .im-control-label.im-control-label{color:#e01f74}.analytics .impac-kpi .kpi .kpi-edit .has-error.im-checkbox .im-helper,.analytics .impac-kpi .kpi .kpi-edit .has-error.im-checkbox .im-messages,.analytics .impac-kpi .kpi .kpi-edit .has-error.im-form-group .im-helper,.analytics .impac-kpi .kpi .kpi-edit .has-error.im-form-group .im-messages,.analytics .impac-kpi .kpi .kpi-edit .has-error.im-form-radio .im-helper,.analytics .impac-kpi .kpi .kpi-edit .has-error.im-form-radio .im-messages,.analytics .impac-kpi .kpi .kpi-edit .has-error.im-radio .im-helper,.analytics .impac-kpi .kpi .kpi-edit .has-error.im-radio .im-messages,.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-checkbox .im-helper,.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-checkbox .im-messages,.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-form-group .im-helper,.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-form-group .im-messages,.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-form-radio .im-helper,.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-form-radio .im-messages,.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-radio .im-helper,.analytics .impac-kpi .kpi .kpi-no-data .has-error.im-radio .im-messages{color:#e01f74;opacity:1}.analytics .impac-kpi .kpi .kpi-edit .has-error .im-bar::before,.analytics .impac-kpi .kpi .kpi-no-data .has-error .im-bar::before{background:#e01f74;left:0;width:100%}.analytics .impac-kpi .kpi .kpi-edit .im-button,.analytics .impac-kpi .kpi .kpi-no-data .im-button{position:relative;background:#60a7e4;border:0;font-size:1.375rem;color:#333;margin:.7rem 0;padding:.4375rem 1.75rem;border-radius:3px;cursor:pointer;overflow:hidden;box-shadow:0 2px 2px 0 rgba(0,0,0,.14),0 3px 1px -2px rgba(0,0,0,.2),0 1px 5px 0 rgba(0,0,0,.12)}.analytics .impac-kpi .kpi .kpi-edit .im-button span,.analytics .impac-kpi .kpi .kpi-no-data .im-button span{color:#fff;position:relative;z-index:1}.analytics .impac-kpi .kpi .kpi-edit .im-button:hover,.analytics .impac-kpi .kpi .kpi-no-data .im-button:hover{-webkit-transition:background .1s ease-in;transition:background .1s ease-in;background:#2583d3}.analytics .impac-kpi .kpi .kpi-edit .im-button:active,.analytics .impac-kpi .kpi .kpi-no-data .im-button:active{box-shadow:inset 0 2px 2px 0 rgba(0,0,0,.14)}.analytics .impac-kpi .kpi .kpi-edit .im-button a:focus,.analytics .impac-kpi .kpi .kpi-edit .im-button:focus,.analytics .impac-kpi .kpi .kpi-no-data .im-button a:focus,.analytics .impac-kpi .kpi .kpi-no-data .im-button:focus{outline:0;text-decoration:none}.analytics .impac-kpi .kpi .kpi-edit button.im-fab,.analytics .impac-kpi .kpi .kpi-no-data button.im-fab{position:relative;height:46px;width:46px;-webkit-box-flex:0;-ms-flex:0 0 56px;flex:0 0 56px;display:inline-block;padding:0;margin:4px;border:0;border-radius:100%;overflow:hidden;font-size:20px;box-shadow:0 4px 5px 0 rgba(0,0,0,.14),0 1px 10px 0 rgba(0,0,0,.12),0 2px 4px -1px rgba(0,0,0,.2);color:#fff}.analytics .impac-kpi .kpi .kpi-edit button.im-fab:focus,.analytics .impac-kpi .kpi .kpi-no-data button.im-fab:focus{outline:0}.analytics .impac-kpi .kpi .kpi-edit button.im-fab:active,.analytics .impac-kpi .kpi .kpi-no-data button.im-fab:active{box-shadow:inset 0 2px 2px 0 rgba(0,0,0,.14)}.analytics .impac-kpi .kpi .kpi-edit button.im-fab.im-primary,.analytics .impac-kpi .kpi .kpi-no-data button.im-fab.im-primary{background:#358fdc}.analytics .impac-kpi .kpi .kpi-edit button.im-fab.im-primary:hover,.analytics .impac-kpi .kpi .kpi-no-data button.im-fab.im-primary:hover{-webkit-transition:background .1s ease-in;transition:background .1s ease-in;background:#2583d3}.analytics .impac-kpi .kpi .kpi-edit button.im-fab.im-warn,.analytics .impac-kpi .kpi .kpi-no-data button.im-fab.im-warn{background:#e01f74}.analytics .impac-kpi .kpi .kpi-edit button.im-fab.im-warn:hover,.analytics .impac-kpi .kpi .kpi-no-data button.im-fab.im-warn:hover{-webkit-transition:background .1s ease-in;transition:background .1s ease-in;background:#ca1c68}.analytics .impac-kpi .kpi button.kpi-alerts.im-fab.im-primary{position:absolute;top:-12px;right:15px;width:22px;height:22px;font-size:13px;background:#4c4749}.analytics .impac-kpi .kpi button.kpi-alerts.im-fab.im-primary:hover{backgroud:#358fdc}.analytics .impac-kpi .kpi button.kpi-remove.im-fab.im-warn{position:absolute;top:-12px;right:-11px;width:22px;height:22px;font-size:13px;background:#4c4749}.analytics .impac-kpi .kpi button.kpi-remove.im-fab.im-warn:hover{background:#ca1c68}.analytics .impac-kpi .kpi .kpi-data-loader{width:100%;min-height:95px}.analytics kpis-bar>.key-stats .kpi{min-height:80px}.analytics kpis-bar>.kpis{position:relative}.analytics kpis-bar>.kpis .actions{margin-bottom:12px}@media screen and (max-width:675px){.analytics kpis-bar>.kpis .actions{position:relative}}.analytics kpis-bar>.kpis .actions .add-on,.analytics kpis-bar>.kpis .actions .alert,.analytics kpis-bar>.kpis .actions .badge,.analytics kpis-bar>.kpis .actions .btn,.analytics kpis-bar>.kpis .actions .dropdown-menu,.analytics kpis-bar>.kpis .actions .img-polaroid,.analytics kpis-bar>.kpis .actions .label,.analytics kpis-bar>.kpis .actions .modal,.analytics kpis-bar>.kpis .actions .nav>.active>a,.analytics kpis-bar>.kpis .actions .navbar-inner,.analytics kpis-bar>.kpis .actions .popover,.analytics kpis-bar>.kpis .actions .progress,.analytics kpis-bar>.kpis .actions .table-bordered,.analytics kpis-bar>.kpis .actions .tooltip,.analytics kpis-bar>.kpis .actions .tooltip-inner,.analytics kpis-bar>.kpis .actions .well,.analytics kpis-bar>.kpis .actions input,.analytics kpis-bar>.kpis .actions pre,.analytics kpis-bar>.kpis .actions select,.analytics kpis-bar>.kpis .actions textarea{box-shadow:none!important;border-radius:0!important;border-collapse:collapse!important;background-image:none!important}.analytics kpis-bar>.kpis .actions body,.analytics kpis-bar>.kpis .actions body::after,.analytics kpis-bar>.kpis .actions body::before,.analytics kpis-bar>.kpis .actions input,.analytics kpis-bar>.kpis .actions input::after,.analytics kpis-bar>.kpis .actions input::before,.analytics kpis-bar>.kpis .actions select,.analytics kpis-bar>.kpis .actions select::after,.analytics kpis-bar>.kpis .actions select::before,.analytics kpis-bar>.kpis .actions textarea,.analytics kpis-bar>.kpis .actions textarea::after,.analytics kpis-bar>.kpis .actions textarea::before{box-sizing:border-box}.analytics kpis-bar>.kpis .actions input[type=number]::-webkit-inner-spin-button,.analytics kpis-bar>.kpis .actions input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.analytics kpis-bar>.kpis .actions a:hover{text-decoration:none}.analytics kpis-bar>.kpis .actions fieldset{margin:0 0 1.75rem;padding:0;border:none}.analytics kpis-bar>.kpis .actions .im-form-group,.analytics kpis-bar>.kpis .actions .im-form-radio{position:relative;margin-top:1.3125rem;margin-bottom:1.3125rem}.analytics kpis-bar>.kpis .actions .im-form-inline{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row;box-sizing:border-box}.analytics kpis-bar>.kpis .actions .im-form-inline>.im-form-group{display:block;-webkit-box-flex:1;-ms-flex:1;flex:1;position:relative;vertical-align:middle;margin-left:.175rem;margin-right:.175rem}.analytics kpis-bar>.kpis .actions .im-form-inline>.btn{display:inline-block;margin-bottom:0}.analytics kpis-bar>.kpis .actions .im-form-group input{height:2.375rem}.analytics kpis-bar>.kpis .actions .im-form-group select{width:100%;font-size:1.25rem;height:2rem;padding:.15625rem .15625rem .078125rem;background:0 0;border:none;line-height:1.6;box-shadow:none}.analytics kpis-bar>.kpis .actions .im-form-group .im-control-label{position:absolute;top:.3125rem;pointer-events:none;padding-left:.15625rem;z-index:1;color:#b3b3b3;font-size:1.25rem;font-weight:400;-webkit-transition:all .28s ease;transition:all .28s ease}.analytics kpis-bar>.kpis .actions .im-form-group .im-bar{position:relative;border-bottom:.078125rem solid #999;display:block}.analytics kpis-bar>.kpis .actions .im-form-group .im-bar::before{content:'';height:.15625rem;width:0;left:50%;bottom:-.078125rem;position:absolute;background:#358fdc;-webkit-transition:left .28s ease,width .28s ease;transition:left .28s ease,width .28s ease;z-index:2}.analytics kpis-bar>.kpis .actions .im-form-group input,.analytics kpis-bar>.kpis .actions .im-form-group textarea{display:block;background:0 0;padding:.15625rem .15625rem .078125rem;font-size:1.25rem;border-width:0;border-color:transparent;line-height:1.9;width:100%;color:transparent;-webkit-transition:all .28s ease;transition:all .28s ease;box-shadow:none}.analytics kpis-bar>.kpis .actions .im-form-group input[type=file]{line-height:1}.analytics kpis-bar>.kpis .actions .im-form-group input[type=file]~.im-bar{display:none}.analytics kpis-bar>.kpis .actions .im-form-group input.form-file,.analytics kpis-bar>.kpis .actions .im-form-group input.has-value,.analytics kpis-bar>.kpis .actions .im-form-group input:focus,.analytics kpis-bar>.kpis .actions .im-form-group input:valid,.analytics kpis-bar>.kpis .actions .im-form-group select,.analytics kpis-bar>.kpis .actions .im-form-group textarea.form-file,.analytics kpis-bar>.kpis .actions .im-form-group textarea.has-value,.analytics kpis-bar>.kpis .actions .im-form-group textarea:focus,.analytics kpis-bar>.kpis .actions .im-form-group textarea:valid{color:#333}.analytics kpis-bar>.kpis .actions .im-form-group input.form-file~.im-control-label,.analytics kpis-bar>.kpis .actions .im-form-group input.has-value~.im-control-label,.analytics kpis-bar>.kpis .actions .im-form-group input:focus~.im-control-label,.analytics kpis-bar>.kpis .actions .im-form-group input:valid~.im-control-label,.analytics kpis-bar>.kpis .actions .im-form-group select~.im-control-label,.analytics kpis-bar>.kpis .actions .im-form-group textarea.form-file~.im-control-label,.analytics kpis-bar>.kpis .actions .im-form-group textarea.has-value~.im-control-label,.analytics kpis-bar>.kpis .actions .im-form-group textarea:focus~.im-control-label,.analytics kpis-bar>.kpis .actions .im-form-group textarea:valid~.im-control-label{font-size:1rem;color:grey;top:-1.25rem;left:0}.analytics kpis-bar>.kpis .actions .im-form-group input:focus,.analytics kpis-bar>.kpis .actions .im-form-group select:focus,.analytics kpis-bar>.kpis .actions .im-form-group textarea:focus{outline:0}.analytics kpis-bar>.kpis .actions .im-form-group input:focus~.im-control-label,.analytics kpis-bar>.kpis .actions .im-form-group select:focus~.im-control-label,.analytics kpis-bar>.kpis .actions .im-form-group textarea:focus~.im-control-label{color:#358fdc}.analytics kpis-bar>.kpis .actions .im-form-group input:focus~.im-bar::before,.analytics kpis-bar>.kpis .actions .im-form-group select:focus~.im-bar::before,.analytics kpis-bar>.kpis .actions .im-form-group textarea:focus~.im-bar::before{width:100%;left:0}.analytics kpis-bar>.kpis .actions .im-checkbox label,.analytics kpis-bar>.kpis .actions .im-form-radio label{position:relative;cursor:pointer;padding-left:2.5rem;text-align:left;color:#333;display:block}.analytics kpis-bar>.kpis .actions .im-checkbox input,.analytics kpis-bar>.kpis .actions .im-form-radio input{width:auto;opacity:.00000001;position:absolute;left:0}.analytics kpis-bar>.kpis .actions .im-radio{margin-bottom:1.25rem}.analytics kpis-bar>.kpis .actions .im-radio .im-helper{position:absolute;top:-.3125rem;left:-.3125rem;cursor:pointer;display:block;font-size:1.25rem;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;color:#999}.analytics kpis-bar>.kpis .actions .im-radio .im-helper::after,.analytics kpis-bar>.kpis .actions .im-radio .im-helper::before{content:'';position:absolute;left:0;top:0;margin:.3125rem;width:1.25rem;height:1.25rem;-webkit-transition:-webkit-transform .28s ease;transition:-webkit-transform .28s ease;transition:transform .28s ease;transition:transform .28s ease,-webkit-transform .28s ease;border-radius:50%;border:.15625rem solid currentColor}.analytics kpis-bar>.kpis .actions .im-radio .im-helper::after{-webkit-transform:scale(0);transform:scale(0);background-color:#358fdc;border-color:#358fdc}.analytics kpis-bar>.kpis .actions .im-radio label:hover .im-helper{color:#358fdc}.analytics kpis-bar>.kpis .actions .im-radio input:checked~.im-helper::after{-webkit-transform:scale(.5);transform:scale(.5)}.analytics kpis-bar>.kpis .actions .im-radio input:checked~.im-helper::before{color:#358fdc}.analytics kpis-bar>.kpis .actions .im-checkbox{margin-top:1.75rem;margin-bottom:1.25rem}.analytics kpis-bar>.kpis .actions .im-checkbox .im-helper{color:#999;position:absolute;top:0;left:0;width:1.25rem;height:1.25rem;z-index:0;border:.15625rem solid currentColor;border-radius:.078125rem;-webkit-transition:border-color .28s ease;transition:border-color .28s ease}.analytics kpis-bar>.kpis .actions .im-checkbox .im-helper::after,.analytics kpis-bar>.kpis .actions .im-checkbox .im-helper::before{position:absolute;height:0;width:.25rem;background-color:#358fdc;display:block;-webkit-transform-origin:left top;transform-origin:left top;border-radius:.3125rem;content:'';-webkit-transition:opacity .28s ease,height 0s linear .28s;transition:opacity .28s ease,height 0s linear .28s;opacity:0}.analytics kpis-bar>.kpis .actions .im-checkbox .im-helper::before{top:.8125rem;left:.475rem;-webkit-transform:rotate(-135deg);transform:rotate(-135deg);box-shadow:0 0 0 .078125rem #fff}.analytics kpis-bar>.kpis .actions .im-checkbox .im-helper::after{top:.375rem;left:0;-webkit-transform:rotate(-45deg);transform:rotate(-45deg)}.analytics kpis-bar>.kpis .actions .im-checkbox label:hover .im-helper{color:#358fdc}.analytics kpis-bar>.kpis .actions .im-checkbox input:checked~.im-helper{color:#358fdc}.analytics kpis-bar>.kpis .actions .im-checkbox input:checked~.im-helper::after,.analytics kpis-bar>.kpis .actions .im-checkbox input:checked~.im-helper::before{opacity:1;-webkit-transition:height .28s ease;transition:height .28s ease}.analytics kpis-bar>.kpis .actions .im-checkbox input:checked~.im-helper::after{height:.625rem}.analytics kpis-bar>.kpis .actions .im-checkbox input:checked~.im-helper::before{height:1.5rem;-webkit-transition-delay:.28s;transition-delay:.28s}.analytics kpis-bar>.kpis .actions .im-checkbox+.im-checkbox,.analytics kpis-bar>.kpis .actions .im-radio+.im-radio{margin-top:1.25rem}.analytics kpis-bar>.kpis .actions .im-messages{font-size:1.04166667rem;color:#e01f74;overflow:hidden;-webkit-transition:all .28s cubic-bezier(.55,0,.55,.2);transition:all .28s cubic-bezier(.55,0,.55,.2);opacity:0;margin-top:0;padding-top:5px}.analytics kpis-bar>.kpis .actions .has-error .legend.legend,.analytics kpis-bar>.kpis .actions .has-error.im-form-group .im-control-label.im-control-label{color:#e01f74}.analytics kpis-bar>.kpis .actions .has-error.im-checkbox .im-helper,.analytics kpis-bar>.kpis .actions .has-error.im-checkbox .im-messages,.analytics kpis-bar>.kpis .actions .has-error.im-form-group .im-helper,.analytics kpis-bar>.kpis .actions .has-error.im-form-group .im-messages,.analytics kpis-bar>.kpis .actions .has-error.im-form-radio .im-helper,.analytics kpis-bar>.kpis .actions .has-error.im-form-radio .im-messages,.analytics kpis-bar>.kpis .actions .has-error.im-radio .im-helper,.analytics kpis-bar>.kpis .actions .has-error.im-radio .im-messages{color:#e01f74;opacity:1}.analytics kpis-bar>.kpis .actions .has-error .im-bar::before{background:#e01f74;left:0;width:100%}.analytics kpis-bar>.kpis .actions .im-button{position:relative;background:#60a7e4;border:0;font-size:1.375rem;color:#333;margin:.7rem 0;padding:.4375rem 1.75rem;border-radius:3px;cursor:pointer;overflow:hidden;box-shadow:0 2px 2px 0 rgba(0,0,0,.14),0 3px 1px -2px rgba(0,0,0,.2),0 1px 5px 0 rgba(0,0,0,.12)}.analytics kpis-bar>.kpis .actions .im-button span{color:#fff;position:relative;z-index:1}.analytics kpis-bar>.kpis .actions .im-button:hover{-webkit-transition:background .1s ease-in;transition:background .1s ease-in;background:#2583d3}.analytics kpis-bar>.kpis .actions .im-button:active{box-shadow:inset 0 2px 2px 0 rgba(0,0,0,.14)}.analytics kpis-bar>.kpis .actions .im-button a:focus,.analytics kpis-bar>.kpis .actions .im-button:focus{outline:0;text-decoration:none}.analytics kpis-bar>.kpis .actions button.im-fab{position:relative;height:46px;width:46px;-webkit-box-flex:0;-ms-flex:0 0 56px;flex:0 0 56px;display:inline-block;padding:0;margin:4px;border:0;border-radius:100%;overflow:hidden;font-size:20px;box-shadow:0 4px 5px 0 rgba(0,0,0,.14),0 1px 10px 0 rgba(0,0,0,.12),0 2px 4px -1px rgba(0,0,0,.2);color:#fff}.analytics kpis-bar>.kpis .actions button.im-fab:focus{outline:0}.analytics kpis-bar>.kpis .actions button.im-fab:active{box-shadow:inset 0 2px 2px 0 rgba(0,0,0,.14)}.analytics kpis-bar>.kpis .actions button.im-fab.im-primary{background:#358fdc}.analytics kpis-bar>.kpis .actions button.im-fab.im-primary:hover{-webkit-transition:background .1s ease-in;transition:background .1s ease-in;background:#2583d3}.analytics kpis-bar>.kpis .actions button.im-fab.im-warn{background:#e01f74}.analytics kpis-bar>.kpis .actions button.im-fab.im-warn:hover{-webkit-transition:background .1s ease-in;transition:background .1s ease-in;background:#ca1c68}.analytics kpis-bar>.kpis .actions a{color:#fff}.analytics kpis-bar>.kpis .actions button.im-fab.add-kpis,.analytics kpis-bar>.kpis .actions button.im-fab.edit-kpis,.analytics kpis-bar>.kpis .actions button.im-fab.toggle-show-content{position:absolute;width:40px;height:40px;font-size:18px;-webkit-transition:all .28s ease-in;transition:all .28s ease-in}.analytics kpis-bar>.kpis .actions button.im-fab.add-kpis.im-primary,.analytics kpis-bar>.kpis .actions button.im-fab.edit-kpis.im-primary,.analytics kpis-bar>.kpis .actions button.im-fab.toggle-show-content.im-primary{background:#4c4749}.analytics kpis-bar>.kpis .actions button.im-fab.add-kpis.im-primary.disabled,.analytics kpis-bar>.kpis .actions button.im-fab.edit-kpis.im-primary.disabled,.analytics kpis-bar>.kpis .actions button.im-fab.toggle-show-content.im-primary.disabled{background:#b2b5c1;cursor:not-allowed}.analytics kpis-bar>.kpis .actions button.im-fab.add-kpis.im-primary.disabled a,.analytics kpis-bar>.kpis .actions button.im-fab.edit-kpis.im-primary.disabled a,.analytics kpis-bar>.kpis .actions button.im-fab.toggle-show-content.im-primary.disabled a{cursor:not-allowed}.analytics kpis-bar>.kpis .actions button.im-fab.add-kpis.im-primary:hover:not(.disabled),.analytics kpis-bar>.kpis .actions button.im-fab.edit-kpis.im-primary:hover:not(.disabled),.analytics kpis-bar>.kpis .actions button.im-fab.toggle-show-content.im-primary:hover:not(.disabled){background:#000}.analytics kpis-bar>.kpis .actions button.im-fab.toggle-show-content{top:-15px;right:-15px;z-index:10}@media screen and (max-width:675px){.analytics kpis-bar>.kpis .actions button.im-fab.toggle-show-content{top:-30px;right:-14px;bottom:0}}.analytics kpis-bar>.kpis .actions button.im-fab.add-kpis{top:30px;right:-15px;z-index:10}@media screen and (max-width:675px){.analytics kpis-bar>.kpis .actions button.im-fab.add-kpis{top:-30px;right:33px;bottom:0}}.analytics kpis-bar>.kpis .actions button.im-fab.edit-kpis{top:75px;right:-15px;z-index:10}.analytics kpis-bar>.kpis .actions button.im-fab.edit-kpis.editing{background:#358fdc}.analytics kpis-bar>.kpis .actions button.im-fab.edit-kpis.editing:hover:not(.disabled){background:#76b3e7}@media screen and (max-width:675px){.analytics kpis-bar>.kpis .actions button.im-fab.edit-kpis{top:-30px;right:79px;bottom:0}.analytics kpis-bar>.kpis .content{margin-top:25px}}.analytics kpis-bar>.kpis .content-buttons{position:absolute;top:0;right:0}.analytics kpis-bar>.kpis .content{padding:15px;background-color:#fff;box-shadow:0 1px 8px -4px}@media screen and (min-width:725px){.analytics kpis-bar>.kpis .content{padding:0 60px}}.analytics kpis-bar>.kpis .content .impac-kpi{padding-left:5px;padding-right:5px}@media screen and (min-width:1200px){.analytics kpis-bar>.kpis .content .impac-kpi{padding-left:20px;padding-right:20px}}.analytics kpis-bar>.kpis .content .impac-kpi .kpi.add .kpi-show .caption{white-space:inherit}.analytics kpis-bar>.kpis .content .title .text-center{line-height:3;font-variant:small-caps;font-size:larger}.analytics kpis-bar>.kpis .content .title .badge{position:absolute;top:8px;left:-10px;background-color:#d1e55c;color:#4f5959;box-shadow:0 1px 3px -1px}.widget-item .content,.widget-item .top-line{position:relative;background-color:#fff;box-shadow:0 1px 8px -4px}.analytics kpis-bar>.kpis .content .title .no-kpi-templates{color:#afadb5;font-weight:500}.analytics kpis-bar>.kpis .content .add-bar{border-bottom:dashed 1px}.analytics kpis-bar>.kpis .content .kpi-loader{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;min-height:115px}.analytics kpis-bar>.kpis .content .dates-picker-container{width:40%;margin:0 auto}.analytics kpis-bar>.kpis .content .dates-picker-container .sdp-from-label,.analytics kpis-bar>.kpis .content .dates-picker-container .sdp-to-label{text-transform:uppercase;font-weight:400}.analytics kpis-bar{display:block}.analytics kpis-bar>.key-stats{background-color:#fff;padding:5px 0}.analytics.pdf-mode kpis-bar>.kpis .actions{display:none}.widget-item{-webkit-transition:width .3s;transition:width .3s;padding:12px}.widget-item.pdf-mode{width:100%;padding:12px 0}.widget-item .top-line{cursor:move;padding:9px 9px 0 12px;border-radius:5px 5px 0 0;border:1px solid #c8d7d9;border-bottom:none;min-height:41px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row;z-index:4}.widget-item .content{padding:9px;border-radius:0 0 5px 5px;border:1px solid #c8d7d9;border-top:none;vertical-align:top;min-height:250px}@media (min-width:992px){.widget-item .content{height:250px}.widget-item .content .chart-container{max-width:270px;max-height:125px;margin:auto}}.widget-item .content .edit{max-height:230px;overflow-y:auto;overflow-x:hidden;color:#5B6667;padding:2px;font-size:12px}.widget-item .content .edit .bottom-buttons .btn{border-radius:2px;margin-right:5px;padding:3px 13px;text-transform:uppercase;font-size:12px}.widget-item .content .edit .bottom-buttons .btn.btn-default{background-color:#c2c4c4;border:1px solid #a8abab;color:#fff}.widget-item .content .edit .bottom-buttons .btn.btn-default:hover{border:1px solid #8e9292;background-color:#a8abab}.widget-item .content .edit h4{margin:0 0 8px;text-align:left;font-weight:400;font-size:12px;color:#c4caca}.widget-item .content .edit .part{margin-bottom:8px;padding:10px 0;background-color:#fcfcfc;border:1px solid #dfe2e2}.widget-item .content .edit .part h5{display:block;margin:0 0 10px;padding:0 15px;text-transform:uppercase;font-weight:400;font-size:12px;color:#c4caca}.widget-item .content .edit .part label{font-weight:400}.widget-item .content .edit .part select.form-control{margin:0;border:1px solid #acb0b1;outline:0;-webkit-box-shadow:none;font-size:13px;color:#72728b}.widget-item .content.accessible{height:auto!important;min-height:250px!important;max-height:auto!important}.widget-item .content .content-template-wrapper{height:100%;overflow:auto;overflow-x:hidden}.widget-item.pdf-mode .content{height:100%!important;min-height:250px!important;max-height:none!important}.widget-item.pdf-mode .content .collapse{display:inherit}.widget-item.pdf-mode .content .fa-plus-square-o:before{content:"\f147"}.widget-item.pdf-mode .content .legend{max-height:none!important}.widget-item.pdf-mode .content .chart-container{max-height:none}.widget-item.pdf-mode .content .widget-lines-container{max-height:none!important}.widget-item.pdf-mode .content .data-not-found .message{position:inherit;width:100%}.widget-item.pdf-mode .include-to-pdf.title{position:absolute;width:calc(100% - 2*12px);z-index:3;padding-right:1px}.widget-item.pdf-mode .include-to-pdf.title h6{padding:10px;background-color:#FFC928;text-align:center;margin:0}.widget-item.pdf-mode .include-to-pdf.tick i{position:absolute;top:35%;left:46%;font-size:100px;opacity:.5;z-index:2;color:#000}.widget-item.pdf-mode .include-to-pdf .widget-hover{position:absolute;width:100%;height:100%;padding:9px;top:0;right:0;-webkit-transition:all ease .5s;transition:all ease .5s;z-index:1}.widget-item.pdf-mode .include-to-pdf .widget-hover:hover{opacity:.5;background:#CCCFD0}.widget-item .widget-lines-container .widget-line>[class*=col-]{overflow-wrap:break-word}.analytics .kpi .data-not-found,.analytics .widget-item .content .data-not-found{text-align:center;font-size:13px;color:#5B6667}.analytics .kpi .data-not-found .overlay,.analytics .widget-item .content .data-not-found .overlay{background-color:#fff;position:absolute;height:calc(100% - 4px);width:calc(100% - 4px);top:2px;left:2px;opacity:.6;z-index:3}.analytics .kpi .data-not-found .message,.analytics .widget-item .content .data-not-found .message{position:absolute;top:125px;left:50%;padding-bottom:10px;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);width:85%;background-color:#f4f8f9;border-radius:4px;box-shadow:0 0 25px 0;z-index:4}.analytics .kpi .data-not-found .message .title,.analytics .widget-item .content .data-not-found .message .title{padding:2px;background-color:#192831;color:#fff;margin:-1px -1px 10px;text-transform:uppercase}.analytics .kpi .data-not-found .message p,.analytics .widget-item .content .data-not-found .message p{margin-left:5px;margin-right:5px}.analytics .kpi .data-not-found .message .btn,.analytics .widget-item .content .data-not-found .message .btn{margin-top:5px}.analytics .kpi .data-not-found .example,.analytics .widget-item .content .data-not-found .example{position:absolute;bottom:0;left:0;width:100%;color:#fff;background-color:#192831;padding:3px;z-index:6}.analytics .kpi .data-not-found .example a,.analytics .widget-item .content .data-not-found .example a{font-weight:400;color:#dae173}.analytics .kpi .data-not-found .message{width:90%;padding-bottom:0;border:1px solid silver;box-shadow:none}.analytics .kpi .data-not-found .message p{margin:5px}.analytics .kpi .data-not-found .btn,.analytics .kpi .data-not-found .example,.analytics .kpi .data-not-found .overlay,.analytics .kpi .data-not-found .title{display:none}#duplicate-transactions-list .top{height:40px}#duplicate-transactions-list .top a.back-link{font-weight:400}#duplicate-transactions-list .top .pagination{margin:0}#duplicate-transactions-list .table-striped tr.origin:nth-of-type(odd){background-color:#f9f9f9}#duplicate-transactions-list .table-container{max-height:calc(565px - 60px);overflow:auto}#duplicate-transactions-list .table-container div[uib-datepicker-popup-wrap]{display:inline-block}#duplicate-transactions-list .table-container button.btn.reset-date,#duplicate-transactions-list .table-container input.btn.btn-xs{margin-top:-2px}#duplicate-transactions-list .table-container .fa.fa-times{color:#e01f74;cursor:pointer}#duplicate-transactions-list .table-container tr.total{font-weight:700}#duplicate-transactions-list .table-container tr.total.invoices{background-color:#00e600}#duplicate-transactions-list .table-container tr.total.bills{background-color:#f57cb1}#transactions-add{text-align:center;font-size:13px;color:#5B6667}#transactions-add .overlay{background-color:#fff;position:absolute;height:calc(100% - 4px);width:calc(100% - 4px);top:2px;left:2px;opacity:.6;z-index:5}#transactions-add .message{z-index:6;position:absolute;min-height:160px;padding-bottom:10px;background-color:#f4f8f9;border-radius:4px;box-shadow:0 0 25px 0;top:30px;left:35%;width:30%}#transactions-add .message .title{padding:2px;background-color:#192831;color:#fff;margin:-1px -1px 10px;text-transform:uppercase}#transactions-add .message .form{padding:0 10px}#transactions-add .message .form .schedulable-section>label,#transactions-add .message .form>label{padding-top:10px;font-weight:400;margin-bottom:3px}#transactions-add .message .form input.form-control,#transactions-add .message .form select.form-control{width:90%;border-radius:2px;height:28px;font-size:13px}#transactions-add .message .form .btn-group{display:block;min-height:22px}#transactions-add .message .form .btn-group select{border-radius:2px;height:28px;margin-top:0}#transactions-add .message .form .repeat-btn select,#transactions-add .message .form .schedulable-section .btn-group select{height:22px}#transactions-add .message .form .disable{color:#888;font-style:italic}#transactions-add .message .form .never-disable{color:#000;font-style:normal}#transactions-add .message .form .repeat-btn{margin-top:30px}#transactions-add .message .form .repeat-btn input[type=checkbox]{vertical-align:text-bottom;margin:0}#transactions-add .message .form .repeat-btn .btn{float:none;border-color:#888}#transactions-add .message .form .schedulable-section{padding:5px;border:1px solid silver;margin-top:0;background-color:#fff}#transactions-add .message .form .schedulable-section .badge{font-weight:400;background-color:#888}#transactions-add .message .form .schedulable-section .interval-field{width:40px}#transactions-add .message .form .schedulable-section .btn-group{margin-left:10px}#transactions-add .message .form .schedulable-section .btn-group .btn{float:none;border-color:#888}#transactions-add .message .bottom{margin-top:20px}#transactions-list .top{height:40px;position:relative}#transactions-list .top .back{position:absolute}#transactions-list .top .resource-type{position:absolute;left:calc(50% - 98px)}@media (max-width:767px){#transactions-list .top .resource-type{left:unset;right:0}}#transactions-list .top .btn-group{display:-webkit-box;display:-ms-flexbox;display:flex}#transactions-list .bottom{height:40px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}#transactions-list .bottom .pagination{margin:0}#transactions-list .table-container td>.expected-payment-date .reset-date,.analytics .widget-item .content.accounts-assets-vs-liabilities .legend>.title span{margin-left:3px}#transactions-list .table-container{max-height:calc(565px - 100px);overflow:auto;width:100%}#transactions-list .table-container div[uib-datepicker-popup-wrap]{display:inline-block}#transactions-list .table-container button.btn.reset-date,#transactions-list .table-container input.btn.btn-xs{margin-top:-2px}#transactions-list .table-container .actions{cursor:pointer}#transactions-list .table-container .actions .fa.fa-times{color:#e01f74}#transactions-list .table-container tr.total{font-weight:700}#transactions-list .table-container tr.total.invoices{background-color:#c1d1b1}#transactions-list .table-container tr.total.bills{background-color:#e2aeb9}#transactions-list .table-container td>.expected-payment-date{display:-webkit-box;display:-ms-flexbox;display:flex}#trends-add{text-align:center;font-size:13px;color:#5B6667}#trends-add .overlay{background-color:#fff;position:absolute;height:calc(100% - 4px);width:calc(100% - 4px);top:2px;left:2px;opacity:.6;z-index:5}#trends-add .message{z-index:6;position:absolute;min-height:160px;padding-bottom:10px;background-color:#f4f8f9;border-radius:4px;box-shadow:0 0 25px 0;top:30px;left:35%;width:30%}#trends-add .message .title{padding:2px;background-color:#192831;color:#fff;margin:-1px -1px 10px;text-transform:uppercase}#trends-add .message .form{padding:0 10px}#trends-add .message .form>label{padding-top:10px;font-weight:400;margin-bottom:3px}#trends-add .message .form input.form-control{width:90%;border-radius:2px;height:28px;font-size:13px}#trends-add .message .form .btn-group{display:block;min-height:22px;margin-top:10px}#trends-add .message .form .btn-group>.btn{float:none}#trends-add .message .form .btn-group input[type=radio]{margin:4px 0 10px}#trends-add .message .bottom{margin-top:20px}#trends-list .top{height:40px}#trends-list .top a.back-link{font-weight:400}#trends-list .top .pagination{margin:0}#trends-list .table-container{max-height:calc(565px - 60px);overflow:auto}#trends-list .table-container div[uib-datepicker-popup-wrap]{display:inline-block}#trends-list .table-container button.btn.reset-date,#trends-list .table-container input.btn.btn-xs{margin-top:-2px}.analytics .dashboard-settings.currency{text-align:right}.analytics .dashboard-settings.currency select{margin-top:4px}.analytics .dashboard-settings.sync-apps .show-status{margin-right:5px;color:#9ba6a7}.analytics .dashboard-settings.sync-apps .show-status:hover{cursor:pointer;text-decoration:underline}.analytics .dashboard-settings.sync-apps .show-status .fa.fa-info{margin-right:2px}.analytics .dashboard-settings.sync-apps .status-btn{display:inline-block;cursor:pointer;padding:5px 7px 5px 0}.analytics .dashboard-settings.sync-apps .status-btn i{font-size:16px}.analytics .dashboard-settings.sync-apps .status-btn i.fa-exclamation-triangle{color:#ff7300}.analytics .dashboard-settings.sync-apps .status-btn i.fa-check{color:#d1e55c}.analytics .dashboard-settings.sync-apps .popover{max-width:550px}.analytics .dashboard-settings.sync-apps .popover .connector{padding:4px 13px}.analytics .dashboard-settings.sync-apps .popover .connector.add-seperator{border-bottom:1px solid #ccc}.analytics .dashboard-settings.sync-apps .popover .popover-content{padding:0}.analytics .dashboard-settings.sync-apps .popover .popover-footer{border-top:1px solid #ccc;padding:4px 13px}.analytics .dashboard-settings.sync-apps .popover .popover-footer p{font-weight:700;margin:0}.analytics .dashboard-settings.sync-apps .popover .popover-footer.remove-seperator{border:0}.analytics .dashboard-settings.sync-apps .badge{float:right;margin-left:8px}.analytics .dashboard-settings.sync-apps .success .badge{background-color:#d1e55c}.analytics .dashboard-settings.sync-apps .pending .badge,.analytics .dashboard-settings.sync-apps .running .badge{background-color:#ff7300}.analytics .dashboard-settings.sync-apps .disconnected .badge,.analytics .dashboard-settings.sync-apps .error .badge,.analytics .dashboard-settings.sync-apps .failed .badge,.analytics .dashboard-settings.sync-apps .unknown .badge{background-color:#ed1e79}#sync-apps-modal .modal-header{text-align:center;border:0;box-shadow:0 2px 3px 0 #ccc}#sync-apps-modal .modal-list{max-height:280px;overflow-y:auto}#sync-apps-modal .modal-list-item{border-bottom:1px solid #ccc;padding:10px}#sync-apps-modal .modal-list-item .badge{float:right}#sync-apps-modal .modal-list-item.success .badge{background-color:#d1e55c}#sync-apps-modal .modal-list-item.pending .badge,#sync-apps-modal .modal-list-item.running .badge{background-color:#ff7300}#sync-apps-modal .modal-list-item.disconnected .badge,#sync-apps-modal .modal-list-item.error .badge,#sync-apps-modal .modal-list-item.failed .badge,#sync-apps-modal .modal-list-item.unknown .badge{background-color:#ed1e79}#sync-apps-modal .modal-list-item .message{padding:3px;border-radius:2px;margin-left:31px;margin-top:9px}#sync-apps-modal .modal-list-item .message p{margin:0}#sync-apps-modal .modal-list-item.success .message{background-color:rgba(0,255,55,.08)}#sync-apps-modal .modal-list-item.pending .message,#sync-apps-modal .modal-list-item.running .message{background-color:rgba(255,118,0,.08)}#sync-apps-modal .modal-list-item.disconnected .message,#sync-apps-modal .modal-list-item.error .message,#sync-apps-modal .modal-list-item.failed .message,#sync-apps-modal .modal-list-item.unknown .message{background-color:rgba(255,0,0,.08)}#sync-apps-modal .modal-list-item.with-message{cursor:pointer}#sync-apps-modal .modal-list-item.with-message:hover{background-color:#ccc}#sync-apps-modal .modal-footer{border:0}#sync-apps-modal .fa{padding:0 10px}#sync-apps-modal .fa.error{color:red}#sync-apps-modal .fa.warn{color:#ff7300}#sync-apps-modal .fa.success{color:#47ff00}chart-threshold .attach-panel{padding:5px 0;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:baseline;-ms-flex-align:baseline;align-items:baseline;background-color:rgba(20,132,228,.16)}chart-threshold .attach-panel>div{padding-right:5px}chart-threshold .attach-panel>div.target{text-align:center}@media (max-width:1199px){chart-threshold .attach-panel{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-align:center;-ms-flex-align:center;align-items:center}chart-threshold .attach-panel>div{padding:5px}}chart-threshold .attach-panel .text{text-transform:uppercase;font-weight:700;color:#5B6667;font-size:13px}chart-threshold .attach-panel input{border-radius:3px;border:1px #fff;padding:3px}chart-threshold .attach-panel input[name=amount]{max-width:70px}chart-threshold .attach-panel .currency{font-weight:700;color:#000}chart-threshold .attach-panel .actions{display:inline-block;padding:0 2px}chart-threshold .attach-panel .actions button{padding:3px 6px;display:inline-block}chart-threshold .attach-panel .actions button.loading{padding:3px 20px}.analytics widgets-common-confirm-modal{text-align:center;font-size:13px;color:#5B6667}.analytics widgets-common-confirm-modal .overlay{background-color:#fff;position:absolute;height:calc(100% - 4px);width:calc(100% - 4px);top:2px;left:2px;opacity:.6;z-index:5}.analytics widgets-common-confirm-modal .message{z-index:6;position:absolute;min-height:160px;padding-bottom:10px;top:45px;left:7%;width:86%;background-color:#f4f8f9;border-radius:4px;box-shadow:0 0 25px 0;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between}.analytics widgets-common-confirm-modal .message .title{padding:2px;background-color:#192831;color:#fff;margin:-1px -1px 10px;text-transform:uppercase}.analytics widgets-common-confirm-modal .message p{padding:0 10px}.analytics widgets-common-confirm-modal .message button.btn{margin-top:20px}.analytics widgets-common-confirm-modal .message .loader i.fa.fa-spinner{font-size:26px}.currency-conversions img{width:15px;cursor:pointer}.currency-conversions.popover .popover-title{background-color:#000;color:#fff}.analytics .widget-item .editable-title{width:100%;-webkit-box-flex:1;-ms-flex:1;flex:1;overflow:hidden;height:22px}.analytics .widget-item .editable-title .title{text-transform:uppercase;font-weight:600;font-size:12px;color:#4f5959;cursor:text;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;line-height:1.9}.analytics .widget-item .editable-title .editable-wrap{position:relative;height:20px;min-width:100%;white-space:nowrap}.analytics .widget-item .editable-title .editable-wrap .editable-controls{min-width:100%}.analytics .widget-item .editable-title .editable-wrap .editable-controls .editable-input{height:20px;font-size:12px;text-transform:uppercase;width:calc(100% - 65px);padding:0 3px}.analytics .widget-item .editable-title .editable-wrap .editable-controls .editable-buttons{background-color:#fff}.analytics .widget-item .editable-title .editable-wrap .editable-controls .editable-buttons button{margin:0 0 0 5px;height:20px;padding:0 5px}.analytics .widget-item .info-panel{position:absolute;top:15px;left:15px;width:calc(100% - 30px);max-height:calc(100% - 30px);height:100%;background-color:#fff;border:1px dotted #B7CDCE;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;font-family:"Lato Semibold",Lato;z-index:4}.analytics .widget-item .info-panel:hover{opacity:1}.analytics .widget-item .info-panel .i-header{background-color:#FFC928;color:#1E303B;padding:8px;text-transform:uppercase;font-family:"Lato Medium",Lato;font-size:12px}.analytics .widget-item .info-panel .i-header .fa{font-size:18px}.analytics .widget-item .info-panel .i-header .fa-info-circle{float:left}.analytics .widget-item .info-panel .i-header .fa-times-circle{cursor:pointer;float:right}.analytics .widget-item .info-panel .i-content{overflow-y:auto;overflow-x:hidden;padding:5px;text-align:justify;-webkit-box-flex:1;-ms-flex:1;flex:1}.analytics .widget-item .info-panel .i-content .row{margin-bottom:6px;padding-bottom:6px;border-bottom:solid 1px #abc4c6}.analytics .widget-item .info-panel .i-content .row:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.analytics .widget-item .info-panel .i-content .row .key{text-align:right;font-variant:small-caps}@media (max-width:991px){.analytics .widget-item .info-panel .i-content .row .key{text-align:center}}.analytics .widget-item .info-panel .i-content .row .value{text-align:justify}.analytics .time-period-info{font-size:11px;color:#ABC4C6;text-transform:uppercase}.analytics .widget-item .top-line .top-buttons{text-align:right;margin-top:-1px;white-space:nowrap;padding-left:10px}.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-export,.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-info,.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-refresh{font-size:17px;margin-top:1px}.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button{background:0 0;border:none;color:#c4caca;padding:0;outline:0;width:17px}.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button:active,.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button:focus{box-shadow:none}.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-info:hover{color:#FFC928}.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-export:hover,.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-refresh:hover{color:#358fdc}.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-close,.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-edit{font-size:13px}.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-edit.edit-mode,.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-edit:hover{color:#cfd849}.analytics .widget-item .top-line .top-buttons .top-buttons-wrapper .top-button.btn-close:hover{color:#ed1e79}.analytics .widget-item .content.accounts-assets-liability-summary .param-selector{text-align:center}.analytics .widget-item .content.accounts-assets-liability-summary .legend{text-align:left;max-height:90px}.analytics .widget-item .content.accounts-assets-liability-summary .legend .title{text-align:center;border-bottom:dashed 1px #dfe2e2}.analytics .widget-item .content.accounts-assets-summary .legend{text-align:left;max-height:115px}.analytics .widget-item .content.accounts-assets-summary .legend .title{text-align:center;border-bottom:dashed 1px #dfe2e2}.analytics .widget-item .content.accounts-balance h3{font-weight:300;font-size:14px;color:#5B6667;margin-top:30px;text-align:center}.analytics .widget-item .content.accounts-balance .price{font-weight:900;font-size:22px;color:#5B6667;text-align:center;margin-top:0}.analytics .widget-item .content.accounts-balance-sheet{min-height:565px}@media (min-width:992px){.analytics .widget-item .content.accounts-balance-sheet{height:565px}.analytics .widget-item .content.accounts-balance-sheet .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.accounts-balance-sheet .edit{max-height:545px}.analytics .widget-item .content.accounts-balance-sheet .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.accounts-balance-sheet .widget-lines-container{overflow-y:scroll;overflow-x:hidden;max-height:490px}@media (max-width:767px){.analytics .widget-item .content.accounts-balance-sheet .widget-lines-container .row.widget-line:not(:last-child){border-bottom:dashed 1px #dfe2e2}}.analytics .widget-item .content.accounts-balance-sheet .widget-lines-container .row.widget-line.header>[class*=col-]{position:static}.analytics .widget-item .content.accounts-balance-sheet .widget-lines-container.no-scroll{overflow:visible}.analytics .widget-item .content.accounts-balance-sheet .no-data-block{font-weight:300;font-size:16px;color:#5B6667;text-align:center;margin:15px 0}.analytics .widget-item .content.accounts-cash-balance{min-height:565px}@media (min-width:992px){.analytics .widget-item .content.accounts-cash-balance{height:565px}.analytics .widget-item .content.accounts-cash-balance .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.accounts-cash-balance .edit{max-height:545px}.analytics .widget-item .content.accounts-cash-balance .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.accounts-cash-balance .data-container{height:calc(565px - 50px);width:100%}.analytics .widget-item .content.accounts-cash-balance .left-panel{width:180px;display:inline-block;overflow:auto;max-height:100%}.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;min-height:45px;margin:3px;font-size:13px;padding:3px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.analytics .widget-item .content.accounts-cash-projection,.analytics .widget-item .content.accounts-cash-summary,.analytics .widget-item .content.accounts-comparison,.analytics .widget-item .content.accounts-detailed-classifications,.analytics .widget-item .content.accounts-invoices-list{min-height:565px}.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item:hover{background-color:#ececec}.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item i{font-size:19px;padding:4px;margin-top:1px}.analytics .widget-item .content.accounts-cash-balance #cash-balance-legend .header .group-item span{color:#5B6667}.analytics .widget-item .content.accounts-cash-balance .legend-item-icon{width:16px;height:16px}.analytics .widget-item .content.accounts-cash-balance .right-panel{width:calc(100% - 180px);float:right}.analytics .widget-item .content.accounts-cash-balance .right-panel .cash-balance-chart{height:calc(565px - 50px)}.analytics .widget-item .content.accounts-cash-balance .dates-picker{display:inline-block;float:right;font-size:12px}@media (min-width:992px){.analytics .widget-item .content.accounts-cash-projection{height:565px}.analytics .widget-item .content.accounts-cash-projection .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.accounts-cash-projection .edit{max-height:545px}.analytics .widget-item .content.accounts-cash-projection .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.accounts-cash-projection .cash-projection-chart{height:calc(565px - 50px)}.analytics .widget-item .content.accounts-cash-projection .highcharts-legend-item rect.highcharts-point{display:none}.analytics .widget-item .content.accounts-cash-projection .highcharts-legend-item span{width:110px;text-align:center}.analytics .widget-item .content.accounts-cash-projection .highcharts-legend-item span img{text-align:center;width:55px;height:25px}.analytics .widget-item .content.accounts-cash-projection .dates-picker{display:inline-block;float:right;font-size:12px}.analytics .widget-item .content.accounts-cash-projection transactions-list{font-size:12px}@media (min-width:992px){.analytics .widget-item .content.accounts-cash-summary{height:565px}.analytics .widget-item .content.accounts-cash-summary .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.accounts-cash-summary .edit{max-height:545px}.analytics .widget-item .content.accounts-cash-summary .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.accounts-cash-summary .widget-lines-container{max-height:540px}.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line{cursor:pointer;border:1px solid #fff}.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line .selection-tag{display:block;right:0;margin-top:-6px;width:10px;height:29px;position:absolute}.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line:hover{background-color:#e6e0fb}.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line.no-select{cursor:auto}.analytics .widget-item .content.accounts-cash-summary .widget-lines-container .lines-group .widget-line.no-select:hover{color:#626d6d}.analytics .widget-item .content.accounts-cash-summary .right-panel .widget-lines-container{overflow-y:auto;overflow-x:hidden;max-height:215px}.analytics .widget-item .content.accounts-cash-summary .no-element{font-weight:300;font-size:16px;color:#5B6667;text-align:center}.analytics .widget-item .content.accounts-cash-summary .row.lines-group.cash{border-top:solid 1px;border-bottom:double}.analytics .widget-item .content.accounts-class-comparison .param-selector{text-align:center}.analytics .widget-item .content.accounts-class-comparison .widget-lines-container{max-height:94px;color:#626d6d}@media (min-width:992px){.analytics .widget-item .content.accounts-comparison{height:565px}.analytics .widget-item .content.accounts-comparison .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.accounts-comparison .edit{max-height:545px}.analytics .widget-item .content.accounts-comparison .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}@media print{.analytics .widget-item .content.accounts-comparison .chart-container{max-width:80%!important}}.analytics .widget-item .content.accounts-comparison .add-account{position:absolute;right:40px;bottom:30px;width:160px}.analytics .widget-item .content.accounts-comparison .add-account select{font-size:13px;background-color:#977bf0;color:#fff;outline:0;border:none;cursor:pointer}.analytics .widget-item .content.accounts-comparison .add-account select[disabled]{cursor:not-allowed;background-color:#bba9f5}.analytics .widget-item .content.accounts-comparison .add-account select[disabled]:hover{background-color:#bba9f5}.analytics .widget-item .content.accounts-comparison .add-account select:hover{background-color:#734deb}.analytics .widget-item .content.accounts-comparison .add-account select option{background-color:#fff;color:#c4caca}.analytics .widget-item .content.accounts-comparison .add-account select option[disabled]{color:#fff}.analytics .widget-item .content.accounts-comparison button.close{font-size:15px}.analytics .widget-item .content.accounts-comparison .legend{text-align:left;max-height:103px}.analytics .widget-item .content.accounts-comparison .row{margin:0}.analytics .widget-item .content.accounts-comparison .widget-lines-container{font-size:11px;max-height:220px;margin-bottom:65px;overflow:auto}.analytics .widget-item .content.accounts-comparison .settings.params-checkboxes{margin-left:13px}.analytics .widget-item .content.accounts-comparison .comparable-error h5{margin-left:13px;color:#ed1e79}.analytics .widget-item .content.accounts-custom-calculation h3{margin-top:85px;text-align:center;font-weight:700}.analytics .widget-item .content.accounts-custom-calculation .legend{max-height:125px}.analytics.modal-custom-calculation{margin:0;padding:0}.analytics.modal-custom-calculation .modal-body .edit{overflow-y:auto;overflow-x:hidden;color:#5B6667;font-size:12px;padding:5px;overflow:visible}.analytics.modal-custom-calculation .modal-body .edit .bottom-buttons .btn{border-radius:2px;margin-right:5px;padding:3px 13px;text-transform:uppercase;font-size:12px}.analytics.modal-custom-calculation .modal-body .edit .bottom-buttons .btn.btn-default{background-color:#c2c4c4;border:1px solid #a8abab;color:#fff}.analytics.modal-custom-calculation .modal-body .edit .bottom-buttons .btn.btn-default:hover{border:1px solid #8e9292;background-color:#a8abab}.analytics.modal-custom-calculation .modal-body .edit h4{margin:0 0 8px;text-align:left;font-weight:400;font-size:12px;color:#c4caca}.analytics.modal-custom-calculation .modal-body .edit .part{margin-bottom:8px;padding:10px 0;background-color:#fcfcfc;border:1px solid #dfe2e2}.analytics.modal-custom-calculation .modal-body .edit .part h5{display:block;margin:0 0 10px;padding:0 15px;text-transform:uppercase;font-weight:400;font-size:12px;color:#c4caca}.analytics.modal-custom-calculation .modal-body .edit .part label{font-weight:400}.analytics.modal-custom-calculation .modal-body .edit .part select.form-control{margin:0;border:1px solid #acb0b1;outline:0;-webkit-box-shadow:none;font-size:13px;color:#72728b}@media (min-width:992px){.analytics .widget-item .content.accounts-detailed-classifications{height:565px}.analytics .widget-item .content.accounts-detailed-classifications .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.accounts-detailed-classifications .edit{max-height:545px}.analytics .widget-item .content.accounts-detailed-classifications .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.accounts-detailed-classifications .widget-lines-container{overflow-y:scroll;overflow-x:hidden;max-height:540px}.analytics .widget-item .content.accounts-invoices-list .edit .widget-lines-container,.analytics .widget-item .content.accounts-profit-and-loss .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.accounts-detailed-classifications .account-class-title{margin-bottom:8px;margin-left:11px}.analytics .widget-item .content.accounts-detailed-classifications .time-period-info{text-align:right}.analytics .widget-item .content.accounts-detailed-classifications .widget-line.header.sorting{border-bottom:1px solid #ccc}.analytics .widget-item .content.accounts-expense-weight .legend{text-align:left;max-height:115px}.analytics .widget-item .content.accounts-expense-weight .legend .title{text-align:center}.analytics .widget-item .content.accounts-expenses-revenue .legend{font-weight:700}.analytics .widget-item .content.accounts-expenses-revenue .settings.params-checkboxes{font-size:12px;margin-left:0;text-align:center}@media (min-width:992px){.analytics .widget-item .content.accounts-invoices-list{height:565px}.analytics .widget-item .content.accounts-invoices-list .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.accounts-invoices-list .edit{max-height:545px}.analytics .widget-item .content.accounts-invoices-list transactions-list{font-size:12px}.analytics .widget-item .content.accounts-live-balance h3{font-weight:900;color:#5B6667;margin-top:0;font-size:18px;text-align:center;text-shadow:1px}.analytics .widget-item .content.accounts-live-balance .statement-title{font-size:13px;font-weight:400}.analytics .widget-item .content.accounts-live-balance .balance-title{font-size:12px}.analytics .widget-item .content.accounts-live-balance .currency-centered{font-weight:300;font-size:12px;color:#5B6667;text-align:center}.analytics .widget-item .content.accounts-live-balance .headers{text-align:center}.analytics .widget-item .content.accounts-live-balance .spacer{min-height:30px}.analytics .widget-item .content.accounts-profit-and-loss,.analytics .widget-item .content.hr-payroll-summary,.analytics .widget-item .content.invoices-aged-payables-receivables,.analytics .widget-item .content.sales-aged,.analytics .widget-item .content.sales-comparison,.analytics .widget-item .content.sales-forecast,.analytics .widget-item .content.sales-leads-funnel,.analytics .widget-item .content.sales-opportunities-funnel,.analytics .widget-item .content.sales-performance{min-height:565px}.analytics .widget-item .content.accounts-live-balance .price{font-weight:900;font-size:22px;color:#5B6667;text-align:center;margin-top:0}.analytics .widget-item .content.accounts-live-balance .come-back-later{text-align:center;font-size:11px;opacity:.8}.analytics .widget-item .content.accounts-live-balance .negative2{font-size:14px}.analytics .widget-item .content.accounts-payable-receivable h3{text-align:center}.analytics .widget-item .content.accounts-payable-receivable .legend{font-weight:700}.analytics .widget-item .content.accounts-payable-receivable .payable{margin-top:15px}.analytics .widget-item .content.accounts-payable-receivable .price{font-weight:900;font-size:22px;color:#5B6667;text-align:center;margin-top:0}@media (min-width:992px){.analytics .widget-item .content.accounts-profit-and-loss{height:565px}.analytics .widget-item .content.accounts-profit-and-loss .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.accounts-profit-and-loss .edit{max-height:545px}.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container{max-height:540px}.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line{cursor:pointer;border:1px solid #fff}.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line .selection-tag{display:block;right:0;margin-top:-6px;width:10px;height:29px;position:absolute}.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line:hover{background-color:#e6e0fb}.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line.no-select{cursor:auto}.analytics .widget-item .content.accounts-profit-and-loss .widget-lines-container .lines-group .widget-line.no-select:hover{color:#626d6d}.analytics .widget-item .content.accounts-profit-and-loss .right-panel .widget-lines-container{overflow-y:auto;overflow-x:hidden;max-height:215px}.analytics .widget-item .content.accounts-profit-and-loss .no-element{font-weight:300;font-size:16px;color:#5B6667;text-align:center}.analytics .widget-item .content.accounts-profit-and-loss .row.lines-group.profit{border-top:solid 1px;border-bottom:double}.analytics .widget-item .content.accounts-profit-and-loss .row.widget-line.header>[class*=col-]{position:static}.analytics .widget-item .content.accounts-ratios .left-panel{max-height:230px;overflow-y:auto}.analytics .widget-item .content.accounts-ratios .left-panel .separator{border-bottom:solid 1px #5B6667;width:75%}.analytics .widget-item .content.accounts-ratios .left-panel .member{padding-top:20px;padding-bottom:20px}.analytics .widget-item .content.accounts-ratios .left-panel .member .price{margin-top:0;font-size:18px}.analytics .widget-item .content.accounts-ratios .left-panel button{outline:0}.analytics .widget-item .content.accounts-ratios .left-panel.simulation .member{padding-top:5px}.analytics .widget-item .content.accounts-ratios .left-panel.simulation .member .legend{display:none}.analytics .widget-item .content.accounts-ratios .left-panel.simulation .member .price{text-align:right}.analytics .widget-item .content.accounts-ratios .left-panel.simulation .separator{width:100%}.analytics .widget-item .content.hr-employee-details{font-size:12px}.analytics .widget-item .content.hr-employee-details .details-container{padding:0;max-height:none;overflow-y:auto;overflow-x:hidden}.analytics .widget-item .content.hr-employee-details .right-panel .legend{margin-bottom:5px}.analytics .widget-item .content.hr-employee-details .title{text-align:center;margin-bottom:10px;font-size:14px}.analytics .widget-item .content.hr-employees-list .legend{margin-bottom:9px}.analytics .widget-item .content.hr-employees-list .widget-lines-container{text-align:center}.analytics .widget-item .content.hr-employees-list .widget-lines-container .widget-line:nth-child(even){background-color:#f0f0f0}.analytics .widget-item .content.hr-employees-list .widget-lines-container .widget-line:nth-child(odd){background-color:#fff}.analytics .widget-item .content.hr-employees-list .edit .widget-lines-container{text-align:left}.analytics .widget-item .content.hr-leaves-balance .employee-name{text-align:center}.analytics .widget-item .content.hr-leaves-balance .balance{font-weight:900;font-size:22px;color:#5B6667;text-align:center;margin-top:0}.analytics .widget-item .content.hr-leaves-balance h3{margin-top:33px;text-align:center}.analytics .widget-item .content.hr-leaves-schedule .fc-button{height:22px;font-size:12px;color:#977bf0;background:#fff;outline:0}.analytics .widget-item .content.hr-leaves-schedule .fc-button:hover{color:#fff;background:#977bf0}.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line:hover,.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line:hover{background-color:#e6e0fb}.analytics .widget-item .content.hr-leaves-schedule .fc-toolbar{margin-bottom:5px}.analytics .widget-item .content.hr-leaves-schedule .fc-day-grid,.analytics .widget-item .content.hr-leaves-schedule .fc-widget-header{font-size:12px;color:#5B6667}@media (min-width:992px){.analytics .widget-item .content.hr-employee-details .details-container{max-height:200px}.analytics .widget-item .content.hr-employee-details .right-panel .details-container{max-height:220px}.analytics .widget-item .content.hr-payroll-summary{height:565px}.analytics .widget-item .content.hr-payroll-summary .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.hr-salaries-summary h3.right,.analytics .widget-item .content.hr-workforce-summary h3.right{margin-bottom:10px;text-align:center}.analytics .widget-item .content.hr-payroll-summary .edit{max-height:545px}.analytics .widget-item .content.hr-payroll-summary .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.hr-payroll-summary .widget-lines-container{max-height:540px}.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line{cursor:pointer;border:1px solid #fff}.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line .selection-tag{display:block;right:0;margin-top:-6px;width:10px;height:29px;position:absolute}.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line.no-select{cursor:auto}.analytics .widget-item .content.hr-payroll-summary .widget-lines-container .lines-group .widget-line.no-select:hover{color:#626d6d}.analytics .widget-item .content.hr-payroll-summary .right-panel .widget-lines-container{overflow-y:auto;overflow-x:hidden;max-height:145px}.analytics .widget-item .content.hr-payroll-summary .no-element{font-weight:300;font-size:16px;color:#5B6667;text-align:center}.analytics .widget-item .content.hr-salaries-summary h3.left{text-align:center}.analytics .widget-item .content.hr-salaries-summary h3.reduced-left{text-align:center}@media (min-width:992px){.analytics .widget-item .content.hr-salaries-summary h3.left{margin-top:69px}.analytics .widget-item .content.hr-salaries-summary h3.reduced-left{margin-top:10px}}.analytics .widget-item .content.hr-salaries-summary .price{margin-top:0}.analytics .widget-item .content.hr-salaries-summary .widget-lines-container{max-height:75px}.analytics .widget-item .content.hr-salaries-summary .widget-lines-container .widget-line{font-size:11px}.analytics .widget-item .content.hr-superannuation-accruals h3{margin-top:63px;text-align:center}.analytics .widget-item .content.hr-superannuation-accruals .legend{margin-top:23px}.analytics .widget-item .content.hr-superannuation-accruals .currency{font-size:14px}.analytics .widget-item .content.hr-superannuation-accruals .price{font-weight:900;font-size:22px;color:#5B6667;text-align:center;margin-top:0}.analytics .widget-item .content.hr-timesheets .currency{font-size:14px}.analytics .widget-item .content.hr-timesheets .widget-lines-container{max-height:210px}.analytics .widget-item .content.hr-workforce-summary h3.left{text-align:center}.analytics .widget-item .content.hr-workforce-summary h3.reduced-left{text-align:center}@media (min-width:992px){.analytics .widget-item .content.hr-workforce-summary h3.left{margin-top:69px}.analytics .widget-item .content.hr-workforce-summary h3.reduced-left{margin-top:10px}}.analytics .widget-item .content.hr-workforce-summary .price{margin-top:0}.analytics .widget-item .content.hr-workforce-summary .widget-lines-container{max-height:75px}.analytics .widget-item .content.hr-workforce-summary .widget-lines-container .widget-line{font-size:11px}@media (min-width:480px) and (max-width:991px){.analytics .widget-item .content.hr-salaries-summary .right-panel .chart-container,.analytics .widget-item .content.hr-workforce-summary .right-panel .chart-container{max-width:320px}}@media (min-width:992px){.analytics .widget-item .content.invoices-aged-payables-receivables{height:565px}.analytics .widget-item .content.invoices-aged-payables-receivables .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.invoices-aged-payables-receivables .edit{max-height:545px}.analytics .widget-item .content.invoices-aged-payables-receivables .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container{max-height:540px}.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line{cursor:pointer;border:1px solid #fff}.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line .selection-tag{display:block;right:0;margin-top:-6px;width:10px;height:29px;position:absolute}.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line.no-select{cursor:auto}.analytics .widget-item .content.invoices-aged-payables-receivables .widget-lines-container .lines-group .widget-line.no-select:hover{color:#626d6d}.analytics .widget-item .content.invoices-aged-payables-receivables .right-panel .widget-lines-container{overflow-y:auto;overflow-x:hidden;max-height:215px}.analytics .widget-item .content.sales-aged .edit .widget-lines-container,.analytics .widget-item .content.sales-comparison .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.invoices-aged-payables-receivables .no-element{font-weight:300;font-size:16px;color:#5B6667;text-align:center}.analytics .widget-item .content.invoices-aged-payables-receivables .row.astericks-info{margin-top:15px}.analytics .widget-item .content.invoices-aged-payables-receivables .currency-conversions{float:right;margin-left:3px}.analytics .widget-item .content.invoices-list .widget-lines-container{max-height:230px}.analytics .widget-item .content.invoices-list .widget-lines-container .widget-line:nth-child(even){background-color:#f0f0f0}.analytics .widget-item .content.invoices-list .widget-lines-container .widget-line:nth-child(odd){background-color:#fff}.analytics .widget-item .content.invoices-list .widget-lines-container .widget-line.header{background-color:#fff}.analytics .widget-item .content.invoices-list .currency-conversions{float:right;margin-right:3px;margin-top:-2px}.analytics .widget-item .content.invoices-list .fa.fa-info-circle{float:right;font-size:15px}.analytics .widget-item .content.invoices-list .right-column{padding-left:0;padding-right:0}.analytics .widget-item .content.invoices-summary .chart-container{max-width:410px}.analytics .widget-item .content.invoices-summary .legend{max-height:28px}@media (min-width:992px){.analytics .widget-item .content.sales-aged{height:565px}.analytics .widget-item .content.sales-aged .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.sales-aged .edit{max-height:545px}.analytics .widget-item .content.sales-aged .widget-lines-container{max-height:238px}.analytics .widget-item .content.sales-break-even .price{font-weight:900;font-size:22px;color:#5B6667;text-align:center;margin-top:0}.analytics .widget-item .content.sales-break-even .block{margin:5px;padding:0 10px 5px;text-align:left;box-shadow:0 7px 10px -7px #17262d;font-size:12px}.analytics .widget-item .content.sales-break-even .block form.editable-wrap .editable-controls input{margin-top:5px;width:100px}.analytics .widget-item .content.sales-break-even .block.to-date{background-color:#f0f0f0;color:#5B6667}.analytics .widget-item .content.sales-break-even .block.to-breakeven{margin-top:10px;background-color:#192831;color:#1de9b6}.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line:hover,.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main:hover{background-color:#e6e0fb}.analytics .widget-item .content.sales-break-even .block.to-breakeven .title{border-bottom:solid 1px #2a4453}.analytics .widget-item .content.sales-break-even .block.to-breakeven .define-text{font-weight:300;font-size:16px;text-align:center;padding-top:5px;color:#1de9b6}.analytics .widget-item .content.sales-break-even .block.to-breakeven .price{color:#1de9b6}.analytics .widget-item .content.sales-break-even .block .title{font-size:13px;text-align:center;font-variant:small-caps;border-bottom:solid 1px #e6edee;font-weight:300}@media (min-width:992px){.analytics .widget-item .content.sales-comparison{height:565px}.analytics .widget-item .content.sales-comparison .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.sales-comparison .edit{max-height:545px}.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line{cursor:pointer;border:1px solid #fff}.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line .selection-tag{display:block;right:0;margin-top:-6px;width:10px;height:29px;position:absolute}.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line.no-select{cursor:auto}.analytics .widget-item .content.sales-comparison .widget-lines-container .lines-group .widget-line.no-select:hover{color:#626d6d}.analytics .widget-item .content.sales-comparison .no-element{font-weight:300;font-size:16px;color:#5B6667;text-align:center}.analytics .widget-item .content.sales-comparison .widget-lines-container{max-height:530px}.analytics .widget-item .content.sales-comparison .right-panel .widget-lines-container{overflow-y:auto;overflow-x:hidden;max-height:250px}.analytics .widget-item .content.sales-comparison .currency-conversions img{margin-top:-2px}.analytics .widget-item .content.sales-customer-details{font-size:12px}.analytics .widget-item .content.sales-customer-details .loader{font-size:14px}.analytics .widget-item .content.sales-customer-details .details-container{padding:0;overflow-y:auto;overflow-x:hidden}.analytics .widget-item .content.sales-forecast .edit .widget-lines-container,.analytics .widget-item .content.sales-leads-funnel .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}@media (min-width:992px){.analytics .widget-item .content.sales-customer-details .details-container{max-height:194px}.analytics .widget-item .content.sales-customer-details .right-panel .details-container{max-height:230px}}.analytics .widget-item .content.sales-customer-details .right-panel .legend{margin-bottom:5px}.analytics .widget-item .content.sales-customer-details .row.title{text-align:center;margin-bottom:10px;font-size:14px}.analytics .widget-item .content.sales-customer-details .currency-conversions{float:left;margin-right:3px}.analytics .widget-item .content.sales-cycle .chart-container{max-width:410px}.analytics .widget-item .content.sales-cycle .legend{max-height:28px}@media (min-width:992px){.analytics .widget-item .content.sales-forecast{height:565px}.analytics .widget-item .content.sales-forecast .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.sales-forecast .edit{max-height:545px}.analytics .widget-item .content.sales-forecast .widget-lines-container{max-height:275px}.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main{cursor:pointer;border:1px solid #fff}.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main .selection-tag{display:block;right:0;margin-top:-6px;width:10px;height:29px;position:absolute}.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main.no-select{cursor:auto}.analytics .widget-item .content.sales-leads-funnel .right-panel .widget-lines-container .widget-line,.analytics .widget-item .content.sales-opportunities-funnel .right-panel .widget-lines-container .widget-line{cursor:default}.analytics .widget-item .content.sales-forecast .widget-lines-container .widget-line.main.no-select:hover{color:#626d6d}.analytics .widget-item .content.sales-growth .price{font-weight:900;font-size:22px;color:#5B6667;text-align:center;margin-top:0}.analytics .widget-item .content.sales-growth .legend{max-height:49px;font-size:14px;text-overflow:ellipsis;white-space:nowrap}@media (min-width:992px){.analytics .widget-item .content.sales-leads-funnel{height:565px}.analytics .widget-item .content.sales-leads-funnel .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.sales-leads-funnel .edit{max-height:545px}.analytics .widget-item .content.sales-leads-funnel .funnel-container{width:95%;margin:15px auto auto;padding-right:10px;max-height:505px;overflow:auto}.analytics .widget-item .content.sales-leads-funnel .right-panel .widget-lines-container{max-height:545px;margin-right:10px}.analytics .widget-item .content.sales-leads-list .widget-lines-container{max-height:230px;overflow-y:scroll;overflow-x:hidden}.analytics .widget-item .content.sales-leads-list .widget-lines-container .widget-line:nth-child(even){background-color:#f0f0f0}.analytics .widget-item .content.sales-leads-list .widget-lines-container .widget-line:nth-child(odd){background-color:#fff}.analytics .widget-item .content.sales-leads-list .widget-lines-container .widget-line.header{background-color:#fff}.analytics .widget-item .content.sales-list .widget-lines-container .widget-line:nth-child(even){background-color:#f0f0f0}.analytics .widget-item .content.sales-list .widget-lines-container .widget-line:nth-child(odd){background-color:#fff}.analytics .widget-item .content.sales-list .widget-lines-container .widget-line.header{background-color:#fff}.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header:hover,.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line:hover{background-color:#e6e0fb}.analytics .widget-item .content.sales-list .widget-lines-container{overflow-y:scroll;overflow-x:hidden;max-height:170px}.analytics .widget-item .content.sales-list .widget-lines-container.no-scroll{overflow:visible}.analytics .widget-item .content.sales-list .selector{margin-bottom:4px}.analytics .widget-item .content.sales-list .currency-conversions img{margin-top:-2px}.analytics .widget-item .content.sales-net-sales .operator,.analytics .widget-item .content.sales-net-sales .value-container{line-height:85px}.analytics .widget-item .content.sales-net-sales .value-container .title{line-height:20px;font-size:1.2em;padding:10px 0}.analytics .widget-item .content.sales-net-sales .value-container .value-box{font-size:1.3em;border-radius:10px;border-top:solid 1px #C4CACA;border-bottom:solid 1px #C4CACA;white-space:nowrap}.analytics .widget-item .content.sales-net-sales .operator{padding-top:38px;font-size:1.3em}@media (min-width:992px){.analytics .widget-item .content.sales-net-sales .values{margin-top:25px}}.analytics .widget-item .content.sales-new-vs-existing-customers .selector .selector-wrap{display:inline-block;margin:0 5px}.analytics .widget-item .content.sales-new-vs-existing-customers .chart-container{margin-top:15px}.analytics .widget-item .content.sales-new-vs-existing-customers .legend{margin-top:5px;font-weight:700;max-height:77px!important}.analytics .widget-item .content.sales-new-vs-existing-customers .legend .row{margin:0 -5px}.analytics .widget-item .content.sales-new-vs-existing-customers .legend .row>div{padding:0 5px}.analytics .widget-item .content.sales-new-vs-existing-customers .legend .total{color:#5B6667;font-size:14px}.analytics .widget-item .content.sales-number-of-leads .stats{margin-top:35px;font-size:18px}.analytics .widget-item .content.sales-number-of-leads .stats .stat{margin:15px 0 10px;border-bottom:solid 1px #e6edee}.analytics .widget-item .content.sales-number-of-leads .stats .stat span.title{font-weight:700}.analytics .widget-item .content.sales-number-of-leads .stats .stat span.nominal{float:right;text-align:right;font-weight:300}.analytics .widget-item .content.sales-number-of-leads .stats .stat span.variation{float:right;width:50px;text-align:right;font-style:italic;font-size:14px;font-weight:300;margin-top:2px}@media (min-width:992px){.analytics .widget-item .content.sales-opportunities-funnel{height:565px}.analytics .widget-item .content.sales-opportunities-funnel .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.sales-opportunities-funnel .edit{max-height:545px}.analytics .widget-item .content.sales-opportunities-funnel .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.sales-opportunities-funnel .funnel-container{width:95%;margin:15px auto auto;padding-right:10px;max-height:505px;overflow:auto}.analytics .widget-item .content.sales-opportunities-funnel .right-panel .widget-lines-container{max-height:545px;margin-right:10px}@media (min-width:992px){.analytics .widget-item .content.sales-performance{height:565px}.analytics .widget-item .content.sales-performance .chart-container{max-width:585px;max-height:440px;margin:auto}}.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header .selection-tag,.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line .selection-tag{display:block;right:0;margin-top:-6px;width:10px;height:29px;position:absolute}.analytics .widget-item .content.sales-performance .edit{max-height:545px}.analytics .widget-item .content.sales-performance .edit .widget-lines-container{overflow-y:hidden;overflow-x:hidden}.analytics .widget-item .content.sales-performance .widget-lines-container{max-height:540px}.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line{cursor:pointer;border:1px solid #fff}.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line.no-select{cursor:auto}.analytics .widget-item .content.sales-performance .widget-lines-container .lines-group .widget-line.no-select:hover{color:#626d6d}.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container{overflow-y:auto;overflow-x:hidden;max-height:215px}.analytics .widget-item .content.sales-performance .no-element{font-weight:300;font-size:16px;color:#5B6667;text-align:center}.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header{cursor:pointer;border:1px solid #fff}.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header.no-select{cursor:auto}.analytics .widget-item .content.sales-performance .right-panel .widget-lines-container .widget-line.header.no-select:hover{color:#626d6d}.analytics .widget-item .content.sales-segmented-turnover h3.right{margin-top:55px;text-align:center}.analytics .widget-item .content.sales-segmented-turnover .selector{margin-bottom:10px}.analytics .widget-item .content.sales-segmented-turnover .analysis{font-weight:900;font-size:22px;color:#5B6667;text-align:center;margin-top:0}.analytics .widget-item .content.sales-segmented-turnover .widget-lines-container{max-height:75px}.analytics .widget-item .content.sales-segmented-turnover .widget-lines-container .widget-line{font-size:11px}.analytics .widget-item .content.sales-segmented-turnover .right-panel h3{margin:15px 10px 5px;text-align:center}.analytics .widget-item .content.sales-segmented-turnover .right-panel .fa.fa-info-circle{float:left}.analytics .widget-item .content.sales-summary .chart-container{max-width:410px}.analytics .widget-item .content.sales-summary .legend{max-height:28px}.analytics .widget-item .content.sales-summary .selector{margin-bottom:5px}.analytics .widget-item .content.sales-top-customers .selector{border-bottom:dashed 1px #E6E6E6;padding-bottom:3px}.analytics .widget-item .content.sales-top-customers .selector a{font-weight:400}.analytics .widget-item .content.sales-top-customers .selector .param-selector{display:inline-block}.analytics .widget-item .content.sales-top-customers .widget-lines-container{max-height:235px}.analytics .widget-item .content.sales-top-customers .widget-lines-container .widget-line.sub-line{background-color:#f0f0f0}.analytics .widget-item .content.sales-top-customers .widget-lines-container .row>[class*=col-]{position:static}.analytics .widget-item .content.sales-top-customers .currency-conversions img{margin-top:-2px}.analytics .widget-item .content.sales-top-opportunities .opps-container{max-height:195px;margin-top:10px;padding-right:10px;overflow-y:auto;overflow-x:hidden}.analytics .widget-item .content.sales-top-opportunities .opps-container .tile{height:40px;font-size:13px;font-weight:300}.analytics .widget-item .content.sales-top-opportunities .opps-container .tile .colored-area{width:10%;text-align:center;font-size:20px}.analytics .widget-item .content.sales-top-opportunities .opps-container .tile .main-text{color:#5B6667;padding:3px 0 0 10px}.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.first{height:55px;font-size:15px;font-weight:700}.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.first .colored-area{font-size:26px;padding-top:10px;background-color:#ff6e41}.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.first .main-text{padding-top:8px}.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.second{height:55px;font-size:15px;font-weight:500}.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.second .colored-area{font-size:26px;padding-top:10px;background-color:#1de9b6}.analytics .widget-item .content.sales-top-opportunities .opps-container .tile.second .main-text{padding-top:8px}.analytics .settings.accounting-behaviour .btn.btn-primary{background-color:#bba9f5;border:1px solid #977bf0}.analytics .settings.accounting-behaviour .btn.btn-primary.active,.analytics .settings.accounting-behaviour .btn.btn-primary.focus{background-color:#977bf0}.analytics .settings.attach-kpis .attach-kpi{padding:8px 5px}.analytics .settings.attach-kpis .attach-kpi form .row{padding-bottom:5px}.analytics .settings.attach-kpis .attach-kpi .attach-kpi-form{background-color:#fff;border:1px solid #ddd;padding:5px}.analytics .settings.attach-kpis .attach-kpi form .row.kpi-description{padding:10px 2px}.analytics .settings.attach-kpis .attach-kpi form .row.kpi-description span{display:block;font-weight:700;font-size:13px}.analytics .settings.attach-kpis .attach-kpi form.attach-kpi-form input.attach-target{background-color:#fff;height:inherit}.analytics .settings.attach-kpis .attach-kpi .error-messages{color:#e01f74;width:120px}.analytics .settings.attach-kpis .attached-kpis{padding:5px}.analytics .settings.attach-kpis .list-group-item.attached-kpi{padding:5px 10px}.analytics .settings.attach-kpis .list-group-item.attached-kpi .attached-kpi-name{overflow:hidden;width:75%;display:inline-block;white-space:nowrap;text-overflow:ellipsis;margin-top:3px;font-size:13px;font-weight:700}.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions{padding-top:2px}.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .alerts-config{display:inline-block;text-align:left;padding-left:4px;height:20px;border-radius:40px;width:21px;color:#358fdc;background-color:#fff;border:1px solid #358fdc}.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .alerts-config:hover{cursor:pointer}.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .edit-attached-kpi{display:inline-block}.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .edit-attached-kpi i{border-radius:10px;width:21px;color:#358fdc;background-color:#fff;height:20px;padding:3px 5px 5px;border:1px solid #358fdc}.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .edit-attached-kpi i:hover{cursor:pointer}.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .remove-attached-kpi{display:inline-block}.analytics .settings.dates-picker button.btn.btn-sm.btn-danger,.analytics .settings.dates-picker h5{display:none}.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .remove-attached-kpi i{border-radius:10px;width:21px;color:#e01f74;background-color:#fff;height:20px;padding:3px 5px 5px;border:1px solid #e01f74}.analytics .settings.attach-kpis .list-group-item.attached-kpi .actions .remove-attached-kpi i:hover{cursor:pointer}.analytics .widget-item .content .settings.select-account{padding:0 5px}.analytics .widget-item .content .settings.chart-filters .row{margin:0}.analytics .widget-item .content .settings.chart-filters input[type=radio]{margin:0 3px 0 0;padding:0;width:13px;height:13px;vertical-align:middle;position:relative;top:-1px;outline:0}.analytics .widget-item .content .settings.chart-filters input[type=range]{height:auto;width:100%}.analytics .settings.dates-picker button.btn.btn-sm{line-height:1}.analytics .settings.dates-picker button.btn.btn-sm.date-button{margin:0 5px}.analytics .settings.dates-picker button.btn.btn-sm.btn-info{border-radius:3px}.analytics .settings.dates-picker .tooltip-inner{text-transform:none}.analytics .settings.dates-picker .dropdown-menu>li>div>table{outline:0}.analytics .settings.forecast-payroll .widget-lines-container .widget-line{padding:5px 10px 5px 18px}.analytics .settings.forecast-payroll .widget-lines-container .widget-line:nth-child(even){background-color:#f3f4f4}.analytics .settings.forecast-payroll .widget-lines-container .widget-line:nth-child(odd){background-color:#fff}.analytics .settings.forecast-payroll .widget-lines-container .widget-line .fa{float:right;font-size:20px;cursor:pointer}.analytics .settings.forecast-payroll .widget-lines-container .widget-line .fa.fa-toggle-on{color:#977bf0}.analytics .settings.forecast-payroll .widget-lines-container .widget-line .fa.fa-toggle-off{color:#9ba6a7}.analytics .widget-item .content .settings.hist-mode-choser{max-height:70px}.analytics .widget-item .content .settings.hist-mode-choser [common-time-period-info]{padding-bottom:8px}.analytics .widget-item .content .settings.hist-mode-choser .options{width:150px;margin:auto;padding-bottom:8px;border-bottom:solid 1px #e6e6e6;font-weight:500;font-size:12px;color:#c4caca}.analytics .widget-item .content .settings.hist-mode-choser .options a{font-weight:500;font-size:12px;color:#c4caca;text-transform:uppercase}.analytics .widget-item .content .settings.hist-mode-choser .options a.active{color:#977bf0}.analytics .widget-item .content .settings.hist-mode-choser .arrow-container{width:28px;height:28px;position:relative;top:-14px;margin:auto}.analytics .widget-item .content .settings.hist-mode-choser .arrow-container.right{left:46px}.analytics .widget-item .content .settings.hist-mode-choser .arrow-container.left{left:-30px}.analytics .widget-item .content .settings.hist-mode-choser .arrow-container .arrow-border{border-top:14px solid #e6e6e6;border-left:14px solid transparent;border-right:14px solid transparent;width:0;height:0}.analytics .widget-item .content .settings.hist-mode-choser .arrow-container .arrow{border-top:14px solid #fff;border-left:14px solid transparent;border-right:14px solid transparent;position:relative;top:12px;width:0;height:0}.analytics .settings.limit-entries{color:#1E303B;text-transform:uppercase;text-align:center;border-bottom:dashed 1px #E6E6E6;padding-bottom:8px}.analytics .settings.limit-entries a.option.badge{color:#fff;background-color:#1E303B}.analytics .settings.offsets .offset-value{font-style:italic;font-size:13px}.analytics .settings.offsets .offset-value .fa-trash-o{margin-left:10px}.analytics .settings.offsets .offset-value .fa-trash-o:hover{color:#e01f74;cursor:pointer}.analytics .settings.offsets input{width:75%}.analytics .settings.offsets button{width:30px}.analytics .settings.organizations .widget-lines-container .widget-line{padding:5px 10px 5px 18px}.analytics .settings.organizations .widget-lines-container .widget-line:nth-child(even){background-color:#f3f4f4}.analytics .settings.organizations .widget-lines-container .widget-line:nth-child(odd){background-color:#fff}.analytics .settings.organizations .widget-lines-container .widget-line .fa{float:right;font-size:20px;cursor:pointer}.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-check-circle,.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-toggle-on{color:#977bf0}.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-circle-thin,.analytics .settings.organizations .widget-lines-container .widget-line .fa.fa-toggle-off{color:#9ba6a7}.analytics .widget-item .content .settings.param-selector{display:inline-block}.analytics .widget-item .content .settings.param-selector.classic{width:100%}.analytics .widget-item .content .settings.param-selector.classic select{width:100%;height:25px;border:1px solid #ccc;text-transform:uppercase;margin:0 0 5px}.analytics .widget-item .content .settings.param-selector a{font-weight:400;color:#977bf0;white-space:nowrap}.analytics .widget-item .content .settings.param-selector .options-container{position:absolute;background-color:#fff;text-align:left;min-width:150px;max-height:200px;z-index:999;overflow-y:auto;overflow-x:hidden;box-shadow:#000 0 3px 15px -3px}.analytics .settings.tag-filter .tag-lines-container .tag-line .host,.analytics .settings.tag-filter .tag-lines-container .tag-line .tags-col{position:static}.analytics .widget-item .content .settings.param-selector .options-container .param-selector-label{padding:3px 5px;font-weight:500;font-size:inherit;color:#000;cursor:text;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;line-height:1.9}.analytics .widget-item .content .settings.param-selector .options-container .param-selector-label:hover{cursor:pointer;background-color:#977bf0;color:#fff}.analytics .widget-item .content .settings.param-selector .options-container::-webkit-scrollbar{width:8px;background-color:#d7e2e4}.analytics .widget-item .content .settings.param-selector .options-container::-webkit-scrollbar-thumb{background-color:#977bf0}.analytics .widget-item .content .settings.param-selector .options-container::-webkit-scrollbar-thumb:hover{background-color:#a992f3}.analytics .settings.params-checkboxes{padding:2px 0}.analytics .settings.params-checkboxes input{margin:0;height:inherit}.analytics .settings.params-checkboxes span{margin-left:5px}.analytics .settings.params-checkboxes label{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;line-height:14px}.analytics .widget-item .content .settings.params-picker{padding:0 10px}.analytics .widget-item .content .settings.params-picker .parameter{margin:0 3px 3px 0;padding:3px 5px;background-color:#1E303B;color:#fff;border:1px solid #1E303B;border-radius:4px;cursor:move;font-weight:700;white-space:nowrap;float:left}.analytics .widget-item .content .settings.params-picker .parameter input[type=checkbox]{margin:0 -3px 0 3px;vertical-align:middle;height:inherit;outline:0;cursor:pointer}.analytics .widget-item .content .settings.params-picker .parameter .badge{margin-right:3px;font-size:10px;background-color:#f2f2f2;color:#1E303B;padding:2px 6px}.analytics .widget-item .content .settings.params-picker .parameter.unchecked{background-color:inherit;font-weight:400;color:inherit;border-color:#c2c4c4}.analytics .widget-item .content .settings.params-picker .parameter.unchecked .badge{background-color:#c2c4c4;color:#fff}.analytics .settings.tag-filter{padding:0 5px}.analytics .settings.tag-filter .btn.btn-default{height:32px;width:30px}.analytics .settings.tag-filter .tag-lines-container{padding:0 10px}.analytics .settings.tag-filter .tag-lines-container .tag-line{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:end;-ms-flex-pack:end;justify-content:flex-end}.analytics .settings.tag-filter .tag-lines-container .tag-line tags-input .tags{display:-webkit-box;display:-ms-flexbox;display:flex;border-radius:4px;border:1px solid #ccc}.analytics .settings.tag-filter .tag-lines-container .tag-line tags-input .tags .tag-item{background:#79a2bb;border-radius:4px;color:#fff}.analytics .settings.time-period{padding:0 5px}.analytics .settings.time-period select{height:22px;width:100%}.analytics .settings.time-period>.row{margin:0 -5px 7px}.analytics .settings.time-period>.row>div{padding:0 5px;position:static}.analytics .settings.time-period>.row .sub-setting{padding:5px}.analytics .widget-item .content .settings.width{float:right;font-size:14px}.analytics .widget-item .content .settings.width i{color:silver;cursor:pointer}.analytics .widget-item .content .settings.width i.reduce{margin-right:-10px}.analytics .widget-item .content .settings.width i.expand{margin-right:-3px} \ No newline at end of file diff --git a/dist/impac-angular.min.js b/dist/impac-angular.min.js index c93fc78d..e5410bd6 100644 --- a/dist/impac-angular.min.js +++ b/dist/impac-angular.min.js @@ -1,21 +1,22 @@ /** * impac-angular - Impac! Front-End Library - * @version v1.7.5 + * @version v1.7.6 * @git git://github.com/maestrano/impac-angular.git * @license Copyright 2017 Maestrano Pty Ltd */ -(function(){"use strict";angular.module("maestrano.impac",["impac.services","impac.filters","impac.components","ngMessages","ui.sortable","ui.bootstrap","emguo.poller","toastr","pascalprecht.translate","xeditable"]),angular.module("impac.components",["impac.components.dashboard","impac.components.dashboard-create","impac.components.dashboard-selector","impac.components.dashboard-templates-selector","impac.components.dashboard-settings","impac.components.kpis-bar","impac.components.kpi","impac.components.chart","impac.components.alerts-config","impac.components.widget","impac.components.widgets","impac.components.widgets-settings","impac.components.widgets-common","impac.components.common","impac.components.templates"]),angular.module("impac.components.widgets",["impac.components.widgets.accounts-accounting-values","impac.components.widgets.accounts-assets-summary","impac.components.widgets.accounts-assets-liability-summary","impac.components.widgets.accounts-balance-sheet","impac.components.widgets.accounts-balance","impac.components.widgets.accounts-cash-projection","impac.components.widgets.accounts-cash-summary","impac.components.widgets.accounts-comparison","impac.components.widgets.accounts-custom-calculation","impac.components.widgets.accounts-expenses-revenue","impac.components.widgets.accounts-payable-receivable","impac.components.widgets.accounts-profit-and-loss","impac.components.widgets.accounts-class-comparison","impac.components.widgets.accounts-expense-weight","impac.components.widgets.accounts-assets-vs-liabilities","impac.components.widgets.accounts-detailed-classifications","impac.components.widgets.accounts-ratios","impac.components.widgets.accounts-cash-balance","impac.components.widgets.accounts-live-balance","impac.components.widgets.accounts-invoices-list","impac.components.widgets.hr-employee-details","impac.components.widgets.hr-employees-list","impac.components.widgets.hr-leaves-balance","impac.components.widgets.hr-leaves-schedule","impac.components.widgets.hr-payroll-summary","impac.components.widgets.hr-payroll-taxes","impac.components.widgets.hr-salaries-summary","impac.components.widgets.hr-superannuation-accruals","impac.components.widgets.hr-timesheets","impac.components.widgets.hr-workforce-summary","impac.components.widgets.invoices-aged-payables-receivables","impac.components.widgets.invoices-list","impac.components.widgets.invoices-summary","impac.components.widgets.sales-aged","impac.components.widgets.sales-break-even","impac.components.widgets.sales-comparison","impac.components.widgets.sales-customer-details","impac.components.widgets.sales-cycle","impac.components.widgets.sales-forecast","impac.components.widgets.sales-growth","impac.components.widgets.sales-leads-funnel","impac.components.widgets.sales-leads-list","impac.components.widgets.sales-list","impac.components.widgets.sales-margin","impac.components.widgets.sales-net-sales","impac.components.widgets.sales-number-of-leads","impac.components.widgets.sales-opportunities-funnel","impac.components.widgets.sales-performance","impac.components.widgets.sales-segmented-turnover","impac.components.widgets.sales-summary","impac.components.widgets.sales-top-opportunities","impac.components.widgets.sales-top-customers","impac.components.widgets.sales-new-vs-existing-customers"]),angular.module("impac.components.widgets-settings",["impac.components.widgets-settings.account","impac.components.widgets-settings.bolt-account","impac.components.widgets-settings.accounts-list","impac.components.widgets-settings.accounting-behaviour","impac.components.widgets-settings.chart-filters","impac.components.widgets-settings.dates-picker","impac.components.widgets-settings.formula","impac.components.widgets-settings.hist-mode","impac.components.widgets-settings.limit-entries","impac.components.widgets-settings.organizations","impac.components.widgets-settings.param-selector","impac.components.widgets-settings.params-picker","impac.components.widgets-settings.params-checkboxes","impac.components.widgets-settings.time-period","impac.components.widgets-settings.time-presets","impac.components.widgets-settings.time-slider","impac.components.widgets-settings.width","impac.components.widgets-settings.attach-kpis","impac.components.widgets-settings.tag-filter","impac.components.widgets-settings.offsets","impac.components.widgets-settings.forecast-payroll"]),angular.module("impac.components.dashboard-settings",["impac.components.dashboard-settings.currency","impac.components.dashboard-settings.pdf-mode","impac.components.dashboard-settings.sync-apps"]),angular.module("impac.components.widgets-common",["impac.components.widgets-common.editable-title","impac.components.widgets-common.info-panel","impac.components.widgets-common.confirm-modal","impac.components.widgets-common.time-period-info","impac.components.widgets-common.top-buttons","impac.components.widgets-common.autofocus","impac.components.widgets-common.currency-conversions","impac.components.widgets-common.chart-threshold"]),angular.module("impac.components.common",["impac.components.common.data-not-found","impac.components.common.transactions-add","impac.components.common.transactions-list","impac.components.common.duplicate-transactions-list","impac.components.common.trends-add","impac.components.common.trends-list"]),angular.module("impac.services",["impac.services.routes","impac.services.linking","impac.services.theming","impac.services.assets","impac.services.chart-formatter","impac.services.highcharts-factory","impac.services.message-bus","impac.services.utilities","impac.services.main","impac.services.kpis","impac.services.dashboards","impac.services.dashboard-templates","impac.services.widgets","impac.services.developer","impac.services.pusher","impac.services.alerts","impac.services.notifications","impac.services.events","impac.services.currency-rates","impac.services.bolt-resources"]),angular.module("impac.filters",["impac.filters.titleize","impac.filters.truncate","impac.filters.mno-currency","impac.filters.moment-date"]),angular.module("impac.components.templates",[]).run(["$templateCache",function(e){e.put("alerts-config/alerts-config.modal.html",'
\n\n \n\n \n\n \n\n
\n'),e.put("alerts-config/alerts-config.tmpl.html",'
\n \n
\n'),e.put("dashboard/dashboard.tmpl.html",'\n
\n
\n\n \n
\n
\n \n
\n \n \n
\n\n
\n
{{dhbHeadingText}}
\n
\n
\n\n \n \n\n \n \n\n \n\n \n
\n
\n

impac.dashboard.select_the_widgets

\n impac.dashboard.widget_added\n \n
\n\n
\n
\n
\n impac.dashboard.all_categories\n
\n
\n
\n

impac.dashboard.accounting

\n

impac.dashboard.invoicing

\n

impac.dashboard.hr_or_payroll

\n

impac.dashboard.sales

\n
\n
\n
\n
\n \n
\n
\n\n
\n
\n {{getSelectedCategoryName() | titleize}}\n
\n
\n
\n
\n \n

\n \n
\n
\n
\n
\n
\n\n
\n \n {{\'impac.dashboard.can_not_find\' | translate}} {{\'impac.dashboard.give_us\' | translate}}\n \n
\n
\n\n \n
\n\n \n
\n
\n
\n
\n
\n
\n\n \n
\n \n
    \n
  • {{error}}
  • \n
\n
\n\n
\n \n\n
\n \n
\n
\n
\n
\n
\n

{{dhbErrorsConfig.firstTimeCreated.first}}

\n

{{dhbErrorsConfig.firstTimeCreated.second}}

\n
\n
\n
\n
\n
\n \n
\n
\n\n \n
\n
\n
\n
\n
\n

{{dhbErrorsConfig.empty.first}}

\n

{{dhbErrorsConfig.empty.second}}

\n
\n
\n
\n
\n
\n \n
\n
\n
\n
\n\n \n
\n \n \n
\n

{{dhbErrorsConfig.firstTimeCreated.note}}

\n
\n
\n\n \n
\n \n
\n
\n
\n
\n
\n
\n
\n
\n \n
\n \n
\n
\n
impac.dashboard.plus_chart
\n
\n
\n
\n
\n
\n
\n\n
\n
\n
\n \n
\n
\n
\n\n
\n
\n
\n

{{dhbErrorsConfig.failed.first}}

\n
\n

{{dhbErrorsConfig.failed.second}}

\n
\n \n \n \n
\n
\n
\n'),e.put("dashboard/widget-suggestion.modal.html",'\n\n