diff --git a/assets/css/docs.css b/assets/css/docs.css index d0304ff4..9abd799d 100644 --- a/assets/css/docs.css +++ b/assets/css/docs.css @@ -65,7 +65,7 @@ span.hidden-sm { /* Outline button for use within the docs */ .btn-outline { - color: #563d7c; + color: #962A28; background-color: #fff; border-color: #e5e5e5; } @@ -73,8 +73,14 @@ span.hidden-sm { .btn-outline:focus, .btn-outline:active { color: #fff; - background-color: #563d7c; - border-color: #563d7c; + background-color: #962A28; + background-image: -webkit-gradient(linear, left top, right top, color-stop(0, #450915), color-stop(1, #962A28)); + background-image: -o-linear-gradient(right, #450915 0%, #962A28 100%); + background-image: -moz-linear-gradient(right, #450915 0%, #962A28 100%); + background-image: -webkit-linear-gradient(right, #450915 0%, #962A28 100%); + background-image: -ms-linear-gradient(right, #450915 0%, #962A28 100%); + background-image: linear-gradient(to right, #450915 0%, #962A28 100%); + border-color: #962A28; } /* Inverted outline button (white on dark) */ @@ -570,7 +576,7 @@ span.hidden-sm { /* Janky fix for preventing navbar from overlapping */ h1[id] { padding-top: 80px; - margin-top: -45px; + margin-top: -80px; } h2[id], h3[id] { padding-top: 65px; @@ -1124,7 +1130,7 @@ h2[id], h3[id] { .bs-customizer .toggle { float: right; - margin-top: 25px; + margin-top: 80px; } /* Headings and form contrls */ diff --git a/assets/css/docs.min.css b/assets/css/docs.min.css index 5856606f..15901c2c 100644 --- a/assets/css/docs.min.css +++ b/assets/css/docs.min.css @@ -3,4 +3,4 @@ * Copyright 2011-2014 Twitter, Inc. * Licensed under the Creative Commons Attribution 3.0 Unported License. For * details, see http://creativecommons.org/licenses/by/3.0/. - */body{position:relative;padding-top:50px;overflow:auto!important}span.hidden-sm{display:inline!important}@media (min-width:768px) and (max-width:992px){span.hidden-sm{display:none!important}}.table code{font-size:13px;font-weight:400}.btn-outline{color:#563d7c;background-color:#fff;border-color:#e5e5e5}.btn-outline:hover,.btn-outline:focus,.btn-outline:active{color:#fff;background-color:#563d7c;border-color:#563d7c}.btn-outline-inverse{color:#fff;background-color:transparent;border-color:#cdbfe3}.btn-outline-inverse:hover,.btn-outline-inverse:focus,.btn-outline-inverse:active{color:#563d7c;text-shadow:none;background-color:#fff;border-color:#fff}.bs-docs-nav{text-shadow:0 -1px 0 rgba(0,0,0,.15);box-shadow:0 1px 0 rgba(255,255,255,.1)}.bs-docs-nav .navbar-brand{color:#fff}.bs-docs-nav .navbar-nav>li>a{color:#ceb6b8}.bs-docs-nav .navbar-nav>li>a:hover{color:#fff}.bs-docs-nav .navbar-nav>.active>a,.bs-docs-nav .navbar-nav>.active>a:hover{color:#fff;background-color:#6B313B;background-color:rgba(255,255,255,.15)}.bs-docs-nav .navbar-toggle,.bs-docs-nav .navbar-toggle:focus{border-color:#86555C;border-color:rgba(255,255,255,.3);background:0 0}.bs-docs-nav .navbar-toggle:hover{background-color:#63303A;background-color:rgba(255,255,255,.15);border-color:transparent}.bs-footer{padding-top:40px;padding-bottom:30px;margin-top:100px;color:#777;text-align:center;border-top:1px solid #e5e5e5}.footer-links{margin:10px 0;padding-left:0}.footer-links li{display:inline;padding:0 2px}.footer-links li:first-child{padding-left:0}@media (min-width:768px){.bs-footer{text-align:left}.bs-footer p{margin-bottom:0}}.bs-social{margin-top:20px;margin-bottom:20px;text-align:center}.bs-social-buttons{display:inline-block;margin-bottom:0;padding-left:0;list-style:none}.bs-social-buttons li{display:inline-block;line-height:1;padding:5px 8px}.bs-social-buttons .twitter-follow-button{width:225px!important}.bs-social-buttons .twitter-share-button{width:98px!important}.github-btn{border:0;overflow:hidden}@media (min-width:768px){.bs-social{text-align:left}.bs-social-buttons li:first-child{padding-left:0}}.bs-docs-nav,.bs-docs-home,.bs-header{color:#ceb6b8;background-color:#450915;background-image:url(../img/bg-1920x1200.jpg)}@media (min-width:1921px),(min-height:1201px){.bs-header{background-image:url(../img/bg-3500x2500.jpg)}}.bs-header{background-position:0 -51px}.bs-masthead{position:relative;padding:30px 15px;text-align:center;text-shadow:0 1px 0 rgba(0,0,0,.15)}.bs-masthead h1{font-size:50px;line-height:1;color:#fff}.bs-masthead .btn-outline-inverse{margin:10px}.bs-masthead-links{margin-top:20px;margin-bottom:40px;padding:0 15px;list-style:none;text-align:center}.bs-masthead-links li{display:inline}.bs-masthead-links li+li{margin-left:20px}.bs-masthead a,.bs-masthead-links a{color:#fff}@media (min-width:768px){.bs-masthead{text-align:left;padding-top:140px;padding-bottom:140px}.bs-masthead h1{font-size:100px}.bs-masthead .lead{margin-right:25%;font-size:30px}.bs-masthead .btn-outline-inverse{width:auto;margin:20px 5px 20px 0;padding:18px 24px;font-size:21px}.bs-masthead-links{padding:0;text-align:left}}.bs-header{padding:30px 15px 40px;font-size:16px;text-align:center;text-shadow:0 1px 0 rgba(0,0,0,.15)}.bs-header h1{color:#fff}.bs-header p{font-weight:300;line-height:1.5}.bs-header .container{position:relative}@media (min-width:768px){.bs-header{font-size:21px;text-align:left}.bs-header h1{font-size:60px;line-height:1}}@media (min-width:992px){.bs-header h1,.bs-header p{margin-right:380px}}.aboutme{display:block;margin:50px -30px -40px;padding:5px;overflow:hidden;background:#63303A;background:rgba(255,255,255,.15);box-shadow:inset 0 3px 5px rgba(0,0,0,.075);font-size:13px!important;line-height:16px!important;text-decoration:none;text-align:center}.aboutme:hover{text-decoration:none}.aboutme-text{margin-top:5px;color:#ceb6b8}.aboutme-title{font-weight:700;margin-bottom:4px;color:#fff}.aboutme-name{margin-top:9px;color:#fff}.aboutme img{float:right;height:50px;margin-left:10px}@media screen and (min-width:768px){.aboutme{margin:0!important;border-radius:4px;box-shadow:inset 0 3px 5px rgba(0,0,0,.075),0 1px 0 rgba(255,255,255,.1)}.aboutme-title{display:block}}@media screen and (min-width:992px){.aboutme{position:absolute;top:20px;right:0;padding:15px!important;width:330px!important;min-height:132px;text-align:left}.aboutme-title,.aboutme-name{display:block}.aboutme img{height:auto}}.bs-docs-home .aboutme{margin:0 -15px 40px!important}@media screen and (min-width:480px){.bs-docs-home .aboutme{width:330px!important;margin:0 auto 40px!important;border-radius:4px}}@media screen and (min-width:768px){.bs-docs-home .aboutme{float:left;width:330px!important;margin:0!important}.bs-docs-home .bs-social,.bs-docs-home .bs-masthead-links{margin-left:350px}}@media screen and (min-width:992px){.bs-docs-home .aboutme{position:static}}@media screen and (min-width:1170px){.bs-docs-home .aboutme{margin-top:-25px!important}}.bs-old-docs{padding:15px 20px;color:#777;background-color:#fafafa;border-top:1px solid #fff;border-bottom:1px solid #e5e5e5}.bs-old-docs strong{color:#555}.bs-sidebar.affix{position:static}.bs-sidenav{margin-top:30px;margin-bottom:30px;padding-top:10px;padding-bottom:10px;text-shadow:0 1px 0 #fff;background-color:#f7f5fa;border-radius:5px}.bs-sidebar .nav>li>a{display:block;color:#716b7a;padding:5px 20px}.bs-sidebar .nav>li>a:hover,.bs-sidebar .nav>li>a:focus{text-decoration:none;background-color:#e5e3e9;border-right:1px solid #dbd8e0}.bs-sidebar .nav>.active>a,.bs-sidebar .nav>.active:hover>a,.bs-sidebar .nav>.active:focus>a{font-weight:700;color:#563d7c;background-color:transparent;border-right:1px solid #563d7c}.bs-sidebar .nav .nav{display:none;margin-bottom:8px}.bs-sidebar .nav .nav>li>a{padding-top:3px;padding-bottom:3px;padding-left:30px;font-size:90%}@media (min-width:992px){.bs-sidebar .nav>.active>ul{display:block}.bs-sidebar.affix,.bs-sidebar.affix-bottom{width:213px}.bs-sidebar.affix{position:fixed;top:80px}.bs-sidebar.affix-bottom{position:absolute}.bs-sidebar.affix-bottom .bs-sidenav,.bs-sidebar.affix .bs-sidenav{margin-top:0;margin-bottom:0}}@media (min-width:1200px){.bs-sidebar.affix-bottom,.bs-sidebar.affix{width:263px}}.bs-docs-section+.bs-docs-section{padding-top:40px}h1[id]{padding-top:80px;margin-top:-45px}h2[id],h3[id]{padding-top:65px;margin-top:-20px}.bs-callout{margin:20px 0;padding:20px;border-left:3px solid #eee}.bs-callout h4{margin-top:0;margin-bottom:5px}.bs-callout p:last-child{margin-bottom:0}.bs-callout-danger{background-color:#fdf7f7;border-color:#eed3d7}.bs-callout-danger h4{color:#b94a48}.bs-callout-warning{background-color:#faf8f0;border-color:#faebcc}.bs-callout-warning h4{color:#c09853}.bs-callout-info{background-color:#f4f8fa;border-color:#bce8f1}.bs-callout-info h4{color:#3a87ad}.bs-team .team-member{color:#555;line-height:32px}.bs-team .team-member:hover{color:#333;text-decoration:none}.bs-team .github-btn{float:right;margin-top:6px;width:120px;height:20px}.bs-team img{float:left;width:32px;margin-right:10px;border-radius:4px}.show-grid{margin-bottom:15px}.show-grid [class^=col-]{padding-top:10px;padding-bottom:10px;background-color:#eee;background-color:rgba(86,61,124,.15);border:1px solid #ddd;border:1px solid rgba(86,61,124,.2)}.bs-example{position:relative;padding:45px 15px 15px;margin:0 -15px 15px;background-color:#fafafa;box-shadow:inset 0 3px 6px rgba(0,0,0,.05);border-color:#e5e5e5 #eee #eee;border-style:solid;border-width:1px 0}.bs-example:after{content:"Example";position:absolute;top:15px;left:15px;font-size:12px;font-weight:700;color:#bbb;text-transform:uppercase;letter-spacing:1px}.bs-example+.highlight{margin:-15px -15px 15px;border-radius:0;border-width:0 0 1px}@media (min-width:768px){.bs-example{margin-left:0;margin-right:0;background-color:#fff;border-width:1px;border-color:#ddd;border-radius:4px 4px 0 0;box-shadow:none}.bs-example+.highlight{margin-top:-16px;margin-left:0;margin-right:0;border-width:1px;border-bottom-left-radius:4px;border-bottom-right-radius:4px}}.bs-example .container{width:auto}.bs-example>p:last-child,.bs-example>ul:last-child,.bs-example>ol:last-child,.bs-example>blockquote:last-child,.bs-example>.form-control:last-child,.bs-example>.table:last-child,.bs-example>.navbar:last-child,.bs-example>.jumbotron:last-child,.bs-example>.alert:last-child,.bs-example>.panel:last-child,.bs-example>.list-group:last-child,.bs-example>.well:last-child,.bs-example>.progress:last-child,.bs-example>.table-responsive:last-child>.table{margin-bottom:0}.bs-example>p>.close{float:none}.bs-example-type .table .info{color:#999;vertical-align:middle}.bs-example-type .table td{padding:15px 0;border-color:#eee}.bs-example-type .table tr:first-child td{border-top:0}.bs-example-type h1,.bs-example-type h2,.bs-example-type h3,.bs-example-type h4,.bs-example-type h5,.bs-example-type h6{margin:0}.bs-example>.img-circle,.bs-example>.img-rounded,.bs-example>.img-thumbnail{margin:5px}.bs-example>.table-responsive>.table{background-color:#fff}.bs-example>.btn,.bs-example>.btn-group{margin-top:5px;margin-bottom:5px}.bs-example>.btn-toolbar+.btn-toolbar{margin-top:10px}.bs-example-control-sizing select,.bs-example-control-sizing input[type=text]+input[type=text]{margin-top:10px}.bs-example-form .input-group{margin-bottom:10px}.bs-example>textarea.form-control{resize:vertical}.bs-example>.list-group{max-width:400px}.bs-example .navbar:last-child{margin-bottom:0}.bs-navbar-top-example,.bs-navbar-bottom-example{z-index:1;padding:0;overflow:hidden}.bs-navbar-top-example .navbar-header,.bs-navbar-bottom-example .navbar-header{margin-left:0}.bs-navbar-top-example .navbar-fixed-top,.bs-navbar-bottom-example .navbar-fixed-bottom{position:relative;margin-left:0;margin-right:0}.bs-navbar-top-example{padding-bottom:45px}.bs-navbar-top-example:after{top:auto;bottom:15px}.bs-navbar-top-example .navbar-fixed-top{top:-1px}.bs-navbar-bottom-example{padding-top:45px}.bs-navbar-bottom-example .navbar-fixed-bottom{bottom:-1px}.bs-navbar-bottom-example .navbar{margin-bottom:0}@media (min-width:768px){.bs-navbar-top-example .navbar-fixed-top,.bs-navbar-bottom-example .navbar-fixed-bottom{position:absolute}.bs-navbar-top-example{border-radius:0 0 4px 4px}.bs-navbar-bottom-example{border-radius:4px 4px 0 0}}.bs-navmenu-fixed-example{height:200px;padding-left:315px}.bs-navmenu-fixed-example:after{left:315px}.bs-navmenu-offcanvas-example{min-height:200px;overflow:hidden}.bs-navmenu-offcanvas-example:after{display:none}.bs-navmenu-offcanvas-example>div{position:absolute;top:0;left:0;height:100%;width:100%;padding:70px 15px 15px}.bs-navmenu-offcanvas-example p{color:#bbb}.bs-navmenu-fixed-example .navmenu-fixed-left,.bs-navmenu-offcanvas-example .navmenu-fixed-left,.bs-navmenu-offcanvas-example .navbar-fixed-top{position:absolute;z-index:1}.bs-navmenu-offcanvas-example .navmenu-fixed-left{-webkit-transform:translate(-300px,0);transform:translate(-300px,0)}.bs-navmenu-offcanvas-example .navbar-toggle{float:left;margin-left:15px;display:block}.bs-example .pagination{margin-top:10px;margin-bottom:10px}.bs-example .alert-fixed-top{position:absolute;z-index:1;width:auto;left:0;right:0;margin-left:0}@media (min-width:992px){.bs-example .alert-fixed-top{left:15px;right:15px}}.bs-example>.pager{margin-top:0}.bs-example-modal{background-color:#f5f5f5}.bs-example-modal .modal{position:relative;top:auto;right:auto;left:auto;bottom:auto;z-index:1;display:block}.bs-example-modal .modal-dialog{left:auto;margin-left:auto;margin-right:auto}.bs-example>.dropdown>.dropdown-menu{position:static;display:block;margin-bottom:5px}.bs-example-tabs .nav-tabs{margin-bottom:15px}.bs-example-tooltips{text-align:center}.bs-example-tooltips>.btn{margin-top:5px;margin-bottom:5px}.bs-example-popover{padding-bottom:24px;background-color:#f9f9f9}.bs-example-popover .popover{position:relative;display:block;float:left;width:260px;margin:20px}.scrollspy-example{position:relative;height:200px;margin-top:10px;overflow:auto}.highlight{display:none;padding:9px 14px;margin-bottom:14px;background-color:#f7f7f9;border:1px solid #e1e1e8;border-radius:4px}.highlight pre{padding:0;margin-top:0;margin-bottom:0;background-color:transparent;border:0;white-space:nowrap}.highlight pre code{font-size:inherit;color:#333}.highlight pre .lineno{display:inline-block;width:22px;padding-right:5px;margin-right:10px;text-align:right;color:#bebec5}@media (min-width:481px){.highlight{display:block}}.table-responsive .highlight pre{white-space:normal}.bs-table th small,.responsive-utilities th small{display:block;font-weight:400;color:#999}.responsive-utilities tbody th{font-weight:400}.responsive-utilities td{text-align:center}.responsive-utilities td.is-visible{color:#468847;background-color:#dff0d8!important}.responsive-utilities td.is-hidden{color:#ccc;background-color:#f9f9f9!important}.responsive-utilities-test{margin-top:5px}.responsive-utilities-test .col-xs-6{margin-bottom:10px}.responsive-utilities-test span{padding:15px 10px;font-size:14px;font-weight:700;line-height:1.1;text-align:center;border-radius:4px}.visible-on .col-xs-6 .hidden-xs,.visible-on .col-xs-6 .hidden-sm,.visible-on .col-xs-6 .hidden-md,.visible-on .col-xs-6 .hidden-lg,.hidden-on .col-xs-6 .hidden-xs,.hidden-on .col-xs-6 .hidden-sm,.hidden-on .col-xs-6 .hidden-md,.hidden-on .col-xs-6 .hidden-lg{color:#999;border:1px solid #ddd}.visible-on .col-xs-6 .visible-xs,.visible-on .col-xs-6 .visible-sm,.visible-on .col-xs-6 .visible-md,.visible-on .col-xs-6 .visible-lg,.hidden-on .col-xs-6 .visible-xs,.hidden-on .col-xs-6 .visible-sm,.hidden-on .col-xs-6 .visible-md,.hidden-on .col-xs-6 .visible-lg{color:#468847;background-color:#dff0d8;border:1px solid #d6e9c6}.bs-customizer .toggle{float:right;margin-top:25px}.bs-customizer label{margin-top:10px;font-weight:500;color:#555}.bs-customizer h2{margin-top:0;margin-bottom:5px;padding-top:30px}.bs-customizer h3{margin-bottom:0}.bs-customizer h4{margin-top:15px;margin-bottom:0}.bs-customizer .bs-callout h4{margin-top:0;margin-bottom:5px}.bs-customizer input[type=text]{font-family:Menlo,Monaco,Consolas,"Courier New",monospace;background-color:#fafafa}.bs-customizer .help-block{font-size:12px;margin-bottom:5px}#less-section label{font-weight:400}.bs-customizer-input{float:left;width:33.333333%;padding-left:15px;padding-right:15px}.bs-customize-download .btn-outline{padding:20px}.bs-customizer-alert{position:fixed;top:0;left:0;right:0;z-index:1030;padding:15px 0;color:#fff;background-color:#d9534f;box-shadow:inset 0 1px 0 rgba(255,255,255,.25);border-bottom:1px solid #b94441}.bs-customizer-alert .close{margin-top:-4px;font-size:24px}.bs-customizer-alert p{margin-bottom:0}.bs-customizer-alert .glyphicon{margin-right:5px}.bs-customizer-alert pre{margin:10px 0 0;color:#fff;background-color:#a83c3a;border-color:#973634;box-shadow:inset 0 2px 4px rgba(0,0,0,.05),0 1px 0 rgba(255,255,255,.1)}.bs-about{font-size:16px}.bs-examples h4{margin-bottom:5px}.bs-examples p{margin-bottom:20px}#focusedInput{border-color:#52a8ec;border-color:rgba(82,168,236,.8);outline:0;outline:thin dotted \9;-moz-box-shadow:0 0 8px rgba(82,168,236,.6);box-shadow:0 0 8px rgba(82,168,236,.6)}.bs-docs-dl-options h4{margin-top:15px;margin-bottom:5px}.hll{background-color:#ffc}.c{color:#999}.err{color:#A00;background-color:#FAA}.k{color:#069}.o{color:#555}.cm{color:#09F;font-style:italic}.cp{color:#099}.c1{color:#999}.cs{color:#999}.gd{background-color:#FCC;border:1px solid #C00}.ge{font-style:italic}.gr{color:red}.gh{color:#030}.gi{background-color:#CFC;border:1px solid #0C0}.go{color:#AAA}.gp{color:#009}.gu{color:#030}.gt{color:#9C6}.kc{color:#069}.kd{color:#069}.kn{color:#069}.kp{color:#069}.kr{color:#069}.kt{color:#078}.m{color:#F60}.s{color:#d44950}.na{color:#4f9fcf}.nb{color:#366}.nc{color:#0A8}.no{color:#360}.nd{color:#99F}.ni{color:#999}.ne{color:#C00}.nf{color:#C0F}.nl{color:#99F}.nn{color:#0CF}.nt{color:#2f6f9f}.nv{color:#033}.ow{color:#000}.w{color:#bbb}.mf{color:#F60}.mh{color:#F60}.mi{color:#F60}.mo{color:#F60}.sb{color:#C30}.sc{color:#C30}.sd{color:#C30;font-style:italic}.s2{color:#C30}.se{color:#C30}.sh{color:#C30}.si{color:#A00}.sx{color:#C30}.sr{color:#3AA}.s1{color:#C30}.ss{color:#FC3}.bp{color:#366}.vc{color:#033}.vg{color:#033}.vi{color:#033}.il{color:#F60}.css .o,.css .o+.nt,.css .nt+.nt{color:#999} \ No newline at end of file + */body{position:relative;padding-top:50px;overflow:auto!important}span.hidden-sm{display:inline!important}@media (min-width:768px) and (max-width:992px){span.hidden-sm{display:none!important}}.table code{font-size:13px;font-weight:400}.btn-outline{color:#962A28;background-color:#fff;border-color:#e5e5e5}.btn-outline:hover,.btn-outline:focus,.btn-outline:active{color:#fff;background-color:#962A28;background-image:-webkit-gradient(linear,left top,right top,color-stop(0,#450915),color-stop(1,#962A28));background-image:-o-linear-gradient(right,#450915 0,#962A28 100%);background-image:-moz-linear-gradient(right,#450915 0,#962A28 100%);background-image:-webkit-linear-gradient(right,#450915 0,#962A28 100%);background-image:-ms-linear-gradient(right,#450915 0,#962A28 100%);background-image:linear-gradient(to right,#450915 0,#962A28 100%);border-color:#962A28}.btn-outline-inverse{color:#fff;background-color:transparent;border-color:#cdbfe3}.btn-outline-inverse:hover,.btn-outline-inverse:focus,.btn-outline-inverse:active{color:#563d7c;text-shadow:none;background-color:#fff;border-color:#fff}.bs-docs-nav{text-shadow:0 -1px 0 rgba(0,0,0,.15);box-shadow:0 1px 0 rgba(255,255,255,.1)}.bs-docs-nav .navbar-brand{color:#fff}.bs-docs-nav .navbar-nav>li>a{color:#ceb6b8}.bs-docs-nav .navbar-nav>li>a:hover{color:#fff}.bs-docs-nav .navbar-nav>.active>a,.bs-docs-nav .navbar-nav>.active>a:hover{color:#fff;background-color:#6B313B;background-color:rgba(255,255,255,.15)}.bs-docs-nav .navbar-toggle,.bs-docs-nav .navbar-toggle:focus{border-color:#86555C;border-color:rgba(255,255,255,.3);background:0 0}.bs-docs-nav .navbar-toggle:hover{background-color:#63303A;background-color:rgba(255,255,255,.15);border-color:transparent}.bs-footer{padding-top:40px;padding-bottom:30px;margin-top:100px;color:#777;text-align:center;border-top:1px solid #e5e5e5}.footer-links{margin:10px 0;padding-left:0}.footer-links li{display:inline;padding:0 2px}.footer-links li:first-child{padding-left:0}@media (min-width:768px){.bs-footer{text-align:left}.bs-footer p{margin-bottom:0}}.bs-social{margin-top:20px;margin-bottom:20px;text-align:center}.bs-social-buttons{display:inline-block;margin-bottom:0;padding-left:0;list-style:none}.bs-social-buttons li{display:inline-block;line-height:1;padding:5px 8px}.bs-social-buttons .twitter-follow-button{width:225px!important}.bs-social-buttons .twitter-share-button{width:98px!important}.github-btn{border:0;overflow:hidden}@media (min-width:768px){.bs-social{text-align:left}.bs-social-buttons li:first-child{padding-left:0}}.bs-docs-nav,.bs-docs-home,.bs-header{color:#ceb6b8;background-color:#450915;background-image:url(../img/bg-1920x1200.jpg)}@media (min-width:1921px),(min-height:1201px){.bs-header{background-image:url(../img/bg-3500x2500.jpg)}}.bs-header{background-position:0 -51px}.bs-masthead{position:relative;padding:30px 15px;text-align:center;text-shadow:0 1px 0 rgba(0,0,0,.15)}.bs-masthead h1{font-size:50px;line-height:1;color:#fff}.bs-masthead .btn-outline-inverse{margin:10px}.bs-masthead-links{margin-top:20px;margin-bottom:40px;padding:0 15px;list-style:none;text-align:center}.bs-masthead-links li{display:inline}.bs-masthead-links li+li{margin-left:20px}.bs-masthead a,.bs-masthead-links a{color:#fff}@media (min-width:768px){.bs-masthead{text-align:left;padding-top:140px;padding-bottom:140px}.bs-masthead h1{font-size:100px}.bs-masthead .lead{margin-right:25%;font-size:30px}.bs-masthead .btn-outline-inverse{width:auto;margin:20px 5px 20px 0;padding:18px 24px;font-size:21px}.bs-masthead-links{padding:0;text-align:left}}.bs-header{padding:30px 15px 40px;font-size:16px;text-align:center;text-shadow:0 1px 0 rgba(0,0,0,.15)}.bs-header h1{color:#fff}.bs-header p{font-weight:300;line-height:1.5}.bs-header .container{position:relative}@media (min-width:768px){.bs-header{font-size:21px;text-align:left}.bs-header h1{font-size:60px;line-height:1}}@media (min-width:992px){.bs-header h1,.bs-header p{margin-right:380px}}.aboutme{display:block;margin:50px -30px -40px;padding:5px;overflow:hidden;background:#63303A;background:rgba(255,255,255,.15);box-shadow:inset 0 3px 5px rgba(0,0,0,.075);font-size:13px!important;line-height:16px!important;text-decoration:none;text-align:center}.aboutme:hover{text-decoration:none}.aboutme-text{margin-top:5px;color:#ceb6b8}.aboutme-title{font-weight:700;margin-bottom:4px;color:#fff}.aboutme-name{margin-top:9px;color:#fff}.aboutme img{float:right;height:50px;margin-left:10px}@media screen and (min-width:768px){.aboutme{margin:0!important;border-radius:4px;box-shadow:inset 0 3px 5px rgba(0,0,0,.075),0 1px 0 rgba(255,255,255,.1)}.aboutme-title{display:block}}@media screen and (min-width:992px){.aboutme{position:absolute;top:20px;right:0;padding:15px!important;width:330px!important;min-height:132px;text-align:left}.aboutme-title,.aboutme-name{display:block}.aboutme img{height:auto}}.bs-docs-home .aboutme{margin:0 -15px 40px!important}@media screen and (min-width:480px){.bs-docs-home .aboutme{width:330px!important;margin:0 auto 40px!important;border-radius:4px}}@media screen and (min-width:768px){.bs-docs-home .aboutme{float:left;width:330px!important;margin:0!important}.bs-docs-home .bs-social,.bs-docs-home .bs-masthead-links{margin-left:350px}}@media screen and (min-width:992px){.bs-docs-home .aboutme{position:static}}@media screen and (min-width:1170px){.bs-docs-home .aboutme{margin-top:-25px!important}}.bs-old-docs{padding:15px 20px;color:#777;background-color:#fafafa;border-top:1px solid #fff;border-bottom:1px solid #e5e5e5}.bs-old-docs strong{color:#555}.bs-sidebar.affix{position:static}.bs-sidenav{margin-top:30px;margin-bottom:30px;padding-top:10px;padding-bottom:10px;text-shadow:0 1px 0 #fff;background-color:#f7f5fa;border-radius:5px}.bs-sidebar .nav>li>a{display:block;color:#716b7a;padding:5px 20px}.bs-sidebar .nav>li>a:hover,.bs-sidebar .nav>li>a:focus{text-decoration:none;background-color:#e5e3e9;border-right:1px solid #dbd8e0}.bs-sidebar .nav>.active>a,.bs-sidebar .nav>.active:hover>a,.bs-sidebar .nav>.active:focus>a{font-weight:700;color:#563d7c;background-color:transparent;border-right:1px solid #563d7c}.bs-sidebar .nav .nav{display:none;margin-bottom:8px}.bs-sidebar .nav .nav>li>a{padding-top:3px;padding-bottom:3px;padding-left:30px;font-size:90%}@media (min-width:992px){.bs-sidebar .nav>.active>ul{display:block}.bs-sidebar.affix,.bs-sidebar.affix-bottom{width:213px}.bs-sidebar.affix{position:fixed;top:80px}.bs-sidebar.affix-bottom{position:absolute}.bs-sidebar.affix-bottom .bs-sidenav,.bs-sidebar.affix .bs-sidenav{margin-top:0;margin-bottom:0}}@media (min-width:1200px){.bs-sidebar.affix-bottom,.bs-sidebar.affix{width:263px}}.bs-docs-section+.bs-docs-section{padding-top:40px}h1[id]{padding-top:80px;margin-top:-80px}h2[id],h3[id]{padding-top:65px;margin-top:-20px}.bs-callout{margin:20px 0;padding:20px;border-left:3px solid #eee}.bs-callout h4{margin-top:0;margin-bottom:5px}.bs-callout p:last-child{margin-bottom:0}.bs-callout-danger{background-color:#fdf7f7;border-color:#eed3d7}.bs-callout-danger h4{color:#b94a48}.bs-callout-warning{background-color:#faf8f0;border-color:#faebcc}.bs-callout-warning h4{color:#c09853}.bs-callout-info{background-color:#f4f8fa;border-color:#bce8f1}.bs-callout-info h4{color:#3a87ad}.bs-team .team-member{color:#555;line-height:32px}.bs-team .team-member:hover{color:#333;text-decoration:none}.bs-team .github-btn{float:right;margin-top:6px;width:120px;height:20px}.bs-team img{float:left;width:32px;margin-right:10px;border-radius:4px}.show-grid{margin-bottom:15px}.show-grid [class^=col-]{padding-top:10px;padding-bottom:10px;background-color:#eee;background-color:rgba(86,61,124,.15);border:1px solid #ddd;border:1px solid rgba(86,61,124,.2)}.bs-example{position:relative;padding:45px 15px 15px;margin:0 -15px 15px;background-color:#fafafa;box-shadow:inset 0 3px 6px rgba(0,0,0,.05);border-color:#e5e5e5 #eee #eee;border-style:solid;border-width:1px 0}.bs-example:after{content:"Example";position:absolute;top:15px;left:15px;font-size:12px;font-weight:700;color:#bbb;text-transform:uppercase;letter-spacing:1px}.bs-example+.highlight{margin:-15px -15px 15px;border-radius:0;border-width:0 0 1px}@media (min-width:768px){.bs-example{margin-left:0;margin-right:0;background-color:#fff;border-width:1px;border-color:#ddd;border-radius:4px 4px 0 0;box-shadow:none}.bs-example+.highlight{margin-top:-16px;margin-left:0;margin-right:0;border-width:1px;border-bottom-left-radius:4px;border-bottom-right-radius:4px}}.bs-example .container{width:auto}.bs-example>p:last-child,.bs-example>ul:last-child,.bs-example>ol:last-child,.bs-example>blockquote:last-child,.bs-example>.form-control:last-child,.bs-example>.table:last-child,.bs-example>.navbar:last-child,.bs-example>.jumbotron:last-child,.bs-example>.alert:last-child,.bs-example>.panel:last-child,.bs-example>.list-group:last-child,.bs-example>.well:last-child,.bs-example>.progress:last-child,.bs-example>.table-responsive:last-child>.table{margin-bottom:0}.bs-example>p>.close{float:none}.bs-example-type .table .info{color:#999;vertical-align:middle}.bs-example-type .table td{padding:15px 0;border-color:#eee}.bs-example-type .table tr:first-child td{border-top:0}.bs-example-type h1,.bs-example-type h2,.bs-example-type h3,.bs-example-type h4,.bs-example-type h5,.bs-example-type h6{margin:0}.bs-example>.img-circle,.bs-example>.img-rounded,.bs-example>.img-thumbnail{margin:5px}.bs-example>.table-responsive>.table{background-color:#fff}.bs-example>.btn,.bs-example>.btn-group{margin-top:5px;margin-bottom:5px}.bs-example>.btn-toolbar+.btn-toolbar{margin-top:10px}.bs-example-control-sizing select,.bs-example-control-sizing input[type=text]+input[type=text]{margin-top:10px}.bs-example-form .input-group{margin-bottom:10px}.bs-example>textarea.form-control{resize:vertical}.bs-example>.list-group{max-width:400px}.bs-example .navbar:last-child{margin-bottom:0}.bs-navbar-top-example,.bs-navbar-bottom-example{z-index:1;padding:0;overflow:hidden}.bs-navbar-top-example .navbar-header,.bs-navbar-bottom-example .navbar-header{margin-left:0}.bs-navbar-top-example .navbar-fixed-top,.bs-navbar-bottom-example .navbar-fixed-bottom{position:relative;margin-left:0;margin-right:0}.bs-navbar-top-example{padding-bottom:45px}.bs-navbar-top-example:after{top:auto;bottom:15px}.bs-navbar-top-example .navbar-fixed-top{top:-1px}.bs-navbar-bottom-example{padding-top:45px}.bs-navbar-bottom-example .navbar-fixed-bottom{bottom:-1px}.bs-navbar-bottom-example .navbar{margin-bottom:0}@media (min-width:768px){.bs-navbar-top-example .navbar-fixed-top,.bs-navbar-bottom-example .navbar-fixed-bottom{position:absolute}.bs-navbar-top-example{border-radius:0 0 4px 4px}.bs-navbar-bottom-example{border-radius:4px 4px 0 0}}.bs-navmenu-fixed-example{height:200px;padding-left:315px}.bs-navmenu-fixed-example:after{left:315px}.bs-navmenu-offcanvas-example{min-height:200px;overflow:hidden}.bs-navmenu-offcanvas-example:after{display:none}.bs-navmenu-offcanvas-example>div{position:absolute;top:0;left:0;height:100%;width:100%;padding:70px 15px 15px}.bs-navmenu-offcanvas-example p{color:#bbb}.bs-navmenu-fixed-example .navmenu-fixed-left,.bs-navmenu-offcanvas-example .navmenu-fixed-left,.bs-navmenu-offcanvas-example .navbar-fixed-top{position:absolute;z-index:1}.bs-navmenu-offcanvas-example .navmenu-fixed-left{-webkit-transform:translate(-300px,0);transform:translate(-300px,0)}.bs-navmenu-offcanvas-example .navbar-toggle{float:left;margin-left:15px;display:block}.bs-example .pagination{margin-top:10px;margin-bottom:10px}.bs-example .alert-fixed-top{position:absolute;z-index:1;width:auto;left:0;right:0;margin-left:0}@media (min-width:992px){.bs-example .alert-fixed-top{left:15px;right:15px}}.bs-example>.pager{margin-top:0}.bs-example-modal{background-color:#f5f5f5}.bs-example-modal .modal{position:relative;top:auto;right:auto;left:auto;bottom:auto;z-index:1;display:block}.bs-example-modal .modal-dialog{left:auto;margin-left:auto;margin-right:auto}.bs-example>.dropdown>.dropdown-menu{position:static;display:block;margin-bottom:5px}.bs-example-tabs .nav-tabs{margin-bottom:15px}.bs-example-tooltips{text-align:center}.bs-example-tooltips>.btn{margin-top:5px;margin-bottom:5px}.bs-example-popover{padding-bottom:24px;background-color:#f9f9f9}.bs-example-popover .popover{position:relative;display:block;float:left;width:260px;margin:20px}.scrollspy-example{position:relative;height:200px;margin-top:10px;overflow:auto}.highlight{display:none;padding:9px 14px;margin-bottom:14px;background-color:#f7f7f9;border:1px solid #e1e1e8;border-radius:4px}.highlight pre{padding:0;margin-top:0;margin-bottom:0;background-color:transparent;border:0;white-space:nowrap}.highlight pre code{font-size:inherit;color:#333}.highlight pre .lineno{display:inline-block;width:22px;padding-right:5px;margin-right:10px;text-align:right;color:#bebec5}@media (min-width:481px){.highlight{display:block}}.table-responsive .highlight pre{white-space:normal}.bs-table th small,.responsive-utilities th small{display:block;font-weight:400;color:#999}.responsive-utilities tbody th{font-weight:400}.responsive-utilities td{text-align:center}.responsive-utilities td.is-visible{color:#468847;background-color:#dff0d8!important}.responsive-utilities td.is-hidden{color:#ccc;background-color:#f9f9f9!important}.responsive-utilities-test{margin-top:5px}.responsive-utilities-test .col-xs-6{margin-bottom:10px}.responsive-utilities-test span{padding:15px 10px;font-size:14px;font-weight:700;line-height:1.1;text-align:center;border-radius:4px}.visible-on .col-xs-6 .hidden-xs,.visible-on .col-xs-6 .hidden-sm,.visible-on .col-xs-6 .hidden-md,.visible-on .col-xs-6 .hidden-lg,.hidden-on .col-xs-6 .hidden-xs,.hidden-on .col-xs-6 .hidden-sm,.hidden-on .col-xs-6 .hidden-md,.hidden-on .col-xs-6 .hidden-lg{color:#999;border:1px solid #ddd}.visible-on .col-xs-6 .visible-xs,.visible-on .col-xs-6 .visible-sm,.visible-on .col-xs-6 .visible-md,.visible-on .col-xs-6 .visible-lg,.hidden-on .col-xs-6 .visible-xs,.hidden-on .col-xs-6 .visible-sm,.hidden-on .col-xs-6 .visible-md,.hidden-on .col-xs-6 .visible-lg{color:#468847;background-color:#dff0d8;border:1px solid #d6e9c6}.bs-customizer .toggle{float:right;margin-top:80px}.bs-customizer label{margin-top:10px;font-weight:500;color:#555}.bs-customizer h2{margin-top:0;margin-bottom:5px;padding-top:30px}.bs-customizer h3{margin-bottom:0}.bs-customizer h4{margin-top:15px;margin-bottom:0}.bs-customizer .bs-callout h4{margin-top:0;margin-bottom:5px}.bs-customizer input[type=text]{font-family:Menlo,Monaco,Consolas,"Courier New",monospace;background-color:#fafafa}.bs-customizer .help-block{font-size:12px;margin-bottom:5px}#less-section label{font-weight:400}.bs-customizer-input{float:left;width:33.333333%;padding-left:15px;padding-right:15px}.bs-customize-download .btn-outline{padding:20px}.bs-customizer-alert{position:fixed;top:0;left:0;right:0;z-index:1030;padding:15px 0;color:#fff;background-color:#d9534f;box-shadow:inset 0 1px 0 rgba(255,255,255,.25);border-bottom:1px solid #b94441}.bs-customizer-alert .close{margin-top:-4px;font-size:24px}.bs-customizer-alert p{margin-bottom:0}.bs-customizer-alert .glyphicon{margin-right:5px}.bs-customizer-alert pre{margin:10px 0 0;color:#fff;background-color:#a83c3a;border-color:#973634;box-shadow:inset 0 2px 4px rgba(0,0,0,.05),0 1px 0 rgba(255,255,255,.1)}.bs-about{font-size:16px}.bs-examples h4{margin-bottom:5px}.bs-examples p{margin-bottom:20px}#focusedInput{border-color:#52a8ec;border-color:rgba(82,168,236,.8);outline:0;outline:thin dotted \9;-moz-box-shadow:0 0 8px rgba(82,168,236,.6);box-shadow:0 0 8px rgba(82,168,236,.6)}.bs-docs-dl-options h4{margin-top:15px;margin-bottom:5px}.hll{background-color:#ffc}.c{color:#999}.err{color:#A00;background-color:#FAA}.k{color:#069}.o{color:#555}.cm{color:#09F;font-style:italic}.cp{color:#099}.c1{color:#999}.cs{color:#999}.gd{background-color:#FCC;border:1px solid #C00}.ge{font-style:italic}.gr{color:red}.gh{color:#030}.gi{background-color:#CFC;border:1px solid #0C0}.go{color:#AAA}.gp{color:#009}.gu{color:#030}.gt{color:#9C6}.kc{color:#069}.kd{color:#069}.kn{color:#069}.kp{color:#069}.kr{color:#069}.kt{color:#078}.m{color:#F60}.s{color:#d44950}.na{color:#4f9fcf}.nb{color:#366}.nc{color:#0A8}.no{color:#360}.nd{color:#99F}.ni{color:#999}.ne{color:#C00}.nf{color:#C0F}.nl{color:#99F}.nn{color:#0CF}.nt{color:#2f6f9f}.nv{color:#033}.ow{color:#000}.w{color:#bbb}.mf{color:#F60}.mh{color:#F60}.mi{color:#F60}.mo{color:#F60}.sb{color:#C30}.sc{color:#C30}.sd{color:#C30;font-style:italic}.s2{color:#C30}.se{color:#C30}.sh{color:#C30}.si{color:#A00}.sx{color:#C30}.sr{color:#3AA}.s1{color:#C30}.ss{color:#FC3}.bp{color:#366}.vc{color:#033}.vg{color:#033}.vi{color:#033}.il{color:#F60}.css .o,.css .o+.nt,.css .nt+.nt{color:#999} \ No newline at end of file diff --git a/assets/js/customize.min.js b/assets/js/customize.min.js index 0f11981d..2bb1076b 100644 --- a/assets/js/customize.min.js +++ b/assets/js/customize.min.js @@ -44,7 +44,7 @@ var saveAs=saveAs||navigator.msSaveOrOpenBlob&&navigator.msSaveOrOpenBlob.bind(n * Copyright 2012-2014 Arnold Daniels * Licensed under Apache-2.0 (https://github.com/jasny/bootstrap/blob/master/LICENSE) */ -var __js={"fileinput.js":"/* ===========================================================\n * Bootstrap: fileinput.js v3.0.0-p7\n * http://jasny.github.com/bootstrap/javascript.html#fileinput\n * ===========================================================\n * Copyright 2012 Jasny BV, Netherlands.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\")\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * ========================================================== */\n\n+function ($) { \"use strict\";\n\n var isIE = window.navigator.appName == 'Microsoft Internet Explorer'\n\n // FILEUPLOAD PUBLIC CLASS DEFINITION\n // =================================\n\n var Fileinput = function (element, options) {\n this.$element = $(element)\n \n this.$input = this.$element.find(':file')\n if (this.$input.length === 0) return\n\n this.name = this.$input.attr('name') || options.name\n\n this.$hidden = this.$element.find('input[type=hidden][name=\"' + this.name + '\"]')\n if (this.$hidden.length === 0) {\n this.$hidden = $('')\n this.$element.prepend(this.$hidden)\n }\n\n this.$preview = this.$element.find('.fileinput-preview')\n var height = this.$preview.css('height')\n if (this.$preview.css('display') != 'inline' && height != '0px' && height != 'none') this.$preview.css('line-height', height)\n\n this.original = {\n exists: this.$element.hasClass('fileinput-exists'),\n preview: this.$preview.html(),\n hiddenVal: this.$hidden.val()\n }\n \n this.listen()\n }\n \n Fileinput.prototype.listen = function() {\n this.$input.on('change.bs.fileinput', $.proxy(this.change, this))\n $(this.$input[0].form).on('reset.bs.fileinput', $.proxy(this.reset, this))\n \n this.$element.find('[data-trigger=\"fileinput\"]').on('click.bs.fileinput', $.proxy(this.trigger, this))\n this.$element.find('[data-dismiss=\"fileinput\"]').on('click.bs.fileinput', $.proxy(this.clear, this))\n },\n\n Fileinput.prototype.change = function(e) {\n if (e.target.files === undefined) e.target.files = e.target && e.target.value ? [ {name: e.target.value.replace(/^.+\\\\/, '')} ] : []\n if (e.target.files.length === 0) return\n\n this.$hidden.val('')\n this.$hidden.attr('name', '')\n this.$input.attr('name', this.name)\n\n var file = e.target.files[0]\n\n if (this.$preview.length > 0 && (typeof file.type !== \"undefined\" ? file.type.match('image.*') : file.name.match(/\\.(gif|png|jpe?g)$/i)) && typeof FileReader !== \"undefined\") {\n var reader = new FileReader()\n var preview = this.$preview\n var element = this.$element\n\n reader.onload = function(re) {\n var $img = $('') // .attr('src', re.target.result)\n $img[0].src = re.target.result\n e.target.files[0].result = re.target.result\n \n element.find('.fileinput-filename').text(file.name)\n \n // if parent has max-height, using `(max-)height: 100%` on child doesn't take padding and border into account\n if (preview.css('max-height') != 'none') $img.css('max-height', parseInt(preview.css('max-height'), 10) - parseInt(preview.css('padding-top'), 10) - parseInt(preview.css('padding-bottom'), 10) - parseInt(preview.css('border-top'), 10) - parseInt(preview.css('border-bottom'), 10))\n \n preview.html($img)\n element.addClass('fileinput-exists').removeClass('fileinput-new')\n\n element.trigger('change.bs.fileinput', e.target.files)\n }\n\n reader.readAsDataURL(file)\n } else {\n this.$element.find('.fileinput-filename').text(file.name)\n this.$preview.text(file.name)\n \n this.$element.addClass('fileinput-exists').removeClass('fileinput-new')\n \n this.$element.trigger('change.bs.fileinput')\n }\n },\n\n Fileinput.prototype.clear = function(e) {\n if (e) e.preventDefault()\n \n this.$hidden.val('')\n this.$hidden.attr('name', this.name)\n this.$input.attr('name', '')\n\n //ie8+ doesn't support changing the value of input with type=file so clone instead\n if (isIE) { \n var inputClone = this.$input.clone(true);\n this.$input.after(inputClone);\n this.$input.remove();\n this.$input = inputClone;\n } else {\n this.$input.val('')\n }\n\n this.$preview.html('')\n this.$element.find('.fileinput-filename').text('')\n this.$element.addClass('fileinput-new').removeClass('fileinput-exists')\n \n if (e !== false) {\n this.$input.trigger('change')\n this.$element.trigger('clear.bs.fileinput')\n }\n },\n\n Fileinput.prototype.reset = function() {\n this.clear(false)\n\n this.$hidden.val(this.original.hiddenVal)\n this.$preview.html(this.original.preview)\n this.$element.find('.fileinput-filename').text('')\n\n if (this.original.exists) this.$element.addClass('fileinput-exists').removeClass('fileinput-new')\n else this.$element.addClass('fileinput-new').removeClass('fileinput-exists')\n \n this.$element.trigger('reset.bs.fileinput')\n },\n\n Fileinput.prototype.trigger = function(e) {\n this.$input.trigger('click')\n e.preventDefault()\n }\n\n \n // FILEUPLOAD PLUGIN DEFINITION\n // ===========================\n\n var old = $.fn.fileinput\n \n $.fn.fileinput = function (options) {\n return this.each(function () {\n var $this = $(this),\n data = $this.data('fileinput')\n if (!data) $this.data('fileinput', (data = new Fileinput(this, options)))\n if (typeof options == 'string') data[options]()\n })\n }\n\n $.fn.fileinput.Constructor = Fileinput\n\n\n // FILEINPUT NO CONFLICT\n // ====================\n\n $.fn.fileinput.noConflict = function () {\n $.fn.fileinput = old\n return this\n }\n\n\n // FILEUPLOAD DATA-API\n // ==================\n\n $(document).on('click.fileinput.data-api', '[data-provides=\"fileinput\"]', function (e) {\n var $this = $(this)\n if ($this.data('fileinput')) return\n $this.fileinput($this.data())\n \n var $target = $(e.target).closest('[data-dismiss=\"fileinput\"],[data-trigger=\"fileinput\"]');\n if ($target.length > 0) {\n e.preventDefault()\n $target.trigger('click.bs.fileinput')\n }\n })\n\n}(window.jQuery);\n","inputmask.js":'/* ===========================================================\n * Bootstrap: inputmask.js v3.0.0-p7\n * http://jasny.github.io/bootstrap/javascript.html#inputmask\n * Based on Masked Input plugin by Josh Bush (digitalbush.com)\n * ===========================================================\n * Copyright 2012 Jasny BV, Netherlands.\n *\n * Licensed under the Apache License, Version 2.0 (the "License")\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an "AS IS" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * ========================================================== */\n\n+function ($) { "use strict";\n\n var isIphone = (window.orientation !== undefined)\n var isAndroid = navigator.userAgent.toLowerCase().indexOf("android") > -1\n var isIE = window.navigator.appName == \'Microsoft Internet Explorer\'\n\n // INPUTMASK PUBLIC CLASS DEFINITION\n // =================================\n\n var Inputmask = function (element, options) {\n if (isAndroid) return // No support because caret positioning doesn\'t work on Android\n \n this.$element = $(element)\n this.options = $.extend({}, Inputmask.DEFAULS, options)\n this.mask = String(this.options.mask)\n \n this.init()\n this.listen()\n \n this.checkVal() //Perform initial check for existing values\n }\n\n Inputmask.DEFAULS = {\n mask: "",\n placeholder: "_",\n definitions: {\n \'9\': "[0-9]",\n \'a\': "[A-Za-z]",\n \'?\': "[A-Za-z0-9]",\n \'*\': "."\n }\n }\n\n Inputmask.prototype.init = function() {\n var defs = this.options.definitions\n var len = this.mask.length\n\n this.tests = [] \n this.partialPosition = this.mask.length\n this.firstNonMaskPos = null\n\n $.each(this.mask.split(""), $.proxy(function(i, c) {\n if (c == \'?\') {\n len--\n this.partialPosition = i\n } else if (defs[c]) {\n this.tests.push(new RegExp(defs[c]))\n if (this.firstNonMaskPos === null)\n this.firstNonMaskPos = this.tests.length - 1\n } else {\n this.tests.push(null)\n }\n }, this))\n\n this.buffer = $.map(this.mask.split(""), $.proxy(function(c, i) {\n if (c != \'?\') return defs[c] ? this.options.placeholder : c\n }, this))\n\n this.focusText = this.$element.val()\n\n this.$element.data("rawMaskFn", $.proxy(function() {\n return $.map(this.buffer, function(c, i) {\n return this.tests[i] && c != this.options.placeholder ? c : null\n }).join(\'\')\n }, this))\n }\n \n Inputmask.prototype.listen = function() {\n if (this.$element.attr("readonly")) return\n\n var pasteEventName = (isIE ? \'paste\' : \'input\') + ".mask"\n\n this.$element\n .on("unmask.bs.inputmask", $.proxy(this.unmask, this))\n\n .on("focus.bs.inputmask", $.proxy(this.focusEvent, this))\n .on("blur.bs.inputmask", $.proxy(this.blurEvent, this))\n\n .on("keydown.bs.inputmask", $.proxy(this.keydownEvent, this))\n .on("keypress.bs.inputmask", $.proxy(this.keypressEvent, this))\n\n .on(pasteEventName, $.proxy(this.pasteEvent, this))\n }\n\n //Helper Function for Caret positioning\n Inputmask.prototype.caret = function(begin, end) {\n if (this.$element.length === 0) return\n if (typeof begin == \'number\') {\n end = (typeof end == \'number\') ? end : begin\n return this.$element.each(function() {\n if (this.setSelectionRange) {\n this.setSelectionRange(begin, end)\n } else if (this.createTextRange) {\n var range = this.createTextRange()\n range.collapse(true)\n range.moveEnd(\'character\', end)\n range.moveStart(\'character\', begin)\n range.select()\n }\n })\n } else {\n if (this.$element[0].setSelectionRange) {\n begin = this.$element[0].selectionStart\n end = this.$element[0].selectionEnd\n } else if (document.selection && document.selection.createRange) {\n var range = document.selection.createRange()\n begin = 0 - range.duplicate().moveStart(\'character\', -100000)\n end = begin + range.text.length\n }\n return {\n begin: begin, \n end: end\n }\n }\n }\n \n Inputmask.prototype.seekNext = function(pos) {\n var len = this.mask.length\n while (++pos <= len && !this.tests[pos]);\n\n return pos\n }\n \n Inputmask.prototype.seekPrev = function(pos) {\n while (--pos >= 0 && !this.tests[pos]);\n\n return pos\n }\n\n Inputmask.prototype.shiftL = function(begin,end) {\n var len = this.mask.length\n\n if (begin < 0) return\n\n for (var i = begin, j = this.seekNext(end); i < len; i++) {\n if (this.tests[i]) {\n if (j < len && this.tests[i].test(this.buffer[j])) {\n this.buffer[i] = this.buffer[j]\n this.buffer[j] = this.options.placeholder\n } else\n break\n j = this.seekNext(j)\n }\n }\n this.writeBuffer()\n this.caret(Math.max(this.firstNonMaskPos, begin))\n }\n\n Inputmask.prototype.shiftR = function(pos) {\n var len = this.mask.length\n\n for (var i = pos, c = this.options.placeholder; i < len; i++) {\n if (this.tests[i]) {\n var j = this.seekNext(i)\n var t = this.buffer[i]\n this.buffer[i] = c\n if (j < len && this.tests[j].test(t))\n c = t\n else\n break\n }\n }\n },\n\n Inputmask.prototype.unmask = function() {\n this.$element\n .unbind(".mask")\n .removeData("inputmask")\n }\n\n Inputmask.prototype.focusEvent = function() {\n this.focusText = this.$element.val()\n var len = this.mask.length \n var pos = this.checkVal()\n this.writeBuffer()\n\n var that = this\n var moveCaret = function() {\n if (pos == len)\n that.caret(0, pos)\n else\n that.caret(pos)\n }\n\n moveCaret()\n setTimeout(moveCaret, 50)\n }\n\n Inputmask.prototype.blurEvent = function() {\n this.checkVal()\n if (this.$element.val() !== this.focusText)\n this.$element.trigger(\'change\')\n }\n\n Inputmask.prototype.keydownEvent = function(e) {\n var k = e.which\n\n //backspace, delete, and escape get special treatment\n if (k == 8 || k == 46 || (isIphone && k == 127)) {\n var pos = this.caret(),\n begin = pos.begin,\n end = pos.end\n\n if (end - begin === 0) {\n begin = k != 46 ? this.seekPrev(begin) : (end = this.seekNext(begin - 1))\n end = k == 46 ? this.seekNext(end) : end\n }\n this.clearBuffer(begin, end)\n this.shiftL(begin, end - 1)\n\n return false\n } else if (k == 27) {//escape\n this.$element.val(this.focusText)\n this.caret(0, this.checkVal())\n return false\n }\n }\n\n Inputmask.prototype.keypressEvent = function(e) {\n var len = this.mask.length\n\n var k = e.which,\n pos = this.caret()\n\n if (e.ctrlKey || e.altKey || e.metaKey || k < 32) {//Ignore\n return true\n } else if (k) {\n if (pos.end - pos.begin !== 0) {\n this.clearBuffer(pos.begin, pos.end)\n this.shiftL(pos.begin, pos.end - 1)\n }\n\n var p = this.seekNext(pos.begin - 1)\n if (p < len) {\n var c = String.fromCharCode(k)\n if (this.tests[p].test(c)) {\n this.shiftR(p)\n this.buffer[p] = c\n this.writeBuffer()\n var next = this.seekNext(p)\n this.caret(next)\n }\n }\n return false\n }\n }\n\n Inputmask.prototype.pasteEvent = function() {\n var that = this\n\n setTimeout(function() {\n that.caret(that.checkVal(true))\n }, 0)\n }\n\n Inputmask.prototype.clearBuffer = function(start, end) {\n var len = this.mask.length\n\n for (var i = start; i < end && i < len; i++) {\n if (this.tests[i])\n this.buffer[i] = this.options.placeholder\n }\n }\n\n Inputmask.prototype.writeBuffer = function() {\n return this.$element.val(this.buffer.join(\'\')).val()\n }\n\n Inputmask.prototype.checkVal = function(allow) {\n var len = this.mask.length\n //try to place characters where they belong\n var test = this.$element.val()\n var lastMatch = -1\n\n for (var i = 0, pos = 0; i < len; i++) {\n if (this.tests[i]) {\n this.buffer[i] = this.options.placeholder\n while (pos++ < test.length) {\n var c = test.charAt(pos - 1)\n if (this.tests[i].test(c)) {\n this.buffer[i] = c\n lastMatch = i\n break\n }\n }\n if (pos > test.length)\n break\n } else if (this.buffer[i] == test.charAt(pos) && i != this.partialPosition) {\n pos++\n lastMatch = i\n }\n }\n if (!allow && lastMatch + 1 < this.partialPosition) {\n this.$element.val("")\n this.clearBuffer(0, len)\n } else if (allow || lastMatch + 1 >= this.partialPosition) {\n this.writeBuffer()\n if (!allow) this.$element.val(this.$element.val().substring(0, lastMatch + 1))\n }\n return (this.partialPosition ? i : this.firstNonMaskPos)\n }\n\n \n // INPUTMASK PLUGIN DEFINITION\n // ===========================\n\n var old = $.fn.inputmask\n \n $.fn.inputmask = function (options) {\n return this.each(function () {\n var $this = $(this)\n var data = $this.data(\'inputmask\')\n \n if (!data) $this.data(\'inputmask\', (data = new Inputmask(this, options)))\n })\n }\n\n $.fn.inputmask.Constructor = Inputmask\n\n\n // INPUTMASK NO CONFLICT\n // ====================\n\n $.fn.inputmask.noConflict = function () {\n $.fn.inputmask = old\n return this\n }\n\n\n // INPUTMASK DATA-API\n // ==================\n\n $(document).on(\'focus.bs.inputmask.data-api\', \'[data-mask]\', function (e) {\n var $this = $(this)\n if ($this.data(\'inputmask\')) return\n $this.inputmask($this.data())\n })\n\n}(window.jQuery);\n',"offcanvas.js":"/* ========================================================================\n * Bootstrap: offcanvas.js v3.0.3-p7\n * http://jasny.github.io/bootstrap/javascript.html#offcanvas\n * \n * Based on Boostrap collapse.js by Twitter, Inc. \n * ========================================================================\n * Copyright 2013 Jasny, BV.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\")\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * ======================================================================== */\n\n+function ($) { \"use strict\";\n\n // OFFCANVAS PUBLIC CLASS DEFINITION\n // =================================\n\n var OffCanvas = function (element, options) {\n this.$element = $(element)\n this.options = $.extend({}, OffCanvas.DEFAULTS, options)\n this.state = null\n \n if (this.options.recalc) {\n this.calcClone()\n $(window).on('resize', $.proxy(this.recalc, this))\n }\n \n if (this.options.autohide)\n $(document).on('click', $.proxy(this.autohide, this))\n\n if (this.options.toggle) this.toggle()\n }\n\n OffCanvas.DEFAULTS = {\n toggle: true,\n placement: 'left',\n autohide: true,\n recalc: true\n }\n\n OffCanvas.prototype.offset = function () {\n switch (this.options.placement) {\n case 'left':\n case 'right': return this.$element.outerWidth()\n case 'top':\n case 'bottom': return this.$element.outerHeight()\n }\n }\n \n OffCanvas.prototype.calcPlacement = function () {\n var horizontal = $(window).width() / this.$element.width(),\n vertical = $(window).height() / this.$element.height()\n \n if (!this.$element.hasClass('in')) {\n this.$element.css('visiblity', 'hidden !important').addClass('in')\n } \n \n var element = this.$element\n function ab(a, b) {\n if (element.css(b) === 'auto') return a\n if (element.css(a) === 'auto') return b\n \n var size_a = parseInt(element.css(a), 10),\n size_b = parseInt(element.css(b), 10)\n \n return size_a > size_b ? b : a\n }\n \n this.options.placement = horizontal > vertical ? ab('left', 'right') : ab('top', 'bottom')\n \n if (this.$element.css('visibility') === 'hidden !important') {\n this.$element.removeClass('in').css('visiblity', '')\n }\n }\n \n OffCanvas.prototype.opposite = function (placement) {\n switch (placement) {\n case 'top': return 'bottom'\n case 'left': return 'right'\n case 'bottom': return 'top'\n case 'right': return 'left'\n }\n }\n \n OffCanvas.prototype.getCanvasElements = function() {\n // Return a set containing the canvas plus all fixed elements\n var canvas = this.options.canvas ? $(this.options.canvas) : this.$element\n \n var fixed_elements = canvas.find('*').filter(function() {\n return $(this).css('position') === 'fixed'\n }).not(this.options.exclude)\n \n return canvas.add(fixed_elements)\n }\n \n OffCanvas.prototype.slide = function (elements, offset, callback) {\n // Use jQuery animation if CSS transitions aren't supported\n if (!$.support.transition) {\n var anim = {}\n anim[this.options.placement] = \"+=\" + offset\n return elements.animate(anim, 350, callback)\n }\n\n var placement = this.options.placement,\n opposite = this.opposite(placement)\n \n elements.each(function() {\n if ($(this).css(placement) !== 'auto')\n $(this).css(placement, (parseInt($(this).css(placement), 10) || 0) + offset)\n \n if ($(this).css(opposite) !== 'auto')\n $(this).css(opposite, (parseInt($(this).css(opposite), 10) || 0) - offset)\n })\n \n this.$element\n .one($.support.transition.end, callback)\n .emulateTransitionEnd(350)\n }\n\n OffCanvas.prototype.disableScrolling = function() {\n var bodyWidth = $('body').width()\n var prop = 'padding-' + this.opposite(this.options.placement)\n\n if ($('body').data('offcanvas-style') === undefined) $('body').data('offcanvas-style', $('body').attr('style'))\n \n $('body').css('overflow', 'hidden')\n\n if ($('body').width() > bodyWidth) {\n var padding = parseInt($('body').css(prop), 10) + $('body').width() - bodyWidth\n \n setTimeout(function() {\n $('body').css(prop, padding)\n }, 1)\n }\n }\n\n OffCanvas.prototype.show = function () {\n if (this.state) return\n \n var startEvent = $.Event('show.bs.offcanvas')\n this.$element.trigger(startEvent)\n if (startEvent.isDefaultPrevented()) return\n\n if (this.options.placement === 'auto') this.calcPlacement()\n\n this.state = 'sliding'\n\n var elements = this.getCanvasElements()\n var offset = this.offset(),\n placement = this.options.placement,\n opposite = this.opposite(placement)\n\n elements.addClass('canvas-sliding').each(function() {\n $(this).data('offcanvas-style', $(this).attr('style') || '')\n if ($(this).css('position') === 'static') $(this).css('position', 'relative')\n if ($(this).css(placement) === 'auto' && $(this).css(opposite) === 'auto') $(this).css(placement, 0)\n })\n \n if (elements.index(this.$element) !== -1) this.$element.css(placement, -1 * offset)\n\n this.disableScrolling()\n \n var complete = function () {\n this.state = 'slid'\n\n elements.removeClass('canvas-sliding').addClass('canvas-slid')\n this.$element.trigger('shown.bs.offcanvas')\n }\n\n setTimeout($.proxy(function() {\n this.$element.addClass('in')\n this.slide(elements, offset, $.proxy(complete, this))\n }, this), 1)\n }\n\n OffCanvas.prototype.hide = function (fast) {\n if (this.state !== 'slid') return\n\n var startEvent = $.Event('hide.bs.offcanvas')\n this.$element.trigger(startEvent)\n if (startEvent.isDefaultPrevented()) return\n\n this.state = 'sliding'\n\n var elements = $('.canvas-slid')\n var offset = -1 * this.offset()\n\n var complete = function () {\n this.state = null\n\n this.$element.removeClass('in')\n \n elements.removeClass('canvas-sliding')\n elements.add('body').each(function() {\n $(this).attr('style', $(this).data('offcanvas-style')).removeData('offcanvas-style')\n })\n\n this.$element.trigger('hidden.bs.offcanvas')\n }\n\n elements.removeClass('canvas-slid').addClass('canvas-sliding')\n \n setTimeout($.proxy(function() {\n this.slide(elements, offset, $.proxy(complete, this))\n }, this), 1)\n }\n\n OffCanvas.prototype.toggle = function () {\n if (this.state === 'sliding') return\n this[this.state === 'slid' ? 'hide' : 'show']()\n }\n\n OffCanvas.prototype.calcClone = function() {\n this.$calcClone = this.$element.clone()\n .html('')\n .addClass('offcanvas-clone').removeClass('in')\n .appendTo($('body'))\n }\n\n OffCanvas.prototype.recalc = function () {\n if (this.state() !== 'slid' || this.$calcClone.css('display') === 'none') return\n \n var offset = -1 * this.offset()\n \n var placement = this.options.placement\n this.getCanvasElements().each(function() {\n $(this).css(placement, (parseInt($(this).css(placement), 10) || 0) + offset)\n }).removeClass('canvas-slid')\n \n $('body').css('overflow', '')\n this.$element.css(placement, '').removeClass('in canvas-slid')\n }\n \n OffCanvas.prototype.autohide = function (e) {\n if ($(e.target).closest(this.$element).length === 0) this.hide()\n }\n\n // OFFCANVAS PLUGIN DEFINITION\n // ==========================\n\n var old = $.fn.offcanvas\n\n $.fn.offcanvas = function (option) {\n return this.each(function () {\n var $this = $(this)\n var data = $this.data('bs.offcanvas')\n var options = $.extend({}, OffCanvas.DEFAULTS, $this.data(), typeof option == 'object' && option)\n\n if (!data) $this.data('bs.offcanvas', (data = new OffCanvas(this, options)))\n if (typeof option == 'string') data[option]()\n })\n }\n\n $.fn.offcanvas.Constructor = OffCanvas\n\n\n // OFFCANVAS NO CONFLICT\n // ====================\n\n $.fn.offcanvas.noConflict = function () {\n $.fn.offcanvas = old\n return this\n }\n\n\n // OFFCANVAS DATA-API\n // =================\n\n $(document).on('click.bs.offcanvas.data-api', '[data-toggle=offcanvas]', function (e) {\n var $this = $(this), href\n var target = $this.attr('data-target')\n || e.preventDefault()\n || (href = $this.attr('href')) && href.replace(/.*(?=#[^\\s]+$)/, '') //strip for ie7\n var $canvas = $(target)\n var data = $canvas.data('bs.offcanvas')\n var option = data ? 'toggle' : $this.data()\n\n e.stopPropagation()\n\n if (data) data.toggle()\n else $canvas.offcanvas(option)\n })\n\n}(window.jQuery);\n","rowlink.js":"/* ============================================================\n * Bootstrap: rowlink.js v3.0.0-p7\n * http://jasny.github.io/bootstrap/javascript.html#rowlink\n * ============================================================\n * Copyright 2012 Jasny BV, Netherlands.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * ============================================================ */\n\n+function ($) { \"use strict\";\n\n var Rowlink = function (element, options) {\n this.$element = $(element)\n this.options = $.extend({}, Rowlink.DEFAULTS, options)\n \n this.$element.on('click.bs.rowlink', 'td:not(.rowlink-skip)', $.proxy(this.click, this))\n }\n\n Rowlink.DEFAULTS = {\n target: \"a\"\n }\n\n Rowlink.prototype.click = function(e) {\n var target = $(e.currentTarget).closest('tr').find(this.options.target)[0]\n if ($(e.target)[0] === target) return\n \n e.preventDefault();\n \n if (target.click) {\n target.click()\n } else if (document.createEvent) {\n var evt = document.createEvent(\"MouseEvents\"); \n evt.initMouseEvent(\"click\", true, true, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null); \n target.dispatchEvent(evt);\n }\n }\n\n \n // ROWLINK PLUGIN DEFINITION\n // ===========================\n\n var old = $.fn.rowlink\n\n $.fn.rowlink = function (options) {\n return this.each(function () {\n var $this = $(this)\n var data = $this.data('rowlink')\n if (!data) $this.data('rowlink', (data = new Rowlink(this, options)))\n })\n }\n\n $.fn.rowlink.Constructor = Rowlink\n\n\n // ROWLINK NO CONFLICT\n // ====================\n\n $.fn.rowlink.noConflict = function () {\n $.fn.rowlink = old\n return this\n }\n\n\n // ROWLINK DATA-API\n // ==================\n\n $(document).on('click.bs.rowlink.data-api', '[data-link=\"row\"]', function (e) {\n var $this = $(this)\n if ($this.data('rowlink')) return\n $this.rowlink($this.data())\n $(e.target).trigger('click.bs.rowlink')\n })\n \n}(window.jQuery);\n"},__less={"alerts-fixed.less":"// Fixed alerts\n//\n// Position to the top or bottom.\n\n.alert-fixed-top,\n.alert-fixed-bottom {\n position: fixed;\n width: 100%;\n z-index: @zindex-alert-fixed;\n border-radius: 0;\n margin: 0;\n left: 0;\n\n @media (min-width: @alert-fixed-width) {\n width: @alert-fixed-width;\n left: 50%;\n margin-left: (-1 * (@alert-fixed-width / 2));\n }\n}\n\n.alert-fixed-top {\n top: 0;\n border-width: 0 0 1px 0;\n \n @media (min-width: @alert-fixed-width) {\n .border-bottom-radius(@alert-border-radius);\n border-width: 0 1px 1px 1px;\n }\n}\n\n.alert-fixed-bottom {\n bottom: 0;\n border-width: 1px 0 0 0;\n \n @media (min-width: @alert-fixed-width) {\n .border-top-radius(@alert-border-radius);\n border-width: 1px 1px 0 1px;\n }\n}\n","button-labels.less":"// Labels for buttons\n// --------------------------------------------------\n\n// Mixin\n.button-label-size(@padding-vertical; @padding-horizontal; @border-radius) {\n padding: @padding-vertical @padding-horizontal;\n left: (-1 * @padding-horizontal);\n border-radius: (@border-radius - 1px) 0 0 (@border-radius - 1px);\n\n &.btn-label-right {\n left: auto;\n right: (-1 * @padding-horizontal);\n border-radius: 0 (@border-radius - 1px) (@border-radius - 1px) 0;\n }\n}\n\n.btn-labeled {\n padding-top: 0;\n padding-bottom: 0;\n}\n\n.btn-label {\n position: relative;\n background: transparent;\n background: rgba(0, 0, 0, 0.15);\n display: inline-block;\n .button-label-size(@padding-base-vertical; @padding-base-horizontal; @border-radius-base);\n}\n\n.btn-lg .btn-label {\n .button-label-size(@padding-large-vertical; @padding-large-horizontal; @border-radius-large);\n}\n.btn-sm .btn-label {\n .button-label-size(@padding-small-vertical; @padding-small-horizontal; @border-radius-small);\n}\n.btn-xs .btn-label {\n .button-label-size(1px; 5px; @border-radius-small);\n}\n","fileinput.less":"// Fileinput.less\n// CSS for file upload button and fileinput widget\n// ------------------------------------------------\n\n.btn-file {\n overflow: hidden;\n position: relative;\n vertical-align: middle;\n > input {\n position: absolute;\n top: 0;\n right: 0;\n margin: 0;\n opacity: 0;\n filter: alpha(opacity=0);\n transform: translate(-300px, 0) scale(4);\n font-size: 23px;\n direction: ltr;\n cursor: pointer;\n }\n}\n\n.fileinput {\n margin-bottom: 9px;\n display: inline-block;\n .uneditable-input {\n display: inline-block;\n margin-bottom: 0px;\n vertical-align: middle;\n cursor: text;\n }\n .thumbnail {\n overflow: hidden;\n display: inline-block;\n margin-bottom: 5px;\n vertical-align: middle;\n text-align: center;\n > img {\n max-height: 100%;\n }\n }\n .btn {\n vertical-align: middle;\n }\n}\n.fileinput-exists .fileinput-new,\n.fileinput-new .fileinput-exists {\n display: none;\n}\n.fileinput-inline .fileinput-controls {\n display: inline;\n}\n\n.fileinput .uneditable-input {\n white-space: normal;\n}\n\n// Not 100% correct, but helps in typical use case\n.fileinput-new .input-group .btn-file {\n border-radius: 0 @border-radius-base @border-radius-base 0;\n}\n.fileinput-new .input-group .btn-file.btn-xs,\n.fileinput-new .input-group .btn-file.btn-sm {\n border-radius: 0 @border-radius-small @border-radius-small 0;\n}\n.fileinput-new .input-group .btn-file.btn-lg {\n border-radius: 0 @border-radius-large @border-radius-large 0;\n}\n\n.form-group.has-warning .fileinput {\n .uneditable-input {\n color: @state-warning-text;\n border-color: @state-warning-border;\n }\n .fileinput-preview {\n color: @state-warning-text;\n }\n .thumbnail {\n border-color: @state-warning-border;\n }\n}\n.form-group.has-error .fileinput {\n .uneditable-input {\n color: @state-danger-text;\n border-color: @state-danger-border;\n }\n .fileinput-preview {\n color: @state-danger-text;\n }\n .thumbnail {\n border-color: @state-danger-border;\n }\n}\n.form-group.has-success .fileinput {\n .uneditable-input {\n color: @state-success-text;\n border-color: @state-success-border;\n }\n .fileinput-preview {\n color: @state-success-text;\n }\n .thumbnail {\n border-color: @state-success-border;\n }\n}\n\n\n// Input group fixes\n\n.input-group-addon:not(:first-child) {\n border-left: 0;\n}\n","grid-container-smooth.less":"// Smooth sizing container\n// -------------------------\n\n@media (min-width: 1px) {\n .container-smooth {\n max-width: @container-lg;\n }\n}\n\n","jasny-bootstrap.less":'/*!\n * Jasny extension p7 to Bootstrap v3.0.0\n *\n * Copyright 2013 Twitter, Inc\n * Licensed under the Apache License v2.0\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Designed and built with all the love in the world by @mdo and @fat.\n */\n\n// Core variables and mixins\n@import "variables.less";\n@import "mixins.less";\n\n// Core CSS\n@import "grid-container-smooth.less";\n@import "button-labels.less";\n\n// Components\n@import "nav-tab-alignment.less";\n@import "navmenu.less";\n@import "alerts-fixed.less";\n\n// Components w/ JavaScript\n@import "offcanvas.less";\n@import "rowlink.less";\n@import "fileinput.less";\n',"mixins.less":'//\n// Mixins\n// --------------------------------------------------\n\n\n// Utilities\n// -------------------------\n\n// Clearfix\n// Source: http://nicolasgallagher.com/micro-clearfix-hack/\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.clearfix() {\n &:before,\n &:after {\n content: " "; /* 1 */\n display: table; /* 2 */\n }\n &:after {\n clear: both;\n }\n}\n\n// WebKit-style focus\n.tab-focus() {\n // Default\n outline: thin dotted #333;\n // WebKit\n outline: 5px auto -webkit-focus-ring-color;\n outline-offset: -2px;\n}\n\n// Center-align a block level element\n.center-block() {\n display: block;\n margin-left: auto;\n margin-right: auto;\n}\n\n// Sizing shortcuts\n.size(@width; @height) {\n width: @width;\n height: @height;\n}\n.square(@size) {\n .size(@size; @size);\n}\n\n// Placeholder text\n.placeholder(@color: @input-color-placeholder) {\n &:-moz-placeholder { color: @color; } // Firefox 4-18\n &::-moz-placeholder { color: @color; } // Firefox 19+\n &:-ms-input-placeholder { color: @color; } // Internet Explorer 10+\n &::-webkit-input-placeholder { color: @color; } // Safari and Chrome\n}\n\n// Text overflow\n// Requires inline-block or block for proper styling\n.text-overflow() {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n\n// CSS image replacement\n//\n// Heads up! v3 launched with with only `.hide-text()`, but per our pattern for\n// mixins being reused as classes with the same name, this doesn\'t hold up. As\n// of v3.0.1 we have added `.text-hide()` and deprecated `.hide-text()`. Note\n// that we cannot chain the mixins together in Less, so they are repeated.\n//\n// Source: https://github.com/h5bp/html5-boilerplate/commit/aa0396eae757\n\n// Deprecated as of v3.0.1 (will be removed in v4)\n.hide-text() {\n font: ~"0/0" a;\n color: transparent;\n text-shadow: none;\n background-color: transparent;\n border: 0;\n}\n// New mixin to use as of v3.0.1\n.text-hide() {\n font: ~"0/0" a;\n color: transparent;\n text-shadow: none;\n background-color: transparent;\n border: 0;\n}\n\n\n\n// CSS3 PROPERTIES\n// --------------------------------------------------\n\n// Single side border-radius\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// Drop shadows\n.box-shadow(@shadow) {\n -webkit-box-shadow: @shadow; // iOS <4.3 & Android <4.1\n box-shadow: @shadow;\n}\n\n// Transitions\n.transition(@transition) {\n -webkit-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-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// Transformations\n.rotate(@degrees) {\n -webkit-transform: rotate(@degrees);\n -ms-transform: rotate(@degrees); // IE9+\n transform: rotate(@degrees);\n}\n.scale(@ratio) {\n -webkit-transform: scale(@ratio);\n -ms-transform: scale(@ratio); // IE9+\n transform: scale(@ratio);\n}\n.translate(@x; @y) {\n -webkit-transform: translate(@x, @y);\n -ms-transform: translate(@x, @y); // IE9+\n transform: translate(@x, @y);\n}\n.skew(@x; @y) {\n -webkit-transform: skew(@x, @y);\n -ms-transform: skewX(@x) skewY(@y); // See https://github.com/twbs/bootstrap/issues/4885; IE9+\n transform: skew(@x, @y);\n}\n.translate3d(@x; @y; @z) {\n -webkit-transform: translate3d(@x, @y, @z);\n transform: translate3d(@x, @y, @z);\n}\n\n.rotateX(@degrees) {\n -webkit-transform: rotateX(@degrees);\n -ms-transform: rotateX(@degrees); // IE9+\n transform: rotateX(@degrees);\n}\n.rotateY(@degrees) {\n -webkit-transform: rotateY(@degrees);\n -ms-transform: rotateY(@degrees); // IE9+\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 transform-origin: @origin;\n}\n\n// Animations\n.animation(@animation) {\n -webkit-animation: @animation;\n animation: @animation;\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.backface-visibility(@visibility){\n -webkit-backface-visibility: @visibility;\n -moz-backface-visibility: @visibility;\n backface-visibility: @visibility;\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// User select\n// For selecting text on the page\n.user-select(@select) {\n -webkit-user-select: @select;\n -moz-user-select: @select;\n -ms-user-select: @select; // IE10+\n -o-user-select: @select;\n user-select: @select;\n}\n\n// Resize anything\n.resizable(@direction) {\n resize: @direction; // Options: horizontal, vertical, both\n overflow: auto; // Safari fix\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// Opacity\n.opacity(@opacity) {\n opacity: @opacity;\n // IE8 filter\n @opacity-ie: (@opacity * 100);\n filter: ~"alpha(opacity=@{opacity-ie})";\n}\n\n\n\n// GRADIENTS\n// --------------------------------------------------\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-gradient(linear, @start-percent top, @end-percent top, from(@start-color), to(@end-color)); // Safari 4+, Chrome 2+\n background-image: -webkit-linear-gradient(left, color-stop(@start-color @start-percent), color-stop(@end-color @end-percent)); // Safari 5.1+, Chrome 10+\n background-image: -moz-linear-gradient(left, @start-color @start-percent, @end-color @end-percent); // FF 3.6+\n background-image: linear-gradient(to right, @start-color @start-percent, @end-color @end-percent); // Standard, IE10\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-gradient(linear, left @start-percent, left @end-percent, from(@start-color), to(@end-color)); // Safari 4+, Chrome 2+\n background-image: -webkit-linear-gradient(top, @start-color @start-percent, @end-color @end-percent); // Safari 5.1+, Chrome 10+\n background-image: -moz-linear-gradient(top, @start-color @start-percent, @end-color @end-percent); // FF 3.6+\n background-image: linear-gradient(to bottom, @start-color @start-percent, @end-color @end-percent); // Standard, IE10\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+, Chrome 10+\n background-image: -moz-linear-gradient(@deg, @start-color, @end-color); // FF 3.6+\n background-image: linear-gradient(@deg, @start-color, @end-color); // Standard, IE10\n }\n .horizontal-three-colors(@start-color: #00b3ee; @mid-color: #7a43b6; @color-stop: 50%; @end-color: #c3325f) {\n background-image: -webkit-gradient(left, linear, 0 0, 0 100%, from(@start-color), color-stop(@color-stop, @mid-color), to(@end-color));\n background-image: -webkit-linear-gradient(left, @start-color, @mid-color @color-stop, @end-color);\n background-image: -moz-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-gradient(linear, 0 0, 0 100%, from(@start-color), color-stop(@color-stop, @mid-color), to(@end-color));\n background-image: -webkit-linear-gradient(@start-color, @mid-color @color-stop, @end-color);\n background-image: -moz-linear-gradient(top, @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-gradient(radial, center center, 0, center center, 460, from(@inner-color), to(@outer-color));\n background-image: -webkit-radial-gradient(circle, @inner-color, @outer-color);\n background-image: -moz-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-gradient(linear, 0 100%, 100% 0, color-stop(.25, @color), color-stop(.25, transparent), color-stop(.5, transparent), color-stop(.5, @color), color-stop(.75, @color), color-stop(.75, transparent), to(transparent));\n background-image: -webkit-linear-gradient(@angle, @color 25%, transparent 25%, transparent 50%, @color 50%, @color 75%, transparent 75%, transparent);\n background-image: -moz-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\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.reset-filter() {\n filter: e(%("progid:DXImageTransform.Microsoft.gradient(enabled = false)"));\n}\n\n\n\n// Retina images\n//\n// Short retina mixin for setting background-image and -size\n\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\n// Responsive image\n//\n// Keep images from scaling beyond the width of their parents.\n\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// COMPONENT MIXINS\n// --------------------------------------------------\n\n// Horizontal dividers\n// -------------------------\n// Dividers (basically an hr) within dropdowns and nav lists\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\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 & > .dropdown .caret {\n border-color: @heading-text-color transparent;\n }\n }\n & > .panel-footer {\n + .panel-collapse .panel-body {\n border-bottom-color: @border;\n }\n }\n}\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// Tables\n// -------------------------\n.table-row-variant(@state; @background; @border) {\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 &.@{state}:hover > th {\n background-color: darken(@background, 5%);\n }\n }\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.button-variant(@color; @background; @border) {\n color: @color;\n background-color: @background;\n border-color: @border;\n\n &:hover,\n &:focus,\n &:active,\n &.active,\n .open .dropdown-toggle& {\n color: @color;\n background-color: darken(@background, 8%);\n border-color: darken(@border, 12%);\n }\n &:active,\n &.active,\n .open .dropdown-toggle& {\n background-image: none;\n }\n &.disabled,\n &[disabled],\n fieldset[disabled] & {\n &,\n &:hover,\n &:focus,\n &:active,\n &.active {\n background-color: @background;\n border-color: @border;\n }\n }\n}\n\n// Button sizes\n// -------------------------\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\n// Pagination\n// -------------------------\n.pagination-size(@padding-vertical; @padding-horizontal; @font-size; @border-radius) {\n > li {\n > a,\n > span {\n padding: @padding-vertical @padding-horizontal;\n font-size: @font-size;\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// Labels\n// -------------------------\n.label-variant(@color) {\n background-color: @color;\n &[href] {\n &:hover,\n &:focus {\n background-color: darken(@color, 10%);\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.navbar-vertical-align(@element-height) {\n margin-top: ((@navbar-height - @element-height) / 2);\n margin-bottom: ((@navbar-height - @element-height) / 2);\n}\n\n// Progress bars\n// -------------------------\n.progress-bar-variant(@color) {\n background-color: @color;\n .progress-striped & {\n #gradient > .striped();\n }\n}\n\n// Responsive utilities\n// -------------------------\n// More easily include all the states for responsive-utilities.less.\n.responsive-visibility() {\n display: block !important;\n tr& { display: table-row !important; }\n th&,\n td& { display: table-cell !important; }\n}\n\n.responsive-invisibility() {\n &,\n tr&,\n th&,\n td& { display: none !important; }\n}\n\n\n// Grid System\n// -----------\n\n// Centered container element\n.container-fixed() {\n margin-right: auto;\n margin-left: auto;\n padding-left: (@grid-gutter-width / 2);\n padding-right: (@grid-gutter-width / 2);\n .clearfix();\n}\n\n// Creates a wrapper for a series of columns\n.make-row(@gutter: @grid-gutter-width) {\n margin-left: (@gutter / -2);\n margin-right: (@gutter / -2);\n .clearfix();\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 // Prevent columns from collapsing when empty\n min-height: 1px;\n // Inner gutter via padding\n padding-left: (@gutter / 2);\n padding-right: (@gutter / 2);\n}\n\n// Generate the small columns\n.make-sm-column(@columns; @gutter: @grid-gutter-width) {\n position: relative;\n // Prevent columns from collapsing when empty\n min-height: 1px;\n // Inner gutter via padding\n padding-left: (@gutter / 2);\n padding-right: (@gutter / 2);\n\n // Calculate width based on number of columns available\n @media (min-width: @screen-sm-min) {\n float: left;\n width: percentage((@columns / @grid-columns));\n }\n}\n\n// Generate the small column offsets\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 // Prevent columns from collapsing when empty\n min-height: 1px;\n // Inner gutter via padding\n padding-left: (@gutter / 2);\n padding-right: (@gutter / 2);\n\n // Calculate width based on number of columns available\n @media (min-width: @screen-md-min) {\n float: left;\n width: percentage((@columns / @grid-columns));\n }\n}\n\n// Generate the medium column offsets\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) {\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 // Prevent columns from collapsing when empty\n min-height: 1px;\n // Inner gutter via padding\n padding-left: (@gutter / 2);\n padding-right: (@gutter / 2);\n\n // Calculate width based on number of columns available\n @media (min-width: @screen-lg-min) {\n float: left;\n width: percentage((@columns / @grid-columns));\n }\n}\n\n// Generate the large column offsets\n.make-lg-column-offset(@columns) {\n @media (min-width: @screen-lg-min) {\n margin-left: percentage((@columns / @grid-columns));\n }\n}\n.make-lg-column-push(@columns) {\n @media (min-width: @screen-lg-min) {\n left: percentage((@columns / @grid-columns));\n }\n}\n.make-lg-column-pull(@columns) {\n @media (min-width: @screen-lg-min) {\n right: percentage((@columns / @grid-columns));\n }\n}\n\n\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) when (@index = 1) { // initial\n @item: ~".col-xs-@{index}, .col-sm-@{index}, .col-md-@{index}, .col-lg-@{index}";\n .col(@index + 1, @item);\n }\n .col(@index, @list) when (@index =< @grid-columns) { // general; "=<" isn\'t a typo\n @item: ~".col-xs-@{index}, .col-sm-@{index}, .col-md-@{index}, .col-lg-@{index}";\n .col(@index + 1, ~"@{list}, @{item}");\n }\n .col(@index, @list) when (@index > @grid-columns) { // terminal\n @{list} {\n position: relative;\n // Prevent columns from collapsing when empty\n min-height: 1px;\n // Inner gutter via padding\n padding-left: (@grid-gutter-width / 2);\n padding-right: (@grid-gutter-width / 2);\n }\n }\n .col(1); // kickstart it\n}\n\n.make-grid-columns-float(@class) {\n .col(@index) when (@index = 1) { // 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(@index, @class, @type) when (@type = width) {\n .col-@{class}-@{index} {\n width: percentage((@index / @grid-columns));\n }\n}\n.calc-grid(@index, @class, @type) when (@type = push) {\n .col-@{class}-push-@{index} {\n left: percentage((@index / @grid-columns));\n }\n}\n.calc-grid(@index, @class, @type) when (@type = pull) {\n .col-@{class}-pull-@{index} {\n right: percentage((@index / @grid-columns));\n }\n}\n.calc-grid(@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.make-grid(@index, @class, @type) when (@index > 0) {\n .calc-grid(@index, @class, @type);\n // next iteration\n .make-grid(@index - 1, @class, @type);\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 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}\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-focus-border` 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\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. `')\n this.$element.prepend(this.$hidden)\n }\n\n this.$preview = this.$element.find('.fileinput-preview')\n var height = this.$preview.css('height')\n if (this.$preview.css('display') != 'inline' && height != '0px' && height != 'none') this.$preview.css('line-height', height)\n\n this.original = {\n exists: this.$element.hasClass('fileinput-exists'),\n preview: this.$preview.html(),\n hiddenVal: this.$hidden.val()\n }\n \n this.listen()\n }\n \n Fileinput.prototype.listen = function() {\n this.$input.on('change.bs.fileinput', $.proxy(this.change, this))\n $(this.$input[0].form).on('reset.bs.fileinput', $.proxy(this.reset, this))\n \n this.$element.find('[data-trigger=\"fileinput\"]').on('click.bs.fileinput', $.proxy(this.trigger, this))\n this.$element.find('[data-dismiss=\"fileinput\"]').on('click.bs.fileinput', $.proxy(this.clear, this))\n },\n\n Fileinput.prototype.change = function(e) {\n if (e.target.files === undefined) e.target.files = e.target && e.target.value ? [ {name: e.target.value.replace(/^.+\\\\/, '')} ] : []\n if (e.target.files.length === 0) return\n\n this.$hidden.val('')\n this.$hidden.attr('name', '')\n this.$input.attr('name', this.name)\n\n var file = e.target.files[0]\n\n if (this.$preview.length > 0 && (typeof file.type !== \"undefined\" ? file.type.match('image.*') : file.name.match(/\\.(gif|png|jpe?g)$/i)) && typeof FileReader !== \"undefined\") {\n var reader = new FileReader()\n var preview = this.$preview\n var element = this.$element\n\n reader.onload = function(re) {\n var $img = $('') // .attr('src', re.target.result)\n $img[0].src = re.target.result\n e.target.files[0].result = re.target.result\n \n element.find('.fileinput-filename').text(file.name)\n \n // if parent has max-height, using `(max-)height: 100%` on child doesn't take padding and border into account\n if (preview.css('max-height') != 'none') $img.css('max-height', parseInt(preview.css('max-height'), 10) - parseInt(preview.css('padding-top'), 10) - parseInt(preview.css('padding-bottom'), 10) - parseInt(preview.css('border-top'), 10) - parseInt(preview.css('border-bottom'), 10))\n \n preview.html($img)\n element.addClass('fileinput-exists').removeClass('fileinput-new')\n\n element.trigger('change.bs.fileinput', e.target.files)\n }\n\n reader.readAsDataURL(file)\n } else {\n this.$element.find('.fileinput-filename').text(file.name)\n this.$preview.text(file.name)\n \n this.$element.addClass('fileinput-exists').removeClass('fileinput-new')\n \n this.$element.trigger('change.bs.fileinput')\n }\n },\n\n Fileinput.prototype.clear = function(e) {\n if (e) e.preventDefault()\n \n this.$hidden.val('')\n this.$hidden.attr('name', this.name)\n this.$input.attr('name', '')\n\n //ie8+ doesn't support changing the value of input with type=file so clone instead\n if (isIE) { \n var inputClone = this.$input.clone(true);\n this.$input.after(inputClone);\n this.$input.remove();\n this.$input = inputClone;\n } else {\n this.$input.val('')\n }\n\n this.$preview.html('')\n this.$element.find('.fileinput-filename').text('')\n this.$element.addClass('fileinput-new').removeClass('fileinput-exists')\n \n if (e !== false) {\n this.$input.trigger('change')\n this.$element.trigger('clear.bs.fileinput')\n }\n },\n\n Fileinput.prototype.reset = function() {\n this.clear(false)\n\n this.$hidden.val(this.original.hiddenVal)\n this.$preview.html(this.original.preview)\n this.$element.find('.fileinput-filename').text('')\n\n if (this.original.exists) this.$element.addClass('fileinput-exists').removeClass('fileinput-new')\n else this.$element.addClass('fileinput-new').removeClass('fileinput-exists')\n \n this.$element.trigger('reset.bs.fileinput')\n },\n\n Fileinput.prototype.trigger = function(e) {\n this.$input.trigger('click')\n e.preventDefault()\n }\n\n \n // FILEUPLOAD PLUGIN DEFINITION\n // ===========================\n\n var old = $.fn.fileinput\n \n $.fn.fileinput = function (options) {\n return this.each(function () {\n var $this = $(this),\n data = $this.data('fileinput')\n if (!data) $this.data('fileinput', (data = new Fileinput(this, options)))\n if (typeof options == 'string') data[options]()\n })\n }\n\n $.fn.fileinput.Constructor = Fileinput\n\n\n // FILEINPUT NO CONFLICT\n // ====================\n\n $.fn.fileinput.noConflict = function () {\n $.fn.fileinput = old\n return this\n }\n\n\n // FILEUPLOAD DATA-API\n // ==================\n\n $(document).on('click.fileinput.data-api', '[data-provides=\"fileinput\"]', function (e) {\n var $this = $(this)\n if ($this.data('fileinput')) return\n $this.fileinput($this.data())\n \n var $target = $(e.target).closest('[data-dismiss=\"fileinput\"],[data-trigger=\"fileinput\"]');\n if ($target.length > 0) {\n e.preventDefault()\n $target.trigger('click.bs.fileinput')\n }\n })\n\n}(window.jQuery);\n","inputmask.js":'/* ===========================================================\n * Bootstrap: inputmask.js v3.0.0-p7\n * http://jasny.github.io/bootstrap/javascript.html#inputmask\n * Based on Masked Input plugin by Josh Bush (digitalbush.com)\n * ===========================================================\n * Copyright 2012 Jasny BV, Netherlands.\n *\n * Licensed under the Apache License, Version 2.0 (the "License")\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an "AS IS" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * ========================================================== */\n\n+function ($) { "use strict";\n\n var isIphone = (window.orientation !== undefined)\n var isAndroid = navigator.userAgent.toLowerCase().indexOf("android") > -1\n var isIE = window.navigator.appName == \'Microsoft Internet Explorer\'\n\n // INPUTMASK PUBLIC CLASS DEFINITION\n // =================================\n\n var Inputmask = function (element, options) {\n if (isAndroid) return // No support because caret positioning doesn\'t work on Android\n \n this.$element = $(element)\n this.options = $.extend({}, Inputmask.DEFAULS, options)\n this.mask = String(this.options.mask)\n \n this.init()\n this.listen()\n \n this.checkVal() //Perform initial check for existing values\n }\n\n Inputmask.DEFAULS = {\n mask: "",\n placeholder: "_",\n definitions: {\n \'9\': "[0-9]",\n \'a\': "[A-Za-z]",\n \'?\': "[A-Za-z0-9]",\n \'*\': "."\n }\n }\n\n Inputmask.prototype.init = function() {\n var defs = this.options.definitions\n var len = this.mask.length\n\n this.tests = [] \n this.partialPosition = this.mask.length\n this.firstNonMaskPos = null\n\n $.each(this.mask.split(""), $.proxy(function(i, c) {\n if (c == \'?\') {\n len--\n this.partialPosition = i\n } else if (defs[c]) {\n this.tests.push(new RegExp(defs[c]))\n if (this.firstNonMaskPos === null)\n this.firstNonMaskPos = this.tests.length - 1\n } else {\n this.tests.push(null)\n }\n }, this))\n\n this.buffer = $.map(this.mask.split(""), $.proxy(function(c, i) {\n if (c != \'?\') return defs[c] ? this.options.placeholder : c\n }, this))\n\n this.focusText = this.$element.val()\n\n this.$element.data("rawMaskFn", $.proxy(function() {\n return $.map(this.buffer, function(c, i) {\n return this.tests[i] && c != this.options.placeholder ? c : null\n }).join(\'\')\n }, this))\n }\n \n Inputmask.prototype.listen = function() {\n if (this.$element.attr("readonly")) return\n\n var pasteEventName = (isIE ? \'paste\' : \'input\') + ".mask"\n\n this.$element\n .on("unmask.bs.inputmask", $.proxy(this.unmask, this))\n\n .on("focus.bs.inputmask", $.proxy(this.focusEvent, this))\n .on("blur.bs.inputmask", $.proxy(this.blurEvent, this))\n\n .on("keydown.bs.inputmask", $.proxy(this.keydownEvent, this))\n .on("keypress.bs.inputmask", $.proxy(this.keypressEvent, this))\n\n .on(pasteEventName, $.proxy(this.pasteEvent, this))\n }\n\n //Helper Function for Caret positioning\n Inputmask.prototype.caret = function(begin, end) {\n if (this.$element.length === 0) return\n if (typeof begin == \'number\') {\n end = (typeof end == \'number\') ? end : begin\n return this.$element.each(function() {\n if (this.setSelectionRange) {\n this.setSelectionRange(begin, end)\n } else if (this.createTextRange) {\n var range = this.createTextRange()\n range.collapse(true)\n range.moveEnd(\'character\', end)\n range.moveStart(\'character\', begin)\n range.select()\n }\n })\n } else {\n if (this.$element[0].setSelectionRange) {\n begin = this.$element[0].selectionStart\n end = this.$element[0].selectionEnd\n } else if (document.selection && document.selection.createRange) {\n var range = document.selection.createRange()\n begin = 0 - range.duplicate().moveStart(\'character\', -100000)\n end = begin + range.text.length\n }\n return {\n begin: begin, \n end: end\n }\n }\n }\n \n Inputmask.prototype.seekNext = function(pos) {\n var len = this.mask.length\n while (++pos <= len && !this.tests[pos]);\n\n return pos\n }\n \n Inputmask.prototype.seekPrev = function(pos) {\n while (--pos >= 0 && !this.tests[pos]);\n\n return pos\n }\n\n Inputmask.prototype.shiftL = function(begin,end) {\n var len = this.mask.length\n\n if (begin < 0) return\n\n for (var i = begin, j = this.seekNext(end); i < len; i++) {\n if (this.tests[i]) {\n if (j < len && this.tests[i].test(this.buffer[j])) {\n this.buffer[i] = this.buffer[j]\n this.buffer[j] = this.options.placeholder\n } else\n break\n j = this.seekNext(j)\n }\n }\n this.writeBuffer()\n this.caret(Math.max(this.firstNonMaskPos, begin))\n }\n\n Inputmask.prototype.shiftR = function(pos) {\n var len = this.mask.length\n\n for (var i = pos, c = this.options.placeholder; i < len; i++) {\n if (this.tests[i]) {\n var j = this.seekNext(i)\n var t = this.buffer[i]\n this.buffer[i] = c\n if (j < len && this.tests[j].test(t))\n c = t\n else\n break\n }\n }\n },\n\n Inputmask.prototype.unmask = function() {\n this.$element\n .unbind(".mask")\n .removeData("inputmask")\n }\n\n Inputmask.prototype.focusEvent = function() {\n this.focusText = this.$element.val()\n var len = this.mask.length \n var pos = this.checkVal()\n this.writeBuffer()\n\n var that = this\n var moveCaret = function() {\n if (pos == len)\n that.caret(0, pos)\n else\n that.caret(pos)\n }\n\n moveCaret()\n setTimeout(moveCaret, 50)\n }\n\n Inputmask.prototype.blurEvent = function() {\n this.checkVal()\n if (this.$element.val() !== this.focusText)\n this.$element.trigger(\'change\')\n }\n\n Inputmask.prototype.keydownEvent = function(e) {\n var k = e.which\n\n //backspace, delete, and escape get special treatment\n if (k == 8 || k == 46 || (isIphone && k == 127)) {\n var pos = this.caret(),\n begin = pos.begin,\n end = pos.end\n\n if (end - begin === 0) {\n begin = k != 46 ? this.seekPrev(begin) : (end = this.seekNext(begin - 1))\n end = k == 46 ? this.seekNext(end) : end\n }\n this.clearBuffer(begin, end)\n this.shiftL(begin, end - 1)\n\n return false\n } else if (k == 27) {//escape\n this.$element.val(this.focusText)\n this.caret(0, this.checkVal())\n return false\n }\n }\n\n Inputmask.prototype.keypressEvent = function(e) {\n var len = this.mask.length\n\n var k = e.which,\n pos = this.caret()\n\n if (e.ctrlKey || e.altKey || e.metaKey || k < 32) {//Ignore\n return true\n } else if (k) {\n if (pos.end - pos.begin !== 0) {\n this.clearBuffer(pos.begin, pos.end)\n this.shiftL(pos.begin, pos.end - 1)\n }\n\n var p = this.seekNext(pos.begin - 1)\n if (p < len) {\n var c = String.fromCharCode(k)\n if (this.tests[p].test(c)) {\n this.shiftR(p)\n this.buffer[p] = c\n this.writeBuffer()\n var next = this.seekNext(p)\n this.caret(next)\n }\n }\n return false\n }\n }\n\n Inputmask.prototype.pasteEvent = function() {\n var that = this\n\n setTimeout(function() {\n that.caret(that.checkVal(true))\n }, 0)\n }\n\n Inputmask.prototype.clearBuffer = function(start, end) {\n var len = this.mask.length\n\n for (var i = start; i < end && i < len; i++) {\n if (this.tests[i])\n this.buffer[i] = this.options.placeholder\n }\n }\n\n Inputmask.prototype.writeBuffer = function() {\n return this.$element.val(this.buffer.join(\'\')).val()\n }\n\n Inputmask.prototype.checkVal = function(allow) {\n var len = this.mask.length\n //try to place characters where they belong\n var test = this.$element.val()\n var lastMatch = -1\n\n for (var i = 0, pos = 0; i < len; i++) {\n if (this.tests[i]) {\n this.buffer[i] = this.options.placeholder\n while (pos++ < test.length) {\n var c = test.charAt(pos - 1)\n if (this.tests[i].test(c)) {\n this.buffer[i] = c\n lastMatch = i\n break\n }\n }\n if (pos > test.length)\n break\n } else if (this.buffer[i] == test.charAt(pos) && i != this.partialPosition) {\n pos++\n lastMatch = i\n }\n }\n if (!allow && lastMatch + 1 < this.partialPosition) {\n this.$element.val("")\n this.clearBuffer(0, len)\n } else if (allow || lastMatch + 1 >= this.partialPosition) {\n this.writeBuffer()\n if (!allow) this.$element.val(this.$element.val().substring(0, lastMatch + 1))\n }\n return (this.partialPosition ? i : this.firstNonMaskPos)\n }\n\n \n // INPUTMASK PLUGIN DEFINITION\n // ===========================\n\n var old = $.fn.inputmask\n \n $.fn.inputmask = function (options) {\n return this.each(function () {\n var $this = $(this)\n var data = $this.data(\'inputmask\')\n \n if (!data) $this.data(\'inputmask\', (data = new Inputmask(this, options)))\n })\n }\n\n $.fn.inputmask.Constructor = Inputmask\n\n\n // INPUTMASK NO CONFLICT\n // ====================\n\n $.fn.inputmask.noConflict = function () {\n $.fn.inputmask = old\n return this\n }\n\n\n // INPUTMASK DATA-API\n // ==================\n\n $(document).on(\'focus.bs.inputmask.data-api\', \'[data-mask]\', function (e) {\n var $this = $(this)\n if ($this.data(\'inputmask\')) return\n $this.inputmask($this.data())\n })\n\n}(window.jQuery);\n',"offcanvas.js":"/* ========================================================================\n * Bootstrap: offcanvas.js v3.0.3-p7\n * http://jasny.github.io/bootstrap/javascript.html#offcanvas\n * \n * Based on Boostrap collapse.js by Twitter, Inc. \n * ========================================================================\n * Copyright 2013 Jasny, BV.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\")\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * ======================================================================== */\n\n+function ($) { \"use strict\";\n\n // OFFCANVAS PUBLIC CLASS DEFINITION\n // =================================\n\n var OffCanvas = function (element, options) {\n this.$element = $(element)\n this.options = $.extend({}, OffCanvas.DEFAULTS, options)\n this.state = null\n \n if (this.options.recalc) {\n this.calcClone()\n $(window).on('resize', $.proxy(this.recalc, this))\n }\n \n if (this.options.autohide)\n $(document).on('click', $.proxy(this.autohide, this))\n\n if (this.options.toggle) this.toggle()\n }\n\n OffCanvas.DEFAULTS = {\n toggle: true,\n placement: 'left',\n autohide: true,\n recalc: true\n }\n\n OffCanvas.prototype.offset = function () {\n switch (this.options.placement) {\n case 'left':\n case 'right': return this.$element.outerWidth()\n case 'top':\n case 'bottom': return this.$element.outerHeight()\n }\n }\n \n OffCanvas.prototype.calcPlacement = function () {\n var horizontal = $(window).width() / this.$element.width(),\n vertical = $(window).height() / this.$element.height()\n \n if (!this.$element.hasClass('in')) {\n this.$element.css('visiblity', 'hidden !important').addClass('in')\n } \n \n var element = this.$element\n function ab(a, b) {\n if (element.css(b) === 'auto') return a\n if (element.css(a) === 'auto') return b\n \n var size_a = parseInt(element.css(a), 10),\n size_b = parseInt(element.css(b), 10)\n \n return size_a > size_b ? b : a\n }\n \n this.options.placement = horizontal > vertical ? ab('left', 'right') : ab('top', 'bottom')\n \n if (this.$element.css('visibility') === 'hidden !important') {\n this.$element.removeClass('in').css('visiblity', '')\n }\n }\n \n OffCanvas.prototype.opposite = function (placement) {\n switch (placement) {\n case 'top': return 'bottom'\n case 'left': return 'right'\n case 'bottom': return 'top'\n case 'right': return 'left'\n }\n }\n \n OffCanvas.prototype.getCanvasElements = function() {\n // Return a set containing the canvas plus all fixed elements\n var canvas = this.options.canvas ? $(this.options.canvas) : this.$element\n \n var fixed_elements = canvas.find('*').filter(function() {\n return $(this).css('position') === 'fixed'\n }).not(this.options.exclude)\n \n return canvas.add(fixed_elements)\n }\n \n OffCanvas.prototype.slide = function (elements, offset, callback) {\n // Use jQuery animation if CSS transitions aren't supported\n if (!$.support.transition) {\n var anim = {}\n anim[this.options.placement] = \"+=\" + offset\n return elements.animate(anim, 350, callback)\n }\n\n var placement = this.options.placement,\n opposite = this.opposite(placement)\n \n elements.each(function() {\n if ($(this).css(placement) !== 'auto')\n $(this).css(placement, (parseInt($(this).css(placement), 10) || 0) + offset)\n \n if ($(this).css(opposite) !== 'auto')\n $(this).css(opposite, (parseInt($(this).css(opposite), 10) || 0) - offset)\n })\n \n this.$element\n .one($.support.transition.end, callback)\n .emulateTransitionEnd(350)\n }\n\n OffCanvas.prototype.disableScrolling = function() {\n var bodyWidth = $('body').width()\n var prop = 'padding-' + this.opposite(this.options.placement)\n\n if ($('body').data('offcanvas-style') === undefined) $('body').data('offcanvas-style', $('body').attr('style'))\n \n $('body').css('overflow', 'hidden')\n\n if ($('body').width() > bodyWidth) {\n var padding = parseInt($('body').css(prop), 10) + $('body').width() - bodyWidth\n \n setTimeout(function() {\n $('body').css(prop, padding)\n }, 1)\n }\n }\n\n OffCanvas.prototype.show = function () {\n if (this.state) return\n \n var startEvent = $.Event('show.bs.offcanvas')\n this.$element.trigger(startEvent)\n if (startEvent.isDefaultPrevented()) return\n\n if (this.options.placement === 'auto') this.calcPlacement()\n\n this.state = 'sliding'\n\n var elements = this.getCanvasElements()\n var offset = this.offset(),\n placement = this.options.placement,\n opposite = this.opposite(placement)\n\n elements.addClass('canvas-sliding').each(function() {\n $(this).data('offcanvas-style', $(this).attr('style') || '')\n if ($(this).css('position') === 'static') $(this).css('position', 'relative')\n if (($(this).css(placement) === 'auto' || $(this).css(placement) === '0px') &&\n ($(this).css(opposite) === 'auto' || $(this).css(opposite) === '0px')) {\n $(this).css(placement, 0)\n }\n })\n \n if (elements.index(this.$element) !== -1) this.$element.css(placement, -1 * offset)\n\n this.disableScrolling()\n \n var complete = function () {\n this.state = 'slid'\n\n elements.removeClass('canvas-sliding').addClass('canvas-slid')\n this.$element.trigger('shown.bs.offcanvas')\n }\n\n setTimeout($.proxy(function() {\n this.$element.addClass('in')\n this.slide(elements, offset, $.proxy(complete, this))\n }, this), 1)\n }\n\n OffCanvas.prototype.hide = function (fast) {\n if (this.state !== 'slid') return\n\n var startEvent = $.Event('hide.bs.offcanvas')\n this.$element.trigger(startEvent)\n if (startEvent.isDefaultPrevented()) return\n\n this.state = 'sliding'\n\n var elements = $('.canvas-slid')\n var offset = -1 * this.offset()\n\n var complete = function () {\n this.state = null\n\n this.$element.removeClass('in')\n \n elements.removeClass('canvas-sliding')\n elements.add('body').each(function() {\n $(this).attr('style', $(this).data('offcanvas-style')).removeData('offcanvas-style')\n })\n\n this.$element.trigger('hidden.bs.offcanvas')\n }\n\n elements.removeClass('canvas-slid').addClass('canvas-sliding')\n \n setTimeout($.proxy(function() {\n this.slide(elements, offset, $.proxy(complete, this))\n }, this), 1)\n }\n\n OffCanvas.prototype.toggle = function () {\n if (this.state === 'sliding') return\n this[this.state === 'slid' ? 'hide' : 'show']()\n }\n\n OffCanvas.prototype.calcClone = function() {\n this.$calcClone = this.$element.clone()\n .html('')\n .addClass('offcanvas-clone').removeClass('in')\n .appendTo($('body'))\n }\n\n OffCanvas.prototype.recalc = function () {\n if (this.state() !== 'slid' || this.$calcClone.css('display') === 'none') return\n \n var offset = -1 * this.offset()\n \n var placement = this.options.placement\n this.getCanvasElements().each(function() {\n $(this).css(placement, (parseInt($(this).css(placement), 10) || 0) + offset)\n }).removeClass('canvas-slid')\n \n $('body').css('overflow', '')\n this.$element.css(placement, '').removeClass('in canvas-slid')\n }\n \n OffCanvas.prototype.autohide = function (e) {\n if ($(e.target).closest(this.$element).length === 0) this.hide()\n }\n\n // OFFCANVAS PLUGIN DEFINITION\n // ==========================\n\n var old = $.fn.offcanvas\n\n $.fn.offcanvas = function (option) {\n return this.each(function () {\n var $this = $(this)\n var data = $this.data('bs.offcanvas')\n var options = $.extend({}, OffCanvas.DEFAULTS, $this.data(), typeof option == 'object' && option)\n\n if (!data) $this.data('bs.offcanvas', (data = new OffCanvas(this, options)))\n if (typeof option == 'string') data[option]()\n })\n }\n\n $.fn.offcanvas.Constructor = OffCanvas\n\n\n // OFFCANVAS NO CONFLICT\n // ====================\n\n $.fn.offcanvas.noConflict = function () {\n $.fn.offcanvas = old\n return this\n }\n\n\n // OFFCANVAS DATA-API\n // =================\n\n $(document).on('click.bs.offcanvas.data-api', '[data-toggle=offcanvas]', function (e) {\n var $this = $(this), href\n var target = $this.attr('data-target')\n || e.preventDefault()\n || (href = $this.attr('href')) && href.replace(/.*(?=#[^\\s]+$)/, '') //strip for ie7\n var $canvas = $(target)\n var data = $canvas.data('bs.offcanvas')\n var option = data ? 'toggle' : $this.data()\n\n e.stopPropagation()\n\n if (data) data.toggle()\n else $canvas.offcanvas(option)\n })\n\n}(window.jQuery);\n","rowlink.js":"/* ============================================================\n * Bootstrap: rowlink.js v3.0.0-p7\n * http://jasny.github.io/bootstrap/javascript.html#rowlink\n * ============================================================\n * Copyright 2012 Jasny BV, Netherlands.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * ============================================================ */\n\n+function ($) { \"use strict\";\n\n var Rowlink = function (element, options) {\n this.$element = $(element)\n this.options = $.extend({}, Rowlink.DEFAULTS, options)\n \n this.$element.on('click.bs.rowlink', 'td:not(.rowlink-skip)', $.proxy(this.click, this))\n }\n\n Rowlink.DEFAULTS = {\n target: \"a\"\n }\n\n Rowlink.prototype.click = function(e) {\n var target = $(e.currentTarget).closest('tr').find(this.options.target)[0]\n if ($(e.target)[0] === target) return\n \n e.preventDefault();\n \n if (target.click) {\n target.click()\n } else if (document.createEvent) {\n var evt = document.createEvent(\"MouseEvents\"); \n evt.initMouseEvent(\"click\", true, true, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null); \n target.dispatchEvent(evt);\n }\n }\n\n \n // ROWLINK PLUGIN DEFINITION\n // ===========================\n\n var old = $.fn.rowlink\n\n $.fn.rowlink = function (options) {\n return this.each(function () {\n var $this = $(this)\n var data = $this.data('rowlink')\n if (!data) $this.data('rowlink', (data = new Rowlink(this, options)))\n })\n }\n\n $.fn.rowlink.Constructor = Rowlink\n\n\n // ROWLINK NO CONFLICT\n // ====================\n\n $.fn.rowlink.noConflict = function () {\n $.fn.rowlink = old\n return this\n }\n\n\n // ROWLINK DATA-API\n // ==================\n\n $(document).on('click.bs.rowlink.data-api', '[data-link=\"row\"]', function (e) {\n var $this = $(this)\n if ($this.data('rowlink')) return\n $this.rowlink($this.data())\n $(e.target).trigger('click.bs.rowlink')\n })\n \n}(window.jQuery);\n"},__less={"alerts-fixed.less":"// Fixed alerts\n//\n// Position to the top or bottom.\n\n.alert-fixed-top,\n.alert-fixed-bottom {\n position: fixed;\n width: 100%;\n z-index: @zindex-alert-fixed;\n border-radius: 0;\n margin: 0;\n left: 0;\n\n @media (min-width: @alert-fixed-width) {\n width: @alert-fixed-width;\n left: 50%;\n margin-left: (-1 * (@alert-fixed-width / 2));\n }\n}\n\n.alert-fixed-top {\n top: 0;\n border-width: 0 0 1px 0;\n \n @media (min-width: @alert-fixed-width) {\n .border-bottom-radius(@alert-border-radius);\n border-width: 0 1px 1px 1px;\n }\n}\n\n.alert-fixed-bottom {\n bottom: 0;\n border-width: 1px 0 0 0;\n \n @media (min-width: @alert-fixed-width) {\n .border-top-radius(@alert-border-radius);\n border-width: 1px 1px 0 1px;\n }\n}\n","button-labels.less":"// Labels for buttons\n// --------------------------------------------------\n\n.btn-labeled {\n padding-top: 0;\n padding-bottom: 0;\n}\n\n.btn-label {\n position: relative;\n background: transparent;\n background: rgba(0, 0, 0, 0.15);\n display: inline-block;\n .button-label-size(@padding-base-vertical; @padding-base-horizontal; @border-radius-base);\n}\n\n.btn-lg .btn-label {\n .button-label-size(@padding-large-vertical; @padding-large-horizontal; @border-radius-large);\n}\n.btn-sm .btn-label {\n .button-label-size(@padding-small-vertical; @padding-small-horizontal; @border-radius-small);\n}\n.btn-xs .btn-label {\n .button-label-size(1px; 5px; @border-radius-small);\n}\n","fileinput.less":"// Fileinput.less\n// CSS for file upload button and fileinput widget\n// ------------------------------------------------\n\n.btn-file {\n overflow: hidden;\n position: relative;\n vertical-align: middle;\n > input {\n position: absolute;\n top: 0;\n right: 0;\n margin: 0;\n opacity: 0;\n filter: alpha(opacity=0);\n transform: translate(-300px, 0) scale(4);\n font-size: 23px;\n height: 100%;\n direction: ltr;\n cursor: pointer;\n }\n}\n\n.fileinput {\n margin-bottom: 9px;\n display: inline-block;\n .form-control {\n padding-top: 7px;\n padding-bottom: 5px;\n display: inline-block;\n margin-bottom: 0px;\n vertical-align: middle;\n cursor: text;\n }\n .thumbnail {\n overflow: hidden;\n display: inline-block;\n margin-bottom: 5px;\n vertical-align: middle;\n text-align: center;\n > img {\n max-height: 100%;\n }\n }\n .btn {\n vertical-align: middle;\n }\n}\n.fileinput-exists .fileinput-new,\n.fileinput-new .fileinput-exists {\n display: none;\n}\n.fileinput-inline .fileinput-controls {\n display: inline;\n}\n\n.fileinput-filename {\n vertical-align: middle;\n display: inline-block;\n overflow: hidden;\n}\n.form-control .fileinput-filename {\n vertical-align: bottom;\n}\n\n// Not 100% correct, but helps in typical use case\n.fileinput-new .input-group .btn-file {\n border-radius: 0 @border-radius-base @border-radius-base 0;\n}\n.fileinput-new .input-group .btn-file.btn-xs,\n.fileinput-new .input-group .btn-file.btn-sm {\n border-radius: 0 @border-radius-small @border-radius-small 0;\n}\n.fileinput-new .input-group .btn-file.btn-lg {\n border-radius: 0 @border-radius-large @border-radius-large 0;\n}\n\n.form-group.has-warning .fileinput {\n .fileinput-preview {\n color: @state-warning-text;\n }\n .thumbnail {\n border-color: @state-warning-border;\n }\n}\n.form-group.has-error .fileinput {\n .fileinput-preview {\n color: @state-danger-text;\n }\n .thumbnail {\n border-color: @state-danger-border;\n }\n}\n.form-group.has-success .fileinput {\n .fileinput-preview {\n color: @state-success-text;\n }\n .thumbnail {\n border-color: @state-success-border;\n }\n}\n\n\n// Input group fixes\n\n.input-group-addon:not(:first-child) {\n border-left: 0;\n}\n","grid-container-smooth.less":"// Smooth sizing container\n// -------------------------\n\n@media (min-width: 1px) {\n .container-smooth {\n max-width: @container-lg;\n }\n}\n\n","jasny-bootstrap.less":'// Twitter Bootstrap\'s "variables.less" should already be imported\n\n// Core variables and mixins\n@import "variables.less";\n@import "mixins.less";\n\n// Core CSS\n@import "grid-container-smooth.less";\n@import "button-labels.less";\n\n// Components\n@import "nav-tab-alignment.less";\n@import "navmenu.less";\n@import "alerts-fixed.less";\n\n// Components w/ JavaScript\n@import "offcanvas.less";\n@import "rowlink.less";\n@import "fileinput.less";\n',"mixins.less":"//\n// Mixins\n// --------------------------------------------------\n\n\n// CSS3 PROPERTIES\n// --------------------------------------------------\n\n// Single side border-radius\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// Drop shadows\n.box-shadow(@shadow) {\n -webkit-box-shadow: @shadow; // iOS <4.3 & Android <4.1\n box-shadow: @shadow;\n}\n\n\n// BUTTONS\n// --------------------------------------------------\n\n.button-label-size(@padding-vertical; @padding-horizontal; @border-radius) {\n padding: @padding-vertical @padding-horizontal;\n left: (-1 * @padding-horizontal);\n border-radius: (@border-radius - 1px) 0 0 (@border-radius - 1px);\n\n &.btn-label-right {\n left: auto;\n right: (-1 * @padding-horizontal);\n border-radius: 0 (@border-radius - 1px) (@border-radius - 1px) 0;\n }\n}\n","nav-tab-alignment.less":"// Alignment options\n// -------------------------\n\n// bottom\n.nav-tabs-bottom {\n border-bottom: 0;\n border-top: 1px solid @nav-tabs-border-color;\n\n > li {\n margin-bottom: 0;\n margin-top: -1px;\n\n > a {\n border-radius: 0 0 @border-radius-base @border-radius-base;\n }\n\n > a:hover,\n > a:focus,\n &.active > a,\n &.active > a:hover,\n &.active > a:focus {\n border: 1px solid @nav-tabs-active-link-hover-border-color;\n border-top-color: transparent;\n }\n }\n}\n\n// left\n.nav-tabs-left {\n border-bottom: 0;\n border-right: 1px solid @nav-tabs-border-color;\n\n > li {\n margin-bottom: 0;\n margin-right: -1px;\n float: none;\n\n > a {\n border-radius: @border-radius-base 0 0 @border-radius-base;\n margin-right: 0;\n margin-bottom: 2px;\n }\n\n > a:hover,\n > a:focus,\n &.active > a,\n &.active > a:hover,\n &.active > a:focus {\n border: 1px solid @nav-tabs-active-link-hover-border-color;\n border-right-color: transparent;\n }\n }\n\n .row > & {\n padding-right: 0;\n padding-left: (@grid-gutter-width / 2);\n margin-right: -1px;\n position: relative;\n z-index: 1;\n\n & + .tab-content {\n border-left: 1px solid @nav-tabs-active-link-hover-border-color;\n }\n }\n}\n\n// right\n.nav-tabs-right {\n border-bottom: 0;\n border-left: 1px solid @nav-tabs-border-color;\n\n > li {\n margin-bottom: 0;\n margin-left: -1px;\n float: none;\n\n > a {\n border-radius: 0 @border-radius-base @border-radius-base 0;\n margin-left: 0;\n margin-bottom: 2px;\n }\n\n > a:hover,\n > a:focus,\n &.active > a,\n &.active > a:hover,\n &.active > a:focus {\n border: 1px solid @nav-tabs-active-link-hover-border-color;\n border-left-color: transparent;\n }\n }\n\n .row > & {\n padding-left: 0;\n padding-right: (@grid-gutter-width / 2);\n }\n}\n","navmenu.less":"//\n// Navmenu and offcanvas navbar\n// --------------------------------------------------\n\n\n// Wrapper and base class\n//\n// Provide a static navmenu from which we expand to create the fixed navmenu\n// variations.\n\n.navmenu,\n.navbar-offcanvas {\n width: @navmenu-width;\n height: 100%;\n border-width: 1px;\n border-style: solid;\n border-radius: @border-radius-base;\n}\n\n.navmenu-fixed-left,\n.navmenu-fixed-right,\n.navbar-offcanvas {\n position: fixed;\n z-index: @zindex-navmenu-fixed;\n top: 0;\n border-radius: 0;\n}\n.navmenu-fixed-left,\n.navbar-offcanvas {\n left: 0;\n border-width: 0 1px 0 0;\n}\n.navmenu-fixed-right {\n right: 0;\n border-width: 0 0 0 1px;\n}\n\n.navmenu-nav {\n margin-bottom: @navmenu-margin-vertical;\n\n &.dropdown-menu {\n position: static;\n margin: 0;\n padding-top: 0;\n float: none;\n border: none;\n .box-shadow(none);\n border-radius: 0;\n }\n}\n\n.navbar-offcanvas {\n .navbar-nav {\n margin: 0;\n }\n\n @media (min-width: @grid-float-breakpoint) {\n width: auto;\n border-top: 0;\n box-shadow: none;\n\n &.offcanvas {\n position: static;\n display: block !important;\n height: auto !important;\n padding-bottom: 0; // Override default setting\n overflow: visible !important;\n }\n\n // Account for first and last children spacing\n .navbar-nav.navbar-left:first-child {\n margin-left: -@navbar-padding-horizontal;\n }\n .navbar-nav.navbar-right:last-child {\n margin-right: -@navbar-padding-horizontal;\n }\n\n .navmenu-brand {\n display: none;\n }\n }\n}\n\n// Brand/project name\n\n.navmenu-brand {\n display: block;\n font-size: @font-size-large;\n line-height: @line-height-computed;\n padding: @nav-link-padding;\n &:hover,\n &:focus {\n text-decoration: none;\n }\n margin: @navmenu-margin-vertical 0;\n}\n\n// Alternate navmenus\n// --------------------------------------------------\n\n// Default navmenu\n.navmenu-default,\n.navbar-default .navbar-offcanvas {\n background-color: @navmenu-default-bg;\n border-color: @navmenu-default-border;\n\n .navmenu-brand {\n color: @navmenu-default-brand-color;\n &:hover,\n &:focus {\n color: @navmenu-default-brand-hover-color;\n background-color: @navmenu-default-brand-hover-bg;\n }\n }\n\n .navmenu-text {\n color: @navmenu-default-color;\n }\n\n .navmenu-nav {\n // Caret should match text color on hover\n > .dropdown > a:hover .caret,\n > .dropdown > a:focus .caret {\n border-top-color: @navmenu-default-link-hover-color;\n border-bottom-color: @navmenu-default-link-hover-color;\n }\n\n // Remove background color from open dropdown\n > .open > a {\n &,\n &:hover,\n &:focus {\n background-color: @navmenu-default-link-active-bg;\n color: @navmenu-default-link-active-color;\n .caret {\n border-top-color: @navmenu-default-link-active-color;\n border-bottom-color: @navmenu-default-link-active-color;\n }\n }\n }\n > .dropdown > a .caret {\n border-top-color: @navmenu-default-link-color;\n border-bottom-color: @navmenu-default-link-color;\n }\n &.dropdown-menu {\n background-color: @navmenu-default-link-active-bg;\n & > .divider {\n background-color: @navmenu-default-bg;\n }\n > .active > a {\n &,\n &:hover,\n &:focus {\n background-color: darken(@navmenu-default-link-active-bg, 6.5%);\n }\n }\n }\n\n > li > a {\n color: @navmenu-default-link-color;\n &:hover,\n &:focus {\n color: @navmenu-default-link-hover-color;\n background-color: @navmenu-default-link-hover-bg;\n }\n }\n > .active > a {\n &,\n &:hover,\n &:focus {\n color: @navmenu-default-link-active-color;\n background-color: @navmenu-default-link-active-bg;\n }\n }\n > .disabled > a {\n &,\n &:hover,\n &:focus {\n color: @navmenu-default-link-disabled-color;\n background-color: @navmenu-default-link-disabled-bg;\n }\n }\n }\n}\n\n// Inverse navmenu\n.navmenu-inverse,\n.navbar-inverse .navbar-offcanvas {\n background-color: @navmenu-inverse-bg;\n border-color: @navmenu-inverse-border;\n\n .navmenu-brand {\n color: @navmenu-inverse-brand-color;\n &:hover,\n &:focus {\n color: @navmenu-inverse-brand-hover-color;\n background-color: @navmenu-inverse-brand-hover-bg;\n }\n }\n\n .navmenu-text {\n color: @navmenu-inverse-color;\n }\n\n .navmenu-nav {\n // Caret should match text color on hover\n > .dropdown > a:hover .caret,\n > .dropdown > a:focus .caret {\n border-top-color: @navmenu-inverse-link-hover-color;\n border-bottom-color: @navmenu-inverse-link-hover-color;\n }\n\n // Remove background color from open dropdown\n > .open > a {\n &,\n &:hover,\n &:focus {\n background-color: @navmenu-inverse-link-active-bg;\n color: @navmenu-inverse-link-active-color;\n .caret {\n border-top-color: @navmenu-inverse-link-active-color;\n border-bottom-color: @navmenu-inverse-link-active-color;\n }\n }\n }\n > .dropdown > a .caret {\n border-top-color: @navmenu-inverse-link-color;\n border-bottom-color: @navmenu-inverse-link-color;\n }\n &.dropdown-menu {\n background-color: @navmenu-inverse-link-active-bg;\n & > .divider {\n background-color: @navmenu-inverse-bg;\n }\n > .active > a {\n &,\n &:hover,\n &:focus {\n background-color: darken(@navmenu-inverse-link-active-bg, 6.5%);\n }\n }\n }\n\n > li > a {\n color: @navmenu-inverse-link-color;\n &:hover,\n &:focus {\n color: @navmenu-inverse-link-hover-color;\n background-color: @navmenu-inverse-link-hover-bg;\n }\n }\n > .active > a {\n &,\n &:hover,\n &:focus {\n color: @navmenu-inverse-link-active-color;\n background-color: @navmenu-inverse-link-active-bg;\n }\n }\n > .disabled > a {\n &,\n &:hover,\n &:focus {\n color: @navmenu-inverse-link-disabled-color;\n background-color: @navmenu-inverse-link-disabled-bg;\n }\n }\n }\n}\n","offcanvas.less":"//\n// Off canvas navigation\n// --------------------------------------------------\n\n.offcanvas {\n display: none;\n &.in {\n display: block;\n }\n}\n\n@media (max-width: @screen-xs-max) {\n .offcanvas-xs {\n .offcanvas;\n }\n}\n@media (max-width: @screen-sm-max) {\n .offcanvas-sm {\n .offcanvas;\n }\n}\n@media (max-width: @screen-md-max) {\n .offcanvas-md {\n .offcanvas;\n }\n}\n.offcanvas-lg {\n .offcanvas;\n}\n\n.canvas-sliding {\n -webkit-transition: top 0.35s, left 0.35s, bottom 0.35s, right 0.35s;\n transition: top 0.35s, left 0.35s, bottom 0.35s, right 0.35s;\n}\n\n.offcanvas-clone {\n height: 0px !important;\n width: 0px !important;\n overflow: hidden !important;\n border: none !important;\n margin: 0px !important;\n padding: 0px !important;\n position: absolute !important;\n top: auto !important;\n left: auto !important;\n bottom: 0px !important;\n right: 0px !important;\n opacity: 0 !important;\n}\n","rowlink.less":"//\n// Rowlink\n// --------------------------------------------------\n\n.table.rowlink,\n.table .rowlink {\n td:not(.rowlink-skip) {\n cursor: pointer;\n\n a {\n color: inherit;\n font: inherit;\n text-decoration: inherit;\n }\n }\n}\n\n.table-hover.rowlink,\n.table-hover .rowlink {\n tr:hover td {\n background-color: darken(@table-bg-hover, 15%);\n }\n}\n","variables.less":"//\n// These variables are used when Jasny Bootstrap is built\n// without importing Twitter Bootstrap.\n// --------------------------------------------------------\n\n//-- Colors\n//\n//## Gray colors for use across Bootstrap.\n\n@gray-darker: lighten(#000, 13.5%); // #222\n@gray-dark: lighten(#000, 20%); // #333\n@gray: lighten(#000, 33.5%); // #555\n@gray-light: lighten(#000, 60%); // #999\n@gray-lighter: lighten(#000, 93.5%); // #eee\n\n//-- Typography\n//\n//## Font size and line-height.\n\n@font-size-base: 14px;\n@font-size-large: ceil((@font-size-base * 1.25)); // ~18px\n@font-size-small: ceil((@font-size-base * 0.85)); // ~12px\n\n//** Unit-less `line-height` for use in components like buttons.\n@line-height-base: 1.428571429; // 20/14\n//** Computed \"line-height\" (`font-size` * `line-height`) for use with `margin`, `padding`, etc.\n@line-height-computed: floor((@font-size-base * @line-height-base)); // ~20px\n\n\n//== Components\n//\n//## Define common padding and border radius sizes and more. Values based on 14px text and 1.428 line-height (~20px to start).\n\n@padding-base-vertical: 6px;\n@padding-base-horizontal: 12px;\n\n@padding-large-vertical: 10px;\n@padding-large-horizontal: 16px;\n\n@padding-small-vertical: 5px;\n@padding-small-horizontal: 10px;\n\n@padding-xs-vertical: 1px;\n@padding-xs-horizontal: 5px;\n\n@line-height-large: 1.33;\n@line-height-small: 1.5;\n\n@border-radius-base: 4px;\n@border-radius-large: 6px;\n@border-radius-small: 3px;\n\n\n//== Tables\n//\n//## Customizes the `.table` component with basic values, each used across all table variations.\n\n//** Background color used for `.table-hover`.\n@table-bg-hover: #f5f5f5;\n\n\n//-- Z-index master list\n//\n// Warning: Avoid customizing these values. They're used for a bird's eye view\n// of components dependent on the z-axis and are designed to all work together.\n//\n// Note: These variables are not generated into the Customizer.\n\n@zindex-navmenu-fixed: 1030;\n@zindex-alert-fixed: 1035;\n\n\n//== Media queries breakpoints\n//\n//## Define the breakpoints at which your layout will change, adapting to different screen sizes.\n\n// Extra small screen / phone\n@screen-xs: 480px;\n\n// Small screen / tablet\n@screen-sm: 768px;\n\n// Medium screen / desktop\n@screen-md: 992px;\n\n// Large screen / wide desktop\n@screen-lg: 1200px;\n\n//-- So media queries don't overlap when required, provide a maximum\n//\n// Note: These variables are not generated into the Customizer.\n@screen-xs-min: @screen-xs;\n@screen-sm-min: @screen-sm;\n@screen-md-min: @screen-md;\n@screen-lg-min: @screen-lg;\n\n@screen-xs-max: (@screen-sm-min - 1);\n@screen-sm-max: (@screen-md-min - 1);\n@screen-md-max: (@screen-lg-min - 1);\n\n//--\n@container-lg: ((1140px + @grid-gutter-width));\n\n//== Grid system\n//\n//## Define your custom responsive grid.\n\n//** Padding between columns. Gets divided in half for the left and right.\n@grid-gutter-width: 30px;\n//** Point at which the navbar becomes uncollapsed.\n@grid-float-breakpoint: 768px;\n\n//** Maximum with of a smooth container.\n@container-smooth: @container-lg;\n\n//== Navbar\n//\n//##\n\n// Basics of a navbar\n@navbar-height: 50px;\n@navbar-padding-horizontal: floor((@grid-gutter-width / 2));\n@navbar-padding-vertical: ((@navbar-height - @line-height-computed) / 2);\n\n\n//== Navmenu\n//\n//##\n\n// Basics of a navmenu\n@navmenu-width: 300px;\n@navmenu-margin-vertical: (0.5 * @line-height-computed);\n@navmenu-default-color: #777;\n@navmenu-default-bg: #f8f8f8;\n@navmenu-default-border: darken(@navmenu-default-bg, 6.5%);\n\n// Navmenu links\n@navmenu-default-link-color: #777;\n@navmenu-default-link-hover-color: #333;\n@navmenu-default-link-hover-bg: transparent;\n@navmenu-default-link-active-color: #555;\n@navmenu-default-link-active-bg: darken(@navmenu-default-bg, 6.5%);\n@navmenu-default-link-disabled-color: #ccc;\n@navmenu-default-link-disabled-bg: transparent;\n\n// Navmenu brand label\n@navmenu-default-brand-color: @navmenu-default-link-color;\n@navmenu-default-brand-hover-color: darken(@navmenu-default-link-color, 10%);\n@navmenu-default-brand-hover-bg: transparent;\n\n\n// Inverted navmenu\n//\n// Reset inverted navmenu basics\n@navmenu-inverse-color: @gray-light;\n@navmenu-inverse-bg: #222;\n@navmenu-inverse-border: darken(@navmenu-inverse-bg, 10%);\n\n// Inverted navmenu links\n@navmenu-inverse-link-color: @gray-light;\n@navmenu-inverse-link-hover-color: #fff;\n@navmenu-inverse-link-hover-bg: transparent;\n@navmenu-inverse-link-active-color: @navmenu-inverse-link-hover-color;\n@navmenu-inverse-link-active-bg: darken(@navmenu-inverse-bg, 10%);\n@navmenu-inverse-link-disabled-color: #444;\n@navmenu-inverse-link-disabled-bg: transparent;\n\n// Inverted navmenu brand label\n@navmenu-inverse-brand-color: @navmenu-inverse-link-color;\n@navmenu-inverse-brand-hover-color: #fff;\n@navmenu-inverse-brand-hover-bg: transparent;\n\n// Inverted navmenu search\n// Normal navmenu needs no special styles or vars\n@navmenu-inverse-search-bg: lighten(@navmenu-inverse-bg, 25%);\n@navmenu-inverse-search-bg-focus: #fff;\n@navmenu-inverse-search-border: @navmenu-inverse-bg;\n@navmenu-inverse-search-placeholder-color: #ccc;\n\n\n//== Navs\n//\n//##\n\n@nav-link-padding: 10px 15px;\n@nav-tabs-active-link-hover-border-color: #ddd;\n@nav-tabs-border-color: #ddd;\n\n\n//== Form states and alerts\n//\n//## Define colors for form feedback states and, by default, alerts.\n\n@state-success-text: #3c763d;\n@state-success-bg: #dff0d8;\n@state-success-border: darken(spin(@state-success-bg, -10), 5%);\n\n@state-info-text: #31708f;\n@state-info-bg: #d9edf7;\n@state-info-border: darken(spin(@state-info-bg, -10), 7%);\n\n@state-warning-text: #8a6d3b;\n@state-warning-bg: #fcf8e3;\n@state-warning-border: darken(spin(@state-warning-bg, -10), 5%);\n\n@state-danger-text: #a94442;\n@state-danger-bg: #f2dede;\n@state-danger-border: darken(spin(@state-danger-bg, -10), 5%);\n\n\n//== Alerts\n//\n//## Define alert colors, border radius, and padding.\n\n@alert-border-radius: @border-radius-base;\n@alert-fixed-width: @screen-md;\n"}; /*! * Bootstrap Customizer (http://getbootstrap.com/customize/) * Copyright 2011-2014 Twitter, Inc. @@ -52,4 +52,4 @@ var __js={"fileinput.js":"/* =================================================== * Licensed under the Creative Commons Attribution 3.0 Unported License. For * details, see http://creativecommons.org/licenses/by/3.0/. */ -window.onload=function(){function a(a,b){throw $('
×

'+a+"

"+(b.extract?'
'+b.extract.join("\n")+"
":"")+"
").appendTo("body").alert(),b}function b(a,b){var c=$('

Attention!

'+a+"

");b?c.appendTo(".bs-docs-container"):c.insertAfter(".bs-customize-download")}function c(a){a=a.replace(/[*+?^$.\[\]{}()|\\\/]/g,"\\$&");var b=location.search.match(new RegExp("[?&]"+a+"=([^&]+)(&|$)"));return b&&decodeURIComponent(b[1].replace(/\+/g," "))}function d(b){var c={description:"Bootstrap Customizer Config","public":!0,files:{"config.json":{content:b}}};$.ajax({url:"https://api.github.com/gists",type:"POST",dataType:"json",data:JSON.stringify(c)}).success(function(a){var b=window.location.protocol+"//"+window.location.host;history.replaceState(!1,document.title,b+window.location.pathname+"?id="+a.id)}).error(function(b){a("Ruh roh! Could not save gist file, configuration not saved.",b)})}function e(){var a={};$("#less-variables-section input").each(function(){$(this).val()&&(a[$(this).prev().text()]=$(this).val())});var b={vars:a,css:$("#less-section input:checked").map(function(){return this.value}).toArray(),js:$("#plugin-section input:checked").map(function(){return this.value}).toArray()};if(!$.isEmptyObject(b.vars)||b.css.length||b.js.length)return b}function f(){var b=c("id");b&&$.ajax({url:"https://api.github.com/gists/"+b,type:"GET",dataType:"json"}).success(function(a){var b=JSON.parse(a.files["config.json"].content);if(b.js&&$("#plugin-section input").each(function(){$(this).prop("checked",~$.inArray(this.value,b.js))}),b.css&&$("#less-section input").each(function(){$(this).prop("checked",~$.inArray(this.value,b.css))}),b.vars)for(var c in b.vars)$('input[data-var="'+c+'"]').val(b.vars[c])}).error(function(b){a("Error fetching bootstrap config file",b)})}function g(b,c,d,e,f){if(!b&&!c)return a("Ruh roh! No Bootstrap files selected.",new Error("no Bootstrap"));var g=new JSZip;if(b){var h=g.folder("css");for(var i in b)h.file(i,b[i])}if(c){var j=g.folder("js");for(var k in c)j.file(k,c[k])}if(d){var l=g.folder("fonts");for(var m in d)l.file(m,d[m],{base64:!0})}e&&g.file("config.json",e);var n=g.generate({type:"blob"});f(n)}function h(a){var b="";for(var c in a)b+=c+": "+a[c]+";\n";return b+"\n\n"}function i(){var a=$('#less-section [value="glyphicons.less"]:checked');return a.length?__fonts:void 0}function j(a){for(var b=/^@import \"(.*?)\";$/,c=__less[a].split("\n"),d=0,e=[];dRuh roh! Could not parse less files.",b):(d[c+".css"]=o+e.toCSS(),void(d[c+".min.css"]=o+e.toCSS({compress:!0})))})}function m(){var b=!1,c={};if($("#less-section input").each(function(){var a=$(this),d=a.is(":checked");c[a.val()]=d,b=b||d}),!b)return!1;var d={},e={};$("#less-variables-section input").each(function(){$(this).val()&&(e[$(this).prev().text()]=$(this).val())});var f=k("bootstrap.less",c,e),g=k("theme.less",c,e);try{l(f,"bootstrap",d),l(g,"bootstrap-theme",d)}catch(h){return a("Ruh roh! Could not parse less files.",h)}return d}function n(){var a=$("#plugin-section input:checked");if(!a.length)return!1;var b=a.map(function(){return __js[this.value]}).toArray().join("\n");return{"bootstrap.js":b,"bootstrap.min.js":o+uglify(b)}}var o="/*!\n * Bootstrap v3.1.0 (http://getbootstrap.com)\n * Copyright 2011-2014 Twitter, Inc.\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n */\n\n",p=$("#less-section input"),q=$("#plugin-section input"),r=$("#less-variables-section input");$("#less-section .toggle").on("click",function(a){a.preventDefault(),p.prop("checked",!p.is(":checked"))}),$("#plugin-section .toggle").on("click",function(a){a.preventDefault(),q.prop("checked",!q.is(":checked"))}),$("#less-variables-section .toggle").on("click",function(a){a.preventDefault(),r.val("")}),$("[data-dependencies]").on("click",function(){if($(this).is(":checked")){var a=this.getAttribute("data-dependencies");if(a){a=a.split(",");for(var b=0;bupgrade to a more modern browser.',!0)):b('Looks like you\'re using safari, which sadly doesn\'t have the best supportfor HTML5 blobs. Because of this your file will be downloaded with the name "untitled".However, if you check your downloads folder, just rename this "untitled" fileto "bootstrap.zip" and you should be good to go!'),f()}; \ No newline at end of file +window.onload=function(){function a(a,b){throw $('
×

'+a+"

"+(b.extract?'
'+b.extract.join("\n")+"
":"")+"
").appendTo("body").alert(),b}function b(a,b){var c=$('

Attention!

'+a+"

");b?c.appendTo(".bs-docs-container"):c.insertAfter(".bs-customize-download")}function c(a){a=a.replace(/[*+?^$.\[\]{}()|\\\/]/g,"\\$&");var b=location.search.match(new RegExp("[?&]"+a+"=([^&]+)(&|$)"));return b&&decodeURIComponent(b[1].replace(/\+/g," "))}function d(b){var c={description:"Bootstrap Customizer Config","public":!0,files:{"config.json":{content:b}}};$.ajax({url:"https://api.github.com/gists",type:"POST",dataType:"json",data:JSON.stringify(c)}).success(function(a){var b=window.location.protocol+"//"+window.location.host;history.replaceState(!1,document.title,b+window.location.pathname+"?id="+a.id)}).error(function(b){a("Ruh roh! Could not save gist file, configuration not saved.",b)})}function e(){var a={};$("#less-variables-section input").each(function(){$(this).val()&&(a[$(this).prev().text()]=$(this).val())});var b={vars:a,css:$("#less-section input:checked").map(function(){return this.value}).toArray(),js:$("#plugin-section input:checked").map(function(){return this.value}).toArray()};if(!$.isEmptyObject(b.vars)||b.css.length||b.js.length)return b}function f(){var b=c("id");b&&$.ajax({url:"https://api.github.com/gists/"+b,type:"GET",dataType:"json"}).success(function(a){var b=JSON.parse(a.files["config.json"].content);if(b.js&&$("#plugin-section input").each(function(){$(this).prop("checked",~$.inArray(this.value,b.js))}),b.css&&$("#less-section input").each(function(){$(this).prop("checked",~$.inArray(this.value,b.css))}),b.vars)for(var c in b.vars)$('input[data-var="'+c+'"]').val(b.vars[c])}).error(function(b){a("Error fetching bootstrap config file",b)})}function g(b,c,d,e,f){if(!b&&!c)return a("Ruh roh! No Bootstrap files selected.",new Error("no Bootstrap"));var g=new JSZip;if(b){var h=g.folder("css");for(var i in b)h.file(i,b[i])}if(c){var j=g.folder("js");for(var k in c)j.file(k,c[k])}if(d){var l=g.folder("fonts");for(var m in d)l.file(m,d[m],{base64:!0})}e&&g.file("config.json",e);var n=g.generate({type:"blob"});f(n)}function h(a){var b="";for(var c in a)b+=c+": "+a[c]+";\n";return b+"\n\n"}function i(){return!1}function j(a){for(var b=/^@import \"(.*?)\";$/,c=__less[a].split("\n"),d=0,e=[];dRuh roh! Could not parse less files.",b):(d[c+".css"]=o+e.toCSS(),void(d[c+".min.css"]=o+e.toCSS({compress:!0})))})}function m(){var b=!1,c={};if($("#less-section input").each(function(){var a=$(this),d=a.is(":checked");c[a.val()]=d,b=b||d}),!b)return!1;var d={},e={};$("#less-variables-section input").each(function(){$(this).val()&&(e[$(this).prev().text()]=$(this).val())});var f=k("jasny-bootstrap.less",c,e);try{l(f,"jasny-bootstrap",d)}catch(g){return a("Ruh roh! Could not parse less files.",g)}return d}function n(){var a=$("#plugin-section input:checked");if(!a.length)return!1;var b=a.map(function(){return __js[this.value]}).toArray().join("\n");return{"jasny-bootstrap.js":b,"jasny-bootstrap.min.js":o+uglify(b)}}{var o="/*!\n * Jasny Bootstrap v3.1.0 (http://jasny.github.com/bootstrap)\n * Copyright 2011-2014 Arnold Daniels.\n * Licensed under Apache-2.0 (https://github.com/jasny/bootstrap/blob/master/LICENSE)\n */\n\n",p=$("#less-section input"),q=$("#plugin-section input");$("#less-variables-section input")}$("#less-section .toggle").on("click",function(a){a.preventDefault(),p.prop("checked",!p.is(":checked"))}),$("#plugin-section .toggle").on("click",function(a){a.preventDefault(),q.prop("checked",!q.is(":checked"))}),$("[data-dependencies]").on("click",function(){if($(this).is(":checked")){var a=this.getAttribute("data-dependencies");if(a){a=a.split(",");for(var b=0;bupgrade to a more modern browser.',!0)):b('Looks like you\'re using safari, which sadly doesn\'t have the best supportfor HTML5 blobs. Because of this your file will be downloaded with the name "untitled".However, if you check your downloads folder, just rename this "untitled" fileto "jasny-bootstrap.zip" and you should be good to go!'),f()}; \ No newline at end of file diff --git a/assets/js/customizer.js b/assets/js/customizer.js index ee85cc85..ccdd7bc2 100644 --- a/assets/js/customizer.js +++ b/assets/js/customizer.js @@ -8,9 +8,9 @@ window.onload = function () { // wait for load in a dumb way because B-0 var cw = '/*!\n' + - ' * Bootstrap v3.1.0 (http://getbootstrap.com)\n' + - ' * Copyright 2011-2014 Twitter, Inc.\n' + - ' * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n' + + ' * Jasny Bootstrap v3.1.0 (http://jasny.github.com/bootstrap)\n' + + ' * Copyright 2011-2014 Arnold Daniels.\n' + + ' * Licensed under Apache-2.0 (https://github.com/jasny/bootstrap/blob/master/LICENSE)\n' + ' */\n\n' function showError(msg, err) { @@ -166,10 +166,7 @@ window.onload = function () { // wait for load in a dumb way because B-0 } function generateFonts() { - var glyphicons = $('#less-section [value="glyphicons.less"]:checked') - if (glyphicons.length) { - return __fonts - } + return false; } // Returns an Array of @import'd filenames in the order @@ -200,7 +197,7 @@ window.onload = function () { // wait for load in a dumb way because B-0 // Custom variables are added after Bootstrap variables so the custom // ones take precedence. - if (('variables.less' === filename) && vars) lessSource += generateCustomCSS(vars) + if (('build/default-variables.less' === filename) && vars) lessSource += generateCustomCSS(vars) }) lessSource = lessSource.replace(/@import[^\n]*/gi, '') //strip any imports @@ -209,7 +206,7 @@ window.onload = function () { // wait for load in a dumb way because B-0 function compileLESS(lessSource, baseFilename, intoResult) { var parser = new less.Parser({ - paths: ['variables.less', 'mixins.less'], + paths: ['build/default-variables.less', 'mixins.less'], optimization: 0, filename: baseFilename + '.css' }).parse(lessSource, function (err, tree) { @@ -242,12 +239,10 @@ window.onload = function () { // wait for load in a dumb way because B-0 $(this).val() && (vars[$(this).prev().text()] = $(this).val()) }) - var bsLessSource = generateLESS('bootstrap.less', lessFileIncludes, vars) - var themeLessSource = generateLESS('theme.less', lessFileIncludes, vars) + var bsLessSource = generateLESS('jasny-bootstrap.less', lessFileIncludes, vars) try { - compileLESS(bsLessSource, 'bootstrap', result) - compileLESS(themeLessSource, 'bootstrap-theme', result) + compileLESS(bsLessSource, 'jasny-bootstrap', result) } catch (err) { return showError('Ruh roh! Could not parse less files.', err) } @@ -265,8 +260,8 @@ window.onload = function () { // wait for load in a dumb way because B-0 .join('\n') return { - 'bootstrap.js': js, - 'bootstrap.min.js': cw + uglify(js) + 'jasny-bootstrap.js': js, + 'jasny-bootstrap.min.js': cw + uglify(js) } } @@ -284,11 +279,6 @@ window.onload = function () { // wait for load in a dumb way because B-0 inputsPlugin.prop('checked', !inputsPlugin.is(':checked')) }) - $('#less-variables-section .toggle').on('click', function (e) { - e.preventDefault() - inputsVariables.val('') - }) - $('[data-dependencies]').on('click', function () { if (!$(this).is(':checked')) return var dependencies = this.getAttribute('data-dependencies') @@ -324,7 +314,7 @@ window.onload = function () { // wait for load in a dumb way because B-0 generateZip(generateCSS(), generateJavascript(), generateFonts(), configJson, function (blob) { $compileBtn.removeAttr('disabled') - saveAs(blob, 'bootstrap.zip') + saveAs(blob, 'jasny-bootstrap.zip') createGist(configJson) }) }) @@ -334,7 +324,7 @@ window.onload = function () { // wait for load in a dumb way because B-0 showCallout('Looks like you\'re using safari, which sadly doesn\'t have the best support' + 'for HTML5 blobs. Because of this your file will be downloaded with the name "untitled".' + 'However, if you check your downloads folder, just rename this "untitled" file' + - 'to "bootstrap.zip" and you should be good to go!') + 'to "jasny-bootstrap.zip" and you should be good to go!') } else if (!window.URL && !window.webkitURL) { $('.bs-docs-section, .bs-docs-sidebar').css('display', 'none') diff --git a/assets/js/raw-files.min.js b/assets/js/raw-files.min.js index a5d7339b..d913c606 100644 --- a/assets/js/raw-files.min.js +++ b/assets/js/raw-files.min.js @@ -3,5 +3,5 @@ * Copyright 2012-2014 Arnold Daniels * Licensed under Apache-2.0 (https://github.com/jasny/bootstrap/blob/master/LICENSE) */ -var __js = {"fileinput.js":"/* ===========================================================\n * Bootstrap: fileinput.js v3.0.0-p7\n * http://jasny.github.com/bootstrap/javascript.html#fileinput\n * ===========================================================\n * Copyright 2012 Jasny BV, Netherlands.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\")\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * ========================================================== */\n\n+function ($) { \"use strict\";\n\n var isIE = window.navigator.appName == 'Microsoft Internet Explorer'\n\n // FILEUPLOAD PUBLIC CLASS DEFINITION\n // =================================\n\n var Fileinput = function (element, options) {\n this.$element = $(element)\n \n this.$input = this.$element.find(':file')\n if (this.$input.length === 0) return\n\n this.name = this.$input.attr('name') || options.name\n\n this.$hidden = this.$element.find('input[type=hidden][name=\"' + this.name + '\"]')\n if (this.$hidden.length === 0) {\n this.$hidden = $('')\n this.$element.prepend(this.$hidden)\n }\n\n this.$preview = this.$element.find('.fileinput-preview')\n var height = this.$preview.css('height')\n if (this.$preview.css('display') != 'inline' && height != '0px' && height != 'none') this.$preview.css('line-height', height)\n\n this.original = {\n exists: this.$element.hasClass('fileinput-exists'),\n preview: this.$preview.html(),\n hiddenVal: this.$hidden.val()\n }\n \n this.listen()\n }\n \n Fileinput.prototype.listen = function() {\n this.$input.on('change.bs.fileinput', $.proxy(this.change, this))\n $(this.$input[0].form).on('reset.bs.fileinput', $.proxy(this.reset, this))\n \n this.$element.find('[data-trigger=\"fileinput\"]').on('click.bs.fileinput', $.proxy(this.trigger, this))\n this.$element.find('[data-dismiss=\"fileinput\"]').on('click.bs.fileinput', $.proxy(this.clear, this))\n },\n\n Fileinput.prototype.change = function(e) {\n if (e.target.files === undefined) e.target.files = e.target && e.target.value ? [ {name: e.target.value.replace(/^.+\\\\/, '')} ] : []\n if (e.target.files.length === 0) return\n\n this.$hidden.val('')\n this.$hidden.attr('name', '')\n this.$input.attr('name', this.name)\n\n var file = e.target.files[0]\n\n if (this.$preview.length > 0 && (typeof file.type !== \"undefined\" ? file.type.match('image.*') : file.name.match(/\\.(gif|png|jpe?g)$/i)) && typeof FileReader !== \"undefined\") {\n var reader = new FileReader()\n var preview = this.$preview\n var element = this.$element\n\n reader.onload = function(re) {\n var $img = $('') // .attr('src', re.target.result)\n $img[0].src = re.target.result\n e.target.files[0].result = re.target.result\n \n element.find('.fileinput-filename').text(file.name)\n \n // if parent has max-height, using `(max-)height: 100%` on child doesn't take padding and border into account\n if (preview.css('max-height') != 'none') $img.css('max-height', parseInt(preview.css('max-height'), 10) - parseInt(preview.css('padding-top'), 10) - parseInt(preview.css('padding-bottom'), 10) - parseInt(preview.css('border-top'), 10) - parseInt(preview.css('border-bottom'), 10))\n \n preview.html($img)\n element.addClass('fileinput-exists').removeClass('fileinput-new')\n\n element.trigger('change.bs.fileinput', e.target.files)\n }\n\n reader.readAsDataURL(file)\n } else {\n this.$element.find('.fileinput-filename').text(file.name)\n this.$preview.text(file.name)\n \n this.$element.addClass('fileinput-exists').removeClass('fileinput-new')\n \n this.$element.trigger('change.bs.fileinput')\n }\n },\n\n Fileinput.prototype.clear = function(e) {\n if (e) e.preventDefault()\n \n this.$hidden.val('')\n this.$hidden.attr('name', this.name)\n this.$input.attr('name', '')\n\n //ie8+ doesn't support changing the value of input with type=file so clone instead\n if (isIE) { \n var inputClone = this.$input.clone(true);\n this.$input.after(inputClone);\n this.$input.remove();\n this.$input = inputClone;\n } else {\n this.$input.val('')\n }\n\n this.$preview.html('')\n this.$element.find('.fileinput-filename').text('')\n this.$element.addClass('fileinput-new').removeClass('fileinput-exists')\n \n if (e !== false) {\n this.$input.trigger('change')\n this.$element.trigger('clear.bs.fileinput')\n }\n },\n\n Fileinput.prototype.reset = function() {\n this.clear(false)\n\n this.$hidden.val(this.original.hiddenVal)\n this.$preview.html(this.original.preview)\n this.$element.find('.fileinput-filename').text('')\n\n if (this.original.exists) this.$element.addClass('fileinput-exists').removeClass('fileinput-new')\n else this.$element.addClass('fileinput-new').removeClass('fileinput-exists')\n \n this.$element.trigger('reset.bs.fileinput')\n },\n\n Fileinput.prototype.trigger = function(e) {\n this.$input.trigger('click')\n e.preventDefault()\n }\n\n \n // FILEUPLOAD PLUGIN DEFINITION\n // ===========================\n\n var old = $.fn.fileinput\n \n $.fn.fileinput = function (options) {\n return this.each(function () {\n var $this = $(this),\n data = $this.data('fileinput')\n if (!data) $this.data('fileinput', (data = new Fileinput(this, options)))\n if (typeof options == 'string') data[options]()\n })\n }\n\n $.fn.fileinput.Constructor = Fileinput\n\n\n // FILEINPUT NO CONFLICT\n // ====================\n\n $.fn.fileinput.noConflict = function () {\n $.fn.fileinput = old\n return this\n }\n\n\n // FILEUPLOAD DATA-API\n // ==================\n\n $(document).on('click.fileinput.data-api', '[data-provides=\"fileinput\"]', function (e) {\n var $this = $(this)\n if ($this.data('fileinput')) return\n $this.fileinput($this.data())\n \n var $target = $(e.target).closest('[data-dismiss=\"fileinput\"],[data-trigger=\"fileinput\"]');\n if ($target.length > 0) {\n e.preventDefault()\n $target.trigger('click.bs.fileinput')\n }\n })\n\n}(window.jQuery);\n","inputmask.js":"/* ===========================================================\n * Bootstrap: inputmask.js v3.0.0-p7\n * http://jasny.github.io/bootstrap/javascript.html#inputmask\n * Based on Masked Input plugin by Josh Bush (digitalbush.com)\n * ===========================================================\n * Copyright 2012 Jasny BV, Netherlands.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\")\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * ========================================================== */\n\n+function ($) { \"use strict\";\n\n var isIphone = (window.orientation !== undefined)\n var isAndroid = navigator.userAgent.toLowerCase().indexOf(\"android\") > -1\n var isIE = window.navigator.appName == 'Microsoft Internet Explorer'\n\n // INPUTMASK PUBLIC CLASS DEFINITION\n // =================================\n\n var Inputmask = function (element, options) {\n if (isAndroid) return // No support because caret positioning doesn't work on Android\n \n this.$element = $(element)\n this.options = $.extend({}, Inputmask.DEFAULS, options)\n this.mask = String(this.options.mask)\n \n this.init()\n this.listen()\n \n this.checkVal() //Perform initial check for existing values\n }\n\n Inputmask.DEFAULS = {\n mask: \"\",\n placeholder: \"_\",\n definitions: {\n '9': \"[0-9]\",\n 'a': \"[A-Za-z]\",\n '?': \"[A-Za-z0-9]\",\n '*': \".\"\n }\n }\n\n Inputmask.prototype.init = function() {\n var defs = this.options.definitions\n var len = this.mask.length\n\n this.tests = [] \n this.partialPosition = this.mask.length\n this.firstNonMaskPos = null\n\n $.each(this.mask.split(\"\"), $.proxy(function(i, c) {\n if (c == '?') {\n len--\n this.partialPosition = i\n } else if (defs[c]) {\n this.tests.push(new RegExp(defs[c]))\n if (this.firstNonMaskPos === null)\n this.firstNonMaskPos = this.tests.length - 1\n } else {\n this.tests.push(null)\n }\n }, this))\n\n this.buffer = $.map(this.mask.split(\"\"), $.proxy(function(c, i) {\n if (c != '?') return defs[c] ? this.options.placeholder : c\n }, this))\n\n this.focusText = this.$element.val()\n\n this.$element.data(\"rawMaskFn\", $.proxy(function() {\n return $.map(this.buffer, function(c, i) {\n return this.tests[i] && c != this.options.placeholder ? c : null\n }).join('')\n }, this))\n }\n \n Inputmask.prototype.listen = function() {\n if (this.$element.attr(\"readonly\")) return\n\n var pasteEventName = (isIE ? 'paste' : 'input') + \".mask\"\n\n this.$element\n .on(\"unmask.bs.inputmask\", $.proxy(this.unmask, this))\n\n .on(\"focus.bs.inputmask\", $.proxy(this.focusEvent, this))\n .on(\"blur.bs.inputmask\", $.proxy(this.blurEvent, this))\n\n .on(\"keydown.bs.inputmask\", $.proxy(this.keydownEvent, this))\n .on(\"keypress.bs.inputmask\", $.proxy(this.keypressEvent, this))\n\n .on(pasteEventName, $.proxy(this.pasteEvent, this))\n }\n\n //Helper Function for Caret positioning\n Inputmask.prototype.caret = function(begin, end) {\n if (this.$element.length === 0) return\n if (typeof begin == 'number') {\n end = (typeof end == 'number') ? end : begin\n return this.$element.each(function() {\n if (this.setSelectionRange) {\n this.setSelectionRange(begin, end)\n } else if (this.createTextRange) {\n var range = this.createTextRange()\n range.collapse(true)\n range.moveEnd('character', end)\n range.moveStart('character', begin)\n range.select()\n }\n })\n } else {\n if (this.$element[0].setSelectionRange) {\n begin = this.$element[0].selectionStart\n end = this.$element[0].selectionEnd\n } else if (document.selection && document.selection.createRange) {\n var range = document.selection.createRange()\n begin = 0 - range.duplicate().moveStart('character', -100000)\n end = begin + range.text.length\n }\n return {\n begin: begin, \n end: end\n }\n }\n }\n \n Inputmask.prototype.seekNext = function(pos) {\n var len = this.mask.length\n while (++pos <= len && !this.tests[pos]);\n\n return pos\n }\n \n Inputmask.prototype.seekPrev = function(pos) {\n while (--pos >= 0 && !this.tests[pos]);\n\n return pos\n }\n\n Inputmask.prototype.shiftL = function(begin,end) {\n var len = this.mask.length\n\n if (begin < 0) return\n\n for (var i = begin, j = this.seekNext(end); i < len; i++) {\n if (this.tests[i]) {\n if (j < len && this.tests[i].test(this.buffer[j])) {\n this.buffer[i] = this.buffer[j]\n this.buffer[j] = this.options.placeholder\n } else\n break\n j = this.seekNext(j)\n }\n }\n this.writeBuffer()\n this.caret(Math.max(this.firstNonMaskPos, begin))\n }\n\n Inputmask.prototype.shiftR = function(pos) {\n var len = this.mask.length\n\n for (var i = pos, c = this.options.placeholder; i < len; i++) {\n if (this.tests[i]) {\n var j = this.seekNext(i)\n var t = this.buffer[i]\n this.buffer[i] = c\n if (j < len && this.tests[j].test(t))\n c = t\n else\n break\n }\n }\n },\n\n Inputmask.prototype.unmask = function() {\n this.$element\n .unbind(\".mask\")\n .removeData(\"inputmask\")\n }\n\n Inputmask.prototype.focusEvent = function() {\n this.focusText = this.$element.val()\n var len = this.mask.length \n var pos = this.checkVal()\n this.writeBuffer()\n\n var that = this\n var moveCaret = function() {\n if (pos == len)\n that.caret(0, pos)\n else\n that.caret(pos)\n }\n\n moveCaret()\n setTimeout(moveCaret, 50)\n }\n\n Inputmask.prototype.blurEvent = function() {\n this.checkVal()\n if (this.$element.val() !== this.focusText)\n this.$element.trigger('change')\n }\n\n Inputmask.prototype.keydownEvent = function(e) {\n var k = e.which\n\n //backspace, delete, and escape get special treatment\n if (k == 8 || k == 46 || (isIphone && k == 127)) {\n var pos = this.caret(),\n begin = pos.begin,\n end = pos.end\n\n if (end - begin === 0) {\n begin = k != 46 ? this.seekPrev(begin) : (end = this.seekNext(begin - 1))\n end = k == 46 ? this.seekNext(end) : end\n }\n this.clearBuffer(begin, end)\n this.shiftL(begin, end - 1)\n\n return false\n } else if (k == 27) {//escape\n this.$element.val(this.focusText)\n this.caret(0, this.checkVal())\n return false\n }\n }\n\n Inputmask.prototype.keypressEvent = function(e) {\n var len = this.mask.length\n\n var k = e.which,\n pos = this.caret()\n\n if (e.ctrlKey || e.altKey || e.metaKey || k < 32) {//Ignore\n return true\n } else if (k) {\n if (pos.end - pos.begin !== 0) {\n this.clearBuffer(pos.begin, pos.end)\n this.shiftL(pos.begin, pos.end - 1)\n }\n\n var p = this.seekNext(pos.begin - 1)\n if (p < len) {\n var c = String.fromCharCode(k)\n if (this.tests[p].test(c)) {\n this.shiftR(p)\n this.buffer[p] = c\n this.writeBuffer()\n var next = this.seekNext(p)\n this.caret(next)\n }\n }\n return false\n }\n }\n\n Inputmask.prototype.pasteEvent = function() {\n var that = this\n\n setTimeout(function() {\n that.caret(that.checkVal(true))\n }, 0)\n }\n\n Inputmask.prototype.clearBuffer = function(start, end) {\n var len = this.mask.length\n\n for (var i = start; i < end && i < len; i++) {\n if (this.tests[i])\n this.buffer[i] = this.options.placeholder\n }\n }\n\n Inputmask.prototype.writeBuffer = function() {\n return this.$element.val(this.buffer.join('')).val()\n }\n\n Inputmask.prototype.checkVal = function(allow) {\n var len = this.mask.length\n //try to place characters where they belong\n var test = this.$element.val()\n var lastMatch = -1\n\n for (var i = 0, pos = 0; i < len; i++) {\n if (this.tests[i]) {\n this.buffer[i] = this.options.placeholder\n while (pos++ < test.length) {\n var c = test.charAt(pos - 1)\n if (this.tests[i].test(c)) {\n this.buffer[i] = c\n lastMatch = i\n break\n }\n }\n if (pos > test.length)\n break\n } else if (this.buffer[i] == test.charAt(pos) && i != this.partialPosition) {\n pos++\n lastMatch = i\n }\n }\n if (!allow && lastMatch + 1 < this.partialPosition) {\n this.$element.val(\"\")\n this.clearBuffer(0, len)\n } else if (allow || lastMatch + 1 >= this.partialPosition) {\n this.writeBuffer()\n if (!allow) this.$element.val(this.$element.val().substring(0, lastMatch + 1))\n }\n return (this.partialPosition ? i : this.firstNonMaskPos)\n }\n\n \n // INPUTMASK PLUGIN DEFINITION\n // ===========================\n\n var old = $.fn.inputmask\n \n $.fn.inputmask = function (options) {\n return this.each(function () {\n var $this = $(this)\n var data = $this.data('inputmask')\n \n if (!data) $this.data('inputmask', (data = new Inputmask(this, options)))\n })\n }\n\n $.fn.inputmask.Constructor = Inputmask\n\n\n // INPUTMASK NO CONFLICT\n // ====================\n\n $.fn.inputmask.noConflict = function () {\n $.fn.inputmask = old\n return this\n }\n\n\n // INPUTMASK DATA-API\n // ==================\n\n $(document).on('focus.bs.inputmask.data-api', '[data-mask]', function (e) {\n var $this = $(this)\n if ($this.data('inputmask')) return\n $this.inputmask($this.data())\n })\n\n}(window.jQuery);\n","offcanvas.js":"/* ========================================================================\n * Bootstrap: offcanvas.js v3.0.3-p7\n * http://jasny.github.io/bootstrap/javascript.html#offcanvas\n * \n * Based on Boostrap collapse.js by Twitter, Inc. \n * ========================================================================\n * Copyright 2013 Jasny, BV.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\")\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * ======================================================================== */\n\n+function ($) { \"use strict\";\n\n // OFFCANVAS PUBLIC CLASS DEFINITION\n // =================================\n\n var OffCanvas = function (element, options) {\n this.$element = $(element)\n this.options = $.extend({}, OffCanvas.DEFAULTS, options)\n this.state = null\n \n if (this.options.recalc) {\n this.calcClone()\n $(window).on('resize', $.proxy(this.recalc, this))\n }\n \n if (this.options.autohide)\n $(document).on('click', $.proxy(this.autohide, this))\n\n if (this.options.toggle) this.toggle()\n }\n\n OffCanvas.DEFAULTS = {\n toggle: true,\n placement: 'left',\n autohide: true,\n recalc: true\n }\n\n OffCanvas.prototype.offset = function () {\n switch (this.options.placement) {\n case 'left':\n case 'right': return this.$element.outerWidth()\n case 'top':\n case 'bottom': return this.$element.outerHeight()\n }\n }\n \n OffCanvas.prototype.calcPlacement = function () {\n var horizontal = $(window).width() / this.$element.width(),\n vertical = $(window).height() / this.$element.height()\n \n if (!this.$element.hasClass('in')) {\n this.$element.css('visiblity', 'hidden !important').addClass('in')\n } \n \n var element = this.$element\n function ab(a, b) {\n if (element.css(b) === 'auto') return a\n if (element.css(a) === 'auto') return b\n \n var size_a = parseInt(element.css(a), 10),\n size_b = parseInt(element.css(b), 10)\n \n return size_a > size_b ? b : a\n }\n \n this.options.placement = horizontal > vertical ? ab('left', 'right') : ab('top', 'bottom')\n \n if (this.$element.css('visibility') === 'hidden !important') {\n this.$element.removeClass('in').css('visiblity', '')\n }\n }\n \n OffCanvas.prototype.opposite = function (placement) {\n switch (placement) {\n case 'top': return 'bottom'\n case 'left': return 'right'\n case 'bottom': return 'top'\n case 'right': return 'left'\n }\n }\n \n OffCanvas.prototype.getCanvasElements = function() {\n // Return a set containing the canvas plus all fixed elements\n var canvas = this.options.canvas ? $(this.options.canvas) : this.$element\n \n var fixed_elements = canvas.find('*').filter(function() {\n return $(this).css('position') === 'fixed'\n }).not(this.options.exclude)\n \n return canvas.add(fixed_elements)\n }\n \n OffCanvas.prototype.slide = function (elements, offset, callback) {\n // Use jQuery animation if CSS transitions aren't supported\n if (!$.support.transition) {\n var anim = {}\n anim[this.options.placement] = \"+=\" + offset\n return elements.animate(anim, 350, callback)\n }\n\n var placement = this.options.placement,\n opposite = this.opposite(placement)\n \n elements.each(function() {\n if ($(this).css(placement) !== 'auto')\n $(this).css(placement, (parseInt($(this).css(placement), 10) || 0) + offset)\n \n if ($(this).css(opposite) !== 'auto')\n $(this).css(opposite, (parseInt($(this).css(opposite), 10) || 0) - offset)\n })\n \n this.$element\n .one($.support.transition.end, callback)\n .emulateTransitionEnd(350)\n }\n\n OffCanvas.prototype.disableScrolling = function() {\n var bodyWidth = $('body').width()\n var prop = 'padding-' + this.opposite(this.options.placement)\n\n if ($('body').data('offcanvas-style') === undefined) $('body').data('offcanvas-style', $('body').attr('style'))\n \n $('body').css('overflow', 'hidden')\n\n if ($('body').width() > bodyWidth) {\n var padding = parseInt($('body').css(prop), 10) + $('body').width() - bodyWidth\n \n setTimeout(function() {\n $('body').css(prop, padding)\n }, 1)\n }\n }\n\n OffCanvas.prototype.show = function () {\n if (this.state) return\n \n var startEvent = $.Event('show.bs.offcanvas')\n this.$element.trigger(startEvent)\n if (startEvent.isDefaultPrevented()) return\n\n if (this.options.placement === 'auto') this.calcPlacement()\n\n this.state = 'sliding'\n\n var elements = this.getCanvasElements()\n var offset = this.offset(),\n placement = this.options.placement,\n opposite = this.opposite(placement)\n\n elements.addClass('canvas-sliding').each(function() {\n $(this).data('offcanvas-style', $(this).attr('style') || '')\n if ($(this).css('position') === 'static') $(this).css('position', 'relative')\n if ($(this).css(placement) === 'auto' && $(this).css(opposite) === 'auto') $(this).css(placement, 0)\n })\n \n if (elements.index(this.$element) !== -1) this.$element.css(placement, -1 * offset)\n\n this.disableScrolling()\n \n var complete = function () {\n this.state = 'slid'\n\n elements.removeClass('canvas-sliding').addClass('canvas-slid')\n this.$element.trigger('shown.bs.offcanvas')\n }\n\n setTimeout($.proxy(function() {\n this.$element.addClass('in')\n this.slide(elements, offset, $.proxy(complete, this))\n }, this), 1)\n }\n\n OffCanvas.prototype.hide = function (fast) {\n if (this.state !== 'slid') return\n\n var startEvent = $.Event('hide.bs.offcanvas')\n this.$element.trigger(startEvent)\n if (startEvent.isDefaultPrevented()) return\n\n this.state = 'sliding'\n\n var elements = $('.canvas-slid')\n var offset = -1 * this.offset()\n\n var complete = function () {\n this.state = null\n\n this.$element.removeClass('in')\n \n elements.removeClass('canvas-sliding')\n elements.add('body').each(function() {\n $(this).attr('style', $(this).data('offcanvas-style')).removeData('offcanvas-style')\n })\n\n this.$element.trigger('hidden.bs.offcanvas')\n }\n\n elements.removeClass('canvas-slid').addClass('canvas-sliding')\n \n setTimeout($.proxy(function() {\n this.slide(elements, offset, $.proxy(complete, this))\n }, this), 1)\n }\n\n OffCanvas.prototype.toggle = function () {\n if (this.state === 'sliding') return\n this[this.state === 'slid' ? 'hide' : 'show']()\n }\n\n OffCanvas.prototype.calcClone = function() {\n this.$calcClone = this.$element.clone()\n .html('')\n .addClass('offcanvas-clone').removeClass('in')\n .appendTo($('body'))\n }\n\n OffCanvas.prototype.recalc = function () {\n if (this.state() !== 'slid' || this.$calcClone.css('display') === 'none') return\n \n var offset = -1 * this.offset()\n \n var placement = this.options.placement\n this.getCanvasElements().each(function() {\n $(this).css(placement, (parseInt($(this).css(placement), 10) || 0) + offset)\n }).removeClass('canvas-slid')\n \n $('body').css('overflow', '')\n this.$element.css(placement, '').removeClass('in canvas-slid')\n }\n \n OffCanvas.prototype.autohide = function (e) {\n if ($(e.target).closest(this.$element).length === 0) this.hide()\n }\n\n // OFFCANVAS PLUGIN DEFINITION\n // ==========================\n\n var old = $.fn.offcanvas\n\n $.fn.offcanvas = function (option) {\n return this.each(function () {\n var $this = $(this)\n var data = $this.data('bs.offcanvas')\n var options = $.extend({}, OffCanvas.DEFAULTS, $this.data(), typeof option == 'object' && option)\n\n if (!data) $this.data('bs.offcanvas', (data = new OffCanvas(this, options)))\n if (typeof option == 'string') data[option]()\n })\n }\n\n $.fn.offcanvas.Constructor = OffCanvas\n\n\n // OFFCANVAS NO CONFLICT\n // ====================\n\n $.fn.offcanvas.noConflict = function () {\n $.fn.offcanvas = old\n return this\n }\n\n\n // OFFCANVAS DATA-API\n // =================\n\n $(document).on('click.bs.offcanvas.data-api', '[data-toggle=offcanvas]', function (e) {\n var $this = $(this), href\n var target = $this.attr('data-target')\n || e.preventDefault()\n || (href = $this.attr('href')) && href.replace(/.*(?=#[^\\s]+$)/, '') //strip for ie7\n var $canvas = $(target)\n var data = $canvas.data('bs.offcanvas')\n var option = data ? 'toggle' : $this.data()\n\n e.stopPropagation()\n\n if (data) data.toggle()\n else $canvas.offcanvas(option)\n })\n\n}(window.jQuery);\n","rowlink.js":"/* ============================================================\n * Bootstrap: rowlink.js v3.0.0-p7\n * http://jasny.github.io/bootstrap/javascript.html#rowlink\n * ============================================================\n * Copyright 2012 Jasny BV, Netherlands.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * ============================================================ */\n\n+function ($) { \"use strict\";\n\n var Rowlink = function (element, options) {\n this.$element = $(element)\n this.options = $.extend({}, Rowlink.DEFAULTS, options)\n \n this.$element.on('click.bs.rowlink', 'td:not(.rowlink-skip)', $.proxy(this.click, this))\n }\n\n Rowlink.DEFAULTS = {\n target: \"a\"\n }\n\n Rowlink.prototype.click = function(e) {\n var target = $(e.currentTarget).closest('tr').find(this.options.target)[0]\n if ($(e.target)[0] === target) return\n \n e.preventDefault();\n \n if (target.click) {\n target.click()\n } else if (document.createEvent) {\n var evt = document.createEvent(\"MouseEvents\"); \n evt.initMouseEvent(\"click\", true, true, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null); \n target.dispatchEvent(evt);\n }\n }\n\n \n // ROWLINK PLUGIN DEFINITION\n // ===========================\n\n var old = $.fn.rowlink\n\n $.fn.rowlink = function (options) {\n return this.each(function () {\n var $this = $(this)\n var data = $this.data('rowlink')\n if (!data) $this.data('rowlink', (data = new Rowlink(this, options)))\n })\n }\n\n $.fn.rowlink.Constructor = Rowlink\n\n\n // ROWLINK NO CONFLICT\n // ====================\n\n $.fn.rowlink.noConflict = function () {\n $.fn.rowlink = old\n return this\n }\n\n\n // ROWLINK DATA-API\n // ==================\n\n $(document).on('click.bs.rowlink.data-api', '[data-link=\"row\"]', function (e) {\n var $this = $(this)\n if ($this.data('rowlink')) return\n $this.rowlink($this.data())\n $(e.target).trigger('click.bs.rowlink')\n })\n \n}(window.jQuery);\n"} -var __less = {"alerts-fixed.less":"// Fixed alerts\n//\n// Position to the top or bottom.\n\n.alert-fixed-top,\n.alert-fixed-bottom {\n position: fixed;\n width: 100%;\n z-index: @zindex-alert-fixed;\n border-radius: 0;\n margin: 0;\n left: 0;\n\n @media (min-width: @alert-fixed-width) {\n width: @alert-fixed-width;\n left: 50%;\n margin-left: (-1 * (@alert-fixed-width / 2));\n }\n}\n\n.alert-fixed-top {\n top: 0;\n border-width: 0 0 1px 0;\n \n @media (min-width: @alert-fixed-width) {\n .border-bottom-radius(@alert-border-radius);\n border-width: 0 1px 1px 1px;\n }\n}\n\n.alert-fixed-bottom {\n bottom: 0;\n border-width: 1px 0 0 0;\n \n @media (min-width: @alert-fixed-width) {\n .border-top-radius(@alert-border-radius);\n border-width: 1px 1px 0 1px;\n }\n}\n","button-labels.less":"// Labels for buttons\n// --------------------------------------------------\n\n// Mixin\n.button-label-size(@padding-vertical; @padding-horizontal; @border-radius) {\n padding: @padding-vertical @padding-horizontal;\n left: (-1 * @padding-horizontal);\n border-radius: (@border-radius - 1px) 0 0 (@border-radius - 1px);\n\n &.btn-label-right {\n left: auto;\n right: (-1 * @padding-horizontal);\n border-radius: 0 (@border-radius - 1px) (@border-radius - 1px) 0;\n }\n}\n\n.btn-labeled {\n padding-top: 0;\n padding-bottom: 0;\n}\n\n.btn-label {\n position: relative;\n background: transparent;\n background: rgba(0, 0, 0, 0.15);\n display: inline-block;\n .button-label-size(@padding-base-vertical; @padding-base-horizontal; @border-radius-base);\n}\n\n.btn-lg .btn-label {\n .button-label-size(@padding-large-vertical; @padding-large-horizontal; @border-radius-large);\n}\n.btn-sm .btn-label {\n .button-label-size(@padding-small-vertical; @padding-small-horizontal; @border-radius-small);\n}\n.btn-xs .btn-label {\n .button-label-size(1px; 5px; @border-radius-small);\n}\n","fileinput.less":"// Fileinput.less\n// CSS for file upload button and fileinput widget\n// ------------------------------------------------\n\n.btn-file {\n overflow: hidden;\n position: relative;\n vertical-align: middle;\n > input {\n position: absolute;\n top: 0;\n right: 0;\n margin: 0;\n opacity: 0;\n filter: alpha(opacity=0);\n transform: translate(-300px, 0) scale(4);\n font-size: 23px;\n direction: ltr;\n cursor: pointer;\n }\n}\n\n.fileinput {\n margin-bottom: 9px;\n display: inline-block;\n .uneditable-input {\n display: inline-block;\n margin-bottom: 0px;\n vertical-align: middle;\n cursor: text;\n }\n .thumbnail {\n overflow: hidden;\n display: inline-block;\n margin-bottom: 5px;\n vertical-align: middle;\n text-align: center;\n > img {\n max-height: 100%;\n }\n }\n .btn {\n vertical-align: middle;\n }\n}\n.fileinput-exists .fileinput-new,\n.fileinput-new .fileinput-exists {\n display: none;\n}\n.fileinput-inline .fileinput-controls {\n display: inline;\n}\n\n.fileinput .uneditable-input {\n white-space: normal;\n}\n\n// Not 100% correct, but helps in typical use case\n.fileinput-new .input-group .btn-file {\n border-radius: 0 @border-radius-base @border-radius-base 0;\n}\n.fileinput-new .input-group .btn-file.btn-xs,\n.fileinput-new .input-group .btn-file.btn-sm {\n border-radius: 0 @border-radius-small @border-radius-small 0;\n}\n.fileinput-new .input-group .btn-file.btn-lg {\n border-radius: 0 @border-radius-large @border-radius-large 0;\n}\n\n.form-group.has-warning .fileinput {\n .uneditable-input {\n color: @state-warning-text;\n border-color: @state-warning-border;\n }\n .fileinput-preview {\n color: @state-warning-text;\n }\n .thumbnail {\n border-color: @state-warning-border;\n }\n}\n.form-group.has-error .fileinput {\n .uneditable-input {\n color: @state-danger-text;\n border-color: @state-danger-border;\n }\n .fileinput-preview {\n color: @state-danger-text;\n }\n .thumbnail {\n border-color: @state-danger-border;\n }\n}\n.form-group.has-success .fileinput {\n .uneditable-input {\n color: @state-success-text;\n border-color: @state-success-border;\n }\n .fileinput-preview {\n color: @state-success-text;\n }\n .thumbnail {\n border-color: @state-success-border;\n }\n}\n\n\n// Input group fixes\n\n.input-group-addon:not(:first-child) {\n border-left: 0;\n}\n","grid-container-smooth.less":"// Smooth sizing container\n// -------------------------\n\n@media (min-width: 1px) {\n .container-smooth {\n max-width: @container-lg;\n }\n}\n\n","jasny-bootstrap.less":"/*!\n * Jasny extension p7 to Bootstrap v3.0.0\n *\n * Copyright 2013 Twitter, Inc\n * Licensed under the Apache License v2.0\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Designed and built with all the love in the world by @mdo and @fat.\n */\n\n// Core variables and mixins\n@import \"variables.less\";\n@import \"mixins.less\";\n\n// Core CSS\n@import \"grid-container-smooth.less\";\n@import \"button-labels.less\";\n\n// Components\n@import \"nav-tab-alignment.less\";\n@import \"navmenu.less\";\n@import \"alerts-fixed.less\";\n\n// Components w/ JavaScript\n@import \"offcanvas.less\";\n@import \"rowlink.less\";\n@import \"fileinput.less\";\n","mixins.less":"//\n// Mixins\n// --------------------------------------------------\n\n\n// Utilities\n// -------------------------\n\n// Clearfix\n// Source: http://nicolasgallagher.com/micro-clearfix-hack/\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.clearfix() {\n &:before,\n &:after {\n content: \" \"; /* 1 */\n display: table; /* 2 */\n }\n &:after {\n clear: both;\n }\n}\n\n// WebKit-style focus\n.tab-focus() {\n // Default\n outline: thin dotted #333;\n // WebKit\n outline: 5px auto -webkit-focus-ring-color;\n outline-offset: -2px;\n}\n\n// Center-align a block level element\n.center-block() {\n display: block;\n margin-left: auto;\n margin-right: auto;\n}\n\n// Sizing shortcuts\n.size(@width; @height) {\n width: @width;\n height: @height;\n}\n.square(@size) {\n .size(@size; @size);\n}\n\n// Placeholder text\n.placeholder(@color: @input-color-placeholder) {\n &:-moz-placeholder { color: @color; } // Firefox 4-18\n &::-moz-placeholder { color: @color; } // Firefox 19+\n &:-ms-input-placeholder { color: @color; } // Internet Explorer 10+\n &::-webkit-input-placeholder { color: @color; } // Safari and Chrome\n}\n\n// Text overflow\n// Requires inline-block or block for proper styling\n.text-overflow() {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n\n// CSS image replacement\n//\n// Heads up! v3 launched with with only `.hide-text()`, but per our pattern for\n// mixins being reused as classes with the same name, this doesn't hold up. As\n// of v3.0.1 we have added `.text-hide()` and deprecated `.hide-text()`. Note\n// that we cannot chain the mixins together in Less, so they are repeated.\n//\n// Source: https://github.com/h5bp/html5-boilerplate/commit/aa0396eae757\n\n// Deprecated as of v3.0.1 (will be removed in v4)\n.hide-text() {\n font: ~\"0/0\" a;\n color: transparent;\n text-shadow: none;\n background-color: transparent;\n border: 0;\n}\n// New mixin to use as of v3.0.1\n.text-hide() {\n font: ~\"0/0\" a;\n color: transparent;\n text-shadow: none;\n background-color: transparent;\n border: 0;\n}\n\n\n\n// CSS3 PROPERTIES\n// --------------------------------------------------\n\n// Single side border-radius\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// Drop shadows\n.box-shadow(@shadow) {\n -webkit-box-shadow: @shadow; // iOS <4.3 & Android <4.1\n box-shadow: @shadow;\n}\n\n// Transitions\n.transition(@transition) {\n -webkit-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-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// Transformations\n.rotate(@degrees) {\n -webkit-transform: rotate(@degrees);\n -ms-transform: rotate(@degrees); // IE9+\n transform: rotate(@degrees);\n}\n.scale(@ratio) {\n -webkit-transform: scale(@ratio);\n -ms-transform: scale(@ratio); // IE9+\n transform: scale(@ratio);\n}\n.translate(@x; @y) {\n -webkit-transform: translate(@x, @y);\n -ms-transform: translate(@x, @y); // IE9+\n transform: translate(@x, @y);\n}\n.skew(@x; @y) {\n -webkit-transform: skew(@x, @y);\n -ms-transform: skewX(@x) skewY(@y); // See https://github.com/twbs/bootstrap/issues/4885; IE9+\n transform: skew(@x, @y);\n}\n.translate3d(@x; @y; @z) {\n -webkit-transform: translate3d(@x, @y, @z);\n transform: translate3d(@x, @y, @z);\n}\n\n.rotateX(@degrees) {\n -webkit-transform: rotateX(@degrees);\n -ms-transform: rotateX(@degrees); // IE9+\n transform: rotateX(@degrees);\n}\n.rotateY(@degrees) {\n -webkit-transform: rotateY(@degrees);\n -ms-transform: rotateY(@degrees); // IE9+\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 transform-origin: @origin;\n}\n\n// Animations\n.animation(@animation) {\n -webkit-animation: @animation;\n animation: @animation;\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.backface-visibility(@visibility){\n -webkit-backface-visibility: @visibility;\n -moz-backface-visibility: @visibility;\n backface-visibility: @visibility;\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// User select\n// For selecting text on the page\n.user-select(@select) {\n -webkit-user-select: @select;\n -moz-user-select: @select;\n -ms-user-select: @select; // IE10+\n -o-user-select: @select;\n user-select: @select;\n}\n\n// Resize anything\n.resizable(@direction) {\n resize: @direction; // Options: horizontal, vertical, both\n overflow: auto; // Safari fix\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// Opacity\n.opacity(@opacity) {\n opacity: @opacity;\n // IE8 filter\n @opacity-ie: (@opacity * 100);\n filter: ~\"alpha(opacity=@{opacity-ie})\";\n}\n\n\n\n// GRADIENTS\n// --------------------------------------------------\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-gradient(linear, @start-percent top, @end-percent top, from(@start-color), to(@end-color)); // Safari 4+, Chrome 2+\n background-image: -webkit-linear-gradient(left, color-stop(@start-color @start-percent), color-stop(@end-color @end-percent)); // Safari 5.1+, Chrome 10+\n background-image: -moz-linear-gradient(left, @start-color @start-percent, @end-color @end-percent); // FF 3.6+\n background-image: linear-gradient(to right, @start-color @start-percent, @end-color @end-percent); // Standard, IE10\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-gradient(linear, left @start-percent, left @end-percent, from(@start-color), to(@end-color)); // Safari 4+, Chrome 2+\n background-image: -webkit-linear-gradient(top, @start-color @start-percent, @end-color @end-percent); // Safari 5.1+, Chrome 10+\n background-image: -moz-linear-gradient(top, @start-color @start-percent, @end-color @end-percent); // FF 3.6+\n background-image: linear-gradient(to bottom, @start-color @start-percent, @end-color @end-percent); // Standard, IE10\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+, Chrome 10+\n background-image: -moz-linear-gradient(@deg, @start-color, @end-color); // FF 3.6+\n background-image: linear-gradient(@deg, @start-color, @end-color); // Standard, IE10\n }\n .horizontal-three-colors(@start-color: #00b3ee; @mid-color: #7a43b6; @color-stop: 50%; @end-color: #c3325f) {\n background-image: -webkit-gradient(left, linear, 0 0, 0 100%, from(@start-color), color-stop(@color-stop, @mid-color), to(@end-color));\n background-image: -webkit-linear-gradient(left, @start-color, @mid-color @color-stop, @end-color);\n background-image: -moz-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-gradient(linear, 0 0, 0 100%, from(@start-color), color-stop(@color-stop, @mid-color), to(@end-color));\n background-image: -webkit-linear-gradient(@start-color, @mid-color @color-stop, @end-color);\n background-image: -moz-linear-gradient(top, @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-gradient(radial, center center, 0, center center, 460, from(@inner-color), to(@outer-color));\n background-image: -webkit-radial-gradient(circle, @inner-color, @outer-color);\n background-image: -moz-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-gradient(linear, 0 100%, 100% 0, color-stop(.25, @color), color-stop(.25, transparent), color-stop(.5, transparent), color-stop(.5, @color), color-stop(.75, @color), color-stop(.75, transparent), to(transparent));\n background-image: -webkit-linear-gradient(@angle, @color 25%, transparent 25%, transparent 50%, @color 50%, @color 75%, transparent 75%, transparent);\n background-image: -moz-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\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.reset-filter() {\n filter: e(%(\"progid:DXImageTransform.Microsoft.gradient(enabled = false)\"));\n}\n\n\n\n// Retina images\n//\n// Short retina mixin for setting background-image and -size\n\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\n// Responsive image\n//\n// Keep images from scaling beyond the width of their parents.\n\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// COMPONENT MIXINS\n// --------------------------------------------------\n\n// Horizontal dividers\n// -------------------------\n// Dividers (basically an hr) within dropdowns and nav lists\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\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 & > .dropdown .caret {\n border-color: @heading-text-color transparent;\n }\n }\n & > .panel-footer {\n + .panel-collapse .panel-body {\n border-bottom-color: @border;\n }\n }\n}\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// Tables\n// -------------------------\n.table-row-variant(@state; @background; @border) {\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 &.@{state}:hover > th {\n background-color: darken(@background, 5%);\n }\n }\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.button-variant(@color; @background; @border) {\n color: @color;\n background-color: @background;\n border-color: @border;\n\n &:hover,\n &:focus,\n &:active,\n &.active,\n .open .dropdown-toggle& {\n color: @color;\n background-color: darken(@background, 8%);\n border-color: darken(@border, 12%);\n }\n &:active,\n &.active,\n .open .dropdown-toggle& {\n background-image: none;\n }\n &.disabled,\n &[disabled],\n fieldset[disabled] & {\n &,\n &:hover,\n &:focus,\n &:active,\n &.active {\n background-color: @background;\n border-color: @border;\n }\n }\n}\n\n// Button sizes\n// -------------------------\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\n// Pagination\n// -------------------------\n.pagination-size(@padding-vertical; @padding-horizontal; @font-size; @border-radius) {\n > li {\n > a,\n > span {\n padding: @padding-vertical @padding-horizontal;\n font-size: @font-size;\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// Labels\n// -------------------------\n.label-variant(@color) {\n background-color: @color;\n &[href] {\n &:hover,\n &:focus {\n background-color: darken(@color, 10%);\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.navbar-vertical-align(@element-height) {\n margin-top: ((@navbar-height - @element-height) / 2);\n margin-bottom: ((@navbar-height - @element-height) / 2);\n}\n\n// Progress bars\n// -------------------------\n.progress-bar-variant(@color) {\n background-color: @color;\n .progress-striped & {\n #gradient > .striped();\n }\n}\n\n// Responsive utilities\n// -------------------------\n// More easily include all the states for responsive-utilities.less.\n.responsive-visibility() {\n display: block !important;\n tr& { display: table-row !important; }\n th&,\n td& { display: table-cell !important; }\n}\n\n.responsive-invisibility() {\n &,\n tr&,\n th&,\n td& { display: none !important; }\n}\n\n\n// Grid System\n// -----------\n\n// Centered container element\n.container-fixed() {\n margin-right: auto;\n margin-left: auto;\n padding-left: (@grid-gutter-width / 2);\n padding-right: (@grid-gutter-width / 2);\n .clearfix();\n}\n\n// Creates a wrapper for a series of columns\n.make-row(@gutter: @grid-gutter-width) {\n margin-left: (@gutter / -2);\n margin-right: (@gutter / -2);\n .clearfix();\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 // Prevent columns from collapsing when empty\n min-height: 1px;\n // Inner gutter via padding\n padding-left: (@gutter / 2);\n padding-right: (@gutter / 2);\n}\n\n// Generate the small columns\n.make-sm-column(@columns; @gutter: @grid-gutter-width) {\n position: relative;\n // Prevent columns from collapsing when empty\n min-height: 1px;\n // Inner gutter via padding\n padding-left: (@gutter / 2);\n padding-right: (@gutter / 2);\n\n // Calculate width based on number of columns available\n @media (min-width: @screen-sm-min) {\n float: left;\n width: percentage((@columns / @grid-columns));\n }\n}\n\n// Generate the small column offsets\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 // Prevent columns from collapsing when empty\n min-height: 1px;\n // Inner gutter via padding\n padding-left: (@gutter / 2);\n padding-right: (@gutter / 2);\n\n // Calculate width based on number of columns available\n @media (min-width: @screen-md-min) {\n float: left;\n width: percentage((@columns / @grid-columns));\n }\n}\n\n// Generate the medium column offsets\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) {\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 // Prevent columns from collapsing when empty\n min-height: 1px;\n // Inner gutter via padding\n padding-left: (@gutter / 2);\n padding-right: (@gutter / 2);\n\n // Calculate width based on number of columns available\n @media (min-width: @screen-lg-min) {\n float: left;\n width: percentage((@columns / @grid-columns));\n }\n}\n\n// Generate the large column offsets\n.make-lg-column-offset(@columns) {\n @media (min-width: @screen-lg-min) {\n margin-left: percentage((@columns / @grid-columns));\n }\n}\n.make-lg-column-push(@columns) {\n @media (min-width: @screen-lg-min) {\n left: percentage((@columns / @grid-columns));\n }\n}\n.make-lg-column-pull(@columns) {\n @media (min-width: @screen-lg-min) {\n right: percentage((@columns / @grid-columns));\n }\n}\n\n\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) when (@index = 1) { // initial\n @item: ~\".col-xs-@{index}, .col-sm-@{index}, .col-md-@{index}, .col-lg-@{index}\";\n .col(@index + 1, @item);\n }\n .col(@index, @list) when (@index =< @grid-columns) { // general; \"=<\" isn't a typo\n @item: ~\".col-xs-@{index}, .col-sm-@{index}, .col-md-@{index}, .col-lg-@{index}\";\n .col(@index + 1, ~\"@{list}, @{item}\");\n }\n .col(@index, @list) when (@index > @grid-columns) { // terminal\n @{list} {\n position: relative;\n // Prevent columns from collapsing when empty\n min-height: 1px;\n // Inner gutter via padding\n padding-left: (@grid-gutter-width / 2);\n padding-right: (@grid-gutter-width / 2);\n }\n }\n .col(1); // kickstart it\n}\n\n.make-grid-columns-float(@class) {\n .col(@index) when (@index = 1) { // 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(@index, @class, @type) when (@type = width) {\n .col-@{class}-@{index} {\n width: percentage((@index / @grid-columns));\n }\n}\n.calc-grid(@index, @class, @type) when (@type = push) {\n .col-@{class}-push-@{index} {\n left: percentage((@index / @grid-columns));\n }\n}\n.calc-grid(@index, @class, @type) when (@type = pull) {\n .col-@{class}-pull-@{index} {\n right: percentage((@index / @grid-columns));\n }\n}\n.calc-grid(@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.make-grid(@index, @class, @type) when (@index > 0) {\n .calc-grid(@index, @class, @type);\n // next iteration\n .make-grid(@index - 1, @class, @type);\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 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}\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-focus-border` 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\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. `')\n this.$element.prepend(this.$hidden)\n }\n\n this.$preview = this.$element.find('.fileinput-preview')\n var height = this.$preview.css('height')\n if (this.$preview.css('display') != 'inline' && height != '0px' && height != 'none') this.$preview.css('line-height', height)\n\n this.original = {\n exists: this.$element.hasClass('fileinput-exists'),\n preview: this.$preview.html(),\n hiddenVal: this.$hidden.val()\n }\n \n this.listen()\n }\n \n Fileinput.prototype.listen = function() {\n this.$input.on('change.bs.fileinput', $.proxy(this.change, this))\n $(this.$input[0].form).on('reset.bs.fileinput', $.proxy(this.reset, this))\n \n this.$element.find('[data-trigger=\"fileinput\"]').on('click.bs.fileinput', $.proxy(this.trigger, this))\n this.$element.find('[data-dismiss=\"fileinput\"]').on('click.bs.fileinput', $.proxy(this.clear, this))\n },\n\n Fileinput.prototype.change = function(e) {\n if (e.target.files === undefined) e.target.files = e.target && e.target.value ? [ {name: e.target.value.replace(/^.+\\\\/, '')} ] : []\n if (e.target.files.length === 0) return\n\n this.$hidden.val('')\n this.$hidden.attr('name', '')\n this.$input.attr('name', this.name)\n\n var file = e.target.files[0]\n\n if (this.$preview.length > 0 && (typeof file.type !== \"undefined\" ? file.type.match('image.*') : file.name.match(/\\.(gif|png|jpe?g)$/i)) && typeof FileReader !== \"undefined\") {\n var reader = new FileReader()\n var preview = this.$preview\n var element = this.$element\n\n reader.onload = function(re) {\n var $img = $('') // .attr('src', re.target.result)\n $img[0].src = re.target.result\n e.target.files[0].result = re.target.result\n \n element.find('.fileinput-filename').text(file.name)\n \n // if parent has max-height, using `(max-)height: 100%` on child doesn't take padding and border into account\n if (preview.css('max-height') != 'none') $img.css('max-height', parseInt(preview.css('max-height'), 10) - parseInt(preview.css('padding-top'), 10) - parseInt(preview.css('padding-bottom'), 10) - parseInt(preview.css('border-top'), 10) - parseInt(preview.css('border-bottom'), 10))\n \n preview.html($img)\n element.addClass('fileinput-exists').removeClass('fileinput-new')\n\n element.trigger('change.bs.fileinput', e.target.files)\n }\n\n reader.readAsDataURL(file)\n } else {\n this.$element.find('.fileinput-filename').text(file.name)\n this.$preview.text(file.name)\n \n this.$element.addClass('fileinput-exists').removeClass('fileinput-new')\n \n this.$element.trigger('change.bs.fileinput')\n }\n },\n\n Fileinput.prototype.clear = function(e) {\n if (e) e.preventDefault()\n \n this.$hidden.val('')\n this.$hidden.attr('name', this.name)\n this.$input.attr('name', '')\n\n //ie8+ doesn't support changing the value of input with type=file so clone instead\n if (isIE) { \n var inputClone = this.$input.clone(true);\n this.$input.after(inputClone);\n this.$input.remove();\n this.$input = inputClone;\n } else {\n this.$input.val('')\n }\n\n this.$preview.html('')\n this.$element.find('.fileinput-filename').text('')\n this.$element.addClass('fileinput-new').removeClass('fileinput-exists')\n \n if (e !== false) {\n this.$input.trigger('change')\n this.$element.trigger('clear.bs.fileinput')\n }\n },\n\n Fileinput.prototype.reset = function() {\n this.clear(false)\n\n this.$hidden.val(this.original.hiddenVal)\n this.$preview.html(this.original.preview)\n this.$element.find('.fileinput-filename').text('')\n\n if (this.original.exists) this.$element.addClass('fileinput-exists').removeClass('fileinput-new')\n else this.$element.addClass('fileinput-new').removeClass('fileinput-exists')\n \n this.$element.trigger('reset.bs.fileinput')\n },\n\n Fileinput.prototype.trigger = function(e) {\n this.$input.trigger('click')\n e.preventDefault()\n }\n\n \n // FILEUPLOAD PLUGIN DEFINITION\n // ===========================\n\n var old = $.fn.fileinput\n \n $.fn.fileinput = function (options) {\n return this.each(function () {\n var $this = $(this),\n data = $this.data('fileinput')\n if (!data) $this.data('fileinput', (data = new Fileinput(this, options)))\n if (typeof options == 'string') data[options]()\n })\n }\n\n $.fn.fileinput.Constructor = Fileinput\n\n\n // FILEINPUT NO CONFLICT\n // ====================\n\n $.fn.fileinput.noConflict = function () {\n $.fn.fileinput = old\n return this\n }\n\n\n // FILEUPLOAD DATA-API\n // ==================\n\n $(document).on('click.fileinput.data-api', '[data-provides=\"fileinput\"]', function (e) {\n var $this = $(this)\n if ($this.data('fileinput')) return\n $this.fileinput($this.data())\n \n var $target = $(e.target).closest('[data-dismiss=\"fileinput\"],[data-trigger=\"fileinput\"]');\n if ($target.length > 0) {\n e.preventDefault()\n $target.trigger('click.bs.fileinput')\n }\n })\n\n}(window.jQuery);\n","inputmask.js":"/* ===========================================================\n * Bootstrap: inputmask.js v3.0.0-p7\n * http://jasny.github.io/bootstrap/javascript.html#inputmask\n * Based on Masked Input plugin by Josh Bush (digitalbush.com)\n * ===========================================================\n * Copyright 2012 Jasny BV, Netherlands.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\")\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * ========================================================== */\n\n+function ($) { \"use strict\";\n\n var isIphone = (window.orientation !== undefined)\n var isAndroid = navigator.userAgent.toLowerCase().indexOf(\"android\") > -1\n var isIE = window.navigator.appName == 'Microsoft Internet Explorer'\n\n // INPUTMASK PUBLIC CLASS DEFINITION\n // =================================\n\n var Inputmask = function (element, options) {\n if (isAndroid) return // No support because caret positioning doesn't work on Android\n \n this.$element = $(element)\n this.options = $.extend({}, Inputmask.DEFAULS, options)\n this.mask = String(this.options.mask)\n \n this.init()\n this.listen()\n \n this.checkVal() //Perform initial check for existing values\n }\n\n Inputmask.DEFAULS = {\n mask: \"\",\n placeholder: \"_\",\n definitions: {\n '9': \"[0-9]\",\n 'a': \"[A-Za-z]\",\n '?': \"[A-Za-z0-9]\",\n '*': \".\"\n }\n }\n\n Inputmask.prototype.init = function() {\n var defs = this.options.definitions\n var len = this.mask.length\n\n this.tests = [] \n this.partialPosition = this.mask.length\n this.firstNonMaskPos = null\n\n $.each(this.mask.split(\"\"), $.proxy(function(i, c) {\n if (c == '?') {\n len--\n this.partialPosition = i\n } else if (defs[c]) {\n this.tests.push(new RegExp(defs[c]))\n if (this.firstNonMaskPos === null)\n this.firstNonMaskPos = this.tests.length - 1\n } else {\n this.tests.push(null)\n }\n }, this))\n\n this.buffer = $.map(this.mask.split(\"\"), $.proxy(function(c, i) {\n if (c != '?') return defs[c] ? this.options.placeholder : c\n }, this))\n\n this.focusText = this.$element.val()\n\n this.$element.data(\"rawMaskFn\", $.proxy(function() {\n return $.map(this.buffer, function(c, i) {\n return this.tests[i] && c != this.options.placeholder ? c : null\n }).join('')\n }, this))\n }\n \n Inputmask.prototype.listen = function() {\n if (this.$element.attr(\"readonly\")) return\n\n var pasteEventName = (isIE ? 'paste' : 'input') + \".mask\"\n\n this.$element\n .on(\"unmask.bs.inputmask\", $.proxy(this.unmask, this))\n\n .on(\"focus.bs.inputmask\", $.proxy(this.focusEvent, this))\n .on(\"blur.bs.inputmask\", $.proxy(this.blurEvent, this))\n\n .on(\"keydown.bs.inputmask\", $.proxy(this.keydownEvent, this))\n .on(\"keypress.bs.inputmask\", $.proxy(this.keypressEvent, this))\n\n .on(pasteEventName, $.proxy(this.pasteEvent, this))\n }\n\n //Helper Function for Caret positioning\n Inputmask.prototype.caret = function(begin, end) {\n if (this.$element.length === 0) return\n if (typeof begin == 'number') {\n end = (typeof end == 'number') ? end : begin\n return this.$element.each(function() {\n if (this.setSelectionRange) {\n this.setSelectionRange(begin, end)\n } else if (this.createTextRange) {\n var range = this.createTextRange()\n range.collapse(true)\n range.moveEnd('character', end)\n range.moveStart('character', begin)\n range.select()\n }\n })\n } else {\n if (this.$element[0].setSelectionRange) {\n begin = this.$element[0].selectionStart\n end = this.$element[0].selectionEnd\n } else if (document.selection && document.selection.createRange) {\n var range = document.selection.createRange()\n begin = 0 - range.duplicate().moveStart('character', -100000)\n end = begin + range.text.length\n }\n return {\n begin: begin, \n end: end\n }\n }\n }\n \n Inputmask.prototype.seekNext = function(pos) {\n var len = this.mask.length\n while (++pos <= len && !this.tests[pos]);\n\n return pos\n }\n \n Inputmask.prototype.seekPrev = function(pos) {\n while (--pos >= 0 && !this.tests[pos]);\n\n return pos\n }\n\n Inputmask.prototype.shiftL = function(begin,end) {\n var len = this.mask.length\n\n if (begin < 0) return\n\n for (var i = begin, j = this.seekNext(end); i < len; i++) {\n if (this.tests[i]) {\n if (j < len && this.tests[i].test(this.buffer[j])) {\n this.buffer[i] = this.buffer[j]\n this.buffer[j] = this.options.placeholder\n } else\n break\n j = this.seekNext(j)\n }\n }\n this.writeBuffer()\n this.caret(Math.max(this.firstNonMaskPos, begin))\n }\n\n Inputmask.prototype.shiftR = function(pos) {\n var len = this.mask.length\n\n for (var i = pos, c = this.options.placeholder; i < len; i++) {\n if (this.tests[i]) {\n var j = this.seekNext(i)\n var t = this.buffer[i]\n this.buffer[i] = c\n if (j < len && this.tests[j].test(t))\n c = t\n else\n break\n }\n }\n },\n\n Inputmask.prototype.unmask = function() {\n this.$element\n .unbind(\".mask\")\n .removeData(\"inputmask\")\n }\n\n Inputmask.prototype.focusEvent = function() {\n this.focusText = this.$element.val()\n var len = this.mask.length \n var pos = this.checkVal()\n this.writeBuffer()\n\n var that = this\n var moveCaret = function() {\n if (pos == len)\n that.caret(0, pos)\n else\n that.caret(pos)\n }\n\n moveCaret()\n setTimeout(moveCaret, 50)\n }\n\n Inputmask.prototype.blurEvent = function() {\n this.checkVal()\n if (this.$element.val() !== this.focusText)\n this.$element.trigger('change')\n }\n\n Inputmask.prototype.keydownEvent = function(e) {\n var k = e.which\n\n //backspace, delete, and escape get special treatment\n if (k == 8 || k == 46 || (isIphone && k == 127)) {\n var pos = this.caret(),\n begin = pos.begin,\n end = pos.end\n\n if (end - begin === 0) {\n begin = k != 46 ? this.seekPrev(begin) : (end = this.seekNext(begin - 1))\n end = k == 46 ? this.seekNext(end) : end\n }\n this.clearBuffer(begin, end)\n this.shiftL(begin, end - 1)\n\n return false\n } else if (k == 27) {//escape\n this.$element.val(this.focusText)\n this.caret(0, this.checkVal())\n return false\n }\n }\n\n Inputmask.prototype.keypressEvent = function(e) {\n var len = this.mask.length\n\n var k = e.which,\n pos = this.caret()\n\n if (e.ctrlKey || e.altKey || e.metaKey || k < 32) {//Ignore\n return true\n } else if (k) {\n if (pos.end - pos.begin !== 0) {\n this.clearBuffer(pos.begin, pos.end)\n this.shiftL(pos.begin, pos.end - 1)\n }\n\n var p = this.seekNext(pos.begin - 1)\n if (p < len) {\n var c = String.fromCharCode(k)\n if (this.tests[p].test(c)) {\n this.shiftR(p)\n this.buffer[p] = c\n this.writeBuffer()\n var next = this.seekNext(p)\n this.caret(next)\n }\n }\n return false\n }\n }\n\n Inputmask.prototype.pasteEvent = function() {\n var that = this\n\n setTimeout(function() {\n that.caret(that.checkVal(true))\n }, 0)\n }\n\n Inputmask.prototype.clearBuffer = function(start, end) {\n var len = this.mask.length\n\n for (var i = start; i < end && i < len; i++) {\n if (this.tests[i])\n this.buffer[i] = this.options.placeholder\n }\n }\n\n Inputmask.prototype.writeBuffer = function() {\n return this.$element.val(this.buffer.join('')).val()\n }\n\n Inputmask.prototype.checkVal = function(allow) {\n var len = this.mask.length\n //try to place characters where they belong\n var test = this.$element.val()\n var lastMatch = -1\n\n for (var i = 0, pos = 0; i < len; i++) {\n if (this.tests[i]) {\n this.buffer[i] = this.options.placeholder\n while (pos++ < test.length) {\n var c = test.charAt(pos - 1)\n if (this.tests[i].test(c)) {\n this.buffer[i] = c\n lastMatch = i\n break\n }\n }\n if (pos > test.length)\n break\n } else if (this.buffer[i] == test.charAt(pos) && i != this.partialPosition) {\n pos++\n lastMatch = i\n }\n }\n if (!allow && lastMatch + 1 < this.partialPosition) {\n this.$element.val(\"\")\n this.clearBuffer(0, len)\n } else if (allow || lastMatch + 1 >= this.partialPosition) {\n this.writeBuffer()\n if (!allow) this.$element.val(this.$element.val().substring(0, lastMatch + 1))\n }\n return (this.partialPosition ? i : this.firstNonMaskPos)\n }\n\n \n // INPUTMASK PLUGIN DEFINITION\n // ===========================\n\n var old = $.fn.inputmask\n \n $.fn.inputmask = function (options) {\n return this.each(function () {\n var $this = $(this)\n var data = $this.data('inputmask')\n \n if (!data) $this.data('inputmask', (data = new Inputmask(this, options)))\n })\n }\n\n $.fn.inputmask.Constructor = Inputmask\n\n\n // INPUTMASK NO CONFLICT\n // ====================\n\n $.fn.inputmask.noConflict = function () {\n $.fn.inputmask = old\n return this\n }\n\n\n // INPUTMASK DATA-API\n // ==================\n\n $(document).on('focus.bs.inputmask.data-api', '[data-mask]', function (e) {\n var $this = $(this)\n if ($this.data('inputmask')) return\n $this.inputmask($this.data())\n })\n\n}(window.jQuery);\n","offcanvas.js":"/* ========================================================================\n * Bootstrap: offcanvas.js v3.0.3-p7\n * http://jasny.github.io/bootstrap/javascript.html#offcanvas\n * \n * Based on Boostrap collapse.js by Twitter, Inc. \n * ========================================================================\n * Copyright 2013 Jasny, BV.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\")\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * ======================================================================== */\n\n+function ($) { \"use strict\";\n\n // OFFCANVAS PUBLIC CLASS DEFINITION\n // =================================\n\n var OffCanvas = function (element, options) {\n this.$element = $(element)\n this.options = $.extend({}, OffCanvas.DEFAULTS, options)\n this.state = null\n \n if (this.options.recalc) {\n this.calcClone()\n $(window).on('resize', $.proxy(this.recalc, this))\n }\n \n if (this.options.autohide)\n $(document).on('click', $.proxy(this.autohide, this))\n\n if (this.options.toggle) this.toggle()\n }\n\n OffCanvas.DEFAULTS = {\n toggle: true,\n placement: 'left',\n autohide: true,\n recalc: true\n }\n\n OffCanvas.prototype.offset = function () {\n switch (this.options.placement) {\n case 'left':\n case 'right': return this.$element.outerWidth()\n case 'top':\n case 'bottom': return this.$element.outerHeight()\n }\n }\n \n OffCanvas.prototype.calcPlacement = function () {\n var horizontal = $(window).width() / this.$element.width(),\n vertical = $(window).height() / this.$element.height()\n \n if (!this.$element.hasClass('in')) {\n this.$element.css('visiblity', 'hidden !important').addClass('in')\n } \n \n var element = this.$element\n function ab(a, b) {\n if (element.css(b) === 'auto') return a\n if (element.css(a) === 'auto') return b\n \n var size_a = parseInt(element.css(a), 10),\n size_b = parseInt(element.css(b), 10)\n \n return size_a > size_b ? b : a\n }\n \n this.options.placement = horizontal > vertical ? ab('left', 'right') : ab('top', 'bottom')\n \n if (this.$element.css('visibility') === 'hidden !important') {\n this.$element.removeClass('in').css('visiblity', '')\n }\n }\n \n OffCanvas.prototype.opposite = function (placement) {\n switch (placement) {\n case 'top': return 'bottom'\n case 'left': return 'right'\n case 'bottom': return 'top'\n case 'right': return 'left'\n }\n }\n \n OffCanvas.prototype.getCanvasElements = function() {\n // Return a set containing the canvas plus all fixed elements\n var canvas = this.options.canvas ? $(this.options.canvas) : this.$element\n \n var fixed_elements = canvas.find('*').filter(function() {\n return $(this).css('position') === 'fixed'\n }).not(this.options.exclude)\n \n return canvas.add(fixed_elements)\n }\n \n OffCanvas.prototype.slide = function (elements, offset, callback) {\n // Use jQuery animation if CSS transitions aren't supported\n if (!$.support.transition) {\n var anim = {}\n anim[this.options.placement] = \"+=\" + offset\n return elements.animate(anim, 350, callback)\n }\n\n var placement = this.options.placement,\n opposite = this.opposite(placement)\n \n elements.each(function() {\n if ($(this).css(placement) !== 'auto')\n $(this).css(placement, (parseInt($(this).css(placement), 10) || 0) + offset)\n \n if ($(this).css(opposite) !== 'auto')\n $(this).css(opposite, (parseInt($(this).css(opposite), 10) || 0) - offset)\n })\n \n this.$element\n .one($.support.transition.end, callback)\n .emulateTransitionEnd(350)\n }\n\n OffCanvas.prototype.disableScrolling = function() {\n var bodyWidth = $('body').width()\n var prop = 'padding-' + this.opposite(this.options.placement)\n\n if ($('body').data('offcanvas-style') === undefined) $('body').data('offcanvas-style', $('body').attr('style'))\n \n $('body').css('overflow', 'hidden')\n\n if ($('body').width() > bodyWidth) {\n var padding = parseInt($('body').css(prop), 10) + $('body').width() - bodyWidth\n \n setTimeout(function() {\n $('body').css(prop, padding)\n }, 1)\n }\n }\n\n OffCanvas.prototype.show = function () {\n if (this.state) return\n \n var startEvent = $.Event('show.bs.offcanvas')\n this.$element.trigger(startEvent)\n if (startEvent.isDefaultPrevented()) return\n\n if (this.options.placement === 'auto') this.calcPlacement()\n\n this.state = 'sliding'\n\n var elements = this.getCanvasElements()\n var offset = this.offset(),\n placement = this.options.placement,\n opposite = this.opposite(placement)\n\n elements.addClass('canvas-sliding').each(function() {\n $(this).data('offcanvas-style', $(this).attr('style') || '')\n if ($(this).css('position') === 'static') $(this).css('position', 'relative')\n if (($(this).css(placement) === 'auto' || $(this).css(placement) === '0px') &&\n ($(this).css(opposite) === 'auto' || $(this).css(opposite) === '0px')) {\n $(this).css(placement, 0)\n }\n })\n \n if (elements.index(this.$element) !== -1) this.$element.css(placement, -1 * offset)\n\n this.disableScrolling()\n \n var complete = function () {\n this.state = 'slid'\n\n elements.removeClass('canvas-sliding').addClass('canvas-slid')\n this.$element.trigger('shown.bs.offcanvas')\n }\n\n setTimeout($.proxy(function() {\n this.$element.addClass('in')\n this.slide(elements, offset, $.proxy(complete, this))\n }, this), 1)\n }\n\n OffCanvas.prototype.hide = function (fast) {\n if (this.state !== 'slid') return\n\n var startEvent = $.Event('hide.bs.offcanvas')\n this.$element.trigger(startEvent)\n if (startEvent.isDefaultPrevented()) return\n\n this.state = 'sliding'\n\n var elements = $('.canvas-slid')\n var offset = -1 * this.offset()\n\n var complete = function () {\n this.state = null\n\n this.$element.removeClass('in')\n \n elements.removeClass('canvas-sliding')\n elements.add('body').each(function() {\n $(this).attr('style', $(this).data('offcanvas-style')).removeData('offcanvas-style')\n })\n\n this.$element.trigger('hidden.bs.offcanvas')\n }\n\n elements.removeClass('canvas-slid').addClass('canvas-sliding')\n \n setTimeout($.proxy(function() {\n this.slide(elements, offset, $.proxy(complete, this))\n }, this), 1)\n }\n\n OffCanvas.prototype.toggle = function () {\n if (this.state === 'sliding') return\n this[this.state === 'slid' ? 'hide' : 'show']()\n }\n\n OffCanvas.prototype.calcClone = function() {\n this.$calcClone = this.$element.clone()\n .html('')\n .addClass('offcanvas-clone').removeClass('in')\n .appendTo($('body'))\n }\n\n OffCanvas.prototype.recalc = function () {\n if (this.state() !== 'slid' || this.$calcClone.css('display') === 'none') return\n \n var offset = -1 * this.offset()\n \n var placement = this.options.placement\n this.getCanvasElements().each(function() {\n $(this).css(placement, (parseInt($(this).css(placement), 10) || 0) + offset)\n }).removeClass('canvas-slid')\n \n $('body').css('overflow', '')\n this.$element.css(placement, '').removeClass('in canvas-slid')\n }\n \n OffCanvas.prototype.autohide = function (e) {\n if ($(e.target).closest(this.$element).length === 0) this.hide()\n }\n\n // OFFCANVAS PLUGIN DEFINITION\n // ==========================\n\n var old = $.fn.offcanvas\n\n $.fn.offcanvas = function (option) {\n return this.each(function () {\n var $this = $(this)\n var data = $this.data('bs.offcanvas')\n var options = $.extend({}, OffCanvas.DEFAULTS, $this.data(), typeof option == 'object' && option)\n\n if (!data) $this.data('bs.offcanvas', (data = new OffCanvas(this, options)))\n if (typeof option == 'string') data[option]()\n })\n }\n\n $.fn.offcanvas.Constructor = OffCanvas\n\n\n // OFFCANVAS NO CONFLICT\n // ====================\n\n $.fn.offcanvas.noConflict = function () {\n $.fn.offcanvas = old\n return this\n }\n\n\n // OFFCANVAS DATA-API\n // =================\n\n $(document).on('click.bs.offcanvas.data-api', '[data-toggle=offcanvas]', function (e) {\n var $this = $(this), href\n var target = $this.attr('data-target')\n || e.preventDefault()\n || (href = $this.attr('href')) && href.replace(/.*(?=#[^\\s]+$)/, '') //strip for ie7\n var $canvas = $(target)\n var data = $canvas.data('bs.offcanvas')\n var option = data ? 'toggle' : $this.data()\n\n e.stopPropagation()\n\n if (data) data.toggle()\n else $canvas.offcanvas(option)\n })\n\n}(window.jQuery);\n","rowlink.js":"/* ============================================================\n * Bootstrap: rowlink.js v3.0.0-p7\n * http://jasny.github.io/bootstrap/javascript.html#rowlink\n * ============================================================\n * Copyright 2012 Jasny BV, Netherlands.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * ============================================================ */\n\n+function ($) { \"use strict\";\n\n var Rowlink = function (element, options) {\n this.$element = $(element)\n this.options = $.extend({}, Rowlink.DEFAULTS, options)\n \n this.$element.on('click.bs.rowlink', 'td:not(.rowlink-skip)', $.proxy(this.click, this))\n }\n\n Rowlink.DEFAULTS = {\n target: \"a\"\n }\n\n Rowlink.prototype.click = function(e) {\n var target = $(e.currentTarget).closest('tr').find(this.options.target)[0]\n if ($(e.target)[0] === target) return\n \n e.preventDefault();\n \n if (target.click) {\n target.click()\n } else if (document.createEvent) {\n var evt = document.createEvent(\"MouseEvents\"); \n evt.initMouseEvent(\"click\", true, true, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null); \n target.dispatchEvent(evt);\n }\n }\n\n \n // ROWLINK PLUGIN DEFINITION\n // ===========================\n\n var old = $.fn.rowlink\n\n $.fn.rowlink = function (options) {\n return this.each(function () {\n var $this = $(this)\n var data = $this.data('rowlink')\n if (!data) $this.data('rowlink', (data = new Rowlink(this, options)))\n })\n }\n\n $.fn.rowlink.Constructor = Rowlink\n\n\n // ROWLINK NO CONFLICT\n // ====================\n\n $.fn.rowlink.noConflict = function () {\n $.fn.rowlink = old\n return this\n }\n\n\n // ROWLINK DATA-API\n // ==================\n\n $(document).on('click.bs.rowlink.data-api', '[data-link=\"row\"]', function (e) {\n var $this = $(this)\n if ($this.data('rowlink')) return\n $this.rowlink($this.data())\n $(e.target).trigger('click.bs.rowlink')\n })\n \n}(window.jQuery);\n"} +var __less = {"alerts-fixed.less":"// Fixed alerts\n//\n// Position to the top or bottom.\n\n.alert-fixed-top,\n.alert-fixed-bottom {\n position: fixed;\n width: 100%;\n z-index: @zindex-alert-fixed;\n border-radius: 0;\n margin: 0;\n left: 0;\n\n @media (min-width: @alert-fixed-width) {\n width: @alert-fixed-width;\n left: 50%;\n margin-left: (-1 * (@alert-fixed-width / 2));\n }\n}\n\n.alert-fixed-top {\n top: 0;\n border-width: 0 0 1px 0;\n \n @media (min-width: @alert-fixed-width) {\n .border-bottom-radius(@alert-border-radius);\n border-width: 0 1px 1px 1px;\n }\n}\n\n.alert-fixed-bottom {\n bottom: 0;\n border-width: 1px 0 0 0;\n \n @media (min-width: @alert-fixed-width) {\n .border-top-radius(@alert-border-radius);\n border-width: 1px 1px 0 1px;\n }\n}\n","button-labels.less":"// Labels for buttons\n// --------------------------------------------------\n\n.btn-labeled {\n padding-top: 0;\n padding-bottom: 0;\n}\n\n.btn-label {\n position: relative;\n background: transparent;\n background: rgba(0, 0, 0, 0.15);\n display: inline-block;\n .button-label-size(@padding-base-vertical; @padding-base-horizontal; @border-radius-base);\n}\n\n.btn-lg .btn-label {\n .button-label-size(@padding-large-vertical; @padding-large-horizontal; @border-radius-large);\n}\n.btn-sm .btn-label {\n .button-label-size(@padding-small-vertical; @padding-small-horizontal; @border-radius-small);\n}\n.btn-xs .btn-label {\n .button-label-size(1px; 5px; @border-radius-small);\n}\n","fileinput.less":"// Fileinput.less\n// CSS for file upload button and fileinput widget\n// ------------------------------------------------\n\n.btn-file {\n overflow: hidden;\n position: relative;\n vertical-align: middle;\n > input {\n position: absolute;\n top: 0;\n right: 0;\n margin: 0;\n opacity: 0;\n filter: alpha(opacity=0);\n transform: translate(-300px, 0) scale(4);\n font-size: 23px;\n height: 100%;\n direction: ltr;\n cursor: pointer;\n }\n}\n\n.fileinput {\n margin-bottom: 9px;\n display: inline-block;\n .form-control {\n padding-top: 7px;\n padding-bottom: 5px;\n display: inline-block;\n margin-bottom: 0px;\n vertical-align: middle;\n cursor: text;\n }\n .thumbnail {\n overflow: hidden;\n display: inline-block;\n margin-bottom: 5px;\n vertical-align: middle;\n text-align: center;\n > img {\n max-height: 100%;\n }\n }\n .btn {\n vertical-align: middle;\n }\n}\n.fileinput-exists .fileinput-new,\n.fileinput-new .fileinput-exists {\n display: none;\n}\n.fileinput-inline .fileinput-controls {\n display: inline;\n}\n\n.fileinput-filename {\n vertical-align: middle;\n display: inline-block;\n overflow: hidden;\n}\n.form-control .fileinput-filename {\n vertical-align: bottom;\n}\n\n// Not 100% correct, but helps in typical use case\n.fileinput-new .input-group .btn-file {\n border-radius: 0 @border-radius-base @border-radius-base 0;\n}\n.fileinput-new .input-group .btn-file.btn-xs,\n.fileinput-new .input-group .btn-file.btn-sm {\n border-radius: 0 @border-radius-small @border-radius-small 0;\n}\n.fileinput-new .input-group .btn-file.btn-lg {\n border-radius: 0 @border-radius-large @border-radius-large 0;\n}\n\n.form-group.has-warning .fileinput {\n .fileinput-preview {\n color: @state-warning-text;\n }\n .thumbnail {\n border-color: @state-warning-border;\n }\n}\n.form-group.has-error .fileinput {\n .fileinput-preview {\n color: @state-danger-text;\n }\n .thumbnail {\n border-color: @state-danger-border;\n }\n}\n.form-group.has-success .fileinput {\n .fileinput-preview {\n color: @state-success-text;\n }\n .thumbnail {\n border-color: @state-success-border;\n }\n}\n\n\n// Input group fixes\n\n.input-group-addon:not(:first-child) {\n border-left: 0;\n}\n","grid-container-smooth.less":"// Smooth sizing container\n// -------------------------\n\n@media (min-width: 1px) {\n .container-smooth {\n max-width: @container-lg;\n }\n}\n\n","jasny-bootstrap.less":"// Twitter Bootstrap's \"variables.less\" should already be imported\n\n// Core variables and mixins\n@import \"variables.less\";\n@import \"mixins.less\";\n\n// Core CSS\n@import \"grid-container-smooth.less\";\n@import \"button-labels.less\";\n\n// Components\n@import \"nav-tab-alignment.less\";\n@import \"navmenu.less\";\n@import \"alerts-fixed.less\";\n\n// Components w/ JavaScript\n@import \"offcanvas.less\";\n@import \"rowlink.less\";\n@import \"fileinput.less\";\n","mixins.less":"//\n// Mixins\n// --------------------------------------------------\n\n\n// CSS3 PROPERTIES\n// --------------------------------------------------\n\n// Single side border-radius\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// Drop shadows\n.box-shadow(@shadow) {\n -webkit-box-shadow: @shadow; // iOS <4.3 & Android <4.1\n box-shadow: @shadow;\n}\n\n\n// BUTTONS\n// --------------------------------------------------\n\n.button-label-size(@padding-vertical; @padding-horizontal; @border-radius) {\n padding: @padding-vertical @padding-horizontal;\n left: (-1 * @padding-horizontal);\n border-radius: (@border-radius - 1px) 0 0 (@border-radius - 1px);\n\n &.btn-label-right {\n left: auto;\n right: (-1 * @padding-horizontal);\n border-radius: 0 (@border-radius - 1px) (@border-radius - 1px) 0;\n }\n}\n","nav-tab-alignment.less":"// Alignment options\n// -------------------------\n\n// bottom\n.nav-tabs-bottom {\n border-bottom: 0;\n border-top: 1px solid @nav-tabs-border-color;\n\n > li {\n margin-bottom: 0;\n margin-top: -1px;\n\n > a {\n border-radius: 0 0 @border-radius-base @border-radius-base;\n }\n\n > a:hover,\n > a:focus,\n &.active > a,\n &.active > a:hover,\n &.active > a:focus {\n border: 1px solid @nav-tabs-active-link-hover-border-color;\n border-top-color: transparent;\n }\n }\n}\n\n// left\n.nav-tabs-left {\n border-bottom: 0;\n border-right: 1px solid @nav-tabs-border-color;\n\n > li {\n margin-bottom: 0;\n margin-right: -1px;\n float: none;\n\n > a {\n border-radius: @border-radius-base 0 0 @border-radius-base;\n margin-right: 0;\n margin-bottom: 2px;\n }\n\n > a:hover,\n > a:focus,\n &.active > a,\n &.active > a:hover,\n &.active > a:focus {\n border: 1px solid @nav-tabs-active-link-hover-border-color;\n border-right-color: transparent;\n }\n }\n\n .row > & {\n padding-right: 0;\n padding-left: (@grid-gutter-width / 2);\n margin-right: -1px;\n position: relative;\n z-index: 1;\n\n & + .tab-content {\n border-left: 1px solid @nav-tabs-active-link-hover-border-color;\n }\n }\n}\n\n// right\n.nav-tabs-right {\n border-bottom: 0;\n border-left: 1px solid @nav-tabs-border-color;\n\n > li {\n margin-bottom: 0;\n margin-left: -1px;\n float: none;\n\n > a {\n border-radius: 0 @border-radius-base @border-radius-base 0;\n margin-left: 0;\n margin-bottom: 2px;\n }\n\n > a:hover,\n > a:focus,\n &.active > a,\n &.active > a:hover,\n &.active > a:focus {\n border: 1px solid @nav-tabs-active-link-hover-border-color;\n border-left-color: transparent;\n }\n }\n\n .row > & {\n padding-left: 0;\n padding-right: (@grid-gutter-width / 2);\n }\n}\n","navmenu.less":"//\n// Navmenu and offcanvas navbar\n// --------------------------------------------------\n\n\n// Wrapper and base class\n//\n// Provide a static navmenu from which we expand to create the fixed navmenu\n// variations.\n\n.navmenu,\n.navbar-offcanvas {\n width: @navmenu-width;\n height: 100%;\n border-width: 1px;\n border-style: solid;\n border-radius: @border-radius-base;\n}\n\n.navmenu-fixed-left,\n.navmenu-fixed-right,\n.navbar-offcanvas {\n position: fixed;\n z-index: @zindex-navmenu-fixed;\n top: 0;\n border-radius: 0;\n}\n.navmenu-fixed-left,\n.navbar-offcanvas {\n left: 0;\n border-width: 0 1px 0 0;\n}\n.navmenu-fixed-right {\n right: 0;\n border-width: 0 0 0 1px;\n}\n\n.navmenu-nav {\n margin-bottom: @navmenu-margin-vertical;\n\n &.dropdown-menu {\n position: static;\n margin: 0;\n padding-top: 0;\n float: none;\n border: none;\n .box-shadow(none);\n border-radius: 0;\n }\n}\n\n.navbar-offcanvas {\n .navbar-nav {\n margin: 0;\n }\n\n @media (min-width: @grid-float-breakpoint) {\n width: auto;\n border-top: 0;\n box-shadow: none;\n\n &.offcanvas {\n position: static;\n display: block !important;\n height: auto !important;\n padding-bottom: 0; // Override default setting\n overflow: visible !important;\n }\n\n // Account for first and last children spacing\n .navbar-nav.navbar-left:first-child {\n margin-left: -@navbar-padding-horizontal;\n }\n .navbar-nav.navbar-right:last-child {\n margin-right: -@navbar-padding-horizontal;\n }\n\n .navmenu-brand {\n display: none;\n }\n }\n}\n\n// Brand/project name\n\n.navmenu-brand {\n display: block;\n font-size: @font-size-large;\n line-height: @line-height-computed;\n padding: @nav-link-padding;\n &:hover,\n &:focus {\n text-decoration: none;\n }\n margin: @navmenu-margin-vertical 0;\n}\n\n// Alternate navmenus\n// --------------------------------------------------\n\n// Default navmenu\n.navmenu-default,\n.navbar-default .navbar-offcanvas {\n background-color: @navmenu-default-bg;\n border-color: @navmenu-default-border;\n\n .navmenu-brand {\n color: @navmenu-default-brand-color;\n &:hover,\n &:focus {\n color: @navmenu-default-brand-hover-color;\n background-color: @navmenu-default-brand-hover-bg;\n }\n }\n\n .navmenu-text {\n color: @navmenu-default-color;\n }\n\n .navmenu-nav {\n // Caret should match text color on hover\n > .dropdown > a:hover .caret,\n > .dropdown > a:focus .caret {\n border-top-color: @navmenu-default-link-hover-color;\n border-bottom-color: @navmenu-default-link-hover-color;\n }\n\n // Remove background color from open dropdown\n > .open > a {\n &,\n &:hover,\n &:focus {\n background-color: @navmenu-default-link-active-bg;\n color: @navmenu-default-link-active-color;\n .caret {\n border-top-color: @navmenu-default-link-active-color;\n border-bottom-color: @navmenu-default-link-active-color;\n }\n }\n }\n > .dropdown > a .caret {\n border-top-color: @navmenu-default-link-color;\n border-bottom-color: @navmenu-default-link-color;\n }\n &.dropdown-menu {\n background-color: @navmenu-default-link-active-bg;\n & > .divider {\n background-color: @navmenu-default-bg;\n }\n > .active > a {\n &,\n &:hover,\n &:focus {\n background-color: darken(@navmenu-default-link-active-bg, 6.5%);\n }\n }\n }\n\n > li > a {\n color: @navmenu-default-link-color;\n &:hover,\n &:focus {\n color: @navmenu-default-link-hover-color;\n background-color: @navmenu-default-link-hover-bg;\n }\n }\n > .active > a {\n &,\n &:hover,\n &:focus {\n color: @navmenu-default-link-active-color;\n background-color: @navmenu-default-link-active-bg;\n }\n }\n > .disabled > a {\n &,\n &:hover,\n &:focus {\n color: @navmenu-default-link-disabled-color;\n background-color: @navmenu-default-link-disabled-bg;\n }\n }\n }\n}\n\n// Inverse navmenu\n.navmenu-inverse,\n.navbar-inverse .navbar-offcanvas {\n background-color: @navmenu-inverse-bg;\n border-color: @navmenu-inverse-border;\n\n .navmenu-brand {\n color: @navmenu-inverse-brand-color;\n &:hover,\n &:focus {\n color: @navmenu-inverse-brand-hover-color;\n background-color: @navmenu-inverse-brand-hover-bg;\n }\n }\n\n .navmenu-text {\n color: @navmenu-inverse-color;\n }\n\n .navmenu-nav {\n // Caret should match text color on hover\n > .dropdown > a:hover .caret,\n > .dropdown > a:focus .caret {\n border-top-color: @navmenu-inverse-link-hover-color;\n border-bottom-color: @navmenu-inverse-link-hover-color;\n }\n\n // Remove background color from open dropdown\n > .open > a {\n &,\n &:hover,\n &:focus {\n background-color: @navmenu-inverse-link-active-bg;\n color: @navmenu-inverse-link-active-color;\n .caret {\n border-top-color: @navmenu-inverse-link-active-color;\n border-bottom-color: @navmenu-inverse-link-active-color;\n }\n }\n }\n > .dropdown > a .caret {\n border-top-color: @navmenu-inverse-link-color;\n border-bottom-color: @navmenu-inverse-link-color;\n }\n &.dropdown-menu {\n background-color: @navmenu-inverse-link-active-bg;\n & > .divider {\n background-color: @navmenu-inverse-bg;\n }\n > .active > a {\n &,\n &:hover,\n &:focus {\n background-color: darken(@navmenu-inverse-link-active-bg, 6.5%);\n }\n }\n }\n\n > li > a {\n color: @navmenu-inverse-link-color;\n &:hover,\n &:focus {\n color: @navmenu-inverse-link-hover-color;\n background-color: @navmenu-inverse-link-hover-bg;\n }\n }\n > .active > a {\n &,\n &:hover,\n &:focus {\n color: @navmenu-inverse-link-active-color;\n background-color: @navmenu-inverse-link-active-bg;\n }\n }\n > .disabled > a {\n &,\n &:hover,\n &:focus {\n color: @navmenu-inverse-link-disabled-color;\n background-color: @navmenu-inverse-link-disabled-bg;\n }\n }\n }\n}\n","offcanvas.less":"//\n// Off canvas navigation\n// --------------------------------------------------\n\n.offcanvas {\n display: none;\n &.in {\n display: block;\n }\n}\n\n@media (max-width: @screen-xs-max) {\n .offcanvas-xs {\n .offcanvas;\n }\n}\n@media (max-width: @screen-sm-max) {\n .offcanvas-sm {\n .offcanvas;\n }\n}\n@media (max-width: @screen-md-max) {\n .offcanvas-md {\n .offcanvas;\n }\n}\n.offcanvas-lg {\n .offcanvas;\n}\n\n.canvas-sliding {\n -webkit-transition: top 0.35s, left 0.35s, bottom 0.35s, right 0.35s;\n transition: top 0.35s, left 0.35s, bottom 0.35s, right 0.35s;\n}\n\n.offcanvas-clone {\n height: 0px !important;\n width: 0px !important;\n overflow: hidden !important;\n border: none !important;\n margin: 0px !important;\n padding: 0px !important;\n position: absolute !important;\n top: auto !important;\n left: auto !important;\n bottom: 0px !important;\n right: 0px !important;\n opacity: 0 !important;\n}\n","rowlink.less":"//\n// Rowlink\n// --------------------------------------------------\n\n.table.rowlink,\n.table .rowlink {\n td:not(.rowlink-skip) {\n cursor: pointer;\n\n a {\n color: inherit;\n font: inherit;\n text-decoration: inherit;\n }\n }\n}\n\n.table-hover.rowlink,\n.table-hover .rowlink {\n tr:hover td {\n background-color: darken(@table-bg-hover, 15%);\n }\n}\n","variables.less":"//\n// These variables are used when Jasny Bootstrap is built\n// without importing Twitter Bootstrap.\n// --------------------------------------------------------\n\n//-- Colors\n//\n//## Gray colors for use across Bootstrap.\n\n@gray-darker: lighten(#000, 13.5%); // #222\n@gray-dark: lighten(#000, 20%); // #333\n@gray: lighten(#000, 33.5%); // #555\n@gray-light: lighten(#000, 60%); // #999\n@gray-lighter: lighten(#000, 93.5%); // #eee\n\n//-- Typography\n//\n//## Font size and line-height.\n\n@font-size-base: 14px;\n@font-size-large: ceil((@font-size-base * 1.25)); // ~18px\n@font-size-small: ceil((@font-size-base * 0.85)); // ~12px\n\n//** Unit-less `line-height` for use in components like buttons.\n@line-height-base: 1.428571429; // 20/14\n//** Computed \"line-height\" (`font-size` * `line-height`) for use with `margin`, `padding`, etc.\n@line-height-computed: floor((@font-size-base * @line-height-base)); // ~20px\n\n\n//== Components\n//\n//## Define common padding and border radius sizes and more. Values based on 14px text and 1.428 line-height (~20px to start).\n\n@padding-base-vertical: 6px;\n@padding-base-horizontal: 12px;\n\n@padding-large-vertical: 10px;\n@padding-large-horizontal: 16px;\n\n@padding-small-vertical: 5px;\n@padding-small-horizontal: 10px;\n\n@padding-xs-vertical: 1px;\n@padding-xs-horizontal: 5px;\n\n@line-height-large: 1.33;\n@line-height-small: 1.5;\n\n@border-radius-base: 4px;\n@border-radius-large: 6px;\n@border-radius-small: 3px;\n\n\n//== Tables\n//\n//## Customizes the `.table` component with basic values, each used across all table variations.\n\n//** Background color used for `.table-hover`.\n@table-bg-hover: #f5f5f5;\n\n\n//-- Z-index master list\n//\n// Warning: Avoid customizing these values. They're used for a bird's eye view\n// of components dependent on the z-axis and are designed to all work together.\n//\n// Note: These variables are not generated into the Customizer.\n\n@zindex-navmenu-fixed: 1030;\n@zindex-alert-fixed: 1035;\n\n\n//== Media queries breakpoints\n//\n//## Define the breakpoints at which your layout will change, adapting to different screen sizes.\n\n// Extra small screen / phone\n@screen-xs: 480px;\n\n// Small screen / tablet\n@screen-sm: 768px;\n\n// Medium screen / desktop\n@screen-md: 992px;\n\n// Large screen / wide desktop\n@screen-lg: 1200px;\n\n//-- So media queries don't overlap when required, provide a maximum\n//\n// Note: These variables are not generated into the Customizer.\n@screen-xs-min: @screen-xs;\n@screen-sm-min: @screen-sm;\n@screen-md-min: @screen-md;\n@screen-lg-min: @screen-lg;\n\n@screen-xs-max: (@screen-sm-min - 1);\n@screen-sm-max: (@screen-md-min - 1);\n@screen-md-max: (@screen-lg-min - 1);\n\n//--\n@container-lg: ((1140px + @grid-gutter-width));\n\n//== Grid system\n//\n//## Define your custom responsive grid.\n\n//** Padding between columns. Gets divided in half for the left and right.\n@grid-gutter-width: 30px;\n//** Point at which the navbar becomes uncollapsed.\n@grid-float-breakpoint: 768px;\n\n//** Maximum with of a smooth container.\n@container-smooth: @container-lg;\n\n//== Navbar\n//\n//##\n\n// Basics of a navbar\n@navbar-height: 50px;\n@navbar-padding-horizontal: floor((@grid-gutter-width / 2));\n@navbar-padding-vertical: ((@navbar-height - @line-height-computed) / 2);\n\n\n//== Navmenu\n//\n//##\n\n// Basics of a navmenu\n@navmenu-width: 300px;\n@navmenu-margin-vertical: (0.5 * @line-height-computed);\n@navmenu-default-color: #777;\n@navmenu-default-bg: #f8f8f8;\n@navmenu-default-border: darken(@navmenu-default-bg, 6.5%);\n\n// Navmenu links\n@navmenu-default-link-color: #777;\n@navmenu-default-link-hover-color: #333;\n@navmenu-default-link-hover-bg: transparent;\n@navmenu-default-link-active-color: #555;\n@navmenu-default-link-active-bg: darken(@navmenu-default-bg, 6.5%);\n@navmenu-default-link-disabled-color: #ccc;\n@navmenu-default-link-disabled-bg: transparent;\n\n// Navmenu brand label\n@navmenu-default-brand-color: @navmenu-default-link-color;\n@navmenu-default-brand-hover-color: darken(@navmenu-default-link-color, 10%);\n@navmenu-default-brand-hover-bg: transparent;\n\n\n// Inverted navmenu\n//\n// Reset inverted navmenu basics\n@navmenu-inverse-color: @gray-light;\n@navmenu-inverse-bg: #222;\n@navmenu-inverse-border: darken(@navmenu-inverse-bg, 10%);\n\n// Inverted navmenu links\n@navmenu-inverse-link-color: @gray-light;\n@navmenu-inverse-link-hover-color: #fff;\n@navmenu-inverse-link-hover-bg: transparent;\n@navmenu-inverse-link-active-color: @navmenu-inverse-link-hover-color;\n@navmenu-inverse-link-active-bg: darken(@navmenu-inverse-bg, 10%);\n@navmenu-inverse-link-disabled-color: #444;\n@navmenu-inverse-link-disabled-bg: transparent;\n\n// Inverted navmenu brand label\n@navmenu-inverse-brand-color: @navmenu-inverse-link-color;\n@navmenu-inverse-brand-hover-color: #fff;\n@navmenu-inverse-brand-hover-bg: transparent;\n\n// Inverted navmenu search\n// Normal navmenu needs no special styles or vars\n@navmenu-inverse-search-bg: lighten(@navmenu-inverse-bg, 25%);\n@navmenu-inverse-search-bg-focus: #fff;\n@navmenu-inverse-search-border: @navmenu-inverse-bg;\n@navmenu-inverse-search-placeholder-color: #ccc;\n\n\n//== Navs\n//\n//##\n\n@nav-link-padding: 10px 15px;\n@nav-tabs-active-link-hover-border-color: #ddd;\n@nav-tabs-border-color: #ddd;\n\n\n//== Form states and alerts\n//\n//## Define colors for form feedback states and, by default, alerts.\n\n@state-success-text: #3c763d;\n@state-success-bg: #dff0d8;\n@state-success-border: darken(spin(@state-success-bg, -10), 5%);\n\n@state-info-text: #31708f;\n@state-info-bg: #d9edf7;\n@state-info-border: darken(spin(@state-info-bg, -10), 7%);\n\n@state-warning-text: #8a6d3b;\n@state-warning-bg: #fcf8e3;\n@state-warning-border: darken(spin(@state-warning-bg, -10), 5%);\n\n@state-danger-text: #a94442;\n@state-danger-bg: #f2dede;\n@state-danger-border: darken(spin(@state-danger-bg, -10), 5%);\n\n\n//== Alerts\n//\n//## Define alert colors, border radius, and padding.\n\n@alert-border-radius: @border-radius-base;\n@alert-fixed-width: @screen-md;\n"} diff --git a/components/index.html b/components/index.html index d3ed5455..b6bce919 100644 --- a/components/index.html +++ b/components/index.html @@ -144,8 +144,6 @@ - -

Navmenu is a vertical navigation component. By default it shares it look and feel with the navmenu component.

@@ -153,6 +151,8 @@

The navmenu is 300px wide by default. You can change this by customizing the @navmenu-width variable or by setting the width of .navmenu in your CSS.

+ +
- - -
- -

Indicate the current page's location within a navigational hierarchy.

-

Separators are automatically added in CSS through :before and content.

-
- - - -
-
<ol class="breadcrumb">
-  <li><a href="#">Home</a></li>
-  <li><a href="#">Library</a></li>
-  <li class="active">Data</li>
-</ol>
-
-
- - - - -
- -

Provide pagination links for your site or app with the multi-page pagination component, or the simpler pager alternative.

- -

Default pagination

-

Simple pagination inspired by Rdio, great for apps and search results. The large block is hard to miss, easily scalable, and provides large click areas.

-
- -
-
<ul class="pagination">
-  <li><a href="#">&laquo;</a></li>
-  <li><a href="#">1</a></li>
-  <li><a href="#">2</a></li>
-  <li><a href="#">3</a></li>
-  <li><a href="#">4</a></li>
-  <li><a href="#">5</a></li>
-  <li><a href="#">&raquo;</a></li>
-</ul>
-
- -

Disabled and active states

-

Links are customizable for different circumstances. Use .disabled for unclickable links and .active to indicate the current page.

-
- -
-
<ul class="pagination">
-  <li class="disabled"><a href="#">&laquo;</a></li>
-  <li class="active"><a href="#">1 <span class="sr-only">(current)</span></a></li>
-  ...
-</ul>
-
-

You can optionally swap out active or disabled anchors for <span> to remove click functionality while retaining intended styles.

-
<ul class="pagination">
-  <li class="disabled"><span>&laquo;</span></li>
-  <li class="active"><span>1 <span class="sr-only">(current)</span></span></li>
-  ...
-</ul>
-
- - -

Sizing

-

Fancy larger or smaller pagination? Add .pagination-lg or .pagination-sm for additional sizes.

-
-
- -
-
- -
-
- -
-
-
<ul class="pagination pagination-lg">...</ul>
-<ul class="pagination">...</ul>
-<ul class="pagination pagination-sm">...</ul>
-
- - -

Pager

-

Quick previous and next links for simple pagination implementations with light markup and styles. It's great for simple sites like blogs or magazines.

- -

Default example

-

By default, the pager centers links.

-
- -
-
<ul class="pager">
-  <li><a href="#">Previous</a></li>
-  <li><a href="#">Next</a></li>
-</ul>
-
- -

Aligned links

-

Alternatively, you can align each link to the sides:

-
- -
-
<ul class="pager">
-  <li class="previous"><a href="#">&larr; Older</a></li>
-  <li class="next"><a href="#">Newer &rarr;</a></li>
-</ul>
-
- - -

Optional disabled state

-

Pager links also use the general .disabled utility class from the pagination.

-
- -
-
<ul class="pager">
-  <li class="previous disabled"><a href="#">&larr; Older</a></li>
-  <li class="next"><a href="#">Newer &rarr;</a></li>
-</ul>
-
-
- - - - -
- -

- -

Example

-
-

Example heading New

-

Example heading New

-

Example heading New

-

Example heading New

-
Example heading New
-
Example heading New
-
-
<h3>Example heading <span class="label label-default">New</span></h3>
-
- -

Available variations

-

Add any of the below mentioned modifier classes to change the appearance of a label.

-
- Default - Primary - Success - Info - Warning - Danger -
-
<span class="label label-default">Default</span>
-<span class="label label-primary">Primary</span>
-<span class="label label-success">Success</span>
-<span class="label label-info">Info</span>
-<span class="label label-warning">Warning</span>
-<span class="label label-danger">Danger</span>
-
- -
- - - - -
- -

Easily highlight new or unread items by adding a <span class="badge"> to links, Bootstrap navs, and more.

- -
- Inbox 42 -
-
<a href="#">Inbox <span class="badge">42</span></a>
-
- -

Self collapsing

-

When there are no new or unread items, badges will simply collapse (via CSS's :empty selector) provided no content exists within.

- -
-

Cross-browser compatibility

-

Badges won't self collapse in Internet Explorer 8 because it lacks support for the :empty selector.

-
- -

Adapts to active nav states

-

Built-in styles are included for placing badges in active states in pill and list navigations.

- -
<ul class="nav nav-pills nav-stacked">
-  <li class="active">
-    <a href="#">
-      <span class="badge pull-right">42</span>
-      Home
-    </a>
-  </li>
-  ...
-</ul>
-
-
- - - - -
- -

A lightweight, flexible component that can optionally extend the entire viewport to showcase key content on your site.

-
-
-

Hello, world!

-

This is a simple hero unit, a simple jumbotron-style component for calling extra attention to featured content or information.

-

Learn more

-
-
-
<div class="jumbotron">
-  <h1>Hello, world!</h1>
-  <p>...</p>
-  <p><a class="btn btn-primary btn-lg" role="button">Learn more</a></p>
-</div>
-
-

To make the jumbotron full width, and without rounded corners, place it outside all .containers and instead add a .container within.

-
<div class="jumbotron">
-  <div class="container">
-    ...
-  </div>
-</div>
-
- -
- - - - -
- -

A simple shell for an h1 to appropriately space out and segment sections of content on a page. It can utilize the h1's default small element, as well as most other components (with additional styles).

-
- -
-
<div class="page-header">
-  <h1>Example page header <small>Subtext for header</small></h1>
-</div>
-
-
- - - - -
- -

Extend Bootstrap's grid system with the thumbnail component to easily display grids of images, videos, text, and more.

- -

Default example

-

By default, Bootstrap's thumbnails are designed to showcase linked images with minimal required markup.

-
-
-
- - Generic placeholder thumbnail - -
-
- - Generic placeholder thumbnail - -
-
- - Generic placeholder thumbnail - -
-
- - Generic placeholder thumbnail - -
-
-
-
<div class="row">
-  <div class="col-sm-6 col-md-3">
-    <a href="#" class="thumbnail">
-      <img data-src="holder.js/100%x180" alt="...">
-    </a>
-  </div>
-  ...
-</div>
-
- -

Custom content

-

With a bit of extra markup, it's possible to add any kind of HTML content like headings, paragraphs, or buttons into thumbnails.

-
-
-
-
- Generic placeholder thumbnail -
-

Thumbnail label

-

Cras justo odio, dapibus ac facilisis in, egestas eget quam. Donec id elit non mi porta gravida at eget metus. Nullam id dolor id nibh ultricies vehicula ut id elit.

-

Button Button

-
-
-
-
-
- Generic placeholder thumbnail -
-

Thumbnail label

-

Cras justo odio, dapibus ac facilisis in, egestas eget quam. Donec id elit non mi porta gravida at eget metus. Nullam id dolor id nibh ultricies vehicula ut id elit.

-

Button Button

-
-
-
-
-
- Generic placeholder thumbnail -
-

Thumbnail label

-

Cras justo odio, dapibus ac facilisis in, egestas eget quam. Donec id elit non mi porta gravida at eget metus. Nullam id dolor id nibh ultricies vehicula ut id elit.

-

Button Button

-
-
-
-
-
-
<div class="row">
-  <div class="col-sm-6 col-md-4">
-    <div class="thumbnail">
-      <img data-src="holder.js/300x200" alt="...">
-      <div class="caption">
-        <h3>Thumbnail label</h3>
-        <p>...</p>
-        <p><a href="#" class="btn btn-primary" role="button">Button</a> <a href="#" class="btn btn-default" role="button">Button</a></p>
-      </div>
-    </div>
-  </div>
-</div>
-
-
- - - -
diff --git a/customize/index.html b/customize/index.html index 93c248bd..06fb5ee2 100644 --- a/customize/index.html +++ b/customize/index.html @@ -123,13 +123,10 @@
  • jQuery plugins
  • Less variables
  • - -

    jQuery plugins

    - + +

    Choose which jQuery plugins should be included in your custom JavaScript files. Unsure what to include? Read the JavaScript page in the docs.

    Linked to components

    @@ -248,7 +254,7 @@

    Magic

    @@ -269,62 +275,14 @@
    - -

    Less variables

    +

    Customize Less variables to define colors, sizes and more inside your custom CSS stylesheets.

    -

    Colors

    -

    Gray and brand colors for use across Bootstrap.

    -
    -
    - - -
    -
    - - -
    -
    - - -
    -
    - - -
    -
    - - -
    -
    -

    Typography

    -

    Font, line-height, and color for body text, headings, and more.

    -
    -
    - - -
    -
    - - -
    -
    - - -
    -
    - - -

    Unit-less line-height for use in components like buttons.

    -
    -
    - - -

    Computed "line-height" (font-size * line-height) for use with margin, padding, etc.

    -
    -

    Components

    Define common padding and border radius sizes and more. Values based on 14px text and 1.428 line-height (~20px to start).

    @@ -397,62 +355,18 @@
    -
    - - -
    -
    - - -
    -
    - - -
    -
    - - -
    -
    - - -
    -
    - - -
    -
    - - -
    -
    - - -
    -
    - - -
    -
    - - -
    -
    - - -

    Grid system

    Define your custom responsive grid.

    @@ -467,18 +381,10 @@

    Point at which the navbar becomes uncollapsed.

    -
    -

    Container sizes

    -

    Define the maximum width of .container for different screen sizes.

    -
    - - -
    -
    - - -

    For @screen-lg-min and up.

    + + +

    Maximum with of a smooth container.

    @@ -715,9 +621,11 @@
    -

    Download

    - -

    Hooray! Your custom version of Bootstrap is now ready to be compiled. Just click the button below to finish the process.

    + + +

    Hooray! Your custom version of Jasny Bootstrap is now ready to be compiled. Just click the button below to finish the process.

    @@ -779,12 +687,7 @@ - - - - - - + diff --git a/dist/css/jasny-bootstrap.css.map b/dist/css/jasny-bootstrap.css.map index 81ce1861..39d7a65c 100644 --- a/dist/css/jasny-bootstrap.css.map +++ b/dist/css/jasny-bootstrap.css.map @@ -1 +1 @@ -{"version":3,"sources":["less/grid-container-smooth.less","less/button-labels.less","less/nav-tab-alignment.less","less/navmenu.less","less/mixins.less","less/alerts-fixed.less","less/offcanvas.less","less/rowlink.less","less/fileinput.less"],"names":[],"mappings":";;;;;;;;;AASA,QANwB;EACtB;IACE,iBAAA;;;ACWJ;EACE,cAAA;EACA,iBAAA;;AAGF;EACE,kBAAA;EACA,uBAAA;EACA,+BAAA;EACA,qBAAA;EApBA,iBAAA;EACA,WAAA;EACA,0BAAA;;AAEA,UAAC;EACC,UAAA;EACA,YAAA;EACA,0BAAA;;AAiBJ,OAAQ;EAxBN,kBAAA;EACA,WAAA;EACA,0BAAA;;AAEA,OAoBM,WApBL;EACC,UAAA;EACA,YAAA;EACA,0BAAA;;AAoBJ,OAAQ;EA3BN,iBAAA;EACA,WAAA;EACA,0BAAA;;AAEA,OAuBM,WAvBL;EACC,UAAA;EACA,YAAA;EACA,0BAAA;;AAuBJ,OAAQ;EA9BN,gBAAA;EACA,UAAA;EACA,0BAAA;;AAEA,OA0BM,WA1BL;EACC,UAAA;EACA,WAAA;EACA,0BAAA;;ACRJ;EACE,gBAAA;EACA,6BAAA;;AAFF,gBAIE;EACE,gBAAA;EACA,gBAAA;;AANJ,gBAIE,KAIE;EACE,0BAAA;;AATN,gBAIE,KAQE,IAAG;AAZP,gBAIE,KASE,IAAG;AACH,gBAVF,KAUG,OAAQ;AACT,gBAXF,KAWG,OAAQ,IAAG;AACZ,gBAZF,KAYG,OAAQ,IAAG;EACV,yBAAA;EACA,6BAAA;;AAMN;EACE,gBAAA;EACA,+BAAA;;AAFF,cAIE;EACE,gBAAA;EACA,kBAAA;EACA,WAAA;;AAPJ,cAIE,KAKE;EACE,0BAAA;EACA,eAAA;EACA,kBAAA;;AAZN,cAIE,KAWE,IAAG;AAfP,cAIE,KAYE,IAAG;AACH,cAbF,KAaG,OAAQ;AACT,cAdF,KAcG,OAAQ,IAAG;AACZ,cAfF,KAeG,OAAQ,IAAG;EACV,yBAAA;EACA,+BAAA;;AAIJ,IAAK;EACH,gBAAA;EACA,kBAAA;EACA,kBAAA;EACA,kBAAA;EACA,UAAA;;AAEA,IAPG,iBAOD;EACA,8BAAA;;AAMN;EACE,gBAAA;EACA,8BAAA;;AAFF,eAIE;EACE,gBAAA;EACA,iBAAA;EACA,WAAA;;AAPJ,eAIE,KAKE;EACE,0BAAA;EACA,cAAA;EACA,kBAAA;;AAZN,eAIE,KAWE,IAAG;AAfP,eAIE,KAYE,IAAG;AACH,eAbF,KAaG,OAAQ;AACT,eAdF,KAcG,OAAQ,IAAG;AACZ,eAfF,KAeG,OAAQ,IAAG;EACV,yBAAA;EACA,8BAAA;;AAIJ,IAAK;EACH,eAAA;EACA,mBAAA;;ACpFJ;AACA;EACE,YAAA;EACA,YAAA;EACA,iBAAA;EACA,mBAAA;EACA,kBAAA;;AAGF;AACA;AACA;EACE,eAAA;EACA,aAAA;EACA,MAAA;EACA,gBAAA;;AAEF;AACA;EACE,OAAA;EACA,uBAAA;;AAEF;EACE,QAAA;EACA,uBAAA;;AAGF;EACE,mBAAA;;AAEA,YAAC;EACC,gBAAA;EACA,SAAA;EACA,cAAA;EACA,WAAA;EACA,YAAA;EC4EF,wBAAA;EACQ,gBAAA;ED3EN,gBAAA;;AAIJ,iBACE;EACE,SAAA;;AA4BJ,QAzB6C;EAyB7C;IAxBI,WAAA;IACA,aAAA;IACA,gBAAA;;EAEA,iBAAC;IACC,gBAAA;IACA,yBAAA;IACA,uBAAA;IACA,iBAAA;IACA,4BAAA;;EAeN,iBAXI,YAAW,YAAY;IACrB,kBAAA;;EAUN,iBARI,YAAW,aAAa;IACtB,mBAAA;;EAON,iBAJI;IACE,aAAA;;;AAON;EACE,cAAA;EACA,eAAA;EACA,iBAAA;EACA,kBAAA;EAKA,cAAA;;AAJA,cAAC;AACD,cAAC;EACC,qBAAA;;AASJ;AACA,eAAgB;EACd,yBAAA;EACA,qBAAA;;AAHF,gBAKE;AAJF,eAAgB,kBAId;EACE,cAAA;;AACA,gBAFF,eAEG;AAAD,eANY,kBAId,eAEG;AACD,gBAHF,eAGG;AAAD,eAPY,kBAId,eAGG;EACC,cAAA;EACA,6BAAA;;AAVN,gBAcE;AAbF,eAAgB,kBAad;EACE,cAAA;;AAfJ,gBAkBE,aAEE,YAAY,IAAG,MAAO;AAnB1B,eAAgB,kBAiBd,aAEE,YAAY,IAAG,MAAO;AApB1B,gBAkBE,aAGE,YAAY,IAAG,MAAO;AApB1B,eAAgB,kBAiBd,aAGE,YAAY,IAAG,MAAO;EACpB,yBAAA;EACA,4BAAA;;AAKA,gBAVJ,aASE,QAAQ;AACN,eA3BU,kBAiBd,aASE,QAAQ;AAEN,gBAXJ,aASE,QAAQ,IAEL;AAAD,eA5BU,kBAiBd,aASE,QAAQ,IAEL;AACD,gBAZJ,aASE,QAAQ,IAGL;AAAD,eA7BU,kBAiBd,aASE,QAAQ,IAGL;EACC,yBAAA;EACA,cAAA;;AAJF,gBAVJ,aASE,QAAQ,IAMJ;AALF,eA3BU,kBAiBd,aASE,QAAQ,IAMJ;AAJF,gBAXJ,aASE,QAAQ,IAEL,MAIC;AAJF,eA5BU,kBAiBd,aASE,QAAQ,IAEL,MAIC;AAHF,gBAZJ,aASE,QAAQ,IAGL,MAGC;AAHF,eA7BU,kBAiBd,aASE,QAAQ,IAGL,MAGC;EACE,yBAAA;EACA,4BAAA;;AAnCV,gBAkBE,aAqBE,YAAY,IAAI;AAtCpB,eAAgB,kBAiBd,aAqBE,YAAY,IAAI;EACd,yBAAA;EACA,4BAAA;;AAEF,gBAzBF,aAyBG;AAAD,eA1CY,kBAiBd,aAyBG;EACC,yBAAA;;AACA,gBA3BJ,aAyBG,cAEG;AAAF,eA5CU,kBAiBd,aAyBG,cAEG;EACA,yBAAA;;AAGA,gBA/BN,aAyBG,cAKC,UAAU;AACR,eAhDQ,kBAiBd,aAyBG,cAKC,UAAU;AAER,gBAhCN,aAyBG,cAKC,UAAU,IAEP;AAAD,eAjDQ,kBAiBd,aAyBG,cAKC,UAAU,IAEP;AACD,gBAjCN,aAyBG,cAKC,UAAU,IAGP;AAAD,eAlDQ,kBAiBd,aAyBG,cAKC,UAAU,IAGP;EACC,yBAAA;;AApDV,gBAkBE,aAuCE,KAAK;AAxDT,eAAgB,kBAiBd,aAuCE,KAAK;EACH,cAAA;;AACA,gBAzCJ,aAuCE,KAAK,IAEF;AAAD,eA1DU,kBAiBd,aAuCE,KAAK,IAEF;AACD,gBA1CJ,aAuCE,KAAK,IAGF;AAAD,eA3DU,kBAiBd,aAuCE,KAAK,IAGF;EACC,cAAA;EACA,6BAAA;;AAIF,gBAhDJ,aA+CE,UAAU;AACR,eAjEU,kBAiBd,aA+CE,UAAU;AAER,gBAjDJ,aA+CE,UAAU,IAEP;AAAD,eAlEU,kBAiBd,aA+CE,UAAU,IAEP;AACD,gBAlDJ,aA+CE,UAAU,IAGP;AAAD,eAnEU,kBAiBd,aA+CE,UAAU,IAGP;EACC,cAAA;EACA,yBAAA;;AAIF,gBAxDJ,aAuDE,YAAY;AACV,eAzEU,kBAiBd,aAuDE,YAAY;AAEV,gBAzDJ,aAuDE,YAAY,IAET;AAAD,eA1EU,kBAiBd,aAuDE,YAAY,IAET;AACD,gBA1DJ,aAuDE,YAAY,IAGT;AAAD,eA3EU,kBAiBd,aAuDE,YAAY,IAGT;EACC,cAAA;EACA,6BAAA;;AAOR;AACA,eAAgB;EACd,yBAAA;EACA,qBAAA;;AAHF,gBAKE;AAJF,eAAgB,kBAId;EACE,cAAA;;AACA,gBAFF,eAEG;AAAD,eANY,kBAId,eAEG;AACD,gBAHF,eAGG;AAAD,eAPY,kBAId,eAGG;EACC,cAAA;EACA,6BAAA;;AAVN,gBAcE;AAbF,eAAgB,kBAad;EACE,cAAA;;AAfJ,gBAkBE,aAEE,YAAY,IAAG,MAAO;AAnB1B,eAAgB,kBAiBd,aAEE,YAAY,IAAG,MAAO;AApB1B,gBAkBE,aAGE,YAAY,IAAG,MAAO;AApB1B,eAAgB,kBAiBd,aAGE,YAAY,IAAG,MAAO;EACpB,yBAAA;EACA,4BAAA;;AAKA,gBAVJ,aASE,QAAQ;AACN,eA3BU,kBAiBd,aASE,QAAQ;AAEN,gBAXJ,aASE,QAAQ,IAEL;AAAD,eA5BU,kBAiBd,aASE,QAAQ,IAEL;AACD,gBAZJ,aASE,QAAQ,IAGL;AAAD,eA7BU,kBAiBd,aASE,QAAQ,IAGL;EACC,yBAAA;EACA,cAAA;;AAJF,gBAVJ,aASE,QAAQ,IAMJ;AALF,eA3BU,kBAiBd,aASE,QAAQ,IAMJ;AAJF,gBAXJ,aASE,QAAQ,IAEL,MAIC;AAJF,eA5BU,kBAiBd,aASE,QAAQ,IAEL,MAIC;AAHF,gBAZJ,aASE,QAAQ,IAGL,MAGC;AAHF,eA7BU,kBAiBd,aASE,QAAQ,IAGL,MAGC;EACE,yBAAA;EACA,4BAAA;;AAnCV,gBAkBE,aAqBE,YAAY,IAAI;AAtCpB,eAAgB,kBAiBd,aAqBE,YAAY,IAAI;EACd,yBAAA;EACA,4BAAA;;AAEF,gBAzBF,aAyBG;AAAD,eA1CY,kBAiBd,aAyBG;EACC,yBAAA;;AACA,gBA3BJ,aAyBG,cAEG;AAAF,eA5CU,kBAiBd,aAyBG,cAEG;EACA,yBAAA;;AAGA,gBA/BN,aAyBG,cAKC,UAAU;AACR,eAhDQ,kBAiBd,aAyBG,cAKC,UAAU;AAER,gBAhCN,aAyBG,cAKC,UAAU,IAEP;AAAD,eAjDQ,kBAiBd,aAyBG,cAKC,UAAU,IAEP;AACD,gBAjCN,aAyBG,cAKC,UAAU,IAGP;AAAD,eAlDQ,kBAiBd,aAyBG,cAKC,UAAU,IAGP;EACC,yBAAA;;AApDV,gBAkBE,aAuCE,KAAK;AAxDT,eAAgB,kBAiBd,aAuCE,KAAK;EACH,cAAA;;AACA,gBAzCJ,aAuCE,KAAK,IAEF;AAAD,eA1DU,kBAiBd,aAuCE,KAAK,IAEF;AACD,gBA1CJ,aAuCE,KAAK,IAGF;AAAD,eA3DU,kBAiBd,aAuCE,KAAK,IAGF;EACC,cAAA;EACA,6BAAA;;AAIF,gBAhDJ,aA+CE,UAAU;AACR,eAjEU,kBAiBd,aA+CE,UAAU;AAER,gBAjDJ,aA+CE,UAAU,IAEP;AAAD,eAlEU,kBAiBd,aA+CE,UAAU,IAEP;AACD,gBAlDJ,aA+CE,UAAU,IAGP;AAAD,eAnEU,kBAiBd,aA+CE,UAAU,IAGP;EACC,cAAA;EACA,yBAAA;;AAIF,gBAxDJ,aAuDE,YAAY;AACV,eAzEU,kBAiBd,aAuDE,YAAY;AAEV,gBAzDJ,aAuDE,YAAY,IAET;AAAD,eA1EU,kBAiBd,aAuDE,YAAY,IAET;AACD,gBA1DJ,aAuDE,YAAY,IAGT;AAAD,eA3EU,kBAiBd,aAuDE,YAAY,IAGT;EACC,cAAA;EACA,6BAAA;;AEpQR;AACA;EACE,eAAA;EACA,WAAA;EACA,aAAA;EACA,gBAAA;EACA,SAAA;EACA,OAAA;;AAOF,QALyC;EAKzC;EAAA;IAJI,YAAA;IACA,SAAA;IACA,mBAAA;;;AAIJ;EACE,MAAA;EACA,uBAAA;;AAMF,QAJyC;EAIzC;IDmFE,+BAAA;IACC,8BAAA;ICtFC,2BAAA;;;AAIJ;EACE,SAAA;EACA,uBAAA;;AAMF,QAJyC;EAIzC;IDiEE,4BAAA;IACC,2BAAA;ICpEC,2BAAA;;;AChCJ;EACE,aAAA;;AACA,UAAC;EACC,cAAA;;AASJ,QALmC;EACjC;IAPA,aAAA;;EACA,aAAC;IACC,cAAA;;;AAcJ,QALmC;EACjC;IAZA,aAAA;;EACA,aAAC;IACC,cAAA;;;AAmBJ,QALmC;EACjC;IAjBA,aAAA;;EACA,aAAC;IACC,cAAA;;;AAmBJ;EArBE,aAAA;;AACA,aAAC;EACC,cAAA;;AAuBJ;EACE,oEAAA;EACQ,4DAAA;;AAGV;EACE,sBAAA;EACA,qBAAA;EACA,2BAAA;EACA,uBAAA;EACA,sBAAA;EACA,uBAAA;EACA,6BAAA;EACA,oBAAA;EACA,qBAAA;EACA,sBAAA;EACA,qBAAA;EACA,qBAAA;;AC3CF,MAAM,QAEJ,GAAE,IAAI;AADR,MAAO,SACL,GAAE,IAAI;EACJ,eAAA;;AAHJ,MAAM,QAEJ,GAAE,IAAI,eAGJ;AAJJ,MAAO,SACL,GAAE,IAAI,eAGJ;EACE,cAAA;EACA,aAAA;EACA,wBAAA;;AAKN,YAAY,QAEV,GAAE,MAAO;AADX,YAAa,SACX,GAAE,MAAO;EACP,yBAAA;;AChBJ;EACE,gBAAA;EACA,kBAAA;EACA,sBAAA;;AAHF,SAIE;EACE,kBAAA;EACA,MAAA;EACA,QAAA;EACA,SAAA;EACA,UAAA;EACA,wBAAA;EACA,WAAW,qBAAqB,QAAhC;EACA,eAAA;EACA,cAAA;EACA,eAAA;;AAIJ;EACE,kBAAA;EACA,qBAAA;;AAFF,UAGE;EACE,qBAAA;EACA,kBAAA;EACA,sBAAA;EACA,YAAA;;AAPJ,UASE;EACE,gBAAA;EACA,qBAAA;EACA,kBAAA;EACA,sBAAA;EACA,kBAAA;;AAdJ,UASE,WAME;EACE,gBAAA;;AAhBN,UAmBE;EACE,sBAAA;;AAGJ,iBAAkB;AAClB,cAAe;EACb,aAAA;;AAEF,iBAAkB;EAChB,eAAA;;AAGF,UAAW;EACT,mBAAA;;AAIF,cAAe,aAAa;EAC1B,0BAAA;;AAEF,cAAe,aAAa,UAAS;AACrC,cAAe,aAAa,UAAS;EACnC,0BAAA;;AAEF,cAAe,aAAa,UAAS;EACnC,0BAAA;;AAGF,WAAW,YAAa,WACtB;EACE,cAAA;EACA,qBAAA;;AAHJ,WAAW,YAAa,WAKtB;EACE,cAAA;;AANJ,WAAW,YAAa,WAQtB;EACE,qBAAA;;AAGJ,WAAW,UAAW,WACpB;EACE,cAAA;EACA,qBAAA;;AAHJ,WAAW,UAAW,WAKpB;EACE,cAAA;;AANJ,WAAW,UAAW,WAQpB;EACE,qBAAA;;AAGJ,WAAW,YAAa,WACtB;EACE,cAAA;EACA,qBAAA;;AAHJ,WAAW,YAAa,WAKtB;EACE,cAAA;;AANJ,WAAW,YAAa,WAQtB;EACE,qBAAA;;AAOJ,kBAAkB,IAAI;EACpB,cAAA","sourcesContent":["// Smooth sizing container\n// -------------------------\n\n@media (min-width: 1px) {\n .container-smooth {\n max-width: @container-lg;\n }\n}\n\n","// Labels for buttons\n// --------------------------------------------------\n\n// Mixin\n.button-label-size(@padding-vertical; @padding-horizontal; @border-radius) {\n padding: @padding-vertical @padding-horizontal;\n left: (-1 * @padding-horizontal);\n border-radius: (@border-radius - 1px) 0 0 (@border-radius - 1px);\n\n &.btn-label-right {\n left: auto;\n right: (-1 * @padding-horizontal);\n border-radius: 0 (@border-radius - 1px) (@border-radius - 1px) 0;\n }\n}\n\n.btn-labeled {\n padding-top: 0;\n padding-bottom: 0;\n}\n\n.btn-label {\n position: relative;\n background: transparent;\n background: rgba(0, 0, 0, 0.15);\n display: inline-block;\n .button-label-size(@padding-base-vertical; @padding-base-horizontal; @border-radius-base);\n}\n\n.btn-lg .btn-label {\n .button-label-size(@padding-large-vertical; @padding-large-horizontal; @border-radius-large);\n}\n.btn-sm .btn-label {\n .button-label-size(@padding-small-vertical; @padding-small-horizontal; @border-radius-small);\n}\n.btn-xs .btn-label {\n .button-label-size(1px; 5px; @border-radius-small);\n}\n","// Alignment options\n// -------------------------\n\n// bottom\n.nav-tabs-bottom {\n border-bottom: 0;\n border-top: 1px solid @nav-tabs-border-color;\n\n > li {\n margin-bottom: 0;\n margin-top: -1px;\n\n > a {\n border-radius: 0 0 @border-radius-base @border-radius-base;\n }\n\n > a:hover,\n > a:focus,\n &.active > a,\n &.active > a:hover,\n &.active > a:focus {\n border: 1px solid @nav-tabs-active-link-hover-border-color;\n border-top-color: transparent;\n }\n }\n}\n\n// left\n.nav-tabs-left {\n border-bottom: 0;\n border-right: 1px solid @nav-tabs-border-color;\n\n > li {\n margin-bottom: 0;\n margin-right: -1px;\n float: none;\n\n > a {\n border-radius: @border-radius-base 0 0 @border-radius-base;\n margin-right: 0;\n margin-bottom: 2px;\n }\n\n > a:hover,\n > a:focus,\n &.active > a,\n &.active > a:hover,\n &.active > a:focus {\n border: 1px solid @nav-tabs-active-link-hover-border-color;\n border-right-color: transparent;\n }\n }\n\n .row > & {\n padding-right: 0;\n padding-left: (@grid-gutter-width / 2);\n margin-right: -1px;\n position: relative;\n z-index: 1;\n\n & + .tab-content {\n border-left: 1px solid @nav-tabs-active-link-hover-border-color;\n }\n }\n}\n\n// right\n.nav-tabs-right {\n border-bottom: 0;\n border-left: 1px solid @nav-tabs-border-color;\n\n > li {\n margin-bottom: 0;\n margin-left: -1px;\n float: none;\n\n > a {\n border-radius: 0 @border-radius-base @border-radius-base 0;\n margin-left: 0;\n margin-bottom: 2px;\n }\n\n > a:hover,\n > a:focus,\n &.active > a,\n &.active > a:hover,\n &.active > a:focus {\n border: 1px solid @nav-tabs-active-link-hover-border-color;\n border-left-color: transparent;\n }\n }\n\n .row > & {\n padding-left: 0;\n padding-right: (@grid-gutter-width / 2);\n }\n}\n","//\n// Navmenu and offcanvas navbar\n// --------------------------------------------------\n\n\n// Wrapper and base class\n//\n// Provide a static navmenu from which we expand to create the fixed navmenu\n// variations.\n\n.navmenu,\n.navbar-offcanvas {\n width: @navmenu-width;\n height: 100%;\n border-width: 1px;\n border-style: solid;\n border-radius: @border-radius-base;\n}\n\n.navmenu-fixed-left,\n.navmenu-fixed-right,\n.navbar-offcanvas {\n position: fixed;\n z-index: @zindex-navmenu-fixed;\n top: 0;\n border-radius: 0;\n}\n.navmenu-fixed-left,\n.navbar-offcanvas {\n left: 0;\n border-width: 0 1px 0 0;\n}\n.navmenu-fixed-right {\n right: 0;\n border-width: 0 0 0 1px;\n}\n\n.navmenu-nav {\n margin-bottom: @navmenu-margin-vertical;\n\n &.dropdown-menu {\n position: static;\n margin: 0;\n padding-top: 0;\n float: none;\n border: none;\n .box-shadow(none);\n border-radius: 0;\n }\n}\n\n.navbar-offcanvas {\n .navbar-nav {\n margin: 0;\n }\n\n @media (min-width: @grid-float-breakpoint) {\n width: auto;\n border-top: 0;\n box-shadow: none;\n\n &.offcanvas {\n position: static;\n display: block !important;\n height: auto !important;\n padding-bottom: 0; // Override default setting\n overflow: visible !important;\n }\n\n // Account for first and last children spacing\n .navbar-nav.navbar-left:first-child {\n margin-left: -@navbar-padding-horizontal;\n }\n .navbar-nav.navbar-right:last-child {\n margin-right: -@navbar-padding-horizontal;\n }\n\n .navmenu-brand {\n display: none;\n }\n }\n}\n\n// Brand/project name\n\n.navmenu-brand {\n display: block;\n font-size: @font-size-large;\n line-height: @line-height-computed;\n padding: @nav-link-padding;\n &:hover,\n &:focus {\n text-decoration: none;\n }\n margin: @navmenu-margin-vertical 0;\n}\n\n// Alternate navmenus\n// --------------------------------------------------\n\n// Default navmenu\n.navmenu-default,\n.navbar-default .navbar-offcanvas {\n background-color: @navmenu-default-bg;\n border-color: @navmenu-default-border;\n\n .navmenu-brand {\n color: @navmenu-default-brand-color;\n &:hover,\n &:focus {\n color: @navmenu-default-brand-hover-color;\n background-color: @navmenu-default-brand-hover-bg;\n }\n }\n\n .navmenu-text {\n color: @navmenu-default-color;\n }\n\n .navmenu-nav {\n // Caret should match text color on hover\n > .dropdown > a:hover .caret,\n > .dropdown > a:focus .caret {\n border-top-color: @navmenu-default-link-hover-color;\n border-bottom-color: @navmenu-default-link-hover-color;\n }\n\n // Remove background color from open dropdown\n > .open > a {\n &,\n &:hover,\n &:focus {\n background-color: @navmenu-default-link-active-bg;\n color: @navmenu-default-link-active-color;\n .caret {\n border-top-color: @navmenu-default-link-active-color;\n border-bottom-color: @navmenu-default-link-active-color;\n }\n }\n }\n > .dropdown > a .caret {\n border-top-color: @navmenu-default-link-color;\n border-bottom-color: @navmenu-default-link-color;\n }\n &.dropdown-menu {\n background-color: @navmenu-default-link-active-bg;\n & > .divider {\n background-color: @navmenu-default-bg;\n }\n > .active > a {\n &,\n &:hover,\n &:focus {\n background-color: darken(@navmenu-default-link-active-bg, 6.5%);\n }\n }\n }\n\n > li > a {\n color: @navmenu-default-link-color;\n &:hover,\n &:focus {\n color: @navmenu-default-link-hover-color;\n background-color: @navmenu-default-link-hover-bg;\n }\n }\n > .active > a {\n &,\n &:hover,\n &:focus {\n color: @navmenu-default-link-active-color;\n background-color: @navmenu-default-link-active-bg;\n }\n }\n > .disabled > a {\n &,\n &:hover,\n &:focus {\n color: @navmenu-default-link-disabled-color;\n background-color: @navmenu-default-link-disabled-bg;\n }\n }\n }\n}\n\n// Inverse navmenu\n.navmenu-inverse,\n.navbar-inverse .navbar-offcanvas {\n background-color: @navmenu-inverse-bg;\n border-color: @navmenu-inverse-border;\n\n .navmenu-brand {\n color: @navmenu-inverse-brand-color;\n &:hover,\n &:focus {\n color: @navmenu-inverse-brand-hover-color;\n background-color: @navmenu-inverse-brand-hover-bg;\n }\n }\n\n .navmenu-text {\n color: @navmenu-inverse-color;\n }\n\n .navmenu-nav {\n // Caret should match text color on hover\n > .dropdown > a:hover .caret,\n > .dropdown > a:focus .caret {\n border-top-color: @navmenu-inverse-link-hover-color;\n border-bottom-color: @navmenu-inverse-link-hover-color;\n }\n\n // Remove background color from open dropdown\n > .open > a {\n &,\n &:hover,\n &:focus {\n background-color: @navmenu-inverse-link-active-bg;\n color: @navmenu-inverse-link-active-color;\n .caret {\n border-top-color: @navmenu-inverse-link-active-color;\n border-bottom-color: @navmenu-inverse-link-active-color;\n }\n }\n }\n > .dropdown > a .caret {\n border-top-color: @navmenu-inverse-link-color;\n border-bottom-color: @navmenu-inverse-link-color;\n }\n &.dropdown-menu {\n background-color: @navmenu-inverse-link-active-bg;\n & > .divider {\n background-color: @navmenu-inverse-bg;\n }\n > .active > a {\n &,\n &:hover,\n &:focus {\n background-color: darken(@navmenu-inverse-link-active-bg, 6.5%);\n }\n }\n }\n\n > li > a {\n color: @navmenu-inverse-link-color;\n &:hover,\n &:focus {\n color: @navmenu-inverse-link-hover-color;\n background-color: @navmenu-inverse-link-hover-bg;\n }\n }\n > .active > a {\n &,\n &:hover,\n &:focus {\n color: @navmenu-inverse-link-active-color;\n background-color: @navmenu-inverse-link-active-bg;\n }\n }\n > .disabled > a {\n &,\n &:hover,\n &:focus {\n color: @navmenu-inverse-link-disabled-color;\n background-color: @navmenu-inverse-link-disabled-bg;\n }\n }\n }\n}\n","//\n// Mixins\n// --------------------------------------------------\n\n\n// Utilities\n// -------------------------\n\n// Clearfix\n// Source: http://nicolasgallagher.com/micro-clearfix-hack/\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.clearfix() {\n &:before,\n &:after {\n content: \" \"; /* 1 */\n display: table; /* 2 */\n }\n &:after {\n clear: both;\n }\n}\n\n// WebKit-style focus\n.tab-focus() {\n // Default\n outline: thin dotted #333;\n // WebKit\n outline: 5px auto -webkit-focus-ring-color;\n outline-offset: -2px;\n}\n\n// Center-align a block level element\n.center-block() {\n display: block;\n margin-left: auto;\n margin-right: auto;\n}\n\n// Sizing shortcuts\n.size(@width; @height) {\n width: @width;\n height: @height;\n}\n.square(@size) {\n .size(@size; @size);\n}\n\n// Placeholder text\n.placeholder(@color: @input-color-placeholder) {\n &:-moz-placeholder { color: @color; } // Firefox 4-18\n &::-moz-placeholder { color: @color; } // Firefox 19+\n &:-ms-input-placeholder { color: @color; } // Internet Explorer 10+\n &::-webkit-input-placeholder { color: @color; } // Safari and Chrome\n}\n\n// Text overflow\n// Requires inline-block or block for proper styling\n.text-overflow() {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n\n// CSS image replacement\n//\n// Heads up! v3 launched with with only `.hide-text()`, but per our pattern for\n// mixins being reused as classes with the same name, this doesn't hold up. As\n// of v3.0.1 we have added `.text-hide()` and deprecated `.hide-text()`. Note\n// that we cannot chain the mixins together in Less, so they are repeated.\n//\n// Source: https://github.com/h5bp/html5-boilerplate/commit/aa0396eae757\n\n// Deprecated as of v3.0.1 (will be removed in v4)\n.hide-text() {\n font: ~\"0/0\" a;\n color: transparent;\n text-shadow: none;\n background-color: transparent;\n border: 0;\n}\n// New mixin to use as of v3.0.1\n.text-hide() {\n font: ~\"0/0\" a;\n color: transparent;\n text-shadow: none;\n background-color: transparent;\n border: 0;\n}\n\n\n\n// CSS3 PROPERTIES\n// --------------------------------------------------\n\n// Single side border-radius\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// Drop shadows\n.box-shadow(@shadow) {\n -webkit-box-shadow: @shadow; // iOS <4.3 & Android <4.1\n box-shadow: @shadow;\n}\n\n// Transitions\n.transition(@transition) {\n -webkit-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-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// Transformations\n.rotate(@degrees) {\n -webkit-transform: rotate(@degrees);\n -ms-transform: rotate(@degrees); // IE9+\n transform: rotate(@degrees);\n}\n.scale(@ratio) {\n -webkit-transform: scale(@ratio);\n -ms-transform: scale(@ratio); // IE9+\n transform: scale(@ratio);\n}\n.translate(@x; @y) {\n -webkit-transform: translate(@x, @y);\n -ms-transform: translate(@x, @y); // IE9+\n transform: translate(@x, @y);\n}\n.skew(@x; @y) {\n -webkit-transform: skew(@x, @y);\n -ms-transform: skewX(@x) skewY(@y); // See https://github.com/twbs/bootstrap/issues/4885; IE9+\n transform: skew(@x, @y);\n}\n.translate3d(@x; @y; @z) {\n -webkit-transform: translate3d(@x, @y, @z);\n transform: translate3d(@x, @y, @z);\n}\n\n.rotateX(@degrees) {\n -webkit-transform: rotateX(@degrees);\n -ms-transform: rotateX(@degrees); // IE9+\n transform: rotateX(@degrees);\n}\n.rotateY(@degrees) {\n -webkit-transform: rotateY(@degrees);\n -ms-transform: rotateY(@degrees); // IE9+\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 transform-origin: @origin;\n}\n\n// Animations\n.animation(@animation) {\n -webkit-animation: @animation;\n animation: @animation;\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.backface-visibility(@visibility){\n -webkit-backface-visibility: @visibility;\n -moz-backface-visibility: @visibility;\n backface-visibility: @visibility;\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// User select\n// For selecting text on the page\n.user-select(@select) {\n -webkit-user-select: @select;\n -moz-user-select: @select;\n -ms-user-select: @select; // IE10+\n -o-user-select: @select;\n user-select: @select;\n}\n\n// Resize anything\n.resizable(@direction) {\n resize: @direction; // Options: horizontal, vertical, both\n overflow: auto; // Safari fix\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// Opacity\n.opacity(@opacity) {\n opacity: @opacity;\n // IE8 filter\n @opacity-ie: (@opacity * 100);\n filter: ~\"alpha(opacity=@{opacity-ie})\";\n}\n\n\n\n// GRADIENTS\n// --------------------------------------------------\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-gradient(linear, @start-percent top, @end-percent top, from(@start-color), to(@end-color)); // Safari 4+, Chrome 2+\n background-image: -webkit-linear-gradient(left, color-stop(@start-color @start-percent), color-stop(@end-color @end-percent)); // Safari 5.1+, Chrome 10+\n background-image: -moz-linear-gradient(left, @start-color @start-percent, @end-color @end-percent); // FF 3.6+\n background-image: linear-gradient(to right, @start-color @start-percent, @end-color @end-percent); // Standard, IE10\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-gradient(linear, left @start-percent, left @end-percent, from(@start-color), to(@end-color)); // Safari 4+, Chrome 2+\n background-image: -webkit-linear-gradient(top, @start-color @start-percent, @end-color @end-percent); // Safari 5.1+, Chrome 10+\n background-image: -moz-linear-gradient(top, @start-color @start-percent, @end-color @end-percent); // FF 3.6+\n background-image: linear-gradient(to bottom, @start-color @start-percent, @end-color @end-percent); // Standard, IE10\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+, Chrome 10+\n background-image: -moz-linear-gradient(@deg, @start-color, @end-color); // FF 3.6+\n background-image: linear-gradient(@deg, @start-color, @end-color); // Standard, IE10\n }\n .horizontal-three-colors(@start-color: #00b3ee; @mid-color: #7a43b6; @color-stop: 50%; @end-color: #c3325f) {\n background-image: -webkit-gradient(left, linear, 0 0, 0 100%, from(@start-color), color-stop(@color-stop, @mid-color), to(@end-color));\n background-image: -webkit-linear-gradient(left, @start-color, @mid-color @color-stop, @end-color);\n background-image: -moz-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-gradient(linear, 0 0, 0 100%, from(@start-color), color-stop(@color-stop, @mid-color), to(@end-color));\n background-image: -webkit-linear-gradient(@start-color, @mid-color @color-stop, @end-color);\n background-image: -moz-linear-gradient(top, @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-gradient(radial, center center, 0, center center, 460, from(@inner-color), to(@outer-color));\n background-image: -webkit-radial-gradient(circle, @inner-color, @outer-color);\n background-image: -moz-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-gradient(linear, 0 100%, 100% 0, color-stop(.25, @color), color-stop(.25, transparent), color-stop(.5, transparent), color-stop(.5, @color), color-stop(.75, @color), color-stop(.75, transparent), to(transparent));\n background-image: -webkit-linear-gradient(@angle, @color 25%, transparent 25%, transparent 50%, @color 50%, @color 75%, transparent 75%, transparent);\n background-image: -moz-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\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.reset-filter() {\n filter: e(%(\"progid:DXImageTransform.Microsoft.gradient(enabled = false)\"));\n}\n\n\n\n// Retina images\n//\n// Short retina mixin for setting background-image and -size\n\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\n// Responsive image\n//\n// Keep images from scaling beyond the width of their parents.\n\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// COMPONENT MIXINS\n// --------------------------------------------------\n\n// Horizontal dividers\n// -------------------------\n// Dividers (basically an hr) within dropdowns and nav lists\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\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 & > .dropdown .caret {\n border-color: @heading-text-color transparent;\n }\n }\n & > .panel-footer {\n + .panel-collapse .panel-body {\n border-bottom-color: @border;\n }\n }\n}\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// Tables\n// -------------------------\n.table-row-variant(@state; @background; @border) {\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 &.@{state}:hover > th {\n background-color: darken(@background, 5%);\n }\n }\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.button-variant(@color; @background; @border) {\n color: @color;\n background-color: @background;\n border-color: @border;\n\n &:hover,\n &:focus,\n &:active,\n &.active,\n .open .dropdown-toggle& {\n color: @color;\n background-color: darken(@background, 8%);\n border-color: darken(@border, 12%);\n }\n &:active,\n &.active,\n .open .dropdown-toggle& {\n background-image: none;\n }\n &.disabled,\n &[disabled],\n fieldset[disabled] & {\n &,\n &:hover,\n &:focus,\n &:active,\n &.active {\n background-color: @background;\n border-color: @border;\n }\n }\n}\n\n// Button sizes\n// -------------------------\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\n// Pagination\n// -------------------------\n.pagination-size(@padding-vertical; @padding-horizontal; @font-size; @border-radius) {\n > li {\n > a,\n > span {\n padding: @padding-vertical @padding-horizontal;\n font-size: @font-size;\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// Labels\n// -------------------------\n.label-variant(@color) {\n background-color: @color;\n &[href] {\n &:hover,\n &:focus {\n background-color: darken(@color, 10%);\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.navbar-vertical-align(@element-height) {\n margin-top: ((@navbar-height - @element-height) / 2);\n margin-bottom: ((@navbar-height - @element-height) / 2);\n}\n\n// Progress bars\n// -------------------------\n.progress-bar-variant(@color) {\n background-color: @color;\n .progress-striped & {\n #gradient > .striped();\n }\n}\n\n// Responsive utilities\n// -------------------------\n// More easily include all the states for responsive-utilities.less.\n.responsive-visibility() {\n display: block !important;\n tr& { display: table-row !important; }\n th&,\n td& { display: table-cell !important; }\n}\n\n.responsive-invisibility() {\n &,\n tr&,\n th&,\n td& { display: none !important; }\n}\n\n\n// Grid System\n// -----------\n\n// Centered container element\n.container-fixed() {\n margin-right: auto;\n margin-left: auto;\n padding-left: (@grid-gutter-width / 2);\n padding-right: (@grid-gutter-width / 2);\n .clearfix();\n}\n\n// Creates a wrapper for a series of columns\n.make-row(@gutter: @grid-gutter-width) {\n margin-left: (@gutter / -2);\n margin-right: (@gutter / -2);\n .clearfix();\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 // Prevent columns from collapsing when empty\n min-height: 1px;\n // Inner gutter via padding\n padding-left: (@gutter / 2);\n padding-right: (@gutter / 2);\n}\n\n// Generate the small columns\n.make-sm-column(@columns; @gutter: @grid-gutter-width) {\n position: relative;\n // Prevent columns from collapsing when empty\n min-height: 1px;\n // Inner gutter via padding\n padding-left: (@gutter / 2);\n padding-right: (@gutter / 2);\n\n // Calculate width based on number of columns available\n @media (min-width: @screen-sm-min) {\n float: left;\n width: percentage((@columns / @grid-columns));\n }\n}\n\n// Generate the small column offsets\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 // Prevent columns from collapsing when empty\n min-height: 1px;\n // Inner gutter via padding\n padding-left: (@gutter / 2);\n padding-right: (@gutter / 2);\n\n // Calculate width based on number of columns available\n @media (min-width: @screen-md-min) {\n float: left;\n width: percentage((@columns / @grid-columns));\n }\n}\n\n// Generate the medium column offsets\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) {\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 // Prevent columns from collapsing when empty\n min-height: 1px;\n // Inner gutter via padding\n padding-left: (@gutter / 2);\n padding-right: (@gutter / 2);\n\n // Calculate width based on number of columns available\n @media (min-width: @screen-lg-min) {\n float: left;\n width: percentage((@columns / @grid-columns));\n }\n}\n\n// Generate the large column offsets\n.make-lg-column-offset(@columns) {\n @media (min-width: @screen-lg-min) {\n margin-left: percentage((@columns / @grid-columns));\n }\n}\n.make-lg-column-push(@columns) {\n @media (min-width: @screen-lg-min) {\n left: percentage((@columns / @grid-columns));\n }\n}\n.make-lg-column-pull(@columns) {\n @media (min-width: @screen-lg-min) {\n right: percentage((@columns / @grid-columns));\n }\n}\n\n\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) when (@index = 1) { // initial\n @item: ~\".col-xs-@{index}, .col-sm-@{index}, .col-md-@{index}, .col-lg-@{index}\";\n .col(@index + 1, @item);\n }\n .col(@index, @list) when (@index =< @grid-columns) { // general; \"=<\" isn't a typo\n @item: ~\".col-xs-@{index}, .col-sm-@{index}, .col-md-@{index}, .col-lg-@{index}\";\n .col(@index + 1, ~\"@{list}, @{item}\");\n }\n .col(@index, @list) when (@index > @grid-columns) { // terminal\n @{list} {\n position: relative;\n // Prevent columns from collapsing when empty\n min-height: 1px;\n // Inner gutter via padding\n padding-left: (@grid-gutter-width / 2);\n padding-right: (@grid-gutter-width / 2);\n }\n }\n .col(1); // kickstart it\n}\n\n.make-grid-columns-float(@class) {\n .col(@index) when (@index = 1) { // 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(@index, @class, @type) when (@type = width) {\n .col-@{class}-@{index} {\n width: percentage((@index / @grid-columns));\n }\n}\n.calc-grid(@index, @class, @type) when (@type = push) {\n .col-@{class}-push-@{index} {\n left: percentage((@index / @grid-columns));\n }\n}\n.calc-grid(@index, @class, @type) when (@type = pull) {\n .col-@{class}-pull-@{index} {\n right: percentage((@index / @grid-columns));\n }\n}\n.calc-grid(@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.make-grid(@index, @class, @type) when (@index > 0) {\n .calc-grid(@index, @class, @type);\n // next iteration\n .make-grid(@index - 1, @class, @type);\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 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}\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-focus-border` 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\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. `'),this.$element.prepend(this.$hidden)),this.$preview=this.$element.find(".fileinput-preview");var d=this.$preview.css("height");"inline"!=this.$preview.css("display")&&"0px"!=d&&"none"!=d&&this.$preview.css("line-height",d),this.original={exists:this.$element.hasClass("fileinput-exists"),preview:this.$preview.html(),hiddenVal:this.$hidden.val()},this.listen()}};c.prototype.listen=function(){this.$input.on("change.bs.fileinput",a.proxy(this.change,this)),a(this.$input[0].form).on("reset.bs.fileinput",a.proxy(this.reset,this)),this.$element.find('[data-trigger="fileinput"]').on("click.bs.fileinput",a.proxy(this.trigger,this)),this.$element.find('[data-dismiss="fileinput"]').on("click.bs.fileinput",a.proxy(this.clear,this))},c.prototype.change=function(b){if(void 0===b.target.files&&(b.target.files=b.target&&b.target.value?[{name:b.target.value.replace(/^.+\\/,"")}]:[]),0!==b.target.files.length){this.$hidden.val(""),this.$hidden.attr("name",""),this.$input.attr("name",this.name);var c=b.target.files[0];if(this.$preview.length>0&&("undefined"!=typeof c.type?c.type.match("image.*"):c.name.match(/\.(gif|png|jpe?g)$/i))&&"undefined"!=typeof FileReader){var d=new FileReader,e=this.$preview,f=this.$element;d.onload=function(d){var g=a("");g[0].src=d.target.result,b.target.files[0].result=d.target.result,f.find(".fileinput-filename").text(c.name),"none"!=e.css("max-height")&&g.css("max-height",parseInt(e.css("max-height"),10)-parseInt(e.css("padding-top"),10)-parseInt(e.css("padding-bottom"),10)-parseInt(e.css("border-top"),10)-parseInt(e.css("border-bottom"),10)),e.html(g),f.addClass("fileinput-exists").removeClass("fileinput-new"),f.trigger("change.bs.fileinput",b.target.files)},d.readAsDataURL(c)}else this.$element.find(".fileinput-filename").text(c.name),this.$preview.text(c.name),this.$element.addClass("fileinput-exists").removeClass("fileinput-new"),this.$element.trigger("change.bs.fileinput")}},c.prototype.clear=function(a){if(a&&a.preventDefault(),this.$hidden.val(""),this.$hidden.attr("name",this.name),this.$input.attr("name",""),b){var c=this.$input.clone(!0);this.$input.after(c),this.$input.remove(),this.$input=c}else this.$input.val("");this.$preview.html(""),this.$element.find(".fileinput-filename").text(""),this.$element.addClass("fileinput-new").removeClass("fileinput-exists"),a!==!1&&(this.$input.trigger("change"),this.$element.trigger("clear.bs.fileinput"))},c.prototype.reset=function(){this.clear(!1),this.$hidden.val(this.original.hiddenVal),this.$preview.html(this.original.preview),this.$element.find(".fileinput-filename").text(""),this.original.exists?this.$element.addClass("fileinput-exists").removeClass("fileinput-new"):this.$element.addClass("fileinput-new").removeClass("fileinput-exists"),this.$element.trigger("reset.bs.fileinput")},c.prototype.trigger=function(a){this.$input.trigger("click"),a.preventDefault()};var d=a.fn.fileinput;a.fn.fileinput=function(b){return this.each(function(){var d=a(this),e=d.data("fileinput");e||d.data("fileinput",e=new c(this,b)),"string"==typeof b&&e[b]()})},a.fn.fileinput.Constructor=c,a.fn.fileinput.noConflict=function(){return a.fn.fileinput=d,this},a(document).on("click.fileinput.data-api",'[data-provides="fileinput"]',function(b){var c=a(this);if(!c.data("fileinput")){c.fileinput(c.data());var d=a(b.target).closest('[data-dismiss="fileinput"],[data-trigger="fileinput"]');d.length>0&&(b.preventDefault(),d.trigger("click.bs.fileinput"))}})}(window.jQuery); \ No newline at end of file +if("undefined"==typeof jQuery)throw new Error("Jasny Bootstrap's JavaScript requires jQuery");+function(a){"use strict";var b=function(c,d){this.$element=a(c),this.options=a.extend({},b.DEFAULTS,d),this.state=null,this.options.recalc&&(this.calcClone(),a(window).on("resize",a.proxy(this.recalc,this))),this.options.autohide&&a(document).on("click",a.proxy(this.autohide,this)),this.options.toggle&&this.toggle()};b.DEFAULTS={toggle:!0,placement:"left",autohide:!0,recalc:!0},b.prototype.offset=function(){switch(this.options.placement){case"left":case"right":return this.$element.outerWidth();case"top":case"bottom":return this.$element.outerHeight()}},b.prototype.calcPlacement=function(){function b(a,b){if("auto"===e.css(b))return a;if("auto"===e.css(a))return b;var c=parseInt(e.css(a),10),d=parseInt(e.css(b),10);return c>d?b:a}var c=a(window).width()/this.$element.width(),d=a(window).height()/this.$element.height();this.$element.hasClass("in")||this.$element.css("visiblity","hidden !important").addClass("in");var e=this.$element;this.options.placement=c>d?b("left","right"):b("top","bottom"),"hidden !important"===this.$element.css("visibility")&&this.$element.removeClass("in").css("visiblity","")},b.prototype.opposite=function(a){switch(a){case"top":return"bottom";case"left":return"right";case"bottom":return"top";case"right":return"left"}},b.prototype.getCanvasElements=function(){var b=this.options.canvas?a(this.options.canvas):this.$element,c=b.find("*").filter(function(){return"fixed"===a(this).css("position")}).not(this.options.exclude);return b.add(c)},b.prototype.slide=function(b,c,d){if(!a.support.transition){var e={};return e[this.options.placement]="+="+c,b.animate(e,350,d)}var f=this.options.placement,g=this.opposite(f);b.each(function(){"auto"!==a(this).css(f)&&a(this).css(f,(parseInt(a(this).css(f),10)||0)+c),"auto"!==a(this).css(g)&&a(this).css(g,(parseInt(a(this).css(g),10)||0)-c)}),this.$element.one(a.support.transition.end,d).emulateTransitionEnd(350)},b.prototype.disableScrolling=function(){var b=a("body").width(),c="padding-"+this.opposite(this.options.placement);if(void 0===a("body").data("offcanvas-style")&&a("body").data("offcanvas-style",a("body").attr("style")),a("body").css("overflow","hidden"),a("body").width()>b){var d=parseInt(a("body").css(c),10)+a("body").width()-b;setTimeout(function(){a("body").css(c,d)},1)}},b.prototype.show=function(){if(!this.state){var b=a.Event("show.bs.offcanvas");if(this.$element.trigger(b),!b.isDefaultPrevented()){"auto"===this.options.placement&&this.calcPlacement(),this.state="sliding";var c=this.getCanvasElements(),d=this.offset(),e=this.options.placement,f=this.opposite(e);c.addClass("canvas-sliding").each(function(){a(this).data("offcanvas-style",a(this).attr("style")||""),"static"===a(this).css("position")&&a(this).css("position","relative"),"auto"!==a(this).css(e)&&"0px"!==a(this).css(e)||"auto"!==a(this).css(f)&&"0px"!==a(this).css(f)||a(this).css(e,0)}),-1!==c.index(this.$element)&&this.$element.css(e,-1*d),this.disableScrolling();var g=function(){this.state="slid",c.removeClass("canvas-sliding").addClass("canvas-slid"),this.$element.trigger("shown.bs.offcanvas")};setTimeout(a.proxy(function(){this.$element.addClass("in"),this.slide(c,d,a.proxy(g,this))},this),1)}}},b.prototype.hide=function(){if("slid"===this.state){var b=a.Event("hide.bs.offcanvas");if(this.$element.trigger(b),!b.isDefaultPrevented()){this.state="sliding";var c=a(".canvas-slid"),d=-1*this.offset(),e=function(){this.state=null,this.$element.removeClass("in"),c.removeClass("canvas-sliding"),c.add("body").each(function(){a(this).attr("style",a(this).data("offcanvas-style")).removeData("offcanvas-style")}),this.$element.trigger("hidden.bs.offcanvas")};c.removeClass("canvas-slid").addClass("canvas-sliding"),setTimeout(a.proxy(function(){this.slide(c,d,a.proxy(e,this))},this),1)}}},b.prototype.toggle=function(){"sliding"!==this.state&&this["slid"===this.state?"hide":"show"]()},b.prototype.calcClone=function(){this.$calcClone=this.$element.clone().html("").addClass("offcanvas-clone").removeClass("in").appendTo(a("body"))},b.prototype.recalc=function(){if("slid"===this.state()&&"none"!==this.$calcClone.css("display")){var b=-1*this.offset(),c=this.options.placement;this.getCanvasElements().each(function(){a(this).css(c,(parseInt(a(this).css(c),10)||0)+b)}).removeClass("canvas-slid"),a("body").css("overflow",""),this.$element.css(c,"").removeClass("in canvas-slid")}},b.prototype.autohide=function(b){0===a(b.target).closest(this.$element).length&&this.hide()};var c=a.fn.offcanvas;a.fn.offcanvas=function(c){return this.each(function(){var d=a(this),e=d.data("bs.offcanvas"),f=a.extend({},b.DEFAULTS,d.data(),"object"==typeof c&&c);e||d.data("bs.offcanvas",e=new b(this,f)),"string"==typeof c&&e[c]()})},a.fn.offcanvas.Constructor=b,a.fn.offcanvas.noConflict=function(){return a.fn.offcanvas=c,this},a(document).on("click.bs.offcanvas.data-api","[data-toggle=offcanvas]",function(b){var c,d=a(this),e=d.attr("data-target")||b.preventDefault()||(c=d.attr("href"))&&c.replace(/.*(?=#[^\s]+$)/,""),f=a(e),g=f.data("bs.offcanvas"),h=g?"toggle":d.data();b.stopPropagation(),g?g.toggle():f.offcanvas(h)})}(window.jQuery),+function(a){"use strict";var b=function(c,d){this.$element=a(c),this.options=a.extend({},b.DEFAULTS,d),this.$element.on("click.bs.rowlink","td:not(.rowlink-skip)",a.proxy(this.click,this))};b.DEFAULTS={target:"a"},b.prototype.click=function(b){var c=a(b.currentTarget).closest("tr").find(this.options.target)[0];if(a(b.target)[0]!==c)if(b.preventDefault(),c.click)c.click();else if(document.createEvent){var d=document.createEvent("MouseEvents");d.initMouseEvent("click",!0,!0,window,0,0,0,0,0,!1,!1,!1,!1,0,null),c.dispatchEvent(d)}};var c=a.fn.rowlink;a.fn.rowlink=function(c){return this.each(function(){var d=a(this),e=d.data("rowlink");e||d.data("rowlink",e=new b(this,c))})},a.fn.rowlink.Constructor=b,a.fn.rowlink.noConflict=function(){return a.fn.rowlink=c,this},a(document).on("click.bs.rowlink.data-api",'[data-link="row"]',function(b){var c=a(this);c.data("rowlink")||(c.rowlink(c.data()),a(b.target).trigger("click.bs.rowlink"))})}(window.jQuery),+function(a){"use strict";var b=void 0!==window.orientation,c=navigator.userAgent.toLowerCase().indexOf("android")>-1,d="Microsoft Internet Explorer"==window.navigator.appName,e=function(b,d){c||(this.$element=a(b),this.options=a.extend({},e.DEFAULS,d),this.mask=String(this.options.mask),this.init(),this.listen(),this.checkVal())};e.DEFAULS={mask:"",placeholder:"_",definitions:{9:"[0-9]",a:"[A-Za-z]","?":"[A-Za-z0-9]","*":"."}},e.prototype.init=function(){var b=this.options.definitions,c=this.mask.length;this.tests=[],this.partialPosition=this.mask.length,this.firstNonMaskPos=null,a.each(this.mask.split(""),a.proxy(function(a,d){"?"==d?(c--,this.partialPosition=a):b[d]?(this.tests.push(new RegExp(b[d])),null===this.firstNonMaskPos&&(this.firstNonMaskPos=this.tests.length-1)):this.tests.push(null)},this)),this.buffer=a.map(this.mask.split(""),a.proxy(function(a){return"?"!=a?b[a]?this.options.placeholder:a:void 0},this)),this.focusText=this.$element.val(),this.$element.data("rawMaskFn",a.proxy(function(){return a.map(this.buffer,function(a,b){return this.tests[b]&&a!=this.options.placeholder?a:null}).join("")},this))},e.prototype.listen=function(){if(!this.$element.attr("readonly")){var b=(d?"paste":"input")+".mask";this.$element.on("unmask.bs.inputmask",a.proxy(this.unmask,this)).on("focus.bs.inputmask",a.proxy(this.focusEvent,this)).on("blur.bs.inputmask",a.proxy(this.blurEvent,this)).on("keydown.bs.inputmask",a.proxy(this.keydownEvent,this)).on("keypress.bs.inputmask",a.proxy(this.keypressEvent,this)).on(b,a.proxy(this.pasteEvent,this))}},e.prototype.caret=function(a,b){if(0!==this.$element.length){if("number"==typeof a)return b="number"==typeof b?b:a,this.$element.each(function(){if(this.setSelectionRange)this.setSelectionRange(a,b);else if(this.createTextRange){var c=this.createTextRange();c.collapse(!0),c.moveEnd("character",b),c.moveStart("character",a),c.select()}});if(this.$element[0].setSelectionRange)a=this.$element[0].selectionStart,b=this.$element[0].selectionEnd;else if(document.selection&&document.selection.createRange){var c=document.selection.createRange();a=0-c.duplicate().moveStart("character",-1e5),b=a+c.text.length}return{begin:a,end:b}}},e.prototype.seekNext=function(a){for(var b=this.mask.length;++a<=b&&!this.tests[a];);return a},e.prototype.seekPrev=function(a){for(;--a>=0&&!this.tests[a];);return a},e.prototype.shiftL=function(a,b){var c=this.mask.length;if(!(0>a)){for(var d=a,e=this.seekNext(b);c>d;d++)if(this.tests[d]){if(!(c>e&&this.tests[d].test(this.buffer[e])))break;this.buffer[d]=this.buffer[e],this.buffer[e]=this.options.placeholder,e=this.seekNext(e)}this.writeBuffer(),this.caret(Math.max(this.firstNonMaskPos,a))}},e.prototype.shiftR=function(a){for(var b=this.mask.length,c=a,d=this.options.placeholder;b>c;c++)if(this.tests[c]){var e=this.seekNext(c),f=this.buffer[c];if(this.buffer[c]=d,!(b>e&&this.tests[e].test(f)))break;d=f}},e.prototype.unmask=function(){this.$element.unbind(".mask").removeData("inputmask")},e.prototype.focusEvent=function(){this.focusText=this.$element.val();var a=this.mask.length,b=this.checkVal();this.writeBuffer();var c=this,d=function(){b==a?c.caret(0,b):c.caret(b)};d(),setTimeout(d,50)},e.prototype.blurEvent=function(){this.checkVal(),this.$element.val()!==this.focusText&&this.$element.trigger("change")},e.prototype.keydownEvent=function(a){var c=a.which;if(8==c||46==c||b&&127==c){var d=this.caret(),e=d.begin,f=d.end;return f-e===0&&(e=46!=c?this.seekPrev(e):f=this.seekNext(e-1),f=46==c?this.seekNext(f):f),this.clearBuffer(e,f),this.shiftL(e,f-1),!1}return 27==c?(this.$element.val(this.focusText),this.caret(0,this.checkVal()),!1):void 0},e.prototype.keypressEvent=function(a){var b=this.mask.length,c=a.which,d=this.caret();if(a.ctrlKey||a.altKey||a.metaKey||32>c)return!0;if(c){d.end-d.begin!==0&&(this.clearBuffer(d.begin,d.end),this.shiftL(d.begin,d.end-1));var e=this.seekNext(d.begin-1);if(b>e){var f=String.fromCharCode(c);if(this.tests[e].test(f)){this.shiftR(e),this.buffer[e]=f,this.writeBuffer();var g=this.seekNext(e);this.caret(g)}}return!1}},e.prototype.pasteEvent=function(){var a=this;setTimeout(function(){a.caret(a.checkVal(!0))},0)},e.prototype.clearBuffer=function(a,b){for(var c=this.mask.length,d=a;b>d&&c>d;d++)this.tests[d]&&(this.buffer[d]=this.options.placeholder)},e.prototype.writeBuffer=function(){return this.$element.val(this.buffer.join("")).val()},e.prototype.checkVal=function(a){for(var b=this.mask.length,c=this.$element.val(),d=-1,e=0,f=0;b>e;e++)if(this.tests[e]){for(this.buffer[e]=this.options.placeholder;f++c.length)break}else this.buffer[e]==c.charAt(f)&&e!=this.partialPosition&&(f++,d=e);return!a&&d+1=this.partialPosition)&&(this.writeBuffer(),a||this.$element.val(this.$element.val().substring(0,d+1))),this.partialPosition?e:this.firstNonMaskPos};var f=a.fn.inputmask;a.fn.inputmask=function(b){return this.each(function(){var c=a(this),d=c.data("inputmask");d||c.data("inputmask",d=new e(this,b))})},a.fn.inputmask.Constructor=e,a.fn.inputmask.noConflict=function(){return a.fn.inputmask=f,this},a(document).on("focus.bs.inputmask.data-api","[data-mask]",function(){var b=a(this);b.data("inputmask")||b.inputmask(b.data())})}(window.jQuery),+function(a){"use strict";var b="Microsoft Internet Explorer"==window.navigator.appName,c=function(b,c){if(this.$element=a(b),this.$input=this.$element.find(":file"),0!==this.$input.length){this.name=this.$input.attr("name")||c.name,this.$hidden=this.$element.find('input[type=hidden][name="'+this.name+'"]'),0===this.$hidden.length&&(this.$hidden=a(''),this.$element.prepend(this.$hidden)),this.$preview=this.$element.find(".fileinput-preview");var d=this.$preview.css("height");"inline"!=this.$preview.css("display")&&"0px"!=d&&"none"!=d&&this.$preview.css("line-height",d),this.original={exists:this.$element.hasClass("fileinput-exists"),preview:this.$preview.html(),hiddenVal:this.$hidden.val()},this.listen()}};c.prototype.listen=function(){this.$input.on("change.bs.fileinput",a.proxy(this.change,this)),a(this.$input[0].form).on("reset.bs.fileinput",a.proxy(this.reset,this)),this.$element.find('[data-trigger="fileinput"]').on("click.bs.fileinput",a.proxy(this.trigger,this)),this.$element.find('[data-dismiss="fileinput"]').on("click.bs.fileinput",a.proxy(this.clear,this))},c.prototype.change=function(b){if(void 0===b.target.files&&(b.target.files=b.target&&b.target.value?[{name:b.target.value.replace(/^.+\\/,"")}]:[]),0!==b.target.files.length){this.$hidden.val(""),this.$hidden.attr("name",""),this.$input.attr("name",this.name);var c=b.target.files[0];if(this.$preview.length>0&&("undefined"!=typeof c.type?c.type.match("image.*"):c.name.match(/\.(gif|png|jpe?g)$/i))&&"undefined"!=typeof FileReader){var d=new FileReader,e=this.$preview,f=this.$element;d.onload=function(d){var g=a("");g[0].src=d.target.result,b.target.files[0].result=d.target.result,f.find(".fileinput-filename").text(c.name),"none"!=e.css("max-height")&&g.css("max-height",parseInt(e.css("max-height"),10)-parseInt(e.css("padding-top"),10)-parseInt(e.css("padding-bottom"),10)-parseInt(e.css("border-top"),10)-parseInt(e.css("border-bottom"),10)),e.html(g),f.addClass("fileinput-exists").removeClass("fileinput-new"),f.trigger("change.bs.fileinput",b.target.files)},d.readAsDataURL(c)}else this.$element.find(".fileinput-filename").text(c.name),this.$preview.text(c.name),this.$element.addClass("fileinput-exists").removeClass("fileinput-new"),this.$element.trigger("change.bs.fileinput")}},c.prototype.clear=function(a){if(a&&a.preventDefault(),this.$hidden.val(""),this.$hidden.attr("name",this.name),this.$input.attr("name",""),b){var c=this.$input.clone(!0);this.$input.after(c),this.$input.remove(),this.$input=c}else this.$input.val("");this.$preview.html(""),this.$element.find(".fileinput-filename").text(""),this.$element.addClass("fileinput-new").removeClass("fileinput-exists"),a!==!1&&(this.$input.trigger("change"),this.$element.trigger("clear.bs.fileinput"))},c.prototype.reset=function(){this.clear(!1),this.$hidden.val(this.original.hiddenVal),this.$preview.html(this.original.preview),this.$element.find(".fileinput-filename").text(""),this.original.exists?this.$element.addClass("fileinput-exists").removeClass("fileinput-new"):this.$element.addClass("fileinput-new").removeClass("fileinput-exists"),this.$element.trigger("reset.bs.fileinput")},c.prototype.trigger=function(a){this.$input.trigger("click"),a.preventDefault()};var d=a.fn.fileinput;a.fn.fileinput=function(b){return this.each(function(){var d=a(this),e=d.data("fileinput");e||d.data("fileinput",e=new c(this,b)),"string"==typeof b&&e[b]()})},a.fn.fileinput.Constructor=c,a.fn.fileinput.noConflict=function(){return a.fn.fileinput=d,this},a(document).on("click.fileinput.data-api",'[data-provides="fileinput"]',function(b){var c=a(this);if(!c.data("fileinput")){c.fileinput(c.data());var d=a(b.target).closest('[data-dismiss="fileinput"],[data-trigger="fileinput"]');d.length>0&&(b.preventDefault(),d.trigger("click.bs.fileinput"))}})}(window.jQuery); \ No newline at end of file diff --git a/examples/navmenu-push/index.html b/examples/navmenu-push/index.html index 5d205aa4..56c8a28f 100644 --- a/examples/navmenu-push/index.html +++ b/examples/navmenu-push/index.html @@ -72,6 +72,6 @@ - + diff --git a/getting-started/index.html b/getting-started/index.html index 3e7c9f99..c12ed5d7 100644 --- a/getting-started/index.html +++ b/getting-started/index.html @@ -324,7 +324,7 @@ Copy any changes made here over to the README too. --> -

    Navmenu

    +

    Off canvas navbar

    A template using offcanvas for mobile view of the navbar.

    @@ -449,7 +449,6 @@ Copy any changes made here over to the README too. -->
  • Tab alignments are still supported in this fork (while dropped in Twitter Bootstrap).
  • Typeahead has been dropped, in favor of using Selectize.js.
  • Iconic icons are still available from P.J. Onori.
  • -
  • Customize no longer generates a 'custom.json' file.
  • For more information on upgrading to v3.0, and code snippets from the community, see Bootply.

    diff --git a/javascript/index.html b/javascript/index.html index cef5b58b..6f149142 100644 --- a/javascript/index.html +++ b/javascript/index.html @@ -560,7 +560,7 @@
    -
    +
    Select fileChange Remove
    @@ -568,7 +568,7 @@
    <div class="fileinput fileinput-new" data-provides="fileinput">
       <div class="input-group">
    -    <div class="form-control uneditable-input span3" data-trigger="fileinput"><i class="glyphicon glyphicon-file fileinput-exists"></i> <span class="fileinput-filename"></span></div>
    +    <div class="form-control" data-trigger="fileinput"><i class="glyphicon glyphicon-file fileinput-exists"></i> <span class="fileinput-filename"></span></div>
         <span class="input-group-addon btn btn-default btn-file"><span class="fileinput-new">Select file</span><span class="fileinput-exists">Change</span><input type="file" name="..."></span>
         <a href="#" class="input-group-addon btn btn-default fileinput-exists" data-dismiss="fileinput">Remove</a>
       </div>